Thank you Peter and sorry for the delay !
You put me in the correct direction and the problem is now resolved :)
I wrongly assumed that attaching the device to the guest in "preboot
mode" should be only made in the "serial" way because I supposed that we
can not attach the device as a "hostdev" before the host really detect
the device as a USB device listed by "lsusb" which can take a moment.
But simply attach with "hostdev" with the idVendor/idProduct given in
"preboot mode" did the trick :
echo "<hostdev mode='subsystem' type='usb'
managed='yes'> \
<source> \
<vendor id='0x091e'/> \
<product id='0x0003'/> \
</source> \
</hostdev>" > serial_device.xml
From the host (here Debian 11) when I plug the GPS, I see this :
root@host:~# journalctl -kf
...
févr. 04 13:11:46 host kernel: usb 2-11: new high-speed USB device
number 34 using xhci_hcd
févr. 04 13:11:46 host kernel: usb 2-11: New USB device found,
idVendor=091e, idProduct=0003, bcdDevice= 0.01
févr. 04 13:11:46 host kernel: usb 2-11: New USB device strings: Mfr=0,
Product=0, SerialNumber=0
févr. 04 13:11:46 host kernel: garmin_gps 2-11:1.0: Garmin GPS usb/tty
converter detected
févr. 04 13:11:46 host kernel: usb 2-11: Garmin GPS usb/tty converter
now attached to ttyUSB0
févr. 04 13:11:54 host kernel: usb 2-11: USB disconnect, device number 34
févr. 04 13:11:54 host kernel: garmin_gps ttyUSB0: Garmin GPS usb/tty
converter now disconnected from ttyUSB0
févr. 04 13:11:54 host kernel: garmin_gps 2-11:1.0: device disconnected
...
From a guest (here Debian 11 too) when the script attach the GPS, I see
this :
root@guest:~# journalctl -kf
...
févr. 04 13:25:58 guest kernel: usb 2-6: new high-speed USB device
number 8 using ehci-pci
févr. 04 13:25:58 guest kernel: usb 2-6: New USB device found,
idVendor=091e, idProduct=0003, bcdDevice= 0.01
févr. 04 13:25:58 guest kernel: usb 2-6: New USB device strings: Mfr=0,
Product=0, SerialNumber=0
févr. 04 13:25:58 guest kernel: garmin_gps 2-6:1.0: Garmin GPS usb/tty
converter detected
févr. 04 13:25:58 guest kernel: usb 2-6: Garmin GPS usb/tty converter
now attached to ttyUSB0
févr. 04 13:26:03 guest kernel: usb 2-6: USB disconnect, device number 8
févr. 04 13:26:03 guest kernel: garmin_gps ttyUSB0: Garmin GPS usb/tty
converter now disconnected from ttyUSB0
févr. 04 13:26:03 guest kernel: garmin_gps 2-6:1.0: device disconnected
...
So the device is correctly transferred, and it is confirmed as the
"preboot tools" detect the device in a "Windows 7"**guest
I want to add that, as far as I know we can not use the "virt-manager"
GUI to do the same, for two reasons :
- the USB host device window do not refresh itself when the items are
added or removed
- the delay to attach this device is pretty short (5 to 8 seconds) and
just after, from the guest we must trigger the tools which can manage
the device in "preboot mode" (typically a flash tool)
That is why the solution I found, is to automate this with a script
which detects the kernel events and automatically attach the devices.
The host versions :
root@host:~# cat /etc/os-release | grep -E "^(NAME|VERSION)=" | tr '\n'
' ' ; uname -a ; kvm --version | grep version ; libvirtd --version ;
virt-manager --version
NAME="Debian GNU/Linux" VERSION="11 (bullseye)"
Linux host 5.10.0-8-amd64 #1 SMP Debian 5.10.46-4 (2021-08-03) x86_64
GNU/Linux
QEMU emulator version 5.2.0 (Debian 1:5.2+dfsg-11)
libvirtd (libvirt) 7.0.0
3.2.0
As I want to post the complete method I used, I will certainly make a
feedback in this thread later ;)
Le 25/01/2023 à 15:24, Peter Krempa a écrit :
On Tue, Jan 24, 2023 at 00:10:46 +0100,lnj.sam(a)gmail.com wrote:
> Hello everyone and best wishes for 2023 :)
>
> I have an old *Garmin Drive Smart 50 GPS* and I want to be able to attach it
> when it is in preboot mode to a VM hosted by a *Debian 11 host*.
>
> From what I understand, the preboot mode allows us to flash a firmware
> before the GPS actually starts (used among other things when the GPS is soft
> bricked).
>
> When I connect the GPS to the host it gives:
[...]
> My questions :
>
> Q1 : Is it possible ?
It shpi;d be/
> Q2 : Am I doing it the right way ?
I don't think so. You are using a serial device emulated which is then
connected to the host side USB-tty device.
A better way is simply to use USB-assignment/passthrough and have the
guest OS handle also the USB side
> Q3 : Is there a method to pass such a device directly (pass-through) ?
To pass a USB device use the following XML:
<hostdev mode='subsystem' type='usb' managed='yes'>
<source>
<vendor id='0x1a86'/>
<product id='0x55d4'/>
</source>
<address type='usb' bus='0' port='4'/>
</hostdev>
Obviously tweak vendor/product.
Alternatively when you are using virt-manager GUI there's a menu to pass
any device, or by default when you have a VM window active and plug in a
USB device it's passed to the VM. (It can be disabled though).