blob: ed9ca278d9b00dc755f638d0011c32f08d519bd3 [file] [log] [blame]
// Copyright (C) 2023 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
package {
default_applicable_licenses: ["Android-Apache-2.0"],
}
cc_library_headers {
name: "libberberis_interpreter_riscv64_headers",
defaults: ["berberis_defaults"],
host_supported: true,
export_include_dirs: ["include"],
}
cc_library_static {
name: "libberberis_interpreter_riscv64",
defaults: ["berberis_defaults_64"],
host_supported: true,
cflags: ["-DBERBERIS_RISCV64_INTERPRETER_SEPARATE_INSTANTIATION_OF_VECTOR_OPERATIONS"],
header_libs: [
"libberberis_base_headers",
"libberberis_decoder_riscv64_headers",
"libberberis_guest_state_riscv64_headers",
"libberberis_interpreter_riscv64_headers",
"libberberis_intrinsics_riscv64_headers",
"libberberis_kernel_api_headers",
"libberberis_runtime_primitives_headers",
],
export_header_lib_headers: ["libberberis_interpreter_riscv64_headers"],
arch: {
x86_64: {
cflags: ["-mssse3"],
srcs: ["riscv64/faulty_memory_accesses_x86_64.cc"],
},
},
srcs: [
"riscv64/interpreter-main.cc",
"riscv64/interpreter-VLoadIndexedArgs.cc",
"riscv64/interpreter-VLoadStrideArgs.cc",
"riscv64/interpreter-VLoadUnitStrideArgs.cc",
"riscv64/interpreter-VOpFVfArgs.cc",
"riscv64/interpreter-VOpFVvArgs.cc",
"riscv64/interpreter-VOpIViArgs.cc",
"riscv64/interpreter-VOpIVvArgs.cc",
"riscv64/interpreter-VOpIVxArgs.cc",
"riscv64/interpreter-VOpMVvArgs.cc",
"riscv64/interpreter-VOpMVxArgs.cc",
"riscv64/interpreter-VStoreIndexedArgs.cc",
"riscv64/interpreter-VStoreStrideArgs.cc",
"riscv64/interpreter-VStoreUnitStrideArgs.cc",
],
}
cc_test_library {
name: "libberberis_interpreter_riscv64_unit_tests",
defaults: ["berberis_test_library_defaults_64"],
srcs: [
"riscv64/faulty_memory_accesses_test.cc",
"riscv64/interpreter_test.cc",
],
header_libs: [
"berberis_test_utils_headers",
"libberberis_base_headers",
"libberberis_guest_state_riscv64_headers",
"libberberis_interpreter_riscv64_headers",
"libberberis_intrinsics_riscv64_headers",
"libberberis_kernel_api_headers",
],
}