usb keyboard and mouse can't work on QEMU ARM64 with KVM

Shannon Zhao zhaoshenglong at huawei.com
Tue Jul 26 00:34:08 PDT 2016


Hi,

Recently I'm trying to use usb keyboard and mouse with QEMU on ARM64. Below is my QEMU command line,
host and guest kernel both are 4.7.0-rc7+, and I ran it on Hikey board.

    qemu-system-aarch64 \
    -smp 1 -cpu host -enable-kvm \
    -m 256 -M virt \
    -k en-us \
    -nographic \
    -device usb-ehci -device usb-kbd -device usb-mouse -usb\
    -kernel Image \
    -initrd guestfs.cpio.gz \
    -append "rdinit=/sbin/init console=ttyAMA0 root=/dev/ram earlycon=pl011,0x9000000 rw"

The following guest log shows that usb controller can be probed but the keyboard and mouse can't be
found.

[    1.597433] ehci_hcd: USB 2.0 'Enhanced' Host Controller (EHCI) Driver
[    1.599562] ehci-pci: EHCI PCI platform driver
[    1.608082] ehci-pci 0000:00:03.0: EHCI Host Controller
[    1.609485] ehci-pci 0000:00:03.0: new USB bus registered, assigned bus number 1
[    1.611833] ehci-pci 0000:00:03.0: irq 49, io mem 0x10041000
[    1.623599] ehci-pci 0000:00:03.0: USB 2.0 started, EHCI 1.00
[    1.625867] hub 1-0:1.0: USB hub found
[    1.626906] hub 1-0:1.0: 6 ports detected
[    1.628685] ehci-platform: EHCI generic platform driver
[    1.630263] ehci-msm: Qualcomm On-Chip EHCI Host Controller
[    1.631947] ohci_hcd: USB 1.1 'Open' Host Controller (OHCI) Driver
[    1.633547] ohci-pci: OHCI PCI platform driver
[    1.634807] ohci-platform: OHCI generic platform driver
[...]
[    1.939001] usb 1-1: new high-speed USB device number 2 using ehci-pci
[   17.467040] usb 1-1: device not accepting address 2, error -110
[   17.579165] usb 1-1: new high-speed USB device number 3 using ehci-pci
[   32.287242] random: dd urandom read with 7 bits of entropy available
[   33.110970] usb 1-1: device not accepting address 3, error -110
[   33.223030] usb 1-1: new high-speed USB device number 4 using ehci-pci
[   43.635185] usb 1-1: device not accepting address 4, error -110
[   43.747033] usb 1-1: new high-speed USB device number 5 using ehci-pci
[   54.159043] usb 1-1: device not accepting address 5, error -110
[   54.160752] usb usb1-port1: unable to enumerate USB device
[   54.307290] usb 1-2: new high-speed USB device number 6 using ehci-pci
[   69.839052] usb 1-2: device not accepting address 6, error -110
[   69.951249] usb 1-2: new high-speed USB device number 7 using ehci-pci
[   85.483171] usb 1-2: device not accepting address 7, error -110
[   85.595035] usb 1-2: new high-speed USB device number 8 using ehci-pci
[   90.619247] usb 1-2: device descriptor read/8, error -110
[   95.743482] usb 1-2: device descriptor read/8, error -110
[   95.959165] usb 1-2: new high-speed USB device number 9 using ehci-pci
[  106.371177] usb 1-2: device not accepting address 9, error -110
[  106.372894] usb usb1-port2: unable to enumerate USB device

lsusb shows:
root at genericarmv8:~# lsusb
Bus 001 Device 001: ID 1d6b:0002

Besides, I have also tried QEMU TCG without KVM. The guest can successfully probe usb controller,
keyboard and mouse.
lsusb shows:
root at genericarmv8:~# lsusb
Bus 001 Device 002: ID 0627:0001
Bus 001 Device 003: ID 0627:0001
Bus 001 Device 001: ID 1d6b:0002

So it looks like that usb keyboard and mouse don't work with KVM on QEMU ARM64 while they can work
with TCG. IIUC, all the usb devices are emulated by QEMU, it has nothing with KVM. So it really
confused me and I'm not familiar with usb devices. Also I have seen someone else reports this issue
before[1].

[1]https://lists.gnu.org/archive/html/qemu-arm/2016-06/msg00110.html

Any comments and help are welcome. Thanks in advance.

Thanks,
-- 
Shannon




More information about the linux-arm-kernel mailing list