| # Copyright 2023 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. |
| |
| load("@io_bazel_rules_scala//scala:scala.bzl", "scala_binary", "scala_library") |
| load("@rules_hdl//verilog:providers.bzl", "VerilogInfo", "verilog_library") |
| load("@kelvin_hw//rules:verilator.bzl", "verilator_cc_library") |
| |
| def chisel_library( |
| name, |
| srcs = [], |
| deps = [], |
| visibility = None): |
| scala_library( |
| name = name, |
| srcs = srcs, |
| deps = [ |
| "@kelvin_hw//lib:chisel_lib", |
| "@edu_berkeley_cs_chisel3_plugin//jar", |
| ] + deps, |
| scalacopts = [ |
| "-Xplugin:$(execpath @edu_berkeley_cs_chisel3_plugin//jar)", |
| "-P:chiselplugin:genBundleElements", |
| ], |
| visibility = visibility, |
| ) |
| |
| def chisel_binary( |
| name, |
| main_class, |
| srcs = [], |
| deps = [], |
| visibility = None): |
| scala_binary( |
| name = name, |
| srcs = srcs, |
| main_class = main_class, |
| deps = [ |
| "@kelvin_hw//lib:chisel_lib", |
| "@edu_berkeley_cs_chisel3_plugin//jar", |
| ] + deps, |
| scalacopts = [ |
| "-Xplugin:$(execpath @edu_berkeley_cs_chisel3_plugin//jar)", |
| "-P:chiselplugin:genBundleElements", |
| ], |
| visibility = visibility, |
| ) |
| |
| def chisel_cc_library( |
| name, |
| chisel_lib, |
| emit_class, |
| module_name, |
| verilog_deps = []): |
| gen_binary_name = name + "_emit_verilog_binary" |
| chisel_binary( |
| name = gen_binary_name, |
| deps = [chisel_lib], |
| main_class = emit_class, |
| ) |
| |
| native.genrule( |
| name = name + "_emit_verilog", |
| srcs = [], |
| outs = [module_name + ".v"], |
| cmd = "./$(location " + gen_binary_name + ") --target-dir $(RULEDIR)", |
| tools = [":{}".format(gen_binary_name)], |
| ) |
| |
| verilog_library( |
| name = name + "_verilog", |
| srcs = [module_name + ".v"], |
| deps = verilog_deps, |
| ) |
| |
| verilator_cc_library( |
| name = name, |
| module = ":{}_verilog".format(name), |
| module_top = module_name, |
| visibility = ["//visibility:public"], |
| # TODO(derekjchow): Re-enable the default -Wall? |
| vopts = [], |
| ) |