Abstract

The FIDO Basic Attestation scheme uses attestation "group" keys shared across a set of authenticators with identical characteristics in order to preserve privacy by avoiding the introduction of global correlation handles. If such an attestation key is extracted from one single authenticator, it is possible to create a "fake" authenticator using the same key and hence indistinguishable from the original authenticators by the relying party. Removing trust for registering new authenticators with the related key would affect the entire set of authenticators sharing the same "group" key. Depending on the number of authenticators, this risk might be unacceptable high.

This is especially relevant when the attestation key is primarily protected against malware attacks as opposed to targeted physical attacks.

An alternative approach to "group" keys is the use of individual keys combined with a Privacy-CA [TPMv1-2-Part1]. Translated to FIDO, this approach would require one Privacy-CA interaction for each Uauth key. This means relatively high load and high availability requirements for the Privacy-CA. Additionally the Privacy-CA aggregates sensitive information (i.e. knowing the relying parties the user interacts with). This might make the Privacy-CA an interesting attack target.

Another alternative is the Direct Anonymous Attestation [BriCamChe2004-DAA]. Direct Anonymous Attestation is a cryptographic scheme combining privacy with security. It uses the authenticator specific secret once to communicate with a single DAA Issuer and uses the resulting DAA credential in the DAA-Sign protocol with each relying party. The DAA scheme has been adopted by the Trusted Computing Group for TPM v1.2 [TPMv1-2-Part1].

In this document, we specify the use of an improved DAA scheme based on elliptic curves and bilinear pairings largely compatible with [CheLi2013-ECDAA] called ECDAA. This scheme provides significantly improved performance compared with the original DAA and basic building blocks for its implementation are part of the TPMv2 specification [TPMv2-Part1].

Our improvements over [CheLi2013-ECDAA] mainly consist of security fixes (see [ANZ-2013] and [XYZF-2014]) when splitting the sign operation into two parts.

Status of This Document

This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current FIDO Alliance publications and the latest revision of this technical report can be found in the FIDO Alliance specifications index at https://www.fidoalliance.org/specifications/.

This document was published by the FIDO Alliance as a Implementation Draft. This document is intended to become a FIDO Alliance Proposed Standard. If you wish to make comments regarding this document, please Contact Us. All comments are welcome.

IMPLEMENTATION DRAFT

This Implementation Draft Specification has been prapared by FIDO Alliance, Inc. Permission is hereby granted to use the Specification solely for the purpose of implementing the Specification. No rights are granted to prepare derivative works of this Specification. Entities seeking permission to reproduce portions of this Specification for other uses must contact the FIDO Alliance to determine whether an appropriate license for such use is available.

Implementation of certain elements of this Specification may require licenses under third party intellectual property rights, including without limitation, patent rights. The FIDO Alliance, Inc. and its Members and any other contributors to the Specification are not, and shall not be held, responsible in any manner for identifying or failing to identify any or all such third party intellectual property rights.

THIS FIDO ALLIANCE SPECIFICATION IS PROVIDED “AS IS” AND WITHOUT ANY WARRANTY OF ANY KIND, INCLUDING, WITHOUT LIMITATION, ANY EXPRESS OR IMPLIED WARRANTY OF NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.

Table of Contents

1. Notation

Type names, attribute names and element names are written as code.

String literals are enclosed in “”, e.g. “ED256”.

In formulas we use “|” to denote byte wise concatenation operations.

X=Px denotes scalar multiplication (with scalar x) of a (elliptic) curve point P.

RAND(x) denotes generation of a random number between 0 and x-1.

RAND(G) denotes generation of a random number belonging to Group G.

Specific terminology used in this document is defined in [FIDOGlossary].

The type BigNumber denotes an arbitrary length integer value.

The type ECPoint denotes an elliptic curve point with its affine coordinates x and y.

The type ECPoint2 denotes a point on the sextic twist of a BN elliptic curve over F(q2). The ECPoint2 has two affine coordinates each having two components of type BigNumber

1.1 Conformance

As well as sections marked as non-normative, all authoring guidelines, diagrams, examples, and notes in this specification are non-normative. Everything else in this specification is normative.

The key words MUST, MUST NOT, REQUIRED, SHOULD, SHOULD NOT, RECOMMENDED, MAY, and OPTIONAL in this specification are to be interpreted as described in [RFC2119].

2. Overview

This section is non-normative.

FIDO uses the concept of attestation to provide a cryptographic proof of the authenticator [FIDOGlossary] model to the relying party. When the authenticator is registered to the relying party (RP), it generates a new authentication key pair and includes the public key in the attestation message (also known as key registration data object, KRD). When using the ECDAA algorithm, the KRD object is signed using 3.5 ECDAA-Sign.

For privacy reasons, the authentication key pair is dedicated to one RP (to an application identifier AppID [FIDOGlossary] to be more specific). Consequently the attestation method needs to provide the same level of unlinkability. This is the reason why the FIDO ECDAA Algorithm doesn't use a basename (bsn) often found in other direct anonymous attestation algorithms, e.g. [BriCamChe2004-DAA] or [BFGSW-2011].

The authenticator encapsulates all user verification operations and cryptographic functions. An authenticator specific module (ASM) [FIDOGlossary] is used to provide a standardized communication interface for authenticators. The authenticator might be implemented in separate hardware or trusted execution environments. The ASM is assumed to run in the normal operating system (e.g. Android, Windows, ...).

2.1 Scope

This document describes the FIDO ECDAA attestation algorithm in detail.

2.2 Architecture Overview

ECDAA attestation defines global system parameters and issuer specific parameters. Both parameter sets need to be installed on the host, in the authenticator and in the FIDO Server. The ECDAA method consists of two steps:

The technical implementation details of the ECDAA-Join step are out-of-scope for FIDO. In this document we normatively specify the general algorithm to the extent required for interoperability and we outline examples of some possible implementations for this step.

The ECDAA-Sign and ECDAA-Verify steps and the encoding of the related ECDAA Signature are normatively specified in this document. The generation and encoding of the KRD object is defined in other FIDO specifications.

The algorithm and terminology are inspired by [BFGSW-2011]. The algorithm was modified in order to fix security weaknesses (e.g. as mentioned by [ANZ-2013] and [XYZF-2014]). Our algorithm proposes an improved task split for the sign operation while still being compatible to TPMv2 (without fixing the TPMv2 weaknesses in such case).

3. FIDO ECDAA Attestation

This section is normative.

3.1 Object Encodings

We need to convert BigNumber and ECPoint objects to byte strings using the following encoding functions:

3.1.1 Encoding BigNumber values as byte strings (BigNumberToB)

We use the I2OSP algorithm as defined in [RFC3447] for converting big numbers to byte arrays. The bytes from the big endian encoded (non-negative) number n will be copied right-aligned into the buffer area b. The unused bytes will be set to 0. Negative values will not occur due to the construction of the algorithms.
Example 1: Converting BigNumber n to byte string b
b0 b1 b2 b3 b4 b5 b6 b7
 0  0 n0 n1 n2 n3 n4 n5
The algorithm implemented in Java looks like this:
Example 2: Algorithm for converting BigNumber to byte strings
ByteArray BigNumberToB(
      BigNumber inVal, // IN: number to convert
      int size         // IN: size of the output.
     )
{
  ByteArray buffer = new ByteArray(size);
  int oversize = size - inVal.length;
  if (oversize < 0)
    return null;
  for (int i=overvize; i > 0; i--)
     buffer[i] = 0;
  ByteCopy( inVal.bytes, &buffer[oversize], inVal.length);
 return buffer;
}

3.1.2 Encoding ECPoint values as byte strings (ECPointToB)

We use the ANSI X9.62 Point-to-Octet-String [ECDSA-ANSI] conversion using the expanded format, i.e. the format where the compression byte (i.e. 0x04 for expanded) is followed by the encoding of the affine x coordinate, followed by the encoding of the affine y coordinate.
Example 3: Converting ECPoint P to byte string
(x, y) = ECPointGetAffineCoordinates(P)
len = G1.byteLength
byte string = 0x04 | BigIntegerToB(x,len) | BigIntegerToB(y,len)

3.1.3 Encoding ECPoint2 values as byte strings (ECPoint2ToB)

The type ECPoint2 denotes a point on the sextic twist of a BN elliptic curve over F(q2), see section 4.1 Supported Curves for ECDAA. Each ECPoint2 is represented by a pair (a, b) of elements of F(q).

The group zero element is always encoded (using the encoding rules as described below) as a an element having all components set to zero (i.e. cx.a=0, cx.b=0, cy.a=0, cy.b=0).

We always assume normalized (non-zero) ECPoint2 values (i.e. cz = 1) before encoding them. Non-zero values are encoded using the expanded format (i.e. 0x04 for expanded) followed by the cx followed by the cy value. This leads to the concatenation of 0x04 followed by the first element (cx.a) and second element (cx.b) of the pair of cx followed by the first element (cy.a) and second element (cy.b) of the pair of cy. All individual numbers are padded to the same length (i.e. the maximum byte length of all relevant 4 numbers).

Example 4: Converting ECPoint2 P2 to byte string
(cx, cy) = ECPointGetAffineCoordinates(P2)
len = G2.byteLength
byte string = 0x04 | BigIntegerToB(cx.a,len) | BigIntegerToB(cx.b,len) 
              | BigIntegerToB(cy.a,len) | BigIntegerToB(cy.b,len)

3.2 Global ECDAA System Parameters

  1. Groups G1, G2 and GT, of sufficiently large prime order p
  2. Two generators P1 and P2, such that G1=P1 and G2=P2
  3. A bilinear pairing e:G1×G2GT. We propose the use of "ate" pairing (see [BarNae-2006]). For example source code on this topic, see BNPairings.
  4. Hash function H with H:{0,1}Zp.
  5. (G1,P1,p,H) are installed in all authenticators implementing FIDO ECDAA attestation.

Definition of G1,G2,GT, Pairings and hash function H

See section 4.1 Supported Curves for ECDAA.

3.3 Issuer Specific ECDAA Parameters

Issuer Parameters parI
  1. Randomly generated issuer private key isk=(x,y) with [x,y=RAND(p)].
  2. Issuer public key (X,Y), with X=P2x and Y=P2y.
  3. A proof that the issuer key was correctly computed
    1. BigInteger rx=RAND(p)
    2. BigInteger ry=RAND(p)
    3. ECPoint2 Ux=P2rx
    4. ECPoint2 Uy=P2ry
    5. BigInteger c=H(Ux|Uy|P2|X|Y)
    6. BigInteger sx=rx+cx(modp)
    7. BigInteger sy=ry+cy(modp)
  4. ipk=X,Y,c,sx,sy
Whenever a party uses ipk for the first time, it must first verify that it was correctly generated:

H(P2sxXc|P2syYc|P2|X|Y)=?c

Note

P2sxXc=P2rx+cxP2cx=P2rx=Ux

P2syYc=P2ry+cyP2cy=P2ry=Uy

The ECDAA-Issuer public key ipk MUST be dedicated to a single authenticator model.

3.4 ECDAA-Join

Note

One ECDAA-Join operation is required once in the lifetime of an authenticator prior to the first registration of a credential.

In order to use ECDAA, the authenticator must first receive ECDAA credentials from an ECDAA-Issuer. This is done by the ECDAA-Join operation. This operation needs to be performed a single time (before the first credential registration can take place). After the ECDAA-Join, the authenticator will use the ECDAA-Sign operation as part of each FIDO Registration. The ECDAA-Issuer is not involved in this step. ECDAA plays no role in FIDO Authentication / Transaction Confirmation operations.

In order to use ECDAA, (at least) one ECDAA-Issuer is needed. The approach specified in this document easily scales to multiple ECDAA-Issuers, e.g. one per authenticator vendor. FIDO lets the authenticator vendor choose any ECDAA-Issuer (similar to his current freedom for selecting any PKI infrastructure/service provider to issuing attestation certificates required for FIDO Basic Attestation).

There are two different implementation options relevant for the authenticator Vendors (the authenticator vendor can freely choose them):

  1. In-Factory ECDAA-Join
  2. Remote ECDAA-Join and

In the first case, physical proximity is used to locally establish the trust between the ECDAA-Issuer and the authenticator (e.g. using a key provisioning station in a production line). There is no requirement for the ECDAA-Issuer to operate an online web service.

In the second case, some credential is required to remotely establish the trust between the ECDAA-Issuer and the authenticator. As this operation is performed once and only with a single ECDAA-Issuer, privacy is preserved and an authenticator specific credential can and should be used.

Not all ECDAA authenticators might be able to add their authenticator model IDs (e.g. AAGUID) to the registration assertion (e.g. TPMs). In all cases, the ECDAA-Issuer will be able to derive the exact the authenticator model from either the credential or the physically proximiate authenticator. So the ECDAA-Issuer root key MUST be dedicated to a single authenticator model.

3.4.1 ECDAA-Join Algorithm

This section is normative.

Note

If this join is not in-factory, the value Q must be authenticated by the authenticator. Upon receiving this value, the issuer must verify that this authenticator did not join before.

  1. The authenticator asks the issuer for a nonce.
  2. The issuer chooses a nonce BigInteger n=RAND(p) and sends n via the ASM to the authenticator.
  3. The authenticator chooses and stores the ECDAA private key BigInteger sk=RAND(p)
  4. The authenticator computes its ECDAA public key ECPoint Q=P1sk
  5. The authenticator proves knowledge of sk as follows
    1. BigInteger r1=RAND(p)
    2. ECPoint U1=P1r1
    3. BigInteger c1=H(U1|P1|Q|n)
    4. BigInteger s1=r1+c1sk
  6. The authenticator sends Q,c1,s1 via the ASM to the issuer
  7. The issuer verifies that the authenticator is "authentic" and that Q was indeed generated by the authenticator. In the case of an in-factory Join, this might be trivial; in the case of a remote Join this typically requires the use of other cryptographic methods. Since ECDAA-Join is a one-time operation, unlinkability is not a concern for that.
  8. The issuer verifies that QG1 and verifies H(P1s1Qc1|P1|Q|n)=?c1 (check proof-of-possession of private key).
    Note

    P1s1Qc1=P1r1+c1skQc1=P1r1+c1skP1c1sk=P1r1=U1

  9. The issuer creates credential (A,B,C,D) as follows
    1. BigInteger lJ=RAND(p)
    2. ECPoint A=P1lJ
    3. ECPoint B=Ay
    4. ECPoint C=AxQxylJ
    5. ECPoint D=QlJy
  10. The issuer proves that it computed this credential correctly:
    1. BigInteger r2=RAND(p)
    2. ECPoint U2=P1r2
    3. ECPoint V2=Qr2
    4. BigInteger c2=H(U2|V2|P1|B|Q|D)
    5. BigInteger s2=r2+c2lJy
  11. The issuer sends A,B,C,D,c2,s2 to the authenticator.
  12. The authenticator checks that A,B,C,DG1 and A1G1
  13. The authenticator checks H(P1s2Bc2|Qs2Dc2|P1|B|Q|D)=?c2
  14. Note

    P1s2Bc2=P1r2P1c2lJyBc2=U2Bc2Bc2=U2

    Qs2Dc2=Qr2Qc2lJyDc2=V2Dc2Dc2=V2

  15. The authenticator checks e(A,Y)=?e(B,P2)
    Note

    e(A,Y)=e(P1lJ,P2y); e(B,P2)=e(Ay,P2)=e(P1ylJ,P2)

  16. and the authenticator checks e(C,P2)=?e(AD,X)
    Note

    e(C,P2)=e(AxQxylJ,P2); e(AD,X)=e(AQylJ,P2x)

  17. The authenticator stores credential A,B,C,D

3.4.2 ECDAA-Join Split between Authenticator and ASM

This section is non-normative.

Note

If this join is not in-factory, the value Q must be authenticated by the authenticator. Upon receiving this value, the issuer must verify that this authenticator did not join before.

  1. The ASM asks the issuer for a nonce.
  2. The issuer chooses a nonce BigInteger n=RAND(p) and sends n to the ASM.
  3. The ASM forwards n to the authenticator
  4. The authenticator chooses and stores the private key BigInteger sk=RAND(p)
  5. The authenticator computes its ECDAA public key ECPoint Q=P1sk
  6. The authenticator proves knowledge of sk as follows
    1. BigInteger r1=RAND(p)
    2. ECPoint U1=P1r1
    3. BigInteger c1=H(U1|P1|Q|n)
    4. BigInteger s1=r1+c1sk
  7. The authenticator sends Q,c1,s1 to the ASM, who forwards it to the issuer.
  8. The issuer verifies that the authenticator is "authentic" and that Q was indeed generated by the authenticator. In the case of an in-factory Join, this might be trivial; in the case of a remote Join this typically requires the use of other cryptographic methods. Since ECDAA-Join is a one-time operation, unlinkability is not a concern for that.
  9. The issuer verifies that QG1 and verifies H(P1s1Qc1|P1|Q|n)=?c1.
  10. The issuer creates credential (A,B,C,D) as follows
    1. BigInteger lJ=RAND(p)
    2. ECPoint A=P1lJ
    3. ECPoint B=Ay
    4. ECPoint C=AxQxylJ
    5. ECPoint D=QlJy
  11. The issuer proves that it computed this credential correctly:
    1. BigInteger r2=RAND(p)
    2. ECPoint U2=P1r2
    3. ECPoint V2=Qr2
    4. BigInteger c2=H(U2|V2|P1|B|Q|D)
    5. BigInteger s2=r2+c2lJy
  12. The issuer sends A,B,C,D,c2,s2 to the ASM. The issuer authenticates B,D,c2,s2 such that the authenticator can verify they were created by the issuer.
  13. The ASM checks that A,B,C,DG1 and A1G1
  14. The ASM checks H(P1s2Bc2|Qs2Dc2|P1|B|Q|D)=?c2
  15. The ASM checks e(A,Y)=?e(B,P2)
  16. and the ASM checks that e(C,P2)=?e(AD,X)
  17. The ASM stores A,B,C,D and sends B,D,c2,s2 to the authenticator
  18. The authenticator checks B,DG1 and B1G1, and verifies that B,D,c2,s2 were sent by the issuer.
  19. The authenticator checks H(P1s2Bc2|Qs2Dc2|P1|B|Q|D)=?c2
  20. The authenticator stores B,D and ignores further join requests.
    Note

    These values belong to the ECDAA secret key sk. They should persist even in the case of a factory reset.

3.4.3 ECDAA-Join Split between TPM and ASM

This section is non-normative.

Note

The Endorsement key credential (EK-C) and TPM2_ActivateCredentials are used for supporting the remote Join.

This description is based on the principles described in [TPMv2-Part1] section 24 and [Arthur-Challener-2015], page 109 ("Activating a Credential").

  1. The ASM asks the ECDAA Issuer for a nonce.
  2. The ECDAA Issue chooses a nonce BigInteger n=RAND(p) and sends n to the ASM.
  3. The ASM
    1. instructs the TPM to create a restricted key by calling TPM2_Create, giving the public key template TPMT_PUBLIC [TPMv2-Part2] (including the public key Q in field unique) to the ASM.
    2. retrieves TPM Endorsement Key Certificate (EK-C) from the TPM
    3. calls TPM2_Commit(keyhandle, P1, s2, y2) where keyhandle is the handle of the restricted key generated before (see above), P1 is set to P1, and s2 and y2 are left empty. This call returns K, L, E, and ctr; where K and L will be empty.
    4. computes BigInteger c1=H(E|P1|Q|n)
    5. call TPM2_Sign(c1, ctr), returning s1.
    6. sends EK-C, TPMT_PUBLIC (including Q in field unique), c1,s1 to the ECDAA Issuer.
  4. The ECDAA Issuer
    1. verifies EK-C and its certificate chain. As a result the ECDAA Issuer knows the TPM model related to EK-C.
    2. verifies that this EK-C was not used in a (successful) Join before
    3. Verifies that the objectAttributes in TPMT_PUBLIC [TPMv2-Part2] matches the following flags: fixedTPM = 1; fixedParent = 1; sensitiveDataOrigin = 1; encryptedDuplication = 0; restricted = 1; decrypt = 0; sign = 1.
    4. examines the public key Q, i.e. it verifies that QG1
    5. checks H(P1s1Qc1|P1|Q|n)=?c1
    6. generates the ECDAA credential (A,B,C,D) as follows
      1. BigInteger lJ=RAND(p)
      2. ECPoint A=P1lJ
      3. ECPoint B=Ay
      4. ECPoint C=AxQxylJ
      5. ECPoint D=QlJy
    7. proves that it computed this credential correctly:
      1. BigInteger r2=RAND(p)
      2. ECPoint U2=P1r2
      3. ECPoint V2=Qr2
      4. BigInteger c2=H(U2|V2|P1|B|Q|D)
      5. BigInteger s2=r2+c2lJy
    8. generates a secret (derived from a seed) and wraps the credential A,B,C,D using that secret.
    9. encrypts the seed using the public key included in EK-C.
    10. uses seed and name in KDFa (see [TPMv2-Part2] section 24.4) to derive HMAC and symmetric encryption key. Wrap the secret in symmetric encryption key and protect it with the HMAC key.
      Note

      The parameter name in KDFa is derived from TPMT_PUBLIC, see [TPMv2-Part1], section 16.

    11. sends the credential proof c2,s2 and the wrapped object including the credential from previous step to the ASM.
  5. The ASM instructs the TPM (by calling TPM2_ActivateCredential) to
    1. decrypt the seed using the TPM Endorsement key
    2. compute the name (for the ECDAA attestation key)
    3. use the seed in KDFa (with name) to derive the HMAC key and the symmetric encryption key.
    4. use the symmetric encryption key to unwrap the secret.
  6. The ASM
    1. unwraps the credential A,B,C,D using the secret received from the TPM.
    2. checks that A,B,C,DG1 and A1G1
    3. checks H(P1s2Bc2|Qs2Dc2|P1|B|Q|D)=?c2
    4. checks e(A,Y)=?e(B,P2) and e(C,P2)=?e(AD,X)
    5. stores A,B,C,D

3.5 ECDAA-Sign

Note

One ECDAA-Sign operation is required for the client-side environment whenever a new credential is being registered at a relying party.

3.5.1 ECDAA-Sign Algorithm

This section is normative.

(signature, KRD) = EcdaaSign(String AppID)

Parameters

  • p: System parameter prime order of group G1 (global constant)
  • AppID: FIDO AppID (i.e. https-URL of TrustedFacets object)

Algorithm outline

  1. KRD = BuildAndEncodeKRD(); // all traditional Registration tasks are here
  2. BigNumber l=RAND(p)
  3. ECPoint R=Al;
  4. ECPoint S=Bl;
  5. ECPoint T=Cl;
  6. ECPoint W=Dl;
  7. BigInteger r=RAND(p)
  8. ECPoint U=Sr
  9. BigInteger c=H(U|S|W|AppID|H(KRD))
  10. BigInteger s=r+csk(modp)
  11. signature = (c, s, R, S, T, W)
  12. return (signature, KRD)

3.5.2 ECDAA-Sign Split between Authenticator and ASM

This section is non-normative.

Note

This split requires both the authenticator and ASM to be honest to achieve anonymity. Only the authenticator must be trusted for unforgeability. The communication between ASM and authenticator must be secure.

Algorithm outline

  1. The ASM randomizes the credential
    1. BigNumber l=RAND(p)
    2. ECPoint R=Al;
    3. ECPoint S=Bl;
    4. ECPoint T=Cl;
    5. ECPoint W=Dl;
  2. The ASM sends l,AppID to the authenticator
  3. The authenticator performs the following tasks
    1. KRD = BuildAndEncodeKRD(); // all traditional Registration tasks are here
    2. ECPoint S=Bl
    3. ECPoint W=Dl
    4. BigInteger r=RAND(p)
    5. ECPoint U=Sr
    6. BigInteger c=H(U|S|W|AppID|H(KRD))
    7. BigInteger s=r+csk(modp)
    8. Send c,s,KRD to the ASM
  4. The ASM sets signature = (c, s, R, S, T, W) and outputs (signature, KRD)

3.5.3 ECDAA-Sign Split between TPM and ASM

This section is non-normative.

Note

This algorithm is for the special case of a TPMv2 as authenticator. This case requires both the TPM and ASM to be honest for anonymity and unforgeability (see [XYZF-2014]).

Algorithm outline

  1. The ASM randomizes the credential
    1. BigNumber l=RAND(p)
    2. ECPoint R=Al;
    3. ECPoint S=Bl;
    4. ECPoint T=Cl;
    5. ECPoint W=Dl;
  2. The ASM calls TPM2_Commit() with P1 set to S and s2,y2 empty buffers. The ASM receives the result values K,L,E=Sr and ctr. K and L are empty since s2,y2 are empty buffers.
  3. The ASM calls TPM2_Create to generate the new authentication key pair.
  4. The ASM calls TPM2_Certify() on the newly created key with ctr from the TPM2_Commit and E,S,W,AppID as qualifying data (E=Sr is returned by step 2). The ASM receives signature c,s and attestation block KRD (i.e. TPMS_ATTEST structure in this case).
  5. The ASM sets signature = (c, s, R, S, T, W) and outputs (signature, KRD)

3.6 ECDAA-Verify Operation

This section is normative.

Note

One ECDAA-Verify operation is required for the FIDO Server as part of each FIDO Registration.

boolean EcdaaVerify(signature, AppID, KRD, ModelName)

Parameters

Algorithm outline

  1. Based on the claimed ModelName, look up X,Y from trusted source
  2. Check that R,S,T,WG1, R1G1, and S1G1.
  3. H(SsWc|S|W|AppID|H(KRD))=?c; fail if not equal
    Note

    B=Ay=P1ly

    D=QlJy=P1sklJy=Bsk

    S=Bl and W=Dl

    U=Sr

    SsWc=Sr+cskWc=UScskWc
    =UBlcskDlc=UBlcskBlcsk=U

  4. e(R,Y)=?e(S,P2); fail if not equal
    Note

    e(R,Y)=e(Al,P2y);e(S,P2)=e(Bl,P2)=e(Aly,P2)

  5. e(T,P2)=?e(RW,X); fail if not equal
    Note

    e(T,P2)=e(Cl,P2)=e(AxlQxlylJ,P2);e(AlDl,X)=e(AlQlylJ,P2x)

  6. for (all sk' on RogueList) do if W=?Ssk fail;
  7. // perform all other processing steps for new credential registration
    Note
    In the case of a TPMv2, i.e. KRD is a TPMS_ATTEST object. In this case the verifier must check whether the TPMS_ATTEST object starts with TPM_GENERATED magic number and whether its field objectAttributes contains the flag fixedTPM=1 (indicating that the key was generated by the TPM).
  8. return true;

4. FIDO ECDAA Object Formats and Algorithm Details

This section is normative.

4.1 Supported Curves for ECDAA

Definition of G1

G1 is an elliptic curve group E : y2=x3+ax+b over F(q) with a=0.

Definition of G2

G2 is the p-torsion subgroup of E(Fq2) where E' is a sextic twist of E. With E' : y2=x3+b.

An element of F(q2) is represented by a pair (a,b) where a + bX is an element of F(q)[X]/<X2+1>. We use angle brackets <Y> to signify the ideal generated by the enclosed value.

Note

In the literature the pair (a,b) is sometimes also written as a complex number a+bi.

Definition of GT

GT is an order-p subgroup of Fq12.

Pairings

We propose the use of Ate pairings as they are efficient (more efficient than Tate pairings) on Barreto-Naehrig curves [DevScoDah2007].

Supported BN curves

We use pairing-friendly Barreto-Naehrig [BarNae-2006] [ISO15946-5] elliptic curves. The curves TPM_ECC_BN_P256 and TPM_ECC_BN_P638 curves are defined in [TPMv2-Part4].

BN curves have a Modulus q=36u4+36u3+24u2+6u+1 [ISO15946-5] and a related order of the group p=36u4+36u3+18u2+6u+1 [ISO15946-5].

  • TPM_ECC_BN_P256 is a curve of form E(F(q)), where q is the field modulus [TPMv2-Part4] [BarNae-2006]. This curve is identical to the P256 curve defined in [ISO15946-5] section C.3.5.
    • The values have been generated using u=-7 530 851 732 716 300 289.
    • Modulus q = 115 792 089 237 314 936 872 688 561 244 471 742 058 375 878 355 761 205 198 700 409 522 629 664 518 163
    • Group order p = 115 792 089 237 314 936 872 688 561 244 471 742 058 035 595 988 840 268 584 488 757 999 429 535 617 037
    • p and q have length of 256 bit each.
    • b = 3
    • P1_256 = (x=1, y=2)
    • b = (a=3, b=3)
    • P2_256 = (x,y), with
      • P2_256.x = (a=114 909 019 869 825 495 805 094 438 766 505 779 201 460 871 441 403 689 227 802 685 522 624 680 861 435, b=35 574 363 727 580 634 541 930 638 464 681 913 209 705 880 605 623 913 174 726 536 241 706 071 648 811)
      • P2_256.y = (a=65 076 021 719 150 302 283 757 931 701 622 350 436 355 986 716 727 896 397 520 706 509 932 529 649 684, b=113 380 538 053 789 372 416 298 017 450 764 517 685 681 349 483 061 506 360 354 665 554 452 649 749 368)
  • TPM_ECC_BN_P638 [TPMv2-Part4] uses
    • The values have been generated using u=365 375 408 992 443 362 629 982 744 420 548 242 302 862 098 433
    • Modulus q = 641 593 209 463 000 238 284 923 228 689 168 801 117 629 789 043 238 356 871 360 716 989 515 584 497 239 494 051 781 991 794 253 619 096 481 315 470 262 367 432 019 698 642 631 650 152 075 067 922 231 951 354 925 301 839 708 740 457 083 469 793 717 125 223
    • The related order of the group is p = 641 593 209 463 000 238 284 923 228 689 168 801 117 629 789 043 238 356 871 360 716 989 515 584 497 239 494 051 781 991 794 252 818 101 344 337 098 690 003 906 272 221 387 599 391 201 666 378 807 960 583 525 233 832 645 565 592 955 122 034 352 630 792 289
    • p and q have length of 638 bit each.
    • b = 257
    • P1_638 = (x=641 593 209 463 000 238 284 923 228 689 168 801 117 629 789 043 238 356 871 360 716 989 515 584 497 239 494 051 781 991 794 253 619 096 481 315 470 262 367 432 019 698 642 631 650 152 075 067 922 231 951 354 925 301 839 708 740 457 083 469 793 717 125 222, y=16)
    • b = (a=771, b=1542)
    • P2_638 = (x, y), with
      • P2_638.x = (a=192 492 098 325 059 629 927 844 609 092 536 807 849 769 208 589 403 233 289 748 474 758 010 838 876 457 636 072 173 883 771 602 089 605 233 264 992 910 618 494 201 909 695 576 234 119 413 319 303 931 909 848 663 554 062 144 113 485 982 076 866 968 711 247, b=166 614 418 891 499 184 781 285 132 766 747 495 170 152 701 259 472 324 679 873 541 478 330 301 406 623 174 002 502 345 930 325 474 988 134 317 071 869 554 535 111 092 924 719 466 650 228 182 095 841 246 668 361 451 788 368 418 036 777 197 454 618 413 255)
      • P2_638.y = (a=622 964 952 935 200 827 531 506 751 874 167 806 262 407 152 244 280 323 674 626 687 789 202 660 794 092 633 841 098 984 322 671 973 226 667 873 503 889 270 602 870 064 426 165 592 237 410 681 318 519 893 784 898 821 343 051 339 820 566 224 981 344 169 470, b=514 285 963 827 225 043 076 463 721 426 569 583 576 029 220 880 138 564 906 219 230 942 887 639 456 599 654 554 743 732 087 558 187 149 207 036 952 474 092 411 405 629 612 957 921 369 286 372 038 525 830 610 755 207 588 843 864 366 759 521 090 861 911 494)
  • ECC_BN_DSD_P256 [DevScoDah2007] section 3 uses
    • The values have been generated using u=6 917 529 027 641 089 837
    • Modulus q = 82434016654300679721217353503190038836571781811386228921167322412819029493183
    • The related order of the group is p = 82434016654300679721217353503190038836284668564296686430114510052556401373769
    • p and q have length of 256 bit each.
    • b = 3
    • P1_DSD_P256 = (1, 2)
    • b = (a=3, b=6)
    • P2_DSD_P256 = (x, y), with
      • P2_DSD_P256.x = (a=73 481 346 555 305 118 071 940 904 527 347 990 526 214 212 698 180 576 973 201 374 397 013 567 073 039, b=28 955 468 426 222 256 383 171 634 927 293 329 392 145 263 879 318 611 908 127 165 887 947 997 417 463)
      • P2_DSD_P256.y = (a=3 632 491 054 685 712 358 616 318 558 909 408 435 559 591 759 282 597 787 781 393 534 962 445 630 353, b=60 960 585 579 560 783 681 258 978 162 498 088 639 544 584 959 644 221 094 447 372 720 880 177 666 763)
  • ECC_BN_ISOP512 [ISO15946-5] section C.3.7 uses
    • The values have been generated using u=138 919 694 570 470 098 040 331 481 282 401 523 727
    • Modulus q = 13 407 807 929 942 597 099 574 024 998 205 830 437 246 153 344 875 111 580 494 527 427 714 590 099 881 795 845 981 157 516 604 994 291 639 750 834 285 779 043 186 149 750 164 319 950 153 126 044 364 566 323
    • The related order of the group is p = 13 407 807 929 942 597 099 574 024 998 205 830 437 246 153 344 875 111 580 494 527 427 714 590 099 881 680 053 891 920 200 409 570 720 654 742 146 445 677 939 306 408 461 754 626 647 833 262 056 300 743 149
    • p and q have length of 512 bit each.
    • b = 3
    • P1_ISO_P512 = (x=1,y=2)
    • b = (a=3, b=3)
    • P2_ISO_P512 = (x, y), with
      • P2_ISO_P512.x = (a=3 094 648 157 539 090 131 026 477 120 117 259 896 222 920 557 994 037 039 545 437 079 729 804 516 315 481 514 566 156 984 245 473 190 248 967 907 724 153 072 490 467 902 779 495 072 074 156 718 085 785 269, b=3 776 690 234 788 102 103 015 760 376 468 067 863 580 475 949 014 286 077 855 600 384 033 870 546 339 773 119 295 555 161 718 985 244 561 452 474 412 673 836 012 873 126 926 524 076 966 265 127 900 471 529)
      • P2_ISO_P512.y = (a=7 593 872 605 334 070 150 001 723 245 210 278 735 800 573 263 881 411 015 285 406 372 548 542 328 752 430 917 597 485 450 360 707 892 769 159 214 115 916 255 816 324 924 295 339 525 686 777 569 132 644 242, b=9 131 995 053 349 122 285 871 305 684 665 648 028 094 505 015 281 268 488 257 987 110 193 875 868 585 868 792 041 571 666 587 093 146 239 570 057 934 816 183 220 992 460 187 617 700 670 514 736 173 834 408)
Note

Spaces are used inside numbers to improve readability.

Hash Algorithms

Depending on the curve, we use H(x) = SHA256(x) mod p or H(x) = SHA512(x) mod p as hash algorithm H:{0,1}Zp.

The argument of the hash function must always be converted to a byte string using the appropriate encoding function specific in section 3.1 Object Encodings, e.g. according to section 3.1.3 Encoding ECPoint2 values as byte strings (ECPoint2ToB) in the case of ECPoint2 points.

Note

We don't use IEEE P1363.3 section 6.1.1 IHF1-SHA with security parameter t (e.g. t=128 or 256) as it is more complex and not supported by TPMv2.

4.2 ECDAA Algorithm Names

We define the following JWS-style algorithm names (see [RFC7515]):
ED256
TPM_ECC_BN_P256 curve, using SHA256 as hash algorithm H.
ED256-2
ECC_BN_DSD_P256 curve, using SHA256 as hash algorithm H.
ED512
ECC_BN_ISOP512 curve, using SHA512 as hash algorithm H.
ED638
TPM_ECC_BN_P638 curve, using SHA512 as hash algorithm H.

4.3 ecdaaSignature object

The fields c and s both have length N. The fields R, S, T, W have equal length (2*N+1 each).

In the case of BN_P256 curve (with key length N=32 bytes), the fields R, S, T, W have length 2*32+1=65 bytes. The fields c and s have length N=32 each.

The ecdaaSignature object is a binary object generated as the concatenation of the binary fields in the order described below (total length of 324 bytes for 256bit curves):

Value Length (in Bytes) Description
UINT8[] ECDAA_Signature_c N The c value, c=H(U | S | W | KRD | AppID) as returned by AuthnrEcdaaSign encoded as byte string according to BigNumberToB.

Where

  • U=Sr, with r=RAND(p) computed by the signer.
  • KRD is the the entire to-be-signed object (e.g. TAG_UAFV1_KRD in the case of FIDO UAF).
  • S=Bl, with l=RAND(p) computed by the signer and B=Ay computed in the ECDAA-Join

UINT8[] ECDAA_Signature_s N The s value, s=r + c * sk (mod p), as returned by AuthnrEcdaaSign encoded as byte string according to BigNumberToB.

Where

UINT8[] ECDAA_Signature_R 2*N+1 R=Al; computed by the ASM or the authenticator at FIDO registration; encoded as byte string according to ECPointToB. Where
  • l = RAND(p), i.e. random number 0≤l≤p. Computed by the ASM or the authenticator at FIDO registration.
  • And where R=Al denotes the scalar multiplication (of scalar l) of a curve point A.
  • Where A has been provided by the ECDAA-Issuer as part of ECDAA-Join: A=P1lJ, see 3.4.1 ECDAA-Join Algorithm.
  • Where P1 and p are system values, injected into the authenticator and lJ is a random number computed by the ECDAA-Issuer on Join.
UINT8[] ECDAA_Signature_S 2*N+1 S=Bl; computed by the ASM or the authenticator at FIDO registration encoded as byte string according to ECPointToB.

Where B has been provided by the ECDAA-Issuer on Join: B=Ay, see 3.4.1 ECDAA-Join Algorithm.

UINT8[] ECDAA_Signature_T 2*N+1 T=Cl; computed by the ASM or the authenticator at FIDO registration encoded as byte string according to ECPointToB. Where
  • C=AxQxylJ, provided by the ECDAA-Issuer on Join
  • lJ=RAN</