OpenRAM/compiler/sram_func.py

92 lines
2.9 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
# See LICENSE for licensing information.
#
# Copyright (c) 2016-2021 Regents of the University of California and The Board
# of Regents for the Oklahoma Agricultural and Mechanical College
# (acting for and on behalf of Oklahoma State University)
# All rights reserved.
#
"""
This script will functionally simulate an SRAM previously generated by OpenRAM
given a configuration file. Configuration option "use_pex" determines whether
extracted or generated spice is used. Command line arguments dictate the
number of cycles and period to be simulated.
"""
import sys
import datetime
from globals import *
2023-01-19 21:18:38 +01:00
try:
import openram
except:
# If openram library isn't found as a python package,
# import it from the $OPENRAM_HOME path.
import importlib.util
OPENRAM_HOME = os.getenv("OPENRAM_HOME")
# Import using spec since the directory can be named something
# other than "openram".
spec = importlib.util.spec_from_file_location("openram", "{}/../__init__.py".format(OPENRAM_HOME))
module = importlib.util.module_from_spec(spec)
sys.modules["openram"] = module
spec.loader.exec_module(module)
import openram
(OPTS, args) = openram.parse_args()
# Override the usage
USAGE = "Usage: {} [options] <config file> <cycles> <period>\nUse -h for help.\n".format(__file__)
# Check that we are left with a single configuration file as argument.
if len(args) != 3:
print(USAGE)
sys.exit(2)
2022-08-19 05:35:02 +02:00
OPTS.top_process = 'memfunc'
# Parse argument
config_file = args[0]
cycles = int(args[1])
period = float(args[2])
2023-01-19 21:18:38 +01:00
sp_file = args[3]
html_file = args[4]
# These depend on arguments, so don't load them until now.
2023-01-19 21:18:38 +01:00
from openram import debug
# Parse config file and set up all the options
2023-01-19 21:18:38 +01:00
openram.init_openram(config_file=config_file, is_unit_test=False)
2023-01-19 21:18:38 +01:00
openram.print_banner()
# Configure the SRAM organization (duplicated from openram.py)
2022-12-13 16:53:58 +01:00
from characterizer.fake_sram import fake_sram
s = fake_sram(name=OPTS.output_name,
word_size=OPTS.word_size,
num_words=OPTS.num_words,
write_size=OPTS.write_size,
num_banks=OPTS.num_banks,
words_per_row=OPTS.words_per_row,
num_spare_rows=OPTS.num_spare_rows,
num_spare_cols=OPTS.num_spare_cols)
2023-01-19 21:18:38 +01:00
s.parse_html(html_file)
2022-12-13 16:53:58 +01:00
s.generate_pins()
s.setup_multiport_constants()
OPTS.netlist_only = True
OPTS.check_lvsdrc = False
# Generate stimulus and run functional simulation on the design
start_time = datetime.datetime.now()
2023-01-19 21:18:38 +01:00
from openram.characterizer import functional
debug.print_raw("Functional simulation... ")
2023-01-19 21:18:38 +01:00
f = functional(s, cycles=cycles, spfile=sp_file, period=period, output_path=OPTS.openram_temp)
(fail, error) = f.run()
2022-03-09 18:43:00 +01:00
debug.print_raw(error)
2023-01-19 21:18:38 +01:00
openram.print_time("Functional simulation", datetime.datetime.now(), start_time)
# Delete temp files, remove the dir, etc. after success
if fail:
2023-01-19 21:18:38 +01:00
openram.end_openram()