// 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, }