PDKMaster based scalable standard cell library
Project description
Flexible, scalable, standard cell library
A standard cell library is a collection of cells that perform certain digital functions. It consists of so-called combinatorial cells which perform a binary logic function and sequential cells sync internal signal with a clock signal.
Standard cells are introduced into an ASIC EDA flow during the synthesis step. This is the step where a (RTL) logic design into a netlist consisting only of the cells from your standard cell library. Later on these cells are then placed next to each and the inputs and outputs of each cell connected to each other. The former is called placement and the latter routing.
Release History
- v0.4.4: Mainly update for signoff fixing and new PDK support.
- v0.4.3:
- regular code cleansing
- update layout generation to avoid DRC violation with updated primitives in PDKMaster
- v0.4.2: only internal improvements
- v0.4.1:
major reworking of the code. A new class ActiveColumnsCell has been introduced to generate the layouts of the standard cells. This removes the lambda based dimensions from the cells to compute them all from the design rules.
All cells were converter to this new layout method and this should allow to make standard cell libraries with much lower height of the cells. Compatiblity function are provided so that layout spec can be derived as was done previously as based on a lambda value.
v0.4.0 had only dev releases and code was rebased and squashed for this release. - v0.3.3: bug fix; remove public 0.3.2 release
- v0.3.2: code cleansing, bug fixing, update dependencies
- v0.3.1: small update for Coriolis export
- v0.3.0: Update for release v0.9.0 of PDKMaster; replace Library-> StdCellFactory to follow common usage of a factory to generate cells.
- v0.2.0: Small updates for changing PDKMaster API
- v0.1.0
- v0.0.4
Rationale
Up to now for a lot of standard cell libraries the layout was done manually leading to a lot manual work when changes need to be done like changing the height of the cells or porting it to another technology node. Some of them are based on so-called lambda rules to make them scalable to different nodes. Usage of lambda rules will cause their own inefficiencies in the layout especially when scaling to smaller nodes.
Alternative implementations try to fully automate the layout generation out of the transistor netlist. Finding a good placement of the transistor for non-trivial logic cells is a hard problem leading often to complex code for finding acceptable solutions. Also the layout code itself often becomes complex to take peculiarities of different design rules into account.
The flexcell
library tries to take a middle road. It will start from a topological layout of the cell but without the layout already fixed to certain design rules; it thus avoid the step where netlist need to be converted to topologies. It will use the design rules from a PDKMaster Technology object to generate an optimized layout for conforming to the cells topology. By baking in independence of the Technology the standard cell library should be easily ported to different technologies with better area efficiency than current lambda rules based solutions.
In future options are planned so libraries can be generated for different targets like ,minimum area, maximum performance or minimum power consumption.
Status
This repository is currently considered experimental code with no backwards compatibility guarantees whatsoever.
Current implementation is based on the topology of the Coriolis nsxlib standard cells with some area improvements but not yet with optimal area use. For v0.1 of this library a total replacement of the layout generation is planned fully based on minimized area for the technology design rules.
If interested head over to gitter for further discussion.
Project Arrakeen subproject
This project is part of Chips4Makers' project Arrakeen. It shares some common guide lines and regulations:
- Contributing.md
- LICENSE.md: license of release code
- LICENSE_rationale.md
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file c4m_flexcell-0.4.4.tar.gz
.
File metadata
- Download URL: c4m_flexcell-0.4.4.tar.gz
- Upload date:
- Size: 41.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 06f361e7fce22cf3c5e2f5c7e95bc80abc67b68f38430f1b6eaae8dc983c4150 |
|
MD5 | 1f5e15265eb78575432549b9caf2a10d |
|
BLAKE2b-256 | ac28f2990beb9a1096aceb6bb3da259c3f2aa3fcc06fceb3acfeed2337de269d |
File details
Details for the file c4m_flexcell-0.4.4-py3-none-any.whl
.
File metadata
- Download URL: c4m_flexcell-0.4.4-py3-none-any.whl
- Upload date:
- Size: 43.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 36ba744d18b1fb5ab0574710b5d3369a3c9b99b4c791820b1cf770e4a3d68461 |
|
MD5 | 5caac15f6ecd4617ff1bc5947942e936 |
|
BLAKE2b-256 | 878635cdf9837c941db1f917841c74ddd6c93bcfdc31d6fb6013a76683404bde |