USB Redirector for Linux
Setup and configuration of a systemd-Services
This tutorial explains how to install the USB Redirector for Linux and incorporate a USB device.
Here we presume you are starting from a freshly installed Ubunto 20.04 LTS system. The procedure for setup and configuration can however be applied to other distributions. The only prerequisite is that the following minimum requirements for the USB Redirector are met:
- Current Linux kernel (>=4.4.0)
- Support for the VHCI kernel module
- modprobe tool
Structure of the USB Redirector
The USB Redirector for Linux represents the link between the USB-Server and the kernel landscape.
Virtual USB devices are created on the Linux system using the open-source and common VHCI kernel module. The actual communication is then passed through the USB Redirector via TCP/IP to the USB-Server and the actual USB device.
The USB Redirector is divided into two separate modules.
The Redirector is operated in daemon mode as a background service. The daemon communicates with the kernel and must therefore be used with elevated rights.
As a counterpart to the background service the USB Redirector can be invoked in the application mode. This then instructs the background service to integrate or enable USB devices.
You activate the video function using the following button, whereby you use the provider Google and (at your own risk in terms of data protection ;) share data with it.
Preparation: Download USB Redirector
The latest version of the USB Redirector can always be downloaded at the address
https://www.wut.de/linux-usb-umlenkung
. The downloaded TAR archive can then be simply unzipped. On most desktops this is possible using the Windows Explorer in the context menu of the file.
If there is no desktop environment available on the destination system, the Redirector can also be downloaded and unzipped using the following command line:
wget -O redirector.tar.gz https://www.wut.de/linux-usb-umlenkung
tar -xzf ./redirector.tar.gz
After unzipping, check the newly created folder usb-redirector_v3.xx for the needed files.
Installation
The following step requires that a terminal in the folder with the installation files for the Redirector be opened.
Installation of the USB Redirector can be performed automatically using the provided script install.sh. During the installation the system requirements are automatically checked.
On systemd based systems the installation script can also add a corresponding service for automatically starting the background service.
Guided installation
The installation procedure can be started with higher permissions using the following command line:
sudo ./install.sh
Then follow the installation instructions. During installation some prompts appear with respect to naming and installation location. Unless there are reasons otherwise, here you can use the Enter key to apply the standard settings (shown in brackets).
Before the changes are actually made, you must again conform your entry with y.
The files are automatically coped to the corresponding locations. The downloaded folder with the installation files can then be deleted.
Manual installation
The USB Redirector can also be installed without the installation script shown above. To do this, first select the correct version for your Linux system:
- usb-redirector.i686 for 32-bit operating systems
- usb-redirector.x86_64 for 64-bit operating systems
The file can then be copied to the desired location in the file system. To start the downloaded background service you can either manually or using an existing Init system start the respective file with root permissions and the daemon parameter:
sudo usb-redirector daemon
Integrating devices
Checking status of the Redirector
Using the following command you can first check whether the background service has been correctly started. If yes, there should be an empty table of the currently connected devices in the terminal.
usb-redirector status
Listing devices
If the USB Redirector has been correctly initialized, you can use the list
command to query the devices connected to the USB server
usb-redirector list 10.40.28.165
By specifying the corresponding port you can then use the plug
command to connect locally:
usb-redirector plug 10.40.28.165 2
Using devices
After integration the virtual USB device is created on the host just as would be the case for a locally connected USB device.
This makes it possible to use application software as normal. In the example shown above the image from the USB Webcam for example can be displayed in Ubunto using the provided "Cheese" program.
Try this tutorial with hardware
Would you like to try this tutorial but don’t have the necessary hardware? We will be glad to provide you with a USB Server as a sample.
Any questions about the Linux environment?
Mr. Knabe will be glad to assist you.
Phone: +49 202/2680-110 (Mon.-Fri. 8 a.m. to 5 p.m.)
E-mail: p.knabe@wut.de