mirror of
https://github.com/YosysHQ/yosys
synced 2025-10-24 00:14:36 +00:00
Add "write_edif -gndvccy"
Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
parent
e70ebe557c
commit
54dc33b905
1 changed files with 13 additions and 5 deletions
|
@ -106,6 +106,10 @@ struct EdifBackend : public Backend {
|
||||||
log(" if the design contains constant nets. use \"hilomap\" to map to custom\n");
|
log(" if the design contains constant nets. use \"hilomap\" to map to custom\n");
|
||||||
log(" constant drivers first)\n");
|
log(" constant drivers first)\n");
|
||||||
log("\n");
|
log("\n");
|
||||||
|
log(" -gndvccy\n");
|
||||||
|
log(" create \"GND\" and \"VCC\" cells with \"Y\" outputs. (the default is \"G\"\n");
|
||||||
|
log(" for \"GND\" and \"P\" for \"VCC\".)\n");
|
||||||
|
log("\n");
|
||||||
log(" -attrprop\n");
|
log(" -attrprop\n");
|
||||||
log(" create EDIF properties for cell attributes\n");
|
log(" create EDIF properties for cell attributes\n");
|
||||||
log("\n");
|
log("\n");
|
||||||
|
@ -126,7 +130,7 @@ struct EdifBackend : public Backend {
|
||||||
bool port_rename = false;
|
bool port_rename = false;
|
||||||
bool attr_properties = false;
|
bool attr_properties = false;
|
||||||
std::map<RTLIL::IdString, std::map<RTLIL::IdString, int>> lib_cell_ports;
|
std::map<RTLIL::IdString, std::map<RTLIL::IdString, int>> lib_cell_ports;
|
||||||
bool nogndvcc = false;
|
bool nogndvcc = false, gndvccy = true;
|
||||||
CellTypes ct(design);
|
CellTypes ct(design);
|
||||||
EdifNames edif_names;
|
EdifNames edif_names;
|
||||||
|
|
||||||
|
@ -141,6 +145,10 @@ struct EdifBackend : public Backend {
|
||||||
nogndvcc = true;
|
nogndvcc = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (args[argidx] == "-gndvccy") {
|
||||||
|
gndvccy = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (args[argidx] == "-attrprop") {
|
if (args[argidx] == "-attrprop") {
|
||||||
attr_properties = true;
|
attr_properties = true;
|
||||||
continue;
|
continue;
|
||||||
|
@ -211,7 +219,7 @@ struct EdifBackend : public Backend {
|
||||||
*f << stringf(" (cellType GENERIC)\n");
|
*f << stringf(" (cellType GENERIC)\n");
|
||||||
*f << stringf(" (view VIEW_NETLIST\n");
|
*f << stringf(" (view VIEW_NETLIST\n");
|
||||||
*f << stringf(" (viewType NETLIST)\n");
|
*f << stringf(" (viewType NETLIST)\n");
|
||||||
*f << stringf(" (interface (port G (direction OUTPUT)))\n");
|
*f << stringf(" (interface (port %c (direction OUTPUT)))\n", gndvccy ? 'Y' : 'G');
|
||||||
*f << stringf(" )\n");
|
*f << stringf(" )\n");
|
||||||
*f << stringf(" )\n");
|
*f << stringf(" )\n");
|
||||||
|
|
||||||
|
@ -219,7 +227,7 @@ struct EdifBackend : public Backend {
|
||||||
*f << stringf(" (cellType GENERIC)\n");
|
*f << stringf(" (cellType GENERIC)\n");
|
||||||
*f << stringf(" (view VIEW_NETLIST\n");
|
*f << stringf(" (view VIEW_NETLIST\n");
|
||||||
*f << stringf(" (viewType NETLIST)\n");
|
*f << stringf(" (viewType NETLIST)\n");
|
||||||
*f << stringf(" (interface (port P (direction OUTPUT)))\n");
|
*f << stringf(" (interface (port %c (direction OUTPUT)))\n", gndvccy ? 'Y' : 'P');
|
||||||
*f << stringf(" )\n");
|
*f << stringf(" )\n");
|
||||||
*f << stringf(" )\n");
|
*f << stringf(" )\n");
|
||||||
}
|
}
|
||||||
|
@ -420,9 +428,9 @@ struct EdifBackend : public Backend {
|
||||||
if (nogndvcc)
|
if (nogndvcc)
|
||||||
log_error("Design contains constant nodes (map with \"hilomap\" first).\n");
|
log_error("Design contains constant nodes (map with \"hilomap\" first).\n");
|
||||||
if (sig == RTLIL::State::S0)
|
if (sig == RTLIL::State::S0)
|
||||||
*f << stringf(" (portRef G (instanceRef GND))\n");
|
*f << stringf(" (portRef %c (instanceRef GND))\n", gndvccy ? 'Y' : 'G');
|
||||||
if (sig == RTLIL::State::S1)
|
if (sig == RTLIL::State::S1)
|
||||||
*f << stringf(" (portRef P (instanceRef VCC))\n");
|
*f << stringf(" (portRef %c (instanceRef VCC))\n", gndvccy ? 'Y' : 'P');
|
||||||
}
|
}
|
||||||
*f << stringf(" ))\n");
|
*f << stringf(" ))\n");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue