blob: 469e7da1cdf74ae4982cedc398b139412e59b5e7 [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_all_hosts_defaults"],
host_supported: true,
export_include_dirs: ["include"],
}
cc_library_static {
name: "libberberis_interpreter_riscv64",
defaults: [
"berberis_all_hosts_defaults_64",
"berberis_memory_region_reservation_defaults",
],
host_supported: true,
header_libs: [
"libberberis_base_headers",
"libberberis_decoder_riscv64_headers",
"libberberis_guest_state_riscv64_headers",
"libberberis_interpreter_riscv64_headers",
"libberberis_kernel_api_headers",
"libberberis_runtime_primitives_headers",
"libberberis_intrinsics_riscv64_headers",
],
export_header_lib_headers: ["libberberis_interpreter_riscv64_headers"],
arch: {
x86_64: {
cflags: [
"-DBERBERIS_RISCV64_INTERPRETER_SEPARATE_INSTANTIATION_OF_VECTOR_OPERATIONS",
"-mssse3",
],
srcs: [
"riscv64/faulty_memory_accesses_x86_64.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",
],
},
arm64: {
srcs: [
"riscv64/faulty_memory_accesses_arm64.cc",
],
},
},
srcs: [
"riscv64/interpreter-main.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_guest_os_primitives_headers",
"libberberis_interpreter_riscv64_headers",
"libberberis_intrinsics_riscv64_headers",
"libberberis_kernel_api_headers",
],
}
cc_test {
name: "berberis_interpreter_riscv64_to_arm64_insn_tests_static",
defaults: ["berberis_all_hosts_defaults_64"],
static_libs: [
"libbase",
"libberberis_base",
"libberberis_interpreter_riscv64",
"libberberis_kernel_api_riscv64",
"liblog",
"libberberis_intrinsics_riscv64",
],
srcs: [
"riscv64/faulty_memory_accesses_test.cc",
"riscv64/interpreter_arm64_test.cc",
],
header_libs: [
"libberberis_base_headers",
"libberberis_guest_state_riscv64_headers",
"libberberis_interpreter_riscv64_headers",
"libberberis_runtime_primitives_headers",
],
arch: {
x86_64: {
enabled: false,
},
},
static_executable: true,
host_supported: false,
}