| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
|
|
|
| |
backends/protobuf/protobuf.cc depends on the source and header files
generated by protoc, but this dependency wasn't explicitly declared. Add
a rule to the Makefile to fix intermittent build failures when the
protobuf header/source file isn't built before protobuf.cc.
|
|
|
|
| |
Fixes #2999.
|
| |
|
|
|
|
|
|
| |
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.
|
| |
|
|\
| |
| | |
cxxrtl: treat wires with multiple defs as not inlinable
|
| |
| |
| |
| | |
Fixes #2883.
|
|/
|
|
|
|
| |
This issue was introduced in commit 4aa65f40 while fixing #2739.
Fixes #2882.
|
|
|
|
|
|
|
|
|
|
|
|
| |
The following VCD file crashes GTKWave's VCD loader:
$var wire 1 ! x:1 $end
$enddefinitions $end
In practice, a colon can be a part of a variable name that is
translated from a Verilog function, something like:
update$func$.../hdl/hazard3_csr.v:350$2534.$result
|
|
|
|
| |
Fixes #2877.
|
|
|
|
| |
Fixes #2739 (again).
|
|\
| |
| | |
cxxrtl: run hierarchy pass regardless of (*top*) attribute presence
|
| |
| |
| |
| |
| |
| |
| | |
The hierarchy pass does a lot more than just finding the top module,
mainly resolving implicit (positional, wildcard) module connections.
Fixes #2589.
|
|\ \
| | |
| | | |
cxxrtl: emit debug items for unused public wires
|
| |/
| |
| |
| |
| |
| | |
This greatly improves debug information coverage.
Fixes #2500.
|
|/
|
|
|
|
| |
Ports can be connected to constants, too. (Usually resets.)
Fixes #2521.
|
|
|
|
|
|
|
|
|
|
| |
Public wires may alias buffered internal wires, so keep BUFFERED
wires in debug information even if they are private. Debug items are
only created for public wires, so this does not otherwise affect how
debug information is emitted.
Fixes #2540.
Fixes #2841.
|
|
|
|
| |
Fixes #2739.
|
|
|
|
|
|
|
| |
While this helper is already useful to squash sequential initializations
into one in cxxrtl, its main purpose is to squash overlapping masked memory
initializations (when they land) and avoid having to deal with them in
cxxrtl runtime.
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
| |
This *only* does conversion, but doesn't add any new functionality —
support for memory read port init/reset is still upcoming.
|
|
|
|
| |
Signed-off-by: Claire Xenia Wolf <claire@clairexen.net>
|
|
|
|
|
|
|
|
| |
s/((Claire|Xen|Xenia|Clifford)\s+)+(Wolf|Xen)\s+<(claire|clifford)@(symbioticeda.com|clifford.at|yosyshq.com)>/Claire Xenia Wolf <claire@yosyshq.com>/gi;
s/((Nina|Nak|N\.)\s+)+Engelhardt\s+<nak@(symbioticeda.com|yosyshq.com)>/N. Engelhardt <nak@yosyshq.com>/gi;
s/((David)\s+)+Shah\s+<(dave|david)@(symbioticeda.com|yosyshq.com|ds0.me)>/David Shah <dave@ds0.me>/gi;
s/((Miodrag)\s+)+Milanovic\s+<(miodrag|micko)@(symbioticeda.com|yosyshq.com)>/Miodrag Milanovic <micko@yosyshq.com>/gi;
s,https?://www.clifford.at/yosys/,http://yosyshq.net/yosys/,g;
|
|
|
|
|
|
| |
This essentially adds wide port support for free in passes that don't
have a usefully better way of handling wide ports than just breaking
them up to narrow ports, avoiding "please run memory_narrow" annoyance.
|
| |
|
| |
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
|
| |
There will soon be more (versioned) memory cells, so handle passes that
only care if a cell is memory-related by a simple helper call instead of
a hardcoded list.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
* xilinx: add SCC test for DSP48E1
* xilinx: Gate DSP48E1 being a whitebox behind ALLOW_WHITEBOX_DSP48E1
Have a test that checks it works through ABC9 when enabled
* abc9 to break SCCs using $__ABC9_SCC_BREAKER module
* Add test
* abc9_ops: remove refs to (* abc9_keep *) on wires
* abc9_ops: do not bypass cells in an SCC
* Add myself to CODEOWNERS for abc9*
* Fix compile
* abc9_ops: run -prep_hier before scc
* Fix tests
* Remove bug reference pending fix
* abc9: fix for -prep_hier -dff
* xaiger: restore PI handling
* abc9_ops: -prep_xaiger sigmap
* abc9_ops: -mark_scc -> -break_scc
* abc9: eliminate hard-coded abc9.box from tests
Also tidy up
* Address review
|
|
|
|
| |
Fixes #2646 fallout.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Previously, memories were silently discarded by the JSON backend, making
round-tripping modules with them crash.
Since there are already some users using JSON to implement custom
external passes that use memories (and infer width/size from memory
ports), let's fix this by just making JSON backend and frontend support
memories as first-class objects.
Processes are still not supported, and will now cause a hard error.
Fixes #1908.
|
|\
| |
| | |
CXXRTL: some -noproc fixes
|
| |
| |
| |
| |
| | |
These are commonly the result of tying an async reset to an inactive
level.
|
| |
| |
| |
| |
| | |
These can be produced from `always @*` processes, if `-noproc`
is used.
|
| | |
|
|/ |
|
|\
| |
| | |
cxxrtl: follow aliases to outlines when emitting $memrd.ADDR
|
| | |
|
|\ \
| | |
| | | |
cxxrtl: add pass debug flag to show assigned wire types
|
| |/
| |
| |
| | |
Refs #2543.
|
|/ |
|
| |
|
|\
| |
| | |
cxxrtl: do not use `->template` for non-dependent names
|