2016-11-08 18:57:35 +01:00
|
|
|
#!/usr/bin/env python2.7
|
|
|
|
|
"""
|
|
|
|
|
SRAM Compiler
|
|
|
|
|
|
|
|
|
|
The output files append the given suffixes to the output name:
|
|
|
|
|
a spice (.sp) file for circuit simulation
|
|
|
|
|
a GDS2 (.gds) file containing the layout
|
|
|
|
|
a LEF (.lef) file for preliminary P&R (real one should be from layout)
|
|
|
|
|
a Liberty (.lib) file for timing analysis/optimization
|
|
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
import sys,os
|
|
|
|
|
import datetime
|
|
|
|
|
import re
|
|
|
|
|
import importlib
|
2018-02-08 21:47:19 +01:00
|
|
|
from globals import *
|
2016-11-08 18:57:35 +01:00
|
|
|
|
2018-02-08 21:47:19 +01:00
|
|
|
(OPTS, args) = parse_args(is_unit_test=False)
|
2017-11-14 22:24:14 +01:00
|
|
|
|
2016-11-08 18:57:35 +01:00
|
|
|
# These depend on arguments, so don't load them until now.
|
|
|
|
|
import debug
|
|
|
|
|
|
2018-02-08 21:47:19 +01:00
|
|
|
# Only print banner here so it's not in unit tests
|
|
|
|
|
print_banner()
|
2016-11-08 18:57:35 +01:00
|
|
|
|
2018-02-08 21:47:19 +01:00
|
|
|
init_openram(args[0])
|
2016-11-08 18:57:35 +01:00
|
|
|
|
2018-02-08 21:47:19 +01:00
|
|
|
# Start importing design modules after we have the config file
|
2017-11-14 23:59:14 +01:00
|
|
|
import verify
|
2016-11-08 18:57:35 +01:00
|
|
|
import sram
|
|
|
|
|
|
2018-02-08 21:47:19 +01:00
|
|
|
# Keep track of running stats
|
2017-11-14 22:24:14 +01:00
|
|
|
start_time = datetime.datetime.now()
|
2018-02-08 22:11:18 +01:00
|
|
|
print_time("Start",start_time)
|
2018-02-08 21:47:19 +01:00
|
|
|
|
2016-11-08 18:57:35 +01:00
|
|
|
# import SRAM test generation
|
2018-02-08 21:47:19 +01:00
|
|
|
s = sram.sram(word_size=OPTS.word_size,
|
|
|
|
|
num_words=OPTS.num_words,
|
|
|
|
|
num_banks=OPTS.num_banks,
|
2017-06-12 23:37:15 +02:00
|
|
|
name=OPTS.output_name)
|
2016-11-08 18:57:35 +01:00
|
|
|
|
|
|
|
|
# Output the files for the resulting SRAM
|
2018-02-08 22:11:18 +01:00
|
|
|
s.save_output()
|
2016-11-08 18:57:35 +01:00
|
|
|
|
2018-02-08 21:47:19 +01:00
|
|
|
# Delete temp files etc.
|
|
|
|
|
end_openram()
|
|
|
|
|
print_time("End",datetime.datetime.now(), start_time)
|
2016-11-08 18:57:35 +01:00
|
|
|
|
|
|
|
|
|