

# ASIC FULL FLOW

## 1) Preparation

- Tạo cây thư mục (đặt tên bất kỳ) bằng lệnh: mkdir -p counter/rtl chặng hạn

## 2) RTL Design & Verification

- Truy cập thư mục tổng vừa tạo
- Tạo đường dẫn “rtl”: mkdir rtl
- Truy cập đường dẫn đó và add 2 files: rtl design + testbench
- Code mẫu:

- o rtl

```
V counter.v
1 `timescale 1ns / 1ps
2 ///////////////////////////////////////////////////////////////////
3 module counter (
4     input  wire      clk,
5     input  wire      rst_n,
6     input  wire      i_enable_w,
7     input  wire      i_updown_w,    // 1: up, 0: down
8     output reg [7:0] o_count_r   // 0 -> 255
9 );
10    reg   [7:0] count_next_r;
11
12    wire [7:0] count_up_1_w;
13    assign   count_up_1_w = o_count_r + 8'd1;
14
15    wire [7:0] count_down_1_w;
16    assign   count_down_1_w = o_count_r - 8'd1;
17
18    //Combinational logic to determine next count value
19    always @(*) begin
20        if (i_enable_w)
21            if (i_updown_w) begin
22                count_next_r = count_up_1_w;
23            end else begin
24                count_next_r = count_down_1_w;
25            end
26        end else begin
27            count_next_r = o_count_r;
28        end
29    end
30
31    //Sequential logic to update count value on clock edge
32    always @(posedge clk or negedge rst_n) begin
33        if (!rst_n) begin
34            o_count_r <= 8'd0;
35        end else begin
36            o_count_r <= count_next_r;
37        end
38    end
39 endmodule
```

- o testbench

```

V tb_counter.v
 1 `timescale 1ns/1ps
 2
 3 module tb_counter;
 4
 5   reg clk;
 6   reg rst_n;
 7   reg i_enable_w;
 8   reg i_updown_w;
 9
10  // DUT output
11  wire [7:0] o_count_r;
12
13  // Instantiate DUT
14  counter dut (
15    .clk      (clk),
16    .rst_n   (rst_n),
17    .i_enable_w (i_enable_w),
18    .i_updown_w (i_updown_w),
19    .o_count_r (o_count_r)
20  );
21
22  // Clock generation: 10ns period (100 MHz)
23  initial begin
24    clk = 0;
25    forever #5 clk = ~clk;
26  end
27
28  // Stimulus
29  initial begin
30
31    // Initial state
32    rst_n = 0;
33    i_enable_w = 0;
34    i_updown_w = 1;
35
36    // Hold reset
37    #20;
38    rst_n = 1;
39
40    #10 i_enable_w = 1;
41    i_updown_w = 1; // UP
42    #100;
43
44    i_updown_w = 0; // DOWN
45    #100;
46
47    // Disable counter
48    i_enable_w = 0;
49    #50;
50
51    rst_n = 0;
52    #20;
53    rst_n = 1;
54
55    i_enable_w = 1;
56    i_updown_w = 1;
57    #100;
58
59    $finish;
60  end
61
62 endmodule

```

- Về thư mục tổng, tạo đường dẫn “sim”: mkdir sim
- Truy cập đường dẫn “sim” vừa tạo, tạo đường dẫn con “pre\_syn”
- Truy cập đường dẫn “pre\_syn”
- Dùng lệnh ‘vcs -debug +v2k ../../rtl/\*.v để check syntax 2 files verilog trong rtl
- Sau đó bật DVE bằng lệnh ‘./simv -gui’ để simulate xem waveform
- Khi vào gui, chuột phải cửa sổ nhỏ bên trái có tên “tb\_...(tùy theo tên testbench của ae)” > Add to wave > New waveview – Nhấn F5 trên bàn phím > Xem waveform xong > Tắt DVE
- Dùng pwd để thu mục đang đứng hiện tại
- Dùng cd ../../ để về thư mục cha counter
- Tạo đường dẫn “syn\_check”: mkdir syn\_check
- Truy cập syn\_check

- Chạy lệnh ‘leda’ để bắt Synopsys Leda – đây là tool check syntax nâng cao, cũng như xem code có synthesizable, ASIC friendly hay không. Ví dụ: inferred latch, sensitivity list có list đủ chưa và còn nâng cao ác hơn nữa ae
- Sau khi vào leda, cửa sổ project sẽ mở lên
- Chọn New project > OK
- Đặt đường dẫn cho Project name là “/home/ltk/counter/syn\_check/counter.pro” > Next
- Tại cửa sổ HDL, trong Verilog chọn Version 2001 > Next > Next lần 2
- Tại cửa sổ Source Files, xuống ô Files chọn đường dẫn rtl chứa file rtl design > Next > Finish
- Sau khi bấm Finish, Leda sẽ bắt đầu chạy và out ra cửa sổ Specify Design Information, kéo chân input clk vào clk tích cực cạnh lên thì để rising, rst\_n của anh để mức thấp thì để Low level > OK
- Exit qua Synthesis

### 3) Synthesis

- Về thư mục gốc counter, tạo đường dẫn “syn” bằng mkdir syn
- Truy cập syn
- Để mở Design Compiler, sử dụng lệnh ‘dc\_shell -gui’
- Design Compiler mở, vào File > Setup > Add các thư viện tương ứng dưới đây
- Search path:
  - /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib
- Link library:
  - /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_max.db
  - /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_min.db
  - /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_typ.db
  - /home/eda/synopsys/syn\_vD-2010.03-SP4/libraries/syn/dw.foundation.sldb
- Target library:
  - /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_max.db
  - /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_min.db
  - /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_typ.db
- Symbol library:
  - /home/eda/synopsys/syn\_vD-2010.03-SP4/libraries/syn/generic.sdb
- Synthetic library:
  - /home/eda/synopsys/syn\_vD-2010.03-SP4/libraries/syn/dw.foundation.sldb
- Sau đó OK
- Dùng command ‘set\_svf counter.svf’: để ghi lại mọi tối ưu trong quá trình synthesis vô file svf để dùng cho LEC – Formality Checking sau này
- File > Read.. > trả lời file RTL design trong folder rtl > OK
- File > Analyze > Add > file RTL design trong folder rtl > Format: Verilog HDL > Tick Create Library nếu kh exist > OK
- File > Elaborate > Design: chọn file top module nếu thiết kế có nhiều hierarchy > Tick Reanalyze... > OK
- Design > Check Design > OK (nhớ theo dõi console log)

- Bấm schematic Button trên thanh công cụ để xem mạch – lúc này mạch chưa chạy tối ưu tổng hợp nếu nhìn có vẻ rất phức tạp



- Bây giờ khi đã thấy được mạch bằng schematic > Chuột phải vô chân clock của mạch > Attributes trên tool > Specify Clock.. > Period 20ns để test (nếu slack dương mạnh thì giảm period để mạch chạy được Fmax cao nhất có thể) > Rising 0 Falling 10 > Tick Don't touch network + Tick Fix hold > OK – Nay là chúng ta khai báo tần số đầu vào cho mạch á
- Tiếp theo, chọn tất cả chân input (không phải chân clock) cùng lúc ví dụ: reset, enable, up\_down chẳng hạn > Attributes > Operating Environment > Input Delay > Max rise 2 Min rise 1 > Tick add delay > OK
- Chọn chân output > Attributes > Operating Environment > Output Delay > Max rise 2 Min rise 1 > Tick add delay > OK
- Vào Attributes > Operating Environment > Wire Load > Kéo lên đầu chọn cái đầu tiên > OK
- Vào Attributes > Operating Environment > Operating Conditions > Library: chọn typ Condition TYPICAL > OK
- Vào Attributes > Optimization Constraints > Design Constraints > Max area: 1000 > OK
- Design > Compile Design > Để setting Default > OK (Tuy nhiên anh không khuyến khích mấy đứa sử dụng Compile thường này mà hãy xài thẳng Compile Ultra và bỏ qua thẳng này)
- Sau đó mấy đứa lại xem schematic lúc này các cổng đã được tối ưu
- Chạy thẳng Compile Ultra: Design > Compile Ultra > OK (có thể tìm hiểu thêm về setting của nó)
- Check timing report: Timing > Report Timing Path > kiểm tra Path type: full Delay type: max (setup checking report) hoặc để min (hold checking report) > OK
- Mấy đứa có thể check report về constraints về resource, power bằng cách vào Design > Report .....
- Sau khi xong hết sẽ xuất ra file : File > Save as > nhớ check là đã trong thư mục syn – lưu lại tên file là “netlist.v” – đây là netlist mà synthesis xuất ra cho tụi mình để xài cho các stage tiếp theo – tương tự cho counter.ddc đây là file sẽ lưu netlist, constraints, attributes mà mình đã làm
- Dùng lệnh ‘write\_sdf counter.sdf’ để lưu lại các delay cơ bản
- Dùng lệnh ‘write\_sdc counter.sdc’ để lưu các timing và non timing constraint của mạch sau synthesis

#### 4) Formality Checking – Logic Equivalent Checking

- Make sure chúng ta đang về thư mục counter
- Tạo đường dẫn “formal” bằng mkdir formal
- cd formal
- Dùng lệnh fm\_shell -gui để bật giao diện tool check formal
- Ở 0.Guidance, chọn Guidance > Chọn đường dẫn về thư mục syn – chọn file svf > OK > Load Files
- Qua 1. Reference, 1. Read Design Files – đây là mình sẽ load golden netlist tức là netlist từ rtl: Chọn Verilog > Về đường dẫn rtl chọn file counter.v > OK > Load Files

- Qua mục 3. Set Top design của 1. Reference: Chọn counter > Set Top
- Qua mục tổng 2. Implementation – đây là nơi mình sẽ load file netlist sau synthesis vào: Chọn Verilog > Về đường dẫn syn chọn file netlist.v > OK > Load Files
- Qua mục 2. Read DB: Chọn DBs > vào đường dẫn sau /home/ltk/ASIC\_LIB/Lib/syn\_lib/synlib – Ctrl + A sau đó load tất cả files DB trong đó vào > Load Files
- Qua mục 3. Set top design của 2. Implementation: chọn file counter\_1 để Set Top
- Qua mục tổng 4. Match: Run Matching > 0 Unmatching Compare Points thì lumen tiền
- Qua mục tổng 5. Verify: Run Verify: check console thấy passing hết total thì lumen tiền

## 5) Post Synthesis – STA

- Ở terminal, về thư mục counter, mkdir timing
- cd timing
- chạy pt\_shell để cho tool chạy bằng tcl command
- Trong terminal: chạy lần lượt các lệnh sau
  - o set lib\_path "/home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib";
  - o set ADDITIONAL\_SEARCH\_PATH "\$lib\_path";
  - o set TARGET\_LIBRARY\_FILES "saed90nm\_typ.db";
  - o set\_app\_var search\_path "\$search\_path \$ADDITIONAL\_SEARCH\_PATH";
  - o set\_app\_var target\_library \$TARGET\_LIBRARY\_FILES;
  - o set\_app\_var link\_library "\* \$target\_library";
  - o read\_ddc /home/ltk/counter/syn/counter.ddc
  - o read\_sdc /home/ltk/counter/syn/counter.sdc
- Sau đó dùng lệnh 'start\_gui' để mở giao diện tool ở dạng cửa sổ
- Vào Timing trên toolbar > Report Timing > OK (check report)

## 6) Post Synthesis – Simulation

- Truy cập thư mục sim của counter
- mkdir post\_syn > cd post\_syn
- Copy file netlist, sdf từ thư mục syn vào post\_syn bằng lệnh:
  - o cp -r ../../syn/netlist.v ./
  - o cp -r ../../syn/counter.sdf ./
- Copy 90nm model vào post\_syn bằng lệnh:
  - o cp -r ../../../../ASIC\_LIB/Lib/syn\_lib/model/saed90nm.v ./
- Copy file testbench từ rtl vào post\_syn:
  - o cp -r ../../rtl/tb\_counter.v ./
- Dùng lệnh 'gedit netlist.v &' để add thêm `timescale 1ns/1ps rồi save lại. **Chú ý tên top module counter trong file này: counter\_1**
- 'gedit tb\_counter.v &' để chỉnh tên instance thành **counter\_1**. Lưu ý chỉ chỉnh ở bước này

```
// Instantiate DUT
counter_1 dut (
    .clk      (clk),
    .rst_n    (rst_n),
    .i_enable_w (i_enable_w),
    .i_updown_w (i_updown_w),
    .o_count_r  (o_count_r)
);
```

- Dùng lệnh ‘vlogan -debug +v2k \*.v’ để phân tích kiểm tra cú pháp của file verilog trong post\_syn
- Dùng lệnh ‘vcs -debug tb\_counter - sdf typ:counter\_1: counter.sdf -l comp.log’ để chuẩn bị môi trường, kết nối các module cho việc mô phỏng
- Dùng lệnh ‘./simv -gui’ để bật tool DVE: Khi vào gui, chuột phải cửa sổ nhỏ bên trái có tên “tb\_(tùy theo tên testbench của ae)” > Add to wave > New waveview – Nhấn F5 trên bàn phím > Xem waveform xong > Tắt DVE

## 7) Physical Design – Layout

- Về terminal, trong thư mục counter, mkdir layout > cd layout
- mkdir lib
- ‘icc\_shell -gui’ để bật IC Compiler
- a) Data setup
  - Vào File trên tool bar > Setup > Application Setup:
  - Search path:
    - o /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib
  - Link library:
    - o /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_max.db
    - o /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_min.db
    - o /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_typ.db
    - /home/eda/synopsys/syn\_vD-2010.03-SP4/libraries/syn/dw.foundation.sldb
  - Target library:
    - o /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_max.db
    - o /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_min.db
    - o /home/ltk/ASIC\_LIB/Lib/syn\_lib/syn\_lib/saed90nm\_typ.db
  - Symbol library:
    - o /home/eda/synopsys/syn\_vD-2010.03-SP4/libraries/syn/generic.sdb
  - Synthetic library:
    - o /home/eda/synopsys/syn\_vD-2010.03-SP4/libraries/syn/dw.foundation.sldb
  - OK
- File > Create Library > Ở new library path chọn thư mục lib trong layout vừa tạo ở trên > new library name: my\_lib
- Technology file: /home/ltk/ASIC\_LIB/Lib/process/astro/tech/astroTechFile.tf
- Tick Input reference libraries > Add :
  - o /home/ltk/ASIC\_LIB/Lib/process/astro/fram/saed90nm\_fr > OK
- Tick Open library > OK
- File > Import > Read DDC > Add > Chọn counter.ddc từ thư mục syn > OK
- File > Import > Read SDC > Input file name: Chọn counter.sdc từ thư mục syn > OK
- Windows > New Layout Window
- Trong Layout Window, File > Set TLU+:
  - o Max TLU+ file:  
/home/ltk/ASIC\_LIB/Lib/process/star\_rcxt/tluplus/saed90nm\_1p9m\_1t\_Cmax.tluplus
  - o Min TLU+ file:  
/home/ltk/ASIC\_LIB/Lib/process/star\_rcxt/tluplus/saed90nm\_1p9m\_1t\_Cmin.tluplus
  - o Layer name mapping file between technology library and ITF file:  
/home/ltk/ASIC\_LIB/Lib/process/astro/tech/tech2itf.map

- OK
- Vô console của tool: 'check\_library'
- 'check\_tlu\_plus\_files' trong console
- 'check\_timing' trong console
- 'report\_timing\_requirements' trong console
- 'report\_disable\_timing' trong console
- 'report\_case\_analysis' trong console
- 'report\_clock' trong console
- 'report\_clock -skew' trong console
- 'remove\_ideal\_network [get\_ports]' trong console
- 'save\_mw\_cel -as data\_setup' trong console

**b) Floorplan**

- Vào layout window, Floorplan > Initialize Floorplan > Core to Left, Right, Top Bottom set là 5 hết > OK
- Preroute > Derive PG Connection > Tick Manual connection > Power net: VDD, Ground net: VSS, Power pin: VDD, Ground pin: VSS > Create port: Tick All > OK
- Preroute > Create Rings > Net: VDD > Như hình dưới > OK



- Preroute > Create Rings > Net: VSS > Như hình dưới > OK



- Preroute > Create Power Straps > Nets: VDD > Như hình dưới 0.140 > OK



- Preroute > Create Power Straps > Nets: VSS > Như hình dưới 0.140 > OK



- Để save 'save\_mw\_cel -as floorplan'

### c) Placement

- Placement > Core Placement and Optimization > Tick Effort: High, Power Optimization, Minimize Congestion > OK



- Lúc này có thể standard cell đã được move vào bên trong core area
- Chạy globalroute để check overflow bằng lệnh:

  - o report\_congestion -grc\_based -by\_layer -routing\_stage global

- Save design tại stage ' save\_mw\_cel -as placement'

### d) Clock Tree Synthesis – CTS (route metal đường clock)

- Clock > Core CTS and Optimization > Tick fix hold time violation for all clocks > OK



- Có thể quan sát trên layout lúc này đường clock signal đã được route metal
- 'save\_mw\_cel -as cts'

### e) Routing (Route metal tất cả đường signal)

- Route > Core Routing and Optimization > Effort: High Tick Perform power optimization > OK
- 'save\_mw\_cel -as routing'
- Route > Extract RC > OK mục đích để có thông tin chính xác của metal net delay cho giai đoạn STA Signoff
- Trong ICC console: icc\_shell> 'write\_verilog icc.v'
- 'write\_format ddc -hierarchy -modified -output icc.dcc'
- 'write\_sdc icc.sdc'
- 'write\_sdf icc.sdf'