2015-04-02 08:56:18 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Nico von Geyso <nico.geyso@fu-berlin.de>
|
|
|
|
* Copyright (C) 2015 René Kijewski <rene.kijewski@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "crypto/helper.h"
|
|
|
|
|
|
|
|
void crypto_block_inc_ctr(uint8_t block[16], int L)
|
|
|
|
{
|
|
|
|
uint8_t *b = &block[15];
|
2019-10-08 15:07:28 +02:00
|
|
|
|
2015-04-02 08:56:18 +02:00
|
|
|
for (int i = 0; i < L; ++i, --b) {
|
|
|
|
if (++*b != 0) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-21 20:27:33 +02:00
|
|
|
int crypto_equals(const uint8_t *a, const uint8_t *b, size_t len)
|
2015-04-02 08:56:18 +02:00
|
|
|
{
|
|
|
|
uint8_t diff = 0;
|
2019-10-08 15:07:28 +02:00
|
|
|
|
2015-04-02 08:56:18 +02:00
|
|
|
for (size_t i = 0; i < len; ++i, ++a, ++b) {
|
|
|
|
diff |= (*a ^ *b);
|
|
|
|
}
|
|
|
|
|
|
|
|
diff |= (diff >> 1) | (diff << 7);
|
|
|
|
diff |= (diff >> 2) | (diff << 6);
|
|
|
|
diff |= (diff >> 4) | (diff << 4);
|
|
|
|
++diff;
|
|
|
|
|
|
|
|
return diff;
|
|
|
|
}
|
2018-10-21 20:31:54 +02:00
|
|
|
|
|
|
|
/* Compiler should not be allowed to optimize this */
|
|
|
|
void crypto_secure_wipe(void *buf, size_t len)
|
|
|
|
{
|
2019-10-08 15:07:28 +02:00
|
|
|
volatile uint8_t *vbuf = (uint8_t *)buf;
|
|
|
|
|
2018-10-21 20:31:54 +02:00
|
|
|
for (size_t i = 0; i < len; i++) {
|
|
|
|
vbuf[i] = 0;
|
|
|
|
}
|
|
|
|
}
|