aboutsummaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* Fix typo in passes/pmgen/README.mdClifford Wolf2019-02-211-1/+1
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Bugfix in ice40_dspClifford Wolf2019-02-213-22/+35
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Add ice40 test_dsp_map test case generatorClifford Wolf2019-02-202-0/+99
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Add "synth_ice40 -dsp"Clifford Wolf2019-02-202-7/+31
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Add FF support to wreduceClifford Wolf2019-02-202-1/+73
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Improve iCE40 SB_MAC16 modelClifford Wolf2019-02-205-121/+179
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Detect and reject cases that do not map well to iCE40 DSPs (yet)Clifford Wolf2019-02-202-2/+17
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Add first draft of functional SB_MAC16 modelClifford Wolf2019-02-194-53/+467
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Add actual DSP inference to ice40_dsp passClifford Wolf2019-02-173-24/+214
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Merge branch 'master' of github.com:YosysHQ/yosys into pmgenClifford Wolf2019-02-1728-199/+627
|\
| * Merge pull request #811 from ucb-bar/firrtlfixesClifford Wolf2019-02-176-56/+298
| |\ | | | | | | Update cells supported for verilog to FIRRTL conversion.
| | * Removed unused variables, functions.Jim Lawson2019-02-151-20/+0
| | |
| | * Append (instead of over-writing) EXTRA_FLAGSJim Lawson2019-02-151-1/+1
| | |
| | * Update cells supported for verilog to FIRRTL conversion.Jim Lawson2019-02-155-55/+317
| |/ | | | | | | | | | | | | | | | | | | | | | | | | Issue warning messages for missing parameterized modules and attempts to set initial values. Replace simple "if (cell-type)" with "else if" chain. Fix FIRRTL shift handling. Add support for parameterized modules, $shift, $shiftx. Handle default output file. Deal with no top module. Automatically run pmuxtree pass. Allow EXTRA_FLAGS and SEED parameters to be set in the environment for tests/tools/autotest.mk. Support FIRRTL regression testing in tests/tools/autotest.sh Add xfirrtl files to test directories to exclude files from FIRRTL regression tests that are known to fail.
| * Fix sign handling of real constantsClifford Wolf2019-02-131-5/+4
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
| * Merge pull request #802 from whitequark/write_verilog_async_mem_portsClifford Wolf2019-02-121-38/+41
| |\ | | | | | | write_verilog: correctly emit asynchronous transparent ports
| | * write_verilog: correctly emit asynchronous transparent ports.whitequark2019-01-291-38/+41
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit fixes two related issues: * For asynchronous ports, clock is no longer added to domain list. (This would lead to absurd constructs like `always @(posedge 0)`. * The logic to distinguish synchronous and asynchronous ports is changed to correctly use or avoid clock in all cases. Before this commit, the following RTLIL snippet (after memory_collect) cell $memrd $2 parameter \MEMID "\\mem" parameter \ABITS 2 parameter \WIDTH 4 parameter \CLK_ENABLE 0 parameter \CLK_POLARITY 1 parameter \TRANSPARENT 1 connect \CLK 1'0 connect \EN 1'1 connect \ADDR \mem_r_addr connect \DATA \mem_r_data end would lead to invalid Verilog: reg [1:0] _0_; always @(posedge 1'h0) begin _0_ <= mem_r_addr; end assign mem_r_data = mem[_0_]; Note that there are two potential pitfalls remaining after this change: * For asynchronous ports, the \EN input and \TRANSPARENT parameter are silently ignored. (Per discussion in #760 this is the correct behavior.) * For synchronous transparent ports, the \EN input is ignored. This matches the behavior of the $mem simulation cell. Again, see #760.
| * | Merge pull request #806 from daveshah1/fsm_opt_no_resetClifford Wolf2019-02-121-1/+2
| |\ \ | | | | | | | | fsm_opt: Fix runtime error for FSMs without a reset state
| | * | fsm_opt: Fix runtime error for FSMs without a reset stateDavid Shah2019-02-071-1/+2
| |/ / | | | | | | | | | Signed-off-by: David Shah <dave@ds0.me>
| * / Add missing blackslash-to-slash convertion to smtio.py (matching ↵Clifford Wolf2019-02-061-1/+1
| |/ | | | | | | | | | | Smt2Worker::get_id() behavior) Signed-off-by: Clifford Wolf <clifford@clifford.at>
| * Merge pull request #798 from mmicko/masterClifford Wolf2019-01-271-1/+1
| |\ | | | | | | Fixed Anlogic simulation model
| | * Fixed Anlogic simulation modelMiodrag Milanovic2019-01-251-1/+1
| | |
| * | Merge pull request #800 from whitequark/write_verilog_tribufClifford Wolf2019-01-271-0/+12
| |\ \ | | | | | | | | write_verilog: write $tribuf cell as ternary
| | * | write_verilog: write $tribuf cell as ternary.whitequark2019-01-271-0/+12
| | | |
| * | | Merge branch 'whitequark-write_verilog_keyword'Clifford Wolf2019-01-275-69/+27
| |\ \ \ | | |/ / | |/| |
| | * | Remove asicworld tests for (unsupported) switch-level modellingClifford Wolf2019-01-274-69/+0
| | | | | | | | | | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
| | * | write_verilog: escape names that match SystemVerilog keywords.whitequark2019-01-271-0/+27
| |/ /
| * | Merge pull request #796 from whitequark/proc_clean_typoDavid Shah2019-01-251-1/+1
| |\ \ | | |/ | |/| proc_clean: fix critical typo
| | * proc_clean: fix critical typo.whitequark2019-01-231-1/+1
| |/
| * Merge pull request #793 from whitequark/proc_clean_fix_fully_defClifford Wolf2019-01-191-1/+7
| |\ | | | | | | proc_clean: fix fully def check to consider compare/signal length
| | * proc_clean: fix fully def check to consider compare/signal length.whitequark2019-01-181-1/+7
| |/ | | | | | | Fixes #790.
| * Cleanups in igloo2 example designClifford Wolf2019-01-176-7/+4
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
| * Add SF2 IO buffer insertionClifford Wolf2019-01-176-3/+171
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
| * Improve Igloo2 exampleClifford Wolf2019-01-178-22/+41
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
| * Add "synth_sf2 -vlog", fix "synth_sf2 -edif"Clifford Wolf2019-01-171-2/+17
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
| * Add "write_edif -gndvccy"Clifford Wolf2019-01-171-5/+13
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* | Progress in pmgenClifford Wolf2019-01-151-3/+11
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* | Progress in pmgen, add pmgen READMEClifford Wolf2019-01-153-14/+260
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* | Fix pmgen "reject" statementClifford Wolf2019-01-151-1/+1
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* | Progress in pmgenClifford Wolf2019-01-153-36/+139
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* | Progress in pmgenClifford Wolf2019-01-153-21/+157
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* | Progress in pmgenClifford Wolf2019-01-155-8/+347
| | | | | | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* | Add mockup .pmg (pattern matcher generator) fileClifford Wolf2019-01-151-0/+75
|/ | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Add optional nullstr argument to log_id()Clifford Wolf2019-01-151-1/+3
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Fix handling of $shiftx in Verilog back-endClifford Wolf2019-01-151-3/+6
| | | | Signed-off-by: Clifford Wolf <clifford@clifford.at>
* Merge pull request #788 from whitequark/masterClifford Wolf2019-01-151-5/+17
|\ | | | | Document $tribuf and some gates
| * manual: document some gates.whitequark2019-01-141-9/+11
| |
| * manual: explain $tribuf cell.whitequark2019-01-141-0/+10
| |
* | Merge pull request #787 from whitequark/flowmap_relaxClifford Wolf2019-01-157-35/+776
|\ \ | |/ |/| flowmap: implement depth relaxation
| * flowmap: clean up terminology.whitequark2019-01-081-17/+18
| | | | | | | | | | | | | | | | | | | | * "map": group gates into LUTs; * "pack": replace gates with LUTs. This is important because we have FlowMap and DF-Map, and currently our messages are ambiguous. Also clean up some other log messages while we're at it.