Received: by 2002:ac0:aa62:0:0:0:0:0 with SMTP id w31-v6csp3302431ima; Tue, 23 Oct 2018 03:52:02 -0700 (PDT) X-Google-Smtp-Source: ACcGV63/F1CLK2LgT2rngD79ZU/D5wJE5ctuMhmkssLARZ47vWnYTHZoA0QXvn69c++4l0dnXSDu X-Received: by 2002:a62:798e:: with SMTP id u136-v6mr48204053pfc.95.1540291922508; Tue, 23 Oct 2018 03:52:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540291922; cv=none; d=google.com; s=arc-20160816; b=ZGVYS/GBBKoH4LtP6NQC508k3gdgMFyVnhQPkXB94thNIx6gO/DKeEmqdxNmIyKRZP qI4GjGnwjL6TUps9Q9VAb6nPl4QYzF+m1UX+O+0QfHlIL1j8zN3Vb/D+vYCFCDVNS4Nq xb7qRNSfGP7hZbcOZZy0ace/u6YJGH+dp6oYyeIWMauyrzARsSE1gs9GeepXWmVhoeNj S3KHQ8CYbZIiwGVwmKRrWykMXuiKApQ75uK4J5pmmWX02kAnGNX/2HRFoKkAXFEh8tFF L//z/ugX2RaP0D8ApNeA0d71aUChI795GvOxTLWj8uhbMNlr+gavreX5vScRW1pT6kcc 1tMg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:cc:to:subject :message-id:date:from:references:in-reply-to:mime-version :dkim-signature; bh=umVJRm+Q8LyQ43wRvgLS7GmIknwhy36zd2FIlxnBkSQ=; b=O3xEfeV/ebQv1vMChJvX5Qbc1VgLMT67iaMNc/E65WAHUXj/esXXAhphtFXJfHBJwt SydHLuF7+PHs2DgqDhSyhvkI+1gOAENWSlX1u2uEPvky8fJ5OhQgp0Dv0gPc8nC1Z8Za fYpZbsIeCVQkh49h3+csgsSBldXpr6yXrUvp5OgeM+6vtvG/W0GtkY7ZdwNtGsIj47Jv QfAuIFXGL9Gt1I+MtRrXkv6TWuLWr3SSsdUSsSSi2gwYx7skgKdq9RNpRQe8qVl1j0xd 7bKS0TR6jqKUDJugGoRE/yoHC5w8vl4UYQroxGqUr5Nmleewpi1Jabl57F5q6Sp3p8Nt FExQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=jRmlsPlM; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 185-v6si995522pff.270.2018.10.23.03.51.46; Tue, 23 Oct 2018 03:52:02 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=jRmlsPlM; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727813AbeJWTD2 (ORCPT + 99 others); Tue, 23 Oct 2018 15:03:28 -0400 Received: from mail-it1-f195.google.com ([209.85.166.195]:40558 "EHLO mail-it1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727250AbeJWTD2 (ORCPT ); Tue, 23 Oct 2018 15:03:28 -0400 Received: by mail-it1-f195.google.com with SMTP id i191-v6so1413929iti.5 for ; Tue, 23 Oct 2018 03:40:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=umVJRm+Q8LyQ43wRvgLS7GmIknwhy36zd2FIlxnBkSQ=; b=jRmlsPlMqiVzjkb0tVI9qGV4p4VddLjWwnIfzQLhiZjN1SQtgOXI1UUi4/Bwkqwt+x SkvrECsjUkDQUTs7CP//73FG9XMj7eLXSdMcSUjjk3ff7mPgOPWniPgT0nPabFGMZaMd LafKZOaBCx8XlF1gxrZxGgwPAsWxAqa4baCWg= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=umVJRm+Q8LyQ43wRvgLS7GmIknwhy36zd2FIlxnBkSQ=; b=bMmV7zs7pplmcda6WOVCuWAVfCZWPiozdrt85QjbOirJvRv5czklKyPJpckoYdWK4T jXx7YxmAmzjNGeMj8dGSa/WCnQFPjMlI4ToPIamshLxEadm7zC82HjNrytUIG4TfZzbc Ev3bwRKzHTKXBVKh7MQNbCZJfuMmdk47HhL76inqBwMqVsz/drBlievdReycPAPX3iGJ jhA4mjpj/2RwaQB8DUr0r8ZHJMrimAEwZLkYod13+hac5RB+nr7hdG6H2dfZPFrAuFBT zLSzOZPE8kDZZLhrFprvxQKHp+QUqK7qBOx6vWzC9h8PGdfdrsLi4AURc5xlmX555PYU /3XA== X-Gm-Message-State: ABuFfog4OCpZcksdhnrouK6LzEDaieX8oIAtu17e8mJz39yKDMvY1HNx Ix1fpEvFtPVmCaomGb6TDWkV0uWDaykOG3baiJUbKw== X-Received: by 2002:a05:660c:383:: with SMTP id x3mr10843540itj.121.1540291235318; Tue, 23 Oct 2018 03:40:35 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a6b:5910:0:0:0:0:0 with HTTP; Tue, 23 Oct 2018 03:40:34 -0700 (PDT) In-Reply-To: <20181020071206.GE876@sol.localdomain> References: <20181015175424.97147-1-ebiggers@kernel.org> <20181015175424.97147-12-ebiggers@kernel.org> <20181020071206.GE876@sol.localdomain> From: Ard Biesheuvel Date: Tue, 23 Oct 2018 07:40:34 -0300 Message-ID: Subject: Re: [RFC PATCH v2 11/12] crypto: adiantum - add Adiantum support To: Eric Biggers Cc: "open list:HARDWARE RANDOM NUMBER GENERATOR CORE" , linux-fscrypt@vger.kernel.org, linux-arm-kernel , Linux Kernel Mailing List , Herbert Xu , Paul Crowley , Greg Kaiser , Michael Halcrow , "Jason A . Donenfeld" , Samuel Neves , Tomer Ashur Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20 October 2018 at 15:12, Eric Biggers wrote: > Hi Ard, > > On Sat, Oct 20, 2018 at 12:17:58PM +0800, Ard Biesheuvel wrote: >> On 16 October 2018 at 01:54, Eric Biggers wrote: >> > From: Eric Biggers >> > >> > Add support for the Adiantum encryption mode. Adiantum was designed b= y >> > Paul Crowley and is specified by our paper: >> > >> > Adiantum: length-preserving encryption for entry-level processors >> > (https://eprint.iacr.org/2018/720.pdf) >> > >> > See our paper for full details; this patch only provides an overview. >> > >> > Adiantum is a tweakable, length-preserving encryption mode designed fo= r >> > fast and secure disk encryption, especially on CPUs without dedicated >> > crypto instructions. Adiantum encrypts each sector using the XChaCha1= 2 >> > stream cipher, two passes of an =CE=B5-almost-=E2=88=86-universal (=CE= =B5A=E2=88=86U) hash >> > function, and an invocation of the AES-256 block cipher on a single >> > 16-byte block. On CPUs without AES instructions, Adiantum is much >> > faster than AES-XTS; for example, on ARM Cortex-A7, on 4096-byte secto= rs >> > Adiantum encryption is about 4 times faster than AES-256-XTS encryptio= n, >> > and decryption about 5 times faster. >> > >> > Adiantum is a specialization of the more general HBSH construction. O= ur >> > earlier proposal, HPolyC, was also a HBSH specialization, but it used = a >> > different =CE=B5A=E2=88=86U hash function, one based on Poly1305 only.= Adiantum's >> > =CE=B5A=E2=88=86U hash function, which is based primarily on the "NH" = hash function >> > like that used in UMAC (RFC4418), is about twice as fast as HPolyC's; >> > consequently, Adiantum is about 20% faster than HPolyC. >> > >> > This speed comes with no loss of security: Adiantum is provably just a= s >> > secure as HPolyC, in fact slightly *more* secure. Like HPolyC, >> > Adiantum's security is reducible to that of XChaCha12 and AES-256, >> > subject to a security bound. XChaCha12 itself has a security reductio= n >> > to ChaCha12. Therefore, one need not "trust" Adiantum; one need only >> > trust ChaCha12 and AES-256. Note that the =CE=B5A=E2=88=86U hash func= tion is only >> > used for its proven combinatorical properties so cannot be "broken". >> > >> >> So what happens if the part of the input covered by the block cipher >> is identical between different generations of the same disk block >> (whose sector count is used as the 'outer' IV). How are we not in the >> same boat as before when using stream ciphers for disk encryption? >> > > This is the point of the hash step. The value encrypted with the block c= ipher > to produce the intermediate value C_M (used as the stream cipher nonce) i= s > H(T, P_L) + P_R. (T is the tweak a.k.a the IV, P_L is the plaintext exce= pt the > last 16 bytes, P_R is the last 16 bytes.) A collision in this value occu= rs iff: > > H(T1, P1_L) + P1_R =3D H(T2, P2_L) + P2_R > i.e. > H(T1, P1_L) - H(T2, P2_L) =3D P2_R - P1_R > > If (T1, P1_L) =3D (T2, P2_L) then P1_R !=3D P2_R so the equation has no s= olutions > (since we don't consider queries where the whole input is the same; those > unavoidably produce the same ciphertext). Otherwise (T1, P1_L) !=3D (T2,= P2_L), > and since the hash function H is =CE=B5-almost-=E2=88=86-universal over i= ntegers mod 2^128, > the equation is true for at most a very small proportion '=CE=B5' of hash= keys. > But, the hash key is chosen at random and is unknown to the attacker. > > The same applies in the other direction, for chosen ciphertext attacks. > > Basically, it's very difficult for an attacker to cause the intermediate = value > C_M to be reused, and the outputs will appear random until they do. > > Of course, all this is explained much more precisely and comprehensively = in our > paper. See section 5, "Security reduction". > Thanks for the explanation. I saw that the result of the AES encryption was used as the XChaCha nonce, but I failed to spot that the result of the nhpoly1305 pass is added/subtracted to/from that particular block first. In any case, this looks good to me: as far as I can tell, the code implements the algorithm as described in the paper, and the plumbing into the crypto API looks correct to me as well. Reviewed-by: Ard Biesheuvel Whether the paper is correct is a different matter: it looks convincing to me but IANAC. The only request I have is to add a speed test to tcrypt as well so we can easily benchmark it.