

#### 2023 DCS Lab 10

# Clock Domain Crossing (CDC)

- CDC: When the data launched and captured by different (asynchronous) clock domain, this case is called Clock Domain Crossing.
- Consider two clocks, clk1 and clk2, with periods 13 and 10 respectively.



### Metastability

- The unstable status due to non-ideal data transition is called metastability.
- To avoid this phenomenon, we have to ensure data transition during setup/hold timing check.
- However, CDC designs will inevitably face this problem.



#### Solution: A Brute-Force Synchronizer



細節請參考: 上課講義 Lecture 12

### You need to design

- Clk1 = 14.1 ns, clk2 = 2.5 ns
- Input 在clk1 domain傳送
   1bit control signal(in\_valid)
   [3:0]in\_a,in\_b
   1bit mode
- Out 在clk2 domain計算並接收一筆8bit資料

## Block diagram



#### Block diagram





| State   | description                                                  | next_state                   |
|---------|--------------------------------------------------------------|------------------------------|
| IDLE    | IDLE                                                         | 若CDC_res==1 則進入COMPUTE STATE |
| COMPUTE | mode = 0 , out = in_a + in_b<br>mode = 1 , out = in_a * in_b | 下個cycle無條件進入OUT STATE        |
| OUT     | 將out_valid拉為high一個cycle                                      | 下個cycle無條件進入IDLE STATE       |

#### CDC.sv

| Input Signal | Bit Width | Definition                                                                        |
|--------------|-----------|-----------------------------------------------------------------------------------|
| clk1         | 1         | clk1 domain 14.1ns                                                                |
| clk2         | 1         | clk2 domain 2.5 ns                                                                |
| rst_n        | 1         | Asynchronous active-low reset                                                     |
| in_valid     | 1         | 當此訊號拉起時給in_a和in_b和mode                                                            |
| in_a         | 4         | 在clk1 domain 且 in_valid = 1時,給予一筆資料                                               |
| in_b         | 4         | 在clk1 domain 且 in_valid = 1時,給予一筆資料                                               |
| mode         | 1         | 在clk1 domain 且 in_valid = 1時,給予一筆資料<br>0: out輸出in_a + in_b<br>1: out輸出in_a * in_b |

| <b>Output Signal</b> | Bit Width | Definition                                                                                  |
|----------------------|-----------|---------------------------------------------------------------------------------------------|
| out_valid            | 1         | 在clk2 domain且out_valid = 1時,檢查out out_valid必須為1個cycle,不能多也不能少必須要在100個clk2 cycle內拉起out_valid |
| out                  | 8         | 根據mode輸出out                                                                                 |

#### Spec

- 請使用synchronizer.v完成本次作業
- 所有output必須非同步負準位reset。
- 01\_RTL需要PASS。
- 02\_SYN不能有error跟latches。
- 02\_SYN時間timing slack必須為MET。
- 03\_GATE 需要PASS且不能有timing violation

#### Output & Waveform

negative trigger asynchronous reset



#### 02\_SYN

• 這個error 可以忽略

```
Thank you...

Error: Library Compiler executable path is not set. (PT-063)

PrimeTime (R)

Version P-2019.03-SP5-1 for linux64 - Dec 13, 2019

Copyright (c) 1988 - 2019 Synopsys, Inc.
```

#### Command

- tar -xvf ~dcsta01/Lab10.tar
- Upload
   Upload to E3 with naming rule
   ex: CDC\_dcsxxx.sv
   otherwise it will not be graded
- 上傳如果沒有用synchronizer 會發生的錯誤或是情況 截取波型圖 同樣上傳到E3
   ex:CDC\_dcsxxx.png
- Separate combinational and sequential blocks