Atmel AVR4950: ASF - USB Host Stack. 8-bit Atmel Microcontrollers. Application Note. Features. 1 Introduction



Similar documents
Atmel AVR4903: ASF - USB Device HID Mouse Application. Atmel Microcontrollers. Application Note. Features. 1 Introduction

Atmel AVR4921: ASF - USB Device Stack Differences between ASF V1 and V2. 8-bit Atmel Microcontrollers. Application Note. Features.

Atmel AVR4920: ASF - USB Device Stack - Compliance and Performance Figures. Atmel Microcontrollers. Application Note. Features.

How To Use An Atmel Atmel Avr32848 Demo For Android (32Bit) With A Microcontroller (32B) And An Android Accessory (32D) On A Microcontroller (32Gb) On An Android Phone Or

APPLICATION NOTE. Atmel AVR134: Real Time Clock (RTC) Using the Asynchronous Timer. Atmel AVR 8-bit Microcontroller. Introduction.

AVR287: USB Host HID and Mass Storage Demonstration. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

Application Note. 8-bit Microcontrollers. AVR270: USB Mouse Demonstration

32-bit AVR UC3 Microcontrollers. 32-bit AtmelAVR Application Note. AVR32769: How to Compile the standalone AVR32 Software Framework in AVR32 Studio V2

AVR115: Data Logging with Atmel File System on ATmega32U4. Microcontrollers. Application Note. 1 Introduction. Atmel

AVR32701: AVR32AP7 USB Performance. 32-bit Microcontrollers. Application Note. Features. 1 Introduction

AT09333: USB Host Interface (UHI) for Communication Class Device (CDC) Introduction. Atmel Microcontrollers APPLICATION NOTE

Application Note. Atmel ATSHA204 Authentication Modes. Prerequisites. Overview. Introduction

Atmel AVR1017: XMEGA - USB Hardware Design Recommendations. 8-bit Atmel Microcontrollers. Application Note. Features.

Atmel AVR4905: ASF - USB Device HID Generic. 8-/32-bit Atmel Microcontrollers. Application Note. Features. 1 Introduction

APPLICATION NOTE. Atmel AT04389: Connecting SAMD20E to the AT86RF233 Transceiver. Atmel SAMD20. Description. Features

APPLICATION NOTE. Atmel AT02985: User s Guide for USB-CAN Demo on SAM4E-EK. Atmel AVR 32-bit Microcontroller. Features. Description.

USER GUIDE EDBG. Description

AVR1922: Xplain Board Controller Firmware. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

APPLICATION NOTE Atmel AT02509: In House Unit with Bluetooth Low Energy Module Hardware User Guide 8-bit Atmel Microcontroller Features Description

Atmel AVR4027: Tips and Tricks to Optimize Your C Code for 8-bit AVR Microcontrollers. 8-bit Atmel Microcontrollers. Application Note.

Application Note. Atmel CryptoAuthentication Product Uses. Atmel ATSHA204. Abstract. Overview

Introducing a platform to facilitate reliable and highly productive embedded developments

AVR1510: Xplain training - XMEGA USART. 8-bit Microcontrollers. Application Note. Prerequisites. 1 Introduction

Atmel AVR4904: ASF - USB Device HID Keyboard Application. Atmel Microcontrollers. Application Note. Features. 1 Introduction

APPLICATION NOTE. Atmel LF-RFID Kits Overview. Atmel LF-RFID Kit. LF-RFID Kit Introduction

APPLICATION NOTE. Atmel AVR443: Sensor-based Control of Three Phase Brushless DC Motor. Atmel AVR 8-bit Microcontrollers. Features.

AVR1900: Getting started with ATxmega128A1 on STK bit Microcontrollers. Application Note. 1 Introduction

TivaWare USB Library USER S GUIDE SW-TM4C-USBL-UG Copyright Texas Instruments Incorporated

AVR319: Using the USI module for SPI communication. 8-bit Microcontrollers. Application Note. Features. Introduction

AVR1321: Using the Atmel AVR XMEGA 32-bit Real Time Counter and Battery Backup System. 8-bit Microcontrollers. Application Note.

AVR125: ADC of tinyavr in Single Ended Mode. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

AVR1309: Using the XMEGA SPI. 8-bit Microcontrollers. Application Note. Features. 1 Introduction SCK MOSI MISO SS

AVR317: Using the Master SPI Mode of the USART module. 8-bit Microcontrollers. Application Note. Features. Introduction

Using CryptoMemory in Full I 2 C Compliant Mode. Using CryptoMemory in Full I 2 C Compliant Mode AT88SC0104CA AT88SC0204CA AT88SC0404CA AT88SC0808CA

APPLICATION NOTE. Atmel AT01095: Joystick Game Controller Reference Design. 8-/16-bit Atmel Microcontrollers. Features.

8-bit. Application Note. Microcontrollers. AVR282: USB Firmware Upgrade for AT90USB

AVR32788: AVR 32 How to use the SSC in I2S mode. 32-bit Microcontrollers. Application Note. Features. 1 Introduction

UM1734 User manual. STM32Cube USB device library. Introduction

AT91SAM ARM-based Flash MCU. Application Note

8051 Flash Microcontroller. Application Note. A Digital Thermometer Using the Atmel AT89LP2052 Microcontroller

How To Design An Ism Band Antenna For 915Mhz/2.4Ghz Ism Bands On A Pbbb (Bcm) Board

AVR1318: Using the XMEGA built-in AES accelerator. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

AVR151: Setup and Use of the SPI. Introduction. Features. Atmel AVR 8-bit Microcontroller APPLICATION NOTE

AT89C5131A Starter Kit... Software User Guide

Application Note. 8-bit Microcontrollers. AVR293: USB Composite Device

AVR32138: How to optimize the ADC usage on AT32UC3A0/1, AT32UC3A3 and AT32UC3B0/1 series. 32-bit Microcontrollers. Application Note.

Freescale MQX USB Device User Guide

SMARTCARD XPRO. Preface. SMART ARM-based Microcontrollers USER GUIDE

General Porting Considerations. Memory EEPROM XRAM

AVR305: Half Duplex Compact Software UART. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

Software Prerequisites Linux Ubuntu LTS. Estimated completion time: 15min. The goal of this hands-on is to:

AVR033: Getting Started with the CodeVisionAVR C Compiler. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

AVR1301: Using the XMEGA DAC. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

Atmel AT32UC3A3256 microcontroller 64MBit SDRAM Analog input (to ADC) Temperature sensor RC filter

USER GUIDE. ZigBit USB Stick User Guide. Introduction

APPLICATION NOTE. AT07175: SAM-BA Bootloader for SAM D21. Atmel SAM D21. Introduction. Features

APPLICATION NOTE. Atmel AVR600: STK600 Expansion, Routing and Socket Boards. Atmel Microcontrollers. Introduction

Application Note. USB Mass Storage Device Implementation. USB Microcontrollers. References. Abbreviations. Supported Controllers

Application Note. 8-bit Microcontrollers. AVR272: USB CDC Demonstration UART to USB Bridge

AN3998 Application note

HANDLING SUSPEND MODE ON A USB MOUSE

AT88CK490 Evaluation Kit

AVR1600: Using the XMEGA Quadrature Decoder. 8-bit Microcontrollers. Application Note. Features. 1 Introduction. Sensors

AN3354 Application note

CryptoAuth Xplained Pro

8-bit Microcontroller. Application Note. AVR134: Real-Time Clock (RTC) using the Asynchronous Timer. Features. Theory of Operation.

AVR134: Real Time Clock (RTC) using the Asynchronous Timer. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

APPLICATION NOTE. Secure Personalization with Transport Key Authentication. ATSHA204A, ATECC108A, and ATECC508A. Introduction.

Freescale MQX RTOS USB Host User s Guide

AVR106: C Functions for Reading and Writing to Flash Memory. Introduction. Features. AVR 8-bit Microcontrollers APPLICATION NOTE

Application Note. 1. Introduction. 2. Associated Documentation. 3. Gigabit Ethernet Implementation on SAMA5D3 Series. AT91SAM ARM-based Embedded MPU

AVR315: Using the TWI Module as I2C Master. Introduction. Features. AVR 8-bit Microcontrollers APPLICATION NOTE

APPLICATION NOTE. Atmel AT01180: Barcode and QR code scanner User Guide. Atmel 32-bit Microcontroller. Features. Introduction

AVR106: C functions for reading and writing to Flash memory. 8-bit Microcontrollers. Application Note. Features. Introduction

APPLICATION NOTE. Authentication Counting. Atmel CryptoAuthentication. Features. Introduction

An introduction to nxpusblib. March 2012

APPLICATION NOTE. Atmel AVR911: AVR Open Source Programmer. 8-bit Atmel Microcontrollers. Features. Introduction

Atmel AVR ATxmega384C3 microcontroller OLED display with pixels resolution Analog sensors. Ambient light sensor Temperature sensor

Atmel ATSAM3X8E microcontroller Atmel AT86RF GHz radio transceiver Atmel proprietary Lightweight Mesh software stack 10/100Mbps Ethernet

PL-2303 (Chip Rev H, HX, X) USB to Serial Adapter Windows Driver Installer Manual

AT91 ARM Thumb Microcontrollers. Application Note. AT91 USB CDC Driver Implementation. 1. Introduction. 2. Related Documents

APPLICATION NOTE. AT16268: JD Smart Cloud Based Smart Plug Getting. Started Guide ATSAMW25. Introduction. Features

AVR030: Getting Started with IAR Embedded Workbench for Atmel AVR. 8-bit Microcontrollers. Application Note. Features.

AVR2006: Design and characterization of the Radio Controller Board's 2.4GHz PCB Antenna. Application Note. Features.

Application Note. C51 Bootloaders. C51 General Information about Bootloader and In System Programming. Overview. Abreviations

Universal Serial Bus Implementers Forum EHCI and xhci High-speed Electrical Test Tool Setup Instruction

Atmel AVR1618: ATxmegaB ASCII Character Mapping. 8-bit Atmel Microcontrollers. Application Note. Features. 1 Introduction

8-bit Microcontroller. Application Note. AVR105: Power Efficient High Endurance Parameter Storage in Flash Memory

Application Note. 8-bit Microcontrollers. AVR280: USB Host CDC Demonstration. 1. Introduction

MODFLEX MINI GATEWAY ETHERNET USER S GUIDE

AVR311: Using the TWI Module as I2C Slave. Introduction. Features. AVR 8-bit Microcontrollers APPLICATION NOTE

Useful USB Gadgets on Linux

AVR353: Voltage Reference Calibration and Voltage ADC Usage. 8-bit Microcontrollers. Application Note. Features. 1 Introduction

etpu Host Interface by:

AN AES encryption and decryption software on LPC microcontrollers. Document information

AVR32807: Getting Started with the AVR UC3 Software Framework USB Classes. 32-bit Microcontrollers. Application Note. Features.

AVR131: Using the AVR s High-speed PWM. Introduction. Features. AVR 8-bit Microcontrollers APPLICATION NOTE

AT12181: ATWINC1500 Wi-Fi Network Controller - AP Provision Mode. Introduction. Features. Atmel SmartConnect APPLICATION NOTE

Designing Feature-Rich User Interfaces for Home and Industrial Controllers

8-bit Microcontroller. Application Note. AVR415: RC5 IR Remote Control Transmitter. Features. Introduction. Figure 1.

Transcription:

Atmel AVR4950: ASF - USB Host Stack Features USB 2.0 compliance - Chapter 9 - Control, Bulk, Isochronous and Interrupt transfer types - Low Speed (1.5Mbit/s), Full Speed (12Mbit/s), High Speed (480Mbit/s) data rates Low stack size Real time (OS compliance, no latency) Interrupt driven Speed performance using USB DMA Low power modes USB HUB Major USB classes and ready to use (HID, CDC, MSC, PHDC, AUDIO) Composite device 8-bit and 32-bit AVR platforms GCC and IAR compilers 8-bit Atmel Microcontrollers Application Note 1 Introduction This document introduces the USB host stack. This stack is included in the Atmel AVR Software Framework (ASF), and aims to provide the customer with the quickest and easiest way to build a USB embedded host application. Also this USB host stack is oriented low footprint and low power. A full description of this stack is available in this document. Rev.

2 Abbreviations ASF: AVR Software Framework CBW: Command Block Wrapper (from Mass Storage Class) CDC: Communication Device Class CSW: Command Status Wrapper (from Mass Storage Class) DP or D+: Data Plus differential line DM or D-: Data Minus differential line EHCI: Enhanced Host Controller Interface FS: USB Full Speed HID: Human interface device HS: USB High Speed LS: USB Low Speed MSC: Mass Storage Class OHCI: Open Host Controller Interface PHDC: Peripheral Health Device Class PIPE: Data buffer to manage an endpoint transfer in host mode sleepmgr: Sleep management service from ASF UDC: USB Device Controller UDD: USB Device Descriptor UDI: USB Device Interface : USB Host Controller UHD: USB Host Descriptor UHI: USB Host Interface USB: Universal Serial Bus USBB: USB hardware interface version B for 32-bit Atmel core USBC: USB hardware interface version C for 32-bit Atmel core STALL: USB token used to stop a USB transaction ZLP: Zero length packet 2 Atmel AVR4950

3 USB host application notes Atmel AVR4950 Several USB host examples are provided by Atmel. For each example, Atmel provides several application notes. Figure 3-1. USB host application notes. Application notes on USB host class AN AVR4953 AN AVR4954 AN AVR4955 ASF - USB host HID mouse ASF - USB host HID keyboard ASF - USB host HID Generic AN AVR4956 AN AVR4957 AN AVR4958 AN AVR4959 ASF - USB host MSC ASF - USB host CDC ASF - USB host PHDC ASF - USB host AUDIO Application notes for USB host vendor class AN AVR4950 ASF - USB host Stack AN AVR4951 ASF - USB host Vendor Class Basic USB knowledge is necessary to understand the USB host class application notes (Classes: HID, CDC, MSC, PHDC, AUDIO). To create a USB host with one of the ASF provided classes, refer directly to the related application note for this USB class. The USB host stack and USB host vendor class application notes are designed for advanced USB developers. 3

4 Organization 4.1 Overview The USB host stack is divided into three parts: NOTE The USB Host Controller (), providing USB Chapter 9 compliance The USB Host Interface (UHI), providing USB Class compliance The USB Host Driver (UHD), providing the USB interface for each Atmel product The USB host drivers are implemented in full interrupt mode, thus this UHD is a perfect base to create a USB driver for third party s USB stacks. This is applicable either for custom interface or for OHCI/EHCI interface. Figure 4-1. USB host stack architecture. USB host Stack Application UHIs UHD In case of dual (device/host) mode, the application note AVR4900: ASF USB Device stack is provided to describe the USB device stack. 4.2 Memory Footprint The USB host stack footprint depends on: Atmel core (megaavr, UC3) USB hardware version USB Class used Compiler and optimization level These parameters give different footprint values, but in average the USB host stack does not exceed 10Kbytes of FLASH and 1Kbytes of RAM using compiler highest optimization level. 4.3 USB host stack files 4 Atmel AVR4950 The USB host stack is available in Atmel AVR Studio 5 through the New Example Project wizard and Select ASF Modules wizard. Accessing examples is done by browsing the examples list or simply by typing "host" in the search field. NOTE Tip: Select Technology USB to reduce examples list in AVR Studio 5.

Atmel AVR4950 NOTE The example names including «From ASF V1» refer to former implementation of USB host stack from ASF v1.7 which is beyond the scope of this application note. 4.3.1 Common files for all products Files Defines USB constants usb_protocol.h* (from usb.org) usb_atmel.h* (from Atmel) files uhc.c/h uhi.h uhd.h Classes Protocols files usb_protocol_<class>.h* Paths common/services/usb/ common/services/usb/uhc/ common/services/usb/class/<class>/ NOTE UHI files common/services/usb/class/foo/host/ uhi_foo.c/h * These files are common with USB device stack. 4.3.2 UHD files depending on selected products NOTE avr32/drivers/usbb/usbb_host.c/h avr32/drivers/usbb/usbb_otg.h* avr32/drivers/usbc/usbc_host.c/h avr32/drivers/usbc/usbc_otg.h* * These files are common with the USB device stack. 4.3.3 Specific file for each application Application file to configure USB host stack (see Chapter 7 Configuration, and Table 5-3) usb_conf_host.h 5

5 Application programming interface This section describes all APIs except the UHI APIs, which are described in a separate document. Figure 5-1. USB modules. Application External API from Described in this document UHI - External API from UHI Described in external UHI documents UHD Internal API Described in this document for USB experts 5.1 External API from The external API allows the application to manage common USB host behavior and receive common USB host events. These controls and events are common to any USB application. Input functions Callback functions Table 5-1. External API from Input functions. Declaration Description uhc_start() Start the host mode. uhc_stop(bool b_id_stop) Stop the host mode and stop control of USB ID pin, if requested by b_id_stop. uhc_suspend(bool b_remotewakeup) Suspend the USB line. This authorize or not the remote wakeup features of each devices. uhc_is_suspend() Test if the suspend state is enabled on the USB line. uhc_resume() Resume the USB line. 6 Atmel AVR4950

Atmel AVR4950 Table 5-2. External API from Input functions concerning connected devices. Declaration uint8_t uhc_get_device_number() char* uhc_dev_get_str_manufacturer( uhc_device_t*dev) char* uhc_dev_get_str_product( uhc_device_t*dev) char* uhc_dev_get_str_serial( uhc_device_t*dev) char* uhc_dev_get_str( uhc_device_t*dev, uint8_t str_id) uint16_t uhc_dev_get_power( uhc_device_t*) uhd_speed_t uhc_dev_get_speed( uhc_device_t*) bool uhc_dev_is_high_speed_support( uhc_device_t*) Description Return the number of devices connected. Return the string ASCII manufacturer corresponding at USB device. Return the string ASCII product corresponding at USB device. Return the string ASCII serial corresponding at USB device. Return the USB string ASCII corresponding at the string ID. Get the maximum consumption of a device (ma). Return the current device speed. Return true if it is the device supports high speed. All callbacks are optional and defined by the user in conf_usb_host.h file for each application. Table 5-3. External API from Callback functions. Define name Description _MODE_CHANGE( bool b_host_mode) _VBUS_CHANGE(bool b_present) _VBUS_ERROR() _CONNECTION_EVENT( uhc_device_t* dev, bool b_present) _WAKEUP_EVENT() _SOF_EVENT() _DEVICE_CONF( uhc_device_t* dev) To notify that the USB mode are switched automatically. This is possible only when ID pin is available. To notify that the V BUS level has changed (Available only in USB hardware with V BUS monitoring). To notify that a V BUS error has occurred (Available only in USB hardware with V BUS monitoring). To notify that a device has been connected or disconnected. Called when a USB device or the host have wake up the USB line. Called for each received SOF each 1ms. Note: Available in High and Full speed mode. Called when a USB device configuration must be chosen. Thus, the application can choose either a configuration number for this device or a configuration number 0 to reject it. If callback not defined the configuration 1 is chosen. 7

Define name _ENUM_EVENT ( uhc_device_t* dev, uhc_enum_status_t status) Description Called when a USB device enumeration is completed. The status can be: - _ENUM_SUCCESS Device is bus enumerated with at least one supported interface. - _ENUM_UNSUPPORTED All interfaces are not supported by UHIs. - _ENUM_OVERCURRENT Device power can not be supported - _ENUM_FAIL A problem has been occurred during USB enumeration. - _ENUM_HARDWARE_LIMIT USB hardware can not support it. Not enough free pipes. - _ENUM_SOFTWARE_LIMIT USB software can not support it. Implementaion limit. - _ENUM_MEMORY_LIMIT USB software can not support it. Not enough memory. 5.2 Internal APIs The following definitions are defined for advanced USB users who intend to develop a specific USB host, not provided in ASF. Figure 5-2. Internal USB host API overview. 2 1 UHI - Linked at compilation 3 4 5 UHD Callback linked during firmware execution NOTE Numbers are references for tables below. Table 5-4. UHI input from (1). Declaration Description uhc_enum_status_t (*install)(uhc_device_t*) void (*uninstall)(uhc_device_t*) void (*enable)(uhc_device_t*) Install interface if supported by new device (allocation of endpoints). Uninstall the interface if installed for this device. Called to start the USB interface of the device. 8 Atmel AVR4950

Declaration void (*sof_notify)(bool b_micro) Description Atmel AVR4950 Called by to notify a SOF event on the enabled USB interface. Note: The UHI API are stored in USB_HOST_UHI array, see Table 7-1. Table 5-5. input from UHD (3). Declaration Description uhc_start() Start the host mode. uhc_stop(bool b_id_stop) Stop the host mode and USB ID pin management if requested by b_id_stop. uhc_notify_connection(bool b_plug) uhc_notify_sof(bool b_micro) uhc_notify_resume() Called when a device has been connected or disconnected. Called when a SOF is sent. Called when resume bus state occurs. After a downstream or an upstream resume. Table 5-6. UHD input (4). Declaration Caller Description uhd_enable() Enables the USB host mode and ID management if the ID pin is available. uhd_disable(bool b_id_stop) Disables the USB host mode and USB ID pin management if requested by b_id_stop. uhd_speed_t uhd_get_speed() /UHI To check the speed of device connected to USB interface port (not device connected on a USB hub). uint16_t uhd_get_frame_number() Application Returns the current start of frame number. uint16_t uhd_get_microframe_number() Application Returns the current micro start of frame number. uhd_send_reset ( uhd_callback_reset_t callback) The USB driver enables the reset state on the USB line. uhd_suspend() The USB driver enables the suspend state on the USB line. uhd_is_suspend() Test if the suspend state is enabled on the USB line. uhd_resume() The USB driver enables the IDLE state on the USB line. ( Downstream Resume ) bool uhd_setup_request( usb_add_t add, usb_setup_req_t req, uint8_t *payload, uint16_t payload_size, uhd_callback_setup_run_t callback_run, uhd_callback_setup_end_t callback_end) bool uhd_ep0_alloc( usb_add_t add, uint8_t ep_size) bool uhd_ep_alloc( usb_add_t add, usb_ep_desc_t *ep_desc) /UHI Add this setup request, in the control endpoint setup queue. (Request timeout is 5s) Enables control endpoint 0. Enables endpoints (except control endpoint). uhd_ep_free(usb_add_t add, usb_ep_t endp) Disables one endpoint or all endpoints of a device. 9

Declaration Caller Description bool uhd_ep_run( usb_add_t add, usb_ep_t endp, bool b_shortpacket, uint8_t *buf, iram_size_t buf_size, uint16_t timeout, uhd_callback_trans_t callback) uhd_ep_abort( usb_add_t add, usb_ep_t endp) UHI UHI Starts/stops a data transfer in or out on an endpoint. The schedule of the transfer is managed by UHD. Note: The control endpoint is not authorized here. Table 5-7. UHD callback (5). Declaration typedef void (*uhd_callback_reset_t)(void); typedef bool (*uhd_callback_setup_run_t)( usb_add_t add, uint8_t **payload, uint16_t *payload_size ); typedef void (*uhd_callback_setup_end_t)( usb_add_t add, uhd_trans_status_t status, uint16_t payload_trans); typedef void (*uhd_callback_trans_t) ( usb_add_t add, uhd_trans_status_t status, iram_size_t nb_transfered) uhd_trans_status_t Description Called when the reset event, requested via uhd_send_reset(), is completed. Called when the (payload) buffer, assigned via uhd_setup_request() is full or empty. Then the setup request is hold. A new buffer can be provided to restart the setup request or the setup request will be aborted. Called when the setup request is completed. This callback is given via uhd_setup_request() routine. Called when a transfer request is completed or cancelled. This request is registered via uhd_ep_run(). This structure is updated after every attempted transaction, whether successful or not. If the transaction is successful, then the status field is set to: - UHD_TRANS_NOERROR. Otherwise, it is set according to the following transmission error types: - UHD_TRANS_CRC, CRC error in data packet. - UHD_TRANS_DISCONNECT, device is disconnected. - UHD_TRANS_DT_MISMATCH, data toggle PID did not match the expected value. - UHD_TRANS_STALL, the endpoint returned a STALL PID. - UHD_TRANS_NOT_RESPONDING, Device did not respond to token (IN) or did not provide a handshake (OUT). - UHD_TRANS_PID_FAILURE, Check bits on PID from endpoint failed. - UHD_TRANS_TIMEOUT, Data transmission not completed before timeout. - UHD_TRANS_ABORTED, Data transmission has been aborted. 10 Atmel AVR4950

5.3 Device connected information NOTE Table 5-8. UHD input for High Speed application only (4). Declaration Caller Description uhd_test_mode_j() uhd_test_mode_k() uhd_test_mode_se0_nak() uhd_test_mode_packet() Atmel AVR4950 Features to enable a specific signal on a USB HS port. These are requested to run a USB host HS certification. The manages the devices via a structure called uhc_device_t, which stores many information about the devices connected on the USB tree. The global variable g_uhc_device_root contains the information about the first device connected and it is the first element of the device list. The user application can read this list to get information on current USB tree. There is no USB tree limitation, because the device list and the USB descriptor fields allocations are dynamic and require the standard allocation library (e.g. alloc()). The uhc_device_t structure includes: A pointer on the USB device descriptor A pointer on the USB configuration descriptor the USB device address the USB device speed pointers on parent USB HUB device (for USB HUB support only) HUB port number connection (for USB HUB support only) Figure 5-3. uhc_device_t definition. uhc_device_t g_uhc_device_root usb_dev_desc_t dev_desc usb_conf_desc_t *conf_desc uint8_t address uhd_speed_t speed uhc_device_t *prev uhc_device_t *next uhc_device_t *hub uint8_t hub_port uint16_t power Device Descriptor Device Configuration Descriptor uhc_device_t uhc_device_t uhc_device_t For USB HUB support only Legend: From USB 2.0 ASF struct... 11

6 USB host stack behavior This chapter aims to answer advanced USB usage questions and introduce the USB host stack behavior. The following sections describe the interaction between the different layers for these steps: USB dual roles management USB V BUS management USB device connection management USB device enumeration management 6.1 Dual roles When the USB hardware has the possibility to work in USB device and in USB host mode, the user can implement a dual role application. This application will switch between a USB device and a USB host task following the USB ID pin level (from OTG specification) or a custom process. The USB host stack provides three possibilities to manage the dual role: manual, automatic and semi-automatic. The manual dual role must be used when ID pin is not available. In this case, a custom process manages the dual role. The automatic and semi-automatic dual role must be used when ID pin is managed by the USB hardware interface. The semi-automatic dual role allows delaying the start of USB device and USB host mode when the ID pin change. This possibility is enabled when UHD_START_MODE_MANUAL is defined (See Table 7-2). 12 Atmel AVR4950

Atmel AVR4950 Figure 6-1. USB manual dual role. App USB device/host stacks Custom event uhc_stop() Switch from host to device mode udc_start() USB device mode running Custom event udc_stop() Switch from device to host mode uhc_start() USB host mode running Figure 6-2. USB semi-automatic dual role. App USB device/host stacks Start dual role uhc_start() The ID pin is not tide to ground. (OTG connector unplugged) _MODE_CHANGE(false) Stop host auto App can wait before start device mode USB device mode running App can wait before start host mode USB host mode running udc_start() _MODE_CHANGE(true) uhc_start() The ID pin tides to ground. (OTG connector plugged) Stop device auto USB interrupts 13

Figure 6-3. USB automatic dual role. App USB device/host stacks Start dual role uhc_start() The ID pin is not tide to ground. (OTG connector unplugged) Just to notify application but not mandatory USB device mode running _MODE_CHANGE(false) Stop host auto Start device auto The ID pin tides to ground. (OTG connector plugged) Just to notify application but not mandatory USB host mode running _MODE_CHANGE(true) Stop device auto Start host auto USB interrupts 14 Atmel AVR4950

Atmel AVR4950 6.2 V BUS management Figure 6-4. V BUS management. App UHD Start host mode uhc_start() V BUS always on uhd_enable() USB host mode running Start host mode uhc_stop() uhd_disable() V BUS controlled by application Start host mode Turn on V BUS uhc_start() uhd_enable() USB host mode running Start host mode Turn off V BUS uhc_stop() uhd_disable() Start host mode USB host mode running V BUS controlled by USB Driver (VBOF) uhc_start() uhd_enable() _VBUS_CHANGE(true) _VBUS_ERROR() Turn on V BUS V BUS high V BUS error Start host mode uhc_stop() uhd_disable() Turn off V BUS USB interrupts 15

6.3 Device connection Figure 6-5. USB device connection. UHD Device plugged _CONNECTION_EVENT() USB RESET USB IDLE 20ms USB RESET USB IDLE 100ms Setup request - Get device descriptor (Default control endpoint size = 64B, and fill uhc_device_t.dev_desc.bmaxpa cketsize0) USB IDLE 20ms USB RESET USB IDLE 100ms Setup request - Set address USB IDLE 20ms Setup request - Get device descriptor (Fill uhc_device_t.dev_desc) uhc_connection(true) uhd_send_reset() Reset callback uhc_sof() uhd_send_reset() Reset callback uhc_sof() uhd_setup_request() Setup callback uhc_sof() uhd_send_reset() Reset callback uhc_sof() uhd_setup_request() Setup callback uhc_sof() uhd_setup_request() End of reset SOF End of reset SOF Setup ACK IN ACK ZLP OUT ACK SOF End of reset SOF Setup SOF USB interrupts NOTE NOTE This sequence is the same for the device connected thru a USB HUB, but the connection and reset events are managed via USB HUB setup request. When the USB device enumeration fails four times, the USB line of the device is set in USB SUSPEND mode. 16 Atmel AVR4950

Atmel AVR4950 6.4 Device enumeration Figure 6-6. USB device enumeration (single USB configuration). Send request Get configuration descriptor 1 Fill uhc_device_t.conf_desc UHI UHI UHD uhd_setup_request() Setup end uhi_install() Call the UHIs to install (allocate endpoints) the new supported USB interface. No supported uhi_install() uhd_ep_alloc() Send request Set configuration 1 _ENUM_EVENT( _ENUM_SUCCESS) Enable all UHI modules. The UHI module(s) can send a setup interface request. Supported uhi_enable() uhi_enable() uhd_setup_request() uhd_setup_request() Setup end Setup end The UHI module receives the result of the setup interface request and can continue the initialization of USB interface. Here, a transfer is start on an endpoint. uhd_ep_run() USB interrupts NOTE Here the callback _DEVICE_CONF() is not defined, thus the device configuration 1 is chosen by default. 17

Figure 6-7. USB device enumeration (multiple USB configurations). UHI UHD _DEVICE_CONF () Which return the configuration number chosen (N) Send request Get configuration descriptor N Fill uhc_device_t.conf_desc uhd_setup_request() Setup end Call the UHIs to find unless one supported USB interface and allocate endpoints of valid interface(s). Send request Set configuration N uhi_valid() uhi_alloc() uhd_ep_alloc() uhd_setup_request() Setup end _ENUM_EVENT() USB interrupts User code example to support a known device with multiple configurations: <conf_usb.h> #define _DEVICE_CONF(dev) user_choose_usb_conf(dev) <User C file>: uint8_t user_choose_usb_conf(uhc_device_t* dev) { if ((dev->dev_desc.idvendor == 0x1234) && (dev->dev_desc.idproduct == 0x5678)) { Assert(dev->dev_desc.bNumConfigurations>=2); return 2; // The configuration 2 is chosen } return 0; // No conf chosen because of unknown device } 18 Atmel AVR4950

Atmel AVR4950 7 Configuration The application s configurations are defined in the conf_usb_host.h file. This file must be created for each application, and this action requires a basic USB knowledge. The conf_usb_host.h file defines the following configurations: USB host configuration USB host interface configuration USB host driver configuration 7.1 USB host configuration The following configuration must be included in the conf_usb.h file of the application, which is the main USB device configuration. Table 7-1. USB host configuration. Define name Type Description USB_HOST_UHI Array of UHI APIs Define the list of UHI supported by USB host. Example: #define USB_HOST_UHI UHI_MSC, UHI_HID_MOUSE USB_HOST_POWER_MAX ma Maximum current allowed on V BUS. USB_HOST_HUB_SUPPORT (1) Only defined Authorize the USB HUB support. (Available for release ASF3) USB_HOST_HS_SUPPORT (1) Only defined Authorize the USB host to run in High Speed. Note: 1. Optional configuration. Comment the define statement to disable it (ex: // #define USB_HOST_X). 7.2 USB host interface configuration 7.3 USB host drivers configuration The UHI configurations are described in USB host class application notes. The USB hardware interface can provide specific features which can be enabled in conf_usb_host.h file, in conf_board.h file and in project options. Table 7-2. USB host driver configuration in conf_usb_host.h. Define name Values UHD Description UHD_NO_SLEEP_MGR Only All Remove the management of sleepmgr service. defined UHD_ISOCHRONOUS_NB_BANK 1, 2, 3 USBB Reduces or increases isochronous endpoint buffering. Default value if not defined: 2 UHD_BULK_NB_BANK 1, 2, 3 USBB Reduces or increases bulk endpoint buffering. Default value if not defined: 2 UHD_INTERRUPT_NB_BANK 1, 2, 3 USBB Reduces or increases interrupt endpoint buffering. Default value if not defined: 1 UHD_INT_LEVEL 0 to 3 USBB USBC Sets the USB interrupt level on AVR32 cores. Default value if not defined: 0 (recommended) 19

Define name Values UHD Description UHD_START_MODE_MANUAL Only defined USBB USBC By default, when the ID pin is available (USB_ID defined), the host or device mode are stopped and started automatically when the ID pin changes. This automatically start can be disabled, but the automatically stop mode remains. Table 7-3. USB host driver configuration in conf_board.h. Define name Values UHD Description USB_ID AVR32_USBB_USB_ID_x_x AVR32 - USBB Define the input pin connected to ID pin from USB connector. This enables usage of USB ID pin from OTG connector. If not defined, the ID pin usage is disabled. USB_ID AVR32_USBC_USB_ or AVR32_USBC_USB_x AVR32 - USBC Define the input pin connected to ID pin from USB connector. This enables usage of USB ID pin from OTG connector. If not defined, the ID pin usage is disabled. USB_VBOF AVR32_USBB_USB_VBOF_x_x AVR32 - USBB Define the output pin connected to enable pin of V BUS generator. This enables usage of V BUS control by the USB hardware interface. If not defined, the V BUS control is disabled. USB_VBOF AVR32_USBC_USB_VBOF or AVR32_USBC_USB_VBOF_x AVR32 - USBC USB_VBOF_ACTIVE_LEVEL LOW or HIGH AVR32 - USBB AVR32 - USBC Define the output pin connected to enable pin of V BUS generator. This enables usage of V BUS control by the USB hardware interface. If not defined, the V BUS control is disabled. Active level of the USB_VBOF output pin. Table 7-4. USB host/device driver configuration in project. Define name Values UHD Description UHD_ENABLE UDD_ENABLE Defined Defined USBB USBC These defines allow to know if the dual role (host & device) is enabled. 20 Atmel AVR4950

Atmel AVR4950 8 USB HUB support The USB host stack is able to support a USB tree through a USB HUB. However, the USB hardware interface provided on Atmel parts can limit the USB tree. Table 8-1. USB HUB hardware limitation. USB hardware interface Description USBB USBC Note: Number of pipes limited to seven or eight, but control endpoint multiplexed in one pipe. Does not support multiple USB speeds in same time on a USB tree. Number of pipes limited to seven, but control endpoint multiplexed in one pipe. Supports pipe multiplexing (1). Does not support multiple USB speeds in same time on a USB tree. 1. To avoid the limitation due to pipes number a multiplexing of the pipes is possible. However, the transfer scheduling must be done by software (UHD driver) instead of by USB hardware. 21

9 Power consumption The power modes available on Atmel products are supported by the USB hardware. All USB drivers implement the feature from sleepmgr service. Thus, the sleepmgr service initialization sleepmgr_init() must be called by the application prior any calls to the USB stack. 9.1 AVR32 core On AVR32 core, the clocks and oscillators can be automatically switched off during idle periods by using the sleep instruction on the CPU. Table 9-1. Sleep level supported in by USBB and USBC host drivers. USB state Maximum sleep mode authorized ID pin no active (wait host mode) STATIC No V BUS (wait V BUS event) STOP or FROZEN on UTMI parts (UTMI = high speed capability) V BUS present and device disconnected IDLE Suspend STATIC V BUS present and device connected IDLE without DMA IDLE IDLE + DMA running IDLE NOTE The sleep modes listed here may not be reached if any other software module than the USB stack requires a less profound sleep mode. 22 Atmel AVR4950

Atmel AVR4950 10 Table of Contents Atmel AVR4950: ASF - USB Host Stack... 1 Features... 1 1 Introduction... 1 2 Abbreviations... 2 3 USB host application notes... 3 4 Organization... 4 4.1 Overview... 4 4.2 Memory Footprint... 4 4.3 USB host stack files... 4 4.3.1 Common files for all products... 5 4.3.2 UHD files depending on selected products... 5 4.3.3 Specific file for each application... 5 5 Application programming interface... 6 5.1 External API from... 6 5.2 Internal APIs... 8 5.3 Device connected information... 11 6 USB host stack behavior... 12 6.1 Dual roles... 12 6.2 V BUS management... 15 6.3 Device connection... 16 6.4 Device enumeration... 17 7 Configuration... 19 7.1 USB host configuration... 19 7.2 USB host interface configuration... 19 7.3 USB host drivers configuration... 19 8 USB HUB support... 21 9 Power consumption... 22 9.1 AVR32 core... 22 10 Table of Contents... 23 23

Atmel Corporation 2325 Orchard Parkway San Jose, CA 95131 USA Tel: (+1)(408) 441-0311 Fax: (+1)(408) 487-2600 www.atmel.com Atmel Asia Limited Unit 01-5 & 16, 19F BEA Tower, Milennium City 5 418 Kwun Tong Road Kwun Tong, Kowloon HONG KONG Tel: (+852) 2245-6100 Fax: (+852) 2722-1369 Atmel Munich GmbH Business Campus Parkring 4 D-85748 Garching b. Munich GERMANY Tel: (+49) 89-31970-0 Fax: (+49) 89-3194621 Atmel Japan 16F, Shin Osaki Kangyo Bldg. 1-6-4 Osaki Shinagawa-ku Tokyo 104-0032 JAPAN Tel: (+81) 3-6417-0300 Fax: (+81) 3-6417-0370 2012 Atmel Corporation. All rights reserved. Atmel, Atmel logo and combinations thereof, AVR, AVR Studio, megaavr, and others are registered trademarks of Atmel Corporation or its subsidiaries. Other terms and product names may be trademarks of others. Disclaimer: The information in this document is provided in connection with Atmel products. No license, express or implied, by estoppel or otherwise, to any intellectual property right is granted by this document or in connection with the sale of Atmel products. EXCEPT AS SET FORTH IN THE ATMEL TERMS AND CONDITIONS OF SALES LOCATED ON THE ATMEL WEBSITE, ATMEL ASSUMES NO LIABILITY WHATSOEVER AND DISCLAIMS ANY EXPRESS, IMPLIED OR STATUTORY WARRANTY RELATING TO ITS PRODUCTS INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, CONSEQUENTIAL, PUNITIVE, SPECIAL OR INCIDENTAL DAMAGES (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS AND PROFITS, BUSINESS INTERRUPTION, OR LOSS OF INFORMATION) ARISING OUT OF THE USE OR INABILITY TO USE THIS DOCUMENT, EVEN IF ATMEL HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. Atmel makes no representations or warranties with respect to the accuracy or completeness of the contents of this document and reserves the right to make changes to specifications and product descriptions at any time without notice. Atmel does not make any commitment to update the information contained herein. Unless specifically provided otherwise, Atmel products are not suitable for, and shall not be used in, automotive applications. Atmel products are not intended, authorized, or warranted for use as components in applications intended to support or sustain life.