

# Agenda



- Why CDC Verification on Gate-Level Designs
- Traditional Methodology and Challenges
- Proposed Gate-CDC Verification Methodology
- Experiments & Results

# Clock Domain Crossing(CDC)



### • What is CDC

Signal originating in one clock domain sampled in another asynchronous clock domain



## **Need for Gate-Level CDC Verification**



### Traditionally CDC verification done on RTL



### Gate-CDC Example



### CDC path introduced due to insertion of loc



upf\_version 2.0 set\_design\_top top create\_power\_domain TOP create\_power\_domain PD\_TX -elements {Tx} create\_power\_domain PD\_RX -elements {Rx} create\_power\_domain PD\_RX2 -elements {Rx2} create\_supply\_port VDD\_HIGH create\_supply\_net VDD\_HIGH -domain TOP connect\_supply\_net VDD\_HIGH -ports VDD\_HIGH set isolation PD TX ISO OUT -domain PD TX -clamp value 1 -applies to outputs -isolation power net VDD HIGH \

clk1

-isolation\_ground\_net VSS -isolation\_signal {x} -isolation\_sense low -location parent set\_isolation PD\_TX\_ISO\_OUT -domain PD\_RX -clamp\_value 1 -applies\_to outputs -isolation\_power\_net VDD HIGH \

## Gate-CDC Glitch Structure Example



- Combination logic that can reduce to:
  - X.~X or X+~X





## Gate-CDC Mux Glitch Example





# Gate-CDC Mux Synchronizer Glitch Example





For given constants, logic reduces to (tx0|~tx0) which causes glitch

# Gate-CDC Mux Synchronizer Glitch Example







### **CDC** Verification Flow



### CDC verification is necessary on gate-level netlist



## **Traditional Methodology**





### **Traditional Methodology**





## **Proposed Methodology**





### **RTL Constraints Reuse**

### **RTL Constraints**

#### netlist blackbox

netlist constant com gace master netlist constant ccc\_sync0\_async1\_sel 1'b1 netlist constant shadow clock 1'b0 netlist constant tap atpg\_shift 1'b0 netlist constant tap test mode tdr 1'b0 netlist constant tcr async reset atpg ctrl 1'b0 netlist constant tcr async set atpg ctrl 1'b0 netlist constant tcr cgc atpg ctrl 1'b0 netlist constant msm addr range 1'b1 netlist clock axi clk -group AXICLK netlist clock ddr cc.u core 2x clk mux.genblk1[1].inst0.z -group DDR2XCLK netlist clock ddr cc.u core clk div2.inst0.clk out -group DDR2XCLK netlist clock ddr cc.u core clk mux.genblk1[1].inst0.z -group DDR2XCLK netlist clock ddr2xclk -group DDR2XCLK netlist clock memintclk -group DDR2XCLK netlist clock cdcslogic clk -group DDR2XCLK netlist clock ddr cc.runAlwaysClock gate.genblk1[1].inst0.clk -group DDR2XCLK netlist clock ddr cc.intClk gate.genblk1[1].inst0.clk -group DDR2XCLK netlist clock ddr\_cc.ddr2xClk\_gate.genblk1[1].inst0.clk -group DDR2XCLK netlist clock ddr\_cc.u\_clk\_src.genblk1[1].inst0.z -group DDR2XCLK

#### cdc custom sync

### netlist clock dicting delege detect\_async\_rs\_ctrl

cdc custom sync gctlib edge detect dftc async rs ctrl -type DFF cdc custom sync data -from edge in -to async edge -module gctlib edge detect dftc async rs ctrl hier assume port edge in -no combo -module gctlib edge detect dftc async rs ctrl hier port domain reset edge stb -clock clk -module gctlib edge detect dftc async rs ctrl hier port domain async edge edge in -module gctlib edge detect dftc async rs ctrl -sync cdc report crossing -through { smiEbi.memController.dataReadLogic.devRegData[\*] } -severity waived cdc report crossing -from \*io cal top.pcnt gual\* -to \*io cal top.pcnt reg\* -severity waived cdc report crossing -from \*io cal top.ncnt qual\* -to \*io cal top.ncnt reg\* -severity waived cdc report crossing -from {\*io cal top.pcnt reg[0]} -to {\*ioc pcnt set[0]} -severity waived cdc report crossing -from \*io cal top.ncnt reg\* -to \*ioc ncnt set\* -severity waived cdc report crossing -through msm addr -severity waived



# SYSTEMS INITIATIVE

### **Traditional Methodology :**

- Constraints not applied due to name and topology changes post synthesis
- No black-boxing
  - Redundant processing inside the module •
- Custom synchronizer not detected
  - False missing synchronizer Noise

### **RTL Constraints Reuse**





### **RTL Constraints**

#### netlist blackbox cm\_cdc\_master

netlist constant ccc sync0 async1 sel 1'b1 netlist constant shadow clock 1'b0 netlist constant tap atpg shift 1'b0 netlist constant tap test mode tdr 1'b0 netlist constant tcr\_async\_reset\_atpg\_ctrl 1'b0 netlist constant tcr async set atpg ctrl 1'b0 netlist constant tcr cgc atpg ctrl 1'b0 netlist constant msm addr range 1'b1 netlist clock axi clk -group AXICLK netlist clock ddr cc.u core 2x clk mux.genblk1[1].inst0.z -group DDR2XCLK netlist clock ddr cc.u core clk div2.inst0.clk out -group DDR2XCLK netlist clock ddr cc.u core clk mux.genblk1[1].inst0.z -group DDR2XCLK netlist clock ddr2xclk -group DDR2XCLK netlist clock memintclk -group DDR2XCLK netlist clock cdcslogic clk -group DDR2XCLK netlist clock ddr cc.runAlwaysClock gate.genblk1[1].inst0.clk -group DDR2XCLK netlist clock ddr\_cc.intClk\_gate.genblk1[1].inst0.clk -group DDR2XCLK netlist clock ddr cc.ddr2xClk gate.genblk1[1].inst0.clk -group DDR2XCLK netlist clock ddr\_cc.u\_clk\_src.genblk1[1].inst0.z -group DDR2XCLK netlist clock {ddr read dqs[3]} -group group3 netlist clock {ddr\_read\_dqs[2]} -group group2 netlist clock {ddr read dqs[1]} -group group1

#### cdc custom sync

### hier assume por**cetlic**o ecoce asserted as the second state of the

hier port domain reset edge\_stb -ctock ctk -module qctlib\_edge\_detect\_dftc\_async\_rs\_ctrl hier port domain async\_edge edge\_in -module qctlib\_edge\_detect\_dftc\_async\_rs\_ctrl -sync cdc report crossing -through { smiEbi.memController.dataReadLogic.devRegData[\*] } -severity waived cdc report crossing -from \*io\_cal\_top.pcnt\_qual\* -to \*io\_cal\_top.pcnt\_reg\* -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_qual\* -to \*io\_cal\_top.ncnt\_reg\* -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_reg[0]} -to {\*ioc\_pcnt\_set[0]} -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_reg\* -to \*ioc\_ncnt\_set\* -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_reg\* -to \*ioc\_ncnt\_set\* -severity waived cdc report crossing - through msm addr -severity waived

### Auto-generated gate constraints

#### netlist blackbox cm cdc slave

 $\mathbf{Q}_{0}^{0}$ 

netlist blackbox cm\_cdc\_master\_0\_2 netlist blackbox cm\_cdc\_master\_0\_1

#### etlist constant shadow\_clock 1'b0

netlist constant tap\_atpg\_shift 1'b0 netlist constant tap test mode tdr 1'b0 netlist constant tcr\_async\_reset\_atpg\_ctrl 1'b0 netlist constant tcr async set atpg ctrl 1'b0 netlist constant tcr cgc atpg ctrl 1'b0 netlist clock axi clk -group AXICLK netlist clock ddr cc.u core 2x clk mux.genblk1 1 .inst0.z -group DDR2XCLK netlist clock ddr cc.u core clk div2.inst0.clk out -group DDR2XCLK netlist clock ddr cc.u core clk mux.genblk1 1 .inst0.z -group DDR2XCLK netlist clock ddr2xclk -group DDR2XCLK netlist clock memintclk -group DDR2XCLK netlist clock cdcslogic clk -group DDR2XCLK netlist clock ddr cc.runAlwaysClock gate.genblk1 1 .inst0.clk -group DDR2XCLK netlist clock ddr cc.intClk gate.genblk1 1 .inst0.clk -group DDR2XCLK netlist clock ddr cc.ddr2xClk gate.genblk1 1 .inst0.clk -group DDR2XCLK netlist clock ddr cc.u clk src.genblk1 1 .inst0.z -group DDR2XCLK netlist clock {ddr read dqs[3]} -group group3 netlist clock {ddr read dqs[2]} -group group2 netlist clock {ddr read dqs[1]} -group group1

#### cdc custom sync

#### hier assume por **Collib** no **edge** ul**Cetect**e **async**as <u>msrs</u> <u>ctrl</u> **6 16** hier port domain reset edge stb -ctock clk -module qctlib edge detect dftc async rs ctrl <u>16</u> hier port domain async edge edge in -module qctlib edge detect dftc async rs ctrl <u>16</u> -sync cdc report crossing -through { smiEbi.memController.dataReadLogic.devRegData \* } -severity waived cdc report crossing -from \*io\_cal\_top.pcnt\_qual\* -to \*io\_cal\_top.pcnt\_reg\* -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_qual\* -to \*io\_cal\_top.ncnt\_reg\* -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_reg\_reg\_0\_iq} -to {\*ioc\_pcnt\_set\_reg\_0\_iq} -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_reg\* -to \*ioc\_ncnt\_set\* -severity waived cdc report crossing -from \*io\_cal\_top.ncnt\_reg\* -to \*ioc\_ncnt\_set\* -severity waived

### **RTL Waivers Reuse**





### **RTL Constraints**

| cdc report crossing -from<br>{*io_cal_top.pcnt_reg[0]}<br>-to {*ioc_pcnt_set[0]} -severity waived                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             | <pre>{*io_cal_top.pcnt_reg_reg_0iq} -to {*ioc_pcnt_set_0iq} -severity waived</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 100 - 100 B | cdc report crossing -from                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| netlist clock {ddr_read_dqs[3]} -group group3<br>netlist clock {ddr_read_dqs[2]} -group group2<br>netlist clock {ddr_read_dqs[2]} -group group0<br>cdc custom sync qtlib_edge_detect_dftc_async_rs_ctrl -type DFF<br>cdc custom sync qtata -from edge_in -to async_edge -module qctlib_edge_detect_dftc_async_rs_ctrl<br>hier assume port edge_in -no_combo -module qctlib_edge_detect_dftc_async_rs_ctrl<br>hier port domain reset edge_stb -clock clk -module qctlib_edge_detect_dftc_async_rs_ctrl<br>hier port domain reset edge_in -module qctlib_edge_detect_dftc_async_rs_ctrl<br>hier port domain async_edge edge_in -module qctlib_edge_detect_dftc_async_rs_ctrl<br>hier port crossing -through { smiEbi.memController.dataReadLogic.devRegData[*] } -severity waived<br>cdc report crossing -from *io cal top.pcnt_qual* -to *io_cal top.pcnt_reg* -severity waived                                                                                                                                                            |             | <pre>"group DURZALLK "mettist clock {ddr_read_dqs[2]} -group group3 netlist clock {ddr_read_dqs[2]} -group group2 netlist clock {ddr_read_dqs[1]} -group group1 netlist clock {ddr_read_dqs[0]} -group group0 cdc custom sync qctlib_edge_detect_dftc_async_rs_ctrl -type DFF cdc custom sync data -from edge_in -to async_edge -module qctlib_edge_detect_dftc_async_rs_ctrl_16 hier assume port edge_in -no_combo -module qctlib_edge_detect_dftc_async_rs_ctrl_16 hier port domain reset edge_stb -clock clk -module qctlib_edge_detect_dftc_async_rs_ctrl_16 hier port domain async_edge edge_in -module qctlib_edge_detect_dftc_async_rs_ctrl_16 hier port crossing -through { smiEbi.memController.dataReadLogic.devRegData_*_ } -severity waived</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| netlist constant tcr_async_reset_atpg_ctrl 1'b0<br>netlist constant tcr_async_set_atpg_ctrl 1'b0<br>netlist constant tcr_cgc_atpg_ctrl 1'b0<br>netlist constant msm_addr_range 1'b1<br>netlist clock ddr_cc.u_core_2x_clk_mux.genblk1[1].inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_div2.inst0.clk_out -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1[1].inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1[1].inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1[1].inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1[1].inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.runAlwaysClock_gate.genblk1[1].inst0.clk -group DDR2XCLK<br>netlist clock ddr_cc.intClk_gate.genblk1[1].inst0.clk -group DDR2XCLK<br>netlist clock ddr_cc.ddr2xClk_gate.genblk1[1].inst0.clk -group DDR2XCLK<br>netlist clock ddr_cc.ddr2xClk_gate.genblk1[1].inst0.clk -group DDR2XCLK<br>netlist clock ddr_cc.ddr2xClk_gate.genblk1[1].inst0.clk -group DDR2XCLK |             | netlist constant tap_test_mode_tdr 1'b0<br>netlist constant tcr_async_reset_atpg_ctrl 1'b0<br>netlist constant tcr_gc_atpg_ctrl 1'b0<br>netlist clock dxi_cclkgroup AXICLK<br>netlist clock ddr_cc.u_core_2x_clk_mux.genblk1_1.inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_div2.inst0.clk_out -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1_1.inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1_1.inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1_1.inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.u_core_clk_mux.genblk1_1.inst0.z -group DDR2XCLK<br>netlist clock ddr_cc.runAlwaysClock_gate.genblk1_1.inst0.clk -group DDR2XCLK<br>netlist clock ddr_cc.runAlwaysClock_gate.genblk1_1_inst0.clk -group DDR2XCLK |
| netlist blackbox cm_cdc_slave<br>netlist blackbox cm_cdc_master<br>netlist constant propagation<br>netlist constant ccc_sync0_async1_sel 1'b1<br>netlist constant shadow_clock 1'b0<br>netlist constant tap_atpg_shift 1'b0<br>netlist constant tap_test_mode_tdr 1'b0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             | netlist blackbox cm_cdc_slave_1<br>netlist blackbox cm_cdc_master_0_1<br>netlist blackbox cm_cdc_master_0_2<br>netlist constant propagation<br>netlist constant ccc_sync0_async1_sel 1'b1<br>netlist constant shadow_clock 1'b0<br>netlist constant tap_atpg_shift 1'b0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

### Auto-generated gate constraints

## Auto Infer Test Mode Settings



### Scan mux inserted CDC path



False

- Traditional methodology
  - Synchronizer not detected

### Auto Infer Test Mode Settings



### Scan mux inserted CDC path



- Proposed methodology
  - Structural analysis detects scan enable settings
  - Two dff synchronizer detected

# **Regroup Bit-blasted Crossings**





Gate-level : 16 separate 1-bit paths



- Traditional methodology
  - 16 separate 1-bit paths reported
  - r\_reg\_0.iq -> q\_reg\_0.iq, r\_reg\_1.iq -> q\_reg\_1.iq, ...

Crossing count multiplied by number of vector signal bits

# **Regroup Bit-blasted Crossings**





Gate-level : 16 separate 1-bit paths



- Proposed methodology
  - 16 separate paths regrouped to 1 CDC path
  - r\_reg\_[15:0].iq -> q\_reg\_[15:0].iq

Crossing count same as RTL for vector signals

## **Proposed Methodology**







## **Experiment Results**







- Average 1.6x improvement in runtime
- Average 18% improvement in memory consumption
- No iterations required for setup



## **Experiment Results**





- Upto 80% reduction in noise
  - Bit-merging
  - Constraints & waivers reuse
  - Test logic removed

## Summary



- Gate-CDC verification closure is necessary and now possible
- Proposed methodology addresses gate-level CDC verification challenges
  - Automatic RTL constraints transformation engine
  - Auto detection of test logic
  - Detect glitches introduced in synthesis
  - Regroup bit-blasted CDC paths
  - Correlates gate-CDC results with RTL
  - Waiver reuse
- Benefits
  - Seamless setup and reduced noise
  - Accelerates verification closure



# Thank You