wiki/gofurther/evdev.md

65 lines
2.0 KiB
Markdown
Raw Normal View History

2022-08-13 00:26:05 +00:00
---
title: Share an input device with a guest using evdev
description:
published: true
2023-05-13 16:00:23 +00:00
date: 2023-05-13T16:00:21.759Z
2022-08-13 00:26:05 +00:00
tags:
editor: markdown
dateCreated: 2022-08-13T00:26:02.801Z
---
2022-08-25 10:40:46 +00:00
# Share an input device
2022-08-13 00:26:05 +00:00
2023-05-13 15:04:04 +00:00
In this section, we focus on sharing a locally attached input device with a guest virtual machine.
2023-02-08 19:09:04 +00:00
2023-05-13 15:59:21 +00:00
## Using Evdev
2022-08-25 10:40:46 +00:00
2023-05-13 15:59:21 +00:00
Since version 7.4.0, Libvirt added a low-latency local-only way to share an input device with a guest, using the [Linux evdev event interface](https://www.kernel.org/doc/html/latest/input/input.html?highlight=evdev#evdev).
2022-08-25 10:40:46 +00:00
2023-05-13 16:00:23 +00:00
### Configuration
2023-05-13 15:58:29 +00:00
- List input devices based on their identification, only listing those with an *event* in their name and excluding these with *if*:
```
ls /dev/input/by-id/* | grep event | grep -v if
```
2022-08-13 00:26:05 +00:00
```
2023-05-13 15:56:23 +00:00
/dev/input/by-id/usb-Corsair_CORSAIR_HARPOON_RGB_PRO_Gaming_Mouse_1902B02BAF5E04655DEB612AF5001C05-event-mouse
/dev/input/by-id/usb-Logitech_G513_RGB_MECHANICAL_GAMING_KEYBOARD_156930783132-event-kbd
/dev/input/by-id/usb-Logitech_USB_Keyboard-event-kbd
/dev/input/by-id/usb-Logitech_USB_Optical_Mouse-event-mouse
2022-08-25 10:40:46 +00:00
```
2023-05-13 16:00:23 +00:00
- Make sure that the correct one is selected by registering its inputs in the console:
2022-08-25 10:40:46 +00:00
2022-08-25 20:26:04 +00:00
```
2023-05-13 15:56:23 +00:00
cat /dev/input/by-id/usb-Logitech_G513_RGB_MECHANICAL_GAMING_KEYBOARD_156930783132-event-kbd
2022-08-25 20:26:04 +00:00
```
2022-08-25 10:40:46 +00:00
2023-05-13 15:56:23 +00:00
- Clicking or typing on the device you wish to share should display gibberish characters on the screen:
2022-08-25 20:26:04 +00:00
```
<EFBFBD><EFBFBD>c $
2023-02-08 18:58:01 +00:00
<EFBFBD><EFBFBD>c<EFBFBD><EFBFBD><EFBFBD>c<EFBFBD><EFBFBD><EFBFBD>c<EFBFBD>$<24><>c<EFBFBD>$<24><><63><D78F><63><D78F>c
2022-08-25 20:26:04 +00:00
```
2023-02-08 19:09:53 +00:00
2023-05-13 15:56:23 +00:00
- Add the following snippet to the XML domain definition of an existing virtual machine, inside the `<device>` section:
```
<input type='evdev'>
<source dev='/dev/input/by-id/usb-Logitech_G513_RGB_MECHANICAL_GAMING_KEYBOARD_156930783132-event-kbd' grab='all' repeat='on'/>
</input>
```
2023-05-13 16:00:23 +00:00
### Usage
2023-05-13 15:59:21 +00:00
2023-05-13 15:57:19 +00:00
> Press <kbd>Left Ctrl + Right Ctrl</kbd> simultaneously to switch your devices between the guest and the host.
{.is-info}
2023-05-13 15:56:23 +00:00
2023-05-13 16:00:23 +00:00
2023-05-13 15:56:23 +00:00
## Resources
2023-02-08 19:09:53 +00:00
2023-05-13 15:56:23 +00:00
* https://libvirt.org/formatdomain.html#input-devices
2023-02-08 19:09:53 +00:00