// 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_guest_os_primitives_headers", "libberberis_interpreter_riscv64_headers", "libberberis_intrinsics_riscv64_headers", "libberberis_kernel_api_headers", ], }