## USB/FireWire Simulation

- The goal of this simulation is to write a VHDL model for a system that is somewhat similar in nature to the new serial standards USB (Universal Serial Bus) and IEEE Firewire
- Simulation aspects
  - Totally event driven no global clock
  - Communication is bidirectional, half-duplex over a single wire
  - $-\;$  Data type is a resolved data type using a record structure
  - Network structure is a tree structure that consists of a root node, hubs, and endpoints

BR

1

2

6/26/01

6/26/01

### Universal Serial Bus

- Universal Serial Bus is a new synchronous serial protocol for low to medium speed data transmission
- Full speed signaling 12 Mbs
- Low Speed signaling 1.5 Mbs
- Intended devices are keyboards, mice, joysticks, speakers; other low to medium speed IO devices

BR

#### PERFORMANCE APPLICATIONS ATTRIBUTES Keyboard, Mouse Stylus Game peripherals Virtual Reality peripherals Monitor Configuration Lower cost Hot plug-unplug Ease of use LOW SPEED Interactive Devices Multiple peripherals •10-100 Kb/s Low cost Ease of use Guaranteed latency Guaranteed Bandwidth MEDIUM SPEED ISDN PBX POTS Phone, Audio, Compressed Video Audio 500Kb/s - 10Mbp/s Dynamic Attach- Detach Multiple devices HIGH SPEED High Bandwidth Guaranteed latency Ease of use Video Disk •Video, Disk •25-500 Mb/s

Figure 3-1. Application Space Taxonomy























| Bus State                       |           | Signaling Levels                                               |                            |     |             |         |  |  |
|---------------------------------|-----------|----------------------------------------------------------------|----------------------------|-----|-------------|---------|--|--|
|                                 | From      | From Originating Driver                                        |                            |     | At Receiver |         |  |  |
| Differential "1"                | (D+) - (D | (D+) - (D-) $>~200$ mV and D+ or D- $>$ $V_{_{\rm SE}}$ (min.) |                            |     |             |         |  |  |
| Differential "0"                | (D+) - (D | (D+) - (D-) < -200 mV and D+ or D- > $V_{\rm sc}$ (min.)       |                            |     |             |         |  |  |
| Input Levels:                   | ·         |                                                                |                            |     |             | т.<br>Т |  |  |
| Differential Input Sensitivity  |           | VDI                                                            | (D+)-(D-) , and Figure 7-4 | 0.2 |             | v       |  |  |
| Differential Common Mode Range  |           | VCM                                                            | Includes VDI range         | 0.8 | 2.5         | V       |  |  |
| Single Ended Receiver Threshold |           | VSE                                                            |                            | 0.8 | 2.0         | V       |  |  |
| Output Levels:                  |           |                                                                |                            |     |             |         |  |  |
| Static Output Low               |           | VOL                                                            | RL of 1.5 kΩ to 3.6 V      |     | 0.3         | V       |  |  |
| Static Output High              |           | Voн                                                            | RL of 15 kΩ to GND         | 2.8 | 3.6         | V       |  |  |
| Vse = Voltag                    | ge Single | e Ende                                                         | d threshold                |     |             |         |  |  |
| 6/26/01                         |           |                                                                | BR                         |     |             |         |  |  |



















| Data J State:            |                                                                                                                |                                                                                   |  |
|--------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
| Low Speed                | Differential "0"                                                                                               |                                                                                   |  |
| Full Speed               | Differential "1"                                                                                               | Differential "1"                                                                  |  |
| Data K State:            |                                                                                                                |                                                                                   |  |
| Low Speed                | Differential "1"                                                                                               |                                                                                   |  |
| Full Speed               | Differential "0"                                                                                               |                                                                                   |  |
| Idle State:              |                                                                                                                |                                                                                   |  |
| Low Speed                | Differential "0" and D- > $V_{\scriptscriptstyle SE}$ (max.) and D+ < $V_{\scriptscriptstyle SE}$ (min.)       |                                                                                   |  |
| Full Speed               | Differential "1" and D+ > $V_{\rm\scriptscriptstyle SE}$ (max.) and D- < $V_{\rm\scriptscriptstyle SE}$ (min.) |                                                                                   |  |
| Resume State:            |                                                                                                                |                                                                                   |  |
| Low Speed                | Differential "1" and D+ > $V_{_{\rm SE}}$ (max.) and D- < $V_{_{\rm SE}}$ (min.)                               |                                                                                   |  |
| Full Speed               | Differential "0" and D- > $V_{_{\rm SE}}$ (max.) and D+ < $V_{_{\rm SE}}$ (min.)                               |                                                                                   |  |
| Start of Packet<br>(SOP) | Data lines switch from Idle to K State                                                                         |                                                                                   |  |
| End of Packet<br>(EOP)   | D+ and D- $< V_{se}$ (min) for 2 bit times' followed by an Idle for 1 bit time                                 | D+ and D- < $V_{se}(min)$ for $\ge 1$ bit time <sup>2</sup> followed by a J State |  |











Bit Stuffing -a '0' is inserted after every six consecutive '1's in order to ensure a signal transition so that receiver clock can remain synchronized to the bit stream.









## Data Formatting

- · Data sent in packets
- · Packets will have:
  - Start of Packet Sync Pattern ( 8 bits, 7 zeros + 1 one)
  - Packet ID (PID) identifies type of packet. 8 bits total, but only 4 unique bits
  - Address field 11 bits. 7 bits for USB device (so 128 possible USB devices on bus, host is always address 0), 4 bits for internal use by USB device.
  - Frame number field (11 bits) incremented by host
  - Data Payload (up to 1023 bytes for high-speed connection) - CRC bits - 5 bits for address field, and 16 bits for data field
  - EOP strobe single ended 0 (160ns-175 ns for high speed, 1.25 us to 1.75 us for high speed)
- · Not all packets sent over USB bus have all of these fields (always have SOP, EOP and PID). Packet without data field is a token packet.

6/26/01 BR

| Table 8-1. PID Types |          |          |                                                                                              |  |
|----------------------|----------|----------|----------------------------------------------------------------------------------------------|--|
| PID Type             | PID Name | PID[3:0] | Description                                                                                  |  |
| Token                | OUT      | b0001    | Address + endpoint number in host -> function<br>transaction                                 |  |
|                      | IN       | b1001    | Address + endpoint number in function -> host<br>transaction                                 |  |
|                      | SOF      | b0101    | Start of frame marker and frame number                                                       |  |
|                      | SETUP    | b1101    | Address + endpoint number in host -> function<br>transaction for setup to a control endpoint |  |
| Data                 | DATA0    | ь0011    | Data packet PID even                                                                         |  |
|                      | DATA1    | b1011    | Data packet PID odd                                                                          |  |
| Handshake            | ACK      | b0010    | Receiver accepts error free data packet                                                      |  |
|                      | NAK      | b1010    | Rx device cannot accept data or Tx device cannot send data                                   |  |
|                      | STALL    | Ь1110    | Endpoint is stalled                                                                          |  |
| Special              | PRE      | b1100    | Host-issued preamble. Enables downstream bus traffic<br>to low speed devices.                |  |











| hub.vhd                                                                         |                      |    |  |  |
|---------------------------------------------------------------------------------|----------------------|----|--|--|
| library ieee;<br>use ieee.std_logic_1164.all;                                   |                      |    |  |  |
| library work;<br>use work.usbpkg.all;                                           | One upstream port,   |    |  |  |
|                                                                                 | two downstream ports | 5  |  |  |
| entity hub is<br>generic (<br>HUBDELAY : time := 5 ns<br>);                     |                      |    |  |  |
| port (<br>signal downstrm_a,downstrm_b : ino<br>signal upstrm : inout pkt<br>); | ut pkt;              |    |  |  |
| end hub;                                                                        |                      |    |  |  |
| 6/26/01                                                                         | BR                   | 24 |  |  |







|                                                                                                                   | usbpkg.vł          | nd                 |
|-------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|
| Package that defines '                                                                                            | 'pkt' type         |                    |
| PACKAGE usbpkg IS                                                                                                 |                    |                    |
| constant PTIME: time := 1 us; I<br>constant RTIME: time := 70 ns;<br>constant MAXENDPT: natural := 3              | turn around time   | endpoints          |
| type ptype is (NONE, POUT, PIN,                                                                                   | PACK,ERR);         |                    |
| type upkt is RECORD                                                                                               | I                  | Packet type        |
| id: ptype;<br>dest : integer ;                                                                                    |                    | Packet destination |
| data: string(1 to 80);<br>END RECORD;                                                                             |                    | Packet payload     |
| type upkt_vector is array (natural ra<br>function resolve_upkt (s : upkt_vec<br>subtype pkt is resolve_upkt upkt; | ctor) return upkt; |                    |
| END usbpkg;                                                                                                       | Res                | solved data type   |
| 6/26/01                                                                                                           | BR                 | 26                 |

### Protocol

- · Root initiates all transactions
- · Root will either send a PIN or POUT packet with an destination (address) field set
  - At endpoint, if destination field matches endpoint address, process packet else ignore packet
  - if POUT packet, endpoint responds with ACK packet and places local data (initially set to MANUF string) in ACK packet

  - if PIN packet, endpoint copies packet payload ('data' field) into local data, and responds with ACK packet the data field of this ACK packet is a don't care

BR

6/26/01

### Releasing the Line

- To simulate 'releasing' the line, after either a POUT, PIN, or PACK packet is sent, send a packet of type NONE
- A signal between a hub and an endpoint/root will only • have 2 drivers
  - To resolve the two drivers, look at the packet type
  - A packet type of NONE resolved with POUT/PIN/PACK will return POUT/PIN/PACK
  - A packet type of NONE resolved with NONE will return NONE A packet type of POUT/PIN/PACK resolved with POUT/PIN/PACK with POUT/PIN/PACK will return a packet of type ERR (this should not happen – if it does, then you have a packet collision which \_
- should never happen). · root a.vhd illustrates how to send/receive packets

6/26/01 BR

# HUB operation

- · On downstream ports, any packets of type PACK or NONE should be echoed to upstream port - PACK packet can only come from an endpoint · On upstream port, any packet that is not a PACK packet should be echoed to both downstream ports
- Use HUBDELAY generic for delay time through hub

## What do you have do?

BR

- Complete the resolution function for *pkt* data type
- · Complete architectures for ENDPOINT and HUB
- Test your design with 'tb\_a.vhd' and 'tb\_b'.vhd - I may test your code with other configurations!!!!
- The *root\_a.vhd* code does the following: Loops sending POUT packets to addresses 1 to 32. If a PACK is received, know that there is an ENDPOINT at that address
  - Prints out data from ACK packet to screen
  - Sends a PIN packet to the endpoint with the data from the PACK packet modified
  - Send a POUT packet to the endpoint to verify that the endpoint stored the new data wait for the PACK response and print returned data to console

BR

6/26/01

6/26/01

28









