Magic is a Very-large-scale integration (VLSI) layout tool originally written by John Ousterhout and his graduate students at UC Berkeley.
Magic VLSI is a open source software for physical chip layout.Magic currently runs under Linux, although versions exist for DOS, OS/2, and other operating systems.
Magic is frequently used in conjunction with IRSIM and other simulation programs.
I would recommend to get Magic VLSI from the latest sources:https://github.com/libresilicon/magic-8.2
and also check these websites for further details:
http://opencircuitdesign.com/magic/
http://vlsi.csl.cornell.edu/magic/
http://www.research.digital.com/wrl/magic/magic.html
In order to open the layout of a cell, do the following:
- For starting up magic: Magic uses its own internal ASCII format for storing cells in disk files. Each cell name is stored in its own file, named name.mag.
- The first line in a .mag file is the string to identify this as a Magic file.
magic - The next line is optional and is used to identify the technology in which a cell was designed. If present, it should be of the form
tech techname (the technology we used is *scmos and sample6m) - If absent, the technology defaults to a system-wide standard, currently nmos.
- For selecting a file: In the top menu-bar select File > Open and navigate to one of the *.mag files from the examples, e.g. andgate.mag
- Select a *.mag file and click Open. The layout of the selected cell will be show in the main window called top level
- For editing the layout: you can edit the layout by entering commands in the command window called tkcon 2.3 main
- Further tutorials for Magic can be found here http://opencircuitdesign.com/magic/tutorials/tut1.html.
The output state of a digital logic AND gate only returns “LOW” again when ANY of its inputs are at a logic level “0”. In other words for a logic AND gate, any LOW input will give a LOW output.
Below is the picture of the andgate I designed:
After the completion of the drawing in Magic we basically need to extract the code of the drawing to test and see if we are getting the requried results and if the gate is working properly or not. This code includes the values of parasitic capacitors appear in the metal connections of the transistors, width to length ratios of the transistors and so on.This extraction can be done easily by extract all command. Then a file which has an extension of .ext will be saved to the common direction. However this .ext file is not usable for us, therefore we need to use ext2sim command to obtain the code of the magic layout design.THhe following file will be in .sim extension and it can be viewed by text editor in linux.lets see what IRSIM really is :
IRSIM is a tool for simulating digital circuits. It is a "switch-level" simulator; that is, it treats transistors as ideal switches. Extracted capacitance and lumped resistance values are used to make the switch a little bit more realistic than the ideal, using the RC time constants to predict the relative timing of events.
IRSIM shares a history with magic, although it is an independent program. Magic was designed to produce, and IRSIM to read, the ".sim" file format, which is largely unused outside of these two programs.
HOW IRSIM WORKS:
- The basic idea of IRSIM is that you tell it which nodes to pull high, which nodes to pull low, which nodes to tristate, and then you tell IRSIM to run the simulation for a certain period of time. This period of time is the stepsize.The stepsize we used in the inverter's stimulation is 50nanoseconds. The default stepsize is 10 nanoseconds.
- stepsize 50
- Because not all power supplies are so obviously labeled, it is necessary to provide power to your circuit by declaring the power supply ("vdd") to be logic high and ground ("gnd") to be logic low. This may seem trivial, but the simulation won't work without it.
h vdd
l gnd - The command 'w' tells IRSIM to watch the following nodes.
w a b input - d displays all the nodes that are being watched. You can also enter in something like 'd a ' which tells IRSIM to only display nodes a and b at time zero, the values of the nodes are all undefined
d - The l command forces the nodes to a logic low value of 0 The command below sets node a to logic 0
l a
l b - s tells IRSIM to simulate for a certain period of time previously defined by the stepsize command. The default value is 10 ns, but we set it to 50ns above.
s - IRSIM displays the values of the nodes after each step because of the previous d command. The current time is also displayed. Note that time = 50 ns. This is the current simulation time now.
- a=0 b=0 out=0
**h sets the following nodes to a logic high value. Therefore the above command sets node c to logic 1.
h a b - same steps will be repeated again for logic high value
- IRSIM has a built-in graphical logic analyzer which lets you view waveforms. The 'analyzer' command sets up the analyzer window.the following command will tell IRSIM to display the nodes a and b in the analyzer window
ana a b out
OR
analyzer a b out - IMPORTANT, When you set a node high or low using the h or l commands, the node keeps being set to high or low (no matter what the circuit is trying to do to the node!) until you use the x command to stop setting the node.
time = 0.000ns
note:
I am not a professional physical chip layout engineer and the content of this repository may not reflect any industry standard. Errors, even obvious ones, may be presented without proper indication.