ref: f7b0cc7a64b4d2df64c666cdc9740a1aceb7aa9d
parent: 5cf5f6e9ac953270c696c1f4bd01881d183be5e3
author: cinap_lenrek <cinap_lenrek@felloff.net>
date: Mon Jan 1 16:14:39 EST 2018
factotum: replace custom hex parsing code with dec16() avoding timing side channels
--- a/sys/src/cmd/auth/factotum/p9sk1.c
+++ b/sys/src/cmd/auth/factotum/p9sk1.c
@@ -507,33 +507,6 @@
}
static int
-unhex(char c)
-{
- if('0' <= c && c <= '9')
- return c-'0';
- if('a' <= c && c <= 'f')
- return c-'a'+10;
- if('A' <= c && c <= 'F')
- return c-'A'+10;
- abort();
- return -1;
-}
-
-static int
-hexparse(char *hex, uchar *dat, int ndat)
-{
- int i;
-
- if(strlen(hex) != 2*ndat)
- return -1;
- if(hex[strspn(hex, "0123456789abcdefABCDEF")] != '\0')
- return -1;
- for(i=0; i<ndat; i++)
- dat[i] = (unhex(hex[2*i])<<4)|unhex(hex[2*i+1]);
- return 0;
-}
-
-static int
p9skaddkey(Key *k, int before)
{
Authkey *akey;
@@ -547,13 +520,13 @@
akey = emalloc(sizeof(Authkey));
if(s = _strfindattr(k->privattr, "!hex")){
if(k->proto == &dp9ik){
- if(hexparse(s, akey->aes, AESKEYLEN) < 0){
+ if(dec16(akey->aes, AESKEYLEN, s, strlen(s)) != AESKEYLEN){
free(akey);
werrstr("malformed key data");
return -1;
}
} else {
- if(hexparse(s, (uchar*)akey->des, DESKEYLEN) < 0){
+ if(dec16((uchar*)akey->des, DESKEYLEN, s, strlen(s)) != DESKEYLEN){
free(akey);
werrstr("malformed key data");
return -1;
--- a/sys/src/cmd/auth/factotum/wpapsk.c
+++ b/sys/src/cmd/auth/factotum/wpapsk.c
@@ -35,35 +35,13 @@
uchar resp[PTKlen];
};
-static int
-hextob(char *s, char **sp, uchar *b, int n)
-{
- int r;
-
- n <<= 1;
- for(r = 0; r < n && *s; s++){
- *b <<= 4;
- if(*s >= '0' && *s <= '9')
- *b |= (*s - '0');
- else if(*s >= 'a' && *s <= 'f')
- *b |= 10+(*s - 'a');
- else if(*s >= 'A' && *s <= 'F')
- *b |= 10+(*s - 'A');
- else break;
- if((++r & 1) == 0)
- b++;
- }
- if(sp != nil)
- *sp = s;
- return r >> 1;
-}
-
static void
pass2pmk(char *pass, char *ssid, uchar pmk[PMKlen])
{
- if(hextob(pass, nil, pmk, PMKlen) == PMKlen)
+ int npass = strlen(pass);
+ if(npass == 2*PMKlen && dec16(pmk, PMKlen, pass, npass) == PMKlen)
return;
- pbkdf2_x((uchar*)pass, strlen(pass), (uchar*)ssid, strlen(ssid), 4096, pmk, PMKlen, hmac_sha1, SHA1dlen);
+ pbkdf2_x((uchar*)pass, npass, (uchar*)ssid, strlen(ssid), 4096, pmk, PMKlen, hmac_sha1, SHA1dlen);
}
static void