Skip to content

Commit

Permalink
Temp.
Browse files Browse the repository at this point in the history
  • Loading branch information
mithro committed Dec 31, 2023
1 parent 895a7e2 commit 17ffcae
Show file tree
Hide file tree
Showing 19 changed files with 1,360 additions and 0 deletions.
Empty file added benchmarks/basic/BUILD
Empty file.
202 changes: 202 additions & 0 deletions benchmarks/basic/add/BUILD
Original file line number Diff line number Diff line change
@@ -0,0 +1,202 @@
# 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.

""" Benchmark for add """

load("@bazel_skylib//rules:build_test.bzl", "build_test")
load("@rules_hdl//dependency_support/com_google_skywater_pdk:cells_info.bzl", "for_each_sky130_cells")
load("@rules_hdl//dependency_support/org_theopenroadproject_asap7_pdk_r1p7:cells_info.bzl", "for_each_asap7_cells")
load("//flows:basic_asic.bzl", "basic_asic_flow")
load("//verilog:providers.bzl", "verilog_library")

verilog_library(
name = "rtl",
srcs = [
"top_add.sv",
"mod_add.sv",
],
)

build_test(
name = "rtl_build_test",
targets = [
":rtl",
],
)

# Run for add on asap7 with sc7p5t_rev27
[
basic_asic_flow(
name = cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "asap7.sdc",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 400,
die_width_microns = 400,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_asap7_cells("sc7p5t_rev27")
]

# Run for add on asap7 with sc7p5t_rev27 using straight placement.
[
basic_asic_flow(
name = "straight-"+cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "asap7.sdc",
manual_placement_script = "place.straight.tcl",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 400,
die_width_microns = 400,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_asap7_cells("sc7p5t_rev27")
]

# Run for add on asap7 with sc7p5t_rev27 using loopback placement.
[
basic_asic_flow(
name = "loopback-"+cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "asap7.sdc",
manual_placement_script = "place.loopback.tcl",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 400,
die_width_microns = 400,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_asap7_cells("sc7p5t_rev27")
]

# Run for add on asap7 with sc7p5t_rev27 using diagonal placement.
[
basic_asic_flow(
name = "diagonal-"+cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "asap7.sdc",
manual_placement_script = "place.diagonal.tcl",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 400,
die_width_microns = 400,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_asap7_cells("sc7p5t_rev27")
]

# Run for add on sky130 with sc_hd
[
basic_asic_flow(
name = cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "sky130.sdc",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 200,
die_width_microns = 100,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_sky130_cells("sc_hd")
]

# Run for add on sky130 with sc_hd using straight placement.
[
basic_asic_flow(
name = "straight-"+cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "sky130.sdc",
manual_placement_script = "place.straight.tcl",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 200,
die_width_microns = 100,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_sky130_cells("sc_hd")
]

# Run for add on sky130 with sc_hd using loopback placement.
[
basic_asic_flow(
name = "loopback-"+cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "sky130.sdc",
manual_placement_script = "place.loopback.tcl",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 200,
die_width_microns = 100,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_sky130_cells("sc_hd")
]

# Run for add on sky130 with sc_hd using diagonal placement.
[
basic_asic_flow(
name = "diagonal-"+cell_name,
cells = cell_target,
extra_args = dict(
place_and_route = dict(
sdc = "sky130.sdc",
manual_placement_script = "place.diagonal.tcl",
skip_detailed_routing = False,
core_padding_microns = 2,
die_height_microns = 200,
die_width_microns = 100,
),
),
target = ":rtl",
top = "add",
)
for cell_name, cell_target in for_each_sky130_cells("sc_hd")
]
1 change: 1 addition & 0 deletions benchmarks/basic/add/asap7.sdc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
set clk_port_name "clk"
8 changes: 8 additions & 0 deletions benchmarks/basic/add/mod_add.sv
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
module mod_add(
input wire [7:0] a,
input wire [7:0] b,
output wire [7:0] x
);

assign x = a + b;
endmodule
6 changes: 6 additions & 0 deletions benchmarks/basic/add/sky130.sdc
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
set clk_port_name "clk"
set clk_period 10
set clk_half_period [format "%.5f" [expr {$clk_period / 2.0}]]

create_clock -name clk -period $clk_period -waveform "0 $clk_half_period" \
[get_ports -quiet $clk_port_name]
36 changes: 36 additions & 0 deletions benchmarks/basic/add/top_add.sv
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
// 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.
module top_add (
input wire clk,
input wire [7:0] a,
input wire [7:0] b,
output reg [7:0] x
);

reg [7:0] a_;
reg [7:0] b_;
wire [7:0] i_;

always_ff @ (posedge clk)
a_ <= a;

always_ff @ (posedge clk)
b_ <= b;

always_ff @ (posedge clk)
x <= i_;

mod_add mod (.a(a_), .b(b_), .x(i_));

endmodule
Loading

0 comments on commit 17ffcae

Please sign in to comment.