OpenRAM/compiler/options.py

185 lines
5.6 KiB
Python
Raw Normal View History

# See LICENSE for licensing information.
#
2021-01-22 20:23:28 +01:00
# Copyright (c) 2016-2021 Regents of the University of California and The Board
2019-06-14 17:43:41 +02:00
# of Regents for the Oklahoma Agricultural and Mechanical College
# (acting for and on behalf of Oklahoma State University)
# All rights reserved.
#
2016-11-08 18:57:35 +01:00
import optparse
2019-10-03 01:26:02 +02:00
import getpass
import os
2016-11-08 18:57:35 +01:00
class options(optparse.Values):
"""
2019-10-03 01:26:02 +02:00
Class for holding all of the OpenRAM options. All
of these options can be over-riden in a configuration file
that is the sole required command-line positional argument for openram.py.
2016-11-08 18:57:35 +01:00
"""
###################
# Configuration options
###################
2016-11-08 18:57:35 +01:00
# This is the technology directory.
openram_tech = ""
2020-05-28 05:03:11 +02:00
2016-11-08 18:57:35 +01:00
# This is the name of the technology.
tech_name = ""
2020-05-28 05:03:11 +02:00
# Port configuration (1-2 ports allowed)
num_rw_ports = 1
num_r_ports = 0
num_w_ports = 0
2020-11-19 19:48:35 +01:00
# By default, don't use hierarchical wordline
local_array_size = 0
2020-11-03 15:29:17 +01:00
# Write mask size, default will be overwritten with word_size if not user specified
write_size = None
2020-05-28 05:03:11 +02:00
# These will get initialized by the user or the tech file
nominal_corner_only = False
supply_voltages = ""
temperatures = ""
process_corners = ""
load_scales = ""
slew_scales = ""
# Size parameters must be specified by user in config file.
2019-10-03 01:26:02 +02:00
# num_words = 0
# word_size = 0
# You can manually specify banks, but it is better to auto-detect it.
num_banks = 1
words_per_row = None
num_spare_rows = 0
num_spare_cols = 0
###################
# Optimization options
###################
2019-10-03 01:26:02 +02:00
# Approximate percentage of delay compared to bitlines
rbl_delay_percentage = 0.5
2020-05-28 05:03:11 +02:00
# Allow manual adjustment of the delay chain over automatic
auto_delay_chain_sizing = False
delay_chain_stages = 9
delay_chain_fanout_per_stage = 4
2020-05-28 05:03:11 +02:00
accuracy_requirement = 0.75
###################
# Debug options.
2020-05-28 05:03:11 +02:00
###################
2016-11-08 18:57:35 +01:00
# This is the temp directory where all intermediate results are stored.
2019-03-08 20:12:30 +01:00
try:
# If user defined the temporary location in their environment, use it
openram_temp = os.path.abspath(os.environ.get("OPENRAM_TMP"))
except:
openram_temp = "/tmp"
2021-02-03 23:19:11 +01:00
2016-11-08 18:57:35 +01:00
# This is the verbosity level to control debug information. 0 is none, 1
# is minimal, etc.
verbose_level = 0
# Drop to pdb on failure?
debug = False
# Only use corners in config file. Disables generated corners
only_use_config_corners = False
# A list of PVT tuples and be given and only these will be characterized
use_specified_corners = None
# Allows specification of model data
sim_data_path = None
###################
# Run-time vs accuracy options.
# Default, sacrifice accuracy/completeness for speed.
# Must turn on options for verification, final routing, etc.
###################
# When enabled, layout is not generated (and no DRC or LVS are performed)
netlist_only = False
# Whether we should do the final power routing
route_supplies = "tree"
# This determines whether LVS and DRC is checked at all.
check_lvsdrc = False
# This determines whether LVS and DRC is checked for every submodule.
inline_lvsdrc = False
# Remove noncritical memory cells for characterization speed-up
2019-07-24 17:15:10 +02:00
trim_netlist = False
# Run with extracted parasitics
use_pex = False
# Output config with all options
output_extended_config = False
# Output temporary file used to format HTML page
output_datasheet_info = False
2020-12-09 21:54:11 +01:00
# Determines which analytical model to use.
# Available Models: elmore, linear_regression
model_name = "elmore"
2020-05-28 05:03:11 +02:00
###################
# Tool options
###################
# Variable to select the variant of spice
spice_name = ""
# The spice executable being used which is derived from the user PATH.
spice_exe = ""
# Variable to select the variant of drc, lvs, pex
drc_name = ""
lvs_name = ""
pex_name = ""
2019-10-03 01:26:02 +02:00
# The DRC/LVS/PEX executable being used
# which is derived from the user PATH.
2018-01-12 23:39:42 +01:00
drc_exe = None
lvs_exe = None
pex_exe = None
# For sky130, we need magic for filtering.
magic_exe = None
2020-11-17 22:30:18 +01:00
# Number of threads to use
num_threads = 2
2021-02-03 23:19:11 +01:00
# Number of threads to use in ngspice/hspice
num_sim_threads = 2
2020-05-28 05:03:11 +02:00
# Should we print out the banner at startup
print_banner = True
2019-11-29 21:01:33 +01:00
2016-11-08 18:57:35 +01:00
# Define the output file paths
output_path = "."
2016-11-08 18:57:35 +01:00
# Define the output file base name
output_name = ""
2019-10-03 01:26:02 +02:00
# Use analytical delay models by default
# rather than (slow) characterization
analytical_delay = True
2019-10-03 01:26:02 +02:00
# Purge the temp directory after a successful
# run (doesn't purge on errors, anyhow)
# Route the input/output pins to the perimeter
perimeter_pins = True
2020-11-03 15:29:17 +01:00
keep_temp = False
# These are the default modules that can be over-riden
2019-01-17 01:15:38 +01:00
bank_select = "bank_select"
bitcell_array = "bitcell_array"
bitcell = "bitcell"
buf_dec = "pbuf"
column_mux_array = "column_mux_array"
2019-01-17 01:15:38 +01:00
control_logic = "control_logic"
decoder = "hierarchical_decoder"
2019-01-17 01:15:38 +01:00
delay_chain = "delay_chain"
dff_array = "dff_array"
dff = "dff"
inv_dec = "pinv"
nand2_dec = "pnand2"
nand3_dec = "pnand3"
2020-12-09 21:54:11 +01:00
nand4_dec = "pnand4" # Not available right now
precharge_array = "precharge_array"
ptx = "ptx"
2019-01-17 01:15:38 +01:00
replica_bitline = "replica_bitline"
sense_amp_array = "sense_amp_array"
sense_amp = "sense_amp"
tri_gate_array = "tri_gate_array"
2019-01-17 01:15:38 +01:00
tri_gate = "tri_gate"
wordline_driver = "wordline_driver"
2019-01-17 01:15:38 +01:00
write_driver_array = "write_driver_array"
write_driver = "write_driver"
write_mask_and_array = "write_mask_and_array"