Blame SOURCES/libsodium-1.0.18/test/default/pwhash_scrypt_ll.c

ca16be
ca16be
#define TEST_NAME "pwhash_scrypt_ll"
ca16be
#include "cmptest.h"
ca16be
ca16be
static const char *   passwd1 = "";
ca16be
static const char *   salt1   = "";
ca16be
static const uint64_t N1      = 16U;
ca16be
static const uint32_t r1      = 1U;
ca16be
static const uint32_t p1      = 1U;
ca16be
ca16be
static const char *   passwd2 = "password";
ca16be
static const char *   salt2   = "NaCl";
ca16be
static const uint64_t N2      = 1024U;
ca16be
static const uint32_t r2      = 8U;
ca16be
static const uint32_t p2      = 16U;
ca16be
ca16be
static const char *   passwd3 = "pleaseletmein";
ca16be
static const char *   salt3   = "SodiumChloride";
ca16be
static const uint64_t N3      = 16384U;
ca16be
static const uint32_t r3      = 8U;
ca16be
static const uint32_t p3      = 1U;
ca16be
ca16be
static void
ca16be
tv(const char *passwd, const char *salt, uint64_t N, uint32_t r, uint32_t p)
ca16be
{
ca16be
    uint8_t data[64];
ca16be
    size_t  i;
ca16be
    size_t  olen       = (sizeof data / sizeof data[0]);
ca16be
    size_t  passwd_len = strlen(passwd);
ca16be
    size_t  salt_len   = strlen(salt);
ca16be
    int     line_items  = 0;
ca16be
ca16be
    if (crypto_pwhash_scryptsalsa208sha256_ll(
ca16be
            (const uint8_t *) passwd, passwd_len, (const uint8_t *) salt,
ca16be
            salt_len, N, r, p, data, olen) != 0) {
ca16be
        printf("pwhash_scryptsalsa208sha256_ll([%s],[%s]) failure\n", passwd,
ca16be
               salt);
ca16be
        return;
ca16be
    }
ca16be
ca16be
    printf("scrypt('%s', '%s', %lu, %lu, %lu, %lu) =\n", passwd, salt,
ca16be
           (unsigned long) N, (unsigned long) r, (unsigned long) p,
ca16be
           (unsigned long) olen);
ca16be
ca16be
    for (i = 0; i < olen; i++) {
ca16be
        printf("%02x%c", data[i], line_items < 15 ? ' ' : '\n');
ca16be
        line_items = line_items < 15 ? line_items + 1 : 0;
ca16be
    }
ca16be
}
ca16be
ca16be
int
ca16be
main(void)
ca16be
{
ca16be
    tv(passwd1, salt1, N1, r1, p1);
ca16be
    tv(passwd2, salt2, N2, r2, p2);
ca16be
    tv(passwd3, salt3, N3, r3, p3);
ca16be
ca16be
    return 0;
ca16be
}