Manpages

NAME

cougar − Hierarchical netlist extractor

SYNOPSIS

cougar [ −v ] [ −c ] [ −f ] [ −t ] [ −ar ] [ −ac ] input_name [ output_name ]

DESCRIPTION

Lynx changed its name to Cougar during May 2002 in order to avoid name conflict with the famous text-mode Web browser. Cougar is a hierarchical layout extractor. It builds a netlist of interconnections from a symbolic layout view. The input argument is the name of the symbolic layout cell to be extracted, using as input format the one selected by the MBK_IN_PH(1) environment variable. If output is present, the resulting netlist will be given this name. If no output is given, then input will also be the generated netlist name. The output format is specified by the MBK_OUT_LO(1) environment variable.
As most of the Alliance cad tools, cougar uses mbk(1) environment variables. MBK_CATA_LIB(1), MBK_WORK_LIB(1), MBK_IN_PH(1), MBK_OUT_LO(1), RDS_TECHNO_NAME(1).

Cougar computes capacitances attached to the signals if the -ac option is set. At the moment, the value of these capacitances is computed for a typical one micron technology, and cannot be changed by the user through a technology file. The extracted netlist can be simulated for performance evaluation.
The typical capacitances are given below in 10e-18 farad / lamda^2 :

POLY

100

ALU1

50

ALU2

25

OPTIONS

Cougar checks the two basic ALLIANCE rules regarding connector names:

If two physical connectors are connected to the same net, they must have the same name.
If two physical connectors have the same name, they must be internally connected to the same net.

As a result only one logical connector will appear in the netlist. A fatal error occurs if one of those two rules is violated ( even for power and ground connectors )

When no options are specified, the current hierarchical level is extracted. The resulting netlist is the list of interconnections of the current layout hierarchy level. Three options are available to change cougar behaviour :

−t

Notifies a transistor level extraction, the symbolic layout cell is flattened to transistor layout before extraction.

−f

The symbolic layout cell is flattened to the catalog level before extraction. Use "man catal" for detail on the catalog file. If the catalog is empty, or doesn’t exist, the netlist is an interconection of transistors, if it isn’t, the netlist is an interconection of gates or blocks whose names are defined in the catalog.

−v

Verbose mode on. Each step of the extraction is displayed on the standard output, along with some statistics.

−c

Generates a core file representing the conflictuel net, when cougar detects two external connectors with different names on the same signal, or when it finds two external connectors having the same name but not internally connected to the same net, or when it cannot correctly extract an L shaped transistor.

−ac

Extract capacitance to ground on losig.

−ar

Extract interconnect resistance and capacitance to ground. Value of resistance foreach layer can be changed in the RDS file.

EXAMPLES

prompt> cougar -v amd2901

Gives a logical netlist of the chip amd2901, for one hierarchical level, using verbose mode. This would be typically used to verify the work of the ring(1) router, in conjunction with lvx on the specificated netlist and the extracted one.

prompt> cat $MBK_WORK_LIB/$MBK_CATAL_NAME
a2_y
a2p_y
.
.
prompt> cougar -f amd2901

Gives a logical netlist of the chip amd2901, after a flatten operation stopping on the cells specified in the catalog ( the standard cell library in our case ).

prompt> cougar -t amd2901

Gives a logical netlist of the amd2901 chip at the transistor level. This is useful with yagle(1), to retrieve logical equations from a layout.

SEE ALSO

al(5), MBK_CATA_LIB(1), MBK_WORK_LIB(1), MBK_CATAL_NAME(1), MBK_IN_PH(1), catal(5), RDS_TECHNO_NAME(1).