1 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5 <link rel=
"stylesheet" media=
"screen" type=
"text/css" href=
"./style.css" />
6 <link rel=
"stylesheet" media=
"screen" type=
"text/css" href=
"./design.css" />
7 <link rel=
"stylesheet" media=
"print" type=
"text/css" href=
"./print.css" />
9 <meta http-equiv=
"Content-Type" content=
"text/html; charset=utf-8" />
14 <em>Translations of this guide are also available in the following languages:
</em> <a href=
"geda-gschem_symbol_creation.ru.html" class=
"wikilink1" title=
"geda-gschem_symbol_creation.ru.html">Русский
</a>
17 <h1 class=
"sectionedit1" id=
"geda_gaf_symbol_creation">gEDA/gaf Symbol Creation
</h1>
21 The latest version of this document may be found at:
<a href=
"http://www.geda-project.org/wiki/geda:gschem_symbol_creation" class=
"urlextern" title=
"http://www.geda-project.org/wiki/geda:gschem_symbol_creation" rel=
"nofollow">http://www.geda-project.org/wiki/geda:gschem_symbol_creation
</a><br/>
23 This document is released under the
<a href=
"geda-gfdl.html" class=
"wikilink1" title=
"geda-gfdl.html">GNU Free Documentation License (GFDL)
</a>.
<br/>
28 <!-- EDIT1 SECTION "gEDA/gaf Symbol Creation" [125-372] -->
29 <h2 class=
"sectionedit2" id=
"overview">Overview
</h2>
33 This document describes the manual creation of component symbols,
34 including style conventions, and hints/tips and things to look out
35 for when drawing symbols for the gEDA/gaf system.
39 For automatic symbol creation or conversion from other formats
40 please see the
<a href=
"geda-gschem_symbol_generators.html" class=
"wikilink1" title=
"geda-gschem_symbol_generators.html">gschem symbol generators
</a> page.
44 <!-- EDIT2 SECTION "Overview" [373-691] -->
45 <h2 class=
"sectionedit3" id=
"component_symbol_creation">Component Symbol Creation
</h2>
49 Component symbols (from here on known as “symbols”) are drawn using gschem. You can start with a blank page or a known-to-be good symbol that is similar to the one you want to create.
53 <!-- EDIT3 SECTION "Component Symbol Creation" [692-915] -->
54 <h3 class=
"sectionedit4" id=
"preparing">Preparing
</h3>
58 Before you open gschem to create your symbol, there are a few questions you should ask yourself, that will effect how you create your symbol:
61 <li class=
"level1"><div class=
"li"> Is this symbol purely for aesthetic purposes (a graphic)? If so, several steps are simplified.
</div>
63 <li class=
"level1"><div class=
"li"> Do I want to simulate the component in question, with e.g. Spice?
</div>
65 <li class=
"level1"><div class=
"li"> Do I want to use this symbol in a schematic that includes power distribution? This will become important when deciding what pins to draw.
</div>
67 <li class=
"level1"><div class=
"li"> Does this symbol represent a component that comes several in a package? This is called
'slotting
' in gEDA
's language, and has special rules.
</div>
72 Once you
've answered those questions, the following guide will be more useful to you.
76 To start building your symbol:
79 <li class=
"level1"><div class=
"li"> Open gschem.
</div>
81 <li class=
"level1"><div class=
"li"> The default empty page has boxes on it. Use the selection tool (the one that looks like a black mouse cursor) to select everything on the page. Hit the
<kbd>Delete
</kbd> key to delete it.
</div>
83 <li class=
"level1"><div class=
"li"> Zoom in at least one step (
<strong>View
</strong>→
<strong>Zoom
</strong>, or hit the
<kbd>Z
</kbd> key).
</div>
85 <li class=
"level1"><div class=
"li"> Make sure the snap-to-grid functionality is ON (
<strong>Options
</strong>→
<strong>Toggle Snap On/Off
</strong>, or
<kbd>O
</kbd> <kbd>S
</kbd>).
</div>
87 <li class=
"level1"><div class=
"li"> Make sure grid snap size is set to
100 (
<strong>Options
</strong>→
<strong>Snap Grid Spacing…
</strong>, or
<kbd>O
</kbd> <kbd>Shift
</kbd>+
<kbd>S
</kbd>).
</div>
92 <!-- EDIT4 SECTION "Preparing" [916-2184] -->
93 <h3 class=
"sectionedit5" id=
"drawing_your_symbol">Drawing your Symbol
</h3>
97 Use the
'line
',
'box
',
'circle
', and
'arc
' tools (in the
<strong>Add
</strong> menu) to create a simplified visual representation of your device. Make sure that the only colour you use is
'Graphic
' (green). Do not place any pins on the device until the next step.
101 To check what colour you are using to draw, go to
<strong>Edit
</strong>→
<strong>Color…
</strong> (or hit
<kbd>E
</kbd> <kbd>O
</kbd>).
105 <!-- EDIT5 SECTION "Drawing your Symbol" [2185-2576] -->
106 <h3 class=
"sectionedit6" id=
"placing_pins_on_your_symbol">Placing Pins on your Symbol
</h3>
110 If you have decided your symbol is graphical in nature (e.g., does not connect to anything, is just artwork), you can skip this step.
117 <li class=
"level1"><div class=
"li"> Select
<strong>Add
</strong>→
<strong>Pin
</strong>, or hit
<kbd>A
</kbd> <kbd>P
</kbd>. Once that is done, click from the end of your pin, to one of the edges of your symbol. A
'0' and the word
'unknown
' should pop up near your new pin. Please note that the direction you draw your pins is important. If you draw them starting from the edge of your symbol to outside of your symbol, you will end up with text outside of the symbol!
</div>
119 <li class=
"level1"><div class=
"li"> Click on the selection tool, and use it to select the pin you just drew. The pin and text with it should change colors, and boxes should be drawn around the ends of the pin.
</div>
121 <li class=
"level1"><div class=
"li"> Select
<strong>Edit
</strong>→
<strong>Edit…
</strong>, or hit
<kbd>E
</kbd> <kbd>E
</kbd> (or right click, and hit
<strong>Edit…
</strong>). This will bring up the edit dialog for this pin.
</div>
126 In the Edit dialog for a pin, you should see four attributes (
<code>name=value
</code> pairs) already associated with your new pin. These attributes can be edited by clicking on the attribute in the list at the top of the edit window, then clicking on the field you want to edit. Note that when selected, the
<strong>Add Attribute
</strong> section of this dialog does not reflect what has been selected, as it is only meant for addition, not for editing.
130 Let
's look at each attribute already associated with your pin, and edit some of the values. I recommend expanding the size of the edit window until all attributes are visible.
133 <li class=
"level1"><div class=
"li"> All pins should have a
<code>pinseq
</code> attribute. This number dictates the order pins are looked at on this symbol in spice, gnetlist, and other tools. For our first pin, start this sequence number at
'1', incrementing it on each new pin, as we add them.
</div>
135 <li class=
"level1"><div class=
"li"> All pins should have a
<code>pinnumber
</code> attribute. This is the number of the pin, on the package of the item you are drawing a symbol for.
<code>pinnumber
</code> values can be alphanumeric (i.e. like E or C).
</div>
137 <li class=
"level1"><div class=
"li"> All pins should have a
<code>pinlabel
</code> attribute. This attribute is the name or label of the pin (not the pin number).
</div>
139 <li class=
"level1"><div class=
"li"> All pins should have a
<code>pintype
</code> attribute. This attribute describes the kind of a pin.
</div>
141 <li class=
"level1"><div class=
"li"> <code>pinseq
</code> and
<code>pinnumber
</code> attributes of several pins can be automatically numbered by
<strong>Attributes
</strong>→
<strong>Autonumber Text…
</strong>.
</div>
146 Possible
<code>pintype
</code> values are:
<code>in
</code>,
<code>out
</code>,
<code>io
</code>,
<code>oc
</code>,
<code>oe
</code>,
<code>pas
</code>,
<code>tp
</code>,
<code>tri
</code>,
<code>clk
</code>,
<code>pwr
</code>. Please see the
<a href=
"geda-master_attributes_list.html#pintype" class=
"wikilink1" title=
"geda-master_attributes_list.html">Master
147 Attribute Document
</a> for more info.
151 <!-- EDIT6 SECTION "Placing Pins on your Symbol" [2577-5136] -->
152 <h3 class=
"sectionedit7" id=
"adding_attributes_to_your_symbol">Adding Attributes to your Symbol
</h3>
156 Every symbol needs some attributes (name=value pairs) in order to be useful in gschem, and in other tools.
160 First we
're going to add all of the attributes we want, then make the ones that need to be invisible invisible.
163 <li class=
"level1"><div class=
"li"> A
<code>device=DEVICENAME
</code> attribute should be placed somewhere in the symbol. The
<code>devicename
</code> should consist of nothing but capital letters, dashes, numbers, and underscores. If the object is a graphic then
<code>device=
</code> should be set to
<code>none
</code> (
<code>device=none
</code>).
</div>
165 <li class=
"level1"><div class=
"li"> A
<code>graphical=
1</code> attribute should exist somewhere in a symbol which is purely graphical (such as a title block or
<em>decon
</em> symbol). Symbols which have this attribute have no electrical or circuit significance. Don
't forget to set
<code>device=none
</code> per the previous step.
</div>
167 <li class=
"level1"><div class=
"li"> A
<code>description=TEXT
</code> attribute should exist somewhere in the symbol. The
<code>TEXT
</code> value should provide a one line description of the symbol.
</div>
169 <li class=
"level1"><div class=
"li"> A
<code>footprint=PACKAGENAME
</code> attribute should exist somewhere in the symbol which might be used with a pcb netlister.
<code>PACKAGENAME
</code> is a pcb footprint or package type like DIP14 or DIP40. Please see the
<a href=
"geda-pcb_footprint_naming_conventions.html" class=
"wikilink1" title=
"geda-pcb_footprint_naming_conventions.html"> footprint naming conventions
</a> page for further detail. If you are using gEDA / PCB, also see the
<a href=
"http://pcb.geda-project.org/manual.html" class=
"urlextern" title=
"http://pcb.geda-project.org/manual.html" rel=
"nofollow">PCB documentation
</a> and gnetlist/docs/README.pcb for more info on this attribute and how it is used.
</div>
171 <li class=
"level1"><div class=
"li"> A
<code>refdes=
</code> attribute should be placed inside all non-graphical symbols. This attribute should default to
<code>U?
</code> for integrated circuits, and
'T?
' for transistors. Make only the value visible and it will be promoted (attached to the outside of the symbol (so it can be edited)) when the symbol is placed in a schematic.
</div>
173 <li class=
"level1"><div class=
"li"> A
<code>numslots=
</code> attribute should be placed inside of all symbols, to prevent a warning when you will check your symbol by gsymcheck.
<code>numslots=
1</code> works fine.
</div>
178 Now that those have been added, make the
<code>numslots
</code>,
<code>footprint
</code>,
<code>description
</code>,
<code>graphical
</code> and
<code>device
</code> attributes invisible. Leave only the value of the
<code>refdes
</code> attribute visible, and place it somewhere at the top of your symbol.
182 <!-- EDIT7 SECTION "Adding Attributes to your Symbol" [5137-7315] -->
183 <h3 class=
"sectionedit8" id=
"finishing">Finishing
</h3>
186 <li class=
"level1"><div class=
"li"> Add a label to your symbol by selecting
<strong>Add
</strong>→
<strong>Text…
</strong> or pressing
<kbd>A
</kbd> <kbd>T
</kbd>. Type out your label, and move it to the top of your symbol.
</div>
188 <li class=
"level1"><div class=
"li"> Translate the symbol to the origin using
<strong>Edit
</strong>→
<strong>Symbol Translate…
</strong> or press
<kbd>E
</kbd> <kbd>T
</kbd>.
</div>
190 <li class=
"level1"><div class=
"li"> Enter
'0' into the entry field and press
<strong>OK
</strong>.
</div>
192 <li class=
"level1"><div class=
"li"> Save the symbol using
<strong>File
</strong>→
<strong>Save
</strong> or
<strong>File
</strong>→
<strong>Save As…
</strong></div>
194 <li class=
"level1"><div class=
"li"> Place the symbol in one of the directories specified as a symbol library in a suite configuration file (one of the “gafrc” files). For an explanation of how to set up symbol libraries, see the
<a href=
"geda-gschem_ug-config.html" class=
"wikilink1" title=
"geda-gschem_ug-config.html">gEDA gschem User Guide
</a>. Once this is done, the symbol should be visible immediately and can be selected and placed with the
<strong>Add
</strong>→
<strong>Select Component…
</strong> menu item. On Debian, placing files in /usr/share/gEDA/sym/local/ works, but requires permissions setup.
</div>
200 <h4 id=
"note">Note
</h4>
204 Translating the symbol to the origin is a required step. To translate a symbol elsewhere, enter a offset (in mils) which is a even multiple of
100. Make sure all pins are snapped to a
100 mil grid point.
208 <!-- EDIT8 SECTION "Finishing" [7316-8446] -->
209 <h2 class=
"sectionedit9" id=
"common_symbol_naming_conventions">Common Symbol Naming Conventions
</h2>
212 <li class=
"level1"><div class=
"li"> Symbols are named:
<code>symbolname-#.sym
</code></div>
214 <li class=
"level1"><div class=
"li"> Symbols end with a
<code>.sym
</code> extension.
</div>
216 <li class=
"level1"><div class=
"li"> Symbols have a
<code>-#
</code> where
<code>#
</code> is a number. Typically
<code>#
</code> is
1 but if there are multiple symbols for a device then this number simply increments.
</div>
218 <li class=
"level1"><div class=
"li"> Symbol names are typically lowercase but letters which are part of a part number are uppercase.
</div>
220 <li class=
"level1"><div class=
"li"> The above case rule can be broken if the filename looks incorrect or wrong.
</div>
225 <!-- EDIT9 SECTION "Common Symbol Naming Conventions" [8447-8914] -->
226 <h2 class=
"sectionedit10" id=
"symbol_requirements">Symbol Requirements
</h2>
230 This section describes the various requirements which must be met in order to create a valid symbol which will display and netlist in the gEDA/gaf system.
234 <!-- EDIT10 SECTION "Symbol Requirements" [8915-9102] -->
235 <h3 class=
"sectionedit11" id=
"pins">Pins
</h3>
238 <li class=
"level1"><div class=
"li"> All pins should have a
<code>pinseq
</code> attribute. This number dictates the order pins are looked at on this symbol in spice, gnetlist, and other tools. This is just a sequence number, and should increment sequentially starting at
1.
</div>
240 <li class=
"level1"><div class=
"li"> All pins should have a
<code>pinnumber
</code> attribute attached to them. This is the number of the pin, on the package of the item you are drawing a symbol for. The pin number can be alphanumeric (i.e. like E or C).
</div>
242 <li class=
"level1"><div class=
"li"> All pins should have a
<code>pinlabel
</code> attribute attached to them. This attribute is the name or label of the pin (not the pin number). This attribute is also used when a symbol is used in a hierarchical schematic.
</div>
244 <li class=
"level1"><div class=
"li"> All pins should have
<code>pintype
</code> attribute attached to them. This attribute describes the kind of a pin. Possible values are:
<code>in
</code>,
<code>out
</code>,
<code>io
</code>,
<code>oc
</code>,
<code>oe
</code>,
<code>pas
</code>,
<code>tp
</code>,
<code>tri
</code>,
<code>clk
</code>,
<code>pwr
</code>. Please see the
<a href=
"geda-master_attributes_list.html#pintype" class=
"wikilink1" title=
"geda-master_attributes_list.html">Master Attribute Document
</a> for more info.
</div>
249 <!-- EDIT11 SECTION "Pins" [9103-10085] -->
250 <h3 class=
"sectionedit12" id=
"attributes">Attributes
</h3>
254 For more information on the attributes presented here, please see the
<a href=
"geda-master_attributes_list.html" class=
"wikilink1" title=
"geda-master_attributes_list.html">Master
255 Attribute Document
</a>.
258 <li class=
"level1"><div class=
"li"> A
<code>device=DEVICENAME
</code> attribute should be placed somewhere in the symbol and made invisible. Typically the
<code>devicename
</code> is in all caps (capital letters). This attribute should not be used as a label. Use a separate text object for the label. If the object is a graphic then
<code>device=
</code> should be set to none (
<code>device=none
</code>).
</div>
260 <li class=
"level1"><div class=
"li"> A
<code>graphical=
1</code> attribute should exist somewhere in a symbol which is purely graphical (such as a title block or
<em>decon
</em> symbol). Symbols which have this attribute have no electrical or circuit significance. Don
't forget to set
<code>device=none
</code> per the previous requirement.
</div>
262 <li class=
"level1"><div class=
"li"> A
<code>description=TEXT
</code> attribute should exist somewhere in the symbol. The
<code>TEXT
</code> value should provide a one line description of the symbol.
</div>
264 <li class=
"level1"><div class=
"li"> A
<code>footprint=PACKAGENAME
</code> attribute should exist somewhere in the symbol which might be used with a pcb netlister.
<code>PACKAGENAME
</code> is a pcb footprint or package type like DIP14 or DIP40. Please see the
<a href=
"geda-pcb_footprint_naming_conventions.html" class=
"wikilink1" title=
"geda-pcb_footprint_naming_conventions.html"> footprint naming conventions
</a> page for further detail. If you are using gEDA / PCB, also see the
<a href=
"http://pcb.geda-project.org/manual.html" class=
"urlextern" title=
"http://pcb.geda-project.org/manual.html" rel=
"nofollow">PCB documentation
</a> and gnetlist/docs/README.pcb for more info on this attribute and how it is used.
</div>
266 <li class=
"level1"><div class=
"li"> A
<code>refdes=U?
</code> attribute should be placed inside all non-graphical symbols. Make only the value visible and it will be promoted (attached to the outside of the symbol, so it can be edited) when the symbol is placed in a schematic.
</div>
268 <li class=
"level1"><div class=
"li"> The
<code>label=
</code> and
<code>name=
</code> attributes should not exist anywhere in the symbol. They are obsolete.
</div>
270 <li class=
"level1"><div class=
"li"> The
<code>netname=
</code> attribute should not be attached anywhere in the symbol. It is only used in schematics.
</div>
276 <h4 id=
"slotting">Slotting
</h4>
279 <li class=
"level1"><div class=
"li"> If a component has multiple slots in a package (such as a
7400 (NAND) which has
4 NANDs per package) then you need a
<code>numslots=#
</code> attribute. The
<code>#
</code> is the number of slots the device has.
<code>numslots=
</code> should be exist somewhere in the symbol and made invisible. Additional slot related required attributes are described below.
</div>
281 <li class=
"level1"><div class=
"li"> If a component has multiple slots in a physical package then you also need to include a
<code>slotdef=#:#,#,#…
</code> for every slot. The first
<code>#
</code> corresponds to the slot number. If a device has
4 slots then there should be
<code>slotdef=
1:…
</code>,
<code>slotdef=
2:…
</code>,
<code>slotdef=
3:…
</code>, and
<code>slotdef=
4:…
</code>, attributes existing somewhere in the symbol and made invisible. The subsequent
<code>#
</code> have a one-to-one correspondence to
<code>pinseq=#
</code> attributes and specify what corresponding
<code>pinnumber=#
</code> should be when that slot is set. See the
<a href=
"#example" title=
":geda:gschem_symbol_creation.txt ↵" class=
"wikilink1">attached
7400-
1.sym
</a> as an example of how this should all work.
</div>
283 <li class=
"level1"><div class=
"li"> It is recommended that all symbols which have slots have a
<code>slot=
1</code> attribute inside the symbol.
</div>
288 <!-- EDIT12 SECTION "Attributes" [10086-13001] -->
289 <h2 class=
"sectionedit13" id=
"checking_a_symbol">Checking a Symbol
</h2>
293 Running gsymcheck will check that all of these requirements are met. gsymcheck will output fatal errors which are quite serious and must be corrected. gsymcheck will also output warnings on things which should be fixed but are not fatal.
297 <!-- EDIT13 SECTION "Checking a Symbol" [13002-13271] -->
298 <h2 class=
"sectionedit14" id=
"style">Style
</h2>
302 This section describes the style which is used in the standard gEDA/gaf symbol library.
306 <!-- EDIT14 SECTION "Style" [13272-13379] -->
307 <h3 class=
"sectionedit15" id=
"text">Text
</h3>
310 <li class=
"level1"><div class=
"li"> All text labels should all be
10 pt in size.
</div>
312 <li class=
"level1"><div class=
"li"> Text (labels not attributes) should be color number
9 (text | green).
</div>
314 <li class=
"level1"><div class=
"li"> Use the special overbar encoding (e.g.
<code>pinlabel=\_Reset\_
</code>) to express inverse logic levels.
</div>
319 <!-- EDIT15 SECTION "Text" [13380-13619] -->
320 <h3 class=
"sectionedit16" id=
"attributes1">Attributes
</h3>
323 <li class=
"level1"><div class=
"li"> <code>pinnumber
</code> attributes should be displayed as pin numbers for pins (not
<code>pinseq
</code>) and should be
8 pt in size.
</div>
325 <li class=
"level1"><div class=
"li"> Attached attributes should be color number
5 (attributes | yellow). The color is set automatically to yellow if the text item is attached.
</div>
327 <li class=
"level1"><div class=
"li"> The only exception to this is
<code>pinlabel=
</code> attributes, those should be color number
9 (text | green). If every text item within a symbol is yellow, the symbol looks too yellow.
</div>
329 <li class=
"level1"><div class=
"li"> Attributes can be attached to some part of the symbol. Toplevel attributes (like the
<code>device=
</code> or
<code>net=
</code> attributes) used to be required to be attached to something to be attributes, but now they just have to exist in the symbol file as
<code>name=value
</code>.
</div>
331 <li class=
"level1"><div class=
"li"> Expanding a bit on the last sentence, as long as the text item has the format
<code>name=value
</code>, it is considered an attribute. Attributes inside a symbol do not have to be attached to anything. In order to see hidden attributes in gschem select
<strong>Edit
</strong>→
<strong>Show/Hide Inv Text
</strong>.
</div>
333 <li class=
"level1"><div class=
"li"> There is a symbol content versioning system in libgeda which is based on the
<code>symversion=
</code> attribute. Please see the
<a href=
"geda-master_attributes_list.html#symversion" class=
"wikilink1" title=
"geda-master_attributes_list.html">Master Attribute Document
</a> for more information on using this versioning scheme.
</div>
338 <!-- EDIT16 SECTION "Attributes" [13620-14868] -->
339 <h3 class=
"sectionedit17" id=
"graphics">Graphics
</h3>
342 <li class=
"level1"><div class=
"li"> Lines, boxes, arcs, and any other graphics should be color number
3 (graphic | green).
</div>
344 <li class=
"level1"><div class=
"li"> Polarity bubbles should be color number
6 (logic bubble | cyan).
</div>
346 <li class=
"level1"><div class=
"li"> If you are unsure on how to make a new symbol look or how big to make a new symbol, look at the existing symbols to get a feel for the appropriate appearance and size.
</div>
351 <!-- EDIT17 SECTION "Graphics" [14869-15220] -->
352 <h3 class=
"sectionedit18" id=
"pins1">Pins
</h3>
355 <li class=
"level1"><div class=
"li"> Pins should all be
300 mils (
3 grid spaces) long.
</div>
357 <li class=
"level1"><div class=
"li"> For pins which are next to a logic bubble, make the pins
200 mils (
2 grid spaces) long and then make the logic bubble
100 mils in diameter. In order to draw a
100 mil diameter circle, you will need to change the snap spacing to
50.
</div>
359 <li class=
"level1"><div class=
"li"> A pin has two ends: one end has a red endpoint and one end that does not. The red endpoint is where nets can be connected. You can either rotate the pin so that this active end is in the right place or manually edit the symbol file changing the “whichend” parameter on the pin object. See the
<a href=
"geda-file_format_spec.html#pin" class=
"wikilink1" title=
"geda-file_format_spec.html">File Format document
</a> for more info.
</div>
361 <li class=
"level1"><div class=
"li"> Be that all endpoints of pins which are meant to be connected to are on the
100 mil grid. The endpoint which is not active can be off the grid if necessary.
</div>
363 <li class=
"level1"><div class=
"li"> Pins should be color number
1 (pins | white).
</div>
365 <li class=
"level1"><div class=
"li"> Leave
400 mils (
4 grid spaces) between (vertically) pins, unless you are drawing a special symbol, then just try to make it look good.
</div>
367 <li class=
"level1"><div class=
"li"> Pin number attributes should be
50 mils above (or below; which ever makes the most sense) the pin which they are attached to.
</div>
369 <li class=
"level1"><div class=
"li"> Input pins belong on the left and output pins belong on the right of the symbol.
</div>
371 <li class=
"level1"><div class=
"li"> Please do not mix inputs and outputs on the same side of the symbol, unless absolutely necessary.
</div>
373 <li class=
"level1"><div class=
"li"> You can have pins on the top or bottom of a symbol.
</div>
375 <li class=
"level1"><div class=
"li"> The order for rows of pins (buses) should be LSB (least significant bit) to MSB (most significant bit). When drawing pins which are part of a bus, make sure the LSB of the bus is at the top (or for pins on top/bottom of a symbol, left of the rest of the other pins). Look at
74/
74181-
1.sym for a correct example of this order (A0 on top through A3 and B0 on top through B3). Violating this rule will make connecting buses much more difficult.
</div>
377 <li class=
"level1"><div class=
"li"> When placing pins on logic gates, be sure to place the smallest pin numbers toward the top (or left) and then increment going down (or across).
</div>
382 <!-- EDIT18 SECTION "Pins" [15221-17202] -->
383 <h3 class=
"sectionedit19" id=
"electrical">Electrical
</h3>
386 <li class=
"level1"><div class=
"li"> Do not draw power and ground pins. That information will be conveyed using attributes (see the
<a href=
"geda-na_howto.html" class=
"wikilink1" title=
"geda-na_howto.html">net= attribute mini-HOWTO
</a>).
</div>
388 <li class=
"level1"><div class=
"li"> The above rule can be broken if necessary, but keep in mind most of the standard library does not have power pins showing.
</div>
390 <li class=
"level1"><div class=
"li"> Keep in mind, symbols are supposed to be symbolic, they do not represent the physical package that the device comes in.
</div>
392 <li class=
"level1"><div class=
"li"> There is some disagreement on above, so this is okay too: arrange the pins on a symbol logically so that they promote an uncluttered schematic. Note that this is frequently not the same pin arrangement as the physical device.
</div>
397 <!-- EDIT19 SECTION "Electrical" [17203-17845] -->
398 <h2 class=
"sectionedit20" id=
"hints_and_tips">Hints and Tips
</h2>
402 This section describes some hints and tips which will make your symbol creation
406 <li class=
"level1"><div class=
"li"> Pins MUST be snapped on the
100-spaced grid.
</div>
408 <li class=
"level1"><div class=
"li"> Avoid drawing things off of the grid. If you do, you cannot move the object(s) using the move command (if the grid is on) since the object will be snapped to the grid. [This was an old bug, which I think has been fixed, but avoid doing this anyway]. Use the symbol translate command instead (or move the object with grid snap off).
</div>
410 <li class=
"level1"><div class=
"li"> It is okay to set the grid finer than
100 (say
10 or
25) when creating symbols, just remember to set this back to
100 once you are ready to translate the symbol to the origin.
</div>
412 <li class=
"level1"><div class=
"li"> If you want to translate a symbol from the origin to elsewhere, then use the
<strong>Edit
</strong>→
<strong>Symbol Translate…
</strong> command and enter a non zero number. Make sure this number is a multiple of
100 (i.e.
1000, or
1100).
</div>
414 <li class=
"level1"><div class=
"li"> Remember that pins are special objects; if you want to add a pin, make sure it is a pin and not a line or net. Use the
<strong>Add
</strong>→
<strong>Pin
</strong> command to place a pin.
</div>
416 <li class=
"level1"><div class=
"li"> Don
't include nets or buses inside symbols. That is not supported and doesn
't make much sense anyway.
</div>
418 <li class=
"level1"><div class=
"li"> <code>pinnumber
</code> should be the visible attribute for pins, along with
<code>pinlabel
</code> if any.
</div>
423 <!-- EDIT20 SECTION "Hints and Tips" [17846-19117] -->
424 <h2 class=
"sectionedit21" id=
"example">Example
</h2>
428 This section provides a simple example which tries to follow all of the above rules. This symbol is of a
7400 (NAND gate).
431 <dt><a href=
"/./_export/code/:geda:gschem_symbol_creation.txt?codeblock=0" title=
"Download Snippet" class=
"mediafile mf_sym">7400-
1.sym
</a></dt>
432 <dd><pre class=
"code gschem">v
20031231 1
433 L
300 200 300 800 3 0 0 0 -
1 -
1
434 T
300 0 9 8 1 0 0 0 1
436 L
300 800 700 800 3 0 0 0 -
1 -
1
437 T
500 900 5 10 0 0 0 0 1
439 T
500 1100 5 10 0 0 0 0 1
441 T
500 1300 5 10 0 0 0 0 1
443 T
500 1500 5 10 0 0 0 0 1
445 T
500 1700 5 10 0 0 0 0 1
447 T
500 1900 5 10 0 0 0 0 1
449 T
500 2100 5 10 0 0 0 0 1
451 L
300 200 700 200 3 0 0 0 -
1 -
1
452 A
700 500 300 270 180 3 0 0 0 -
1 -
1
453 V
1050 500 50 6 0 0 0 -
1 -
1 0 -
1 -
1 -
1 -
1 -
1
454 P
1100 500 1300 500 1 0 1
456 T
1100 550 5 8 1 1 0 0 1
458 T
1100 450 5 8 0 1 0 2 1
460 T
950 500 9 8 0 1 0 6 1
462 T
950 500 5 8 0 1 0 8 1
465 P
300 300 0 300 1 0 1
467 T
200 350 5 8 1 1 0 6 1
469 T
200 250 5 8 0 1 0 8 1
471 T
350 300 9 8 0 1 0 0 1
473 T
350 300 5 8 0 1 0 2 1
476 P
300 700 0 700 1 0 1
478 T
200 750 5 8 1 1 0 6 1
480 T
200 650 5 8 0 1 0 8 1
482 T
350 700 9 8 0 1 0 0 1
484 T
350 700 5 8 0 1 0 2 1
487 T
300 900 8 10 1 1 0 0 1
489 T
500 2250 5 10 0 0 0 0 1
491 T
500 2450 5 10 0 0 0 0 1
492 description=
4 NAND gates with
2 inputs
493 T
500 2850 5 10 0 0 0 0 1
495 T
500 3050 5 10 0 0 0 0 1
497 T
500 2650 5 10 0 0 0 0 1
498 documentation=http://www-s.ti.com/sc/ds/sn74hc00.pdf
</pre>
502 This example produces the following (using gschem):
506 <a href=
"media/geda/symbol_7400-1_hidden.png" class=
"media" target=
"_blank" title=
"geda:symbol_7400-1_hidden.png"><img src=
"media/geda/symbol_7400-1_hidden.png" class=
"media" title=
":geda:symbol_7400-1_hidden.png" alt=
":geda:symbol_7400-1_hidden.png" /></a>
510 This is the same symbol with all the hidden text visible (via
<strong>Edit
</strong>→
<strong>Show/Hide Inv Text
</strong>):
514 <a href=
"media/geda/symbol_7400-1.png" class=
"media" target=
"_blank" title=
"geda:symbol_7400-1.png"><img src=
"media/geda/symbol_7400-1.png" class=
"media" title=
":geda:symbol_7400-1.png" alt=
":geda:symbol_7400-1.png" /></a>
518 <!-- EDIT21 SECTION "Example" [19118-] --></body>