|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | Mutating the SigMap by adding a new connection will throw off FfInitVals
index.  Work around this by removing the relevant init values from index
whenever we connect nets, then re-add the new init value.
Should fix #2920. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Previously, opt_clean would reconnect all ports (including FF Q ports)
to a "canonical" SigBit chosen by complex rules, but would leave the
init attribute on the old wire.  This change applies the same
canonicalization rules to the init attributes, ensuring that init moves
to wherever the Q port moved.
Part of another jab at #2920. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | * deal with active-low tristate
* remove empty port
* update sim models
* add expected lut1 to tests | 
| |\  
| | 
| | | Make Verific extensions optional | 
| |/ |  | 
| | |  | 
| | 
| 
| 
| | Signed-off-by: Sylvain Munaut <tnt@246tNt.com> | 
| | |  | 
| | 
| 
| 
| | Fixes #2967. | 
| | |  | 
| | 
| 
| 
| | Fixes #2962. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This code now takes the AST nodes of type AST_BIND and generates a
representation in the RTLIL for them.
This is a little tricky, because a binding of the form:
    bind baz foo_t foo_i (.arg (1 + bar));
means "make an instance of foo_t called foo_i, instantiate it inside
baz and connect the port arg to the result of the expression 1+bar".
Of course, 1+bar needs a cell for the addition. Where should that cell
live?
With this patch, the Binding structure that represents the construct
is itself an AST::AstModule module. This lets us put the adder cell
inside it. We'll pull the contents out and plonk them into 'baz' when
we actually do the binding operation as part of the hierarchy pass.
Of course, we don't want RTLIL::Binding to contain an
AST::AstModule (since kernel code shouldn't depend on a frontend), so
we define RTLIL::Binding as an abstract base class and put the
AST-specific code into an AST::Binding subclass. This is analogous to
the AST::AstModule class. | 
| | 
| 
| 
| | If all of us are wide, then none of us are! | 
| | 
| 
| 
| | This unlocks wide port recognition by default. | 
| | |  | 
| | |  | 
| |\  
| | 
| | | logger: Add -check-expected subcommand. | 
| | | 
| | 
| | 
| | 
| | | This allows us to have multiple "expect this warning" calls in a single
long script, covering only as many passes as necessary. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | - User-defined types must be data types. Using a net type (e.g. wire) is
  a syntax error.
- User-defined types without a net type are always variables (i.e.
  logic).
- Nets and variables can now be explicitly declared using user-defined
  types:
    typedef logic [1:0] W;
    wire W w;
    typedef logic [1:0] V;
    var V v;
Fixes #2846 | 
| | | |  | 
| |/  
|   
|   
| | This fixes wide port recognition in some cases. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | These parts keep rereading a Verilog module, then using chparam
to test it with various parameter combinations.  Since the default
parameters are on the large side, this spends a lot of time
needlessly elaborating the default parametrization that will then
be discarded.  Fix it with -deref and manual hierarchy call.
Shaves 30s off the test time on my machine. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This also aligns the functionality:
- in all cases, the onehot attribute is used to create appropriate
  constraints (previously, opt_dff didn't do it at all, and share
  created one-hot constraints based on $pmux presence alone, which
  is unsound)
- in all cases, shift and mul/div/pow cells are now skipped when
  importing the SAT problem (previously only memory_share did this)
  — this avoids creating clauses for hard cells that are unlikely
  to help with proving the UNSATness needed for optimization | 
| | |  | 
| | 
| 
| 
| | Partial #2920 fix. | 
| | |  | 
| | 
| 
| 
| 
| 
| | These are, by the standard, just aliases for wire/wand/wor.
Fixes #2918. | 
| | |  | 
| | 
| 
| 
| | Fixes #2912. | 
| | |  | 
| | 
| 
| 
| | Fixes #2907. | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| | This mode will be used whenever read port cannot be handled in the
"extract address register" way, ie. whenever it has enable, reset,
init functionality or (in the future) mixed transparency mask. | 
| | 
| 
| 
| 
| 
| | This will make more sense when the new transparency masks land.
Fixes #2902. |