## 通訊多媒體核心設計 (Multimedia Communication IP Design)

## 蔡宗漢

(Tsung-Han Tsai) Dept. of E.E., N.C.U.









































































































| Block<br>Type | Flexibility vs.<br>predictability | Design flow               | Represen-<br>tation | Libraries                                           | Process<br>technology | Porta-<br>bility   | Pro-<br>tecting |
|---------------|-----------------------------------|---------------------------|---------------------|-----------------------------------------------------|-----------------------|--------------------|-----------------|
| Soft          | Very flexible,<br>unpredictable   | System<br>design          | Behavioral          | Not applicable                                      | Independent           | Unlimited          | Week            |
|               |                                   | RTL design                | RTL                 |                                                     |                       |                    |                 |
| Firm          | Flexible,<br>predictable          | Floorplaning<br>synthesis | RTL,<br>blocks      | Reference                                           | Generic               | Library<br>mapping | Medium          |
|               |                                   | Placement                 | Netlist             | Footprint,<br>timing model,<br>wiring model         |                       |                    |                 |
| Hard          | Inflexible,very predictable       | Routing,<br>verification  | Polygon<br>data     | Process-<br>specific library<br>and design<br>rules | Fixed                 | Process<br>mapping | Good            |





| Functiona     | of Cores Classified by ality               |
|---------------|--------------------------------------------|
| Core category | Product examples                           |
| Processor:    |                                            |
| RISC          | LSI Logic CW4K, ARM 71DMI, PPC             |
| CISC          | 680x0, x86                                 |
| DSP           | TI TMS320C80, DSP Group Pine               |
| BIST          | MemBIST-IC, PLL BIST, ADC BIST             |
| Encryption    | PkuP, DES                                  |
| Controllers   | USB, PCI, UART                             |
| Multimedia    | JPEG compression, MPEG decoder, DAC        |
| Networking    | ATM SAR, Ethernet                          |
|               | Specialized memories: high speed, low nowe |
































































![](_page_44_Figure_1.jpeg)

![](_page_45_Figure_0.jpeg)

![](_page_45_Picture_1.jpeg)

![](_page_46_Figure_0.jpeg)

![](_page_46_Figure_1.jpeg)

![](_page_47_Figure_0.jpeg)

![](_page_47_Figure_1.jpeg)

![](_page_48_Figure_0.jpeg)

![](_page_48_Picture_1.jpeg)

![](_page_49_Figure_0.jpeg)

![](_page_49_Figure_1.jpeg)

![](_page_50_Figure_0.jpeg)

![](_page_50_Figure_1.jpeg)

![](_page_51_Figure_0.jpeg)

![](_page_51_Figure_1.jpeg)

![](_page_52_Figure_0.jpeg)

![](_page_52_Picture_1.jpeg)

| Verilog-                                                                                                                                                              | Mode                                         |                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------|
| <pre>module example (/+=UTDIRD=/);<br/>input 1;<br/>output 0;<br/>/==UTDIRDIFUT=/<br/>/==UTDIRDIFUT=/<br/>/==UTDIRDIFUT=/1;<br/>alaage<br/>o = 1;<br/>endmodule</pre> | <pre>&gt; module compute (rem.NOOPEGA/</pre> | <pre>Prim invased adjustment (reports)</pre> |
| NCUEE Multimedia Commu                                                                                                                                                | nication IP Design Tsung-Han Tsai            | 107                                          |

| Module Tedium?                                                                                             |                                                                                      |
|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| nodule tedium (i1,i2,o1,o2)                                                                                | Argument list is same as input/output statements.                                    |
| wire interl; Wires needed for our                                                                          | puts<br>or interconnections.                                                         |
| <pre>always @(il or i2 or interl);<br/>ol = il   i2   interl;<br/>subl subl (.il (il).<br/>iii (i2).</pre> | Sensitivity lists.                                                                   |
| .02 (02),<br>.interl (interl));<br>sub2 sub2 (.i1 (i1),                                                    | Named based instantiations<br>mostly replicate input/outputs<br>from the sub module. |
| .interl (interl));<br>endmodule                                                                            |                                                                                      |

![](_page_54_Figure_0.jpeg)

![](_page_54_Figure_1.jpeg)

![](_page_55_Figure_0.jpeg)

![](_page_55_Figure_1.jpeg)

![](_page_56_Figure_0.jpeg)

![](_page_56_Figure_1.jpeg)

![](_page_57_Figure_0.jpeg)

![](_page_57_Figure_1.jpeg)

![](_page_58_Figure_0.jpeg)

![](_page_58_Figure_1.jpeg)

![](_page_59_Figure_0.jpeg)

| Converse connected in verificable <b>DT</b> |             |         |           |  |
|---------------------------------------------|-------------|---------|-----------|--|
| olwaya                                      | alaa        | initial | naramata  |  |
| always                                      | erse        | incut   | parameter |  |
| basign                                      | enu         | inout   | poseuge   |  |
| begin                                       | endcase     | input   | reg       |  |
| case                                        | endfunction | module  | wire      |  |
| casez                                       | endmodule   | negedge |           |  |
| default                                     | function    | or      |           |  |
|                                             | if          | output  |           |  |

![](_page_60_Figure_0.jpeg)

![](_page_60_Figure_1.jpeg)

![](_page_61_Figure_0.jpeg)

![](_page_61_Figure_1.jpeg)

![](_page_62_Figure_0.jpeg)

![](_page_62_Figure_1.jpeg)

![](_page_63_Figure_0.jpeg)

![](_page_63_Figure_1.jpeg)

![](_page_64_Figure_0.jpeg)

![](_page_64_Figure_1.jpeg)

![](_page_65_Figure_0.jpeg)

![](_page_65_Figure_1.jpeg)

![](_page_66_Picture_0.jpeg)

![](_page_66_Figure_1.jpeg)

![](_page_67_Figure_0.jpeg)

![](_page_67_Picture_1.jpeg)

![](_page_68_Figure_0.jpeg)

![](_page_68_Figure_1.jpeg)

![](_page_69_Figure_0.jpeg)

![](_page_69_Picture_1.jpeg)

![](_page_70_Figure_0.jpeg)

![](_page_70_Picture_1.jpeg)

![](_page_71_Figure_0.jpeg)

![](_page_71_Figure_1.jpeg)


































































































































