Changelog for clash-lib-1.0.0
Changelog for the clash-lib package
1.0.0 September 3rd 2019
- 
10x - 50x faster compile times 
- 
New features: - API changes: check the migration guide at the end of Clash.Tutorial
- All memory elements now have an (implicit) enable line; "Gated" clocks have been removed as the clock wasn't actually gated, but implemented as an enable line.
- Circuit domains are now configurable in:
- 
(old) The clock period 
- 
(new) Clock edge on which memory elements latch their inputs (rising edge or falling edge) 
- 
(new) Whether the reset port of a memory element is level sensitive (asynchronous reset) or edge sensitive (synchronous reset) 
- 
(new) Whether the reset port of a memory element is active-high or active-low (negated reset) 
- 
(new) Whether memory element power on in a configurable/defined state (common on FPGAs) or in an undefined state (ASICs) 
- 
See the blog post on this new feature 
 
- 
- Data types can now be given custom bit-representations: http://hackage.haskell.org/package/clash-prelude/docs/Clash-Annotations-BitRepresentation.html
- Annotate expressions with attributes that persist in the generated HDL, e.g. synthesis directives: http://hackage.haskell.org/package/clash-prelude/docs/Clash-Annotations-SynthesisAttributes.html
- Control (System)Verilog module instance, and VHDL entity instantiation names in generated code: http://hackage.haskell.org/package/clash-prelude/docs/Clash-Magic.html
- Much improved infrastructure for handling of unknown values: defined spine, but unknown leafs: http://hackage.haskell.org/package/clash-prelude/docs/Clash-XException.html#t:NFDataX
- Experimental: Multiple hidden clocks. Can be enabled by compiling
clash-preludewith-fmultiple-hidden
- Experimental: Limited GADT support (pattern matching on vectors, or custom GADTs as longs as their usage can be statically removed; no support of recursive GADTs)
- Experimental: Use regular Haskell functions to generate HDL black boxes for primitives (in an addition to existing string templates for HDL black boxes) See for example: http://hackage.haskell.org/package/clash-lib/docs/Clash-Primitives-Intel-ClockGen.html
 
- API changes: check the migration guide at the end of 
- 
Fixes issues: - #316
- #319
- #323
- #324
- #329
- #331
- #332
- #335
- #348
- #349
- #350
- #351
- #352
- #353
- #358
- #359
- #363
- #364
- #365
- #371
- #372
- #373
- #378
- #380
- #381
- #382
- #383
- #387
- #393
- #396
- #398
- #399
- #401
- #403
- #407
- #412
- #413
- #420
- #422
- #423
- #424
- #438
- #450
- #452
- #455
- #460
- #461
- #463
- #468
- #475
- #476
- #500
- #507
- #512
- #516
- #517
- #526
- #556
- #560
- #566
- #567
- #569
- #573
- #575
- #581
- #582
- #586
- #588
- #591
- #596
- #601
- #607
- #629
- #637
- #644
- #647
- #661
- #668
- #677
- #678
- #682
- #691
- #703
- #713
- #715
- #727
- #730
- #736
- #738
 
0.99.3 July 28th 2018
- Fixes bugs:
- Evaluator recognizes Bitliterals #329
- Use existential type-variables in context of GADT pattern match
- Do not create zero-bit temporary variables in generated HDL
- Use correct arguments in nested primitives #323
- Zero-constructor data type needs 0 bits #238
- Create empty component when result needs 0 bits
- Evaluator performs BigNat arithmetic
 
- Evaluator recognizes 
0.99.1 May 12th 2018
- Allow ~NAME[N]tag inside~GENSYM[X]
- Support HDL record selector generation #313
0.99 March 31st 2018
- New features:
- Support for clash-prelude-0.99:- Explicit clock and reset arguments
- Overhaul of TopEntityannotations
 
- Hierarchies with multiple synthesisable boundaries by allowing more than one
function in scope to have a Synthesizeannotation.- Local caching of functions with a Synthesizeannotation
 
- Local caching of functions with a 
- Bittype is mapped to a HDL scalar type (e.g.- std_logicin VHDL)
- Improved name preservation
- Zero-bit values are filtered out of the generated HDL
- Improved compile-time computation
 
- Support for 
- Many bug fixes
0.7.1 April 11th 2017
- New features:
- Support distribution of primitive templates with Cabal/Hackage packages commit
- Find memory data files and primitive files relative to import dirs (-i<DIR>)
 
- Fixes bugs:
- case (EmptyCase ty) of ty' { ... }->- EmptyCase ty'#198
- BitVector.split#apply the correct type arguments
 
0.7 January 16th 2017
- New features:
- Support for clash-prelude0.11
- Primitive templates can include QSys files
- VHDL blackboxes: support additional libraries and uses keywords in generated VHDL
- Highly limited Float/Double support (literals and Rationalconversion), hidden behind the-clash-float-supportflag.
 
- Support for 
- Fixes bugs:
0.6.21 August 18th 2016
- Fixes bugs:
- Type families are not currently being reduced correctly #167
 
0.6.20 August 3rd 2016
- Fixes bugs:
- Bug in DEC transformation overwrites case-alternatives
- Bug in DEC transformation creates non-representable let-binders
 
0.6.19 July 19th 2016
- Fixes bugs:
- Rounding error in logBasecalculation
 
- Rounding error in 
0.6.18 July 15th 2016
- New features:
- Better error location reporting
 
- Fixes bugs:
- Values of type Index 'n', where 'n' > 2^MACHINE_WIDTH, incorrectly considered non-synthesisable due to overflow
 
0.6.17 June 9th 2016
- Fixes bugs:
- Eqinstance of- Vecsometimes not synthesisable
 
0.6.16 June 7th 2016
- New features:
- DEC transformation also lifts HO-primitives applied to "interesting" primitives (i.e. zipWith (*))
 
- DEC transformation also lifts HO-primitives applied to "interesting" primitives (i.e. 
- Fixes bugs:
0.6.15 April 7th 2016
- New features:
- Up to 2x reduced compilation times when working with large Vecliterals
 
- Up to 2x reduced compilation times when working with large 
- Fixes bugs:
- Bug in DEC transformation throws CLaSH into an endless loop #140
 
0.6.14 March 21st 2016
- New features:
- Also generate testbench for circuits without input ports #135
 
- Fixes bugs:
- clockWizardbroken #49
 
0.6.13 March 14th 2016
- Fixes bugs:
- Not all lambda's in a function position removed
 
0.6.12 March 14th 2016
- Fixes bugs:
- Not all lambda's in a function position removed due to bad eta-expansion #132
 
0.6.11 March 11th 2016
- New features:
- Add support for HDL synthesis tool specific HDL generation
- Preserve more Haskell names in generated HDL #128
 
0.6.10 February 10th 2016
- New features:
- hdl files can be written to a directory other than the current working directory #125
 
- Fixes bugs:
0.6.9
- Fixes bugs:
0.6.8 January 13th 2015
- New features:
- Support for Haskell's: Char,Int8,Int16,Int32,Int64,Word,Word8,Word16,Word32,Word64.
- Int/Word/Integer bitwidth for generated HDL is configurable using the -clash-intwidth=Nflag, whereNcan be either 32 or 64.
 
- Support for Haskell's: 
- Fixes bugs:
- Cannot reduce case error ... of ...toerror ...#109
 
- Cannot reduce 
0.6.7 December 21st 2015
- Support for unbound-generics-0.3
- New features:
- Only look for 'topEntity' in the root module. #22
 
0.6.6 December 11th 2015
- New features:
- Remove all existing HDL files before generating new ones. This can be disabled by the -clash-nocleanflag. #96
- Support for clash-prelude0.10.4
 
- Remove all existing HDL files before generating new ones. This can be disabled by the 
0.6.5 November 17th 2015
- Fixes bugs:
- Integer literals used as arguments not always properly annotated with their type.
 
0.6.4 November 12th 2015
- Fixes bugs:
0.6.3 October 24th 2015
- New features:
- Improve DEC transformation: consider alternatives before the subject when checking for disjoint expressions.
 
- Fixes bugs:
- DEC: don't generate single-branch case-expressions #90
 
0.6.2 October 21st 2015
- Fixes bugs:
- DEC: Subject and alternatives are not disjoint #88
 
0.6.1 October 16th 2015
- 
New features: - 
Support for clash-prelude0.10.1
- 
Transformation that lifts applications of the same function out of alternatives of case-statements. e.g. case x of A -> f 3 y B -> f x x C -> h xis transformed into: let f_arg0 = case x of {A -> 3; B -> x} f_arg1 = case x of {A -> y; B -> x} f_out = f f_arg0 f_arg1 in case x of A -> f_out B -> f_out C -> h x
 
- 
- 
Fixes bugs: - Case-statements acting like normal decoder circuits are erroneously synthesised to priority decoder circuits.
 
0.6 October 3rd 2015
- New features:
- Support for clash-prelude0.10
- Add ~INDEXTYPEtag: primitives get access to theIndexclash-prelude type
- Add ~IFconstruct: primitives can do conditional templating
- Unroll "definitions" of the following primitives: fold,dfold,foldr
 
- Support for 
0.5.13 September 21st 2015
- Fixes bugs:
- Performance bug: top-level definitions of type "Signal" erroneously inlined.
 
0.5.12 September 14th 2015
- 
New features: - Completely unroll "definitions" of some higher-order primitives with non-representable argument or result vectors:
It is now possible to translate e.g. f xs ys = zipWith ($) (map (+) xs) ys :: Vec 4 Int -> Vec 4 Int -> Vec 4 Int
 
- Completely unroll "definitions" of some higher-order primitives with non-representable argument or result vectors:
It is now possible to translate e.g. 
- 
Fixes bugs: 
0.5.11 September 7th 2015
- Fixes bugs:
- Clash running out of memory on Simple-ish project #70
- CLaSH.Sized.Vector.:>was not allowed as a function argument to HO-primitives
 
0.5.10 August 2nd 2015
- Fixes bugs:
- Make testbench generation deterministic
- Compile against unbound-generics-0.2
 
0.5.9 July 9th 2015
- Fixes bugs:
- coreViewdidn't look through newtypes of the form:- newtype Foo a = MkFoo (Maybe a)
 
0.5.8 June 26th 2015
- Fixes bugs:
- Allow text and tags in ~SIGD black box construct
 
0.5.7 June 25th 2015
- 
New features: - Support for copying string literals from Haskell to generated code
- Collect and copy data-files
 
- 
Fixes bugs: 
0.5.6 June 3rd 2015
- New features:
- Support Verilog backend
- Generated component names are prefixed by the name of the module containing the topEntity
 
0.5.5 May 18th 2015
- 
New features: - Make inlining and specialisation limit configurable
- Make debug message level configurable
 
- 
Fixes bugs: - Netlist: ensure that the arguments of a component instantiation are always simple variables
- CaseCon transformation: ensure that we run the compile-time evaluator on the subject before handling the one-alternative case
- Emit a warning if a function remains recursive, instead of producing an error: compilation can still be successful if the function is an argument to a higher-order blackbox that doesn't use the function.
- Emit a warning if inlining limit is reached, instead of producing an error: compilation can still be successful if the function is an argument to a higher-order blackbox that doesn't use the function.
- Always inline terms that have a type of kind Constraint
 
0.5.4 May 10th 2015
- New features:
- Add ~COMPNAMEtag: primitives get access to the component name in which they are instantiated
 
- Add 
0.5.3 May 5th 2015
- New features:
- TopEntitywrappers are now specified as- ANNannotation pragmas
 
- Fixes bugs:
- Lost system1000 clock in VHDL generation... #53
- flattenCallTreesometimes introduces free variables
 
0.5.2 May 1st 2015
- New features:
- Generate wrappers around topEntitythat have constant names and types
 
- Generate wrappers around 
0.5.1 April 20th 2015
- GHC 7.10 support
0.5 March 11th 2015
- 
New features: 
- 
Fixes bugs: - VHDL generation error: wrapper for sum-of-products type. #44
 
0.4.1 February 4th 2015
- Fixes bugs:
- Treat BlackBox expressions as declarations when DC args. #37
- Don't inline recursive closed bindings
 
0.4 November 17th 2014
- 
New features: - Support for clash-prelude 0.6
 
- 
Fixes bugs: - Ambiguous type: 'std_logic_vector' or 'std_ulogic_vector' #33
 
0.3.2 June 5th 2014
- Fixes bugs:
0.3.1 May 15th 2014
- 
New features: 
- 
Fixes bugs: 
- 
Code improvements: