# Floorplanning Cheat Sheet

- What Is Floorplanning?
  - First major physical design step after synthesis
  - Defines chip's physical organization
  - Impacts: Timing | Power | Area | Routability
  - Foundation for placement → CTS → routing

## **©** Key Objectives

| Objective           | Description                                             |  |
|---------------------|---------------------------------------------------------|--|
| Define Core<br>Area | Based on die size,<br>utilization, std.<br>cells/macros |  |
| Place Macros        | Memories, IPs, with orientation + spacing               |  |
| IO<br>Placement     | Input/output pads/bumps<br>(wirebond/flip-chip)         |  |
| Power<br>Planning   | Rings, stripes, mesh                                    |  |
| Channel<br>Planning | Leave whitespace<br>between macros                      |  |
| Clock<br>Planning   | Place FF-heavy logic for easier CTS                     |  |
| Define<br>Blockages | Restrict placement near macros/analog blocks            |  |

# 📥 Inputs to Floorplan

- Synthesized netlist (.v) → logic hierarchy
- Constraints (SDC) → timing
- Tech LEF → std. cell + macro sizes
- Power intent (UPF/CPF) → multi-V, low power
- IO Pad Ring → pad definition (wirebond)
- Macro LEF/DEF → orientation + pins

# Floorplanning Flow

- Estimate die/core area (utilization)
- 2. Define core boundary (core-to-die ratio)
- 3. Place hard macros / analog IPs
- 4. Place IO pads/bumps
- 5. Reserve whitespace & channels
- 6. Create power planning (rings/stripes)
- 7. Add blockages (hard/soft)
- 8. Define regions/partitions (optional)
- 9. Verify DRC, overlaps, accessibility

### Important Metrics

| Parameter            | Description                         |
|----------------------|-------------------------------------|
| Core<br>Utilization  | Std. cell area ÷ core area (60–80%) |
| Core-to-Die<br>Ratio | Core vs die edge<br>spacing         |
| Aspect<br>Ratio      | W:H (ideal ≈ 1:1)                   |
| Halo                 | Keep-out margin around macros       |
| Channel<br>Spacing   | Space between macros                |
| Row<br>Utilization   | % of std. cell rows used            |

## Macro Placement Best Practices

- Place large macros near edges → better routing & isolation
- Avoid corners → routing restriction
- Orient for pin accessibility → fewer detours
- Leave channels between macros → avoid congestion
- Use halo + blockages → prevent close placement

# Power Planning (During Floorplan)

- Power Rings: around core/macros, wide metals
- Stripes: inside core (H/V)
- Tap Cells: tie substrate to power net
- Well Taps + Decaps: noise stability
- Domain Separation: for multi-V (UPF/CPF)

# Floorplan Constraints (Tool-Level)

| Constraint            | Purpose                           |
|-----------------------|-----------------------------------|
| Soft<br>Blockages     | Block placement (routing allowed) |
| Hard<br>Blockages     | Block both placement<br>+ routing |
| Region<br>Constraints | Force logic into area             |
| Fence<br>Region       | Boundary for IP reuse             |
| Pin<br>Constraints    | Guide IO/macro pin placement      |

# **X** Tool Commands

#### Cadence Innovus

floorPlan -site CORE -coreUtil 0.7 -aspectRatio 1.0 -coreToDie placeIoPins addHalo -allMacros -halo 10 10 createPlaceBlockage -type hard -area {x1 y1 x2 y2}

## Synopsys ICC2

initialize\_floorplan -utilization 0.7 -aspect\_ratio 1.0 create\_power\_straps create\_macro\_blockage -region {x1 y1 x2 y2}

## ♠ Common Issues & Fixes

| Issue             | Cause                     | Fix                            |
|-------------------|---------------------------|--------------------------------|
| Macro<br>overlaps | Bad<br>placement/<br>halo | Reposition + set halo          |
| Congesti on zones | Dense<br>macros           | Increase spacing, add channels |

| Timing violations | Bad macro location | Move logic closer, reroute      |
|-------------------|--------------------|---------------------------------|
| Power<br>DRCs     | Stripe/ring issues | Redo with correct pitch/width   |
| Routing detours   | Poor pin access    | Adjust orientation, constraints |

# Post-Floorplan Checks

- DRC clean (no overlaps/spacings)
- Power/ground rings + stripes present
- Clock sinks distributed well
- No macros in corners / bottlenecks
- IR/EM preview (RedHawk/Voltus)