Keil Logo

Technical Support

On-Line Manuals

RL-ARM User's Guide (MDK v4)

RL-RTX RL-FlashFS RL-TCPnet RL-CAN RL-USB RL-USB for USB Device Applications RL-USB Device Library RL-USB Device Features RL-USB Device Software Stack RL-USB Device Functions RL-USB Device Source Files RL-USB Device Configuration Audio Device (ADC) Options Communication Device (CDC) - ACM Options Human Interface Device (HID) Options Mass Storage Device (MSC) Options Create USB Device Applications Create ADC Applications Create CDC ACM Applications Create HID Applications Create MSC Applications Create Composite Applications Test USB Device Applications Compliance Tests Test HID Client Application RL-USB for USB Host Applications RL-USB Host Library RL-USB Host Features RL-USB Host Software Stack RL-USB Host Functions RL-USB Host Source Files RL-USB Host Configuration Host Controller Driver Selection Host Controller Driver Configuration Host Class Driver Selection Create USB Host Applications Create USB Host HID Applications HID_Kbd Example Create USB Host MSC Applications Create USB Host Class Driver RL-USB Host Constants and Structures Error constants Speed constants Transaction Packet Type constants Transaction Error Type constants USB Request Block structure (USBH_URB) Endpoint structure (USBH_EP) Driver Capabilites structure (USBH_HCI_CAP) Device Class Instance structure (USBH_DCI) Host Controller Instance structure (USBH_HCI) Host Controller Driver structure (USBH_HCD) USB Concepts USB Transfer Rates USB Network Basic Communication Model USB Protocol Control Transfer Interrupt Transfer Isochronous Transfer Bulk Transfer Descriptors Device Configuration Device Descriptor Configuration Descriptor Interface Descriptor Endpoint Descriptor Device Qualifier Descriptor Example Programs Library Reference Appendix

Create USB Host HID Applications

Create USB Host HID Applications shows how to program a USB Host to support USB human interface devices using the RL-USB Library.

Include into the project and configure the following RL-USB Host Source Files:

  1. The USB library that matches the device core:
    USB_CM1.lib - for Cortex-M1 devices.
    USB_CM3.lib - for Cortex-M3 devices.
    USB_ARM_L.lib - for ARM7 or ARM9 devices.
  2. usbh_ohci_device family.c - to configure the device hardware layer (for devices with OHCI host controllers).
  3. usb_config.c - to configure the USB system.
  4. main file.c - to initialize the USB Host from main().
    ..
    usbh_init(0);                                            // initialize USB Host Controller 0
    while(1) {
      ..
      usbh_engine(0);                                        // check for new devices
      ..
    }
    

Several µVision USB Host HID projects can be used as a template for creating new USB Host HID applications. The files can be edited directly or using the µVision Configuration Wizard.

  1. Copy all files from any folder \ARM\Boards\Vendor\Board\RL\USB\Host\HID_Kbd to a new folder and open the *.uvproj project with µVision.
  2. Open the file usb_config.c and set USB Host.

For USB Host devices that support OHCI:

  1. Enable the option USB Host x and select OHCI for Controller Interface.
    Config OHCI USB Host Controller
  2. In the Class Configuration section, enable Human Interface Device Class (HID).
  3. Open the file usbh_ohci_device family.c and set the USB Host OHCI Settings.
    Config OHCI Settings

For USB Host devices that support a Custom USB Host Controller:

  1. Enable the option USB Host x and select Custom for Controller Interface.
    Config Custom USB Host Controller
  2. In the Class Configuration section, enable Human Interface Device Class (HID).
  3. Open the file usbh_device family.c and set the Custom USB Host Controller Settings.
    Config Custom Settings

Note

  Arm logo
Important information

This site uses cookies to store information on your computer. By continuing to use our site, you consent to our cookies.

Change Settings

Privacy Policy Update

Arm’s Privacy Policy has been updated. By continuing to use our site, you consent to Arm’s Privacy Policy. Please review our Privacy Policy to learn more about our collection, use and transfers
of your data.