<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html;
      charset=windows-1252">
  </head>
  <body text="#000000" bgcolor="#FFFFFF">
    <p><br>
    </p>
    On 9/19/2018 1:37 PM, Bernd Eckenfels wrote:<br>
    <blockquote type="cite"
cite="mid:DB7PR08MB3307C27FB14917AAB27037C8FF1C0@DB7PR08MB3307.eurprd08.prod.outlook.com">
      <meta http-equiv="Content-Type" content="text/html;
        charset=windows-1252">
      <div>
        <style id="ms-outlook-ios-style" type="text/css">html {
background-color: transparent;
}

body {
color: #333;
line-height: 150%;
font-family: "-apple-system", "HelveticaNeue";
margin: 0;
}

.ms-outlook-ios-reference-expand {
display: block;
color: #999;
padding: 20px 0px;
text-decoration: none;
}

.ms-outlook-ios-availability-container {
max-width: 500px;
margin: auto;
padding: 12px 15px 15px 15px;
border: 1px solid #C7E0F4;
border-radius: 4px;
}

.ms-outlook-ios-availability-container > .ms-outlook-ios-availability-delete-button {
width: 25px;
height: 25px;
right: -12px;
top: -12px;
background-image: url("");
background-size: 25px 25px;
background-position: center;
}

#ms-outlook-ios-main-container {
margin: 0 0 0 0;
margin-top: 120;
padding: 8;
}

#ms-outlook-ios-content-container {
padding: 0;
padding-top: 12;
padding-bottom: 20;
}

.ms-outlook-ios-mention {
color: #333;
background-color: #f1f1f1;
border-radius: 4px;
padding: 0 2px 0 2px;
pointer-events: none;
text-decoration: none;
}

.ms-outlook-ios-mention-external {
color: #ba8f0d;
background-color: #fdf7e7;
}</style>
        <meta name="viewport" content="width=device-width,
          user-scalable=no, initial-scale=1.0">
        <!-- This file has been automatically generated. See web/README.md -->
        <div>
          <div>
            <div style="direction: ltr;">Hello,</div>
            <div><br>
            </div>
            <div style="direction: ltr;">I think I missed it, but where
              is the conversion on BigInteger branching on key material?
              Isn’t this only branching on effective constant values?</div>
            <div><br>
            </div>
            <div style="direction: ltr;">Or are you concerned about
              Spectre-type problems?</div>
          </div>
        </div>
      </div>
    </blockquote>
    <br>
    This is not for Spectre (etc.) issues, which effectively dump all
    memory contents, so there is nothing we can do to prevent it at this
    level. The proposed implementation defends against cache attacks
    like Flush+Reload[1], as well as timing attacks.<br>
    <br>
    Imagine an EC private key (i.e. a scalar) is stored in a
    fixed-length little-endian byte array in the key implementation
    class. I can perform the required EC operations directly on this
    byte array without branching on any part of its value. Now if I want
    to convert this key to an ECPrivateKeySpec using the KeyFactory, I
    need to convert this scalar to a BigInteger, which uses a
    variable-length representation. This conversion necessarily branches
    on the value of the private key, which we are trying to avoid.<br>
    <br>
    Branching on any non-secret value (including algorithm parameters
    and constants) is fine, but in the example above, we would be
    branching on the valud of the private key.<br>
    <br>
    [1] <a class="moz-txt-link-freetext" href="https://eprint.iacr.org/2013/448.pdf">https://eprint.iacr.org/2013/448.pdf</a><br>
    <br>
    <blockquote type="cite"
cite="mid:DB7PR08MB3307C27FB14917AAB27037C8FF1C0@DB7PR08MB3307.eurprd08.prod.outlook.com">
      <div>
        <div>
          <div>
            <div><br>
            </div>
            <div style="direction: ltr;">Besides that I totally agree on
              the idea of having a more secure implementation which can
              be activated by simply switching provider priorities.</div>
            <div><br>
            </div>
            <div style="direction: ltr;">Gruss</div>
            <div style="direction: ltr;">Bernd<br>
            </div>
          </div>
        </div>
      </div>
    </blockquote>
    <br>
  </body>
</html>