emUSB-Device CDC-ECM class
emUSB-Device Communication Device Class - Ethernet Control Model (CDC-ECM) enables a USB device to act as a virtual network adapter. This can be used to run TCP/IP-based applications over USB.
- Makes any TCP/IP application available using USB
- No host driver needed for macOS & Linux
- Small footprint, typically 1.2KB RAM and 1.6KB ROM
The most noteworthy application is a USB-based webserver. The USB webserver allows users to configure their device and to view data using a web browser. This saves development costs as there is no need to develop an application for every major operating system which would allow the user to interact with the USB device. The hardware costs can also be reduced as an Ethernet interface is not required.
- USB to Ethernet adapter
- Configuring a USB device using a web browser
Application Samples emUSB-Device CDC-ECM Class
USB to Ethernet Adapter
emUSB-Device CDC-ECM comes as a complete package and contains the following components:
- CDC-ECM device class implementation
- Network interface driver which uses emNet as a TCP/IP stack
- A sample application demonstrating how to work with CDC-ECM
The CDC-ECM Class is a standard USB class protocol defined by the USB.org consortium.
A TCP/IP stack like emNet is required on the USB device side to handle the actual IP communication.
Any available IP protocol (UDP, TCP, FTP, HTTP, etc.) can be used to exchange data.
Linux kernel versions newer than 2.6.22 have full support for CDC-ECM. macOS supports CDC-ECM natively from version 10.4 (Tiger).
For Windows a CDC-ECM driver is required.
One Bulk IN, one Bulk OUT and one Interrupt IN endpoint are required for emUSB-Device CDC-ECM.
emUSB-Device CDC-ECM can be used in combination with other interfaces (Bulk, CDC, MSD, MTP, HID) without any issues.
On a typical Cortex-M CPU running at 120MHz a transfer speed of about 5 MB/s can be achieved when using a high-speed USB connection.
Components required to use CDC-ECM:
- emUSB CDC-ECM
- emUSB-Device core
- emUSB target driver
- emNet (IP stack)