diff --git a/ChangeLog b/ChangeLog index 3300ce1a6..564a13748 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2013-11-12 Vladimir Serbinenko + + * grub-core/tests/pbkdf2_test.c: New test. + 2013-11-12 Vladimir Serbinenko * grub-core/lib/xzembed/xz_dec_stream.c: Remove variable length arrays. diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def index e237a9507..8df80a616 100644 --- a/grub-core/Makefile.core.def +++ b/grub-core/Makefile.core.def @@ -1916,6 +1916,11 @@ module = { common = tests/xnu_uuid_test.c; }; +module = { + name = pbkdf2_test; + common = tests/pbkdf2_test.c; +}; + module = { name = div_test; common = tests/div_test.c; diff --git a/grub-core/tests/lib/functional_test.c b/grub-core/tests/lib/functional_test.c index 8459f3968..6b849f5ae 100644 --- a/grub-core/tests/lib/functional_test.c +++ b/grub-core/tests/lib/functional_test.c @@ -60,6 +60,7 @@ grub_functional_all_tests (grub_extcmd_context_t ctxt __attribute__ ((unused)), grub_dl_load ("cmdline_cat_test"); grub_dl_load ("div_test"); grub_dl_load ("xnu_uuid_test"); + grub_dl_load ("pbkdf2_test"); FOR_LIST_ELEMENTS (test, grub_test_list) ok = !grub_test_run (test) && ok; diff --git a/grub-core/tests/pbkdf2_test.c b/grub-core/tests/pbkdf2_test.c new file mode 100644 index 000000000..16b72c432 --- /dev/null +++ b/grub-core/tests/pbkdf2_test.c @@ -0,0 +1,97 @@ +/* + * GRUB -- GRand Unified Bootloader + * Copyright (C) 2013 Free Software Foundation, Inc. + * + * GRUB is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * GRUB is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with GRUB. If not, see . + */ + +#include +#include +#include +#include + +GRUB_MOD_LICENSE ("GPLv3+"); + +struct +{ + const char *P; + grub_size_t Plen; + const char *S; + grub_size_t Slen; + unsigned int c; + grub_size_t dkLen; + const char *DK; +} vectors[] = { + /* RFC6070. */ + { + "password", 8, + "salt", 4, + 1, 20, + "\x0c\x60\xc8\x0f\x96\x1f\x0e\x71\xf3\xa9\xb5\x24\xaf\x60\x12" + "\x06\x2f\xe0\x37\xa6" + }, + { + "password", 8, + "salt", 4, + 2, 20, + "\xea\x6c\x01\x4d\xc7\x2d\x6f\x8c" + "\xcd\x1e\xd9\x2a\xce\x1d\x41\xf0" + "\xd8\xde\x89\x57" + }, + { + "password", 8, + "salt", 4, + 4096, 20, + "\x4b\x00\x79\x01\xb7\x65\x48\x9a\xbe\xad\x49\xd9\x26\xf7" + "\x21\xd0\x65\xa4\x29\xc1" + }, + { + "passwordPASSWORDpassword", 24, + "saltSALTsaltSALTsaltSALTsaltSALTsalt", 36, + 4096, 25, + "\x3d\x2e\xec\x4f\xe4\x1c\x84\x9b\x80\xc8\xd8\x36\x62\xc0" + "\xe4\x4a\x8b\x29\x1a\x96\x4c\xf2\xf0\x70\x38" + }, + { + "pass\0word", 9, + "sa\0lt", 5, + 4096, 16, + "\x56\xfa\x6a\xa7\x55\x48\x09\x9d\xcc\x37\xd7\xf0\x34\x25\xe0\xc3" + } +}; + +static void +pbkdf2_test (void) +{ + grub_size_t i; + + for (i = 0; i < ARRAY_SIZE (vectors); i++) + { + gcry_err_code_t err; + grub_uint8_t DK[32]; + err = grub_crypto_pbkdf2 (GRUB_MD_SHA1, + (const grub_uint8_t *) vectors[i].P, + vectors[i].Plen, + (const grub_uint8_t *) vectors[i].S, + vectors[i].Slen, + vectors[i].c, + DK, vectors[i].dkLen); + grub_test_assert (err == 0, "gcry error %d", err); + grub_test_assert (grub_memcmp (DK, vectors[i].DK, vectors[i].dkLen) == 0, + "PBKDF2 mismatch"); + } +} + +/* Register example_test method as a functional test. */ +GRUB_FUNCTIONAL_TEST (pbkdf2_test, pbkdf2_test);