Releases: llvm/circt
Releases · llvm/circt
Sifive 0.2.0
Weekly snapshot for Sifive use.
What's Changed
- [Tests] Added Icarus Verilog test harness by @nandor in #2739
- Track LLVM commits by @GeorgeLyon in #2801
- Update LLVM by @youngar in #2813
- [LLHD] Refactor enum class and move header file locations. by @DeepFlyingSky in #2805
- [Moore] Add concat expression by @fabianschuiki in #2799
- [FIRRTL] Use the new dutModuleName attribute for root of port target. by @mikeurbach in #2817
- [FIRRTL] Fix port symbol creation logic edge case in LowerTypes. by @mikeurbach in #2819
- [Support] Extract ValueMapper to separate support file by @mortbopet in #2725
- [LLHD] Refactor struct Time with class Time. by @DeepFlyingSky in #2814
- [Moore] Add shift expressions by @maerhart in #2812
- [SV] Use Better Named Wires When Possible by @seldridge in #2821
- [MSFT] Systolic Arrays -- high level model by @teqdruid in #2822
- [HW] Support hw.instance of modules with parametric in/out types by @mortbopet in #2823
- [ExportVerilog] Printed nested
else
-if
ops aselse if
by @nandor in #2776 - [FIRRTL][HW] Added module visibility attributes by @nandor in #2816
- [Moore] Add types to C API by @maerhart in #2827
- [PyCDE] Add SystolicArray construct by @teqdruid in #2831
- [ExportVerilog] Make module portlist one name per line, more like humans often do. by @darthscsi in #2824
- [ExportVerilog] explicitBitcastAddMul all add/mul by @seldridge in #2832
- [FIRRTL][Dedup] Don't dump the circuit on errors by @youngar in #2834
- [FIRRTL][Dedup] Delay fixup of connects by @youngar in #2830
Full Changelog: sifive/0/1/0...sifive/0/2/0
SiFive-v0.1.0
This release covers accumulated bug fixes after the 0.0.9 release from running CIRCT on a matrix of internal designs.
What's Changed
- use
hasVerifier
instead ofverifier
by @DeepFlyingSky in #2775 - [FIRRTL][InstanceGraph] Add missing implementation of
addModule()
by @youngar in #2786 - Bump LLVM to 1ebf1afb4ff by @nandor in #2789
- [FIRRTL] Parse nonlocal annotations on ports correctly by @prithayan in #2792
- [NFC] Rename dump method with toString method by @DeepFlyingSky in #2797
- [HW] GlobalRefOp performance enhancement by @teqdruid in #2796
- [FIRRTL] Put Grand Central Black Boxes in Correct Directories by @seldridge in #2798
- [FIRRTL] Infer type of mux with aggregate operands by @fabianschuiki in #2807
- [FIRRTL] Cleaned up verifiers for connects by @nandor in #2765
- [FIRRTL] Verified types for RegOp and RegResetOp by @nandor in #2741
- [FIRParser] Expand and remove partial connects at parse time by @youngar in #2793
- [PrepareForEmission] Add max expression size before creating a wire. by @mikeurbach in #2795
- [ExportVerilog] Add explicit bitcast for width mismatch LINT errors by @prithayan in #2756
- [MSFT] [PyCDE] Make placement DB global rather than rooted by @teqdruid in #2804
Full Changelog: sifive/0/0/9...sifive/0/1/0
SiFive-v0.0.9
This release covers accumulated bug fixes after the 0.0.8 release from running CIRCT on a matrix of internal designs.
What's Changed
- [HandshakeToHW] Initial commit for handshake-to-hw by @mortbopet in #2680
- [Handshake] Generate dialect documentation #2677 by @mortbopet in #2697
- [LLHD] Fix SigArrayGetOp canonicalization by @maerhart in #2698
- Bump LLVM, Remove Duplicate Handshake Verification by @seldridge in #2702
- [PyCDE] Implement new DynamicInstance operation methodology by @teqdruid in #2683
- [Handshake] Make BufferOp sequential attribute a StrEnumAttr attribute by @DeepFlyingSky in #2670
- Add IDE configuration for CLion by @sequencer in #2679
- Add NLATable analysis and use it in PrefixModules by @darthscsi in #2695
- [FIRRTL][RemoveUnusedPorts] Support strictconnect by @uenoku in #2700
- [HW] Allow hw::IntType in hw::isHWIntegerType by @mortbopet in #2701
- [FIRRTL] Fix GCT Data Tap Bug by @seldridge in #2711
- [FIRRTL][Dedup] Fix issue with NLAs on ExtModule ports by @youngar in #2714
- [LowerToHW] Guard out-of-bounds multi-bit mux by @seldridge in #2716
- [reduce] Make reducer NLA aware by @fabianschuiki in #2715
- [FIRTL][Annotations] Fix issue when module name matches inner name by @youngar in #2717
- [FIRRTL][Dedup] Include port types in ext module hashing by @youngar in #2721
- [FIRRTL] Properly handle analog types w/ NamePreservation option by @youngar in #2723
- [Moore] Add SystemVerilog types by @fabianschuiki in #2699
- [HW] Add port dir flip function, make
PortDirection
an enum class; NFC by @fabianschuiki in #2726 - [Moore] Omit wrapper types where unique by @maerhart in #2729
- [FIRRTL] Add more tests for NamePreservation by @youngar in #2724
- [LowerToHW] Don't extract TestHarness verif bboxes by @seldridge in #2732
- [FIRRTL][Dedup] Get a module's name before deleting it by @youngar in #2734
- [FIRRTL][LowerTypes] Fix std::lower_bound usage by @youngar in #2736
- [FIRRTL][NLATable] Fix invalidated reference after growing a DenseMap by @youngar in #2738
- [FIRRTL][WireDFT] Fix invalidated reference from growing DenseMap by @youngar in #2735
- [FIRRTL][ExpandWhens] Improve location tracking while lowering by @youngar in #2742
- [SV] Add a File Descriptor parameter to FWriteOp by @nandor in #2737
- [LLHD] Process Lowering: support muxed signals by @maerhart in #2720
- [HandshakeToFIRRTL]: Add support for signed ops by @Dinistro in #2730
- [HW] Add port modification for module-like ops by @fabianschuiki in #2727
- [LLHD] Allow instantiation of hw.module by @maerhart in #2743
- [FIRRTL] Add signalPassFailure to LowerToHW and exit early. by @mikeurbach in #2745
- [FIRRTL] Don't lower types for invalid durring parsing. by @darthscsi in #2731
- [NFC] silence warning by @darthscsi in #2754
- InferReset generates strict connects by @darthscsi in #2753
- [FIRRTL][OMIR] Don't assume NLA's have an absolute path by @youngar in #2747
- [HW][ExportModuleHierarchy] Allow multiple output files per module by @youngar in #2752
- [LLHD] Add output operation by @maerhart in #2762
- Bump LLVM to 61814586 by @fabianschuiki in #2758
- [HWMemSimImpl] Add Memory Randomization by @seldridge in #2757
- [FIRRTL] Emitted PartialConnect instead of Connect for mismatched types by @nandor in #2764
- [FIRRTL] Fixed issue with undefined registers in HWMemSim by @nandor in #2769
- [FIRRTL][Inliner] Filter non-local annos by the instance path by @youngar in #2770
- [GCT] Create the proper XMR for GCT memtaps by @prithayan in #2771
- [HW] Add clog2 parameter expression by @trilorez in #2766
- [FIRRTL][Inliner] Fix NLA filtering on symbol collision by @youngar in #2777
- [FIRParser] Don't bulk connect bundles with analog in them by @youngar in #2778
- [Calyx] SCFToCalyx generates zero-width memref address ports for memrefs with size 1 dims by @makslevental in #2661
- [IMCONSTPROP] Only merge the reset value into a register if the enabl… by @darthscsi in #2780
- [InferReadWrite] Identify StrictConnectOp patterns along with ConnectOp by @prithayan in #2783
- [FIRRTL][LowerToHW] Find the DUT in a prepass by @youngar in #2784
New Contributors
- @nandor made their first contribution in #2737
- @Dinistro made their first contribution in #2730
- @makslevental made their first contribution in #2661
Full Changelog: sifive/0/0/8...sifive/0/0/9
Sifive 0.0.8 release
[FIRRTL] Preserve/Tap all "Named" Nodes or Wires (#2676) Change end-to-end FIRRTL compilation behavior to preserve (via tapping) all nodes and wires which are "named". A "named" node or wire is one whose name does not begin with an underscore. Tapping is done by creating a "shadow node" that is assigned the value of the actual wire and marked "don't touch". This is done to enable better debug-ability of Chisel designs by enabling users to always have references to named things they define in Chisel. More specifically, anytime a Chisel user defines a `val foo = <expression>`, CIRCT will now produce a wire called "foo" in the output Verilog. Add a parser option for controlling whether or not "named" wires and nodes will be preserved from FIRRTL to Verilog. Add a firtool command-line option for disabling name preservation during FIRRTL parsing. Signed-off-by: Schuyler Eldridge <[email protected]>
Sifive-v0.0.7
Internal Sifive release.
Sifive-v0.0.6
Internal sifive checkpoint release
Sifive-v0.0.5
Internal sifive checkpoint release
Sifive-v0.0.4
Sifive Internal Checkpoint.
Sifive-v0.0.3
Sifive internal checkpoint
Sifive-v0.0.2
Testing tag for sifive-internal packaging.