Skip to content

Latest commit

 

History

History
200 lines (191 loc) · 10.4 KB

CHANGELOG.md

File metadata and controls

200 lines (191 loc) · 10.4 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog.

Unreleased - 2024-10-14

Added

  • Xschem install script: added Python shebang line
  • Qucs-S install script: added Python shebang line
  • Qucs-s install script: added checking for qucs-s binary
  • Add vbic examples for Xyce/adms
  • Add moshv lib and examples for Xyce
  • Initial list of tool versions
  • Added cross-platform compatibility for logger
  • Added initial version of multiplier check for netlists in stdcells
  • Add CODEOWNERS file
    • Krzysztof and Sergei are the maintainer of this repository. Add them as CODEOWNER to auto-assign them in Pull Requests.
  • KLayout XSection: added initial README
  • Initial version of KLayout cross-section (XS) settings
  • Added HBT models for Xyce simulator
  • Added smaller SRAM macros
  • KLayout Pycells: added NWell to 'dpantenna' device
  • Added pnpMPA measurements documentation
  • Added 'Digital' IHP130 cells as submodule

Changed

  • Update ISSUE_TEMPLATE.md
    • removed explicit env items, user should put his own related settings
  • Updated procedure to avoid constant openning cmd window on Windows to execute task list.
  • Update versions.txt
    • added OpenVAF
  • Klayout PyCell integration
    • Added support for or'ed #ifdef defines
    • Took over windows compatibility work from Andreas Krinke andreas.krinke@gmx.de
    • Fixed pypreprocessor issues
    • Fixed misleading import
    • Fixed documentation
    • Add pypreprocessor IHP clone submodule
    • Added evalution of names used for conditional compilation against process-chain
    • Added catching of PyCell static/dynamic compilation errors for correction of file-path stack-dump
    • Added diagnositc logging of process-chain as well as set defines
    • Eleminate pre-definition of used defines by pre-scanning cell code
    • Fixed issue from IHP open source server regarding remove of tmp-file
    • Implemented 'conditional compilation' for PyCell code, see documentation in ihp-sg13g2/libs.tech/klayout/python/sg13g2_pycell_lib/init.py
    • Simplified referencing python modules by setting search path
    • Re-implemented clone() for shapes using deepcopy
    • Implemented tagging of shapes feature from SKILL Pcell counter-part
    • Fixed npn13G2L/npn13G2V to be equal to SKILL Pcell counter-part
    • Introduced library code/documentation as submodule from pycell4klayout-api repo
    • Added support for fgAnd, fgNot andfgSize
    • Fixed dbLayerSize
    • Fixed pin label creation by removing extra text generation
    • Added missing self-argument in class Box
    • Fix wrong assignment: re-assign pins, terms and nets from PyCell-instances to cell-instances for multi-cell instances of the same PyCell
    • Fixed merge-error
    • Added PyCell parameter type bool
    • Added partial implementation for PyCell API class Net
    • Added partial implementation for PyCell API class Path
    • Added partial implementation for PyCell API class ShapeFilter
    • Added support for Net's
    • Added generic registering of IHP PyCell's in Klayout
    • Added support for inductor2, inductor2_sc, inductor2_sp, inductor3, inductor3_sc and inductor3_sp
    • Added partial implementation of class Pin from PyCell API
    • Added partial implementation of class Term from PyCell API
    • Added support for pins/terminals
    • Added support for XOR geometric transformation
    • Added support for text alignment/orientation
    • Fixed dbLayerXorList from geometry.py
    • Added support of npn13G2L and npn13G2V
    • Extended documentation
  • Update KLayout DRC scripts
    • fixes regression that missed DRC errors, e.g. for M1.b
    • improves running the DRC on Windows
    • prints message for each rule during run
    • new options, increased accuracy of width and overlap checks
    • fixes bug regarding µm/dbu conversion
    • new options, increased accuracy of space and separation checks
    • fixes incorrect DRC errors, e.g. for pSD.d, pSD.d1
    • maximal DRC script supports ~75% of rules
    • rename DRC script parameters for OpenROAD compatibility
      • logfile -> log_file
      • gdsfile -> in_gds
      • outfile -> report_file
    • DRC script parameter "cell" is now optional
    • output number of DRC errors at the end
    • DRC script no longer depends on layout dbu
      • all lengths are given in micrometers
    • add limits to rule descriptions, e.g., "Min. GatPoly width = 0.13"
  • Improve Windows compatibility of PyCell code
    • remove dependency on psutil, which is difficult to install on Windows
  • Updated Qucs-S examples, install.py for Qucs
  • Use Xyce vbic build-in model instead Verilog-A model
  • Change example file names
  • Xyce library extension moslv
  • Update README.md
    • added tool versions part
    • Aligned file names
    • added note on XSection in PDK contents
    • updated year in Apache license header
    • Added 'Digital' tool in PDK contents
    • Added LVS in PDK contents section
  • pmosHV Pycell: various updates to align to the implementation in commercial PDK
  • Pycell4klayout-api updated to the latest version
  • Sealring Pycell: area for registration
  • libs.tech: openroad: Add missing SRAMs
    • A4defa8ab added missing .lib files for recently added SRAMs. Update the export.yml with all files for these RAMs.
  • Xyce HBT models: commented vbe_max, vbc_max, vce_max parameters - these are not used
  • libs.tech: Python tool to generate export.yml
    • The export.yml file communicates all exportable files, with additional meta data, to OpenROAD. It can automatically check if files changed or new exist and sync those.
  • libs.ref: Don't ignore sub-directories
    • The .gitignore in the root level ignores directories like lib/. This will prevent checking in new libs as Git would ignore those.
  • Update README.md
    • added note on current status
    • screenshot as an example
  • KLayout Pycells: small typo correction in npn13G2* devices
  • Update README.md
    • Added requirement to set PDK_ROOT
  • Ngspice models: changed '.parameters' to '.param' in corner*.lib files
  • Option list duplication removed
  • Update xschemrc
    • Adding append XSCHEM_LIBRARY_PATH :${XSCHEM_SHAREDIR}/xschem_library/devices line
  • Update path to standard symbols
  • .spiceinit PDK env. variable added + fixes
  • .spiceinit PDK env. variable added
  • Update .gitmodules
    • Changed SSH to HTTPS mode
  • Updating custom writer for LVS runset
  • Major change in ngspice model referencing, xschem testcases update, qucs-s examples updated
  • Construct full lvs rule deck for SG13G2 tech
  • libs.tech: Klayout: tech: sg13g2.lyt: Use empty lef-files
    • OpenROAD-flow-scripts will search and replace for .*. Therefore, keep it empty in this syntax.
  • libs.tech: Klayout: tech: Add map file
    • This file was copied from the OpenROAD-flow-scripts repository and should be maintained and kept here.
  • libs.tech: Klayout: tech: Add layer map
    • OpenROAD requires the sg13g2.map file to correctly place each layer. Fix this here to not overwrite manually changes in OpenROAD-Flow-Scripts.
  • KLayout Pycells: updated device library name
  • KLayout tech file: setting up technology specific grids, smallest (req) = 5nm
  • IO cells: renamed 'liberty' folder to 'lib' to align across cellsets (stdcell, sram)
  • IO cells: aligned Liberty file names
  • libs.tech: klayout: Add macro to report layer density
    • This script calculates and reports the density for multiple important layers and can help to see which layers will violatie fill rules. Based-on: Krzystof Herman herman@ihp-microelectronics.com
  • libs.tech: klayout: drc: Use correct border
    • The DRC report had multiple violations included which are relate to unclean calculation of the chip border. Based-on: Andreas Krinke andreas.krinke@tu-dresden.de
  • libs.tech: klayout: Add Python script to generate Sealring files
    • This script can be called in Klayout's batch mode and generates a GDS file with a sealring included. The width and height of the ring are configurable via arguments.
    • Example call:
    klayout -n sg13g2 -zz -r sealring.py \
    -rd width=1300.0 -rd height=1300.0 \
    -rd output=macros/sealring.gds.gz
    
  • DbCreateRect outside if..else
  • Via stack PCell integration
  • KLayout Pycells: some fixes and cleanup for npn13G2
  • IO cells: renamed CDL file to align
  • Dantenna and dpantenna PCells integration
  • Xschem testcases *.sch files updated to support lower-case w and l
  • Xschemrc res_drc function updated
  • DRC checks for xschem added in xschemrc (mosfets, hbt, diode, res, mim), symbols modified, some testcases modified
  • @spiceprefix added for mos devices and diodes, RF symbols added for HV mosfets
  • Lv symbols modified for lvs, @spiceprofix added
  • Change hv pcells name
  • KLayout Pycells: updated 'Ae' text string in npn13G2* cells to be consistent w/ internal implementation
  • Hv added to init
  • Hv-mos pcell integration
  • Lvs-symbol
  • Some updates on top of #121
    • Remove labels on ESD diodes so they are now recognized as regular d(p)antenna diodes
    • Increase width to minimum 0.48µm to account for new rule not yet in DRC check.
  • Layout rule manual updated
  • Update README.md
    • OpenROAD, OpenROAD flow scripts, Qucs-S added as supported EDA tools.

Fixed

  • Stdcells LEF: USE ANALOG changed to USE SIGNAL
  • pnpMPA: fixed pin order in model, updated xschem symbol and testbench
  • libs.ref: sg13g2_io: verilog: Fix specify syntax
    • The input and output definition in the Verilog specify block were positioned in the wrong order (output to input). Change and also implement the tri-state better.
  • LVS rule decks: Fix GF180 remnants in log strings
  • pnpMPA docs: fixed typos in file naming
  • libs.tech: klayout: macros: Fix intentation
  • libs.tech: klayout: Fix Metal density min/max values
    • Global min./max. Metal(n) density values are 35% and 60%. The previous 25% and 75% are only valid for 800x800 chip areas.
  • Fix class name in hv-pmos pcell
  • Fix hv pcell integration in init file

Removed

  • Qucs-S symbols: removed .INCLUDE, removed temperature sensing terminal from standard npn13G2* devices
  • Pycells: removed via_stack device, it's obsolete
  • Remove merged.lef from klayout setup
    • Removing reference to merged.lef which does not exist.
  • Delete ihp-sg13g2/libs.tech/pycell directory
  • KLayout tech JSON: removed all layers definitions, these are taken from .lyp file
  • KLayout DRC: removed obsolete deck file (now we have min and max in separate files)