<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>