Skip to content
Naked Security Naked Security

Yubico recalls FIPS Yubikey tokens after flaw found

Security token maker Yubico has issued an important advisory affecting high-end versions of its YubiKey authentication key.

Security token maker Yubico has issued an important advisory affecting high-end versions of its YubiKey authentication key, arguably the most significant vulnerability discovered in this class of product to date.

Yubico describes the bug in its FIPS series as being:

Where the first set of random values used by YubiKey FIPS applications after each device power-up have reduced randomness … for the first operations performed after YubiKey FIPS power-up. The buffer holding random values contains some predictable content left over from the FIPS power-up self-tests which could affect cryptographic operations which require random data until the predictable content is exhausted.

In other words, for the first operation after power-up at least, the cryptographic material produced by the key isn’t as random as it should be for secure encryption, creating a hypothetical short-term weakness that is only ironed out when that data has been consumed.

This affects cryptographic algorithms to different extents. For RSA it’s a modest 80 bits out of a minimum of 2,048 while for ECDSA it’s more like 80 bits out of 256 which could:

Allow an attacker who gains access to several signatures to reconstruct the private key.

These differences mean that the weakness is worse in some products than in others, for example the PIV Smart Card and OpenPGP implementations (which use RSA) compared to the FIPS FIDO U2F keys (whose authentication depends on ECDSA).

FIPS with everything

The weakness exists only in the YubiKey FIPS, YubiKey Nano FIPS, YubiKey C FIPS, and YubiKey C Nano FIPS, that is products that have the ‘FIPS’ prefix printed on them. Consumer and most business YubiKeys are not affected.

The Federal Information Processing Standards, or FIPS, is a suite of US standards for products used in environments such as the federal government or military that demand sophisticated encryption, hashing and signing algorithms.

Getting even a basic FIPS certification is time-consuming and expensive because NIST has to test compliance to all sorts of security characteristics, including things like physical tamper-proofing in addition to the robustness in the way encryption algorithms have been implemented.

Device makers jump through these hoops because they have to – no FIPS compliance at the required level and selling to the Feds becomes a non-starter.

It’s worth mentioning all this because the issue of FIPS has had a direct influence on the timing of Yubico’s advisory.

Affected YubiKeys are those running firmware versions 4.4.2 and 4.4.4 (there is no 4.4.3), which should be updated to FIPS Series firmware version 4.4.5.

It seems the weakness was discovered some time ago but the fix only shipped to customers on 30 April 2019 once it had passed FIPS certification.

That’s the extra complication of FIPS, which applies to everything, including urgent security updates.

Total recall

As arcane as this might all sound, encryption stands and falls on fine margins. Even a modest theoretical weakness must be fixed ASAP and the new code submitted for checks.

In fairness to Yubico, security advisories affecting any of its products have been few and far between, and most of the small number that have come to light have been caused by interactions with other products, such as the Google Chrome’s WebUSB flaw discovered in 2018.

That said, the fact that something that looks as baked-in as a security token might require a firmware update or even physical replacement is a new experience for customers.

Coincidentally, Google recently suffered similar problems when a weakness was discovered in its implementation of the Bluetooth Low Energy (BLE) in the Bluetooth version of its Titan 2FA hardware tokens.

That forced a recall of affected keys, which at the time of writing no longer seem to be available for purchase.

Replacement service

If you own an affected FIPS YubiKey bought before 30 April 2019, it can be replaced at no charge although how this is done will depend on which channel it came through. FIPS YubiKeys ordered on or after that date have updated firmware and don’t need to be replaced. Yubico said:

At the time of this advisory, we estimate that the majority of affected YubiKey FIPS Series devices have been replaced, or are in process of replacement with updated, fixed versions of the devices.

2 Comments

Why wasn’t this caught when the products went through FIPS Validation?

Reply

Cryptographic flaws are hard to find if they are subtle, and detecting flawed random number sequences even harder still.

This seems to have been a case where the numbers coming out were random when treated as a sequence, but not every possible sequence would be generated, which could allow an attacker to crack the underlying crypto without doing as much work as theory suggested.

It’s a bit like knowing I have a 9-digit passcode, so you need to try one billion different passwords to be sure of cracking my account… but if someone realises I don’t like the digit 7, and never use 0 or 1, then their work would be cut to 79 different codes, which is only 40 million, and so my account would be a dangerous 25 times less secure than theory predicts.

But in a test where I give you 1000 goes at my password, or even 100,000 goes, you’re still so unlikely to guess correctly that your test wouldn’t reveal any deficiency in my digit selection process. You wouldn’t have any reason to conclude that I was 25 times less secure in practice than in theory…

Reply

Leave a Reply

Your email address will not be published. Required fields are marked *

Subscribe to get the latest updates in your inbox.
Which categories are you interested in?
You’re now subscribed!