Thesycon’s USB device software stack implements the core functionality of a USB device and optionally provides device class specific protocols. It enables developers to easily add USB device functionality to embedded systems.
The software stack complies with the USB v1.1 and USB v2.0 specifications. It supports all transfer modes (control, bulk, interrupt, isochronous) at low, full and high speed. Complete USB request processing and extended error recovery mechanisms that are required for reliable operation are implemented internally.
The modular design allows to implement proprietary USB interfaces and standard device classes. The creation of composite devices which implement multiple logical functions on one physical controller as well as multi-configuration devices are fully supported.
Thesycon also offers the appropriate device drivers for PC and so it is able to provide complete software solutions.
The USB Function Library is a software layer which is designed to handle the complete USB function peripheral. It implements all USB standard requests, the required state machines and the data transfer. An embedded application program does not have to access the USB peripheral via registers, it simply uses the software API defined by the USB Function Library.
To use the USB Function API directly without a device class, basic USB knowledge is required.
The Bulk Loop Demo application included in the demo packages represents a plain sample for the usage of the USB Function Library without a device class.
The device class specific APIs provide a high abstraction level and are easy to use. No USB know-how is required.
The CDC/ACM protocol module implements a standard-compliant serial link (RS-232) emulation on top of USB. This provides an easy migration path for existing applications. Thesycon also offers an appropriate CDC/ACM class driver for Windows operating systems. The combination of the CDC/ACM device class and the CDC/ACM class driver for Windows allows to re-use existing Windows applications unmodified.
The CDC/ACM Loop Demo application included in the demo packages represents a plain sample for the usage of the CDC/ACM device class.
The CDC/ACM Multi Instance Loop Demo application included in the demo packages represents a plain sample for the usage of the CDC/ACM device class with multiple instances (so called composite device).
The RNDIS module implements an Ethernet emulation on top of USB. This approach is especially useful if an embedded system contains an Ethernet interface and a TCP/IP protocol implementation. A suitable RNDIS device driver is included in Windows and some other operating systems.
The RNDIS Simple IP Demo application included in the demo packages provides very basic IP protocol functionality to support ARP, ICMP and DHCP. So it is possible to attach the device to a PC and to test the USB connection by means of ping.
The Mass Storage protocol module emulates a disc drive with FAT or CD-ROM file system. It can be used to create a CD-less PC software installation, or to exchange static data files between the device and the PC. The required PC drivers are part of Windows, MacOS, and Linux. Under Windows the CD-ROM emulation supports the auto-run feature.
The Mass Storage Demo application included in the demo packages works as a block device driver for the memory. This sample implements the USB mass storage device that can expose multiple logical units (LUN). It supports the SCSI transparent command set and the emulation of CD-ROM and disk drives. The CD-ROM can be used to automatically start an application on Windows. A special compression algorithm can be used for ISO images. (At this time only integrated in the LPC1768 demo.)
The THID module implements a generic HID device (Human Interface Device). The device does not require a device driver installation under Windows. It uses the in-box HID class driver. Applications can communicate with the THID device by means of Windows HID API functions. Thesycon provides sample application source code.
The THID Loop Demo application included in the demo packages is designed to demonstrate and test the data exchange.
The USB stack firmware is written in ANSI-C and can be ported to any hardware platform. For easy integration the software is designed as a library and provided as source code. The library does not depend on any specific operating system support. It can be integrated into any embedded OS, or can be used in stand-alone applications. Hardware access is encapsulated by a Hardware Abstraction Layer (HAL) which needs to be implemented in a platform-specific way. The stack supports 32-bit and 16-bit CPUs and works in either endian mode.
Embedded USB Device Stack Product Sheet ![]()
Embedded USB Device Stack Manual ![]()
Mass Storage Device Class Manual ![]()
The code size and the memory requirements mainly depend on the processor architecture, the bit alignment as well as the used compiler and its optimization settings.
The following values are achieved on an ARM7 CPU in the release build without debug information. The ARM RealView compiler was used with default optimization (-O2). Data buffers as well as USB descriptors are not considered because they belong to the application layer. They have to be allocated in the application outside the Embedded USB Device Stack. Depending on the number of endpoints and the configuration of the device USB descriptors usually consume between 150 and 400 bytes of constant data.
When designing a USB device you need an official USB vendor ID (VID) which is unique world-wide. Vendor ID's will be assigned by the USB Implementers Forum (www.usb.org). There is a fee of $1500 US.
Thesycon owns a USB vendor ID and provides a subset of product ID's (PID) to customers who licensed our USB software.
If you would like to be kept informed of product updates, please subscribe to the Thesycon newsletter.
© 2011 THESYCON