mirror of
				https://git.proxmox.com/git/grub2
				synced 2025-10-31 03:50:11 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			98 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  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 <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| #include <grub/test.h>
 | |
| #include <grub/dl.h>
 | |
| #include <grub/misc.h>
 | |
| #include <grub/crypto.h>
 | |
| 
 | |
| GRUB_MOD_LICENSE ("GPLv3+");
 | |
| 
 | |
| static 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);
 | 
