You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
pikvm/docs/community_faq.md

16 KiB

Can I power the Pi via POE?

  • Yes! But you will still need to ensure you isolate the 5v connection between the Raspberry Pi and host PC to prevent backpower issues that can cause instability or damage to either the host PC or the Pi. Power/Data cable + usb power blocker would work. Please see Variant #1 in the main getting started page for details.

Do I need a power splitter? Why do I need one?

  • Yes for RPi4, Yes and No for ZeroW - Yes if you want dedicated power, otherwise No
  • Yes, otherwise you could back power the pi and or the target
  • You can get a Y cable from amazon and mod one of the leads - Please see getting started guide - or see non modding of Y cable
  • You can also get a power splitter board from Tindi or PiShop (Links provided under variants #3 & #4)
  • If you have the v3 HAT - This is built in

I can't get the KVM KB to work on my ZeroW!

Make sure that you did NOT modify your config.txt file, this is the default:

# See /boot/overlays/README for all available options
initramfs initramfs-linux.img followkernel
hdmi_force_hotplug=1
gpu_mem=64
enable_uart=1
dtoverlay=tc358743,i2c_pins_28_29=1
dtoverlay=disable-bt
dtoverlay=dwc2,dr_mode=peripheral

Ensure that you have the cable(Needs to support both power/data) plugged into the right port, the one closest to the mini HDMI is the correct port

Can I use a KB on my ZeroW?

  • Yes but kb/mouse passthrough will not work. Its one or the other - This is especially true if you use an addon that requires the below to change.
  • edit /boot/config.txt
    • Host mode - Comment out dtoverlay=dwc2
    • Passthrough mode - Uncomment out dtoverlay=dwc2

Can you have the pikvm(RPi4) connected along with a monitor?

  • A community member has had success with the following: https://www.amazon.com/gp/product/B08DQWLXF1
  • Some Alternitives
    • If you have two outputs, you may be able to use screen mirroring from the OS but not BIOS
    • If you have one output or need access from both a local monitor or PiKVM at boot time, one of the following options may work:
    • Passthrough HDMI capture devices (sometimes referred to as a loop capture device). The Elgato devices DO NOT WORK! Look for Linux OS support when choosing a device, the expected price range is about $35-$70 US.
    • Depending on your capture device, an HDMI splitter may work but will need what is called an EDID (Extended Device ID) generator, the monitor and capture device both generate EDID so the splitter must produce its own separate EDID for the host.
    • Look for HDMI splitters - although there have been reports that these are not stable
      • Please use the search function in Discord, some users have had sucess in getting this to work but your mileage may vary
    • The better solution is to capture the stream in a dir and then use VLC to stream to that capture on another computer. This will result in fps loss.

Wouldn't it be good to have different hostnames for your multitude of pikvms?

Yes! And it's easy to do! Using a SSH session or the web terminal:

  • Make sure you're root, if you're not root use the su command to become root
  • Enter read write mode of the PiKVM by executing the rw command
  • Execute: hostnamectl set-hostname yournewhostname.domain
  • Optional: Edit /etc/kvmd/meta.yaml to alter the displayed hostname in the web UI
  • Reboot the pikvm
  • It's recommended that you review Arch documents related to what you want to do, while there are several folks in discord who can help, there is no obligation...they do it for the feels. So if you don't get an answer within the time frame you are looking for, it's advised you start google searching for what you want.

Can this be used in any other distros like Rasbian? Run this in a Docker?

  • Officially, no. Unofficially yes and totally #unsupported. Please DM @srepac on discord for the directions.
  • Docker image is available, search the docker hub but this is #unsupported and #unofficial and not updated.

Can you switch from USB to CSI or from CSI to USB?

  • Officially, no. You would be advised to make 2 seperate SD cards and swap them when needed. Unofficially yes and totally NOT supported. Please DM @srepac on discord for the script and directions.

My Pi keeps disconnecting from my wireless! What do I do?

  • You can try the following: Edit "/etc/conf.d/wireless-regdom" and look for your region and uncomment it. Example: WIRELESS_REGDOM="US"

I want a static IP!!

  • You can configure systemd-networkd for a static address for ethernet NIC. Config file is /etc/systemd/network/eth0.network
  • For wireless adapter, config file is /etc/netctl/wlan0-
  • See this page for details on how to get basic wireless config with DHCP going. Afterwards, youll need to edit the /etc/netctl/wlan0- file changing the IP=dhcp line with the following lines updated to reflect your network:
For /etc/systemd/network/eth0.network
[Match]
Name=eth0

[Network]
Address=192.168.X.XXX/24
Gateway=192.168.X.X
DNS=192.168.X.X
DNS=192.168.X.X

For /etc/netctl/wlan0-<wifiname>
IP=static
Address=('192.168.X.XXX/24')
Gateway=('192.168.X.X')
DNS=("192.168.X.X 1.0.0.1 1.1.1.1")
  • You can also reserve the IP in your dhcp server (Quicker)

Why do I keep getting a different IP?

  • You can do 2 of the following actions:
  • Add to, /etc/systemd/network/eth0.network
[DHCP]
ClientIdentifier=mac
  • OR reserve the DHCP ip in your server/router

HELP!! I can't find the IP on the ZeroW/RPi4

  • Open a browser and type: pikvm, still doesnt work?
  • Use the FING mobile app to scan your network, its free
  • Install Angry IP scanner, tools/preferences/Display results in the results list/Select Alive hosts, modify IP range, hit start
  • Using FF, navigate to https://pikvm (Depends on your network if this actually works, in most case's it "should" work))
    • The below commands will verify that your Pi on on your network
Linux: arp -a | grep below is a list of MAC's for Raspberry Pi
	B8:27:EB:xx:xx:xx	B8-27-EB-xx-xx-xx	B827.EBxx.xxxx
	DC:A6:32:xx:xx:xx	DC-A6-32-xx-xx-xx	DCA6.32xx.xxxx
	E4:5F:01:xx:xx:xx	E4-5F-01-xx-xx-xx	E45F.01xx.xxxx
Windows Power shell: arp -a | findstr 'b8-27-eb' (Replace with the above, all lower case)
  • For older flashed images you can do the following on the RPI4, ZeroW edit it when you edit WiFi info
    • Open web terminal and go to root, rw then nano /etc/issue
    • add IP: \4
    • Once you reboot, you will now see the IP in the upper left

Help! I ran out of space aka room! What now?

(This ONLY applies to the older flashed images and is no longer nessessary as the newer images had the main partition increased, as a result, the MSD partition was shrunk)

  • Youve cached package updates you no longer need.
  • Enter read/write mode by executing rw as root
  • Execute the following as root to clear the package cache
rm -rf /var/cache/pacman/pkg/*
  • Exit read/write mode by executing ro as root
  • You can also use gparted to resize partitions without "losing data", although there is a chance this may delete all of your data

Can you connect a camera to this and still make pikvm functional?

  • Yes, any cheapo webcam can be used in place of the usb dongle, please use the usb image
  • A PiCam will NOT work

HELP!! Something isn't working!!

  • What was the last thing or most recent thing you did? Did you undo it?
  • Did you change a file? Did you back it up before changing it?
  • Did you hook this to anything else? If not why not?
  • Did you try different cables?

HELP! I am getting a 500/503 error when I try and access the main KVM page!

  • This is due to a bad line in your yaml file, here are some steps you can make to help in the future.
  • Run kvmd -m, this will display ALL kvmd settings, you can compare to your own. Make sure you are not doubling up on child/sub-child entries.
  • Remember you need 4 space per child and 4 additional for each sub-child
  • Make a .nanorc file and populate it with the following: set linenumbers is optional
set linenumbers
set tabsize 4
set tabstospaces
  • Now re-edit your override.yaml file and just use tab to get the right spacing, you might need to delete the current leading "spaces" to ensure proper formatting

Can you use an iPad on PiKVM?

  • Yes, with the correct hardware you can control an iPad
  • Yes, activate VNC and use JUMP app(Full featured but more expensive), or bVNC(Not recommended, lack luster features but cheap). RealVNC does NOT work

How do I add my own SSL cert?

  • If you have a certificate(Making a cert falls outside the scope of PIKVM - Please reference Linux documentation), replace the public key in /etc/kvmd/nginx/ssl/server.crt and private key in /etc/kvmd/nginx/ssl/server.key and restart the kvmd-nginx service.
  • It should look like the following:
cd /etc/kvmd/nginx
cat ssl.conf (Expection of what's inside the file)
ssl_protocols TLSv1.3 TLSv1.2 TLSv1.1 TLSv1;
ssl_ciphers "EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH";
ssl_certificate /etc/kvmd/nginx/ssl/server.crt;
ssl_certificate_key /etc/kvmd/nginx/ssl/server.key;
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;

How do I emulate various USB devices on the target machine?

By default this is what is set:

otg:
    manufacturer: PiKVM
    max_power: 250
    product: Composite KVM Device
    product_id: 260
    serial: CAFEBABE
    udc: ''
    user: kvmd
    vendor_id: 7531

You can change how this is displayed with the following example: nano /etc/kvmd/override.yaml

otg:
    manufacturer: Corsair
    product: Corsair Gaming RGB
    serial:
    vendor_id: 6940
    product_id: 6973

Use the following USB Data Base to get the desired devices: https://the-sz.com/products/usbid/ or https://devicehunt.com

NOTE You may need to include 0x0 in the id string's for it to work properly.

  • Example:
    • vendor_id: 0x06940

Things to do after initial install:

  • Fix date: 'timedatectl list-timezones' then 'timedatectl set-timezone America/Los_Angeles' (Change to your location)
  • Update PiKVM, follow #news on Discord for instructions
  • Setup a NFS share to give read/write storage on the read only pikvm
pacman -S nfs-utils
showmount -e 192.168.1.XXX
mount -t nfs 192.168.1.XXX:/volume1/Data /mnt/Data
nano /etc/fstab

Add To the bottom of the file

192.168.1.XXX:/volume1/Data /mnt/Data nfs      auto,rw,soft    0 0

Can you run a desktop on pikvm?

  • Yes BUT, its not recommended OR supported as this OS should be used in RO and it will need RW enabled all of the time. Instructions here

Troubleshooting

  • It is expected that you are aware of basic networking while working on this project and that you have read up on the project prior to going to Discord

    • Do you know the IP?
    • Can you ping the IP?
    • Did you swap cables?
    • Did you swap the eth port to a known working eth port?
    • Do you have access to another router or switch?
    • Did you change ports on the router/switch?
    • RPi4 - Did you hook up a monitor? Once logged in, can you ping to your gateway? Other IP's on the same network?
    • Did you connect a monitor to the target? Does it work?
    • Did you connect the PIKVM to the target directly? Does it work?
  • Reboot target

  • Try default image, do not update and test

-copy/paste into a file, call it pi-info.sh, chmod +x pi-info.sh, ./pi-info.sh Same script is located here

#!/bin/bash
uptime
TMPFILE="/tmp/pacmanquery"; /bin/rm -f $TMPFILE
pacman -Q | awk '{print $2, $1}' > $TMPFILE
chmod go+w $TMPFILE

pistat && echo

printf "%-18s\t%s\n" "Version" "Package-Name" "----------------------" "-----------------------------"

PACKAGES="firmware bootloader kvmd ustreamer nginx wpa wireless"
for PKG in $( echo $PACKAGES ); do
        printf "%-18s\t%s\n" $(grep $PKG $TMPFILE | sed 's/-[1-9]//g')
done

dmesg | grep tc35 - CSI

dmesg | egrep '1-1.[245]|uvc' - USB

systemctl status kvmd

systemctl status kvmd-otg

  • hint: look at kvmd-platform line of the output... make sure it matches the image they expect for the capture device and platform

  • Keyboard/Mouse icons orange? Try a different cable (ALLOT are power only), try a different usb port

  • Should see the following if everything is in place ls -l /dev/kvmd

lrwxrwxrwx 1 root root 5 Apr  5 21:33 /dev/kvmd-hid-keyboard -> hidg0
lrwxrwxrwx 1 root root 5 Apr  5 21:33 /dev/kvmd-hid-mouse -> hidg1
lrwxrwxrwx 1 root root 6 Mar 15 09:07 /dev/kvmd-video -> video0

Common Commands for troubleshooting PiKVM

  • journalctl -u kvmd
  • journalctl -u kvmd-vnc
  • journalctl -u kvmd-ipmi

Bootup/power issues

  • PiKVM wont boot past “rainbow” screen
    • Are you plugged into the right HDMI port? Needs to be the one next to the power for RPI4
    • Have you reflashed your SD card?

PiKVM Complains about low power warnings

  • Are you using a proper power supply? Not one you hacked together?
  • Some USB power bricks advertise 5V @ 2.1A or higher, but cant deliver consistent 5V. Best to use rpi foundation recommended power supplies

USB Video Capture Issues

  • Make sure this is a capture card and not an adapter (HDMI->USB)

HDMI-CSI Capture issues

  • Have you reset the Target PC?
  • Are you sure it's a bridge and not an extender? There is a difference
  • Did you make sure it's plugged into the right port? It needs to say Camera NOT Display
  • Did you try another ribbon cable?
  • Did you reseat the ribbon cable?
  • Is the ribbon cable facing the right way? Needs to be towards the PCB (Green or Black)
  • If you are getting snow looking screen, you need to make sure you select 50hz OR select anything below 1080p, like 720p60
  • If you are getting an Indian looking screen, please clear the browser cache or use private/incog window

Misc stuff

  • Fully working example of a Pi4 USB-HDMI KVM attached to AIMOS 4-port HDMI KVM switch (8 port is on AliExpress), with keyboard hotkey switching between inputs, and mass storage media emulation on a Pi Zero W
  • PiKVM that mitigates HDMI backpower and requires no splitter board here
  • VERY useful scripts that enhance the PiKVM's functionality - Please DM @srepac on discord to gain access

As of March 2021, Below are frequently out of Stock or hard to get items, all have exceptionally LONG shipping dates

Ezcoo KVM - Goes out of stock frequently
CSI2-HDMI bridge w/ TC358743XBG chip - Goes out of stock freqently 
Alternative names for the same devices:
Tiamu	  	Sling	    	Yazan	    	Ningwang	Essenc	  	Geekworm
Fauge	  	Haudang	  	AKAT	    	Docoop	    	Katigan	  	Lyusa (recommended by mdevaev)
LNIMI	  	cherrypop	Lopbinte	Uang	      	Tuneway	  	Mustwell
Facibom		Binchil	  	Cobeky	  	Ctzrzyt	    	Davitu	
  • Community recommended USB capture card
  • Community recommended Loop device that allows Monitor+PiKVM