Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pico Fido not working on Windows 10 after update from 5.8 to 5.10 #49

Open
reppad opened this issue Jul 23, 2024 · 38 comments
Open

Pico Fido not working on Windows 10 after update from 5.8 to 5.10 #49

reppad opened this issue Jul 23, 2024 · 38 comments

Comments

@reppad
Copy link

reppad commented Jul 23, 2024

Hi,

First of all, thank you very much for this project, it is very useful !

After updating my key from version 5.8 to version 5.10, I can no longer use it with Windows 10.
It appears in the device manager as before, 4 USB devices with the expected VID:PID (1 Composite, 2 HID & 1 Smart Card), but the browser (tried with Firefox and Edge) or applications like Yubikey Manager and FIDO2.1 Manager no longer detect it.

I use the base variant pico_fido_pico-5.10.uf2
I've tried the update using the original binary and the patched binary (Yubikey 4/5), restoring RP2040 flash between the 2 tests, I get the same behavior in both cases.

Everything seems to work correctly in 5.10 with Ubuntu 24.04 and all my settings are preserved (PIN, 2FA, resident keys...).

I didn't lose anything. I had done a memory dump before updating, so I simply restored my key to version 5.8.

If I can provide any other useful information, please don't hesitate to ask :)

@polhenarejos
Copy link
Owner

Can you try with Chrome? Firefox has buggy behaviour. I’ll try to debug with win10 to see what’s happening.

@reppad
Copy link
Author

reppad commented Jul 23, 2024

Sure, I'll try it tonight.
There may be a problem with my environment but I doubt it's a problem with Firefox, as Edge doesn't work either, and neither do Yubikey Manager and FIDO2.1 Manager.

@reppad
Copy link
Author

reppad commented Jul 23, 2024

I tried to conduct some more thorough tests, and the behavior is quite strange.
I tested it on several Windows 10 and 11 computers, and the key works randomly. The chosen browser does not seem to influence the behavior.

Sometimes the browser asks to insert the key as if it were not recognized at all, sometimes the browser loops on the PIN code request and the registration does not succeed, and sometimes it works.
Generally, it ends up working after a certain number of attempts; once it works once, it works every time as long as the key is not unplugged.

It's as if a value is at the limit and the functioning depends on the tolerance of the environment.

In any case, reverting to version 5.8 and everything works perfectly, so I don't think it's a hardware problem with my Pico board.

@polhenarejos
Copy link
Owner

polhenarejos commented Jul 24, 2024

I cannot reproduce it. I tested in Windows 10 with Chrome, Firefox and Edge against webauthn.io and worked 3/3. Did you try it with webauthn.io or you use a specific page?

Edit: also tested with Yubikey Manager and Fido 2.1 Manager. Did you patch VID/PID with Yubikey values? Mines are 1050:0407

@reppad
Copy link
Author

reppad commented Jul 26, 2024

I cannot reproduce it. I tested in Windows 10 with Chrome, Firefox and Edge against webauthn.io and worked 3/3. Did you try it with webauthn.io or you use a specific page?

In addition to linux -which works well- I tested most combinations of

I've also done some new tests

  • using a fresh installation (using flash_nuke.uf2 before flashing Pico FIDO) as well as updating a key that already had a PIN and passkeys
  • using another RP2040 dev board

Same behavior

Edit: also tested with Yubikey Manager and Fido 2.1 Manager. Did you patch VID/PID with Yubikey values? Mines are 1050:0407

My usual setup is patched as a Yubikey 4/5, I tested with and without.

image

I noticed that when the key was ‘not recognised’, there was no need to try several times, just wait between 30 seconds and 1 minute and the ‘Insert your security key’ message disappears and the key is recognised, which is why I found the behavior erratic

Finally, a more accurate description of what I observe is :
Although it appears immediately in the device manager, I have to wait between 30 seconds and 1 minute after connection for the key to be usable on Windows.

@rojvv
Copy link

rojvv commented Aug 18, 2024

Same issue. The led doesn't even blink on 5.10 while it does on 5.8. This is regardless of the operating system apparently, since I've tried on both macOS and Fedora.

@rojvv
Copy link

rojvv commented Aug 19, 2024

I tried on another Pico. 5.10 makes the led blink, but it does not function at all.

@polhenarejos
Copy link
Owner

I spotted several critical problems mixing CCID and HID interfaces. I am preparing a new release, which also adds a support for ESP32.
They are available in the main branch.

@rojvv
Copy link

rojvv commented Aug 19, 2024

Happy to hear that!

@rojvv
Copy link

rojvv commented Aug 21, 2024

I cannot reproduce this issue with Waveshare Zero. I think I will be using that for now.

@reppad
Copy link
Author

reppad commented Aug 26, 2024

I spotted several critical problems mixing CCID and HID interfaces. I am preparing a new release, which also adds a support for ESP32. They are available in the main branch.

I just tried with the HEAD of the main branch (02556fc).
The key is usable for authentication right from the connection on Windows, so this issue seems to be resolved.
However, the functionality with YubiKey Manager and Yubico Authenticator seems to be broken. I can't manage the active interfaces or access the OTP functions (I'm patched with 1050:0407).

@polhenarejos
Copy link
Owner

v5.12 should fix all these problems.

@reppad
Copy link
Author

reppad commented Sep 2, 2024

v5.12 should fix all these problems.

Version 5.12 seems to be working well on Windows for authentication.
I don't quite understand why, but it's now necessary to run "Yubico Authenticator" as administrator for it to access the key, which wasn't the case in v5.8.

@polhenarejos
Copy link
Owner

What do you mean? You can use Pico Fido with your browser without any external tool.

@reppad
Copy link
Author

reppad commented Sep 2, 2024

Yes, absolutely, and that usage works well.

Yubico Manager and Yubico Authenticator allow you to configure the key, for example the action of the button when the key is not expecting user presence.
It's not a big issue, it's just that it worked fine in v5.8.

@polhenarejos
Copy link
Owner

It should work with both, but before you must patch VIDPID with a know Yubico VIDPID in order to those apps recognize your key as a Yubico one.

@reppad
Copy link
Author

reppad commented Sep 2, 2024

Yes, that's what I do in both cases, using Pico Patcher and selecting Yubikey 4/5 OTP+FIDO+CCID.

@polhenarejos
Copy link
Owner

What lsusb -vv reports?

@reppad
Copy link
Author

reppad commented Sep 3, 2024

v5.12

Bus 001 Device 029: ID 1050:0407 Yubico.com Yubikey 4/5 OTP+U2F+CCID
Device Descriptor:
  bLength                18
  bDescriptorType         1
  bcdUSB               2.00
  bDeviceClass            0 
  bDeviceSubClass         0 
  bDeviceProtocol         0 
  bMaxPacketSize0        64
  idVendor           0x1050 Yubico.com
  idProduct          0x0407 Yubikey 4/5 OTP+U2F+CCID
  bcdDevice            6.00
  iManufacturer           1 Pol Henarejos
  iProduct                2 Pico Key
  iSerial                 3 DE693C65CB344C36
  bNumConfigurations      1
  Configuration Descriptor:
    bLength                 9
    bDescriptorType         2
    wTotalLength       0x0096
    bNumInterfaces          3
    bConfigurationValue     1
    iConfiguration          4 Pico Key Config
    bmAttributes         0xa0
      (Bus Powered)
      Remote Wakeup
    MaxPower              100mA
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        0
      bAlternateSetting       0
      bNumEndpoints           2
      bInterfaceClass         3 Human Interface Device
      bInterfaceSubClass      0 
      bInterfaceProtocol      0 
      iInterface              5 Pico Key HID Interface
        HID Device Descriptor:
          bLength                 9
          bDescriptorType        33
          bcdHID               1.11
          bCountryCode            0 Not supported
          bNumDescriptors         1
          bDescriptorType        34 Report
          wDescriptorLength      34
         Report Descriptors: 
           ** UNAVAILABLE **
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x04  EP 4 OUT
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval              10
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x84  EP 4 IN
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval              10
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        1
      bAlternateSetting       0
      bNumEndpoints           1
      bInterfaceClass         3 Human Interface Device
      bInterfaceSubClass      0 
      bInterfaceProtocol      0 
      iInterface              6 Pico Key HID Keyboard Interface
        HID Device Descriptor:
          bLength                 9
          bDescriptorType        33
          bcdHID               1.11
          bCountryCode            0 Not supported
          bNumDescriptors         1
          bDescriptorType        34 Report
          wDescriptorLength      67
         Report Descriptors: 
           ** UNAVAILABLE **
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x85  EP 5 IN
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0010  1x 16 bytes
        bInterval               5
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        2
      bAlternateSetting       0
      bNumEndpoints           3
      bInterfaceClass        11 Chip/SmartCard
      bInterfaceSubClass      0 
      bInterfaceProtocol      0 
      iInterface              7 Pico Key CCID Interface
      ChipCard Interface Descriptor:
        bLength                54
        bDescriptorType        33
        bcdCCID              1.10  (Warning: Only accurate for version 1.0)
        nMaxSlotIndex           0
        bVoltageSupport         1  5.0V 
        dwProtocols             2  T=1
        dwDefaultClock       3580
        dwMaxiumumClock      3580
        bNumClockSupported      0
        dwDataRate           9600 bps
        dwMaxDataRate        9600 bps
        bNumDataRatesSupp.      0
        dwMaxIFSD             254
        dwSyncProtocols  00000000 
        dwMechanical     00000000 
        dwFeatures       00040840
          Auto parameter negotiation made by CCID
          Short and extended APDU level exchange
        dwMaxCCIDMsgLen     65554
        bClassGetResponse    echo
        bClassEnvelope       echo
        wlcdLayout           none
        bPINSupport             0 
        bMaxCCIDBusySlots       1
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x01  EP 1 OUT
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval               0
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x81  EP 1 IN
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval               0
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x82  EP 2 IN
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval               0
Device Status:     0x0000
  (Bus Powered)

v5.8

Bus 001 Device 031: ID 1050:0407 Yubico.com Yubikey 4/5 OTP+U2F+CCID
Device Descriptor:
  bLength                18
  bDescriptorType         1
  bcdUSB               2.00
  bDeviceClass            0 
  bDeviceSubClass         0 
  bDeviceProtocol         0 
  bMaxPacketSize0        64
  idVendor           0x1050 Yubico.com
  idProduct          0x0407 Yubikey 4/5 OTP+U2F+CCID
  bcdDevice            5.00
  iManufacturer           1 Pol Henarejos
  iProduct                2 Pico Key
  iSerial                 3 DE693C65CB344C36
  bNumConfigurations      1
  Configuration Descriptor:
    bLength                 9
    bDescriptorType         2
    wTotalLength       0x0096
    bNumInterfaces          3
    bConfigurationValue     1
    iConfiguration          4 Pico Key Config
    bmAttributes         0xa0
      (Bus Powered)
      Remote Wakeup
    MaxPower                2mA
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        0
      bAlternateSetting       0
      bNumEndpoints           2
      bInterfaceClass         3 Human Interface Device
      bInterfaceSubClass      0 
      bInterfaceProtocol      0 
      iInterface              5 Pico Key HID Interface
        HID Device Descriptor:
          bLength                 9
          bDescriptorType        33
          bcdHID               1.11
          bCountryCode            0 Not supported
          bNumDescriptors         1
          bDescriptorType        34 Report
          wDescriptorLength      34
         Report Descriptors: 
           ** UNAVAILABLE **
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x03  EP 3 OUT
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval              10
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x83  EP 3 IN
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval              10
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        1
      bAlternateSetting       0
      bNumEndpoints           1
      bInterfaceClass         3 Human Interface Device
      bInterfaceSubClass      0 
      bInterfaceProtocol      0 
      iInterface              6 Pico Key HID Keyboard Interface
        HID Device Descriptor:
          bLength                 9
          bDescriptorType        33
          bcdHID               1.11
          bCountryCode            0 Not supported
          bNumDescriptors         1
          bDescriptorType        34 Report
          wDescriptorLength      78
         Report Descriptors: 
           ** UNAVAILABLE **
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x84  EP 4 IN
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0010  1x 16 bytes
        bInterval               5
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        2
      bAlternateSetting       0
      bNumEndpoints           3
      bInterfaceClass        11 Chip/SmartCard
      bInterfaceSubClass      0 
      bInterfaceProtocol      0 
      iInterface              7 Pico Key CCID Interface
      ChipCard Interface Descriptor:
        bLength                54
        bDescriptorType        33
        bcdCCID              1.10  (Warning: Only accurate for version 1.0)
        nMaxSlotIndex           0
        bVoltageSupport         1  5.0V 
        dwProtocols             3  T=0 T=1
        dwDefaultClock       3580
        dwMaxiumumClock      3580
        bNumClockSupported      0
        dwDataRate           9600 bps
        dwMaxDataRate        9600 bps
        bNumDataRatesSupp.      0
        dwMaxIFSD             254
        dwSyncProtocols  00000000 
        dwMechanical     00000000 
        dwFeatures       00040840
          Auto parameter negotiation made by CCID
          Short and extended APDU level exchange
        dwMaxCCIDMsgLen     65554
        bClassGetResponse    echo
        bClassEnvelope       echo
        wlcdLayout           none
        bPINSupport             0 
        bMaxCCIDBusySlots       1
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x81  EP 1 IN
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval               0
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x01  EP 1 OUT
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval               0
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x82  EP 2 IN
        bmAttributes            3
          Transfer Type            Interrupt
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval               0
Device Status:     0x0000
  (Bus Powered)

@polhenarejos
Copy link
Owner

Not much differences, maxCurrentPower, dwProtocol, bcdVersion and size of HID report descriptor.

Is this behavior still happening if you flash v5.8 now?

@reppad
Copy link
Author

reppad commented Sep 5, 2024

The behavior seems consistent across version regardless of installation method.

Works like real Yubikey, without administrator privileges, except for managing passkeys :

  • Version 5.8 installed on a blank Pico
  • Version 5.8 installed over version 5.12 (downgrade)

Requires administrator privileges

  • Version 5.12 installed on a blank Pico
  • Version 5.12 installed over version 5.8 (upgrade)

@polhenarejos
Copy link
Owner

I tried v5.8 and it requires to be ran with Admin privileges, like in v5.12. I do not see any difference in that sense. Perhaps, your OS has whitelisted your previous device.

@benallard
Copy link

I'm having some kind of similar issues with 5.12, Win10 and Firefox.

Pressing reset or removing the key while attempting to generate (register) a key prompt for the device to be re-inserted, but nothing happen after reinsertion. Else the dialog just says please insert your device. The same device works on MacOS.

@polhenarejos
Copy link
Owner

I made some adjustments for Windows in 2011cfd3 but the overall behavior seems buggy. Whilst it works smoothly with Edge, in Chrome is not even recognized. I'm not sure if it's a problem of permissions or what.

@benallard
Copy link

Let me know if you need some logs or such, I can try to gather some data there. Should I rather open a separate ticket ?

@polhenarejos
Copy link
Owner

First try it with Edge to see whether is a browser specific problem or not.

@benallard
Copy link

will try tomorrow first thing in the morning and let you know 👍

@benallard
Copy link

So edge is not working either, and only proposing me a QR-code to scan on my phone. as if it would not see the device at all.

Okay, seems like edge is not working at all with hardware keys as my yubikey is not recognized there either. So I just checked again on firefox, and it's working there, the pico, unfortunately not.

@reppad
Copy link
Author

reppad commented Sep 25, 2024

I'm having some kind of similar issues with 5.12, Win10 and Firefox.

Pressing reset or removing the key while attempting to generate (register) a key prompt for the device to be re-inserted, but nothing happen after reinsertion. Else the dialog just says please insert your device. The same device works on MacOS.

What happens if you leave the pico plugged in for 1 minute before registering (instead of inserting it at the time of the request)?

@polhenarejos
Copy link
Owner

So edge is not working either, and only proposing me a QR-code to scan on my phone. as if it would not see the device at all.

Okay, seems like edge is not working at all with hardware keys as my yubikey is not recognized there either. So I just checked again on firefox, and it's working there, the pico, unfortunately not.

You have to select "use external security key" or similar, the first option. If you get the QR probably you are selecting the second option of "using security key" (not the external security key).

@benallard
Copy link

Thank you that is correct, I had tried the wrong option in the popup.

I managed to get some progress there. it seems firefox is working some times as well, you just have to wait long enough. (I was copying the prompt to insert a key, when it suddently chenged into "Enter PIN").

I just timed it, it seems like it's about 45-50sek. you have to wait between device insertion and prompt for your pin.

@polhenarejos
Copy link
Owner

I made a nightly automatic snapshot to build the firmwares in the development branch.

https://github.com/polhenarejos/pico-fido/releases/tag/nightly-development

Can you try if it is fixed with latest development firmware?

@benallard
Copy link

It worked!, thanks.
And thanks for modifying the led, that way I was sure I flashed the last version.

@metabo7000
Copy link

I made a nightly automatic snapshot to build the firmwares in the development branch.

https://github.com/polhenarejos/pico-fido/releases/tag/nightly-development

Can you try if it is fixed with latest development firmware?

Developer tell me! v5.8 does not work under windows Acccount (smartcard) mode only under android and linux under Yubico Authenticato under what is the reason?
v5.12 Yubico Authenticato Acccount (smartcard) mode now doesn't even work under linux, it just flashes blue!
Snap020

@polhenarejos
Copy link
Owner

polhenarejos commented Sep 28, 2024

This is a bug of Yubico Authenticator which its regex only accepts minor versions up to 9. This will be fixed with next version 6.0

This only affects to Smartcard and not ctap/fido.

@metabo7000
Copy link

This is a bug of Yubico Authenticator which its regex only accepts minor versions up to 9. This will be fixed with next version 6.0

This only affects to Smartcard and not ctap/fido.

Snap020
But we use the best in publishing!

@metabo7000
Copy link

This is a bug of Yubico Authenticator which its regex only accepts minor versions up to 9. This will be fixed with next version 6.0

This only affects to Smartcard and not ctap/fido.

v5.8
this is the question!

linux account is working! :)
Snap021

windows account he doesn't work? :(

Snap022

v5.12 fault linux and windows os to account !

@FSCSoft
Copy link

FSCSoft commented Nov 12, 2024

Yo tengo el mimo problema aún ya instale la versión 6.0

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants