helper.c 834 Bytes
/*
 * 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];
    for (int i = 0; i < L; ++i, --b) {
        if (++*b != 0) {
            break;
        }
    }
}

int crypto_equals(uint8_t *a, 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;
}