|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | | | |  | 
| | | | |  | 
| |/ / |  | 
| | | 
| | 
| | 
| | 
| | | If a local variable is always assigned before it is used, then adding
nosync prevents latches from being needlessly generated. | 
| | | |  | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | | I also removed the unnecessary shadowing of `width_hint` and `sign_hint`
in the corresponding case in `simplify()`. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | The preprocessor currently destroys double slash containing escaped
identifiers (for example \a//b ). This is due to next_token trying to
convert single line comments (//) into /* */ comments. This then leads
to an unintuitive error message like this:
ERROR: syntax error, unexpected '*'
This patch fixes the error by recognizing escaped identifiers and
returning them as single token. It also adds a testcase. | 
| | | 
| | 
| | 
| | | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| |\ \  
| | | 
| | | | Fix verific import of enum values with x and/or z | 
| | | | 
| | | 
| | | 
| | | | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| | | | 
| | | 
| | | | Ad-hoc fixes/improvements | 
| |/ / |  | 
| |/ |  | 
| | 
| 
| | Signed-off-by: Kamil Rakoczy <krakoczy@antmicro.com> | 
| | |  | 
| | 
| 
| 
| | Signed-off-by: Kamil Rakoczy <krakoczy@antmicro.com> | 
| | 
| 
| 
| | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| | 
| 
| 
| | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| | |  | 
| | 
| 
| 
| | This reverts commit b8624ad2aef941776f5b4a08f66f8d43e70f8467. | 
| | 
| 
| 
| 
| 
| 
| 
| | - Attempt to lookup a derived module if it potentially contains a port
  connection with elaboration ambiguities
- Mark the cell if module has not yet been derived
- This can be extended to implement automatic hierarchical port
  connections in a future change | 
| | 
| 
| 
| 
| | This will enable other features to use same core logic for replacing an
existing AstModule with a newly elaborated version. | 
| | |  | 
| | 
| 
| 
| | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| | 
| 
| 
| | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| | |  | 
| | |  | 
| |\  
| | 
| | | Add support for $aldff flip-flops to verific importer | 
| | | 
| | 
| | 
| | | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| | | 
| | 
| | 
| | | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| | | 
| | 
| | 
| | | Signed-off-by: Claire Xenia Wolf <claire@clairexen.net> | 
| |/ |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Yosys works with bison 3.0 (or newer), but not bison 2.7 (the previous
release). Ideally, we would require "3" rather than "3.0" to give a
better error message, but bison 2.3, which still ships with macOS, does
not support major-only version requirements. With this change, building
with an outdated bison yields: `frontends/rtlil/rtlil_parser.y:25.10-14:
require bison 3.0, but have 2.3`. | 
| |\  
| | 
| | | Fix "make vgtest" | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | | This enables the usage of declarations of wand or wor with a base type
of logic, integer, or a typename. Note that declarations of nets with
2-state base types is still permitted, in violation of the spec. | 
| |/  
|   
|   
|   
|   
|   
|   
| | - Root AST_PREFIX nodes are now subject to genblk expansion to allow
  them to refer to a locally-visible generate block
- Part selects on AST_PREFIX member leafs can now refer to generate
  block items (previously would not resolve and raise an error)
- Add source location information to AST_PREFIX nodes | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | This is accomplished by generating a unique name for the genvar,
renaming references to the genvar only in the loop's initialization,
guard, and incrementation, and finally adding a localparam inside the
loop body with the original name so that the genvar can be shadowed as
expected. | 
| | 
| 
| 
| 
| | In line with other tools, this adds an extra wrapping block around such
for loops to appropriately scope the variable. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - 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 | 
| | |  | 
| | 
| 
| 
| 
| 
| | These are, by the standard, just aliases for wire/wand/wor.
Fixes #2918. | 
| | |  | 
| | |  |