aboutsummaryrefslogtreecommitdiffstats
path: root/techlibs/coolrunner2/coolrunner2_fixup.cc
Commit message (Collapse)AuthorAgeFilesLines
* kernel: big fat patch to use more ID::*, otherwise ID(*)Eddie Hung2020-04-021-83/+83
|
* coolrunner2: Attempt to give wires/cells more meaningful namesR. Ou2020-03-021-17/+48
|
* coolrunner2: Fix invalid multiple fanouts of XOR/OR gatesR. Ou2020-03-021-0/+96
| | | | | | | | | | | | | | | | | | | | | | | In some cases where multiple output pins share identical combinatorial logic, yosys would only generate one $sop cell and therefore one MACROCELL_XOR cell to try to feed the multiple sinks. This is not valid, so make the fixup pass duplicate cells when necessary. For example, fixes the following code: module top(input a, input b, input clk_, output reg o, output o2); wire clk; BUFG bufg0 ( .I(clk_), .O(clk), ); always @(posedge clk) o = a ^ b; assign o2 = a ^ b; endmodule
* coolrunner2: Fix packed register+input buffer insertionR. Ou2020-03-021-2/+84
| | | | | The register will be packed with the input buffer if and only if the input buffer doesn't have any other loads.
* coolrunner2: Insert many more required feedthrough cellsR. Ou2020-03-011-36/+186
|
* coolrunner2: Separate and improve buffer cell insertion passR. Ou2020-02-161-0/+161
The new pass will contain all of the logic for inserting "passthrough" product term and XOR cells as appropriate for the architecture. For example, this commit fixes connecting an input pin directly to another output pin with no logic in between.