Usbip
A Rust library to run a USB/IP server
A Rust library to run a USB/IP server to simulate USB devices and share real USB devices over a network. The project is written primarily in Rust, distributed under the MIT License license, first published in 2020. Key topics include: usb-cdc, usb-hid, usb-sharing, usbip.
usbip
A Rust library to run a USB/IP server to simulate USB devices and share real USB devices over a network.
What is USB/IP?
USB/IP is a network protocol that allows USB devices to be shared between computers over a network. It enables:
- Device simulation: Create virtual USB devices that can be accessed remotely
- Device sharing: Share physical USB devices from one machine to another
- Cross-platform: Works across different operating systems (Linux, etc.)
Installation
Prerequisites
Install Rust from the official documentation.
Building from source
bashgit clone https://github.com/jiegec/usbip.git cd usbip cargo build --release
How to use
Examples
The examples/ directory contains three example programs:
- hid_keyboard: Simulate a HID keyboard that types something every second
- cdc_acm_serial: Simulate a CDC ACM serial device that receives a character every second
- host: Act as a USB/IP server, sharing physical devices from the host machine to remote clients
Running an example
bashcargo run --example hid_keyboard
Connecting from a USB/IP client
On the client machine (e.g. Linux with USB/IP support):
bash# List available devices usbip list -r $remote_ip # Attach to a device usbip attach -r $remote_ip -b $bus_id
License
MIT License - see LICENSE file for details.
Contributors
Showing top 7 contributors by commit count.
