### *CS/EE* 5710/6710 Cadence V5 to V6 conversion notes Digitial VLSI Chip Design CAD manual

**Chapter 1:** There are no significant V6 issues with Chapter 1 that I know about. The only minor one is that Verilog-XL is not used as a mainline Verilog simulator any more. NC\_Verilog is the recommended Verilog simulator in V6.

**Chapter 2:** There are only very minor V6 issues with Chapter 2. The Command Interpreter Window (CIW) and Library Manager windows look ever so slightly different. The new windows look like the following:

| 000                                                 | X Virtuoso® 6.1.5-64b - Log: /home/elb/CDS.log.1 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>F</u> ile <u>T</u> ools                          | <u>O</u> ptions <u>H</u> elp                     | cādence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ************<br>Welcome, e<br>Finished w<br>******* | **************************************           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <u>≺</u> Cumouse L:                                 |                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1 ->                                                |                                                  | , in the second se |

Figure a - Figure 2.1 from the text

| C C Library Manager: Directory/caddis/elb/IC_CAD/cadence-f11                                                                                                             |                                   |               |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------|
| <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>D</u> esign Manager <u>H</u> elp                                                                                               |                                   | c ā d e n c e |
| Show Categories Show Files Library NCSU_Analog_Parts NCSU_Digital_Parts UorU_Analog_Parts UorU_Parts UorU_Parts UorU_Parts UorU_TechLib_ami06 avTech basic cdsDefTechLib | Cell                              |               |
| Messages<br>Log file is "/local/caddis/elb/IC_CAD/cadenc<br>Loading NCSU Library Manager customization                                                                   | e-f11/libManager.log".<br>nsdone. |               |

Figure b - Figure 2.2 from the text

**Chapter 3:** The Composer tool works very much the same as described in the text, but the interface in V6 looks a little different. Also, the integration with Verilog-XL has been removed. NC\_Verilog is the preferred Verilog simulator in V6.

Here are some V6 versions of the figures from the book.

| 000                               | X Create Library                                                                                                                                                                |      |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Library -                         |                                                                                                                                                                                 |      |
|                                   |                                                                                                                                                                                 |      |
| Name:                             | tutorial                                                                                                                                                                        |      |
| Path:                             |                                                                                                                                                                                 |      |
| Technolo                          | ngy Library                                                                                                                                                                     |      |
| lf this lib<br>Otherwis<br>Choose | orary will not contain physical design (i.e., layout) data you do not need a tech library.<br>se, you must either attach to an existing tech library or compile one.<br>option: |      |
| 0                                 | No tech library needed                                                                                                                                                          |      |
| ۲                                 | Attach to existing tech library> Uoto AMI 0.600 CSN (3M, 2P, high-res)                                                                                                          |      |
| 0                                 | Compile tech library                                                                                                                                                            |      |
| Misc. —                           |                                                                                                                                                                                 |      |
|                                   | /O Pad Type: 💿 Perimeter 🔾 Area array                                                                                                                                           |      |
|                                   | OK Cancel Apply                                                                                                                                                                 | Help |

#### Figure c - Figure 3.1 in the text

| 000               | X New File                           |
|-------------------|--------------------------------------|
| File              |                                      |
| Library           | tutorial 🔽                           |
| Cell              | FullAdder                            |
| View              | schematic                            |
| Туре              | schematic 🔽                          |
| Application       |                                      |
| Open with         | Schematics L                         |
| 🔲 Always use thi  | is application for this type of file |
| Library path file |                                      |
| cal/caddis/ell    | /IC_CAD/cadence-fl1/cds.lib          |
|                   |                                      |
|                   |                                      |
|                   | OK Cancel Help                       |

Figure d - Figure 3.2 in the text

In section 3.2.1: In the text is says  $Add \rightarrow Instance$ . In the V6 menus this is **Create**  $\rightarrow$  **Instance**. In fact, all the menu choices listed as in the Add menu in the text are in the **Create** menu in V6 (wire, pin, and note specifically). For the sheet titles, use **Edit**  $\rightarrow$  **SheetTitle**.

In section 3.2.2 the symbol can be created with **Create**  $\rightarrow$  **Cellview**  $\rightarrow$  **FromCellview**. You can exit Composer with **File**  $\rightarrow$  **CloseAll**.

In section 3.4, you print your schematic with **File → Print...** 

The following are V6 versions of the figures from Chapter 3. Note that most of them are almost identical to the versions in the text, but I'll include them here just in case there are subtle differences. The main difference is that the main Composer window has a component browser on the left side, and an enhanced set of function widgets along the top.



Figure e - Figure 3.3 from the text

I think the main dialog boxes that you see when using Composer look very much the same as in V5, but I'll include some screen captures here just in case.

| $\bigcirc \bigcirc \bigcirc \bigotimes$ Component                                                                 |
|-------------------------------------------------------------------------------------------------------------------|
| Commands <u>H</u> elp <b>cādence</b>                                                                              |
| Library UofU_Digital_v1_2  Flatten Filter  *                                                                      |
| AND3X1<br>A0121X1<br>A0122X1<br>BUFX2<br>BUFX4<br>BUFX8<br>DCBNX1<br>DCBX1<br>DCNX1<br>DCX1<br>ENTNVX1<br>ENTNVX2 |
|                                                                                                                   |
| Figure 5 - Figure 3 4 from the text                                                                               |

Figure f - Figure

| 000       | Add Instance                          |
|-----------|---------------------------------------|
| Library   | UofU_Digital_v1_2 Browse              |
| Cell      | NAND2X1                               |
| View      | symbol                                |
| Names     |                                       |
| 🗹 Add Wir | e Stubs at:<br>O all terminals        |
| Array     | Rows 1 Columns 1                      |
|           | 🖹 Rotate 🔰 🕼 Sideways ) 🥞 Upside Down |
|           | Hide Cancel Defaults Help             |

Figure g - Figure 3.5 from the text

| 000               |              | Add Pin       |                     |
|-------------------|--------------|---------------|---------------------|
| Pin Names         | АВ           |               |                     |
| Direction         | input        | Bus Expansion | 🖲 off 🔾 on          |
| Usage             | schematic    | Placement     | 🖲 single 🔾 multiple |
| Signal Type       | signal       |               |                     |
| Attach Net Expres | sion: 🥑 No ( | 🔾 Yes         |                     |
| Property Name     |              |               |                     |
| Default Net Name  |              |               |                     |
| Font Height       | 0.0625       | Font Style    | stick               |
| 🕼 Rotate          | / Sideways   | upside Down   | Show Sensitivity >> |
|                   |              | Hide Canc     | el Defaults Help    |

Figure h - Figure 3.6 from the text



Figure i - Figure 3.7 from the text. You can see the new instance browser on the left side of the window. This lets you select components by name in the schematic.

Figures 3.8 and 3.9 in the text are pretty much the same in V6...

| O O O X Add Wire Name |                 |                |                         |
|-----------------------|-----------------|----------------|-------------------------|
| Wire Name             | Net Expression  |                |                         |
| Names                 | A<1:0> B<1:0> C | in             |                         |
| Font Height           | 0.0625          | Bus Expansion  | 🖲 off 🔾 on              |
| Font Style            | stick 🔽         | Placement      | 🖲 single 🔾 multiple     |
| Justification         | lowerCenter     | Purpose        | 🖲 label 🔾 alias         |
| Entry Style           | fixed offset 🧧  | Bundle Display | 🖲 horizontal 🔘 vertical |
|                       |                 | Sh             | ow Offset Defaults      |
| AL Rotate             |                 |                |                         |
|                       |                 | Hide Ca        | ncel Defaults Help      |

Figure j - Figure 3.10 from the text

| 000       | 🔀 Add Instance                                            |
|-----------|-----------------------------------------------------------|
| Library   | VofU_Analog_Parts Browse                                  |
| Cell      | nmos                                                      |
| View      | symbol                                                    |
| Names     |                                                           |
| 🗹 Add Wir | e Stubs at:<br>O all terminals . egistered terminals only |
| Array     | Rows 1 Columns 1                                          |
|           | 🖹 Rotate 💫 🕢 Sideways 🛛 🚭 Upside Down                     |
|           |                                                           |

| Model TypesystemuserMultiplier1Fingers1Width (grid units)20Width3u MWidth (minimum)1.5u MLength (grid units)4Length (grid units)4Length (minimum)600n MDrain diffusion area4.5e-12Source diffusion perimeter9u MSource diffusion res squares5Source diffusion res squares1Virtuoso-XL layout cell1Drain diffusion length5Source diffusion length1                                     | Model name                   | ami06N              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|---------------------|
| Multiplier1Fingers1Width (grid units)20Width (grid units)3u MWidth (minimum)1.5u MLength (grid units)4Length (grid units)4Length (minimum)600m MDrain diffusion area4.5e-12Source diffusion perimeter9u MDrain diffusion res squares9u MSource diffusion length5ource diffusion lengthTemp rise from ambient1                                                                         | Model Type                   | 🖲 system 🔾 user     |
| Fingers1Width (grid units)20Width (minimum)3u MWidth (minimum)1.5u MLength (grid units)4Length (grid units)4Length (minimum)600m MDrain diffusion area4.5e-12Source diffusion area4.5e-12Drain diffusion perimeter9u MSource diffusion res squares5Source diffusion res squares1Virtuoso-XL layout cell1Drain diffusion length1Source diffusion length1                               | Multiplier                   | 1                   |
| Width (grid units)20Width3u MWidth (minimum)1.5u MLength (grid units)4Length (grid units)4Length (minimum)600m MDrain diffusion area4.5e-12Source diffusion area4.5e-12Drain diffusion perimeter9u MSource diffusion res squares1Source diffusion res squares1Virtuoso-XL layout cell1Drain diffusion length1Source diffusion length1                                                 | Fingers                      | 1                   |
| Width3u MWidth (minimum)1.5u MLength (grid units)4Length (grid units)4Length (minimum)600n MDrain diffusion area4.5e-12Source diffusion area4.5e-12Drain diffusion perimeter9u MSource diffusion res squares9u MDrain diffusion res squares1Source diffusion length1Drain diffusion length1Temp rise from ambient1                                                                    | Width (grid units)           | 20                  |
| Width (minimum)1.5u MLength (grid units)4Length600m MLength (minimum)600m MDrain diffusion area4.5e-12Source diffusion area4.5e-12Drain diffusion perimeter9u MSource diffusion res squares9u MDrain diffusion res squares1Source diffusion length1Drain diffusion length1                                                                                                            | Width                        | 3u M                |
| Length (grid units)4Length600n MLength (minimum)600n MDrain diffusion area4.5e-12Source diffusion area4.5e-12Drain diffusion perimeter9u MSource diffusion perimeter9u MDrain diffusion res squares5Source diffusion res squares1Virtuoso-XL layout cell1Drain diffusion length5Source diffusion length1                                                                              | Width (minimum)              | 1.5u M              |
| Length600m MLength (minimum)600m MDrain diffusion area4.5e-12Source diffusion area4.5e-12Drain diffusion perimeter9u MSource diffusion res squares9u MDrain diffusion res squares1Virtuoso-XL layout cell1Drain diffusion length1Source diffusion length1Temp rise from ambient1                                                                                                      | Length (grid units)          | 4                   |
| Length (minimum)600m MDrain diffusion area4.5e-12Source diffusion area4.5e-12Drain diffusion perimeter9u MSource diffusion perimeter9u MDrain diffusion res squares9u MSource diffusion res squares9u MDrain diffusion res squares9u MSource diffusion res squares9u MSource diffusion res squares9u MDrain diffusion length9u MSource diffusion length9u MTemp rise from ambient9u M | Length                       | 600m M              |
| Drain diffusion area       4.5e-12         Source diffusion perimeter       9u M         Drain diffusion perimeter       9u M         Drain diffusion res squares       5000000000000000000000000000000000000                                                                                                                                                                         | Length (minimum)             | 600m M              |
| Source diffusion area     4.5e-12       Drain diffusion perimeter     9u M       Source diffusion perimeter     9u M       Drain diffusion res squares     9u M       Source diffusion res squares     9u M       Virtuoso-XL layout cell     9u M       Drain diffusion length     9u M       Source diffusion length     9u M                                                       | Drain diffusion area         | 4.5e-12             |
| Drain diffusion perimeter     9u M       Source diffusion perimeter     9u M       Drain diffusion res squares     9u M       Source diffusion res squares     9u M       Virtuoso-XL layout cell     9u M       Drain diffusion length     9u M       Source diffusion length     9u M       Temp rise from ambient     9u M                                                         | Source diffusion area        | 4.5e-12             |
| Source diffusion perimeter     9u M       Drain diffusion res squares                                                                                                                                                                                                                                                                                                                 | Drain diffusion perimeter    | 9u M                |
| Drain diffusion res squares Source diffusion res squares Virtuoso-XL layout cell Drain diffusion length Source diffusion length Temp rise from ambient                                                                                                                                                                                                                                | Source diffusion perimeter   | 9u M                |
| Source diffusion res squares Virtuoso-XL layout cell Drain diffusion length Source diffusion length Temp rise from ambient                                                                                                                                                                                                                                                            | Drain diffusion res squares  |                     |
| Virtuoso-XL layout cell Drain diffusion length Source diffusion length Temp rise from ambient                                                                                                                                                                                                                                                                                         | Source diffusion res squares |                     |
| Drain diffusion length Source diffusion length Temp rise from ambient                                                                                                                                                                                                                                                                                                                 | Virtuoso-XL layout cell      |                     |
| Source diffusion length Temp rise from ambient                                                                                                                                                                                                                                                                                                                                        | Drain diffusion length       |                     |
| Temp rise from ambient                                                                                                                                                                                                                                                                                                                                                                | Source diffusion length      |                     |
|                                                                                                                                                                                                                                                                                                                                                                                       | Temp rise from ambient       |                     |
| Estimated operating region 🛛 sat 🔽 🔽                                                                                                                                                                                                                                                                                                                                                  | Estimated operating region   | sat 🔽               |
|                                                                                                                                                                                                                                                                                                                                                                                       |                              | Hide Cancel Default |



Figures 3.15 and 3.16 for plotting look very similar to the V5 figures in the text.

**Chapter 4:** The biggest change in Chapter 4 is that the Verilog-XL simulator is not recommended any more, so the automatic integration with Composer is now with NC\_Verilog. Verilog-XL was very specifically a Verilog-1995 simulator. It would not interpert any Verilog code that was not included in the 1995 standard.

NC\_Verilog includes all the new Verilog-2001 features, and is the mainline simulator that will continue to be upgraded to new versions of Verilog. So, you can safely skip all the stuff in Chapter 4 related to Verilog-XL.

In section 4.1.2 there are only mild differences between the V5 and V6 interfaces to NC\_Verilog. Here are some of the figures that are different enough for you to notice anything.

| 000                           | X Edit Test Fixture              |
|-------------------------------|----------------------------------|
| TestBench                     |                                  |
| File Name /twoBitAdder_run    | l/testfixture.template 🔽 🛄 👔 🌔 🗶 |
| 🗹 Set Selected File As TestBe | ench Check Syntax                |
| - Stimulus                    |                                  |
| File Name 1/twoBitAdder rm    | al/testfixture.verilog           |
| Sat Salactad Eila Ac Stimul   |                                  |
|                               |                                  |
|                               | OK Cancel Defaults Apply Help    |

Figure 1 - Figure 4.24 in the text. Notice that you are also allowed to change the TestBench file in this version of the dialog. In practice you should not have to change either of the files names in this dialog box.

| 000               | 🔀 New File                          |
|-------------------|-------------------------------------|
| - File            |                                     |
| Library           | tutorial 🔽                          |
| Cell              | nand2                               |
| View              | behavioral                          |
| Туре              | Verilog                             |
| Application       |                                     |
| Open with         | Read HDL                            |
| 🔲 Always use thi  | s application for this type of file |
| Library path file |                                     |
| cal/caddis/elb    | /IC_CAD/cadence-f11/cds.lib         |
|                   |                                     |
|                   |                                     |
|                   | OK Cancel Help                      |

Figure m - Figure 4.28 in the text. The only difference here is that you can give the new file a "type". You probably won't have to worry too much about this label. You should make sure that the type matches what you expect this cell view to be. In practice, the tool is pretty good at getting the default correct.

The other figures in Chapter 4 should be similar enough to not cause any problems.

**Chapter 5:** The main Virtuoso window will look a bit different in V6. The main window is shown here. The main differences are that it now includes the Layer Selection Window as a pane on the left part of the Virtuoso window rather than as a separate window. Also, there are extra command widgets both on the top and bottom of the window. You can hover your mouse over those to see what they do.

| 000                                           |                  |     | X             | Virt          | uoso              | ® L          | ayou          | it Si | uite  | GXL         | Editi         | ing:  | tuto         | rial i  | nver          | ter l  | ayoı | ıt    |      |     |      |      |       |      |       |            |
|-----------------------------------------------|------------------|-----|---------------|---------------|-------------------|--------------|---------------|-------|-------|-------------|---------------|-------|--------------|---------|---------------|--------|------|-------|------|-----|------|------|-------|------|-------|------------|
| Launch <u>F</u> ile <u>E</u> dit <u>V</u> iew | / <u>C</u> reate | Ve  | r <u>i</u> fy | Co <u>n</u> n | ectivi            | ity <u>i</u> | <u>O</u> ptio | ns    | Τοο   | ls <u>\</u> | <u>V</u> indo | w     | Ass <u>u</u> | ra C    | )pti <u>m</u> | ize    | NCS  | UE    | lelp |     |      |      |       |      | ād    | ence       |
| E    🤊 🥐                                      | ÷ (              | ) 🛛 |               | × į           | R                 | 1            |               | (     | •     | »           |               | 5     | abc          | -       | <b>B</b> 3    | »      |      | C     | 2    | »   | Work | spac | :e: ( | Clas | sic   | <b>•</b> » |
| 🔩 🧠 🖓 🖓 🖳                                     | الله ال          |     | -             |               | •                 | 0            | »             | (     | F)Se  | lect:       | O Se          | el(N) | :0 S         | el(l):0 | ) Se          | el(O): | 0    | X:-8. | 2500 | Y:9 | .450 | 0 d) | <:    | dY:  | Dist: | Cmd:       |
| Layers ? 🗗                                    | ×                | -   |               |               | -                 | _            |               |       |       |             |               |       |              |         |               |        |      |       | _    |     |      |      |       |      |       |            |
| AV NV AS NS                                   |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| 💹 nwell drawing 💦 🧧                           | •                |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| 🍸 All Valid Layers 🛛 🧧 🕢                      | 44)              |     |               |               |                   |              |               |       |       |             |               |       |              | •       |               |        |      |       |      |     |      |      |       |      |       |            |
| Used Lavers Only                              |                  |     |               |               |                   |              |               |       |       |             |               |       |              | •       |               |        |      |       |      |     |      |      |       |      |       |            |
|                                               |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
|                                               | _                |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| Nell drawing V S                              | <u> </u>         |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| 🖬 active drawing 🗹 🗹                          |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| 🎆 nact drawing 👿 🔽                            |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| 🧱 pact drawing 🗹 🗹                            |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       | =          |
| nsel drawing 🗹 🗹                              |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| psel drawing ⊻ ⊻                              |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| elec drawing V                                |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| met drawing 🗸 🗸                               | -                |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| <b>=</b> * = =                                |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| Objects ? 🗗                                   | <u>×</u> .       |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| Object V S                                    | $ \geq $         |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| 🕞 Shapes 🗹 🗹                                  |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| Doput V                                       |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| lahel 🗸 🗸                                     |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| Path V                                        |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       | $\cup$     |
|                                               |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| Objects Guides                                |                  |     |               |               |                   |              |               |       |       |             |               |       |              | 11      |               |        |      |       |      |     |      |      |       |      |       |            |
| 1 🎄 🍁 🗐 🛄 🖿                                   |                  | 2   | F0            | Ħ             | Þð                | Ē            | } 📮           | 6     | ۰,    |             |               | -     |              |         |               |        |      |       |      |     |      |      |       |      |       |            |
| 📲 着 🗞 🖉                                       | 2                |     | <b>W</b>      | <b>P:</b>     | 10 (B)<br>(B) (B) | 194          | i 3           | 4     | 7     | ¢           |               | 4     | 000          |         |               |        |      |       |      |     |      |      |       |      |       |            |
| mouse L: showClickInfo()                      |                  |     |               |               |                   |              | M:            | : vto | olsis | eRur        | nNCS          | Simu  | lation       | 0       |               |        |      |       |      |     |      | R:   | _l×   | HiM  | ouseP | opUp()     |
| 9(17) Create Instance                         |                  |     |               |               |                   |              |               |       |       |             |               |       |              |         |               |        |      |       |      |     |      |      |       |      |       | Cmd: 🎽     |

Figure n - This doesn't correspond with any particular figure in the text. It should probably come before Figure 5.4 in the text.

When you get to page 116 where the text talks about creating a contact, you need to substitute "**Create Via**" instead in V6. The Create Via dialog box is a little fancier than what is shown in Figure 5.6 in the text. Mostly you can ignore the extra fancieness and just select the via that you want, and the rows and columns that you wns if you're making a multiple-cut via.

| 000                                                                                                                                    | 🔀 Create Via                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| Mode                                                                                                                                   | O Auto<br>nape(s)<br>Name <b>via0</b>                                                                                 |
| Via Definition N_CC                                                                                                                    | Idard Via / VofU_TechLib_ami06                                                                                        |
| System User defined<br>Reset Parameters to<br>Justification centerCe<br>Cut<br>Cut Class None<br>Rows 2 0<br>Columns 1 0<br>Enclosures | Cut pattern Cut pattern X 0 Y 0 Width 0.6 Column Spacing 0.9 Column Spacing 0.9 Column Spacing 0.9 Column Spacing 0.9 |
| Rotate                                                                                                                                 | Sideways     Hide Cancel Help                                                                                         |

Figure o - Figure 5.6 in the text.

In the **Create**  $\rightarrow$  **Path** dialog (Figure 5.12) I haven't played with paths enough to know how to set the "**Change to Layer**" option, or whether that still works. In the Shape Pin dialog box (Figure 5.16), the main change is that addition of the **Connectivity** button that has to do with the router that you might use later. You should probably leave the connectivity to the default of **Strong**.

In section 5.4.1 on design rule checking, the dialog for finding all the DRC errors has a few more choices of what type of errors to be interested in. This can help you narrow down what you're looking for more quickly.

| 🗙 Find Marker      |                                                                                                        |
|--------------------|--------------------------------------------------------------------------------------------------------|
|                    |                                                                                                        |
| ⊻ error            | 🗹 acknowledged warning                                                                                 |
| 🗹 signed off error | 🗹 info                                                                                                 |
| ır 🗹 warning       | ⊻ annotation                                                                                           |
|                    |                                                                                                        |
|                    |                                                                                                        |
|                    |                                                                                                        |
|                    |                                                                                                        |
| 🔾 read 💿 write     |                                                                                                        |
|                    | <ul> <li>✓ error</li> <li>✓ signed off error</li> <li>✓ warning</li> <li>Im: ● top cellview</li> </ul> |

Figure p - Figure 5.27 in the text

In section 5.5 on the Extraction/LVS process, the biggest change is that when the LVS process reports completion, it also reports the result of the LVS. This is a very nice change!



Figure q - Figure 5.35 from the text

**Chapter 6:** There should be very few V6 issues with Chapter 6. The overall template measurements for the UofU standard cell template have not changed.

**Chapter 7:** The Spectre simulator itself has not changed much in V6. There are two new interfaces for the Analog Design Environment (ADE) though. The one we used in V5 is now called ADE-L and is the one you should use if you're following along with the text. ADE-XL and ADE-GXL are not covered in the CAD text. The interaction with ADE-L is largely the same as described in the text. The waveform window has a few enhancements like better notation of what signals the waveforms represent on the left of the window, and a preview-view of the waveform in the small window at the top.





One thing that's not quite as described in the text is the setting of markers. The dialog box for the **Marker**  $\rightarrow$  **CreateMarker** menu is shown here.

| 000        | 🔀 Create Graph Marker  |
|------------|------------------------|
| Point      | Horizontal Vertical    |
| Label      | %M: %Y                 |
| Expression |                        |
| X Position | 1.42235e-07 on 🔽       |
|            |                        |
|            | Hint: Use bind key 'V' |
|            | OK Close Apply         |

Figure s - This is the dialog box for creating a marker line (vertical or horizontal) in the waveform viewer. It doesn't correspond to any figure in the text, but would be near figure 7.11.

When creating a config view as described in section 7.3, the Hierarchy Viewer has tabs for the tree and table views which is a nice feature.

| Elle Edit View Elugins Help       Câdence         Image: Constraint List       Image: Constraint List       Image: Constraint List       Image: Constraint List         Image: Constraint Constraint Constraint List       Image: Constraint Constraint Constraint List       Image: Constraint Cons                                                                                                           | 000                                                    | 🔀 Virtuoso® Hiera | rchy Editor: New Config | uration (Save N  | eeded)               |              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-------------------|-------------------------|------------------|----------------------|--------------|
| Image: | <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>P</u> lugins | <u>H</u> elp      |                         |                  |                      | cādence      |
| Top Cell       ?                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 🗅 🗁 🗔   🗋 🤜                                            | > 🤊 🦿 🕕 🗖         | i 🗠   🔄 🥥               |                  |                      |              |
| Library:       tutorial         Cell:       nand-test         View:       schematic         Open       Edit         Constraint List:         NCSU_Analog_Parts vdc         Spectre         Spectre cons_sch cmo         NCSU_Analog_Parts vdc         Spectre         Spectre         Spectre cons_sch cmo         UorU_Analog_Parts pmos         Spectre       Spectre cons_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Top Cell                                               |                   | ? 5 ×                   | Global Binding   | s                    | ? <b>5</b> × |
| Cell:       nand-test         View:       schematic         Open       Edit         Cell Bindings         Image: Cell Bindings         Cell Bindings         Image: Cell Bindings         Imad: Image: Cell Binding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Library: tutorial                                      |                   |                         | Library List:    | myLib                |              |
| View:       schematic         Open       Edit         Table View       Tree View         Cell Bindings         VicSU_Analog_Parts       cap         Spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vdc         spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vdc         spectre       spectre cmos_sch cmo         UofU_Analog_Parts       vpulse         spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r_nmos         spectre       spectre cmos_sch cmo         utorial       nand-test         schematic       spectre cmos_sch cmo         utorial       nand2         cmos_sch       spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Cell: nand-test                                        |                   |                         | View List:       | sch schematic verilo | ga ahdi 📖    |
| Open       Edit       Constraint List:          Table View       Tree View       Cell Bindings         Cell Bindings         NCSU_Analog_Parts       cap       spectre         NCSU_Analog_Parts       vdc       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vdc       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vpulse       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r.nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | View: schematic                                        |                   |                         |                  |                      |              |
| Open       Edit       Constraint List:          Table View       Tree View       Tree View       Cell Bindings         Image: Comparison of the stress                                                                                                                    |                                                        |                   |                         | Stop List:       | spectre              |              |
| Table View       Tree View         Cell Bindings <hr/>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Open Edit                                              |                   |                         | Constraint List: |                      |              |
| Table View       Tree View         Cell Bindings       Library       Cell       View Found       View To Use       Inherited View List         NCSU_Analog_Parts       cap       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vdc       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vdc       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vpulse       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       pmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r.nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nand-test       schematic       spectre cmos_sch cmo <td< td=""><td></td><td></td><td></td><td></td><td></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                        |                   |                         |                  |                      |              |
| Cell Bindings         Library       Cell       View Found       View To Use       Inherited View List         NCSU_Analog_Parts       cap       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vdc       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vpulse       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       pmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r_nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r_nmod       spectre       spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Table View Tree                                        | e View            |                         |                  |                      |              |
| Library         Cell         View Found         View To Use         Inherited View List           NCSU_Analog_Parts         cap         spectre         spectre cmos_sch cmo           NCSU_Analog_Parts         vdc         spectre         spectre cmos_sch cmo           NCSU_Analog_Parts         vdc         spectre         spectre cmos_sch cmo           NCSU_Analog_Parts         vpulse         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         nmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         pmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         pmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         r_nmos         spectre         spectre cmos_sch cmo           utorial         nand2         cmos_sch         spectre cmos_sch cmo <td>Cell Bindings</td> <td></td> <td></td> <td></td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Cell Bindings                                          |                   |                         |                  |                      |              |
| NCSU_Analog_Parts       cap       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vdc       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vpulse       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       pmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r_nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nand-test       schematic       spectre cmos_sch cmo         tutorial       nand2       cmos_sch       spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Library                                                | Cell              | View Found              | View To Us       | e Inherited          | View List    |
| NCSU_Analog_Parts       vdc       spectre       spectre cmos_sch cmo         NCSU_Analog_Parts       vpulse       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       pmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       pmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r_nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nand-test       schematic       spectre cmos_sch cmo         tutorial       nand2       cmos_sch       spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | NCSU_Analog_Parts                                      | сар               | spectre                 |                  | spectre cmo:         | s_sch cmo    |
| NCSU_Analog_Parts       vpulse       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       pmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       r_nmos       spectre       spectre cmos_sch cmo         UofU_Analog_Parts       nand-test       schematic       spectre cmos_sch cmo         tutorial       nand2       cmos_sch       spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | NCSU_Analog_Parts                                      | vdc               | spectre                 |                  | spectre cmo:         | s_sch cmo    |
| UofU_Analog_Parts         nmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         pmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         r_nmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         r_nmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         r_nmos         spectre         spectre cmos_sch cmo           tutorial         nand-test         schematic         spectre cmos_sch cmo           tutorial         nand2         cmos_sch         spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | NCSU_Analog_Parts                                      | vpulse            | spectre                 |                  | spectre cmo          | s_sch cmo    |
| UofU_Analog_Parts         pmos         spectre         spectre cmos_sch cmo           UofU_Analog_Parts         r_nmos         spectre         spectre cmos_sch cmo           tutorial         nand-test         schematic         spectre cmos_sch cmo           tutorial         nand2         cmos_sch         spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | UofU_Analog_Parts                                      | nmos              | spectre                 |                  | spectre cmo          | s_sch cmo    |
| UofU_Analog_Parts         r_nmos         spectre         spectre cmos_sch cmo           tutorial         nand-test         schematic         spectre cmos_sch cmo           tutorial         nand2         cmos_sch         spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | UofU_Analog_Parts                                      | pmos              | spectre                 |                  | spectre cmo:         | s_sch cmo    |
| tutorial nand-test schematic spectre cmos_sch cmo<br>tutorial nand2 cmos_sch spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | UofU_Analog_Parts                                      | r_nmos            | spectre                 |                  | spectre cmo:         | s_sch cmo    |
| tutorial nand2 cmos_sch spectre cmos_sch cmo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | tutorial                                               | nand-test         | schematic               |                  | spectre cmo:         | s_sch cmo    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | tutorial                                               | nand2             | cmos_sch                |                  | spectre cmo:         | s_sch cmo    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                        |                   |                         |                  |                      |              |
| U. Newspress CDBA Filters OFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                        |                   |                         |                  |                      |              |
| Mamespace: CDBA Filters: OFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | III Namespace: CDBA Fi                                 | Iters: OFF        |                         |                  |                      |              |
| 5(13) >                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5(13) >                                                |                   |                         |                  |                      |              |

Figure t - Figure 714 in the text.

In section 7.5.1 on parametric simulation, the dialog to set the parameters has all the same information as before, but it's organized slightly differently in the dialog box.

| 0   | 00                   |               | [      | 🗴 Parametric A        | nalysis – s | pectre(9): tu | utorial dc-analy  | sis schematic    |                |                |     |
|-----|----------------------|---------------|--------|-----------------------|-------------|---------------|-------------------|------------------|----------------|----------------|-----|
| Eil | e <u>A</u> nalysis j | <u>H</u> elp  |        |                       |             |               |                   |                  |                | c ā d e n      | ce  |
| Ш   | Ready                |               |        | _                     | _           | _             | _                 | _                | _              |                |     |
|     | 🗖 🖥 🛛                | 4 X           | 00     | 🛃 💷 🗕 Ru              | n Mode: Swe | eps & Range   | es 🔽 📀 🤇          |                  |                |                |     |
| foo | Variable             | Value         | Sweep? | Range Type<br>From/To | From<br>1   | To<br> 5      | Step Mode<br>Auto | Total Steps<br>5 | Inclusion List | Exclusion List |     |
|     |                      |               |        |                       |             |               |                   |                  |                |                |     |
| 49  | Export Data ir       | nto a .csv fi | le     |                       |             |               |                   |                  |                |                | _// |

Figure u – Figure 7.34 in the text.

In section 7.6 on power measurement, the ADE-L calculator is described as a way to do the power calculation. The calculator looks very different in V6 than it did in V5. The interface is shown here.

| X Virtuoso (R) Visualization & Analysis XL calculator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Eile Tools View Options Constants Help Cader                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ıce |
| In Context Results DB: /local/caddis/elb/IC_CAD/cadence-f11/simulation/nand-test/spectre/config/psf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| i app plot erplot i i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| ● vt ○ vf ○ vdc ○ vs ○ op ○ var ○ vn ○ sp ○ vswr ○ hp ○ zm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| ○ it   ○ if   ○ idc   ○ is   ○ opt ○ mp   ○ vn2   ○ zp ○ yp ○ gd ○ data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| 📗 Off O Family O Wave 🗹 Clip   🏹 🐗 Append 🔽 🤣   🚍                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
| Key         Image: Comparison of the system         Image: Comparison of the system | -9  |
| 0 ± . + + 🎝 🗈 🎥 🕸 🛚 🕷 🏁 🎬 ME f 🖓 🦿                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |
| Stack                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ð×  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |

Figure v - Figure 7.39 in the text.

It's basically the same thing, but not every button is labeled with the same text as shown in the book.

The biggest difference is that there is no "eval" or "print" button in the new interface. Instead there is a "plot" button that will plot the results in your waveform window, and a "table" button that looks like a green arrow pointing at a grid that will output the value into a table. Also, the scientific notation in the calculator is a

little different. Instead of 100EEX-9 you would enter 100E-9 or even 100n. Also note that the green u-shaped arrow is the "put the current value on the stack" button (the default mode is still RPN).

This is what the calculator looks like when set up to do a similar calculation as described in section 7.8 of the CAD book. Note that I resized the calculator so the individual panes shifted around a little from the previous figure.

| 🖃 🛛 🛛 Virtuoso (R) Visualization & Analysis XL calculator 👔                                                     | • 🗆                    |
|-----------------------------------------------------------------------------------------------------------------|------------------------|
| File Tools View Options Constants Help cade                                                                     | nce                    |
| In Context Results DB: 1/simulation/nand2_test/spectre/schemat                                                  | ic/psf                 |
| ● vt ○ vf ○ vdc ○ vs ○ op ○ var ○ vn ○ si○ v ○ f<br>○ it ○ if ○ idc ○ is ○ opt ○ mp ○ vn2 ○ zi○ y ○ g           | 1⊖ zi<br>j⊖ d          |
| 🔾 Off 🔾 Family 🔾 Wave   🗹 Clip   🆏 🐖 Append                                                                     | <b>-</b> »             |
| (integ(IT("/V0/MINUS") 0n 100n )*VT("/vdd!"))/100E-9                                                            | _                      |
| ▲ 📮 🚹 Pop   📴 🙀   🗮 🕅 🖓 🖬 L E+ E8                                                                               | =   »                  |
| Stack                                                                                                           |                        |
| <ul> <li>integ(IT("/V0/MINUS") 0n 100n )</li> <li>IT("/V0/MINUS")</li> </ul>                                    |                        |
| 1/x 10**x abs dB10 dB20 exp 🔖 7 8 9                                                                             | $\left  \right\rangle$ |
| Special Functions 4 5 6                                                                                         | ×                      |
| histo ipn overshoot phaseMargin psdt<br>iinteg ipn∨RI peak phaseNoise pzbd<br>integ ion√RI peak phaseNoise pzbd |                        |
| intersect Ishift period_jitter psd riseT $0 \pm .$                                                              | +                      |
| user 1 us                                                                                                       | ser 2                  |
| Successful evaluation                                                                                           |                        |
| 27                                                                                                              |                        |

The button just to the right of the "Clip" check box is the "plot" button that will plot the value in your waveform window. The next button to the right is the "print to table" button that you can use to print the scalar value of your expression. When you press that button you get the following box where you can select to print just one point, or a whole range of points that represent the expression. In this case, the expression evaluates to a scalar, so you get only one value no matter how many times you print it.

| - Calculator Res   | uits Displa | y P     |  |  |  |  |  |  |
|--------------------|-------------|---------|--|--|--|--|--|--|
| Data 🔾 Value       | Point       | 🔾 Range |  |  |  |  |  |  |
| X Intercept 10n    |             |         |  |  |  |  |  |  |
| Start/End On       | 100n        |         |  |  |  |  |  |  |
| Step/Scale 10n     | 🗌 Log       |         |  |  |  |  |  |  |
| Destination Append |             |         |  |  |  |  |  |  |
| OK Apply Cancel    |             |         |  |  |  |  |  |  |

The result that is printed looks like the following:

|                                 |              | Table Window (XL) |  |
|---------------------------------|--------------|-------------------|--|
| <u>F</u> ile ⊻iew <u>T</u> ools | <u>H</u> elp |                   |  |
| 4                               |              |                   |  |
| Names 🛆                         | Value        |                   |  |
| ((integ(IT("/V0                 | 8.795E-6     |                   |  |
|                                 |              |                   |  |
|                                 |              |                   |  |
|                                 |              |                   |  |
|                                 |              |                   |  |
|                                 |              |                   |  |
|                                 |              |                   |  |
|                                 |              |                   |  |
|                                 |              |                   |  |

In this case the value is 8.795 uWatts.

**Chapter 8:** The sections in Chapter 8 that deal with Liberty format (.lib format) have not changed. That format is still the same

The sections on ELC are largely the same. The version we're using is different (we're currently using version 10.11-s036\_1), but the steps as described in the book are still the same (using the step1, step2, and step3 scripts). As far as I can tell, there are no substantive changes with the new tools versions. Please let me know if you see anything that needs updating.

**Chapter 9:** Synthesis with Synopsys design compiler, and especially using the syn-script-tcl template from the class directory should work the same way as described in the CAD book. The version of design compiler has changed, but the script should work the same way. I haven't explored the differences in the Design Vision graphical interface carefully, but everything appears to be very similar to what's in the CAD book.

The Cadence RTL Compiler seems to also have a similar interface to what's in the book. We're now using v10.10-s209\_1, but the script works with the new version, and the gui looks very similar.



Figure w: Figure 9.27 in the text

The procedure for reading the structural Verilog back into the Cadence Composer schematic tool is similar to what's in the book, with minor differences in the dialog boxes.

| Import Options                                                               | Clark                                   | Verilog In <@               | alab3-12>       | Concretion     |        |
|------------------------------------------------------------------------------|-----------------------------------------|-----------------------------|-----------------|----------------|--------|
| Import Options                                                               | GIOD                                    | al Net Options              | Schematic       | : Generation U | ptions |
| File Filter Name                                                             |                                         | 1. 4                        |                 |                |        |
| #aDstract.le<br>/<br>FA.ps<br>Fig4.9.v<br>LVS/<br>NAND.ps                    | 1.5.6.tec                               | n#                          |                 |                | Ì      |
| /home/elb/I                                                                  | C_CAD/cade                              | mce-f11                     |                 |                |        |
| Target Library N                                                             | Name                                    | moore                       |                 |                | Browse |
| Reference Libra                                                              | aries                                   | UofU_Exampl                 | e basic         |                |        |
| Verilog Files To                                                             | ) Import                                | /syn-f11/                   | moore_struct.   | 7              | Add    |
| -f Options                                                                   |                                         |                             |                 |                | Add    |
| -v Options                                                                   |                                         | UofU_Exampl                 | .e/VofU_Example | e.v            | Add    |
| -y Options                                                                   |                                         |                             |                 |                | Add    |
| Library Extensi                                                              | ion                                     |                             |                 |                |        |
| Library Pre-C                                                                | Compilation                             | Options                     |                 |                |        |
| HDL View Nar<br>Target Compile<br>Compile Verild                             | me<br>e Library Na<br>og Library O      | hdl<br>ame                  |                 |                | Browse |
| Ignore Modules                                                               | File                                    |                             |                 |                | Add    |
| -<br>mport Modules                                                           | File                                    |                             |                 |                | Add    |
| Import Structura                                                             | l Modules A                             | schemati                    | C               |                |        |
| - Structural Vi                                                              | ew Names                                |                             | N 1 - 412 - 4   |                |        |
| Schemalic                                                                    | schemati                                | -                           | Netlist         | netiist        |        |
|                                                                              | function                                | naL                         | Symbol          | SAMPOT         |        |
| Functional                                                                   |                                         |                             |                 |                |        |
| Functional<br>Log File                                                       | ./verila                                | ogIn.log                    | Work Area       | /tmp           |        |
| Functional<br>Log File<br>Name Map Tab                                       | ./verilo                                | ogIn.log<br>./verilogIn     | Work Area       | /tmp           |        |
| Functional<br>Log File<br>Name Map Tab<br>Overwrite Existi                   | <b>./verilo</b><br>le<br>ng Views       | ogIn.log<br>./verilogIn     | Work Area       | / tmp          |        |
| Functional<br>Log File<br>Name Map Tab<br>Overwrite Existi<br>Overwrite Symt | ./verilo<br>le<br>ng Views<br>pol Views | ogIn.log<br>./verilogIn<br> | Work Area       | ∕tmp           |        |

Figure x: Figure 9.29 in the text

It isn't shown in the CAD book, but when you read the structural Verilog back into the schematic tool, you should get the following dialog box if everything worked correctly. This shows that the cells that were referenced in the structural view were correctly found in the Reference Libraries.

| ن ک                                                    | Log File <@lab3-12>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | $\odot$ $\odot$ $\otimes$                       |
|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| <u>F</u> ile                                           | Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | cādence                                         |
| ©(#)\$<br>INFO<br>INFO<br>INFO<br>INFO<br>INFO<br>INFO | CDS: ihdl version 6.1.5-64b 05/09/2011 07:50 (sjfdl229) \$ Mon Jul 18 13:44:16 2011<br>(VERILOGIN-211): Module DFFX1 already exists in the target or reference library UofU_<br>(VERILOGIN-211): Module NOR2X1 already exists in the target or reference library UofU<br>(VERILOGIN-211): Module NAND2X1 already exists in the target or reference library UofU<br>(VERILOGIN-211): Module INVX1 already exists in the target or reference library UofU_<br>(VERILOGIN-211): Module INVX1 already exists in the target or reference library UofU_<br>(VERILOGIN-211): Module INVX1 already exists in the target or reference library UofU_<br>(VERILOGIN-377): Checked in symbol moore.<br>(VERILOGIN-372): Checked-in schematic moore.<br>(VERILOGIN-206): End of Logfile. | Example.<br>_Example.<br>U_Example.<br>Example. |
| 4                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 |

Figure y: Import Verilog log file showing that the library cells are found in the reference library (UofU\_Example in this case)

The imported Verilog, now looking like a schematic, looks very similar to the book's version, but with the new Composer Schematic interface.

| 👰 😳                                                       |          | Virtuo        | oso® Sch         | nematic       | Editor       | L Editin  | ig: moo | re mo        | ore s            | chema   | atic <@ | @lab3          | -12> |           |       |     |       |       | 6    | 0      | 8       |
|-----------------------------------------------------------|----------|---------------|------------------|---------------|--------------|-----------|---------|--------------|------------------|---------|---------|----------------|------|-----------|-------|-----|-------|-------|------|--------|---------|
| Launch <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>C</u> re | eate C   | Chec <u>k</u> | O <u>p</u> tions | <u>M</u> igr: | ate <u>W</u> | indow     | NCSL    | Ј <u>Н</u> е | lp               |         |         |                |      |           |       |     |       |       | cā   | l e n  | ce      |
|                                                           | C K      | D ×           |                  | <b>T</b> ⁄/ ( |              | Ċ         | 12      | • 1          | rî -             | T       | Q       | Q              |      | R         | 망     | 1   | 1     | abc   | -    |        |         |
| ○ • ○ • ○    Wa                                           | orkspac  | e: Basi       | с                | _             | -            |           | -       | <b>₩</b>     | 21 <sup>22</sup> | 16      | -R      | <b>T</b> z     |      | 8         | 🕻 Sea | rch |       |       | •    |        |         |
| Navigator ? 🗗 🗙                                           | ·        | ٠             | • •              | •             | •            | • •       | •       | •            | ٠                | •       | ٠       | ٠              | ٠    | • •       | ٠     | •   | ٠     | •     | •    | ٠      | $\land$ |
| Tefault                                                   |          |               |                  |               |              | • •       |         |              |                  | •       |         |                |      | •••       |       |     |       |       |      |        |         |
| Search                                                    |          |               |                  |               |              |           |         |              | •                | •       | •       | •              | -0   | • •       | -0-   | •   | •     | ٠     | •    |        |         |
|                                                           |          |               |                  |               |              |           |         |              | •                | •       |         |                |      |           |       |     |       | •     | •    |        |         |
| state_re (DFFX1)                                          |          |               | • [ ]            |               | •            |           | ->      | • •          | ·                |         | •       |                |      | • • •     |       |     |       |       |      |        |         |
| @ U12 (NOR2X1)<br>@ U13 (NAND2X1)                         | •        |               | •                |               |              |           |         |              | ·                | •       |         | - <b>1</b> 04- | •    | • •       | •     | Ŀ   |       | •     | •    |        | ≣       |
| └── @   14 / NVX1)                                        |          |               | · 🗄              |               | •            | ц<br>=] · |         |              | •                |         | •       |                | • [  | <b></b> ⊳ | •     | ].  |       |       | •    |        |         |
| Property Editor ? EX                                      |          | •             | •                | ŀ             |              |           |         |              |                  |         |         |                |      |           |       |     |       |       | •    |        |         |
|                                                           | •        | •             | • •              | •             |              |           |         |              |                  |         |         |                |      |           |       |     |       |       | •    |        |         |
|                                                           | •        | ÷             | • •              | •             | •            | , È.,     | ,       | ,            | ,                | <u></u> | •       | •              | •    | • •       | •     | •   | •     | •     | •    |        | Ų       |
|                                                           |          |               |                  |               |              |           |         |              |                  | 1111    |         |                |      |           |       |     |       |       |      |        |         |
| i⊪mouse L: mouseAddPt(t)                                  |          |               |                  |               |              | M: schl   | HiMou   | sePop        | oUp()            |         |         |                |      |           |       |     |       | R: sc | hCmo | lOptic | on()    |
| 1(5) Point at one corner of the                           | selectio | n box a       | area:            |               |              |           |         |              |                  |         |         |                |      |           |       | C   | md: S | elect | Box  | Sela   | : 0 📕   |

Figure z: Figure 9.30 in the text.

Chapter 10: The interaction with the Abstract tool is very similar to what's in the book. The new version of Abstract has very few changes to the interface.

One small change from the book is that we're now using LEF v5.6 for output.

| 000                        | X Export L | EF |        |        |
|----------------------------|------------|----|--------|--------|
| LEF Filename:              |            |    |        |        |
| abstract.lef               |            |    |        | Browse |
| 👅 Export Geometry LEF Data |            |    |        |        |
| 🔟 Export Tech LEF Data     |            |    |        |        |
| Cell List Filename:        |            |    |        |        |
|                            |            |    |        | Browse |
| LEF Version:               |            |    | 5.6 🛋  |        |
| Export LEF for Bin:        |            |    | All 🖃  |        |
| Bus characters:            |            |    | [] =   |        |
| Divider character:         |            |    | / =    |        |
|                            |            | ОК | Cancel | Help   |

Figure aa: Figure 10.9 from the book. Note that we're now using LEF Version 5.6.

Chapter 11: The biggest change with SOC Encounter is that it's now called Encounter Digital Implementation System (EDI). So, the script to use to fire up the tool is now called cad-edi. The other change is that the tool now uses "multi-mode, multicorner" timing analysis. This means that the tool can make use of much more detailed timing information with multiple timing files being used for different process corners. This means that instead of a single timing file in the configuration, you need to encapsulate timing information into a "timing view" file which we'll call Default.view. After the design configuration stage, things are very similar to the book, but with slightly different looking interfaces in some cases.

When you fire up the tool with cad-edi, the interface looks only a little bit different from the book.



Figure bb: Figure 11.4 from the book.

Before you import your design, you should create two files: <design>.conf and Default.view. The <design>.conf file should be based on the UofU\_edi.conf file in the class directory

(/uusoc/facility/cad\_common/local/class/6710/F11/cadence/EDI/UofU\_edi.conf). The things that you need to update are marked with !!...!!. Your Default.view file should also be based on the example in the class EDI directory. Our version o the Default.view file does only simple timing using one timing library and no corner analysis, but that should be fine for class chips.

Once you've created your versions of these two files you can proceed with Design->Import as described in section 11.1.1 in the book. If you've made the <design>.conf file correctly, you can use that to fill in all the fields in the Design->Import form. When you first get the Design->Import form all the fields will be empty. Click on the "Load" button to load your .conf file.

| 00                 | X Load Imp                                                                                                                                                                                                                                                                                                         | ort Configura                  | tion                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Look in:           | Part /home/elb/IC_CAD/soc-f11/coun                                                                                                                                                                                                                                                                                 | ter2                           | -                                                                                                                               | 3 5 🐑 🖻 🗉 💽                                                                                                                                                                                                                                                                                                                                                                                                                      |
| € Com<br>elb       | Name         Counter_clock_reports         counter_cts.enc.dat         counter_fplan.enc.dat         counter_placed.enc.dat         counter_plan.enc.dat         counter_reports         counter_reports         counter_routed.enc.dat         SOC         UofU_Example         counter.conf         counter.conf | ∧ Size<br>6 KB<br>6 KB<br>6 KB | Type<br>Folder<br>Folder<br>Folder<br>Folder<br>Folder<br>Folder<br>Folder<br>Folder<br>Folder<br>Folder<br>Conf File<br>conile | Date Modified           19 Jul 2011 17:53:31           19 Jul 2011 17:53:32           19 Jul 2011 17:53:33           19 Jul 2011 17:53:30           19 Jul 2011 17:53:31           19 Jul 2011 17:53:31           19 Jul 2011 17:53:31           19 Jul 2011 17:53:31           19 Jul 2011 17:53:33           17 Oct 2011 18:08:22           10 Nov 2010 11:00:20           19 Jul 2011 17:51:56           19 Jul 2011 17:52:45 |
| File <u>n</u> ame: | counter.conf                                                                                                                                                                                                                                                                                                       |                                |                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Files of type:     | Input config files (*.conf*)                                                                                                                                                                                                                                                                                       |                                |                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Figure cc: Loading a .conf file for EDI configuration. In this example I'm loading counter.conf .

Once the .conf file has been loaded, you'll see the fields of the Design->Import bx filled in.

| $\odot$                | Design Import <@Iab3-12>                     | $\odot$  |
|------------------------|----------------------------------------------|----------|
| Basic Advanced         |                                              |          |
| ~ Netlist:             |                                              |          |
| Verilog                |                                              |          |
| F                      | iles: counter_struct.v                       | <b>.</b> |
|                        | Top Cell: 🔾 Auto Assign 💿 By User: 🛛 counter |          |
| O OA                   |                                              | <u> </u> |
| Lib                    | rary:                                        | -        |
|                        | Cell:                                        | -        |
| N N                    | /iew:                                        | -        |
| - Technology/Physica   | l Libraries:                                 |          |
| LEF F                  | iles: UofU_Example/UofU_Example.lef          |          |
| OA Reference Libra     | ries:                                        |          |
| OA Abstract View Na    | mes:                                         |          |
| OA Layout View Na      | mes:                                         |          |
| Floorplan              |                                              |          |
| IO Assignment          | File:                                        | 6        |
| – Analysis Configurati | on                                           |          |
| MMMC View Definition   | n File: Default.view                         |          |
|                        | Create Analysis Configuration                |          |
|                        |                                              |          |
|                        |                                              |          |
|                        |                                              |          |
| ОК                     | Save Load Cancel He                          | al       |
|                        |                                              |          |

Figure dd: Design->Import dialog box. Note the field for MMMC View Definition File - this is new in this version of EDI.

You may not need to look at this if you have everything set up correctly, but if you want to you can go to the ITO/CTS field under the Advanced tab and notice that the CTS (Clock Tree Synthesis) cell specification has changed. Rather than specify each type of CTS cell separately in terms of their footprints, you simply give the names of all cells you'd like to use in CTS.

| ×                                                                   | Desig             | ın Import <@lab3-12> |        | $\odot$ $\odot$ $\otimes$ |
|---------------------------------------------------------------------|-------------------|----------------------|--------|---------------------------|
| Basic Advanced                                                      |                   |                      |        |                           |
| Basic Advanced<br>Timing<br>ILM<br>IPO/CTS<br>Power<br>RTL<br>Yield | CTS Cell List: IN | vVX1                 |        |                           |
| ОК                                                                  | Save              | Load                 | Cancel | Help                      |
|                                                                     |                   | Eoda                 | Educor |                           |

Figure ee: Figure 11.6 in the CAD book - specifying clock tree cells by name.

The next steps in the EDI flow are largely the same as in the book with only very minor differences in the dialog boxes. When you get to placement, you'll notice that the placement includes a "trial route" which is an initial low-quality but fast routing of the circuit to help in the placement. Don't be fooled – you still have to do clock tree synthesis and real routing!



Figure ff: Figure 11.16 in the book showing the circuit after placement Note that trial routing is also shown.



Figure gg: Figure 11.17 in the text - Dialog box for timing optimization

| × 💿                                      | Virtuoso(R) DEF In <@lab3-12>             |
|------------------------------------------|-------------------------------------------|
| DEFIn File Name                          | /home/elb/IC_CAD/soc-f11/counter.def      |
| Target Library Name                      | counter                                   |
| Ref. Technology Libraries                |                                           |
| Create a module hierarchy<br>New Library | from hierarchical names 📃 Share Library 📃 |
| Technology From L                        | ibrary                                    |
| Target Cell Name                         | counter                                   |
| Target View Name                         | layout                                    |
| Component View List                      |                                           |
| Master Library List                      | UofU_Example                              |
| Overwrite Design                         | Create CustomVias only                    |
| Log File Name                            |                                           |
| 🔾 Use Template File 🏾 🧕                  | Use GUI Fields                            |
| Template File Name                       |                                           |
| Save Template File Name                  | Save                                      |
| Comment Char                             |                                           |
| Pin Purpose                              |                                           |
| Do not create any routing                | data 📃                                    |
| Layer Map File Name                      |                                           |
|                                          | OK Cancel Defaults Apply Help             |

Figure hh: Figure 11.35 in the text - Dialog box for importing DEF files to icfb. This form has some different options than the one seen in the text.

**Chapter 12:** The chip assembly router s essentially the same as the one called ccar in the text, but is now called vcar (Virtuoso Chip Assembly Router). The interface is largely the same, but has tighter integration with icfb in some ways.

In Section 12.1.1 you start the process by opening the schematic (same as the one seen in Figure 12.1 in the text), and then using Launch->LayoutXL. You'll see a couple dialog boxes along the way.

| Layout                                                                                                            |                                                                                                               |
|-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| 🖲 Create                                                                                                          | New 🔾 Open Existing                                                                                           |
| Configurati                                                                                                       | ion                                                                                                           |
| <ul> <li>Create</li> <li>Automa</li> </ul>                                                                        | New 🥥 Open Existing<br>atic                                                                                   |
|                                                                                                                   | OK Cancel Help                                                                                                |
|                                                                                                                   |                                                                                                               |
| 🕛 Ne                                                                                                              | ew File <@lab3-12> 🕐 🕑 🙆                                                                                      |
| File                                                                                                              |                                                                                                               |
| <b>File</b><br>.ibrary                                                                                            | icctest                                                                                                       |
| <b>File</b><br>.ibrary<br>Cell                                                                                    | icctest                                                                                                       |
| <b>File</b><br>Library<br>Cell<br>/iew                                                                            | icctest testme layout                                                                                         |
| <b>File</b><br>.ibrary<br>Cell<br>/iew                                                                            | icctest  testme layout layout                                                                                 |
| File<br>.ibrary<br>Cell<br>/iew<br>Type<br><b>Application</b> -                                                   | icctest  testme layout layout                                                                                 |
| File<br>Library<br>Cell<br>/iew<br>Type<br><b>Application</b> -<br>Open with                                      | icctest  testme layout layout Layout L                                                                        |
| File<br>Library<br>Cell<br>/iew<br>Type<br><b>Application</b> -<br>Open with                                      | icctest                                                                                                       |
| File<br>.ibrary<br>Cell<br>/iew<br>Type<br>Application -<br>Dpen with<br>Dpen with<br>Always us<br>Library path f | icctest                                                                                                       |
| File<br>.ibrary<br>Cell<br>/iew<br>Type<br>Application<br>Open with<br>Den with<br>Always us<br>.ibrary path f    | icctest  testme  layout  Layout  Layout L  this application for this type of fill  tC_CAD/cadence-f11/cds.lib |

Figure ii: Dialog boxes that appear when you Launch LayoutXL to start the cvar chip routing process. The Startup Option is asking if you want to start with a fresh new layout, and the New File just says that the new view should be a layout view.

Once LayoutXL has opened, you will see different views of both your schematic, and of the new layout view for the generated geometry of the layout. Follow the instructions in the text involving the Design -> GenFromSource but in V6 the command is Connectivity -> Generate -> All From Source, or you can click on the

button that looks like this hear the bottom of the window:



When you do this, you'll get a Generate Layout dialog box. The version in Figure 12.2 in your text has all selections on a single window. The V6 version has separate tabs. The V6 dialog boxes are shown below. For the Generate tab, you can leave the defaults alone. For the I/O pins tab you'll want to update the layer on which you'd like the I/O pins created – I've changed things to metal2 in this example. Also, I prefer to do vdd! and gnd! routing myself, so I select those pins, and then uncheck the "Create" button and then Update (using the controls below the list of pins). You can leave the defaults alone for PR Boundary and Floorplan also.



Figure jj: Generate Layout dialog box - the old box was seen in Figure 12.2 in your text. This V6 version has separate tabs.

| 00                                               |                                                  | X Generate Layout                                                                                                                            |
|--------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Generate                                         | I/O Pins                                         | PR Boundary Floorplan                                                                                                                        |
| Specify De                                       | fault Values for a                               | All Pins                                                                                                                                     |
|                                                  | Layer:                                           | width: Height: Num: Create:                                                                                                                  |
|                                                  | metal2                                           | dg 0.9 0.9 1 Apply                                                                                                                           |
| Specify Pin                                      | s to be Generat                                  | ed                                                                                                                                           |
| Select:                                          |                                                  | Number Of Matches: 0 Add New Pin                                                                                                             |
| Term Nam                                         | e Net Name                                       | Layer Width Height Num Create                                                                                                                |
| "out5<0>"<br>"out5<1>"<br>"out5<2>"<br>"out5<3>" | "out5<0>"<br>"out5<1>"<br>"out5<2>"<br>"out5<3>" | ("metal2" "drawing") 0.9 0.9 1 t<br>("metal2" "drawing") 0.9 0.9 1 t<br>("metal2" "drawing") 0.9 0.9 1 t<br>("metal2" "drawing") 0.9 0.9 1 t |
| "vdd!"                                           | "vdd!"                                           | ("metal2" "drawing") 0.9 0.9 1 t                                                                                                             |
| "zero"                                           | "zero"                                           | ("metal2" "drawing") 0.9 0.9 1 t                                                                                                             |
| Name:                                            | Laver:                                           | Width: Height: Num: Create:                                                                                                                  |
| vdd! vdd                                         | metal2                                           | dg 0.9 0.9 0 Update                                                                                                                          |
| Pin Label —                                      | _abel As: 💿 Lak                                  | oel Options                                                                                                                                  |

Figure kk: The I/O Pins tab on the Generate Layout box is where you specify what layer you'd like each I/O pin to be on. I like to disable the vdd! and gnd! pins from being automatcally generated. This box shows the state after disabling (un-checking Create) and Updating for vdd!.

After you make your changes to the I/O Pins section and click OK, you'll get the new layout as in Figure 12.3 in the text. The new version looks very much the same. You can also pick up blocks, and pick up I/O pins and move them around as described in the text to get a placement that looks like Figure 12.4. To see the unconnected nets, first analyze the circuit with Connectivity -> Analyze, and then use Connetivity -> Nets -> Show/Hide All Incomplete Nets.



Figure II: Figure 12.4 in the text, but showing the new V6 look.

Creating the vdd! and gnd! wires that connect the rings of the blocks that came from EDI is the same as described in the text, and shown in Figure 12.5.

Now you can use the procedure in Section 12.1.2 to start up the router. You may get OA (Open Access) warnings about non-via instances. Although I don't know exactly what these warnings are talking about, these appear to be things you can ignore.

| 000        |             | X Virtue | oso Chip Ass | embly Rou              | iter Startup  |             |
|------------|-------------|----------|--------------|------------------------|---------------|-------------|
| Library:   | icctest     |          |              | - Save as:<br>Library: | icctest       |             |
| Cell:      | testme      |          |              | Cell:                  | testme        |             |
| View:      | layout      |          | Browse       | View:                  | layout.routed | Browse      |
| Area       |             |          |              |                        |               |             |
| ((0.0 (    | 0.0) (730.8 | 519.15)) |              |                        | Select Area   | Whole Area  |
| Constrair  | nt Group:   |          |              |                        |               |             |
|            |             |          |              |                        |               |             |
| Do File:   |             |          |              |                        |               |             |
| do . do    |             |          |              |                        |               | Browse      |
| Initial Co | mmand:      |          |              |                        |               |             |
|            |             |          |              |                        |               |             |
|            |             |          | More Opt     | tions >>               |               |             |
|            |             |          |              |                        | ОК            | Cancel Help |
|            |             |          |              |                        |               |             |

Figure mm: Dialog box for starting the chip assembly router. Nte that it's now called Virtuoso Chip Assembly Router (vcar). Ender do.do into the do file field.

| 0                 |                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | Review OA Read Messages                                                                                                                                                                                                                                                                                                                                                               |
|                   | Warnings or errors were encountered while reading your OA design.                                                                                                                                                                                                                                                                                                                     |
| a 200             | These indicate something has or could go wrong during your session<br>or that the design data is incomplete, even for viewing purposes.                                                                                                                                                                                                                                               |
|                   | Please review these messages carefully and consider how the data<br>problems could impact your successful use of the router.                                                                                                                                                                                                                                                          |
| # <<br># <<br># < | <ul> <li>&lt; INFO &gt;&gt; LEFDefaultRouteSpec is the effective constraint group.</li> <li>&lt; WARNING &gt;&gt; Non abstract OA master design - controller has non-via instance.</li> <li>&lt; WARNING &gt;&gt; Non abstract OA master design - counter has non-via instance.</li> <li>&lt; WARNING &gt;&gt; Non abstract OA master design - moore has non-via instance.</li> </ul> |
| <u>  </u>         | 2                                                                                                                                                                                                                                                                                                                                                                                     |
|                   | ОК                                                                                                                                                                                                                                                                                                                                                                                    |

Figure nn: These OA warnings seem to be ignorable.

You can now follow the steps in 21.1.2 to do the routing. In particular, the steps on Page 380 are all still relevant. Note that when you invoke the global router you

might get a warning that "this may not be a chip assembly application." You can ignore this.

IN V6 you no longer need to "write -> session" as described in the text. The layout view in LayoutXL should be updated automatically. Note that it will be updated as a "layout.routed" file instead of a "layout" file.

The rest of Chapter 12, including the pad routing, should follow a similar pattern as in the book, and as modified in the previous examples.

When it comes to generating the GDS (Stream) file, you should use the File->Export->Stream option from the CIW as described in Section 12.3. The Export -> Stream dialog box in V6 now has a Show Options tab that reveals the layer tab. If you Show Options, and then select the Layers tab, you can load a Layer Map File (this is the equivalent of the User-Defined Data described in the text). Load the stream4gds.map file from /uusoc/facility/cad\_common/local/class/6710/F11/cadence/map\_files as seen in the following figures.

|           | 0                                                       |           | C               | 🗙 Virtuoso (R) | XStream Out    |               |                 |        |  |
|-----------|---------------------------------------------------------|-----------|-----------------|----------------|----------------|---------------|-----------------|--------|--|
|           |                                                         |           |                 |                |                |               |                 |        |  |
| St        | ream File                                               | testme.g  | ds              |                |                |               |                 |        |  |
| Te<br>Lit | chnology<br>prary                                       | UofU_Te   | N_TechLib_amiO6 |                |                |               |                 |        |  |
| Lit       | orary                                                   | icctest   | test            |                |                |               |                 |        |  |
| То        | p Level Cell(s)                                         | testme    | stme            |                |                |               |                 |        |  |
| Vi        | ew(s)                                                   | layout.ro | ayout.routed    |                |                |               |                 |        |  |
|           | Hide O                                                  | ptions    |                 | Save Tem       | plate          | Loa           | d Template      |        |  |
| Stn       | eamOut Option                                           | s         |                 |                |                |               |                 | ð      |  |
|           | General C                                               | Cells     | Fonts           | Geometry       | Layers         | Libraries     | Properties      |        |  |
|           | _ Layer Name                                            | Purp      | ose Name        | Stream Layer   | Stream Datatyp | e  Material T | Гурі            |        |  |
| 1         | nwell                                                   | drawi     | ng              | 42             | 0              |               |                 |        |  |
| 2         | pwell                                                   | drawi     | ng              | 41             | 0              |               |                 |        |  |
| 3         | active                                                  | drawi     | ng              | 43             | 0              |               | Add             | Row    |  |
| 4         | nactive                                                 | drawi     | ng              | 43             | 0              |               |                 |        |  |
| 5         | pactive                                                 | drawi     | ng              | 43             | 0              |               |                 |        |  |
| 6         | nselect                                                 | drawi     | ng              | 45             | 0              |               | Del             | Row    |  |
| 7         | pselect                                                 | drawi     | ng              | 44             | 0              |               |                 |        |  |
| 8         | poly                                                    | drawi     | ng              | 46             | 0              |               | <b>T</b>        |        |  |
|           |                                                         |           | III             |                |                |               | $\geq$          |        |  |
|           | Layer Map File Load Save As Use Automatic Layer Mapping |           |                 |                |                |               |                 |        |  |
|           |                                                         |           |                 |                |                |               |                 |        |  |
| St        | ream Out From                                           | Virtual I | Memory          |                |                |               |                 |        |  |
| 🖌 Sh      | ow Completion                                           | Messag    | e Box           | Transl         | ate Cancel     | Apply R       | eset All Fields | (Help) |  |

Figure oo: The Export -> Stream dialog box from Figure 12.25 in your text. This is how the box looks after you've loaded the stream4gds.map file. Note that the View is "layout.routed".

| 000                | X Choose the file(s)                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Look in:           | 🖻 /uusoc/facility/cad_commo710/F11/cadence/map_files 🔽 🕒 🌍 🀑 📂 🧾 📰                                                                                                                                                                                                                                                                                                                                                 |
| Com                | Name       Size       Type       Date Modified         Cifin.map       1 KB map File       22 Jul 2011 15:02:43         Stream4abstract.map       820tes       map File       22 Jul 2011 15:02:43         Stream4gds.map       1 KB map File       22 Jul 2011 15:02:43         Stream4gds.map       1 KB map File       22 Jul 2011 15:02:43         Streamin.map       1 KB map File       22 Jul 2011 15:02:43 |
| File <u>n</u> ame: | stream4gds.map Open                                                                                                                                                                                                                                                                                                                                                                                                |
| Files of type:     | All Files (*)                                                                                                                                                                                                                                                                                                                                                                                                      |

Figure pp: The equivalent of Figure 12.26 in your text. This is how you find the stream4gds.map file to load as a Layer Map File.

After you've exported the gds file, you should read it back in with File -> Import -> Stream from the CIW. You can then DRC and Extract the imported gds information and check to make sure that it's the same as the file you exported. You can use LVS on the extracted file from your layout, and the extracted file from the imported gds to make sure they match.

Stream import requires another map file – this time use the streamin.map file. You should also make a new library to hold the imported information. The import dialog box looks like the following (after the streamin.map has been loaded as the Layer Map File).

| 000                                                                                                    | 🔀 Virtuoso (R) XStream In                |            |              |              |            |
|--------------------------------------------------------------------------------------------------------|------------------------------------------|------------|--------------|--------------|------------|
|                                                                                                        |                                          |            |              |              |            |
| Stream File                                                                                            | /home/elb/IC_CAD/cadence-till/testme.gds |            |              |              |            |
| Library                                                                                                | 3                                        |            |              |              |            |
| Top Level Cell testme                                                                                  |                                          |            |              |              |            |
| Attach Technology Library UotU_TechLib_amiU6                                                           |                                          |            |              |              |            |
| Load ASCII Tech File                                                                                   |                                          |            |              |              |            |
| Generate Technology Information From Stream File                                                       |                                          |            |              |              |            |
| Stream Tech File                                                                                       |                                          |            |              |              |            |
|                                                                                                        |                                          |            |              |              |            |
| Hide Options Save Template Load Template                                                               |                                          |            |              |              |            |
|                                                                                                        |                                          |            |              |              |            |
| StreamIn Options                                                                                       |                                          |            |              |              | 6          |
| General Cells                                                                                          | Fonts                                    | Geometry   | Layers       | Libraries    | Properties |
| Stream Layer   Strea                                                                                   | m Datatype                               | Layer Name | Purpose Name | Material Typ |            |
| 1 42 0                                                                                                 |                                          | nwell      | drawing      |              |            |
| 2 41 0                                                                                                 |                                          | pwell      | drawing      |              |            |
| 3 43 0                                                                                                 |                                          | active     | drawing      |              | Add Row    |
| 4 45 0                                                                                                 |                                          | nselect    | drawing      |              |            |
| 5 44 0                                                                                                 |                                          | pselect    | drawing      |              |            |
| 6 46 0                                                                                                 |                                          | poly       | drawing      |              | Del Row    |
| 7 56 0                                                                                                 |                                          | elec       | drawing      |              |            |
| 8 49 0                                                                                                 |                                          | metal1     | drawing      |              |            |
| Load Save As                                                                                           |                                          |            |              |              |            |
|                                                                                                        |                                          |            |              |              |            |
|                                                                                                        |                                          |            |              |              |            |
| Number of Threads 1                                                                                    |                                          |            |              |              |            |
| Stream In to Virtual Memory  Show Completion Message Roy  Translate Cancel Anniu Recet All Fields Holp |                                          |            |              |              |            |
| Show completion Message Box Translate Cancel Apply Reset All Fields Help                               |                                          |            |              |              |            |

Figure qq: The Import -> Stream dialog box. Note that I've made a new library named icctest-gds to hold this imported information. This box is show after the streamin.map Map File has been loaded.

**Chapter 13:** The content of Chapter 13 doesn't really change. Some of the steps are different than in the book, but those modified steps are documented in the respective chapters, so they're not repeated here.

## New Material: Hierarchical Layout Place and Route Flows

Here is some documentation on taking a previously placed and routed circuit and making is usable as a macro cell in EDI. That is, using EDI as a chip assembly router instead of vcar. DISCLAIMER: The instructions listed here worked for the V5 tools. I haven't gone through in detail and checked everything for the V6 flow. There may be slight differences in the V6 EDI flow that you'll have to navigate.

## Procedure for EDI/VCAR hierarchical flow

For this flow you create pieces of the design in EDI. Those pieces will be selfcontained layout (DEF can be read back in to icfb to become layout views) with power and ground rings.

These, and other custom blocks, can be placed by hand, power and ground routed by hand, and then the signals can be connected in ICC VCAR (Virtuoso Chip Assembly Router) as described in the CAD manual and in the previous V6 discussions in this document. See Chapter 12 for more details about VCAR.

# Procedure for hierarchical EDI flow

You might also want to take blocks that are placed and routed in EDI, and use them as macro blocks in a hierarchical use of EDI. That is, the blocks would be placed within another EDI floorplan and be part of the EDI-style power/ground grid, and standard cells would be placed around the macro blocks. This is possible too. Note that the easy way involves having self-contained power and ground rings around the macro blocks anyway, but then those rings will be connected into the global power/ground structure of the EDI floorplan.

Step one is preparing your circuits as hierarchical blocks. These are blocks that you want to use in another EDI run. They might be macro blocks, or it might be the whole core. To do this you'll eventually need a .lib description of the cell for timing, and a .lef version of the cell for physical place and route. You can get the .lib from EDI, but you'll have to generate the .lef through abstract which means importing the .def into icfb and then running abstract.

1 - place and route your block with EDI. Make sure to put a vdd/gnd ring around your block. You might be able to make this work without one, but I know it works with one. You can use stripes if you like too, but they are not required.

2 - When you have finished and have a correctly placed and routed circuit you export a structural verilog file and def file as usual. You should also generate a .lib file These steps are included in the "verify.tcl" file that is part of the general CS6710 EDI scripted flow.

puts "-----Output \${BASENAME}.def file-----" # Export the DEF, v, spef, sdf, lef, and lib files global dbgLefDefOutVersion set dbgLefDefOutVersion 5.6 defOut -floorplan -netlist -routing \$BASENAME.def saveDesign \${BASENAME}\_done.enc -def

puts "-----Output \${BASENAME}\_soc.v file------" SaveNetlist [format "%s\_soc.v" \$BASENAME]

# generate final timing data
extractRC -outfile \$BASENAME.cap
rcOut -spef \$BASENAME.spef
write\_sdf -ideal\_clock\_network \$BASENAME.sdf

# generate a .lib model of the cell just in case do\_extract\_model -blackbox\_2d \${BASENAME}\_soc.lib

# Generate timing model for PrimeTime just in case
writeTimingCon \${BASENAME}\_done.pt
report\_timing -check\_clocks report\_timing.pt

puts "------Verify and file output done-----"

4 - Now you have the .lib. If you want to use this cell as an instance in Synopsys dc\_shell synthesis and you don't want Synopsys to complain about not knowing what it is (this complaint can be ignored, but it is annoying) you can compile the .lib into a .db file so the synthesis process can use it. Use dc\_shell read\_lib and write\_lib for this.

5 - Import the .def file into icfb using import -> def. Go through the regular abstract view to layout view stuff to get a good layout view. Run DRC and Extract.

6 - Import the structural Verilog from EDI into the same library as the layout.

7 - Compare the layout (extracted) and schematics with LVS to make sure things are right.

8 - The abstract process needs to know where vdd! and gnd! are so put shape pins on the vdd! and gnd! wires in the power ring. The I/O signal pins will all be there from EDI.

9 - Run Abstract to generate the abstract view, and the .lef file. You can run abstract from inside composer or from the command line. The important stuff is:

Pins Step:

- The Boundary Adjust is 0. That is, the prBoundary is right on the edge of the cell.

- Make sure that "create power pins from routing" is set and uses layers metal1, metal2, via.

Extract Step:

- Make sure "Extract Power Pins" is enabled

Abstract Step:

- Select "Create Ring Pins" so that the power pins in the .lef file will be "class ring" This tells EDI that there's a power ring to connect to.

- Select "Create Boundary Pins" too so that you'll get I/O pins.

- Blockage tab - cover type, Boundary should be offset so that the cover obstructions in the lef won't extend all the way to the edge of the cell and keep power routing from getting inside the cell. The amount depends on how much space you've used for the rings in your design. If you left a 30 micron gap and filled that with the power and ground rings, then something close to 30 is good. I use 27 in that case.

10 - When you have a successful abstract view, output a .lef file.

11 - (optional) edit this lef file to take out the rotation symmetry from the macro description. If you leave this in, EDI might rotate your cell. I find that if you rotate it things get ugly because you've changed the normal h/v routing conventions. So, take the following lines and modify them by removing the R90. It's fine to flip a macro in X or Y, but rotating seems to cause problems.

MACRO macro\_name CLASS RING ; FOREIGN macro\_name 0 0 ; ORIGIN 0.00 0.00 ; SIZE 866.10 BY 843.00 ; SYMMETRY X Y R90;

•••

You now have a macro with layout, extracted, schematic, symbol, and abstract views. You also have .lib, .lef, .v, and possibly .db descriptions of the cell. It's now ready to use in EDI as a fixed block in another piece of Verilog code.

-----

Step 2 is to use the block in another macro. The easy part is putting it in your code. You can put it in a piece of structural verilog by hand, or you can include that instance in a larger piece of Verilog that has behavioral stuff and pass the whole thing through Synopsys synthesis to get a purely structural file.

Remember that if you run Synopsys on it you will need the .db description so that Synopsys doesn't complain. Actually you can probably ignore the complaints but it makes it nicer not to see the complaints. This .db file would be listed along with the other .db files in the target library list.

When used as in instance you should always use "dot notation" for the arguments to the instance. That is, don't use:

blockname ID (A, B);

Instead use

blockname ID (.arg1(A), .arg2(B));

With these "black boxes" the tools may or may not have info about the order of arguments in the module so this eliminates that worry.

Now I assume that you have a sturctural Verilog description that has instances of your block or blocks in it. For example:

module alu\_core ( result, a, b, reset, clk, func ); output [15:0] result; input [7:0] a; input [7:0] b; input [3:0] func; input reset, clk; wire n2, n3, n4, n5, n6, n7, n8, n9, n13, n15, n17, n19, n21, n23, n24, n261, n262, n263, n264, n265; wire [7:0] maca; wire [15:0] product; wire [7:0] macb; wire [8:0] sum; wire [15:0] aluout; // instances of pre-designed modules
mult Umult ( .P(product), .A(a), .B(b) );
add Uadd ( .S(sum), .A({maca[7], n264, maca[5:0]}), .B(macb) );

// Standard cells that need to be placed and routed with EDI DFF result\_reg\_15\_ ( .D(aluout[15]), .G(clk), .CLR(reset), .Q(result[15]) ); DFF result\_reg\_14\_ (.D(aluout[14]), .G(clk), .CLR(reset), .Q(result[14])); DFF result\_reg\_13\_ (.D(aluout[13]), .G(clk), .CLR(reset), .Q(result[13])); DFF result\_reg\_12\_ ( .D(aluout[12]), .G(clk), .CLR(reset), .Q(result[12]) ); DFF result\_reg\_11\_ (.D(aluout[11]), .G(clk), .CLR(reset), .Q(result[11])); DFF result\_reg\_10\_(.D(aluout[10]),.G(clk),.CLR(reset),.Q(result[10])); MUX2\_INV U30 ( .A(b[7]), .B(result[7]), .S(func[3]), .Y(n2) ); MUX2 INV U31 (.A(b[6]), .B(result[6]), .S(func[3]), .Y(n3)); NAND2 U46 ( .A(n24), .B(n25), .Y(aluout[9]) ); NAND2 U47 (.A(n210), .B(product[9]), .Y(n25)); NOR2 U87 (.A(n213), .B(n74), .Y(n73)); MUX2\_INV U88 ( .A(n43), .B(n44), .S(a[5]), .Y(n74) ); NAND2 U89 ( .A(n263), .B(a[5]), .Y(n72) ); NAND2 U91 (.A(n211), .B(n13), .Y(n76)); NAND2 U92 (.A(n256), .B(n194), .Y(n75));

### endmodule

Now you can generate a new placed and routed module that includes your blocks and (perhaps) standard cells that should be placed around the blocks. This new block can be made into yet another macro by following the procedure above to generate .lib, .lef, .v, and .db descriptions.

1 - edit the config file to make sure that all the .lib files are included in the timing librarys (standard-cells.lib, block.lib, etc.).

2 - Ditto for the lef files (techheader.lef, cells.lef, block.lef, etc.)

3 - Other config stuff is the same as before - the cell name, input netlist (.v), timing constraint file (sdc) etc. are set as before. You may choose to include a .io file to specify pin placements, or you can leave that out.

4 - Add a couple steps to the normal flow to deal with the blocks.

- After floorplan sizing, you should add a halo around each block so that standard cells aren't placed too close to the block. It doesn't need to be much, but it should be some. The following will add 3 microns of halo to everything in class block. You can do the same from the menu using Floorplan-EditFloorplan-EditHalos. There are two types - routing halos that restrict routing in that halo, and placement halos that restrict cell placement.

addHaloToBlock 3 3 3 3 –allBlock addRoutingHalo -space 3 -top M3 -bottom M1 -allBlocks - Once the block have halos you can place them in the core routing area. You can do this by hand (pick up and move them in the gui with the movement widget), or have EDI do an auto placement for you. The gui is Floorplan-AutomaticFloorplan-PlaceDesign. This will place all the blocks for you. The script version of the command is

#### planDesign

You can also place things relative to other blocks or sides of the core using the Floorplan-RelativeFloorplan dialogs (start with EditConstrants or GenerateConstraints).

- Once the blocks are placed you need to set their placement status to fixed so that standard cell placement won't change them. You do this with Floorplan-EditFloorplan-SetBlockPlacementStatus or with the script command:

setBlockPlacementStatus -allHardMacros -status fixed

- Now you can make the power rings and stripes as usual. The extra settings you need to be careful of are:

- Add Rings - Same as for flat design

- Add Stripe - Set Configuration, Set Patten, Stripe Boundary, and First/Last are the same as in flat. In Advanced make sure Snap Wire Center To Routing Grid is set to Grid. In Via Generation select If Same Layer Target Exists... to be Same Layer Target Only. This keeps problems from happening later with overlapped vias at the corners of the block power rings.

The script commands are (assuming that \$pspace, \$pwidth, \$sspace, and \$soffset have been set in the script):

addRing -spacing\_bottom \$pspace -width\_left \$pwidth -width\_bottom \$pwidth -width\_top \$pwidth -spacing\_top \$pspace -layer\_bottom metal1 -center 1 -stacked\_via\_top\_layer metal3 -width\_right \$pwidth -around core -jog\_distance \$pspace -offset\_bottom \$pspace -layer\_top metal1 -threshold \$pspace -offset\_left \$pspace -spacing\_right \$pspace -spacing\_left \$pspace -offset\_right \$pspace -offset\_top \$pspace -layer\_right metal2 -nets {gnd! vdd! } -stacked\_via\_bottom\_layer metal1 -layer\_left metal2

addStripe -same\_layer\_target\_only 1 -block\_ring\_top\_layer\_limit metal3 -max\_same\_layer\_jog\_length 3.0 -snap\_wire\_center\_to\_grid Grid -padcore\_ring\_bottom\_layer\_limit metal1 -set\_to\_set\_distance \$sspace -stacked\_via\_top\_layer metal3 -padcore\_ring\_top\_layer\_limit metal3 -spacing \$pspace -xleft\_offset \$soffset -merge\_stripes\_value 1.5 -layer metal2 -block\_ring\_bottom\_layer\_limit metal1 -width \$swidth -nets {gnd! vdd! } -stacked\_via\_bottom\_layer metal1

- Now you have the blocks placed and the rings and cores placed. You should now place the cells before you sroute the power and ground lines. I've seen cases where there are gaps in the power lines if you don't place the cells first.

- When you do sroute the power and ground lines you should add the option in the Via Generation tab to Connect to Overlapping Targets on the Closest Layer. This seems to help with the overlapping via problem. The text command in the script is:

sroute -viaThruToClosestRing -jogControl { preferWithChanges differentLayer }

- Other steps should be the same as in the flat flow.

-----

An alternative is to do things in a slightly different order and take advantage of the "place blocks and cells" command to place them all in one shot.

- In this flow you set the floorplan size in the usual way. You can also make the power ring as usual.

- Make halos around the blocks first before you place anything.

- Now, you can place the cells and blocks in one step using the Place-PlaceStandardCellsAndBlocks command. Script is:

```
setPlaceMode -timingdriven -reorderScan -congMediumEffort
-noCongOpt -noModulePlan
placeDesign -inPlaceOpt -prePlaceOpt
```

- Now you can make the power stripes. Note that the stripes will connect to the ring connections of the blocks. But, they also splat right over the standard cells!

- So, now you need to refine the placement to move cells out from under the stripes. This is Place-RefinePlacement. It will move the cells so they're not overlapping with the stripes. Script step is:

refinePlace

- Now you can sroute the power and ground. Remember to use the Overlapping Targets - Closest Layer option.

sroute -viaThruToClosestRing -jogControl { preferWithChanges differentLayer }

- Now you should have a legal placement and power plan so you can continue with the rest of the standard flow...

\_\_\_\_\_

Note that if you're running EDI on a cell with pads then:

- You MUST have a .io file with pad placements in it.

- The pads defined in the .io file must be defined in the structural Verilog file and must have the same names.

- When you get to the SpecifyFloorplan step you need to make sure that you don't specify a floorplan that will change the pad cell spacing! Instead of specifying Size By Core Size and Aspect Ratio, you specify the Size By Die Size and make sure that the die size is exactly the right dimensions. For a single TCU this is 1500 by 1500 for Die Width and Size. Then you can adjust the Core to IO Boundary numbers to change how much space is between the core and the pad ring. The script version of the command uses the -d switch to specify the die size instead of the -r switch for relative aspect ratio and density. An example for a single TCU with 60 microns between the core area and the pag ring (for the power rings) is:

floorPlan -site core -d 1500.0 1500.0 60 60 60 60