CSharp application for converting a custom netlist format to HTML files or PNG images. It was made for documenting all the cells and traces on the Game Boy chip DMG-CPU B.
Read INSTALL for build/install instructions.
This HTML file was generated by this tool:
DMG-CPU B Netlist
PNGs generated by this tool can be seen in this browser map of the chip:
DMG-CPU B Map
Generate HTML file containing all types, cells and wires:
nlconv --html <input.nl >output.html
Generate PNG image containing all cells:
nlconv --png-cells <input.nl >output.png
Generate PNG image containing all wires:
nlconv --png-wires <input.nl >output.png
Generate PNG image containing all labels:
nlconv --png-labels <input.nl >output.png
Generate PNG image containing a floorplan:
nlconv --png-floor <input.nl >output.png
Generate PNG image containing everything:
nlconv --png <input.nl >output.png
Generate Java Script containing all coordinates to be used by the map:
nlconv --js <input.nl >output.js
Not yet implemented, but planned:
- Generate Verilog code containing all cells and wires.
All keywords are case-insensitive. User defined names are case-sensitive. The netlist that gets fed into STDIN of this application can contain type, signal, cell, wire, label and category definitions in any order.
The TYPE
keyword is used to define cell types. Those cell types can then be used for defining instances of cells using
the CELL
keyword.
TYPE <type-name>[:<color>] <port-name>[:<port-dir>]
[<port-name>[:<port-dir>]...]
[@<cell-coordinates>]
[<port-name>@<port-coordinates>...]
["<description-string>" [DOC "<documentation-url>"]];
- <type-name>
- Unique name of the cell type, like
nand2
for example. - <color>
-
Color that will be used when drawing cell instances of this type.
Can be one of:
BLACK
,BLUE
,CYAN
,GREEN
,LIME
,MAGENTA
,ORANGE
,PURPLE
,RED
,TEAL
,YELLOW
,PINK
,NAVY
,BROWN
,GRAY
orWHITE
. Defaults toBLACK
if not given. - <port-name>
-
Name of a port that cells of this type have. Can occur multiple times. When followed by a space or
colon, it defines the port itself. When followed by a
@
, it specifies the coordinates of that port. - <port-dir>
-
Port direction. Can be one of:
IN
,OUT
,TRI
,INOUT
,OUT0
,OUT1
orNC
. Defaults toIN
. - <cell-coordinates>
- Two two-dimensional vectors, describing the bounding box of a cell of this type. This is used to convert the absolute <port-coordinates> to coordinates relative to the center of this bounding box, so they can be used as default coordinates for all cells of this type that do not have them explicitly specified.
- <port-coordinates>
-
One or two two-dimensional vectors, describing either a point or line, where this port is located. Those port
coordinates will be used for all cells of this type that do not have port coordinates explicitely specified
alongside their own
CELL
definition. - <description-string>
- A string in double quotes that describes the function of cells of this type.
- <documentation-url>
- An URL in double quotes that contains more detailed information about cells of this type.
The SIGNAL
keyword is used to define wire signal classes. Those wire signal classes can then be used for defining
instances of wires using the WIRE
keyword.
SIGNAL <signal-name>[:<color>] ["<description-string>"];
- <signal-name>
- Unique name of the wire signal class, like
clock
for example. - <color>
-
Color that will be used when drawing wire instances of this signal class.
Can be one of:
BLACK
,BLUE
,CYAN
,GREEN
,LIME
,MAGENTA
,ORANGE
,PURPLE
,RED
,TEAL
,YELLOW
,PINK
,NAVY
,BROWN
,GRAY
orWHITE
. Defaults toBLACK
if not given. - <description-string>
- A string in double quotes that describes this wire signal class.
The CELL
keyword is used to define cell instances.
CELL <cell-name>:<type-name> [<orientation>[,FLIP]]
[@<cell-coordinates>] [<port-name>@<port-coordinates>...]
[<flags>...] [-> <category>] ["<description-string>"];
- <cell-name>
- Unique name of the cell instance.
- <type-name>
- Cell type being instanciated.
- <orientation>
-
Defines the clock-wise rotation of the cell. Can be one of:
ROT0
,ROT90
,ROT180
orROT270
. If not given, then orientation will be undefined and the cell may not be drawn in images. Can be appended with,FLIP
, which means that the cell is flipped horizontally (reflected along the central vertical axis) before the rotation is applied. - <cell-coordinates>
- Two two-dimensional vectors, describing the bounding box of the cell instance.
- <port-coordinates>
- One or two two-dimensional vectors, describing either a point or line, where this port is located.
- <flags>
-
Any combination of the following flags may be applied to the cell:
SPARE
: This is a spare cell that has no relevant function.VIRTUAL
: This cell does not actually exist in the circuit. May just be used to please the electrical rules checker.COMP
: This cell may not be drawn in the schematics, because it just provides a complement clock for some latches or flip-flops.TRIVIAL
: This cell is not drawn in the schematics, because it is basically just wiring.
- <category>
-
The optional category describes to which part of the circuit this cell belongs to. It is used when drawing the
floorplan. Categories can be defined with the
CATEGORY
keyword. - <description-string>
- A string in double quotes that describes the function of this cell instance within the circuit.
Cells can have alias names. This is useful for example when a cell got renamed at some point. Then it can still have an alias with its old name, so it can still be found in the HTML document when someone searches for it by that old name. Aliases are specified with separate statements that must come somewhere after the cell definition:
ALIAS CELL <alias>... -> <cell-name>;
- <alias>
- One or more alias names for the cell. Each of them must be unique within the cell namespace.
- <cell-name>
- Name of the cell instance.
The WIRE
keyword is used to define connections between cell ports.
WIRE <wire-name>[:<signal-class>] <source-ports>... [-> <drain-ports>...]
[@<wire-coordinates>...] ["<description-string>"];
- <wire-name>
- Unique name of the wire.
- <signal-class>
-
Optional wire signal class. Used for drawing wires in different colors. Wire signal classes can be defined with the
SIGNAL
keyword. - <source-ports>
-
One or more source ports in the form
<cell>.<port>
that are driving this wire. Only ports with the following directions are allowed as source ports:OUT
,TRI
,INOUT
,OUT0
orOUT1
. If direction isOUT
, then the wire must have only one source port. if one port has the directionOUT0
orOUT1
, then all source ports must have the same direction. OnlyTRI
andINOUT
ports can be intermixed. - <drain-ports>
-
Zero or more input ports in the form
<cell>.<port>
that are receiving the signal from this wire. Only ports with directionIN
are allowed as drain ports.INOUT
ports are technically inputs too, but they have to be listed under source ports, because they can also drive the wire. - <wire-coordinates>
- List of two-dimensional vectors, describing a continuous strip of lines fitting the shape of the wire.
- <description-string>
- A string in double quotes that describes the signal carried by this wire within the circuit.
Wires can have alias names. This is useful for example when a wire got renamed at some point. Then it can still have an alias with its old name, so it can still be found in the HTML document when someone searches for it by that old name. Aliases are specified with separate statements that must come somewhere after the wire definition:
ALIAS WIRE <alias>... -> <wire-name>;
- <alias>
- One or more alias names for the wire. Each of them must be unique within the wire namespace.
- <wire-name>
- Name of the wire instance.
The LABEL
keyword is used to define custom labels placed when generating the labels image.
LABEL "<text>"[:<color>] [<orientation>[,FLIP]]
@<label-coordinates> [<alignment>];
- <text>
- Text in double quotes. This is the actual label text that will be drawn.
- <color>
-
Color that will be used when drawing this label.
Can be one of:
BLACK
,BLUE
,CYAN
,GREEN
,LIME
,MAGENTA
,ORANGE
,PURPLE
,RED
,TEAL
,YELLOW
,PINK
,NAVY
,BROWN
,GRAY
orWHITE
. Defaults toBLACK
if not given. - <orientation>
-
Defines the clock-wise rotation of the label. Can be one of:
ROT0
,ROT90
,ROT180
orROT270
. Can be appended with,FLIP
, which means that the text will be flipped horizontally (reflected along the central vertical axis) before the rotation is applied. If not given, defaults toROT0
, not flipped. - <label-coordinates>
- A two-dimensional vector, describing the location where this label gets drawn.
- <alignment>
-
Defines the alignment of the label to the location described by <label-coordinates>. Can be one of:
CENTER
,TOP-LEFT
,TOP-CENTER
,TOP-RIGHT
,CENTER-LEFT
,CENTER-RIGHT
,BOTTOM-LEFT
,BOTTOM-CENTER
orBOTTOM-RIGHT
. Defaults toCENTER
if not given.
The CATEGORY
keyword is used to define cell categories. A cell can optionally have a category assigned to it,
which is used for determining its color when drawing the floorplan.
CATEGORY <category-name>[:<color>] ["<description-string>"];
- <category-name>
- Unique name of the category.
- <color>
-
Color that will be used when drawing cells of this category in the floorplan.
Can be one of:
BLACK
,BLUE
,CYAN
,GREEN
,LIME
,MAGENTA
,ORANGE
,PURPLE
,RED
,TEAL
,YELLOW
,PINK
,NAVY
,BROWN
,GRAY
orWHITE
. If no color is given, then it is not drawn in the floorplan. - <description-string>
- A string in double quotes that describes this category.
The DEFINE
keyword is used to define strings that can influence the output file.
DEFINE <string-name> ["<string-value>"...];
or
DEFINE <string-name> <float-value>;
- <string-name>
-
Name of the string. Can be any valid identifier name, but only the following have an effect:
default-doc-url
: Provides a default value for the documentation URL of type definitions. Use%t
as substitution for the name of the type.map-url
: The URL to the Leaflet map which is used in generated HTML code.html-title
: Title and headline of generated HTML file.html-navbar
: Code inserted as navigation bar in generated HTML file.html-footer
: Code inserted as footer in generated HTML file.png-scale
: Scaling of lines and crosses in generated PNG file.js-wire-scale
: Scaling of wire width for collision detection in generated JavaScript file.
- <string-value>
- Zero or more string literals containing the value that is assigned to the string definition. All given string literals get concatenated. Zero string literals are equivalent to the empty string.
- <float-value>
-
Float literal gets converted to a string. Or in other words, if second argument is a float value, then the
quotes can be omitted:
1.23
is equal to"1.23"
.