2019-01-23 05:41:32 +01:00
# Parallax Static Timing Analyzer
2019-01-17 23:22:45 +01:00
2019-01-23 05:41:32 +01:00
OpenSTA is a gate level static timing verifier. As a stand-alone
executable it can be used to verify the timing of a design using
standard file formats.
2019-01-17 23:22:45 +01:00
2019-01-23 05:41:32 +01:00
* Verilog netlist
* Liberty library
* SDC timing constraints
* SDF delay annotation
* SPEF parasitics
2019-01-17 23:22:45 +01:00
2019-01-23 05:41:32 +01:00
OpenSTA uses a TCL command interpreter to read the design, specify
timing constraints and print timing reports.
2019-01-17 23:22:45 +01:00
2019-01-23 05:41:32 +01:00
##### Clocks
2019-01-17 23:22:45 +01:00
* Generated
* Latency
* Source latency (insertion delay)
* Uncertainty
* Propagated/Ideal
* Gated clock checks
* Multiple frequency clocks
2019-01-23 05:41:32 +01:00
##### Exception paths
* False path
* Multicycle path
* Min/Max path delay
* Exception points
* -from clock/pin/instance -through pin/net -to clock/pin/instance
* Edge specific exception points
* -rise_from/-fall_from, -rise_through/-fall_through, -rise_to/-fall_to
##### Delay calculation
2019-01-17 23:22:45 +01:00
* Integrated Dartu/Menezes/Pileggi RC effective capacitance algorithm
* External delay calculator API
2019-01-23 05:41:32 +01:00
##### Analysis
2019-01-17 23:22:45 +01:00
* Report timing checks -from, -through, -to, multiple paths to endpoint
* Report delay calculation
* Check timing setup
2019-01-23 05:41:32 +01:00
##### Timing Engine
OpenSTA is architected to be easily bolted on to other tools as a
timing engine. By using a network adapter, OpenSTA can access the host
netlist data structures without duplicating them.
2019-01-17 23:22:45 +01:00
* Query based incremental update of delays, arrival and required times
* Simulator to propagate constants from constraints and netlist tie high/low
2023-07-13 16:30:30 +02:00
See doc/OpenSTA.pdf for command documentation.
See doc/StaApi.txt for timing engine API documentation.
2019-10-25 17:51:59 +02:00
See doc/ChangeLog.txt for changes to commands.
2019-01-23 05:41:32 +01:00
2023-03-22 16:23:07 +01:00
OpenSTA is dual licensed. It is released under GPL v3 as OpenSTA and
is also licensed for commerical applications by Parallax Software without
the GPL's requirements.
2023-08-11 02:53:58 +02:00
OpenSTA is open source, meaning the sources are published and can be
compiled locally. Derivative works are supported as long as they
adhere to the GPL license requirements. However, OpenSTA is not
supported by a public community of developers as many other open
source projects are. The copyright and develpment are exclusive to
2024-03-03 17:46:21 +01:00
Parallax Software. Contributors must signing the Contributor License
Agreement (doc/CLA.txt) when submitting pull requests.
2023-08-11 02:53:58 +02:00
Removing copyright and license notices from OpenSTA sources (or any
other open source project for that matter) is illegal. This should be
obvious, but the author of OpenSTA has discovered two different cases
where the copyright and license were removed from source files that
2023-10-11 01:01:02 +02:00
were copied.
2023-03-22 16:23:07 +01:00
The official git repository is located at
2023-06-04 21:38:45 +02:00
https://github.com/parallaxsw/OpenSTA.git. Any forks from this code
2023-03-22 16:23:07 +01:00
base have not passed extensive regression testing which is not
publicly available.
2023-03-22 05:02:59 +01:00
2019-11-08 16:45:03 +01:00
## Build
2019-01-23 05:41:32 +01:00
2019-11-08 16:45:03 +01:00
OpenSTA is built with CMake.
2019-01-23 05:41:32 +01:00
### Prerequisites
The build dependency versions are show below. Other versions may
work, but these are the versions used for development.
```
2024-06-27 22:57:58 +02:00
Ubuntu Macos
22.04.2 14.5
cmake 3.24.2 3.29.2
clang 15.0.0
gcc 11.4.0
tcl 8.6 8.6.6
swig 4.1.0 4.1.1
bison 3.8.2 3.8.2
flex 2.6.4 2.6.4
2019-01-23 05:41:32 +01:00
```
2020-11-10 17:50:06 +01:00
Note that flex versions before 2.6.4 contain 'register' declarations that
are illegal in c++17.
2024-04-20 02:27:21 +02:00
External library dependencies:
2019-01-23 05:41:32 +01:00
```
2024-06-28 05:22:29 +02:00
Ubuntu Macos license
eigen 3.4.0 3.4.0 MPL2 required
2024-07-17 23:19:49 +02:00
cudd 3.0.0 3.0.0 BSD required
2024-06-28 05:22:29 +02:00
tclreadline 2.3.8 2.3.8 BSD optional
zLib 1.2.5 1.2.8 zlib optional
2019-01-23 05:41:32 +01:00
```
2022-10-24 18:18:01 +02:00
The [TCL readline library ](https://tclreadline.sourceforge.net/tclreadline.html )
links the GNU readline library to the TCL interpreter for command line editing
On OSX, Homebrew does not support tclreadline, but the macports system does
(see https://www.macports.org). To enable TCL readline support use the following
2024-06-27 22:57:58 +02:00
Cmake option: See (https://tclreadline.sourceforge.net/) for TCL readline
documentation. To change the overly verbose default prompt, add something this
to your ~/.sta init file:
2022-10-24 18:18:01 +02:00
```
2024-06-27 22:57:58 +02:00
if { ![catch {package require tclreadline}] } {
proc tclreadline::prompt1 {} {
return "> "
}
}
2022-10-24 18:18:01 +02:00
```
The Zlib library is an optional. If CMake finds libz, OpenSTA can
2024-06-27 22:57:58 +02:00
read Liberty, Verilog, SDF, SPF, and SPEF files compressed with gzip.
2022-10-24 18:18:01 +02:00
2020-04-03 18:23:27 +02:00
CUDD is a binary decision diageram (BDD) package that is used to
2024-09-17 21:44:50 +02:00
improve conditional timing arc handling, constant propagation, power
activity propagation and spice netlist generation.
2024-06-27 22:57:58 +02:00
CUDD is available
2024-09-17 18:12:35 +02:00
[here ](https://github.com/davidkebo/cudd/blob/main/cudd_versions/cudd-3.0.0.tar.gz ).
2019-01-23 05:41:32 +01:00
2024-09-17 21:44:50 +02:00
Unpack and build CUDD.
2019-01-23 05:41:32 +01:00
```
2024-09-17 21:44:50 +02:00
tar xvfz cudd-3.0.0.tar.gz
cd cudd-3.0.0
./configure
2019-01-23 05:41:32 +01:00
make
2019-03-25 03:41:05 +01:00
```
2019-01-23 05:41:32 +01:00
2024-09-17 21:44:50 +02:00
You can use the "configure --prefix" option and "make install" to install CUDD
in a different directory.
2019-01-23 05:41:32 +01:00
### Installing with CMake
Use the following commands to checkout the git repository and build the
OpenSTA library and excutable.
```
2024-03-21 01:14:43 +01:00
git clone https://github.com/parallaxsw/OpenSTA.git
2019-07-19 16:17:03 +02:00
cd OpenSTA
2019-01-23 05:41:32 +01:00
mkdir build
cd build
2024-09-17 21:44:50 +02:00
cmake -DCUDD_DIR=< CUDD_INSTALL_DIR > ,.
2019-01-23 05:41:32 +01:00
make
```
The default build type is release to compile optimized code.
The resulting executable is in `app/sta` .
The library without a `main()` procedure is `app/libSTA.a` .
Optional CMake variables passed as -D< var > =< value > arguments to CMake are show below.
```
CMAKE_BUILD_TYPE DEBUG|RELEASE
CMAKE_CXX_FLAGS - additional compiler flags
2020-01-16 01:19:19 +01:00
TCL_LIBRARY - path to tcl library
2019-01-23 05:41:32 +01:00
TCL_HEADER - path to tcl.h
2024-09-17 21:44:50 +02:00
CUDD_DIR - path to cudd installation
2019-01-23 05:41:32 +01:00
ZLIB_ROOT - path to zlib
CMAKE_INSTALL_PREFIX
```
2020-01-16 01:19:19 +01:00
If `TCL_LIBRARY` is specified the CMake script will attempt to locate
the header from the library path.
2019-01-23 05:41:32 +01:00
The default install directory is `/usr/local` .
2024-09-17 21:44:50 +02:00
To install in a different directory with CMake use the CMAKE_INSTALL_PREFIX option.
2019-01-23 05:41:32 +01:00
If you make changes to `CMakeLists.txt` you may need to clean out
existing CMake cached variable values by deleting all of the
files in the build directory.
2019-04-16 01:30:30 +02:00
## Bug Reports
2019-02-16 21:07:59 +01:00
2019-04-16 01:30:30 +02:00
Use the Issues tab on the github repository to report bugs.
2019-02-16 21:07:59 +01:00
2019-04-16 01:30:30 +02:00
Each issue/bug should be a separate issue. The subject of the issue
should be a short description of the problem. Attach a test case to
reproduce the issue as described below. Issues without test cases are
unlikely to get a response.
2019-01-23 05:41:32 +01:00
2019-04-16 01:30:30 +02:00
The files in the test case should be collected into a directory named
YYYYMMDD where YYYY is the year, MM is the month, and DD is the
day (this format allows "ls" to report them in chronological order).
The contents of the directory should be collected into a compressed
tarfile named YYYYMMDD.tgz.
2019-01-23 05:41:32 +01:00
2019-04-16 01:30:30 +02:00
The test case should have a tcl command file recreates the issue named
run.tcl. If there are more than one command file using the same data
files, there should be separate command files, run1.tcl, run2.tcl
etc. The bug report can refer to these command files by name.
2019-01-23 05:41:32 +01:00
2019-04-16 01:30:30 +02:00
Command files should not have absolute filenames like
"/home/cho/OpenSTA_Request/write_path_spice/dump_spice" in them.
These obviously are not portable. Use filenames relative to the test
case directory.
2019-01-23 05:41:32 +01:00
2019-11-08 16:45:03 +01:00
## Authors
* James Cherry
* William Scott authored the arnoldi delay calculator at Blaze, Inc which was subsequently licensed to Nefelus, Inc that has graciously contributed it to OpenSTA.
2019-01-23 05:41:32 +01:00
## License
2019-03-23 23:56:23 +01:00
OpenSTA, Static Timing Analyzer
2023-02-19 01:55:40 +01:00
Copyright (c) 2023, Parallax Software, Inc.
2019-01-23 05:41:32 +01:00
2019-03-23 23:56:23 +01:00
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
2022-01-04 18:17:08 +01:00
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2019-03-23 23:56:23 +01:00
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
2022-01-04 18:17:08 +01:00
along with this program. If not, see < https: / / www . gnu . org / licenses / > .