| # Copyright 2024 Google LLC |
| # |
| # 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 |
| # |
| # https://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. |
| |
| # Convenient memory interface and implementation classes. |
| |
| load("@rules_cc//cc:cc_library.bzl", "cc_library") |
| |
| package( |
| default_applicable_licenses = ["//:license"], |
| default_visibility = ["//visibility:public"], |
| ) |
| |
| cc_library( |
| name = "memory", |
| srcs = [ |
| "atomic_memory.cc", |
| "atomic_tagged_memory.cc", |
| "flat_demand_memory.cc", |
| "flat_memory.cc", |
| "memory_router.cc", |
| "memory_use_profiler.cc", |
| "memory_watcher.cc", |
| "single_initiator_router.cc", |
| "tagged_flat_demand_memory.cc", |
| "tagged_memory_watcher.cc", |
| "tagged_to_untagged_memory_transactor.cc", |
| ], |
| hdrs = [ |
| "atomic_memory.h", |
| "atomic_tagged_memory.h", |
| "flat_demand_memory.h", |
| "flat_memory.h", |
| "memory_interface.h", |
| "memory_router.h", |
| "memory_use_profiler.h", |
| "memory_watcher.h", |
| "single_initiator_router.h", |
| "tagged_flat_demand_memory.h", |
| "tagged_memory_interface.h", |
| "tagged_memory_watcher.h", |
| "tagged_to_untagged_memory_transactor.h", |
| ], |
| copts = ["-O3"], |
| deps = [ |
| "//mpact/sim/generic:core", |
| "//mpact/sim/generic:instruction", |
| "@abseil-cpp//absl/base:core_headers", |
| "@abseil-cpp//absl/container:btree", |
| "@abseil-cpp//absl/container:flat_hash_map", |
| "@abseil-cpp//absl/container:flat_hash_set", |
| "@abseil-cpp//absl/functional:any_invocable", |
| "@abseil-cpp//absl/log", |
| "@abseil-cpp//absl/numeric:bits", |
| "@abseil-cpp//absl/status", |
| "@abseil-cpp//absl/strings", |
| "@abseil-cpp//absl/strings:str_format", |
| ], |
| ) |
| |
| cc_library( |
| name = "cache", |
| srcs = [ |
| "cache.cc", |
| ], |
| hdrs = [ |
| "cache.h", |
| ], |
| copts = ["-O3"], |
| deps = [ |
| ":memory", |
| "//mpact/sim/generic:component", |
| "//mpact/sim/generic:core", |
| "//mpact/sim/generic:counters", |
| "//mpact/sim/generic:instruction", |
| "@abseil-cpp//absl/container:btree", |
| "@abseil-cpp//absl/functional:bind_front", |
| "@abseil-cpp//absl/log", |
| "@abseil-cpp//absl/log:check", |
| "@abseil-cpp//absl/numeric:bits", |
| "@abseil-cpp//absl/status", |
| "@abseil-cpp//absl/strings", |
| ], |
| ) |