/* * Copyright (C) 2015 Nico von Geyso * Copyright (C) 2015 René Kijewski * * 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]; for (int i = 0; i < L; ++i, --b) { if (++*b != 0) { break; } } } int crypto_equals(const uint8_t *a, const uint8_t *b, size_t len) { uint8_t diff = 0; 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; } /* Compiler should not be allowed to optimize this */ void crypto_secure_wipe(void *buf, size_t len) { volatile uint8_t *vbuf = (uint8_t *)buf; for (size_t i = 0; i < len; i++) { vbuf[i] = 0; } }