Re: [Cfrg] BLS standard draft

Michael Scott <mike.scott@miracl.com> Tue, 05 March 2019 17:42 UTC

Return-Path: <mike.scott@miracl.com>
X-Original-To: cfrg@ietfa.amsl.com
Delivered-To: cfrg@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 3C7B71228B7 for <cfrg@ietfa.amsl.com>; Tue, 5 Mar 2019 09:42:19 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.899
X-Spam-Level:
X-Spam-Status: No, score=-1.899 tagged_above=-999 required=5 tests=[AC_DIV_BONANZA=0.001, BAYES_00=-1.9, DKIMWL_WL_MED=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=miracl-com.20150623.gappssmtp.com
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id ou-PGKTy4i_2 for <cfrg@ietfa.amsl.com>; Tue, 5 Mar 2019 09:42:15 -0800 (PST)
Received: from mail-it1-x12e.google.com (mail-it1-x12e.google.com [IPv6:2607:f8b0:4864:20::12e]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id B2180131268 for <cfrg@irtf.org>; Tue, 5 Mar 2019 09:42:12 -0800 (PST)
Received: by mail-it1-x12e.google.com with SMTP id e24so5346714itl.1 for <cfrg@irtf.org>; Tue, 05 Mar 2019 09:42:12 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=miracl-com.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to; bh=3SI0uRYji2lV+Ije+lv4dbDIRmyEzmg2CrSpG9WCbJM=; b=pnsMl0iYL+rqGvKRBsFuLj7exUk6QOQLY2vkq4oOILHQ8fdLM1s915IBvQZCZv/AXE 3bvS6ZnGnOIRIH0ixk3guq8ve0lZeTjZ1icBpjlhno3Yrtgp9XWymhDLUmt2tA8Th4ag jWQX3lLx/Vj4XL1CAVm7qbort+3kLkuqBceq9egV/qjF1Or1ceTXHv2foExZz5jA01dT a8bELfLGgRZ1TBcQuCXGTgLozXYtwqs/lmCl95ajhH54ugCVdUUTeLAmNsuo4jpJmxIl P9Y5sSlcCVIVCEoxCmArtKwl7b5hCCpcMisSmzm2AhnfV6Lv2eqn/StoMcC8oCs9vvUP Up0A==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to; bh=3SI0uRYji2lV+Ije+lv4dbDIRmyEzmg2CrSpG9WCbJM=; b=MaRzKoYkZ1FBDq1rGXIIr3ftcQOJDe8xVeOXCaLIguZObDX4MCZE6rTVUiYk1xQI/t iBZ1gFcOM0oa+YWPh5wn0cLWpPQmcp3A5DYZ/Jo1rInAV4sg5yJVX+4NX/q2eZAAys2R IQV3Wzt6W3dBI8R+k1D7C2hLtSYt6TCjHS1JTb53ceSnRPS/R2rSZX7SwpXEF7mZ4FkQ /9pUrEoF200wevn9dYbR25Ps7xhQt1WvkPMJiETlriq0970pH7rHxlUJeYmqm9WL5uOi g09WBC1x3jMNhAYIxMxj1x5brny9FHzD1cWS6meS1CI6no//sF9GV1V14t5cOLiQSmQR FMKA==
X-Gm-Message-State: APjAAAWqU+/V7JZ6mdZI7/Y1m346q3vQRxPgrnHNvIXI/4wtfra/1hqo McM5Yx8p+Wtpj6ncLMWURXlqWSpGmfWJe3cRzV9x7JDO
X-Google-Smtp-Source: APXvYqwgOCzmkUGT0RWtAt0mXhgaMSEKM54aaBvJ4fNh05YMGM2OxVhZqoKuf5EfXRbtK3N9MZ3s7pfuSaACgzYl1mg=
X-Received: by 2002:a02:5c5d:: with SMTP id q90mr1842809jab.43.1551807731358; Tue, 05 Mar 2019 09:42:11 -0800 (PST)
MIME-Version: 1.0
References: <CACnav0oDeJ14LphESnrsD8C1C+4iFByPqp4tfqxGT4hwbe1ucg@mail.gmail.com> <1F407B07-E1FE-40F5-8C3A-D4FF76577083@ericsson.com>
In-Reply-To: <1F407B07-E1FE-40F5-8C3A-D4FF76577083@ericsson.com>
From: Michael Scott <mike.scott@miracl.com>
Date: Tue, 05 Mar 2019 17:42:00 +0000
Message-ID: <CAEseHRpH2s0i7=u4ZoSCMX9ghiSN_0Y=bLj3_2E1gED+f3WJoQ@mail.gmail.com>
To: "cfrg@irtf.org" <cfrg@irtf.org>
Content-Type: multipart/alternative; boundary="00000000000096986905835c6485"
Archived-At: <https://mailarchive.ietf.org/arch/msg/cfrg/3KFwGfYmyBrns0l2bbFAjjtnnmg>
Subject: Re: [Cfrg] BLS standard draft
X-BeenThere: cfrg@irtf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Crypto Forum Research Group <cfrg.irtf.org>
List-Unsubscribe: <https://www.irtf.org/mailman/options/cfrg>, <mailto:cfrg-request@irtf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/cfrg/>
List-Post: <mailto:cfrg@irtf.org>
List-Help: <mailto:cfrg-request@irtf.org?subject=help>
List-Subscribe: <https://www.irtf.org/mailman/listinfo/cfrg>, <mailto:cfrg-request@irtf.org?subject=subscribe>
X-List-Received-Date: Tue, 05 Mar 2019 17:42:19 -0000

My understanding is that while shortness is a nice feature of BLS
signature, its not the main selling point any more. That would be its
aggregation and compression property.

As it happens I just finished getting some timings for the BLS381 curve on
an Arduino IoT MKR1000 board (48MHz clock, 32-bit ARM Cortex M0 chip - but
no 32x32->64 multiplication instruction, 256K ROM, 32K RAM, no room for any
precomputation :), no assembly language, pure C++, side channel resistant
coding). Signature in G1, public key in G2, SHA3 message hashing.

The test program occupies less than 56K of ROM, and (obviously) something
less than 32K of RAM

Key generation -  2.7 seconds
Signature - 2.8 seconds
Verification - 13.1 seconds

Of course it would be a little crazy to do BLS signature verification on
such a chip....

Mike


On Tue, Mar 5, 2019 at 1:48 PM John Mattsson <john.mattsson@ericsson.com>
wrote:

> Hi Sergey,
>
>
>
> I think this is interesting and likely something worth spending time on. I
> agree with the opinion that quantum computers is not a reason to stop
> looking at this, at least not yet.
>
>
>
> Some very quick high level comments:
>
>
>
> - It is stated the BLS12-381 yield signature sizes of 48 bytes when
> signatures are in G1. I think the draft should also state what the public
> keys sizes are in this case. I assume the "minimizing public key size"
> option just swap the sizes.
>
>
>
> - It would be good if the draft gave some hint to potential implementors
> regarding the amount of processing required. While short signatures would
> be good in many IoT applications, I assume that the pairing operations are
> relatively expensive.
>
>
>
> - The curve is called both BLS12-381 and BLS-381, I assume they are the
> same curve.
>
>
>
> My memory of BLS (backed up by a book section by K.G.Paterson that I had
> in my book shelf) is that BLS signatures where close to half the size of
> ECDSA (170 vs. 320 bits for 80 bit security), I assume some new attacks
> have changed this?
>
>
>
> /John
>
>
>
> *From: *Cfrg <cfrg-bounces@irtf.org> on behalf of Sergey Gorbunov <
> sgorbunov@uwaterloo.ca>
> *Date: *Saturday, 23 February 2019 at 20:26
> *To: *"cfrg@irtf.org" <cfrg@irtf.org>, David Wong <
> davidwong.crypto@gmail.com>, "ylzhao@fudan.edu.cn" <ylzhao@fudan.edu.cn>,
> Eric Rescorla <ekr@rtfm.com>
> *Subject: *Re: [Cfrg] BLS standard draft
>
>
>
> Thanks, David and everyone else for the feedback!
>
> We will create a github repository where anyone will be able to view and
> comment on the latest draft and share the link.
>
>
>
> In the meantime, please continue sending us feedback by email.
>
>
> Regards,
>
> Sergey
>
> web <https://cs.uwaterloo.ca/~sgorbuno/>
>
>
>
>
>
> On Sun, Feb 17, 2019 at 3:00 PM <cfrg-request@irtf.org> wrote:
>
> Message: 1
> Date: Sun, 17 Feb 2019 08:54:36 -0800
> From: David Wong <davidwong.crypto@gmail.com>
> To: ??? <ylzhao@fudan.edu.cn>
> Cc: Eric Rescorla <ekr@rtfm.com>, CFRG <cfrg@irtf.org>,  Sergey
>         Gorbunov <sgorbunov@uwaterloo.ca>
> Subject: Re: [Cfrg] BLS standard draft
> Message-ID:
>         <CAK3aN2r9J9ToH6OZPNqUv4vNPx_DqJM+KQC=X=
> rfHFEkM5hkdg@mail.gmail.com>
> Content-Type: text/plain; charset="UTF-8"
>
> Hi again,
>
> I am not sure what the process is. If you have a github repo where we
> can participate or if you want us to give you feedback here. So here
> is some feedback from a first read. Feel free to ignore the bits you
> don't agree with of course. Some common themes were:
>
> * Keep in mind that this is for implementations, so remove information
> that belongs in a whitepaper
> * Make the RFC timeless (we should be able to read it in 5 years and
> understand it)
> * Set things in stone so that the RFC is actionable, don't make it
> vague. If people want to add to it, extensions and updates are
> possible later.
>
> And here is the more detailed feedback:
>
> - abstract: re-write with "what is it?" in mind first, history bits
> can wait until the introduction. I suggest using developer-friendly
> terms like "compression" and define aggregation later if the term is
> needed. Example:
>
>     BLS is a digital signature scheme with compression properties.
> With a given set of signatures (sig_1, ..., sig_n) anyone can produce
> a compressed signature sig_compressed. The same is true for a set of
> private keys or public keys, while keeping the connection between sets
> (a compressed public key is associated to its compressed public key).
> Furthermore, the BLS signature scheme is deterministic, non-malleable,
> and efficient. Its simplicity and cryptographic properties allows it
> to be useful in a variety of use-cases, specifically when minimal
> storage space or bandwidth are required.
>
> - intro:
>     - "A signature scheme is a fundamental cryptographic primitive
> used on the Internet that is used to protect integrity of
> communication" -> not necessarily used on the internet, and not
> necessarily for integrity of communications.
>     - "2.  Verification requires 2 pairing operations." -> at this
> point pairing is not defined, and what does that mean for the
> developer? how does it compare to other signature schemes that do not
> use pairing?
>     - "we believe the scheme will find very interesting applications"
> -> too temporal. At some point, it is possible that the scheme will be
> popular and this sentence will seem out of place.
>     - "the BLS signature scheme is already integrated" -> maybe out of
> place (as too temporal as well). If not, sort the list by alphabetical
> order, I think no one will mind that.
>     - "BLS signatures are used for authenticating transactions as well
> as votes during the consensus protocol" -> I suggest we itemize the
> different use-cases of BLS (from PKI to blockchain).
> - section "1.1.  Terminology"
>     - "msg" -> I suggest we change that to "message"
>     - "sigma" -> "signature"
>     - "signer/verifier/aggregator" do we need roles for these? Can't
> we do with just an API ("sign/verify/compress")
>     - "P1" is defined but never seem to be used. Am I missing something?
>     - I suggest we spell "e()" as "pairing()" in the algorithms, and
> define it here
> - section "1.2.  Signature Scheme Algorithms and Properties"
>     - "A signature scheme comes with" -> "Like most signature schemes,
> BLS comes with the following API", this way we can leverage the
> reader's knowledge of other signature scheme.
>     - "The signing algorithm may be deterministic or randomized,
> depending on the scheme" -> as this is a spec, we need to make a
> decision here. I think it makes more sense to make it deterministic.
> - section "1..2.2.  Security" -> do we need these security properties
> in the RFC? It sounds to me like they would belong in a whitepaper
> instead..
> - section "2."
>     - "BLS signatures require pairing-friendly curves" -> I suggest
> standardizing BLS with a set of curves. Extensions or updates can
> later add more curves if needed.
>     - "There are two variants of the scheme" -> It'd be nice if the
> two variants were specified in this document, as they both have
> use-cases.
>     - "Put ... in G1" -> not clear, rephrase
> - section "2.1.  Preliminaries". I recommend renaming "suite_string"
> to "domain_separator" and having specific values for it instead of
> potential values.. (We're standardizing something after all, ideally it
> should be self-contained)
> - section "2.4.  Verify: Signature Verification"
>     - "4.  If r*Gamma != 0, output "INVALID" and stop" -> I had heard
> a while ago that this membership check was patented for ECDH. Anyone
> remembers something like this?
> - section "2.5.  Aggregate"
>     - it should be "sigma = E1_to_string(string_to_E1(sigma_1) + ... +
> string_to_E1(sigma_n))"
>     - you specify verifying aggregates of SAME msg and of DIFFERENT
> msgs, but only have the aggregate algorithm for SAME msg specified.
> - section "2.5.3.  Implementation optimizations". Two things:
>     - this should be towards the end of the documentation as these are
> optional recommendations. Perhaps after "security recommendations" or
> as an appendix
>     - is it really wise to have the standard contain this? Available
> optimizations may change over time. I've also never seen an RFC
> talking about optimizations.
> - section "2.7.  Security analysis" -> I don't think this is necessary
> to have that in the RFC.
> - section "3.1. Verifying public keys"
>     - define "G2 membership test"
>     - "to prevent rogue key attacks" -> needs a reference
> - section "3.4. Randomness considerations" needs a citation, for
> example on ECDSA issues when the nonce is repeated
> - section "4.  Implementation Status". Standards usually don't refer
> to implementations AFAIK. I imagine this is because their state can
> change, and new good implementations can arise after the RFC is set in
> stone. I think this is good to have in the draft though, so perhaps
> add an indication somewhere that this will be deleted in the final
> document.
> - section "6.  IANA Considerations". Do we need this?
> - section "2.6.1.  Preliminaries", "In fact, we will pad each
> substring with 0s so that the length of each substring is a multiple
> of 8." specify that this is in bits.
>
> Cheers,
> David
>
> _______________________________________________
> Cfrg mailing list
> Cfrg@irtf.org
> https://www.irtf.org/mailman/listinfo/cfrg
>