Commit Graph

3090 Commits

Author SHA1 Message Date
Rob Taylor a032bdd9ee Convert PyCRL to multiphase initialisation, fetch the module location, and setCORIOLIS_TOP 2023-10-06 16:50:35 +01:00
Rob Taylor d7652a7ebc Reinstate coriolis_top system path 2023-10-06 16:50:35 +01:00
Rob Taylor d373afeffd Remove all usage of etc/SYS_CONF_PATH and any assumptions about the installation location 2023-10-06 16:50:35 +01:00
Jean-Paul Chaput 081569b363 Merge branch 'main' into mac 2023-10-06 13:52:29 +02:00
Rob Taylor bf95753d65 Fix def error handling for buffer overflow 2023-10-06 12:59:07 +02:00
Rob Taylor c0dfed21e4 Fix bitwise OR used instead of AND for flag check 2023-10-06 12:59:07 +02:00
Rob Taylor a77c7bf9bc Fix clang warning about Analog::Device::postCreate overloading 2023-10-06 12:59:07 +02:00
Rob Taylor 1e74e5a167 Various code fixes for building on Mac OSX 2023-10-06 12:59:07 +02:00
Rob Taylor bda776ec02 Make sprints safe in lefdef 2023-10-06 12:59:07 +02:00
Robert Taylor 706e340361 remove deprecated components 2023-10-06 12:32:08 +02:00
Jean-Paul Chaput b3d5c56965 Using Python collections.abc instead of collections (deprecated). 2023-10-05 10:25:29 +02:00
Gabriel Gouvine 151ee6fd82 Add def generated file to gitignore 2023-10-05 10:25:29 +02:00
Gabriel Gouvine 7bc9918aa7 Remove doxygen logs from repository 2023-10-05 10:25:29 +02:00
Rob Taylor c7d564fbb6 Mac/clang: make cfg parameters use key type std::string rather than const std::string 2023-09-29 21:42:45 +01:00
Rob Taylor aa0494a2d5 Add an INSTALL.rst, along with some instructions for Mac 2023-09-29 21:42:45 +01:00
Rob Taylor 138e668150 CMake build system fixes to build on Mac OSX 2023-09-29 21:42:45 +01:00
Rob Taylor 52458effe1 Fix def error handling for buffer overflow 2023-09-29 21:42:25 +01:00
Rob Taylor 2f0a77d170 Fix bitwise OR used instead of AND for flag check 2023-09-29 21:42:25 +01:00
Rob Taylor 4b380f3bcc Fix clang warning about Analog::Device::postCreate overloading 2023-09-29 21:42:25 +01:00
Rob Taylor e9521d108d Various code fixes for building on Mac OSX 2023-09-29 21:42:25 +01:00
Rob Taylor 0f416060d2 Make sprints safe in lefdef 2023-09-29 21:42:25 +01:00
Robert Taylor 54f21a13b7 remove deprecated components 2023-09-29 21:39:47 +01:00
Robert Taylor cb96cae605 Add cgt to exposed toolset from wheel 2023-09-29 22:36:30 +02:00
Jean-Paul Chaput d877a311b5 Use STL bind (not Boost) and the std::placeholders. 2023-09-29 10:11:57 +01:00
Jean-Paul Chaput f22b7000b6 Fix wrong move up of non-preferred direction segments.
* Change: In GCell::stepNetDesaturate(), never move up a segment in
    non-preferred direction as they are usually attached to terminals,
    so they won't reduce the GCell density anyway.
* Change: In LayerAssign::RpsInRow::slacken(), do not slacken horizontals
    from M1 vertical terminals when they are tall enough. Arbitrarily
    choose above 6 H-tracks (should be made a configuration parameter).
* Change: In DataNegociate::update(), when processing perpandicular,
    we were taking into account "fixed axis" even when they were
    reduced (so not in tracks). Now do not.
2023-09-28 19:10:19 +02:00
Jean-Paul Chaput 1ae4eb71e2 Fix the support if "iolib" I/O pad.
In CoreToChip, the "iolib" I/O pad library an alternative to the "cmos"
one. "cmos" uses the pxlib library while iolib uses a symbolic abstract
version of the C4M (real) I/O pad.
  The initialization is a bit split as the "cmos" library are part of
Alliance, while "iolib" is in alliance-check-toolkit. So "iolib" is
added at designflow.technos.setupCMOS().
  Setup additional configuration parameter directly in:
    core2chip.niolib.CoreToChip.__init__().
2023-09-28 00:18:10 +02:00
Jean-Paul Chaput db0adbcc02
Merge pull request #41 from lip6/wip-gf180mcu
Wip gf180mcu
2023-09-26 00:30:11 +02:00
Jean-Paul Chaput cfe42bb550 Fix (again) the Contact minimal size in case of "cut" BasicLayer *only*! 2023-09-25 23:51:23 +02:00
Jean-Paul Chaput 9274c21c14 Support for gf180mcu native I/O pads.
* Bug: In CRL/technos.node180.gf180mcu_c4m.iolib.py, remove the VDD and
    VSS ring terminals in the pad as only *some* of the have it.
    Assume that it is a bug from GF. The power rail will still be ok
    as it connect by abutment (with the filler & other I/O pads).
* New: In cumulus.plugins.block.configuration.py, added support for
    iterable I/O pad specifications in ioPads argument.
* New: In cumulus.plugins.core2chip.core2chip.py, add support for
    any number of control signals on I/O pads. Not fully implemented
    yet, as we only allow to hard-wire them either to one or zero.
      Raise an error if _connect() fails to find a master net, so
    we don't fail strangely later...
2023-09-25 23:50:20 +02:00
Jean-Paul Chaput 4420da664e Revert 2633fb54 as it does not work on github/Ubuntu. Bad boost. 2023-09-21 13:19:10 +02:00
Jean-Paul Chaput 2633fb543b Updated for new boost::placeholders. Drop deprecated Qt4 code. 2023-09-21 12:45:20 +02:00
Jean-Paul Chaput 3d8d737aaf Fix use of bitwise and instead of logical one. 2023-09-21 12:19:17 +02:00
Jean-Paul Chaput ad53372253 Fix stupid mistake in designflow.pnr.doTask(), not executing script. 2023-09-21 12:18:18 +02:00
Jean-Paul Chaput c8d98a304e Always check that coreAb fit into coronaAb while building a chip. 2023-09-20 20:15:24 +02:00
Jean-Paul Chaput 6fb0215742 Add the capability to pass a topName to the P&R script in designflow.pnr 2023-09-19 17:51:06 +02:00
Jean-Paul Chaput 09cace5300 Merge branch 'wip-gf180mcu' of github.com:lip6/coriolis into wip-gf180mcu 2023-09-19 16:01:55 +02:00
Jean-Paul Chaput 8f69fa668d More trials on SystemVerilog to Verilog translators.
* New: In designflow.surelog, support for the Synlig Surelog/UHDM plugin
    for Yosys.
* Fix: In designflow.svase, remove the transient file "slang-args.txt".
* Change: In designflow.yosys, remove the direct SystemVerilog support
    that is delegated to Surelog and just load the resulting UHDM.
      Merge with yosysnp and automatically detect if we can load the
    Python plugin or go through a script.
2023-09-19 16:01:00 +02:00
Jean-Paul Chaput 4398770432 Add SystemVerilog support to designflow.yosys. Merge with YosysNp.
* New: In designflow.yosys, add support to load SystemVerilog with the
    synlig plugin (CHIPS Alliance).
      Integrate back the "non-Python" version of the task. Now switch
    automatically between Python & Non-Python based on the availability
    of the plugin. Also select between "yosys" & "yowasp-yosys".
* Change: In svase & sv2v, suppress the requirement of the *first*
    dependency file to be used as the default target. Now use the
    "top module" argument.
2023-09-16 18:12:10 +02:00
Jean-Paul Chaput c35db5387e
Merge branch 'main' into wip-gf180mcu 2023-09-14 12:58:33 +02:00
Jean-Paul Chaput e0c159c07b Only allow BasicLayer of "cut" material to be of width/length 0. 2023-09-14 12:49:28 +02:00
Jean-Paul Chaput efa932a9aa Fix, again, the extensions of PATHTYPE 4 in GdsParser.
Even when we were creating Contacts of null width or height, they where
bumped to the minimal size by the constructor, hence bits sticking out
at the end with Gds PATHTYPE 4. Now, allow null size for non-composite
(which contains a cut) and non-cut Contacts.

* Fix: In GdsParser::readStructure(), always use the bounding box as
    abutment box if the later is empty (case of small sub-components).
    This was making the sub-component seemingly diseapear in the
    viewer...
* Fix: In GdsParser::xyToPath(), slight change in xadjust & yadjust.
* Change: In Contact::create(), force the contact width and height to
    the minimal size *only* if it's a composite layer *or* a basic layer
    of "cut" material.
2023-09-14 10:26:43 +02:00
Jean-Paul Chaput 495939560e Fix ordering of pad spec in cumulus.plugins.chips.pads.Side._placePads().
* Bug: In cumulus.plugins.chips.pads.Side._placePads(), when pads have
    positions they must be reorder *prior* to recomputing the pad
    final position? In order to avoid overlap and ensuring that they are
    on pitch, according to the I/O pad routing gauge.
2023-09-14 10:26:43 +02:00
Jean-Paul Chaput 11618cc647 Fix managment of layer 0 as bounding box in GdsParser.
* Bug: In GdsParser::readStructure(), the Gds::Layer_0_IsBoundary flag
    was not taken into account. The abutment box was always forced to
    the bounding box, resulting in incorrect cell size (and placement).
2023-09-14 10:26:43 +02:00
Jean-Paul Chaput 53f50ee8ca In GdsParser::xyToPath(), bad management of extension for PATHTYPE 4. 2023-09-14 10:26:43 +02:00
Jean-Paul Chaput 48bf2846e1 Fix bug in LefImport that was preventing loading the GDS file (FOREIGN). 2023-09-14 10:26:43 +02:00
Jean-Paul Chaput c55654eb5f Add partial support for SVase and sv2v to the DesignFlow. 2023-09-14 10:26:43 +02:00
Jean-Paul Chaput 2c32dbbf67 Add support for GF180MCU, borrowed from Chips4Makers.
Original source:
    https://gitlab.com/Chips4Makers/c4m-pdk-gf180mcu.git
Duplicated because I needed to do some patches and combine it with
the vendor I/O pads.
2023-09-14 10:26:43 +02:00
Jean-Paul Chaput 8dc13eab5b Better handling of GDS sub-models, now put into separate library.
In order to better handle colliding cell names coming from multiple
GDS files, now, if a topCell is defined, create a sub-library with
the name of that top cell and put any other model from *that* GDS
file into it. This way, only the top cell will be shown in the
library and sub-cells with common names will be separateds.
Work needed for loading GF180MCU I/O pads.

* New: In Gds::setTopCellname(), specify the name of the top cell
    we specifically wants to load from the GDS file.
* New: In GdsStream::getCell(), function to find/create a Cell in
    the current library and, if any, the "top cell" dedicated
    sub-library.
* Change: In GdsStream::readTextBody(), if the layer material of
    the label is "other", do not create a Net with the name of
    the label. This should be a pure text label. Use the new
    Hurricane::Text Go for that.
      Compute the text box in a approximative way. Have to make
    it smarter in the future.
* Change: In LefImport::_macroForeignCbk(), change of policy for
    loading associated GDS. First, we look if a cell with the
    right name exists, in which case we use it. If not, *only*
    then, do we try to load from GDS.
      This allows to load by ourselves, in a separate way the
    GDS. This is more flexible when there are naming issues.
* New: Hurricane::Text Go class, to display text label without the
    need of a Net.
* New: In Hurricane::CellWidget, add support to display
    Hurricane::Text. Add a new mode to drawDisplayText() : FillBox
    so the text is resized to exactly fill the box it is in
    (in width).
2023-09-14 10:26:43 +02:00
Jean-Paul Chaput 8604f4a26d Fix, again, the extensions of PATHTYPE 4 in GdsParser.
Even when we were creating Contacts of null width or height, they where
bumped to the minimal size by the constructor, hence bits sticking out
at the end with Gds PATHTYPE 4. Now, allow null size for non-composite
(which contains a cut) and non-cut Contacts.

* Fix: In GdsParser::readStructure(), always use the bounding box as
    abutment box if the later is empty (case of small sub-components).
    This was making the sub-component seemingly diseapear in the
    viewer...
* Fix: In GdsParser::xyToPath(), slight change in xadjust & yadjust.
* Change: In Contact::create(), force the contact width and height to
    the minimal size *only* if it's a composite layer *or* a basic layer
    of "cut" material.
2023-09-09 12:46:42 +02:00
Jean-Paul Chaput 10c550593e Fix ordering of pad spec in cumulus.plugins.chips.pads.Side._placePads().
* Bug: In cumulus.plugins.chips.pads.Side._placePads(), when pads have
    positions they must be reorder *prior* to recomputing the pad
    final position? In order to avoid overlap and ensuring that they are
    on pitch, according to the I/O pad routing gauge.
2023-09-08 22:02:27 +02:00