## VHDL Implementation of USB Transceiver Macro cell Interface with 2.0 Specifications

K. Harikrishna

Assistant Professor, Electronics & Communication Engineering, Christu Jyothi Institute of Technology & Science, Warangal, AP, India

**Abstract:** The Universal Serial Bus(USB) Transceiver Macro cell Interface (UTMI) is a two wire, bidirectional serial bus interface. The USB2.0 specifications define three types of UTMI implementations depends on data transmission rates, those are Low Speed (1.5MHz) only (LS), Full Speed (2.0Hz) only (FS) and High Speed (480MHz)/Full speed (12MHz) (HS). UTMI consists of Transmitting and Receiving sections, in which the Transmitter of the UTMI sends data to different 1SP devices through D+ and D- lines whereas the Receiver gets data on the same lines. This presentation reveals the FPGA implementation of UTMI with HS/FS transmission rate providing with USB 2.0 specifications. Further UTMI has been designed by using VHDL code and simulated, synthesized and programmed to the targeted Spartan2family of FPGA in the Xilinx environment

#### 1. Introduction

The Universal Serial Bus (USB) Transceiver Macrocell Interface (UTMI) is a two wire, bi- directional serial bus interface between USB devices through D+ and D- lines. This is one of the important functional blocks of USB controller, which can transmit are receive data to or from USB devices. There are three functional blocks present in USB controller; those are Serial Interface Engine (SIE), UTMI and Device Specific Logic (DSL). Figure 1 shows the block tagram of UTMI. The parallel data from SIE is taken into the transmit hold register and this data issent to transmit shift register from where the data is converted serially. This serial data is bit stuffed to perform data transitions for clock recovery and NRZI (1) encoding. Then the encoded data is sent on to the serial bus. When the data is received on the serial bus, it is decoded, bit unstuffed and is cent to receive shift register. After the shift register is full, the data is sent to receive hold register.

#### 2. Design Aspects

The present UTMI has been resigned according to the following specifications provided by the USB 2.0 protocol. SYNC and End of racket (EOP) generation by the transmitter. SYNC and EOP detection by the receiver. Receive are reporting. Enabling or disabling the bit stuffer and NRZI encoder depends on the operational mode Suspension of the transceiver by the SIE.Further the UTMI is divided into two important modules which are the Transmitter module and the Receiver module. In the section the design Considerations of these modules have been explained separately and integrated to get top level Transceiver (UTMI) module

#### 2.1 The Transmitter Module

The bock diagram of the UTMI transmitter is shown in Figure2. The transmitter module has been implemented by considering the following specifications. The SYNC pattern "ounno" has to be transmitted immediately after the transmitter is initiated by the SIE. After six consecutive '1's occur in the data stream a zero to be inserted. The data should be encoded using Non Return to Zero Invert on 1 (NRZI -1) encoding technique. The EOP pattern two single ended zeroes(D+ and D- lines are carrying zero for two clock cycles) and a bit one have to be transmitted after each packet or after SIE suspends the transmitter This data will be presented on the parallel interfacewhere it is sampled by the SIE. The intent of the UTMI is to accelerate USB 2.0 peripheral development.



The block diagram of the UTMI neceiver is shown in Figure 3. The receiver module has been implemented by considering the following precedutions. When SYNC pattern is detected that should be intimated to the SIE. If a zero is not detected after six consecutive 'i's an error should be reported to the SIE. When EOP pattern is detected that should be intimated to the SIE.



Figure 3: Block diagram of UTMI Receiver.

The receiver logic facilitates SYNC detection, NRZI decoding, bit un stuffing, serial to parallel conversion of data, receive error reporting and EOP detection.

#### 2.3 The Transceiver Module

The transmitter and the receiver modules are combined together to design the transceiver (UTMI) module. This transceiver met all the USB2.0 specifications considered above. The transceiver logic facilitates the output of the transmitter to feed to the input of the receiver for functional verification. The Transceiver module has been designed with the considerations of individual modules of the transmitter and the receiver Specifications. Further the required Transceiver module logic has been verified with the functional simulation followed by necessary Synthesis and perform Programming to the targeted FPGA Device.

#### 3. Simulaton Results

The individual modules of the UTMI are designed using VHDL as stated above and they are invited within the Xilinx based Model Sim 6.0 environment

#### 3.1 The Transmitter Module

The Figure 4 shows the Simulation results of UTMI transmitter. When TX valid and goes high, encoded SYNC pattern "01010100" is transmitted and the signal txready is asserted. The data "10110100" present on the dataln bus is NRZI encoded and transmitted on to the txdp, txdm lines. The signal txready goes low when the data is sampled by the TX hold register.





The Figure 5 shows the Simulation results of UTMI receiver. When SYNC is detected rxactive is asserted. The data present on rxdp, rxdr lines is decoded, serial to parallel converted and sent to the SIE through data out bus by asserting rxvird signal.



Figure 5 The Receiver Module

#### 3.3 The Transceiver Module

The Figure 6 shows the Simulation results of the Transceiver module which transmits and receives data. When txvalid goes high, SYNC is transmitted. The data "oooooooo" present on the data\_bustx is NRZI encoded and transmitted on to the dp, dm lines.

When SYNC is detected by the receiver rxactive is asserted by the UTMI. The data present on the dp, dm lines is NRZI decoded and sent to the SIE through rxdata\_bus by asserting rxvalid signal. Rxdata\_bus contains "oooooooo" since the transmitted data is fed back to the receiver.



Figure 6: Transceiver (UTMI) Module.

#### 4. FPGA Implementation

soft.res.ir The top order module, UTMI is synthesized within the Xilinx 8.1 ISE software tool and it is programmed to the targeted SPARTAN 2 family of FPGA Device. The various levels ND ementation such as Synthesis h s been explained and visualized in report, RTL View, Place and Route Report and Device Programmin the following sub sections

### 4.2 RTL View

This section gives the visualization of Resister Transiston Logic (RTL) views in the form of schematic and Netlist diagrams which are shown in Figure 7 and Figure 8 respectively. Figure 7 which gives RTL schematic diagram reveals the pin diagram of Top order include with the required specified notes whereas Figure 8 reveals the Gate level logic diagram of Top order module with the required input and output ports(Netlist view).





Figure 7: RTL Schematic diagram



Figure 8: RTL netlist view

#### **4.3 Place and Route Report**

This section concentrates on target FPGA device utilization summary which reveals the information required for proper layout at the level of manufacturing in the form of Place and Route report. Further it gives the timing synchronization of CPU with the REAL time environment.

#### **4.4 Device Programming**

After successful process of synthesis the Target device xc2s15 of Spartan2 is connected to the sy through printer port. The pin assignment is specified in the User Constraint File (UCF). The further verification is carried out by using a pattern generator.

#### 5. Conclusion

The individual modules of UTMI have been designed using VHDL and verified functionally ith the Model Sim 6.o.The UTMI Transmitter is capable of converting parallel data into seria performing bit stuffing and NRZI encoding. The UTMI Receiver is capable of performing NRZI dec bitunstuffing and converting serial bits into parallel data.

The functional simulation has been successfully carried out. The design has been synthesized using FPGA technology from Xilinx. This design is targeted to the device family spit 12, device xc2s15, and package cs144 and speed grade 6. The device belongs to the Vertex-E group of FPGAs from Xilinx. The UTMI is ins. The three options allow a single designed to support HS/FS, FS Only and LS Only UTM implement SIE implementation to be used with any speed USB transceiver A vendor can choose the transceiver performance that best meets their needs.

# 6. Refere

- Charles H Roth "Digital system using VN ".2<sup>nd</sup> edition, Thomson publication 1.
- 2. Jayaram Bhasker "A VHDL Primer" edition, Prentice Hall publications 2nd
- 3. Stephen Brown, Zvonko Vranesic, Fundamentals Digital logic with VHDL design". 2nd edition, uly 2004 McGraw-Hill, Hardcover, Published
- 4. Zainalabedin Navabi "Vhd Anarys and Modeling of Digital Systems" 2nd edition, McGraw-Hill, Hardcover, Published Januar, 1998
- William Stallings, "Data and Computer Communications", McGraw-Hill Publications. 5.
- Andrew S. Tannenbaug, "Computer Networks", Pearson publications. 6.
- Z. Kohavi, "Switchin, and finite Automata Theory", Tata McGraw-Hill Publications 7.
- N. N. Biswas, "Louic Resign theory", Printice Hall of India Publications. 8.
- Morris Mano, "Apital design", Tata McGraw-Hill Publications. Lala, "Digital system Design Using PLDs", BSP Publications. 9.
- 10. Lala. "E

