



Application of Model Connection Protocols for System-level Power Delivery Network Analysis

IBIS Summit Tokyo, Japan November 6, 2009

Yutaka Honda, ATE Service Corp. Brad Brim, Sigrity Inc. yutaka@ate.co.jp bradb@sigrity.com







# Agenda

- Discuss chip/package/board system-level analysis
- Review connectivity protocols
- A power delivery network example

## NOTE:

• The Sigrity model connection protocol discussed in this presentation is not being proposed as a standard, merely as an example of an existing solution created in reaction to short term need and lack of existing standard protocols.





# System-level analysis challenges (1)

#### Assume I have ...

- a chip/package/board system with thousands of physical pins
- individual models for chip, package, board







# System-level analysis challenges (2)

## • How do I ...

- 1. know which pins of one model to connect to the pins of another model?
- 2. reliably and quickly connect these models in a netlist or schematic?







## Requirements

#### Chip/package/board systems have many physical connections (pins)

chip-package boundary  $\approx$  100 - 6000
package-board boundary  $\approx$  100 - 2500

#### Not all electrical models can have pin-level resolution

- models may be too large to compute, store, etc.
- difficult to connect in EDA tools

#### Adequate modeling may not be possible with net-level resolution

- especially, if this low resolution is applied throughout the entire system
  - NOTE: "net-level resolution" groups all pins for each net at a domain boundary

#### Support is required for

- arbitrarily pin-grouped models
- automated connection amongst models in EDA tools





service

# System Analysis





# Existing Model Connection Protocols for Chip/Package/Board Analysis

### Sigrity MCP (Model Connection Protocol)

- defined by Sigrity
  - publicly available definition
- objective to support chip/package/board system analysis
- version 1.1 available with user-requested pin locations for support where pin name mismatches exist

## Apache CPP

- defined by Apache
  - definition covered under NDA
- Implemented as model "headers"
- Contained within model-native comment lines
  - model could be either subcircuit or data file





## A Typical Model Connection Protocol (Sigrity MCP)

| * | [MCP Begin]                                             |               |         |   |   |  |
|---|---------------------------------------------------------|---------------|---------|---|---|--|
| * | [MCP Ver] 1.1                                           |               |         |   |   |  |
| * | [Structure Type] {DIE   PKG   PCB }                     |               |         |   |   |  |
| * | [MCP Source] <i>source text</i>                         |               |         |   |   |  |
| * | [Coordinate Unit] <i>unit</i>                           |               |         |   |   |  |
| * | [Connection] connectionName partName numberPhysicalPins |               |         |   |   |  |
| * | [Connection Type] {DIE   PKG   PCB }                    |               |         |   |   |  |
| * | [Power Nets]                                            |               |         |   |   |  |
| * | pinName                                                 | modelNodeName | netName | x | Y |  |
| * | •••                                                     |               |         |   |   |  |
| * | pinName                                                 | modelNodeName | netName | x | У |  |
| * | [Ground Nets]                                           |               |         |   |   |  |
| * | pinName                                                 | modelNodeName | netName | x | У |  |
| * | •••                                                     |               |         |   |   |  |
| * | pinName                                                 | modelNodeName | netName | x | У |  |
| * | [Signal Nets]                                           |               |         |   |   |  |
| * | pinName                                                 | modelNodeName | netName | x | У |  |
| * |                                                         |               |         |   |   |  |
| * | pinName                                                 | modelNodeName | netName | x | У |  |
| * | [MCP End]                                               |               |         |   |   |  |



# Example chip-package-board system



#### Goal

reduce/eliminate PDN impedance peaks at the chip

#### Requirements

- avoid a board re-spin
  - use existing stack-up
  - use existing decap locations
  - allow only same-size or smaller decaps
- performance is primary, cost is secondary
  - allow more expensive decaps if required

On-board decaps (bottom)



SIGRITY



service

## Example chip-package-board system





## Example chip-package-board system initial decap placement

### 220 capacitors

- in-package
- core area
- close to device
- VRM bulk caps

| 4   |   |
|-----|---|
| 98  |   |
| 109 |   |
| 9   | - |







# System PDN analysis setup



#### 2-1) Analysis with pin-grouped package model

- per net chip model
- Grouped (4-by-4 grid) connectivity between board and package
  - 32 electrical connections 16 VDD, 16 VSS

#### 2-2) Optimization of PDN for performance and cost

same setup as 2-1) above







# System analysis with merged board/package



- 4 hours simulation time
- 5GB RAM
- 180% of Z<sub>target</sub> at peak
- Cost = 4.6

#### NOTE:

- 24-layer board and 10-layer package databases are merged into single design.
- Per-pin connection between board and package with all couplings.



# Concept of the Model-to-Model Link by MCP





SIGRITY



# EDA mapping of the MCP package model



- 3 mouse clicks associate an external model with the component definition.
- Quick and error-free process.





## System analysis with pin-grouped package model

#### Impedance Amplitude (ohm) chip decap merged analysis connections board analysis backage model Ztarget Π 0.1 1e-4 1e-5 1e-3 0.01Frequency (GHz) Package Model NOTE: • 24-layer board simulated with S-parameters - 2 hours, 3GB RAM

- RLCK model 30 minutes, 3GB RAM
- Board (with package model attached)
  - 10 minutes, 1GB RAM

- S-parameter model for package.
- 4-by-4 board/package connection.





## System optimization with pin-grouped package model

#### Impedance Amplitude (ohm)

17



- 40 minutes optimization time
- 65% of Z<sub>target</sub> at switching frequencies
- Cost = 2.3 (50% savings) with 93 decaps





#### System optimization with pin-grouped package model



#### Success!

- Impedance peaks have been eliminated
- Impedance is less than Ztarget over frequency range of interest
- Decap cost is saved as well

89 board decaps 4 in-package decaps







## **Observations**

- Chip/package/board designs may have thousands of pins
- Chip/package/board PDN system analysis and optimization requires
  - user-definable model resolution
  - automated connection support for EDA tools
- Circuit and data models are commonly applied
  - both should be supported by any connection protocol
- Model connection protocols are much more than simply "port names"
- Proprietary model connection protocols are currently being applied
- An industry standard model connection protocol should be defined
  - user and EDA vendor participation will be required to agree on a standard
  - active participation by more than a few individuals will be required
  - the authors intend to escalate this topic with the IBIS committees
    - many designers and EDA vendors need as soon as possible





# Thank You!



