2016-11-01 11:31:13 +01:00
|
|
|
/*
|
2019-10-28 13:10:12 +01:00
|
|
|
* yosys -- Yosys Open SYnthesis Suite
|
2016-11-01 11:31:13 +01:00
|
|
|
*
|
2021-06-08 00:39:36 +02:00
|
|
|
* Copyright (C) 2012 Claire Xenia Wolf <claire@yosyshq.com>
|
2016-11-01 11:31:13 +01:00
|
|
|
*
|
2019-10-28 13:10:12 +01:00
|
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
2016-11-01 11:31:13 +01:00
|
|
|
*
|
2019-10-28 13:10:12 +01:00
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
2016-11-01 11:31:13 +01:00
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "kernel/register.h"
|
|
|
|
|
#include "kernel/celltypes.h"
|
|
|
|
|
#include "kernel/rtlil.h"
|
|
|
|
|
#include "kernel/log.h"
|
|
|
|
|
|
|
|
|
|
USING_YOSYS_NAMESPACE
|
|
|
|
|
PRIVATE_NAMESPACE_BEGIN
|
|
|
|
|
|
|
|
|
|
struct SynthGowinPass : public ScriptPass
|
|
|
|
|
{
|
|
|
|
|
SynthGowinPass() : ScriptPass("synth_gowin", "synthesis for Gowin FPGAs") { }
|
|
|
|
|
|
2020-06-19 01:34:52 +02:00
|
|
|
void help() override
|
2016-11-01 11:31:13 +01:00
|
|
|
{
|
2019-10-28 13:10:12 +01:00
|
|
|
// |---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|
|
|
|
|
|
log("\n");
|
|
|
|
|
log(" synth_gowin [options]\n");
|
|
|
|
|
log("\n");
|
|
|
|
|
log("This command runs synthesis for Gowin FPGAs. This work is experimental.\n");
|
|
|
|
|
log("\n");
|
|
|
|
|
log(" -top <module>\n");
|
|
|
|
|
log(" use the specified module as top module (default='top')\n");
|
|
|
|
|
log("\n");
|
|
|
|
|
log(" -vout <file>\n");
|
|
|
|
|
log(" write the design to the specified Verilog netlist file. writing of an\n");
|
|
|
|
|
log(" output file is omitted if this parameter is not specified.\n");
|
|
|
|
|
log("\n");
|
2020-11-30 11:43:12 +01:00
|
|
|
log(" -json <file>\n");
|
|
|
|
|
log(" write the design to the specified JSON netlist file. writing of an\n");
|
|
|
|
|
log(" output file is omitted if this parameter is not specified.\n");
|
|
|
|
|
log(" This disables features not yet supported by nexpnr-gowin.\n");
|
|
|
|
|
log("\n");
|
2019-10-28 13:10:12 +01:00
|
|
|
log(" -run <from_label>:<to_label>\n");
|
|
|
|
|
log(" only run the commands between the labels (see below). an empty\n");
|
|
|
|
|
log(" from label is synonymous to 'begin', and empty to label is\n");
|
|
|
|
|
log(" synonymous to the end of the command list.\n");
|
|
|
|
|
log("\n");
|
|
|
|
|
log(" -nodffe\n");
|
|
|
|
|
log(" do not use flipflops with CE in output netlist\n");
|
|
|
|
|
log("\n");
|
Gowin. Reduce the range of flip-flop types.
UG303-1.0E_Arora Ⅴ Configurable Function Unit (CFU) User Guide.pdf
specifies that the only flip-flop types supported in GW5 are DFFSE,
DFFRE, DFFPE, and DFFCE.
However, the bit streams generated by the vendor IDE also contain DFF
flip-flops, which are probably the result of optimisation, so we leave
them in the list of permitted items, but add a flag that will allow the
generation of completely correct output files, acceptable for further P&
R using vendor tools (they will not allow the use of flip-flops other
than the four specified in the netlist).
In the GW5 SemiDual Port BSRAM series, the primitive does not have
RESETA and RESETB ports—they are replaced by the RESET port, so we
separate the files for BSRAM generation, especially since in the future
we may have to take into account other, as yet unexplored, differences
in BSRAM.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
2025-10-11 13:12:35 +02:00
|
|
|
log(" -strict-gw5a-dffs\n");
|
|
|
|
|
log(" use only DFFSE/DFFRE/DFFPE/DFFCE flipflops for the GW5A family\n");
|
|
|
|
|
log("\n");
|
2019-10-28 13:10:12 +01:00
|
|
|
log(" -nobram\n");
|
|
|
|
|
log(" do not use BRAM cells in output netlist\n");
|
|
|
|
|
log("\n");
|
Harmonize BRAM/LUTRAM descriptions across all of Yosys.
This commit:
* renames all remaining instances of "DRAM" (which is ambiguous)
to "LUTRAM" (which is not), finishing the work started in
the commit 698ab9be;
* renames memory rule files to brams.txt/lutrams.txt;
* adds/renames script labels map_bram/map_lutram;
* extracts where necessary script labels map_ffram and map_gates;
* adds where necessary options -nobram/-nolutram.
The end result is that BRAM/LUTRAM/FFRAM aspects of every target
are now consistent with each other.
Per architecture:
* anlogic: rename drams.txt→lutrams.txt, add -nolutram, add
:map_lutram, :map_ffram, :map_gates
* ecp5: rename bram.txt→brams.txt, lutram.txt→lutrams.txt
* efinix: rename bram.txt→brams.txt, add -nobram, add :map_ffram,
:map_gates
* gowin: rename bram.txt→brams.txt, dram.txt→lutrams.txt,
rename -nodram→-nolutram (-nodram still recognized), rename
:bram→:map_bram, :dram→:map_lutram, add :map_ffram, :map_gates
2020-01-01 13:30:00 +01:00
|
|
|
log(" -nolutram\n");
|
2019-10-28 13:10:12 +01:00
|
|
|
log(" do not use distributed RAM cells in output netlist\n");
|
|
|
|
|
log("\n");
|
|
|
|
|
log(" -noflatten\n");
|
|
|
|
|
log(" do not flatten design before synthesis\n");
|
|
|
|
|
log("\n");
|
|
|
|
|
log(" -retime\n");
|
2019-12-30 21:05:52 +01:00
|
|
|
log(" run 'abc' with '-dff -D 1' options\n");
|
2019-10-28 13:10:12 +01:00
|
|
|
log("\n");
|
2019-11-18 14:25:46 +01:00
|
|
|
log(" -nowidelut\n");
|
|
|
|
|
log(" do not use muxes to implement LUTs larger than LUT4s\n");
|
|
|
|
|
log("\n");
|
2019-11-25 14:33:21 +01:00
|
|
|
log(" -noiopads\n");
|
|
|
|
|
log(" do not emit IOB at top level ports\n");
|
2020-04-01 02:07:30 +02:00
|
|
|
log("\n");
|
2020-11-30 11:43:12 +01:00
|
|
|
log(" -noalu\n");
|
|
|
|
|
log(" do not use ALU cells\n");
|
|
|
|
|
log("\n");
|
2023-11-13 16:12:23 +01:00
|
|
|
log(" -noabc9\n");
|
|
|
|
|
log(" disable use of new ABC9 flow\n");
|
2019-11-18 14:25:46 +01:00
|
|
|
log("\n");
|
2022-06-02 17:15:28 +02:00
|
|
|
log(" -no-rw-check\n");
|
|
|
|
|
log(" marks all recognized read ports as \"return don't-care value on\n");
|
|
|
|
|
log(" read/write collision\" (same result as setting the no_rw_check\n");
|
|
|
|
|
log(" attribute on all memories).\n");
|
|
|
|
|
log("\n");
|
2024-11-26 15:42:22 +01:00
|
|
|
log(" -family <family>\n");
|
|
|
|
|
log(" sets the gowin family to the specified value. The default is 'gw1n'.\n");
|
|
|
|
|
log(" The following families are supported:\n");
|
|
|
|
|
log(" 'gw1n', 'gw2a', 'gw5a'.\n");
|
2019-10-28 13:10:12 +01:00
|
|
|
log("\n");
|
2025-10-16 09:32:39 +02:00
|
|
|
log(" -setundef\n");
|
2025-10-16 10:06:02 +02:00
|
|
|
log(" set undriven wires and parameters to zero\n");
|
2025-10-16 09:32:39 +02:00
|
|
|
log("\n");
|
2019-10-28 13:10:12 +01:00
|
|
|
log("The following commands are executed by this synthesis command:\n");
|
2016-11-01 11:31:13 +01:00
|
|
|
help_script();
|
|
|
|
|
log("\n");
|
|
|
|
|
}
|
|
|
|
|
|
2024-11-26 15:42:22 +01:00
|
|
|
string top_opt, vout_file, json_file, family;
|
2025-10-16 09:32:39 +02:00
|
|
|
bool retime, nobram, nolutram, flatten, nodffe, strict_gw5a_dffs, nowidelut, abc9, noiopads, noalu, no_rw_check, setundef;
|
2016-11-01 11:31:13 +01:00
|
|
|
|
2020-06-19 01:34:52 +02:00
|
|
|
void clear_flags() override
|
2016-11-01 11:31:13 +01:00
|
|
|
{
|
2024-11-26 15:42:22 +01:00
|
|
|
family = "gw1n";
|
2016-11-01 11:31:13 +01:00
|
|
|
top_opt = "-auto-top";
|
|
|
|
|
vout_file = "";
|
2020-11-30 11:43:12 +01:00
|
|
|
json_file = "";
|
2016-11-01 11:31:13 +01:00
|
|
|
retime = false;
|
2019-01-04 11:37:25 +01:00
|
|
|
flatten = true;
|
2019-04-02 19:21:01 +02:00
|
|
|
nobram = false;
|
2019-04-22 09:09:27 +02:00
|
|
|
nodffe = false;
|
Gowin. Reduce the range of flip-flop types.
UG303-1.0E_Arora Ⅴ Configurable Function Unit (CFU) User Guide.pdf
specifies that the only flip-flop types supported in GW5 are DFFSE,
DFFRE, DFFPE, and DFFCE.
However, the bit streams generated by the vendor IDE also contain DFF
flip-flops, which are probably the result of optimisation, so we leave
them in the list of permitted items, but add a flag that will allow the
generation of completely correct output files, acceptable for further P&
R using vendor tools (they will not allow the use of flip-flops other
than the four specified in the netlist).
In the GW5 SemiDual Port BSRAM series, the primitive does not have
RESETA and RESETB ports—they are replaced by the RESET port, so we
separate the files for BSRAM generation, especially since in the future
we may have to take into account other, as yet unexplored, differences
in BSRAM.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
2025-10-11 13:12:35 +02:00
|
|
|
strict_gw5a_dffs = false;
|
Harmonize BRAM/LUTRAM descriptions across all of Yosys.
This commit:
* renames all remaining instances of "DRAM" (which is ambiguous)
to "LUTRAM" (which is not), finishing the work started in
the commit 698ab9be;
* renames memory rule files to brams.txt/lutrams.txt;
* adds/renames script labels map_bram/map_lutram;
* extracts where necessary script labels map_ffram and map_gates;
* adds where necessary options -nobram/-nolutram.
The end result is that BRAM/LUTRAM/FFRAM aspects of every target
are now consistent with each other.
Per architecture:
* anlogic: rename drams.txt→lutrams.txt, add -nolutram, add
:map_lutram, :map_ffram, :map_gates
* ecp5: rename bram.txt→brams.txt, lutram.txt→lutrams.txt
* efinix: rename bram.txt→brams.txt, add -nobram, add :map_ffram,
:map_gates
* gowin: rename bram.txt→brams.txt, dram.txt→lutrams.txt,
rename -nodram→-nolutram (-nodram still recognized), rename
:bram→:map_bram, :dram→:map_lutram, add :map_ffram, :map_gates
2020-01-01 13:30:00 +01:00
|
|
|
nolutram = false;
|
2019-10-28 12:49:08 +01:00
|
|
|
nowidelut = false;
|
2023-11-13 16:12:23 +01:00
|
|
|
abc9 = true;
|
2019-11-25 14:33:21 +01:00
|
|
|
noiopads = false;
|
2020-11-30 11:43:12 +01:00
|
|
|
noalu = false;
|
2022-06-02 17:15:28 +02:00
|
|
|
no_rw_check = false;
|
2025-10-16 09:32:39 +02:00
|
|
|
setundef = false;
|
2016-11-01 11:31:13 +01:00
|
|
|
}
|
|
|
|
|
|
2020-06-19 01:34:52 +02:00
|
|
|
void execute(std::vector<std::string> args, RTLIL::Design *design) override
|
2016-11-01 11:31:13 +01:00
|
|
|
{
|
|
|
|
|
string run_from, run_to;
|
|
|
|
|
clear_flags();
|
|
|
|
|
|
|
|
|
|
size_t argidx;
|
|
|
|
|
for (argidx = 1; argidx < args.size(); argidx++)
|
|
|
|
|
{
|
|
|
|
|
if (args[argidx] == "-top" && argidx+1 < args.size()) {
|
|
|
|
|
top_opt = "-top " + args[++argidx];
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
if (args[argidx] == "-vout" && argidx+1 < args.size()) {
|
|
|
|
|
vout_file = args[++argidx];
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2020-11-30 11:43:12 +01:00
|
|
|
if (args[argidx] == "-json" && argidx+1 < args.size()) {
|
|
|
|
|
json_file = args[++argidx];
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2024-11-26 15:42:22 +01:00
|
|
|
if (args[argidx] == "-family" && argidx+1 < args.size()) {
|
|
|
|
|
family = args[++argidx];
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2016-11-01 11:31:13 +01:00
|
|
|
if (args[argidx] == "-run" && argidx+1 < args.size()) {
|
|
|
|
|
size_t pos = args[argidx+1].find(':');
|
|
|
|
|
if (pos == std::string::npos)
|
|
|
|
|
break;
|
|
|
|
|
run_from = args[++argidx].substr(0, pos);
|
|
|
|
|
run_to = args[argidx].substr(pos+1);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
if (args[argidx] == "-retime") {
|
|
|
|
|
retime = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2018-12-04 03:08:35 +01:00
|
|
|
if (args[argidx] == "-nobram") {
|
|
|
|
|
nobram = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
Harmonize BRAM/LUTRAM descriptions across all of Yosys.
This commit:
* renames all remaining instances of "DRAM" (which is ambiguous)
to "LUTRAM" (which is not), finishing the work started in
the commit 698ab9be;
* renames memory rule files to brams.txt/lutrams.txt;
* adds/renames script labels map_bram/map_lutram;
* extracts where necessary script labels map_ffram and map_gates;
* adds where necessary options -nobram/-nolutram.
The end result is that BRAM/LUTRAM/FFRAM aspects of every target
are now consistent with each other.
Per architecture:
* anlogic: rename drams.txt→lutrams.txt, add -nolutram, add
:map_lutram, :map_ffram, :map_gates
* ecp5: rename bram.txt→brams.txt, lutram.txt→lutrams.txt
* efinix: rename bram.txt→brams.txt, add -nobram, add :map_ffram,
:map_gates
* gowin: rename bram.txt→brams.txt, dram.txt→lutrams.txt,
rename -nodram→-nolutram (-nodram still recognized), rename
:bram→:map_bram, :dram→:map_lutram, add :map_ffram, :map_gates
2020-01-01 13:30:00 +01:00
|
|
|
if (args[argidx] == "-nolutram" || /*deprecated*/args[argidx] == "-nodram") {
|
|
|
|
|
nolutram = true;
|
2019-04-13 06:40:02 +02:00
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
if (args[argidx] == "-nodffe") {
|
|
|
|
|
nodffe = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
Gowin. Reduce the range of flip-flop types.
UG303-1.0E_Arora Ⅴ Configurable Function Unit (CFU) User Guide.pdf
specifies that the only flip-flop types supported in GW5 are DFFSE,
DFFRE, DFFPE, and DFFCE.
However, the bit streams generated by the vendor IDE also contain DFF
flip-flops, which are probably the result of optimisation, so we leave
them in the list of permitted items, but add a flag that will allow the
generation of completely correct output files, acceptable for further P&
R using vendor tools (they will not allow the use of flip-flops other
than the four specified in the netlist).
In the GW5 SemiDual Port BSRAM series, the primitive does not have
RESETA and RESETB ports—they are replaced by the RESET port, so we
separate the files for BSRAM generation, especially since in the future
we may have to take into account other, as yet unexplored, differences
in BSRAM.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
2025-10-11 13:12:35 +02:00
|
|
|
if (args[argidx] == "-strict-gw5a-dffs") {
|
|
|
|
|
strict_gw5a_dffs = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2019-01-04 11:37:25 +01:00
|
|
|
if (args[argidx] == "-noflatten") {
|
|
|
|
|
flatten = false;
|
|
|
|
|
continue;
|
2019-02-26 19:28:42 +01:00
|
|
|
}
|
2019-10-28 12:49:08 +01:00
|
|
|
if (args[argidx] == "-nowidelut") {
|
|
|
|
|
nowidelut = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2020-11-30 11:43:12 +01:00
|
|
|
if (args[argidx] == "-noalu") {
|
|
|
|
|
noalu = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2020-04-01 02:07:30 +02:00
|
|
|
if (args[argidx] == "-abc9") {
|
2023-11-13 16:12:23 +01:00
|
|
|
// removed, ABC9 is on by default.
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2023-11-14 23:37:29 +01:00
|
|
|
if (args[argidx] == "-noabc9") {
|
2023-11-13 16:12:23 +01:00
|
|
|
abc9 = false;
|
2020-04-01 02:07:30 +02:00
|
|
|
continue;
|
|
|
|
|
}
|
2019-11-25 14:33:21 +01:00
|
|
|
if (args[argidx] == "-noiopads") {
|
|
|
|
|
noiopads = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2022-06-02 17:15:28 +02:00
|
|
|
if (args[argidx] == "-no-rw-check") {
|
|
|
|
|
no_rw_check = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2025-10-16 09:32:39 +02:00
|
|
|
if (args[argidx] == "-setundef") {
|
|
|
|
|
setundef = true;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2016-11-01 11:31:13 +01:00
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
extra_args(args, argidx, design);
|
|
|
|
|
|
|
|
|
|
if (!design->full_selection())
|
2018-12-07 20:14:07 +01:00
|
|
|
log_cmd_error("This command only operates on fully selected designs!\n");
|
2016-11-01 11:31:13 +01:00
|
|
|
|
|
|
|
|
log_header(design, "Executing SYNTH_GOWIN pass.\n");
|
|
|
|
|
log_push();
|
|
|
|
|
|
|
|
|
|
run_script(design, run_from, run_to);
|
|
|
|
|
|
|
|
|
|
log_pop();
|
|
|
|
|
}
|
|
|
|
|
|
2020-06-19 01:34:52 +02:00
|
|
|
void script() override
|
2016-11-01 11:31:13 +01:00
|
|
|
{
|
2022-06-02 17:15:28 +02:00
|
|
|
std::string no_rw_check_opt = "";
|
|
|
|
|
if (no_rw_check)
|
|
|
|
|
no_rw_check_opt = " -no-rw-check";
|
|
|
|
|
if (help_mode)
|
|
|
|
|
no_rw_check_opt = " [-no-rw-check]";
|
|
|
|
|
|
2016-11-01 11:31:13 +01:00
|
|
|
if (check_label("begin"))
|
|
|
|
|
{
|
2020-04-01 02:07:30 +02:00
|
|
|
run("read_verilog -specify -lib +/gowin/cells_sim.v");
|
2025-08-20 00:45:26 +02:00
|
|
|
run(stringf("read_verilog -specify -lib +/gowin/cells_xtra_%s.v", help_mode ? "<family>" : family));
|
|
|
|
|
run(stringf("hierarchy -check %s", help_mode ? "-top <top>" : top_opt));
|
2016-11-01 11:31:13 +01:00
|
|
|
}
|
|
|
|
|
|
2019-01-04 11:37:25 +01:00
|
|
|
if (flatten && check_label("flatten", "(unless -noflatten)"))
|
2016-11-01 11:31:13 +01:00
|
|
|
{
|
|
|
|
|
run("proc");
|
|
|
|
|
run("flatten");
|
|
|
|
|
run("tribuf -logic");
|
|
|
|
|
run("deminout");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (check_label("coarse"))
|
|
|
|
|
{
|
2022-06-02 17:15:28 +02:00
|
|
|
run("synth -run coarse" + no_rw_check_opt);
|
2016-11-01 11:31:13 +01:00
|
|
|
}
|
2019-11-18 14:25:46 +01:00
|
|
|
|
2022-02-09 09:25:45 +01:00
|
|
|
if (check_label("map_ram"))
|
2018-12-04 03:08:35 +01:00
|
|
|
{
|
2022-02-09 09:25:45 +01:00
|
|
|
std::string args = "";
|
|
|
|
|
if (help_mode)
|
|
|
|
|
args += " [-no-auto-block] [-no-auto-distributed]";
|
2024-03-17 23:33:18 +01:00
|
|
|
else {
|
|
|
|
|
if (nobram)
|
|
|
|
|
args += " -no-auto-block";
|
|
|
|
|
if (nolutram)
|
|
|
|
|
args += " -no-auto-distributed";
|
|
|
|
|
}
|
2025-10-25 08:36:46 +02:00
|
|
|
run(stringf("memory_libmap -lib +/gowin/lutrams.txt -lib +/gowin/brams.txt -D %s", family) + args, "(-no-auto-block if -nobram, -no-auto-distributed if -nolutram)");
|
Gowin. Reduce the range of flip-flop types.
UG303-1.0E_Arora Ⅴ Configurable Function Unit (CFU) User Guide.pdf
specifies that the only flip-flop types supported in GW5 are DFFSE,
DFFRE, DFFPE, and DFFCE.
However, the bit streams generated by the vendor IDE also contain DFF
flip-flops, which are probably the result of optimisation, so we leave
them in the list of permitted items, but add a flag that will allow the
generation of completely correct output files, acceptable for further P&
R using vendor tools (they will not allow the use of flip-flops other
than the four specified in the netlist).
In the GW5 SemiDual Port BSRAM series, the primitive does not have
RESETA and RESETB ports—they are replaced by the RESET port, so we
separate the files for BSRAM generation, especially since in the future
we may have to take into account other, as yet unexplored, differences
in BSRAM.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
2025-10-11 13:12:35 +02:00
|
|
|
run(stringf("techmap -map +/gowin/lutrams_map.v -map +/gowin/brams_map%s.v", family == "gw5a" ? "_gw5a" : ""));
|
2018-12-04 03:08:35 +01:00
|
|
|
}
|
2019-04-13 06:40:02 +02:00
|
|
|
|
Harmonize BRAM/LUTRAM descriptions across all of Yosys.
This commit:
* renames all remaining instances of "DRAM" (which is ambiguous)
to "LUTRAM" (which is not), finishing the work started in
the commit 698ab9be;
* renames memory rule files to brams.txt/lutrams.txt;
* adds/renames script labels map_bram/map_lutram;
* extracts where necessary script labels map_ffram and map_gates;
* adds where necessary options -nobram/-nolutram.
The end result is that BRAM/LUTRAM/FFRAM aspects of every target
are now consistent with each other.
Per architecture:
* anlogic: rename drams.txt→lutrams.txt, add -nolutram, add
:map_lutram, :map_ffram, :map_gates
* ecp5: rename bram.txt→brams.txt, lutram.txt→lutrams.txt
* efinix: rename bram.txt→brams.txt, add -nobram, add :map_ffram,
:map_gates
* gowin: rename bram.txt→brams.txt, dram.txt→lutrams.txt,
rename -nodram→-nolutram (-nodram still recognized), rename
:bram→:map_bram, :dram→:map_lutram, add :map_ffram, :map_gates
2020-01-01 13:30:00 +01:00
|
|
|
if (check_label("map_ffram"))
|
2016-11-01 11:31:13 +01:00
|
|
|
{
|
|
|
|
|
run("opt -fast -mux_undef -undriven -fine");
|
|
|
|
|
run("memory_map");
|
|
|
|
|
run("opt -undriven -fine");
|
Harmonize BRAM/LUTRAM descriptions across all of Yosys.
This commit:
* renames all remaining instances of "DRAM" (which is ambiguous)
to "LUTRAM" (which is not), finishing the work started in
the commit 698ab9be;
* renames memory rule files to brams.txt/lutrams.txt;
* adds/renames script labels map_bram/map_lutram;
* extracts where necessary script labels map_ffram and map_gates;
* adds where necessary options -nobram/-nolutram.
The end result is that BRAM/LUTRAM/FFRAM aspects of every target
are now consistent with each other.
Per architecture:
* anlogic: rename drams.txt→lutrams.txt, add -nolutram, add
:map_lutram, :map_ffram, :map_gates
* ecp5: rename bram.txt→brams.txt, lutram.txt→lutrams.txt
* efinix: rename bram.txt→brams.txt, add -nobram, add :map_ffram,
:map_gates
* gowin: rename bram.txt→brams.txt, dram.txt→lutrams.txt,
rename -nodram→-nolutram (-nodram still recognized), rename
:bram→:map_bram, :dram→:map_lutram, add :map_ffram, :map_gates
2020-01-01 13:30:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (check_label("map_gates"))
|
|
|
|
|
{
|
2020-11-30 11:43:12 +01:00
|
|
|
if (noalu) {
|
|
|
|
|
run("techmap -map +/techmap.v");
|
|
|
|
|
} else {
|
|
|
|
|
run("techmap -map +/techmap.v -map +/gowin/arith_map.v");
|
|
|
|
|
}
|
2020-02-06 03:39:01 +01:00
|
|
|
run("opt -fast");
|
2016-11-01 11:31:13 +01:00
|
|
|
if (retime || help_mode)
|
2019-12-30 21:09:53 +01:00
|
|
|
run("abc -dff -D 1", "(only if -retime)");
|
2021-08-20 21:21:06 +02:00
|
|
|
if (!noiopads || help_mode)
|
|
|
|
|
run("iopadmap -bits -inpad IBUF O:I -outpad OBUF I:O "
|
2021-11-09 11:22:48 +01:00
|
|
|
"-toutpad TBUF ~OEN:I:O -tinoutpad IOBUF ~OEN:O:I:IO", "(unless -noiopads)");
|
2016-11-01 11:31:13 +01:00
|
|
|
}
|
|
|
|
|
|
2019-04-13 06:40:02 +02:00
|
|
|
if (check_label("map_ffs"))
|
|
|
|
|
{
|
|
|
|
|
run("opt_clean");
|
Gowin. Reduce the range of flip-flop types.
UG303-1.0E_Arora Ⅴ Configurable Function Unit (CFU) User Guide.pdf
specifies that the only flip-flop types supported in GW5 are DFFSE,
DFFRE, DFFPE, and DFFCE.
However, the bit streams generated by the vendor IDE also contain DFF
flip-flops, which are probably the result of optimisation, so we leave
them in the list of permitted items, but add a flag that will allow the
generation of completely correct output files, acceptable for further P&
R using vendor tools (they will not allow the use of flip-flops other
than the four specified in the netlist).
In the GW5 SemiDual Port BSRAM series, the primitive does not have
RESETA and RESETB ports—they are replaced by the RESET port, so we
separate the files for BSRAM generation, especially since in the future
we may have to take into account other, as yet unexplored, differences
in BSRAM.
Signed-off-by: YRabbit <rabbit@yrabbit.cyou>
2025-10-11 13:12:35 +02:00
|
|
|
if (family == "gw5a") {
|
|
|
|
|
if (strict_gw5a_dffs) {
|
|
|
|
|
run("dfflegalize -cell $_SDFFE_PP?P_ r -cell $_DFFE_PP?P_ r");
|
|
|
|
|
} else {
|
|
|
|
|
run("dfflegalize -cell $_DFF_?_ 0 -cell $_SDFFE_PP?P_ r -cell $_DFFE_PP?P_ r");
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
if (nodffe)
|
|
|
|
|
run("dfflegalize -cell $_DFF_?_ 0 -cell $_SDFF_?P?_ r -cell $_DFF_?P?_ r");
|
|
|
|
|
else
|
|
|
|
|
run("dfflegalize -cell $_DFF_?_ 0 -cell $_DFFE_?P_ 0 -cell $_SDFF_?P?_ r -cell $_SDFFE_?P?P_ r -cell $_DFF_?P?_ r -cell $_DFFE_?P?P_ r");
|
|
|
|
|
}
|
2019-04-13 06:40:02 +02:00
|
|
|
run("techmap -map +/gowin/cells_map.v");
|
|
|
|
|
run("opt_expr -mux_undef");
|
|
|
|
|
run("simplemap");
|
|
|
|
|
}
|
|
|
|
|
|
2016-11-01 11:31:13 +01:00
|
|
|
if (check_label("map_luts"))
|
|
|
|
|
{
|
2020-04-01 02:07:30 +02:00
|
|
|
if (nowidelut && abc9) {
|
|
|
|
|
run("read_verilog -icells -lib -specify +/abc9_model.v");
|
|
|
|
|
run("abc9 -maxlut 4 -W 500");
|
|
|
|
|
} else if (nowidelut && !abc9) {
|
2019-10-28 12:49:08 +01:00
|
|
|
run("abc -lut 4");
|
2020-04-01 02:07:30 +02:00
|
|
|
} else if (!nowidelut && abc9) {
|
|
|
|
|
run("read_verilog -icells -lib -specify +/abc9_model.v");
|
|
|
|
|
run("abc9 -maxlut 8 -W 500");
|
|
|
|
|
} else if (!nowidelut && !abc9) {
|
2019-10-28 12:49:08 +01:00
|
|
|
run("abc -lut 4:8");
|
|
|
|
|
}
|
2016-11-01 11:31:13 +01:00
|
|
|
run("clean");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (check_label("map_cells"))
|
|
|
|
|
{
|
|
|
|
|
run("techmap -map +/gowin/cells_map.v");
|
2020-02-03 14:57:17 +01:00
|
|
|
run("opt_lut_ins -tech gowin");
|
2025-10-16 09:32:39 +02:00
|
|
|
if (setundef || help_mode)
|
2025-10-16 10:08:27 +02:00
|
|
|
run("setundef -undriven -params -zero", "(only if -setundef)");
|
2019-09-05 16:38:47 +02:00
|
|
|
run("hilomap -singleton -hicell VCC V -locell GND G");
|
2021-11-07 18:00:18 +01:00
|
|
|
if (!vout_file.empty() || help_mode) // vendor output requires 1-bit wires
|
2025-10-16 10:08:27 +02:00
|
|
|
run("splitnets -ports", "(only if -vout)");
|
2019-04-13 06:40:02 +02:00
|
|
|
run("clean");
|
2020-04-01 02:07:30 +02:00
|
|
|
run("autoname");
|
2016-11-01 11:31:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (check_label("check"))
|
|
|
|
|
{
|
|
|
|
|
run("hierarchy -check");
|
|
|
|
|
run("stat");
|
|
|
|
|
run("check -noinit");
|
2021-03-17 13:16:53 +01:00
|
|
|
run("blackbox =A:whitebox");
|
2016-11-01 11:31:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (check_label("vout"))
|
|
|
|
|
{
|
|
|
|
|
if (!vout_file.empty() || help_mode)
|
2021-11-07 18:00:18 +01:00
|
|
|
run(stringf("write_verilog -simple-lhs -decimal -attr2comment -defparam -renameprefix gen %s",
|
2016-11-01 11:31:13 +01:00
|
|
|
help_mode ? "<file-name>" : vout_file.c_str()));
|
2020-11-30 11:43:12 +01:00
|
|
|
if (!json_file.empty() || help_mode)
|
|
|
|
|
run(stringf("write_json %s",
|
|
|
|
|
help_mode ? "<file-name>" : json_file.c_str()));
|
2016-11-01 11:31:13 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} SynthGowinPass;
|
|
|
|
|
|
|
|
|
|
PRIVATE_NAMESPACE_END
|