Skip to content

Commit

Permalink
Chipyard compatibility (#707)
Browse files Browse the repository at this point in the history
* e2e sky130 fixes

* sky130, cache dir fixes

* new tool versions & paths, make vendor common defaults part of core config for now

* openroad fixes
  • Loading branch information
harrisonliew authored Feb 9, 2023
1 parent cbc1414 commit 5d3c606
Show file tree
Hide file tree
Showing 12 changed files with 42 additions and 35 deletions.
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -25,3 +25,7 @@ dist/
/DVEfiles
/opendatabase.log

# e2e outputs
e2e/obj_dir
e2e/build*
e2e/output.json
4 changes: 0 additions & 4 deletions doc/Technology/Tech-json.rst
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,6 @@ The user may supply the PDK to Hammer as an already extracted directory and/or a
{
"id": "$STDCELLS",
"path": "technology.asap7.stdcell_install_dir"
},
{
"path": "tech-asap7-cache",
"base var": ""
}
],
"tarballs": [
Expand Down
4 changes: 1 addition & 3 deletions e2e/configs/sky130-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,4 @@ vlsi.core.sim_tool: "hammer.sim.vcs"
vlsi.core.power_tool: "hammer.power.voltus"

# SRAM Compiler compiler options
vlsi.core.sram_generator_tool: "sram_compiler"
vlsi.core.sram_generator_tool_path: ["hammer/src/hammer-vlsi/technology/sky130"]
vlsi.core.sram_generator_tool_path_meta: "append"
vlsi.core.sram_generator_tool: "hammer.technology.sky130.sram_compiler"
2 changes: 1 addition & 1 deletion e2e/pdks/asap7-a.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ synthesis.genus.version: "211"
par.innovus.version: "211"

sim.vcs.version: "S-2021.09-SP1-1"
sim.vcs.verdi_home: "/ecad/tools/synopsys/verdi/S-2021.09-SP1-1"
sim.vcs.verdi_home: "/ecad/tools/synopsys/verdi/${sim.vcs.version}"
sim.vcs.verdi_home_meta: lazysubst

lvs.calibre.version: "2022.2_24.16"
Expand Down
8 changes: 4 additions & 4 deletions e2e/pdks/asap7-bwrc.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ technology.asap7.pdk_install_dir: "/tools/B/asap7/asap7PDK_r1p7"
technology.asap7.stdcell_install_dir: "/tools/B/asap7/asap7sc7p5t_27"
technology.asap7.tarball_dir: "/tools/B/asap7/"

synthesis.genus.version: "201"
par.innovus.version: "191_ISR3"
synthesis.genus.version: "211"
par.innovus.version: "211"

sim.vcs.version: "P-2019.06-SP2-5"
sim.vcs.verdi_home: "/tools/synopsys/verdi/P-2019.06-SP2-12"
sim.vcs.version: "S-2021.09-SP1-1"
sim.vcs.verdi_home: "/tools/synopsys/verdi/${sim.vcs.version}"
sim.vcs.verdi_home_meta: lazysubst
15 changes: 11 additions & 4 deletions e2e/pdks/sky130-bwrc.yml
Original file line number Diff line number Diff line change
@@ -1,10 +1,17 @@
vlsi.core.technology: "hammer.technology.sky130"
technology.sky130:
sky130A: "/tools/commercial/skywater/local/sky130A"
openram_lib: "/tools/commercial/skywater/local/sky130_sram_macros"
sky130_nda: "/tools/commercial/skywater/swtech130/skywater-src-nda-20221031"

synthesis.genus.version: "201"
par.innovus.version: "191_ISR3"
synthesis.genus.version: "211"
par.innovus.version: "211"

sim.vcs.version: "P-2019.06-SP2-5"
sim.vcs.verdi_home: "/tools/synopsys/verdi/P-2019.06-SP2-12"
sim.vcs.version: "S-2021.09-SP1-1"
sim.vcs.verdi_home: "/tools/synopsys/verdi/${sim.vcs.version}"
sim.vcs.verdi_home_meta: lazysubst

synthesis.yosys.yosys_bin: "/users/nayiri/conda/envs/yosys/bin/yosys"
par.openroad.openroad_bin: "/users/nayiri/conda/envs/openroad/bin/openroad"
drc.magic.magic_bin: "/tools/C/nayiri/installs/bin/magic"
lvs.netgen.netgen_bin: "/tools/B/nayiri/installs/netgen/bin/netgen"
4 changes: 2 additions & 2 deletions hammer/par/openroad/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ def do_between_steps(self, prev: HammerToolStep, next: HammerToolStep) -> bool:
# Write a checkpoint to disk.
self.verbose_append("write_db pre_{step}".format(step=next.name))
# Symlink the database to latest for open_chip script later.
self.append("ln -sfn pre_{step} latest".format(step=next.name))
self.append("exec ln -sfn pre_{step} latest".format(step=next.name))
self._step_transitions = self._step_transitions + [(prev.name, next.name)]
return True

Expand All @@ -129,7 +129,7 @@ def do_post_steps(self) -> bool:
last = "post_{step}".format(step=self._step_transitions[-1][1])
self.verbose_append("write_db {last}".format(last=last))
# Symlink the database to latest for open_chip script later.
self.verbose_append("ln -sfn {last} latest".format(last=last))
self.verbose_append("exec ln -sfn {last} latest".format(last=last))

return self.run_openroad()

Expand Down
4 changes: 2 additions & 2 deletions hammer/par/openroad/defaults_types.yml
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ par.openroad:

# Optional: OpenRCX RC tech file
# Should be set in technology plugin
openrcx_techfile: Optional[list[str]]
openrcx_techfile: Optional[str]

# Optional: KLayout tech file
# Should be set in technology plugin
klayout_techfile_source: Optional[str]
klayout_techfile_source: Optional[str]
3 changes: 1 addition & 2 deletions hammer/tech/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -314,8 +314,7 @@ def cache_dir(self, value: str) -> None:
def expand_tech_cache_path(self, path) -> str:
""" Replace occurrences of the cache directory's basename with
the full path to the cache dir."""
cache_dir_basename = os.path.basename(self.cache_dir)
return path.replace(cache_dir_basename, self.cache_dir)
return path.replace("cache", self.cache_dir)

# @classmethod
def ensure_dirs_exist(self, path) -> None:
Expand Down
9 changes: 5 additions & 4 deletions hammer/technology/sky130/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
import os, shutil
from pathlib import Path
from typing import NamedTuple, List, Optional, Tuple, Dict, Set, Any
import importlib

import hammer.tech
from hammer.tech import HammerTechnology
Expand Down Expand Up @@ -144,7 +145,7 @@ def setup_lvs_deck(self) -> None:
(source_path, dest_path))
df.write(matcher.sub("", sf.read()))
df.write(LVS_DECK_INSERT_LINES)

def get_tech_par_hooks(self, tool_name: str) -> List[HammerToolHookAction]:
hooks = {
"openroad": [
Expand All @@ -153,7 +154,7 @@ def get_tech_par_hooks(self, tool_name: str) -> List[HammerToolHookAction]:
"innovus": [
HammerTool.make_post_insertion_hook("init_design", sky130_innovus_settings),
HammerTool.make_pre_insertion_hook("place_tap_cells", sky130_add_endcaps),
HammerTool.make_pre_insertion_hook("power_straps", sky130_connect_nets),
HammerTool.make_pre_insertion_hook("power_straps", sky130_connect_nets),
HammerTool.make_pre_insertion_hook("write_design", sky130_connect_nets2)
]}
return hooks.get(tool_name, [])
Expand Down Expand Up @@ -303,11 +304,11 @@ def sky130_add_endcaps(ht: HammerTool) -> bool:
def sky130_set_wire_rc(ht: HammerTool) -> bool:
assert isinstance(ht, HammerPlaceAndRouteTool), "set wire rc only for par"
assert isinstance(ht, TCLTool), "set wire rc can only run on TCL tools"
sky130_plugin_path=ht.get_setting('vlsi.core.technology_path')[-1]
rc_file=importlib.resources.files("hammer.technology.sky130") / "extra/sky130hd.rc"
ht.append(f"""
################################################################
# Repair max slew/cap/fanout violations and normalize slews
source {sky130_plugin_path}/sky130/extra/sky130hd.rc
source {rc_file}
set_wire_rc -signal -layer "met2"
set_wire_rc -clock -layer "met5"
""")
Expand Down
2 changes: 1 addition & 1 deletion hammer/technology/sky130/defaults.yml
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ par.inputs:
par.openroad:
openrcx_techfile: "extra/sky130hd.rcx_rules"
openrcx_techfile_meta: prependlocal
klayout_techfile_source: "${technology.sky130.sky130A}/libs.tech/klayout/sky130A.lyt"
klayout_techfile_source: "${technology.sky130.sky130A}/libs.tech/klayout/tech/sky130A.lyt"
klayout_techfile_source_meta: lazysubst

par.power_straps_mode: generate # Power Straps
Expand Down
18 changes: 10 additions & 8 deletions hammer/vlsi/hammer_vlsi_impl.py
Original file line number Diff line number Diff line change
Expand Up @@ -118,15 +118,17 @@ def load_builtins_and_core(cls, database: hammer_config.HammerDatabase) -> None:
HammerVLSISettings.get_config()
])

# Read in core defaults.
database.update_core(*hammer_config.load_config_from_defaults("hammer.config", types=True))

# Read in vendor-common defaults.
# TODO: move these defaults into respective vendor plugin packages
for pkg in ["hammer.common.cadence", "hammer.common.synopsys", "hammer.common.mentor", "hammer.common.openroad"]:
# Read in core and vendor-common defaults.
# TODO: vendor-common defaults should be in respective vendor plugin packages
# and considered tool configs instead
core_defaults = [] # type: List[dict]
core_defaults_types = [] # type: List[dict]
vendors = ["cadence", "synopsys", "mentor", "openroad"]
for pkg in ["hammer.config"] + list(map(lambda v: "hammer.common." + v, vendors)):
config, types = hammer_config.load_config_from_defaults(pkg, types=True)
database.update_defaults(config)
database.update_types(types, check_type=False)
core_defaults.extend(config)
core_defaults_types.extend(types)
database.update_core(core_defaults, core_defaults_types)

from .hammer_tool import HammerTool, HammerToolStep

Expand Down

0 comments on commit 5d3c606

Please sign in to comment.