# curl --unix-socket /run/kvmd/ustreamer.sock http://localhost/snapshot -o screen.jpg
# pacman -Q | grep kvmd
Specifically to v2.
- Remount internal storage to rw (read-write):
# kvmd-helper-otgmsd-remount rw
- Upload the .ISO image(s) to
/var/lib/kvmd/msd/images
via scp or similar. - Create an empty file in
/var/lib/kvmd/msd/meta/
with the exact name (case sensitive!) of the uploaded image. This will indicate Pi-KVM that the uploaded image is okay and can be used. For example:/var/lib/kvmd/msd/meta/ubuntu-18.04.4-desktop-amd64.iso.complete
- Remount internal storage back to ro (read-only):
# kvmd-helper-otgmsd-remount ro
Specifically to v2. This can be used for terminal access from the managed server to the Pi-KVM, or for any other purpose that requires a serial connection. In the last case, you only need to perform step 1 and reboot.
- Edit
/etc/kvmd/override.yaml
(remove{}
if this your first configuration entry) and add these lines:otg: devices: serial: enabled: true
- Run the following command:
# echo ttyGS0 >> /etc/securetty
- Create the directory
/etc/systemd/system/[email protected]
and add a file file namedttyGS0.override
into it. Afterwards edit the file and copy this into it:[Service] TTYReset=no TTYVHangup=no TTYVTDisallocate=no
- Run these comands:
# systemctl enable [email protected] # reboot
- Once Pi-KVM is rebooted you will have access to a virtual serial port on the server that the USB is connected to. Use mingetty, screen, putty, or something like this to access the kvm from the server. The port is called
/dev/ttyAMA0
.
Specifically to v2. When combined with configuring a DNS server, FTP, or SMB (for example), this is a powerful way to extend the capabilities of Pi-KVM.
- Edit
/etc/kvmd/override.yaml
(remove{}
if this your first configuration entry) and add these lines:Theotg: devices: ethernet: enabled: true driver: ecm host_mac: 48:6f:73:74:50:43 kvm_mac: 42:61:64:55:53:42
host_mac
address will be used on the server's network interface. Thekvm_mac
means the address that will be assigned to the local interface on the Pi-KVM. The KVM interface will be calledusb0
.r's network interface. If thehost_mac
orkvm_mac
is not specified, a random value will be used. Thedriver
parameter means the protocol that will be used for the USB network. The default value isecm
so it can be passed it this example. Other possible values areeem
,ncm
andrndis
. - To automatically configure the USB network on the server recommended using the service
kvmd-otgnet
. It configures the firewall, assigns an address to the local Pi-KVM interfaceusb0
and starts DHCP so the managed server can get the IPv4 address. By default, the address169.254.0.1/28
to interfaceusb0
will be assigned. One of the other addresses from the network169.254.0.0./28
will be assigned to the server when it requests it via DHCP. For security reasons, all incoming connections from the server to the Pi-KVM side are blocked (except for ICMP and UDP port 67 which is used for DHCP). If you want to allow access from the server to the Pi-KVM interface, then you need to add ports 80 and 443 to the whitelist using/etc/kvmd/override.yaml
file like this:To view other available configuration parameters, use the commandotgnet: firewall: allow_tcp: [80, 443]
kvmd -m
. - To enable the service, use the command
systemctl enable kvmd-otgnet
. - Perform
reboot
.
❗ The USB-Ethernet features are experimental, so some of the default settings may be changed in future releases.
Specifically to v2. By default, Pi-KVM creates only one drive for Mass Storage emulation. However, you can create additional drives and manage them manually via the terminal. This is useful if you want to boot the server from a ISO CD (specified in the web interface), then connect a virtual flash drive to the server and download some files from to Pi-KVM from it.
❗ The presence of an additional Mass Storage device should not interfere with the boot, but for reasons of compatibility paranoia, this is disabled by default. We recommend setting up the drives in advance, making sure that booting from the ISO CD is still working, and then using the drives as needed.
How to enable extra drives:
- Switch the root filesystem to
rw
mode. - Edit
/etc/kvmd/override.yaml
(remove{}
if this your first configuration entry) and add these lines:If you specifyotg: devices: drives: enabled: true # Set it to true to enable count: 1 # +1 drive, default value default: # Default configuration for the all extra drives cdrom: false # Defaut value (false for the generic flash drive) rw: false # Read-only by default
count: N
, you will createN
additional drives configured the same way, as described in thedefault
section. - Reboot.
How to create RW flash drive:
- Switch the root filesystem to
rw
mode:# rw
- Create the empty image file of the desire size (1Gb in this example.
# dd if=/dev/zero of=/root/flash.img bs=1024
- Connect it to the drive 1:
After that you will have access to the flash drive from the server.
# kvmd-otgmsd -i 1 --set-rw=1 --set-cdrom=0 --set-image=/root/flash.img
❗ Drive 0 represents a drive that is controlled via a web interface and API. Don't use it with kvmd-otgmsd if you don't know exactly what you're doing. - View the driver state:
# kvmd-otgmsd -i 1 Image file: /root/flash.img CD-ROM flag: no RW flag: yes
- To disable the flash drive and view the files on it from the KVM, run:
❗ This command will interrupt the current IO operation on ALL DRIVES including the one that is managed via the web interface. The same result is achieved by clicking the disable media button in the web interface. Right now, the Linux kernel does not allow to distinguish between internal threads that manage different drives. It is recommended to eject the media when you know that this will not cause problems for the other media.
# kvmd-otgmsd -i 1 --unlock --eject
- Don't forget to remount the root filesystem to read-only mode:
# ro
- You can download the resulting image via SCP or mount it as a loop device on the Pi-KVM.
This procedure requires sufficient space on your SD card. Without resising, the full size of the USB stick will be used, so keep it as small as possible (e.g. 4GB or 8GB). You can also do this on a separate unix machine and transfer the image over to pikvm. On Windows you could use a program like PassMark ImageUSB or 'dd' for Windows to create the image.
You can use a tool like "EaseUS Partition Master Free" or "GParted" to resize the main FAT32 partition. This will save on PiKVM used storage space.
-
Insert Windows based USB stick into Pi4, generated with Microsoft USB creation tool. SSH to PiKVM as root.
# dmesg [ 3025.025401] usb-storage 2-1:1.0: USB Mass Storage device detected [ 3025.038911] scsi host0: usb-storage 2-1:1.0 [ 3026.132248] scsi 0:0:0:0: Direct-Access Kingston DataTraveler 3.0 PMAP PQ: 0 ANSI: 6 [ 3026.771425] sd 0:0:0:0: [sda] 15360000 512-byte logical blocks: (7.86 GB/7.32 GiB) [ 3026.790276] sd 0:0:0:0: [sda] Write Protect is off [ 3026.802530] sd 0:0:0:0: [sda] Mode Sense: 23 00 00 00 [ 3026.804450] sd 0:0:0:0: [sda] No Caching mode page found [ 3026.814082] sd 0:0:0:0: [sda] Assuming drive cache: write through [ 3026.908712] sda: sda1 [ 3026.922794] sd 0:0:0:0: [sda] Attached SCSI removable disk [root@pikvm ~]#
USB devices shows as "sda". We will use "sda1" as the Microsoft Windows (TM) partition.
-
mount msd folder as read/write
# kvmd-helper-otgmsd-remount rw
-
Create image of USB data PARTITION to an image file, this will take some time, in this case about 12 minutes (RPi4).
# dd if=/dev/sda1 of=/var/lib/kvmd/msd/images/windows10-2004.bin bs=8M status=progress 4458545152 bytes (4.5 GB, 4.2 GiB) copied, 736 s, 6.1 MB/s 531+1 records in 531+1 records out 4458545152 bytes (4.5 GB, 4.2 GiB) copied, 736.213 s, 6.1 MB/s
-
Correct ownership of new image and make sure the website reports the file as complete (pay attention to the different folder).
# chown kvmd:kvmd /var/lib/kvmd/msd/images/windows10-2004.bin # touch /var/lib/kvmd/msd/meta/windows10-2004.bin.complete
-
Remount msd folder as read only
# kvmd-helper-otgmsd-remount ro
-
On PiKVM webpage, under Mass Storage select the new image and connect it in Drive Mode: Flash to the server.
Boot the server and select boot device like you normally would. E.g. in a AMI BIOS the boot device is called "Linux File-CD Gadget 0504".