blob: 9baaac897b11762fb104816ed2ff825de35a9267 [file]
# 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
#
# 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.
# This package provides libraries to make it easy to integrate mpact_sim
# based simulators with ReNode, a system modeling framework:
# https://renode.io
load("@rules_cc//cc:cc_library.bzl", "cc_library")
package(
default_applicable_licenses = ["//:license"],
default_visibility = ["//visibility:public"],
)
cc_library(
name = "renode",
srcs = [
"renode_memory_access.cc",
"renode_mpact.cc",
],
hdrs = [
"renode_memory_access.h",
"renode_mpact.h",
],
deps = [
":renode_debug_interface",
"//mpact/sim/generic:core",
"//mpact/sim/generic:core_debug_interface",
"//mpact/sim/generic:instruction",
"//mpact/sim/generic:type_helpers",
"//mpact/sim/util/memory",
"@abseil-cpp//absl/container:flat_hash_map",
"@abseil-cpp//absl/functional:any_invocable",
"@abseil-cpp//absl/log",
"@abseil-cpp//absl/status",
"@abseil-cpp//absl/status:statusor",
"@abseil-cpp//absl/strings",
],
alwayslink = 1,
)
cc_library(
name = "renode_debug_interface",
hdrs = [
"renode_debug_interface.h",
],
deps = [
"//mpact/sim/generic:core_debug_interface",
"//mpact/sim/generic:type_helpers",
"@abseil-cpp//absl/status",
"@abseil-cpp//absl/status:statusor",
],
)
cc_library(
name = "socket_cli",
srcs = [
"cli_forwarder.cc",
"renode_cli_top.cc",
"socket_cli.cc",
],
hdrs = [
"cli_forwarder.h",
"renode_cli_top.h",
"socket_cli.h",
"socket_streambuf.h",
],
deps = [
":renode_debug_interface",
"//mpact/sim/generic:core",
"//mpact/sim/generic:core_debug_interface",
"//mpact/sim/generic:debug_command_shell_interface",
"//mpact/sim/generic:instruction",
"//mpact/sim/generic:type_helpers",
"//mpact/sim/util/program_loader:elf_loader",
"@abseil-cpp//absl/functional:any_invocable",
"@abseil-cpp//absl/log",
"@abseil-cpp//absl/log:check",
"@abseil-cpp//absl/status",
"@abseil-cpp//absl/status:statusor",
"@abseil-cpp//absl/synchronization",
],
)