- update tutorial

OCR->NERO  etc ...
  Spelling
  (but a lot of french or unknown words still remain,
  it would have been better translate from french to english
  using google language !!)
This commit is contained in:
Ludovic Jacomme 2004-07-15 16:15:14 +00:00
parent ab53431dc5
commit 520ba3a840
2 changed files with 105 additions and 151 deletions

View File

@ -1,30 +1,25 @@
TEX = place_and_route.tex TEX = place_and_route.tex
FIG = buff_x1.fig controleplace.fig dpt-all-1.fig gabarit2_sx.fig gabarit3_sx.fig gabarit_sx.fig hierarchie.fig inv_x1.fig placement.fig preplacement.fig colonnes.fig hier.fig bloc.fig stick.fig FIG = buff_x1.fig controleplace.fig dpt-all-1.fig gabarit2_sx.fig gabarit3_sx.fig gabarit_sx.fig hierarchie.fig inv_x1.fig placement.fig preplacement.fig colonnes.fig hier.fig bloc.fig stick.fig
EPS = $(FIG:.fig=.eps) EPS = $(FIG:.fig=.eps)
PDF = $(EPS:.eps=.pdf)
all : place_and_route.pdf
cp place_and_route.pdf ../../
%.pdf : %.tex place_and_route.pdf : place_and_route.dvi
pdflatex $< dvipdf place_and_route.dvi
%.dvi : %.tex place_and_route.ps : place_and_route.dvi
dvipds place_and_route.dvi -o place_and_route.ps
place_and_route.dvi : place_and_route.tex $(EPS)
latex $< latex $<
latex $< latex $<
%.ps : %.dvi
dvips -o $@ $<
%.eps : %.fig %.eps : %.fig
fig2dev -L eps $< > $@ fig2dev -L eps $< > $@
all : $(TEX:.tex=.ps) $(TEX:.tex=.pdf)
$(EPS) : $(FIG) $(EPS) : $(FIG)
$(PDF) : $(EPS) $(PDF) : $(EPS)
$(TEX:.tex=.ps) : $(TEX:.tex=.dvi)
$(TEX:.tex=.dvi) : $(EPS)
$(TEX:.tex=.pdf) : $(PDF)
clean : clean :
rm -f *~ *.aux *.log *.pdf *.dvi *.ps *.out *.toc *.eps rm -f *~ *.aux *.log *.pdf *.dvi *.ps *.out *.toc *.eps

View File

@ -72,7 +72,7 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{\Huge ALLIANCE TUTORIAL \\} {\Huge ALLIANCE TUTORIAL \\}
{\large {\large
Pierre \& Marie Curie University \\ Pierre \& Marie Curie University \\
year 2001 - 2002\\ year 2001 - 2004\\
} }
\vspace{1cm} \vspace{1cm}
{\huge {\huge
@ -97,7 +97,7 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
\\ \\
{1} {\bf Introduction} {1} {\bf Introduction}
\\ \\
{2 }{\bf Inversor and buffer drawing under GRAAL} {2 }{\bf Inverter and buffer drawing using GRAAL}
{2.1} Introduction {2.1} Introduction
@ -107,11 +107,9 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
\hspace{0.5cm} {2.1.3} COUGAR \hspace{0.5cm} {2.1.3} COUGAR
\hspace{0.5cm} {2.1.4} YAGLE
\hspace{0.5cm} {2.1.5} PROOF \hspace{0.5cm} {2.1.5} PROOF
{2.2} inversor Diagram {2.2} inverter Diagram
{2.3} Buffer diagram {2.3} Buffer diagram
@ -119,7 +117,7 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{2.5} steps to follow {2.5} steps to follow
\hspace{0.5cm} {2.5.1} Create an inversor \hspace{0.5cm} {2.5.1} Create an inverter
\hspace{0.5cm} {2.5.2} Create a buffer \hspace{0.5cm} {2.5.2} Create a buffer
\\ \\
@ -158,17 +156,17 @@ This directory contents three subdirectories and one Makefile :
\begin{itemize}\itemsep=-.8ex \begin{itemize}\itemsep=-.8ex
\item Makefile \item Makefile
\item inversor \item inv
\begin{itemize}\itemsep=-.8ex \begin{itemize}\itemsep=-.8ex
\item Makefile \item Makefile
\item inversor.vbe : behavioral description \item inv.vbe : behavioral description
\item inv\_x1.ap : inversor cell under GRAAL \item inv\_x1.ap : inverter cell design using GRAAL
\end{itemize} \end{itemize}
\item buffer \item buffer
\begin{itemize}\itemsep=-.8ex \begin{itemize}\itemsep=-.8ex
\item Makefile \item Makefile
\item buffer.vbe : behavioral description \item buffer.vbe : behavioral description
\item buf\_x2.ap : buffer cell under GRAAL \item buf\_x2.ap : buffer cell design using GRAAL
\end{itemize} \end{itemize}
\item amd2901 \item amd2901
\begin{itemize}\itemsep=-.8ex \begin{itemize}\itemsep=-.8ex
@ -196,11 +194,11 @@ This directory contents three subdirectories and one Makefile :
\item {\bf DRUC} Design rule checker ; \item {\bf DRUC} Design rule checker ;
\item {\bf COUGAR} Symbolic layout extractor ; \item {\bf COUGAR} Symbolic layout extractor ;
\item {\bf PROOF} Formal proof between two behavioral descriptions ; \item {\bf PROOF} Formal proof between two behavioral descriptions ;
\item {\bf OCP, OCR, RING} place and route tools . \item {\bf OCP, OCR, NERO, RING} place and route tools .
\end{itemize} \end{itemize}
The beginning of this tutorial will relate to the drawing under { The beginning of this tutorial will relate to the drawing under {
\bf GRAAL } of a inversor cell and a buffer. \bf GRAAL } of a inverter cell and a buffer.
The predefined cells concepts, model and The predefined cells concepts, model and
hierarchy will be introduced .\\ hierarchy will be introduced .\\
Then this tutorial contain the methodology used in Alliance to produce Then this tutorial contain the methodology used in Alliance to produce
@ -210,24 +208,25 @@ PART 2 "Synthesis" (All the documents used will be provided to you).
\newpage \newpage
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\section{Inversor and buffer drawing under GRAAL} \section{Inverter and buffer drawing under GRAAL}
%----------------------------------------------- %-----------------------------------------------
\subsection{Introduction} \subsection{Introduction}
%------------------------ %------------------------
The library can be enriched by new cells with {\bf GRAAL} editor .\\ The library can be enriched by new cells with {\bf GRAAL} editor .\\
{ \bf GRAAL } is an editor of \/{\underline{symbolic }} {\it { \bf GRAAL } is an editor of \/{\underline{symbolic }} {\it
layout} integrating the drawing rules checker {\bf DRUC}. The layout} integrating the drawing rules checker {\bf DRUC} and also
first part here aims to draw a inversor cell inv\_x1 in the shape a net extractor.
of a predefined cell sxlib by complying with the provided The first part here aims to draw an inverter cell inv\_x1 in the shape
of a predefined cell of sxlib complyiant with provided
drawing rules. drawing rules.
\subsubsection{Technological environment} \subsubsection{Technological environment}
%-------------------- %--------------------
Some tools of Alliance use a particular technological Some tools of Alliance use a particular technological
environment. It is indicated by the environment variable {\bf environment. It is indicated by the environment variable {\bf
RDS\_TECHNO\_NAME} which must be positioned with RDS\_TECHNO\_NAME} which must be set to
{\bf/asim/alliance/etc/cmos\_12.rds} {\bf/alliance/etc/cmos.rds}
\subsubsection{GRAAL} \subsubsection{GRAAL}
%-------------------- %--------------------
@ -236,8 +235,8 @@ RDS\_TECHNO\_NAME} which must be positioned with
\begin{itemize}\itemsep=-.4ex \begin{itemize}\itemsep=-.4ex
\item The ''instance'' (physical cells importation) \item The ''instance'' (physical cells importation)
\item The abutment boxes which define the cell limits \item The abutment boxes which define the cell limits
\item Segments: DiffN, DiffP, Poly, Alu1, Alu2... CAluX is used to indicate \item Segments: DiffN, DiffP, Poly, Alu1, Alu2... CAluX is used to specify
a possible portion for the connectors. a possible rectangle area for the connectors.
\item VIAs or contacts: ContDiffN, ContDiffP, ContPoly and \item VIAs or contacts: ContDiffN, ContDiffP, ContPoly and
ViaMetal1/Metal2. ViaMetal1/Metal2.
\item Big VIAs \item Big VIAs
@ -245,8 +244,7 @@ RDS\_TECHNO\_NAME} which must be positioned with
\end{itemize} \end{itemize}
{\bf GRAAL} uses the environment variable {\bf {\bf GRAAL} uses the environment variable {\bf
GRAAL\_TECHNO\_NAME}. It must be positioned with GRAAL\_TECHNO\_NAME}. It must be set to {\bf/alliance/etc/cmos.graal}.
{\bf/asim/alliance/etc/cmos\_12.graal}.
Steps to follow to create a sxlib cell by respecting the sxlib gauge : Steps to follow to create a sxlib cell by respecting the sxlib gauge :
( cf 2.4 Sxlib gauge ) ( cf 2.4 Sxlib gauge )
@ -264,23 +262,23 @@ Steps to follow to create a sxlib cell by respecting the sxlib gauge :
\subsubsection{COUGAR} \subsubsection{COUGAR}
%-------------------- %--------------------
The tool { \bf COUGAR } is able to extract the { \it netlist } from The tool { \bf COUGAR } is able to extract the { \it netlist } from
a circuit to the format { \bf vst } starting from a description a circuit to the format { \bf al } or { \bf spi } given a layout description
with the format { \bf ap }. To extract on the level transistor, with the format { \bf ap }.
the command to be used is: To extract a netlist at transistor level, use the following command :
\begin{commandline} \begin{commandline}
> cougar -t file1 file2 > cougar -t file1 file2
\end{commandline} \end{commandline}
{ \bf COUGAR } uses the environment variables { \bf MBK\_IN\_PH } { \bf COUGAR } uses the environment variables { \bf MBK\_IN\_PH }
and { \bf MBK\_OUT\_LO } according to the input and output formats. and { \bf MBK\_OUT\_LO } according to the input and output formats.
For example to generate a netlist with the format { \bf .al } For example to generate a SPICE netlist (with the format { \bf .spi })
starting from a description { \bf .ap } it is necessary to write: \\ starting from a layout description { \bf .ap } it is necessary to set
the following environment variables: \\
\begin{commandline} \begin{commandline}
> MBK_IN_PH = ap > MBK_IN_PH = ap
> export MBK_IN_PH > export MBK_IN_PH
> MBK_OUT_LO = al > MBK_OUT_LO = spi
> export MBK_OUT_LO > export MBK_OUT_LO
\end{commandline} \end{commandline}
@ -288,60 +286,23 @@ starting from a description { \bf .ap } it is necessary to write: \\
> cougar -t circuit circuit > cougar -t circuit circuit
\end{commandline} \end{commandline}
\subsubsection{YAGLE} The resulting spice netlist can be then simulated using a SPICE simulator and a given
%-------------------- model card for a dedicated technology.
The tool { \bf YAGLE } is able to extract the behavioral
VHDL description of a circuit to the format { \bf .vbe } starting
from a { \it netlist } \/with the format { \bf .al } { \it if this
one is on the transistor level }.
The command to be used is: \\
The schematic of the transistor neltlist can also be displayed using {\bf XSCH} :
\begin{commandline} \begin{commandline}
> MBK_IN_LO = al > xsch -I spi -l circuit
> export MBK_IN_LO
> YAGLE_BEH_FORMAT = vbe
> export YAGLE_BEH_FORMAT
\end{commandline} \end{commandline}
\begin{commandline} \subsection{inverter Diagram}
> yagle file1 file2
\end{commandline}
Above all, you must use the command:
\begin{commandline}
> source /users/soft5/newlabo/AvtTools/etc/avt_env.csh
\end{commandline}
which allows to set up the environment necessary to use { \bf YAGLE }.\\
Documentations for this tool are in :
{\bf/users/soft5/newlabo/AvtTools/doc}
But the tool { \bf YAGLE } is not part of Alliance anymore. If you want
to use it, you have to get the licence from Avertec.
\subsubsection{PROOF}
%--------------------
When we want to prove the equivalence between two behavioral
descriptions of the same circuit with N inputs, we can simulate
by asimut $2^n$ vectors for two descriptions and compare them.
This solution quickly becomes expensive in CPU time and it is
better to use formal proof tool which carries out the
"mathematical" comparison of the two Boolean networks. { \bf PROOF
} carries out this operation between descriptions file1.vbe and
file2.vbe by the command:
\begin{commandline}
> proof file1 file2
\end{commandline}
\subsection{inversor Diagram}
%--------------------------------- %---------------------------------
The theoretical inversor diagram is presented at the following The theoretical inverter diagram is presented at the following
figure: figure:
\begin{figure}[H]\centering \begin{figure}[H]\centering
\includegraphics[width=6cm]{inv_x1.eps} \includegraphics[width=6cm]{inv_x1.eps}
\caption{transistors diagram of a C-MOS inversor} \caption{transistors diagram of a C-MOS inverter}
\label{Fig:inv_x1} \label{Fig:inv_x1}
\end{figure} \end{figure}
@ -357,7 +318,7 @@ figure:
\label{Fig:buff_x1} \label{Fig:buff_x1}
\end{figure} \end{figure}
It uses two inversors according to the hierarchy: It uses two inverter according to the hierarchy:
\begin{figure}[H]\centering \begin{figure}[H]\centering
\includegraphics[width=8cm]{hierarchie.eps} \includegraphics[width=8cm]{hierarchie.eps}
@ -376,8 +337,7 @@ horizontally placed in top and bottom of the cell.
to the Vss. to the Vss.
\item Box N must have 24 lambdas height . \item Box N must have 24 lambdas height .
\item The special segments CAluX (CAlu1, Calu2, CAlu3...) form the cell interface (PORT\_MAP) \item The special segments CAluX (CAlu1, Calu2, CAlu3...) form the cell interface (PORT\_MAP)
and play the role of ''flat'' connectors. They must {\underline{obligatorily}} and play the role of ''flat'' connectors. They must be placed on a 5x5 grid and can be anywhere in the cell.
be placed on a 5x5 grid and can be anywhere in the cell.
\item The special segments TAlux (TAlu1, TAlu2...) are used to indicate the obstacles for the \item The special segments TAlux (TAlu1, TAlu2...) are used to indicate the obstacles for the
router. When you want to protect AluX segment, it is necessary to cover them router. When you want to protect AluX segment, it is necessary to cover them
or surround them by corresponding TAlux (same layer). TAluX are placed on a grid or surround them by corresponding TAlux (same layer). TAluX are placed on a grid
@ -410,12 +370,12 @@ You will find a summary of these constraints on the diagram
\subsection{steps to follow} \subsection{steps to follow}
%--------------------------------- %---------------------------------
\subsubsection{Create an inversor} \subsubsection{Create an inverter}
%-------------------- %--------------------
\begin{itemize}\itemsep=-.4ex \begin{itemize}\itemsep=-.4ex
\item describe the cell inversor behavior in a file { \bf .vbe } . \item describe the cell inverter behavior in a file { \bf .vbe } .
\item draw the inversor "stick-diagram" inv\_x1 whose transistors diagram \item draw the inverter "stick-diagram" inv\_x1 whose transistors diagram
is represented on the figure \ref{Fig:inv_x1}. is represented on the figure \ref{Fig:inv_x1}.
\begin{figure}[H]\centering \begin{figure}[H]\centering
@ -427,17 +387,14 @@ You will find a summary of these constraints on the diagram
\item draw the cell under {\bf GRAAL} by respecting the \item draw the cell under {\bf GRAAL} by respecting the
gauge specified on the figure \ref{Fig:gabarit}. gauge specified on the figure \ref{Fig:gabarit}.
\item validate the symbolic drawing rules by launching {\bf DRUC} under {\bf GRAAL}. \item validate the symbolic drawing rules by launching {\bf DRUC} under {\bf GRAAL}.
\item extract the { \it netlist } \/from the inversor to the format {\bf al} with {\bf COUGAR}. \item extract the { \it netlist } \/from the inverter to the format {\bf al} with {\bf COUGAR}.
\item extract the behavioral VHDL with { \bf YAGLE }
\item carry out the formal proof between the file { \bf .vbe } extracts by { \bf YAGLE }
and the file { \bf .vbe } from the initial specification.
\end{itemize} \end{itemize}
\subsubsection{Create a buffer} \subsubsection{Create a buffer}
%-------------------- %--------------------
The buffer is produced under { \bf GRAAL } starting from the The buffer is produced under { \bf GRAAL } starting from the
instanciated of two inversors. The hierarchy thus created is instanciated of two inverters. The hierarchy thus created is
represented on the figure \ref{Fig:hier_x1}. The transistors represented on the figure \ref{Fig:hier_x1}. The transistors
diagram is represented on the figure \ref{Fig:buff_x1}. diagram is represented on the figure \ref{Fig:buff_x1}.
@ -446,17 +403,14 @@ diagram is represented on the figure \ref{Fig:buff_x1}.
\item draw the cell under {\bf GRAAL} by respecting the \item draw the cell under {\bf GRAAL} by respecting the
gauge specified on the figure \ref{Fig:gabarit}. gauge specified on the figure \ref{Fig:gabarit}.
You will use for that the instanciated function of { \bf GRAAL }. You will use for that the instanciated function of { \bf GRAAL }.
The cell with instanciate is of course the inversor, which you will connect (will routing) manually. The cell with instanciate is of course the inverter, which you will connect (will routing) manually.
\item validate the symbolic drawing rules by launching {\bf DRUC} under {\bf GRAAL}. \item validate the symbolic drawing rules by launching {\bf DRUC} under {\bf GRAAL}.
\item extract the { \it netlist } \/from the buffer to the format {\bf al} with {\bf COUGAR}. \item extract the { \it netlist } \/from the buffer to the format {\bf al} with {\bf COUGAR}.
\item extract the behavioral VHDL with { \bf YAGLE }
\item carry out the formal proof between the file { \bf .vbe } extracts by { \bf YAGLE }
and the file { \bf .vbe } from the initial specification.
\end{itemize} \end{itemize}
Do not forget that the { \it mans } exist... Do not forget that { \it man } pages exist...
We provide you the cells behaviour description inversor.vbe and buffer.vbe; We provide you the cells behaviour description inv.vbe and buffer.vbe;
and the cells inversor and buffer draws under { \bf GRAAL }. and the cells inverter and buffer drawn under { \bf GRAAL }.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
@ -467,7 +421,7 @@ and the cells inversor and buffer draws under { \bf GRAAL }.
%--------------------------------- %---------------------------------
Am2901 breaks up into 2 blocks: the part controls which gathers Am2901 breaks up into 2 blocks: the part controls which gathers
the logical `` glu '' and the operative part (data-path). the logical `` glu '' (random logic) and the operative part (data-path).
\begin{figure}[H]\centering \begin{figure}[H]\centering
\includegraphics[scale=0.8]{bloc.eps} \includegraphics[scale=0.8]{bloc.eps}
@ -480,11 +434,10 @@ the logical `` glu '' and the operative part (data-path).
\item The data-path contains the regular parts of Amd2901, the registers \item The data-path contains the regular parts of Amd2901, the registers
and the arithmetic logic unit. and the arithmetic logic unit.
\item The control part contains irregular logic, \item The control part contains irregular logic,
the instructions decoding and the `` flags '' calculation. the instructions decoding and the `` flags '' computation.
\end{itemize} \end{itemize}
Hierarchical description used is as follows: The Hierarchy of descriptions is as follows:
\begin{figure}[H]\centering \begin{figure}[H]\centering
\includegraphics[scale=0.8]{hier.eps} \includegraphics[scale=0.8]{hier.eps}
\caption{Hierarchy used} \caption{Hierarchy used}
@ -494,9 +447,9 @@ Hierarchical description used is as follows:
\subsection{Tools used} \subsection{Tools used}
%--------------------------------- %---------------------------------
You will use place and route tools { \bf ocp } and {\bf ocr }, You will use place and route tools { \bf ocp } and {\bf nero },
thus all tools for checking seen in the first part of this Tutorial .\\ thus all tools for checking seen in the first part of this Tutorial .\\
{\bf ocp} is the placer, {\bf ocr} allows routing over the cell. {\bf ocp} is the placer, {\bf nero} allows routing over the cell.
The data-path and the control part will be placed and routed together and not separately. \\ The data-path and the control part will be placed and routed together and not separately. \\
You will use also {\bf lvx}, the netlists comparator. When the You will use also {\bf lvx}, the netlists comparator. When the
system is too complex it is difficult to use {\bf proof}, the system is too complex it is difficult to use {\bf proof}, the
@ -546,25 +499,25 @@ amd2901\_core. Check well that you do not overwrite a file!
For the moment, your file amd2901\_dpt.c contains only one logical For the moment, your file amd2901\_dpt.c contains only one logical
description of the netlist. description of the netlist.
eg you have a file C which contains the lines: \\ eg you have a C file that contains the following lines: \\
\noindent GENLIB\_DEF\_LOFIG()\\ \noindent GENLIB\_DEF\_LOFIG()\\
\noindent ...\\ \noindent ...\\
\noindent GENLIB\_SAVE\_LOFIG()\\ \noindent GENLIB\_SAVE\_LOFIG()\\
That enables you to generate a description structural in file{ \bf This permits to generate a structural description in a { \bf
VST }. But at the same time, { \bf genlib } generated physical VST } file. At the same time, { \bf genlib } will generate
descriptions of each column in files { \bf AP }. physical descriptions of each column in { \bf AP } files.
It is about placing these columns explicitly. \\ It up to you to place these columns explicitly. \\
Take again the file amd2901\_dpt.c and include the lines :\\ Edit again the file amd2901\_dpt.c and include the lines :\\
\noindent GENLIB\_DEF\_PHFIG()\\ \noindent GENLIB\_DEF\_PHFIG()\\
\noindent ...\\ \noindent ...\\
\noindent GENLIB\_SAVE\_PHFIG()\\ \noindent GENLIB\_SAVE\_PHFIG()\\
The suspension points are to be supplemented, they represent your The suspension points are to be supplemented, they represent your
operators placement. You have for, that {\bf placement directives. For this placement task, you have the
GENLIB} functions : following {\bf GENLIB} functions :
\begin{itemize}\itemsep=-.4ex \begin{itemize}\itemsep=-.4ex
\item GENLIB\_PLACE() \item GENLIB\_PLACE()
@ -577,11 +530,11 @@ GENLIB} functions :
\item ... \item ...
\end{itemize} \end{itemize}
Use {\bf GENLIB} manual. The placement of the data Use {\bf GENLIB} manual. The placement of the data-path columns
path columns should not be made randomly. The routing depends on it.\\ should not be done randomly. The routing feasibility and the quality
of the resulting layout depends on it !\\
Use genlib to generate all: Use genlib to generate all:
\begin{commandline} \begin{commandline}
>genlib amd2901_dpt >genlib amd2901_dpt
\end{commandline} \end{commandline}
@ -605,17 +558,16 @@ Do not forget to include a abutment box!
\subsection{heart Placement} \subsection{heart Placement}
%--------------------------------- %---------------------------------
Same manner, take again the file amd2901\_core.c and place data In the same manner, edit agin the file amd2901\_core.c and insert
path explicitly. You should not place the part controls. This one data-path explicitly. You should not place the part controls.
exists only in the form of a structural description. It is the This one exists only in the form of a structural description.
placer { \bf ocp } which will undertake some (during the placement It is the placer { \bf ocp } that will undertake some
of the heart { \bf ocp } detects which are the cells not placed (during the placement of the heart { \bf ocp } detects which are the
and supplements the placement). You should nevertheless envisage cells not placed and supplements the placement).
space for the cells placement { \bf to the top } of the Nevertheless you should reserve enough space for the cells placement
data-path. { \bf to the top } of the data-path.
Include the lines:\\ Include the lines:\\
\noindent GENLIB\_DEF\_PHFIG()\\ \noindent GENLIB\_DEF\_PHFIG()\\
\noindent ...\\ \noindent ...\\
\noindent GENLIB\_SAVE\_PHFIG()\\ \noindent GENLIB\_SAVE\_PHFIG()\\
@ -636,16 +588,18 @@ and
> ocp -partial amd2901_core -ioc amd2901_core amd2901_core amd2901_core_p > ocp -partial amd2901_core -ioc amd2901_core amd2901_core amd2901_core_p
\end{commandline} \end{commandline}
The option {\bf -- partial} indicates that you transmit a partial The option {\bf -- partial} indicates that you give a partial
placement of the data-path. The option { \bf -- ioc } placement of the data-path.
request the loading of a file giving the placement of the The option { \bf -- ioc } permits to specify a placement for external
connectors. This file, amd2901\_core.ioc is provided to you connectors described in a .ioc file.
(Modify it according to your predefined placement. The connectors This file, amd2901\_core.ioc is provided to you (Modify it according
must be in north and the south). The third argument is the netlist to your predefined placement.
heart, the fourth is the file { \bf AP } result. The connectors must be in the north and in the south of your circuit).
The third argument is the netlist heart filename, the fourth is the
name of the { \bf .ap } resulting file.
The figure \ref{Fig:placement} summarize the followed process: The figure \ref{Fig:placement} summarize the followed process:
\begin{figure}[H]\centering \begin{figure}[H]\centering
\includegraphics[scale=0.6]{placement.eps} \includegraphics[scale=0.6]{placement.eps}
\caption{Placement} \caption{Placement}
@ -655,10 +609,10 @@ The figure \ref{Fig:placement} summarize the followed process:
\subsection{Route the heart} \subsection{Route the heart}
%--------------------------------- %---------------------------------
Routing the heart by using { \bf ocr } in the following way: Routing the heart by using { \bf NERO } in the following way:
\begin{commandline} \begin{commandline}
> ocr -P amd2901_core_p -L amd2901_core -O amd2901_core -l 3 -v -i 30 > nero -v -3 -p amd2901_core_p amd2901_core amd2901_core
\end{commandline} \end{commandline}
%The option { \bf -- place } indicates that you transmit a placement, that of the heart. %The option { \bf -- place } indicates that you transmit a placement, that of the heart.
@ -677,14 +631,18 @@ Routing the heart by using { \bf ocr } in the following way:
\subsection{pads placement} \subsection{pads placement}
%--------------------------------- %---------------------------------
The heart is now completed. The pads still should The core of the AMD2001 is completed.
be added allowing the connection of the inputs/outputs to the case. \\ We focus now on the chip with pads description, placement and routing.
The tool {\bf ring} allows to instanciate the pads it has need Those pads allow the connection of the inputs/outputs of the core with
for signals list describing the relations between the heart the external nets of the chip.
and the pads, as well as a file { \bf .rin } specifying the
geometrical provision of the crown of pads. \\
This file uses syntax: The tool {\bf ring} instanciates pads that has been specified
in a {\bf vst} netlist, place them using a file { \bf .rin }
that specified a relative placement of those pads.
It then routes those pads with the core according to the input
netlist.
This syntax of the {\bf .rin} file:
\begin{sourcelisting} \begin{sourcelisting}
> east ( pi1 pi0 ) > east ( pi1 pi0 )
> west ( pck pi4 ) > west ( pck pi4 )
@ -692,7 +650,7 @@ This file uses syntax:
> south ( pvdde pvsse ) > south ( pvdde pvsse )
\end{sourcelisting} \end{sourcelisting}
Where pi1, pi0... are the names of the pads ''instances''. Where pi1, pi0... are the name of instance pads.
Name it `` amd2902\_chip.rin '' and apply the command \\ Name it `` amd2902\_chip.rin '' and apply the command \\
\begin{commandline} \begin{commandline}
@ -702,11 +660,11 @@ Name it `` amd2902\_chip.rin '' and apply the command \\
We will validate the work of {\bf ring} with the tools { \bf druc We will validate the work of {\bf ring} with the tools { \bf druc
}, { \bf lynx } and { \bf lvx }.\\ }, { \bf lynx } and { \bf lvx }.\\
Validate the drawing rules: Validate the physical design rules:
\begin{commandline} \begin{commandline}
> druc amd2901_chip > druc amd2901_chip
\end{commandline} \end{commandline}
Extract the symbolic layout and flattened it: Extract the netlist up to leave cells:
\begin{commandline} \begin{commandline}
> MBK_OUT_LO = al > MBK_OUT_LO = al
> export MBK_OUT_LO > export MBK_OUT_LO
@ -715,6 +673,7 @@ Extract the symbolic layout and flattened it:
\begin{commandline} \begin{commandline}
> cougar -f amd2901_chip > cougar -f amd2901_chip
\end{commandline} \end{commandline}
Compare two netlists : Compare two netlists :
\begin{commandline} \begin{commandline}
> lvx vst al amd2901_chip amd2901_chip -f > lvx vst al amd2901_chip amd2901_chip -f
@ -725,7 +684,7 @@ Compare two netlists :
> export MBK_OUT_LO > export MBK_OUT_LO
\end{commandline} \end{commandline}
simulated the file extracts with { \bf asimut }. Simulated the extracted netlist with { \bf asimut }.
Pay attention to the file { \bf CATAL }!\\ Pay attention to the file { \bf CATAL }!\\
To know the number of transistors, we carry out an extraction of To know the number of transistors, we carry out an extraction of
the circuit on the level transistor: \\ the circuit on the level transistor: \\