| Commit message (Collapse) | Author | Age | Files | Lines |
|\
| |
| | |
gowin: Use local aliases
|
|/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
In the Gowin chips, the tiles are connected to each other by a one-hop
wire, among others. There are 4 one-hop wires, of which 2 are shared
between north/south and east/west, have three names: e.g. SN10 and N110
and S110.
But only one of them, the first, occurs as a sink for PIP, that is, you
can not get a route that would pass through the S110 for example.
This commit corrects the names to SN?0 and EW?0 at the wire creation
stage to avoid dead wires.
In addition, the SN?0 and EW?0 are among the few sinks for global clock
wires and now there is the possibility of a more optimal clock routing.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
|
|\
| |
| | |
gowin: Add support for long wires
|
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| | |
Gowin chips have a highly sophisticated system of long wires that are
wired to each cell and allow the clock or logic to spread quickly.
This commit implements some of the capabilities of the long wire system
for quadrants, leaving out the fine-tuning of them for each column.
To make use of the long wire system, the specified wire is cut at the
driver and a special cell is placed between the driver and the rest of
the wire.
* VCC and GND can not use long wires because they are in every cell and
there is no point in using a net
* Long wire numbers can be specified manually or assigned automatically.
* The route from the driver to the port of the new cell can be quite
long, this will have to be solved somehow.
* It might make sense to add a mechanism for automatically finding
candidates for long wires.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
|
|\ \
| | |
| | | |
Change write_dcc to work with tilegroups from prjoxide
|
| |/
| |
| |
| | |
Signed-off-by: Maciej Dudek <mdudek@antmicro.com>
|
|\ \
| | |
| | | |
Don't assert on mixed domain paths in report
|
|/ /
| |
| |
| | |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\ \
| |/
|/| |
Bump minimum CMake to 3.13
|
|/ |
|
|\
| |
| | |
[interchange] Tying unused LUT inputs according to architecture
|
| |
| |
| |
| |
| |
| | |
specify one.
Signed-off-by: Maciej Kurc <mkurc@antmicro.com>
|
| |
| |
| |
| | |
Signed-off-by: Maciej Kurc <mkurc@antmicro.com>
|
|/
|
|
| |
Signed-off-by: Maciej Kurc <mkurc@antmicro.com>
|
|\
| |
| | |
common: Correct a minor typo in the message
|
|/
|
|
| |
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
|
|\
| |
| | |
ice40: Fix propagation of constraints through SB_GB
|
|/
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
gowin: Add initial syntax support for long wires
|
| |
| |
| |
| |
| |
| |
| | |
Only the recognition of the directive in the .CST file and elementary
checks are added, but not the long-wire mechanism itself.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
|
|/
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
prefine: Do full-tile swaps, too
|
|/
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
Move general parallel detail place code out of parallel_refine
|
|/
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
ice40: Avoid chain finder from mixing up chains by only allowing I3 c…
|
|/
|
|
|
|
| |
at end
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
ci: Restructure and move entirely to GH actions from Cirrus
|
| |
| |
| |
| | |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\|
| |
| | |
Split up common into kernel,place,route
|
|/
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
ecp5: Split the SLICE bel into separate LUT/FF/RAMW bels
|
| | |
|
|\ \
| |/
|/| |
cmake: properly include TBB libraries.
|
|/ |
|
|
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
gowin: handle the GW1N-9 feature.
|
|/
|
|
|
|
|
|
| |
This chip has a different default state for one type of I/O buffer ---
you have to explicitly switch it to the normal state by feeding VCC/VSS
to certain inputs.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
|
|
|
|
| |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\
| |
| | |
ice40: Fix wirenames containing / which is the list separator
|
| |
| |
| |
| | |
Signed-off-by: gatecat <gatecat@ds0.me>
|
|\ \
| |/
|/| |
gowin: Fix z-index of oscillator
|
|/ |
|
|\
| |
| | |
Nexus: Fixed OSCA parameters, add pll default parameters
|
| |
| |
| |
| |
| |
| |
| |
| |
| | |
Add new definition for parse_lattice_param
Now parse_lattice_param is design to parse Property rather than search for it in cell.
This functionalty was move to parse_lattice_param_from_cell.
Signed-off-by: Maciej Dudek <mdudek@antmicro.com>
|
| |
| |
| |
| | |
Signed-off-by: Maciej Dudek <mdudek@antmicro.com>
|
|\ \
| | |
| | | |
ice40: Merge driving LUT<=2s into carry-only LCs
|
| | |
| | |
| | |
| | | |
Signed-off-by: gatecat <gatecat@ds0.me>
|