

# Mentor Graphics USB 2.0 Reference Design for Home Networking Solutions

This leaflet describes a USB 2.0 Transfer System board, which provides a reference design for home networking applications that use the USB 2.0 Universal Serial Bus.

The board comprises a USB 2.0-compliant function controller, an 8051-compatible microcontroller and a DMA controller implemented in two Xilinx Spartan<sup>®</sup>-II FPGAs, together with a Kawasaki USB 2.0 transceiver. It provides an interface for high-speed data transfer between a PC and a SCSI disk drive.

The Mentor Graphics USB 2.0 Transfer System represents a complete solution for low cost, high performance data connection.

#### USB 2.0 Transfer Architecture



Mentor Graphics USB 2.0 Transfer System Board

#### Key features

- Low-cost solution
- High speed operation, up to 480Mbits/sec
- USB 2.0 function controller
  - □ Mentor Graphics MUSBHSFC core
  - □ Complies with industry standards
  - □ 16-bit VCI interface to microcontroller
  - □ 16-bit UTMI interface to USB transceiver
  - 2 Bulk Endpoints with 1024byte synchronous FIFOs
  - Firmware included
- 8051 microcontroller
  - □ Mentor Graphics M8051 E-Warp core
  - □ 2 clocks per cycle, running at 16 MHz
  - □ Complies with industry standards
  - □ 16-bit asynchronous interface to SCSI bus
  - □ 64K bytes external program memory (<10K used)
  - □ 64K bytes external data memory
  - □ On-Chip debug with JTAG interface
  - □ Source-level debug (in 'C')
- FPGA Implementation
  - □ Xilinx Spartan®-II FPGA
  - □ Two XC2S200-6PQ208 devices
  - □ Density up to 200,000 system gates
  - □ Block RAM up to 56K bit
  - □ Reprogrammable



SCSI Disk Drive

### **System Overview**

The figure below shows the board block diagram.

The principal constituents of the board are a USB 2.0 function controller and a 8051 microcontroller. These two devices are provided by reusable and configurable soft cores from the Mentor Graphics Inventra<sup>TM</sup> IP catalog, implemented in Xilinx Spartan®-II FPGAs. The USB 2.0 function controller is provided by the Inventra<sup>TM</sup> MUSBHSFC soft core; the 8051 microcontroller is provided by the Inventra<sup>TM</sup> M8051 E-Warp soft core.

One FPGA contains the MUSBHSFC core, together with the RAM needed to provide FIFOs for the function controller's endpoints. The MUSBHSFC is configured to support two Bulk endpoints in addition to the control Endpoint 0. The Endpoint FIFOs use eight of the memory blocks available within the FPGA.

The other FPGA contains the M8051 E-Warp core together with a DMA controller. The data and program memory for the microcontroller is provided by two external memory chips, one Flash and one SRAM, plus 4Kbytes of internal memory.

The other main component of the board is a USB 2.0 transceiver chip from Kawasaki, the KL5KUSB200, which provides the connection between the USB serial bus and the UTMI bus for both high-speed and full-speed operation.

The MUSBHSFC uses an internal 30 MHz clock and the data transfers are executed on 16-bit buses. The bus on the USB 2.0 transceiver side is UTMI compliant; the bus on the microcontroller side is VCI compliant.

### **USB Device Software**

The software controlling the USB device implements Universal Serial Bus Mass Storage Class, Bulk-Only Transport (Specification Revision 1.0).

The device code occupies less than 10K of program memory, and uses wide SCSI data transfers. It also uses a DMA controller to transfer data directly between the SCSI interface and the VCI interface to help sustain the highbandwidth data transfers supported by USB 2.0.

### **Demonstration Overview**

The USB device is demonstrated using a PC, loaded with Windows 2000 Professional, and including an Intel PDK USB 2.0 Host controller PCI card. The SCSI interface of the demo card is interfaced to a commercially-available SCSI disk drive.

The connection between PC and the demo board is made using a standard USB-compliant cable. Connection between the SCSI interface and the disk drive is via a standard SCSI cable.



#### USB 2.0 Transfer System Block Diagram

### **The USB 2.0 Function Controller**

The Mentor Graphics Inventra<sup>™</sup> MUSBHSFC The MUSBHSFC core provides a USB function controller that complies with the USB 2.0 specification for high/full-speed (480/12 Mbits/s) functions.

The core is user-configurable for up to 15 IN endpoints and up to 15 OUT endpoints in addition to Endpoint 0. These additional endpoints can be individually programmed for Bulk/Interrupt or Isochronous transfers.

Each endpoint requires a FIFO to be associated with it. The MUSBHSFC has a RAM interface for connecting to a single block of synchronous single-port RAM which is used for all the endpoint FIFOs. (The RAM block itself needs to be added by the user.)

The size of the FIFO for Endpoint 0 is fixed at 64 bytes and can buffer 1 packet. The MUSBHSFC's FIFO interface is configurable with regard to the other endpoint FIFOs which may be from 8 to 8192 bytes in size and can buffer either 1 or 2 packets. Separate

| 🗙 MUSBHSFC Configuration                                                                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Inventra Graphics                                                                                                                                                                       |
| MUSBHSFC High-Speed USB Function Controller Configuration                                                                                                                               |
| USB Transceiver Macrocell Interface                                                                                                                                                     |
| Data width: 🔶 8 💠 16                                                                                                                                                                    |
| MCU Interface                                                                                                                                                                           |
| Data width: 🔶 16 💠 32                                                                                                                                                                   |
| IN Endpoints                                                                                                                                                                            |
| Number of IN endpoints (in addition to endpoint 0):                                                                                                                                     |
| ◊ 0 ◊ 1 ◊ 2 ♦ 3 ◊ 4 ◊ 5 ◊ 6 ◊ 7 ◊ 8 ◊ 9 ◊ 10 ◊ 11 ◊ 12 ◊ 13 ◊ 14 ◊ 15                                                                                                                   |
| Enable support for high bandwidth IN ISO endpoints: 💷                                                                                                                                   |
| Use early DMA deassert timing for IN endpoints 🦼                                                                                                                                        |
| IN Endpoint 1 📕 🕨                                                                                                                                                                       |
| FIFO Size (bytes): * 8                                                                                                                                                                  |
| Share FIFO with OUT endpoint 1: 🔟                                                                                                                                                       |
| OUT Endpoints                                                                                                                                                                           |
| Number of OUT endpoints (in addition to endpoint 0):                                                                                                                                    |
| $\diamond 0 \diamond 1 \diamond 2 \diamond 3 \diamond 4 \diamond 5 \diamond 6 \diamond 7 \diamond 8 \diamond 9 \diamond 10 \diamond 11 \diamond 12 \diamond 13 \diamond 14 \diamond 15$ |
| Enable support for high bandwidth OUT ISO endpoints: 🔳                                                                                                                                  |
| Use early DMA deassert timing for OUT endpoints 🔲                                                                                                                                       |
| OUT Endpoint 1 📕 🕨                                                                                                                                                                      |
| FIFO Size (bytes): * 8                                                                                                                                                                  |
| Estimated gate count: 21500                                                                                                                                                             |
| OK Cancel                                                                                                                                                                               |

FIFOs may be associated with each endpoint: alternatively an IN endpoint and the OUT endpoint with the same Endpoint number can be configured to use the same FIFO, for example to reduce the size of RAM block needed.

The MUSBHSFC provides a USB 2.0 Transceiver Macrocell Interface (UTMI Specification version 1.04) to connect to an 8/16-bit high/full-speed transceiver. The design also features a 16/32-bit VCI-compatible interface to connect to a processor bus. Access to the FIFOs and the internal control/status registers is via the 16/32-bit VCI-compatible interface. The device also offers DMA access to the Endpoint FIFOs.

The MUSBHSFC provides all the USB packet encoding, decoding, checking and handshaking – interrupting the CPU only when endpoint data has been successfully transferred.

A graphical user interface script is provided for configuring the core to the user's requirements.

## 8051-Compatible Microcontroller

The Mentor Graphics Inventra<sup>TM</sup> M8051 E-Warp The M8051 E-Warp offers a complete, high performance 8051 core and development kit, based around Mentor Graphics' highly successful M8051 Warp implementation of this popular 8-bit microcontroller.

The M8051 E-Warp is the only 8051-compatible soft core to surpass 50Mips performance reliably. It is also the lowest power core available today. Power control mechanisms are built into the state machine, CPU and peripherals.

The M8051 E-Warp is also 100% legacy compatible, preserving the user's investment in industry-standard 8051 tool suites. It does not use instruction set extensions and exotic clocking mechanisms that require expert hand-editing of design tools.

The M8051 E-Warp can be configured to suit a wide range of user requirements. For example, it can be configured to work with either synchronous or asynchronous memory; it can have separate Program and External Data Memory interfaces or a single multiplexed interface; and it can offer either one, two or eight data pointers and two or four levels of interrupt priority. Wait state support is provided for slow memory devices.

#### **Debug Environment**

The M8051 E-Warp offers a Debug Mode together with an On-Chip Instrumentation (OCI<sup>TM</sup>) interface. This interface offers a set of dedicated Debug signals, which may be used by external debug hardware to provide a range of debugging facilities.

These facilities are intended to be used in conjunction with the ISA-WARP 8051 In-Target System Analyzer from First Silicon Solutions (FS2).

The OCI<sup>TM</sup> interface, working in conjunction with in-circuit emulation tools, enables in-situ, at-speed validation of the board application program. The ISA-WARP 8051

M8051 E-Warp Debugger Kit

In-Target Analyzer provides a PC-based validation platform for the USB2.0 board.

The debug interface provides a range of debugging features from basic stop/start or single-step execution and breakpoint support to reconstruction of execution history and capture of data memory, program memory and SFR accesses.

A graphical, source level debugger program supplied with the ISA-WARP 8051 provides an intuitive, easy to use interface. The debugger runs on a PC over high-speed parallel port.

The ISA-WARP 8051 is contained in a compact chassis that connects to the board using a standard 20 pin AMP debug connector. It requires access to just 6 of the M8051 E-Warp's pins.

© 2001 Mentor Graphics Corporation, All Rights Reserved. <sup>™</sup>Mentor Graphics and Inventra are trademarks of Mentor Graphics Corporation. All other trademarks are the property of their respective owners.

Corporate Headquarters Mentor Graphics Corporation 8005 S.W. Boeckman Road Wilsonville, OR 97070 USA Phone: 503-685-7000 Silicon Valley Headquarters Mentor Graphics Corporation 1001 Ridder Park Drive San Jose, California 95131 USA Phone: 408-486-1500 Fax: 408-436-1501 European Headquarters Mentor Graphics Corporation Immeuble le Pasteur 13/15, rue Jeanne Braconnier 92360 Meudon La Foret France Phone: 33-1-40-94-74-74 Fax: 33-1-46-01-91-73 Pacific Rim Headquarters Mentor Graphics (Taiwan) Room 1603, 16F, International Trade Building No.333, Section 1, Keelung Road Taipei, Taiwan, ROC Phone: 886-2-27576020 Fax: 886-2-2756027 Japan Headquarters Mentor Graphics Japan Co., Ltd. Gotenyama Hills 7-35, Kita-Shinagawa 4-chome Shinagawa-Ku, Tokyo 140 Japan Phone: 81-3-5488-3030 Fax: 81-3-5488-3031



01/01 MB-40113.001-PO