3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-10-26 01:14:37 +00:00

Add "write_edif -gndvccy"

Signed-off-by: Clifford Wolf <clifford@clifford.at>
This commit is contained in:
Clifford Wolf 2019-01-17 13:33:11 +01:00
parent e70ebe557c
commit 54dc33b905

View file

@ -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");
} }