# USBHostSlave IP Core Specification Author: Steve Fielding sfielding@base2designs.com Rev. 1.1 October 13, 2006 This page has been intentionally left blank. ### **Revision History** | Rev. | Date | Author | Description | |------|-----------------|-----------|-----------------------------------------------------| | 0.1 | 10/01/04 | Sfielding | Created | | 0.2 | 12/05/04 | Sfielding | Fixed frame_num register description | | 0.3 | 01/11/05 | Sfielding | Added host slave mode register | | 0.4 | 01/25/05 | Sfielding | Added Version number register, and changed host | | | 0.5 / 1.0 / 0.5 | ~ ~ | and slave frameNum registers | | 0.5 | 02/10/05 | Sfielding | Added instructions for clearing interrupt registers | | 0.6 | 02/25/05 | Sfielding | Added isochronous mode control. Altered | | | | | descriptions of endpoint control and status | | | | | registers | | 0.7 | 06/04/05 | Sfielding | Added SOF timer register | | | | | Split version number into major, and minor | | | | | Added HOST_RX_FIFO_DATA reg to register | | | | | memory map | | 1.0 | 10/14/05 | Sfielding | Seperated bus clock and usb clock. Updated | | | | | Wishbone datasheet. Removed Tx and Rx fifo | | | | | status registers, and removed TX fifo data count | | | | | register. Added RESET_CORE bit to | | | | | HOST_SLAVE_CONTROL_REG. | | | | | Fixed slave mode bug which caused receive fifo to | | | | | be filled with incoming data when the slave was | | | | | responding with a NAK, and the data should have | | | | | been discarded. | | 1.1 | 3/24/06 | Sfielding | Fixed 48MHz clock tolerance requirement, and | | | | | added note to clock chapter about 48MHz | | | | | oscillator on Development boards. | # **Contents** | INTRODUCTION | | |----------------------|----| | ARCHITECTURE | 2 | | OPERATION | 4 | | REGISTERS | 6 | | CLOCKS | 21 | | IO PORTS | 22 | | WISHBONE DATASHEET | 24 | | RESOURCE UTILIZATION | 25 | | USB TRANSCEIVERS | 26 | ## Introduction USBHostSlave is a USB 1.1 Host and Device IP core. - Supports full speed (12Mbps) and low speed (1.5Mbps) operation. - USB Device has four endpoints, each with their own independent FIFO. - Supports the four types of USB data transfer; control, bulk, interrupt, and isochronous transfers. - Host can automatically generate SOF packets. - 8-bit Wishbone slave bus interface. - FIFO depth configurable via parameters. ## **Architecture** The USBhostSlave IP core consists of five major functional blocks (see Figure (1)). USBSerialInterfaceEngine – Supports the lowest level of the USB 1.1 protocol layer. On the transmit path, USBSerialInterfaceEngine implements, sync insertion, CRC calculation and insertion, parallel to serial conversion, bit stuffing, and NRZI encoding. On the receive path, USBSerialInterfaceEngine, implements connection state detection, sync detection and stripping, clock recovery, NRZI decoding, bit de-stuffing, CRC calculation and checking, and serial to parallel conversion. HostSlaveMux – Allows host and slave controllers to share access to the USBSerialInterfaceEngine. USBSlaveControl – Supports the USB 1.1 Device specific portion of the USB 1.1 protocol layer. Supports all USB 1.1 transaction types; bulk, setup, interrupt, and isochronous. USBHostControl – Supports the USB 1.1 Host specific portion of the USB 1.1 protocol layer. Supports all USB 1.1 transaction types; bulk, setup, interrupt, and isochronous. Supports automatic preamble insertion, and automatic SOF generation and transmission WishBoneBI – Provides Wishbone compatible interface to host/slave controllers and the transmit/receive FIFOs. Figure 1USBHostSlave block diagram # **Operation** Consider a system consisting of a USBHostSlave IP core, a USB PHY (eg Fairchild USB1T11A), and a microprocessor (see figure (2)). Figure 2USBHostSlave in a typical system There are two scenarios to consider. Firstly where a USBHostSlave is configured as a USB Host, and the second where it is configured as USB Device. Let's consider the Host configuration first. On power up, the microprocessor will configure USBHostSlave as a USB Host. If the Host is not connected to a USB Device, then USBHostSlave will report that the USB line is in a disconnect state. When the Host is connected to a Device, USBHostSlave will report the connection event and the connection speed. Now the following USBHostSlave parameters can be configured; - USB speed. - USB polarity. - The USB address of the attached Device (Address zero is the default Device address). - The USB endpoint (endpoint zero is used for set up) within the attached Device. Now that the Host has been configured, the Host can attempt to complete a transfer with the attached USB Device. Let's use the example of the Host sending data to the USB Device. First the USBHostSlave transmit FIFO will be loaded with data, then the transaction type will be set, and finally the transaction request flag will be set. The microprocessor detects that the transaction is complete by checking for the transaction done flag to be set, or waiting for the transaction done interrupt. Now let's take a look at the case where USBHostSlave is configured as a USB Device. On power up, the microprocessor will configure USBHostSlave as a USB Device. If the Device is not connected to a USB Host, then USBHostSlave will report that the USB line is in a reset state. When the Device is connected to a Host, USBHostSlave will report the connection event and the connection speed. Now the following USBHostSlave parameters can be configured; - USB speed. - USB polarity. - The USB address (Address zero is the default Device address). - Set the global endpoint enable flag If the Device is expecting a transaction then it must be prepared to accept the transaction. If an incoming data packet is expected then simply set the enable flag for the endpoint that is expecting a transaction, and wait for the transaction done flag (or transaction done interrupt) to be set. If the expected transaction involves outgoing data, then the endpoint FIFO will have to be loaded with data before the enable flag is set. # Registers #### **USB Host Slave Common Registers** | Register Address | Name | |------------------|------------------------| | 0xe0 | HOST_SLAVE_CONTROL_REG | | 0xe1 | HOST SLAVE VERSION REG | #### HOST SLAVE CONTROL REG | Bit Position | Name | Description | |--------------|------------|-----------------------------------| | 0 | HOST_MODE | Set to 1 to enable host mode. Set | | | | to 0 to enable slave mode. | | 1 | RESET_CORE | Write only. Value is not latched. | | | | Set to 1 to reset all the logic | | | | including registers. Must wait 10 | | | | usbClk cycles for reset to | | | | complete. | #### HOST\_SLAVE\_VERSION\_REG | Bit Position | Name | Description | |--------------|-------------------|-----------------------| | [7:4] | VERSION_NUM_MAJOR | Major revision number | | [3:0] | VERSION NUM MINOR | Minor revision number | #### **USB Host** | Register Address | Name | |------------------|--------------------------| | 0x0 | HOST_TX_CONTROL_REG | | 0x1 | HOST_TX_TRANS_TYPE_REG | | 0x2 | HOST_TX_LINE_CONTROL_REG | | 0x3 | HOST_TX_SOF_ENABLE_REG | | 0x4 | HOST_TX_ADDR_REG | | 0x5 | HOST_TX_ENDP_REG | | Register Address | Name | |------------------|-----------------------------| | 0x6 | HOST_FRAME_NUM_MSP_REG | | 0x7 | HOST_FRAME_NUM_LSP_REG | | 0x8 | HOST_INTERRUPT_STATUS_REG | | 0x9 | HOST_INTERRUPT_MASK_REG | | 0xa | HOST_RX_STATUS_REG | | 0xb | HOST_RX_PID_REG | | 0xc | HOST_RX_ADDR_REG | | 0xd | HOST_RX_ENDP_REG | | 0xe | HOST_RX_CONNECT_STATE_REG | | 0xf | HOST_SOF_TIMER_MSB_REG | | | | | 0x20 | HOST_RX_FIFO_DATA | | 0x21 | Reserved | | 0x22 | HOST_RX_FIFO_DATA_COUNT_MSB | | 0x23 | HOST_RX_FIFO_DATA_COUNT_LSB | | 0x24 | HOST_RX_FIFO_CONTROL_REG | | | | | 0x30 | HOST_TX_FIFO_DATA | | 0x31 | Reserved | | 0x32 | Reserved | | 0x33 | Reserved | | 0x34 | HOST_TX_FIFO_CONTROL_REG | #### HOST\_TX\_CONTROL\_REG | Bit Position | Name | Description | |--------------|---------------------|-------------------------------------------| | 0 | TRANS_REQ_BIT | Set to 0 to disable transaction. Set to 1 | | | | to enable transaction, automatically | | | | cleared when transaction complete. | | 1 | SOF_SYNC_BIT | Set to 1 to syncrhonize transaction | | | | with the end of SOF | | | | transmission. Transaction will be | | | | scheduled for transmission | | | | immediately after SOF transmission. | | 2 | PREAMBLE_ENABLE_BIT | Set to 1 to enable preamble. Should | | | | only be enabled when the host is | | | | connected to a low speed device via a | | | | hub. The preamble is a token which is | | | | prefixed to all packet transmissions, | | | | and is transmitted at full speed | | | | irrespective of the state of the | | | | FULL SPEED LINE RATE BIT. | | Bit Position | Name | Description | |--------------|----------------|--------------------------------------| | 3 | ISO_ENABLE_BIT | Set to 1 to enable isochronous mode. | | | | In isochronous mode, no | | | | acknowledgements are sent or | | | | received. Note, the | | | | TRANS_TYPE_REG must be set to | | | | either IN_TRANS or | | | | OUTDATA0_TRANS. Isochronous | | | | mode is not allowed with any other | | | | transaction types. | #### HOST\_RX\_CONNECT\_STATE\_REG | Bit Position | Name | Description | | |--------------|---------------|---------------------------------------------------------------|-----| | [1:0] | RX_LINE_STATE | The contents | of | | | | RX_CONNECT_STATE_REG reflect current connection state, where; | the | | | | DISCONNECT = 0 | | | | | LOW_SPEED_CONNECT = 1 | | | | | FULL_SPEED_CONNECT = 2 | | #### $HOST\_INTERRUPT\_STATUS\_REG$ | Bit Position | Name | Description | |--------------|----------------------|---------------------------------------| | 0 | TRANS_DONE_BIT | Automatically set to 1 when a | | | | transaction is completed. Must be | | | | cleared by writing 1. | | 1 | RESUME_INT_BIT | Automatically set to 1 when resume | | | | state is detected. Must be cleared by | | | | writing 1. | | 2 | CONNECTION_EVENT_BIT | Automatically set to 1 when a connect | | | | or disconnect occurs. Must be cleared | | | | by writing 1. | | 3 | SOF_SENT_BIT | Automatically set to 1 when a SOF | | | | transmission occurs. Must be cleared | | | | by writing 1. | #### $HOST\_INTERRUPT\_MASK\_REG$ | Bit Position | Name | Description | |--------------|----------------|----------------------------------------| | 0 | TRANS_DONE_BIT | Set to 1 to enable interrupt on | | | | transaction completion. | | 1 | RESUME_INT_BIT | Set to 1 to enable interrupt on resume | | | | detected. | | Bit Position | Name | Description | |--------------|----------------------|-----------------------------------------| | 2 | CONNECTION_EVENT_BIT | Set to 1 to enable interrupt on connect | | | | or disconnect event. | | 3 | SOF SENT BIT | Set to 1 to enable interrupt on SOF | | | | transmission. | #### $HOST\_RX\_STATUS\_REG$ | Bit Position | Name | Description | |--------------|---------------------|------------------------------------------| | 0 | CRC_ERROR_BIT | When set to 1, indicates CRC error | | | | detected on the last transaction. | | 1 | BIT_STUFF_ERROR_BIT | When set to 1, indicates bit stuff error | | | | detected on the last transaction. | | 2 | RX_OVERFLOW_BIT | When set to 1, indicates insufficient | | | | free space in RX fifo to accept entire | | | | data packet. | | 3 | RX_TIME_OUT_BIT | When set to 1, indicates no response | | | | from USB device. | | 4 | NAK_RXED_BIT | When set to 1, indicates NAK received | | | | from USB device. | | 5 | STALL_RXED_BIT | When set to 1, indicates STALL | | | | received from USB device. | | 6 | ACK_RXED_BIT | When set to 1, indicates ACK received | | | | from USB device. | | 7 | DATA_SEQUENCE_BIT | If the last transaction was of type | | | | IN_TRANS, then this bit indicates the | | | | sequence number of the last receive | | | | packet. $DATA0 = 0$ , $DATA1 = 1$ . | #### $HOST\_TX\_TRANS\_TYPE\_REG$ | Bit Position | Name | Description | |--------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [1:0] | TRANSACTION_TYPE | SETUP_TRANS = 0 | | | | $IN\_TRANS = 1$ | | | | OUTDATA0_TRANS = 2 | | | | OUTDATA1_TRANS = 3 | | | | These are the four basic types of transaction. The transaction types detailed in USB 1.1 (Setup, bulk, and isochronous) are composed of a series of one or more of these basic atomic | | | | transactions. | $HOST\_TX\_LINE\_CONTROL\_REG$ | Bit Position | Name | Description | |--------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [1:0] | TX_LINE_STATE | When DIRECT_CONTROL_BIT=1,T X_LINE_STATE directly controls the state of the USB physical wires, where; TX_LINE_STATE [1] = D+ | | 2 | DIRECT_CONTROL_BIT | TX LINE STATE [0] = D- Set to 1 to allow direct control the state of the USB physical wires. Clear to 0 for normal operation. | | 3 | FULL_SPEED_LINE_POLARITY_BIT | Set to 1 to enable full speed line polarity. That is J= differential 1, K= differential 0. Clear to zero to enable low speed line poarity. That is J= | | | | differential 0, K= differential 1. If the host is communicating with a full speed device, then full speed line polarity should be enabled. If the host is communicating with a low speed device directly then full speed line polarity should be disabled. If the host is communicating with a low speed device via a hub, then full speed line polarity should be enabled. | | 4 | FULL_SPEED_LINE_RATE_BIT | Set to 1 to enable full speed line rate of 12Mbps. Clear to 0 to enable low speed line rate of 1.5Mbps. If the host is communicating with a full speed device, then full speed line rate should be enabled. If the host is communicating with a low speed device full speed line rate should be disabled. | #### $HOST\_TX\_SOF\_ENABLE\_REG$ | Bit Position | Name | Description | |--------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | SOF_EN_BIT | If FULL_SPEED_LINE_POLARITY_BIT is set, then setting this bit to 1 to enables automatic transmission of SOF tokens every 1mS. Note that SOF tokens will be transmitted at full speed line rate irrespective of the state of FULL_SPEED_LINE_RATE_BIT. | | | | If FULL_SPEED_LINE_POLARITY_BIT is clear, then setting this bit to 1 to enables automatic transmission of low speed EOP keep alive every 1mS. Transition from 0 to 1 causes transmission of resume state prior to EOP transmission. Note that this mode is only used when the host is connected directly to a low speed device. | | | | Clear to 0 to disable automatic SOF/EOP transmission, and allow any devices attached to the host to enter the suspend state. | #### $HOST\_TX\_ADDR\_REG$ | Bit Position | Name | Description | | |--------------|----------------|---------------------|--| | [6:0] | DEVICE_ADDRESS | USB Device address. | | #### HOST\_TX\_ENDP\_REG | Bit Position | Name | Description | |--------------|--------------|-------------------| | [3:0] | ENDP ADDRESS | Endpoint address. | #### HOST\_FRAME\_NUM\_MSP\_REG | Bit Position | Name | Description | |--------------|---------------|------------------------------------| | [2:0] | FRAME_NUM_MSP | Most significant part of the frame | | | | number used for SOF transmission. | | | | That is FRAME NUM MSP = | | | | FRAME_NUM[10:8]. | #### HOST\_FRAME\_NUM\_LSP\_REG | Bit Position | Name | Description | |--------------|---------------|-------------------------------------| | [7:0] | FRAME_NUM_LSP | Least significant part of the frame | | | | number used for SOF transmission. | | | | That is FRAME_NUM_LSP = | | | | FRAME_NUM[7:0]. | HOST\_SOF\_TIMER\_MSB\_REG | Bit Position | Name | Description | |--------------|------|----------------------------------------------------------------------------------------| | [7:0] | | Most significant byte of the SOF timer used for SOF transmission. Timer is incremented | | | | at 48MHz, thus there are 48000 ticks in a 1mS frame. | | | | This register can be used to calculate the number of ticks remaining in a frame. | | | | $Trem = 0xbb - HOST\_SOF\_TIMER\_MSB$ | #### HOST\_RX\_PID\_REG | Bit Position | Name | Description | |--------------|-------------|---------------------------------------| | [3:0] | RECEIVE_PID | Packet identifier for the last packet | | | | received. | #### HOST\_RX\_ADDR\_REG | Bit Position | Name | Description | |-----------------------------------------|-----------------|-------------------------------------| | [6:0] | RECEIVE_ADDRESS | Address from which the last receive | | *************************************** | | packet was sent. | #### HOST\_RX\_ENDP\_REG | Bit Position | Name | Description | |--------------|--------------|---------------------------------------| | [3:0] | RECEIVE ENDP | End point from which the last receive | | | _ | packet was sent. | #### HOST\_RX\_FIFO\_DATA | Bit Position | Name | Description | |--------------|--------------|------------------------------------| | [7:0] | RX_FIFO_DATA | If the last transaction was an | | | | IN_TRANS, then the receive payload | | | | can be retrieved by reading | | | | RX_FIFO_DATA | #### HOST\_TX\_FIFO\_DATA | Bit Position | Name | Descrip | ption | | | | | |--------------|--------------|---------|-------|-----------|-------|-----------|------| | [7:0] | TX_FIFO_DATA | Prior | to | О | reque | esting | an | | | | OUTD | ATA( | _TRA | NS | or | an | | | | OUTD | ATA: | 1 TRA | NS, | load tran | smit | | | | fifo | with | _<br>data | by | writing | to | | | | TX_FI | FO_D | ATA. | | | | #### HOST\_RX\_FIFO\_DATA\_COUNT\_MSB | Bit Position | Name | Description | |--------------|---------------------|-------------------------------------------------------| | [7:0] | FIFO_DATA_COUNT_MSB | MSByte of FIFO_DATA_COUNT. | | | | Indicates the number of data entries within the fifo. | #### HOST\_RX\_FIFO\_DATA\_COUNT\_LSB | Bit Position | Name | Description | |--------------|---------------------|--------------------------------------| | [7:0] | FIFO_DATA_COUNT_LSB | LSByte of FIFO_DATA_COUNT. | | | | Indicates the number of data entries | | | | within the fifo. | #### HOST\_[T,R]X\_FIFO\_CONTROL | Bit Position | Name | Description | |--------------|-------------------------------|----------------------------------------| | 0 | FIFO_FORCE_EMPTY | Write only. Set to 1 to delete all the | | | data samples within the fifo. | | #### **USB Slave (Device)** | Register Address | Name | |------------------|------------------------------------| | 0x40 | ENDPOINT0_CONTROL_REG | | 0x41 | ENDPOINTO_STATUS_REG | | 0x42 | ENDPOINT0_TRANSTYPE_STATUS_REG | | 0x43 | ENDPOINTO_NAK_TRANSTYPE_STATUS_REG | | | | | 0x44 | ENDPOINT1_CONTROL_REG | | 0x45 | ENDPOINT1_STATUS_REG | | 0x46 | ENDPOINT1_TRANSTYPE_STATUS_REG | | 0x47 | ENDPOINT1_NAK_TRANSTYPE_STATUS_REG | | | | | 0x48 | ENDPOINT2_CONTROL_REG | | 0x49 | ENDPOINT2_STATUS_REG | | 0x4a | ENDPOINT2_TRANSTYPE_STATUS_REG | | Register Address | Name | | | |------------------|-------------------------------------------------------|--|--| | 0x4b | ENDPOINT2 NAK TRANSTYPE STATUS REG | | | | | | | | | 0x4c | ENDPOINT3_CONTROL_REG | | | | 0x4d | ENDPOINT3_STATUS_REG | | | | 0x4e | ENDPOINT3_TRANSTYPE_STATUS_REG | | | | 0x4f | ENDPOINT3_NAK_TRANSTYPE_STATUS_REG | | | | | | | | | 0x50 | SC_CONTROL_REG | | | | 0x51 | SC LINE STATUS REG | | | | 0x52 | SC_INTERRUPT_STATUS_REG | | | | 0x53 | SC_INTERRUPT_MASK_REG | | | | 0x54 | SC_ADDRESS | | | | 0x55 | SC FRAME NUM MSP | | | | 0x56 | SC_FRAME_NUM_LSP | | | | 0x60 | EPO RX FIFO DATA | | | | 0x60<br>0x61 | Reserved | | | | 0x61 $0x62$ | EPO RX FIFO DATA COUNT MSB | | | | 0x63 | EPO RX FIFO DATA COUNT LSB | | | | 0x64 | EPO RX FIFO CONTROL REG | | | | OAOT | ETO RATTHO CONTROL REG | | | | 0x70 | EP0 TX FIFO DATA | | | | 0x71 | Reserved | | | | 0x72 | Reserved | | | | 0x73 | Reserved | | | | 0x74 | EPO TX FIFO CONTROL REG | | | | | | | | | 0x80 | EP1_RX_FIFO_DATA | | | | 0x81 | Reserved | | | | 0x82 | EP1_RX_FIFO_DATA_COUNT_MSB | | | | 0x83 | EP1_RX_FIFO_DATA_COUNT_LSB | | | | 0x84 | EP1_RX_FIFO_CONTROL_REG | | | | 2.22 | | | | | 0x90 | EP1_TX_FIFO_DATA | | | | 0x91 | Reserved | | | | 0x92 | Reserved | | | | 0x93 | Reserved | | | | 0x94 | EP1_TX_FIFO_CONTROL_REG | | | | 0xa0 | EP2 RX FIFO DATA | | | | 0xa0<br>0xa1 | Reserved | | | | 0xa1<br>0xa2 | EP2 RX FIFO DATA COUNT MSB | | | | 0xa2<br>0xa3 | EP2 RX FIFO DATA COUNT MSB EP2 RX FIFO DATA COUNT LSB | | | | 0xa3<br>0xa4 | EP2 RX FIFO DATA COUNT LSB<br>EP2 RX FIFO CONTROL REG | | | | 02 <b>.u</b> 1 | ELE INT THE CONTROL IND | | | | 0xb0 | EP2 TX FIFO DATA | | | | | | | | | Register Address | Name | |------------------|----------------------------| | 0xb1 | Reserved | | 0xb2 | Reserved | | 0xb3 | Reserved | | 0xb4 | EP2_TX_FIFO_CONTROL_REG | | 0xc0 | EP3 RX FIFO DATA | | 0xc1 | Reserved | | 0xc2 | EP3_RX_FIFO_DATA_COUNT_MSB | | 0xc3 | EP3_RX_FIFO_DATA_COUNT_LSB | | 0xc4 | EP3 RX FIFO CONTROL REG | | 0xd0 | EP3_TX_FIFO_DATA | | 0xd1 | Reserved | | 0xd2 | Reserved | | 0xd3 | Reserved | | 0xd4 | EP3_TX_FIFO_CONTROL_REG | #### ENDPOINT[3..0]\_CONTROL\_REG | Bit Position | Name | Description | |--------------|-------------------------------|-------------------------------| | 0 | ENDPOINT_ENABLE_BIT | Set to 1 to enable the | | | | endpoint. If endpoint is not | | | | enabled then it will not | | | | respond to any transactions. | | | | If endpoint is enabled, not | | | | ready, and not in | | | | isochronous mode, then all | | | | transactions will be NAK'd. | | 1 | ENDPOINT_READY_BIT | Set to 1 make the endpoint | | | | ready. If endpoint is enabled | | | | and ready then it can | | | | respond to a host inititiated | | | | transaction. Automatically | | | | cleared to 0 when | | | | transaction is complete. | | 2 | ENDPOINT_OUTDATA_SEQUENCE_BIT | If set to 1 then the endpoint | | | | will respond to a host IN | | | | request with a DATA1 | | | | packet, otherwise it will | | | | respond with a DATA0 | | | | packet. | | Bit Position | Name | Description | |--------------|-------------------------|-----------------------------| | 3 | ENDPOINT_SEND_STALL_BIT | If set to 1 and endpoint is | | | | enabled, ready, and not in | | | | isochronous mode, then | | | | endpoint will send STALL | | | | in response to a host | | | | inititiated transaction. | | 4 | ENDPOINT_ISO_ENABLE_BIT | Set to 1 to enable | | | | isochronous transfers. In | | | | isochronous mode the | | | | endpoint does not send | | | | acknowledgements, nor | | | | does it expect to receive | | | | acknowledgements. | #### ENDPOINT[3..0] STATUS REG | Bit Position | Name | Description | |--------------|------------------------|------------------------------------------| | 0 | SC_CRC_ERROR_BIT | When set to 1, indicates CRC error | | | | detected on the last transaction. | | 1 | SC_BIT_STUFF_ERROR_BIT | When set to 1, indicates bit stuff error | | | | detected on the last transaction. | | 2 | SC_RX_OVERFLOW_BIT | When set to 1, indicates insufficient | | | | free space in RX fifo to accept entire | | | | data packet. | | 3 | SC_RX_TIME_OUT_BIT | When set to 1, indicates no response | | | | from USB host. | | 4 | SC_NAK_SENT_BIT | When set to 1, indicates NAK sent to | | | | USB host. | | 5 | SC_STALL_SENT_BIT | When set to 1, indicates STALL sent | | | | to USB host. | | 6 | SC_ACK_RXED_BIT | When set to 1, indicates ACK received | | | | from USB host. | | 7 | SC_DATA_SEQUENCE_BIT | If the last transaction was of type | | | | OUT_TRANS, then this bit indicates | | | | the sequence number of the last | | | | receive packet. DATA0 = 0, DATA1 | | | | = 1. | Note that SC\_NAK\_SENT\_BIT refers to the last host inititiated transaction that occurred whilst the endpoint was enabled, but not ready. The other bits in this register are not effected by host transactions that are NAK'd, and they refer to the last transaction which resulted in ENDPOINT\_READY\_BIT being changed from 1 to 0. SC\_NAK\_SENT\_BIT is cleared to zero immediately after an enabled/ready transaction is completed. Note that the usb slave endpoint cannot NAK a host transmission when the endpoint is enabled and ready. So the NAK\_SENT\_BIT never refers to a transaction which resulted in ENDPOINT READY BIT being changed from 1 to 0 #### ENDPOINT[3..0]\_TRANSTYPE\_STATUS\_REG | Bit Position | Name | Description | |--------------|------------------|-------------------------------------------------------------------------------------------------| | [1:0] | TRANSACTION_TYPE | SC_SETUP_TRANS = 0 | | | | $SC_{IN}_{TRANS} = 1$ | | | | SC_OUTDATA_TRANS = 2 | | | | This is the transaction type of the last transaction which resulted in ENDPOINT_READY_BIT being | | | | changed from 1 to 0 | #### $ENDPOINT [3..0]\_NAK\_TRANSTYPE\_STATUS\_REG$ | Bit Position | Name | Description | |--------------|------------------|------------------------------------------------------------------------------------------------------| | [1:0] | TRANSACTION_TYPE | SC_SETUP_TRANS = 0 | | | | SC_IN_TRANS = 1 | | | | SC_OUTDATA_TRANS = 2 | | | | This is the transaction type of the last transaction which resulted in a NAK being sent to the host. | #### SC\_CONTROL\_REG | Bit | Name | Description | |----------|-----------------------|--------------------------------------| | Position | n | | | 0 | SC_GLOBAL_ENABLE_BIT | When cleared to 0, all endpoints | | | | are disabled, and the slave will | | | | not respond to any host inititiated | | | | transactions. | | [2:1] | SC_TX_LINE_STATE | When | | | | SC_DIRECT_CONTROL_BIT=1 | | | | SC_TX_LINE_STATE directly | | | | controls the state of the USB | | | | physical wires, where; | | | | $SC_TX_LINE_STATE[2] = D+$ | | | | SC_TX_LINE_STATE [1] = D- | | 3 | SC_DIRECT_CONTROL_BIT | Set to 1 to allow direct control the | | | | state of the USB physical wires. | | | | Clear to 0 for normal operation. | | Bit | Name | Description | |----------|---------------------------------|---------------------------------------| | Position | | | | 4 | SC_FULL_SPEED_LINE_POLARITY_BIT | Set to 1 to enable full speed line | | | | polarity. That is J= differential 1, | | | | K= differential 0. | | | | Clear to zero to enable low speed | | | | line poarity. That is J= differential | | | | 0, K= differential 1. | | 5 | SC_FULL_SPEED_LINE_RATE_BIT | Set to 1 to enable full speed line | | | | rate of 12Mbps. Clear to 0 to | | | | enable low speed line rate of | | | | 1.5Mbps. | #### SC\_LINE\_STATUS\_REG | Bit Position | Name | Description | | |--------------|---------------|----------------------------------|-----| | [1:0] | RX_LINE_STATE | The contents | of | | | | RX_CONNECT_STATE_REG reflect | the | | | | current connection state, where; | | | | | RESET = 0 | | | | | LOW_SPEED_CONNECT = 1 | | | | | FULL_SPEED_CONNECT = 2 | | #### SC\_INTERRUPT\_STATUS\_REG | Bit Position | Name | Description | |--------------|---------------------|-----------------------------------------| | 0 | SC_TRANS_DONE_BIT | Set to 1 when a transaction is | | | | completed. Must be cleared by writing | | | | 1. | | 1 | SC_RESUME_INT_BIT | Set to 1 when resume state is detected. | | | | Must be cleared by writing 1. | | 2 | SC_RESET_EVENT_BIT | Set to 1 when reset state is detected. | | | | Must be cleared by writing 1. | | 3 | SC_SOF_RECEIVED_BIT | Set to 1 when a SOF packet is | | | | received. Must be cleared by writing 1. | | 4 | SC_NAK_SENT_INT_BIT | Set to 1 when a NAK sent. Must be | | | | cleared by writing 1. | #### $SC\_INTERRUPT\_MASK\_REG$ | Bit Position | Name | Description | |--------------|-------------------|----------------------------------------| | 0 | SC_TRANS_DONE_BIT | Set to 1 to enable interrupt on | | | | transaction complete. | | 1 | SC_RESUME_INT_BIT | Set to 1 to enable interrupt on resume | | | | detected. | | Bit Position | Name | Description | |--------------|---------------------|---------------------------------------| | 2 | SC_RESET_EVENT_BIT | Set to 1 to enable interrupt on reset | | | | detected. | | 3 | SC_SOF_RECEIVED_BIT | Set to 1 to enable interrupt on SOF | | | | received. | | 4 | SC_NAK_SENT_INT_BIT | Set to 1 to enable interrupt on NAK'd | | | | transaction. | #### SC\_ADDRESS | Bit Position | Name | Description | |--------------|----------------|---------------------| | [6:0] | DEVICE ADDRESS | USB Device address. | #### SC\_FRAME\_NUM\_MSP | Bit Position | Name | Description | |--------------|------------------|---------------------------------------------| | [2:0] | SC_FRAME_NUM_MSP | Most significant part of the frame | | | | number received in the last SOF | | | | transmission. That is | | | | SC FRAME NUM MSP = | | | | $\overline{FRAME}_{NUM[10:\overline{8}]}$ . | #### $SC\_FRAME\_NUM\_LSP$ | Bit Position | Name | Description | |--------------|------|-------------------------------------------------------| | [7:0] | | Least significant part of the frame | | | | number received in the last SOF transmission. That is | | | | SC_FRAME_NUM_LSP =<br>FRAME_NUM[7:0]. | #### EP[3..0]\_TX\_FIFO\_DATA | Bit Position | Name | Description | |--------------|--------------|---------------------------------------| | [7:0] | TX_FIFO_DATA | Prior to receiving a IN_TRANS, load | | | | transmit fifo with data by writing to | | | | ΓX_FIFO_DATA. | #### EP[3..0]\_RX\_FIFO\_DATA | Bit Position | Name | Description | | |--------------|--------------|-------------------------------|--| | [7:0] | RX_FIFO_DATA | After receiving an | | | | | OUTDATA_TRANS, or a | | | | | SETUP TRANS, get receive data | | | | | from fifo by reading from | | | | | RX FIFO DATA. | | #### EP[3..0]\_RX\_FIFO\_DATA\_COUNT\_MSB | Bit Position | Name | Description | | |--------------|---------------------|--------------------------------------|--| | [7:0] | FIFO_DATA_COUNT_MSB | MSByte of FIFO DATA COUNT. | | | | | Indicates the number of data samples | | | | | within the fifo. | | #### EP[3..0]\_RX\_FIFO\_DATA\_COUNT\_LSB | Bit Position | Name | Description | | |--------------|---------------------|--------------------------------------|--| | [7:0] | FIFO_DATA_COUNT_LSB | LSByte of FIFO_DATA_COUNT. | | | | | Indicates the number of data samples | | | | | within the fifo. | | #### EP[3..0]\_[T,R]X\_FIFO\_CONTROL | Bit Position | Name | Description | | |--------------|------------------|----------------------------------------|--| | 0 | FIFO_FORCE_EMPTY | Write only. Set to 1 to delete all the | | | | | data samples within the fifo. | | # **Clocks** | Name | Source | Rates (MHz) | | Remarks | Description | | |--------|--------|-------------|--------|---------|-------------|--------------| | | | Max | Min | Res | | | | usbClk | Input | 48.024 | 47.976 | - | Duty cycle | USB system | | | Pad | | | | 50/50. | clock. | | clk i | Input | 240 | usbClk | | Duty cycle | Wishbone bus | | _ | Pad | | | | 50/50. | clock. | Table 1: List of clocks Several Development kits, such as the Altera Nios Development Kit Cyclone Edition, come with a 50MHz oscillator. Although the Cyclone PLL in the NIOS Development Kit can be used to derive a 48.076923MHz clock, and this complies with the low speed frequency tolerance (+/- 0.25%), it is not sufficient for full speed operation where a +/- 0.05% frequency tolerance is required. The 48MHz socketed half can oscillator on the NIOS Development Kit can be replaced with a 50MHz oscillator (eg ECS ECS-2200B-480, Digikey part number XC280-ND) # IO Ports | Port | Width | Direction | Description | | |-----------------------|-------|-----------|----------------------------------------------|--| | usbClk | 1 | input | usb logic clock. 48MHz +/- 0.25% | | | clk i | 1 | input | WISHBONE clock input. Can be asynchronous | | | _ | | | to usbClk. 48MHz <= clk_i <= 240MHz | | | rst_i | 1 | input | WISHBONE reset. Synchronous to clk i. | | | _ | | | Resets all logic. | | | address i | 8 | input | WISHBONE address input | | | data_i | 8 | input | WISHBONE data input | | | data_o | 8 | output | WISHBONE data output | | | writeEn | 1 | input | WISHBONE write enable | | | strobe i | 1 | input | WISHBONE strobe input | | | ack o | 1 | output | WISHBONE acknowledge output | | | hostSOFSentIntOut | 1 | output | Host SOF sent interrupt | | | hostConnEventIntOut | 1 | output | Host connection event interrupt | | | hostResumeIntOut | 1 | output | Host resume interrupt | | | hostTransDoneIntOut | 1 | output | Host transaction done interrupt | | | slaveSOFRxedIntOut | 1 | output | SlaveSOF received interrupt | | | slaveResetEventIntOut | 1 | output | Slave reset event interrupt | | | slaveResumeIntOut | 1 | output | Slave resume interrupt | | | slaveTransDoneIntOut | 1 | output | Slave transaction done interrupt | | | slaveNAKSentIntOut | 1 | output | Slave NAK sent interrupt | | | USBWireDataIn | | input | USB wire differential data input | | | | | | USBWireDataIn[1] = D+ | | | | 2 | | USBWireDataIn[0] = D- | | | USBWireDataOut | | output | USB wire differential data output | | | | | | USBWireDataOut[1] = D+ | | | | 2 | | USBWireDataOut[0] = D- | | | USBWireDataOutTick | | output | Debug output. 6MHz in full speed mode, | | | | 1 | | 750KHz in low speed mode. | | | USBWireDataInTick | | output | Debug output. 6MHz in full speed mode, | | | | 1 | | 750KHz in low speed mode. | | | USBWireCtrlOut | | output | USB tansmit output enable. Connect to OE pin | | | | | | on USB PHY (eg invert and connect to OE_n | | | | 1 | | on USB1T11A) | | **Table 2: List of IO ports** # **Wishbone Datasheet** | WISHBONE DATASHEET | | | | |----------------------------------------------|---------------------------|-----------------|--| | for USBHostSlave IP Core | | | | | Description | Pescription Specification | | | | General Description: | 8-bit slave input and | output port | | | Supported cycles: | SLAVE READ/WRIT | ГЕ | | | Data port Size: | 8-bit | | | | Data port granularity: | 8-bit | | | | Data port, max operand size: | 8-bit | | | | Data transfer ordering: | N/A | | | | Data transfer sequencing: | Undefined | | | | | Signal Name | WISHBONE Equiv. | | | | address_i | ADR_I | | | Supported signal list and cross reference to | data_i[7:0] | DAT_I() | | | equivalet WISHBONE signals: | data_o[7:0] | DAT_O() | | | | we_i | WE_I | | | | strobe_i | STB_I | | | | ack_o | ACK_O | | | | clk_i | CLK_I | | | | rst_i | RST_I | | Table 3: WISHBONE data sheet # **Resource Utilization** | Design Entity | Logic Cells | Memory bits | |-----------------------------|-------------|-------------| | USBHostControl | 508 | 0 | | USBSlaveControl | 545 | 0 | | USBSerialInterfaceEngine | 984 | 0 | | WishBoneBI | 49 | 0 | | HostSlaveMux | 16 | 0 | | 8 slave FIFOs each 64x8-bit | 412 | 4096 | | 2 host FIFOs each 64x8-bit | 103 | 1024 | | USBHostSlave (top level) | 2617 | 5120 | Table 4 Resource utilization for Altera CycloneEP1C20 # **USB Transceivers** The core must be used with a USB transciver that is capable of driving the USB cable, and complies with the USB 1.1 specification. There are many options available, one of the simplest is the Fairchild USB1T11A. The USB1T11A has seperate pins for transmit and receive paths, and is available in a large SOIC package (nice for prototyping and cheap PCBs), and a very small (3mm x 3mm) MLP package. The USB1T11A will connect directly to the core apart from an inverter between 'USBWireCtrlOut' and USB1T11A OEn. Other parts such as the Philips ISP1105 offer more features such as larger I/O voltage range, and soft connect. The ISP1105 and many other USB transcievers use a single pair of pins for transmit and receive. Thus a tri-state buffer must be implemented in order to connect the two seperate transmit receive pairs between the core and the transceiver, with 'USBWireCtrlOut' used to control the tri-state buffer output enable.