Design and Implementation of USB SIE IP Core by 邹琼
学校编码：10384                           分类号      密级        





厦  门  大  学 
硕  士  学  位  论  文 
                                            
 
 
USB 接口引擎的软核设计与 FPGA 兑现 
Design and Implementation of USB SIE IP Core 
 
 




专 业  名 称：无线电物理 
论文提交日期：2006 年  月 
论文答辩时间：2006 年  月 
学位授予日期：2006 年  月 
 
答辩委员会主席：             
评    阅    人：             






































                   声明人（签名）： 



































  1、保密（ ），在   年解密后适用本授权书。 




作者签名：      日期：  年 月 日 







































配置性角度出发设计了低速、全速、高速三种可选模式；2、支持 多 31 个可
配置端点；3、采用了可综合、可移植的 RTL（Register Transfer Level，寄存器
传输级）代码设计规则，同时也开发了可综合的验证测试代码；4、完全由硬件


































USB (Universal Serial Bus) is one of the most pervasive bus standards 
nowadays in consumed electronic devices and peripherals. There are few USB 
ICs designed by local companies at present. Most of them are imported from 
those worldwide IC Corporations, like Cypress and NEC etc. So, to design this 
kind of USB controller IC independently, instead of using the similar products 
aboard, would be of a large potential market and profit. 
 
The purpose of this paper is to design a feasible and reusable USB SIE (Serial 
Interface Engine) IP core, based on FPGA. This IP core handles the standard 
USB transactions. And embedded with a MCU it would provide all the USB 
functionalities. So it has the merits of simple architecture and easy redesign. It 
is similar to some special USB SIE ICs, like PDIUSBD12 from Royal Philips 
Electronics. 
 
Through the simulation and verification, the results show that our SIE core can 
replace the same production imported. The innovations in our design are: 1. 
flexible speed mode configuration, low-speed / full-speed / high-speed; 2. up to 
31 endpoints are available when developing special products; 3. applying RTL 
methodology and also developed verification Test Bench source code; 4. 





























目  录 
第一章 绪论................................................................................................1 
1.1 引言...................................................................................................1 
1.2 USB技术发展概况 .............................................................................1 
1.3 USB IP核简述 ....................................................................................3 




2.1 USB总线体系结构 .............................................................................7 
2.1.1 USB拓扑结构............................................................................7 
2.1.2 端点和通道...............................................................................8 
2.2 传输方式及传输事务 .........................................................................9 
2.2.1 传输和事务的概念 ....................................................................9 
2.2.2 传输方式 ................................................................................10 
2.2.3 传输事务 ................................................................................ 11 
2.3 USB通信协议标准 ...........................................................................14 
2.3.1 PID类型和信息包类型.............................................................14 
2.3.2 token包 ...................................................................................15 
2.3.3 SOF包 ....................................................................................16 
2.3.4 data包 .....................................................................................16 
2.3.5 handshake包 ..........................................................................16 
2.3.6 Split 事务包 ............................................................................17 















2.4 数据编解码与位填充 .......................................................................19 




3.1 总体设计要求 ..................................................................................21 
3.2 控制器的整体架构 ...........................................................................22 
3.3 USB SIE接口信号 ............................................................................23 
3.3.1 与收发器模块的接口信号 .......................................................23 
3.3.2 与MCU模块的接口信号 ..........................................................24 
3.3.3 与SSRAM模块的接口信号 .....................................................26 
3.4 控制器数据传输流程 .......................................................................26 
3.5 USB接口引擎架构 ...........................................................................29 
3.6 模块的具体功能...............................................................................30 
3.6.1 打包模块 ................................................................................30 
3.6.2 解包模块 ................................................................................32 
3.6.3 协议引擎模块 .........................................................................33 
3.6.4 DMA 和存储接口模块 .............................................................34 
 
第四章 RTL编程与功能仿真.................................................................36 
4.1 RTL编程优势 ...................................................................................36 
4.2 功能模块的编程实现 .......................................................................37 
4.2.1 信号名定义.............................................................................37 
4.2.2 打包模块的RTL设计 ...............................................................38 
4.2.3 解包模块的RTL设计 ...............................................................40 
4.2.4 协议引擎模块的RTL设计........................................................41 


















4.4.3 IN事务仿真结果 ......................................................................46 
4.5 代码覆盖率测试...............................................................................47 
 
第五章 基于FPGA的逻辑综合及其分析 ..................................... 49 
5.1 兑现器件选择 ..................................................................................49 
5.2 FPGA兑现结果 ................................................................................51 
5.3 讨论.................................................................................................53 
 





























Table of Contents 
Chapter 1 Exordium ...............................................................................1 
1.1 Introduction......................................................................................1 
1.2 A brief history of USB......................................................................1 
1.3 USB IP core summary…..................................................................3 
1.4 The key point of soft IP core...........................................................5 
1.5 Main work of this paper...................................................................6 
 
Chapter 2Principle of Universal Serial Bus ...................................7 
2.1 USB system description .................................................................7 
2.1.1 Bus topology................................................................................7 
2.1.2 Endpoint and Pipe .......................................................................8 
2.2 Data flow types and transactions formats.....................................9 
2.2.1 Transfer and Transaction .............................................................9 
2.2.2 Data flow types ..........................................................................10 
2.2.3 Transaction formats ................................................................... 11 
2.3 Bus Protocol ..................................................................................14 
2.3.1 PID and Packet formats.............................................................14 
2.3.2 Token Packet .............................................................................15 
2.3.3 SOF Packet ...............................................................................16 
2.3.4 Data Packet ...............................................................................16 
2.3.5 Handshake Packet ....................................................................16 
2.3.6 Split Transaction Special Token Packets....................................17 















2.4 Data Encoding/Decoding and Bit Stuffing...................................19 
2.4.1 Non Return to Zero Invert ..........................................................19 
2.4.2 Bit Stuffing .................................................................................20 
 
Chapter 3 Whole design of USB SIE....................................... 21 
3.1 Performance targets ......................................................................21 
3.2 Architecture of USB device controller .........................................22 
3.3 The signals of USB SIE .................................................................23 
3.3.1 Signals of UTM interface ........................................................23 
3.3.2 Signals of MCU interface........................................................24 
3.3.3 Signals of SSRAM interface ...................................................26 
3.4 Data transaction of USB device controller ..................................26 
3.5 Architecture of USB SIE ................................................................29 
3.6 Function designs ...........................................................................30 
3.6.1 Packet Assembler Module .........................................................30 
3.6.2 Packet Disassembler Module ....................................................32 
3.6.3 Packet Engine Module...............................................................33 
3.6.4 Interface Modules ......................................................................34 
 
Chapter 4 RTL coding and functional Verification ................ 36 
4.1 Advantages of RTL coding............................................................36 
4.2 Code achieve..................................................................................37 
4.2.1 Signals statement ......................................................................37 
4.2.2 Packet Assembler coding ..........................................................38 
4.2.3 Packet Disassembler coding .....................................................40 
4.2.4 Packet Engine coding................................................................41 














Degree papers are in the “Xiamen University Electronic Theses and Dissertations Database”. Full
texts are available in the following ways: 
1. If your library is a CALIS member libraries, please log on http://etd.calis.edu.cn/ and submit
requests online, or consult the interlibrary loan department in your library. 
2. For users of non-CALIS member libraries, please mail to etd@xmu.edu.cn for delivery details.
厦
门
大
学
博
硕
士
论
文
摘
要
库
