xref: /dpdk/app/test/test_cryptodev_hmac_test_vectors.h (revision a9de470cc7c0649221e156fc5f30a2dbdfe7c166)
1*a9de470cSBruce Richardson /* SPDX-License-Identifier: BSD-3-Clause
2*a9de470cSBruce Richardson  * Copyright(c) 2016 Intel Corporation
3*a9de470cSBruce Richardson  */
4*a9de470cSBruce Richardson 
5*a9de470cSBruce Richardson #ifndef APP_TEST_TEST_CRYPTODEV_HMAC_TEST_VECTORS_H_
6*a9de470cSBruce Richardson #define APP_TEST_TEST_CRYPTODEV_HMAC_TEST_VECTORS_H_
7*a9de470cSBruce Richardson 
8*a9de470cSBruce Richardson /* *** MD5 test vectors *** */
9*a9de470cSBruce Richardson 
10*a9de470cSBruce Richardson #define MD5_DIGEST_LEN	16
11*a9de470cSBruce Richardson 
12*a9de470cSBruce Richardson struct HMAC_MD5_vector {
13*a9de470cSBruce Richardson 	struct {
14*a9de470cSBruce Richardson 		uint8_t data[64];
15*a9de470cSBruce Richardson 		uint16_t len;
16*a9de470cSBruce Richardson 	} key;
17*a9de470cSBruce Richardson 
18*a9de470cSBruce Richardson 	struct {
19*a9de470cSBruce Richardson 			uint8_t data[1024];
20*a9de470cSBruce Richardson 			uint16_t len;
21*a9de470cSBruce Richardson 	} plaintext;
22*a9de470cSBruce Richardson 
23*a9de470cSBruce Richardson 	struct {
24*a9de470cSBruce Richardson 			uint8_t data[16];
25*a9de470cSBruce Richardson 			uint16_t len;
26*a9de470cSBruce Richardson 	} auth_tag;
27*a9de470cSBruce Richardson };
28*a9de470cSBruce Richardson 
29*a9de470cSBruce Richardson static const struct
30*a9de470cSBruce Richardson HMAC_MD5_vector HMAC_MD5_test_case_1 = {
31*a9de470cSBruce Richardson 	.key = {
32*a9de470cSBruce Richardson 		.data = {
33*a9de470cSBruce Richardson 			0xF8, 0x2A, 0xC7, 0x54, 0xDB, 0x96, 0x18, 0xAA,
34*a9de470cSBruce Richardson 			0xC3, 0xA1, 0x53, 0xF6, 0x1F, 0x17, 0x60, 0xBD
35*a9de470cSBruce Richardson 		},
36*a9de470cSBruce Richardson 		.len = 16
37*a9de470cSBruce Richardson 	},
38*a9de470cSBruce Richardson 	.plaintext = {
39*a9de470cSBruce Richardson 		.data = {
40*a9de470cSBruce Richardson 			0x87, 0x4D, 0x61, 0x91, 0xB6, 0x20, 0xE3, 0x26,
41*a9de470cSBruce Richardson 			0x1B, 0xEF, 0x68, 0x64, 0x99, 0x0D, 0xB6, 0xCE,
42*a9de470cSBruce Richardson 			0x98, 0x06, 0xF6, 0x6B, 0x79, 0x70, 0xFD, 0xFF,
43*a9de470cSBruce Richardson 			0x86, 0x17, 0x18, 0x7B, 0xB9, 0xFF, 0xFD, 0xFF,
44*a9de470cSBruce Richardson 			0x5A, 0xE4, 0xDF, 0x3E, 0xDB, 0xD5, 0xD3, 0x5E,
45*a9de470cSBruce Richardson 			0x5B, 0x4F, 0x09, 0x02, 0x0D, 0xB0, 0x3E, 0xAB,
46*a9de470cSBruce Richardson 			0x1E, 0x03, 0x1D, 0xDA, 0x2F, 0xBE, 0x03, 0xD1,
47*a9de470cSBruce Richardson 			0x79, 0x21, 0x70, 0xA0, 0xF3, 0x00, 0x9C, 0xEE
48*a9de470cSBruce Richardson 		},
49*a9de470cSBruce Richardson 		.len = 64
50*a9de470cSBruce Richardson 	},
51*a9de470cSBruce Richardson 	.auth_tag = {
52*a9de470cSBruce Richardson 		.data = {
53*a9de470cSBruce Richardson 			0x67, 0x83, 0xE1, 0x0F, 0xB0, 0xBF, 0x33, 0x49,
54*a9de470cSBruce Richardson 			0x22, 0x04, 0x89, 0xDF, 0x86, 0xD0, 0x5F, 0x0C
55*a9de470cSBruce Richardson 		},
56*a9de470cSBruce Richardson 		.len = MD5_DIGEST_LEN
57*a9de470cSBruce Richardson 	}
58*a9de470cSBruce Richardson };
59*a9de470cSBruce Richardson 
60*a9de470cSBruce Richardson static const struct
61*a9de470cSBruce Richardson HMAC_MD5_vector HMAC_MD5_test_case_2 = {
62*a9de470cSBruce Richardson 	.key = {
63*a9de470cSBruce Richardson 		.data = {
64*a9de470cSBruce Richardson 			0xF8, 0x2A, 0xC7, 0x54, 0xDB, 0x96, 0x18, 0xAA,
65*a9de470cSBruce Richardson 			0xC3, 0xA1, 0x53, 0xF6, 0x1F, 0x17, 0x60, 0xBD,
66*a9de470cSBruce Richardson 			0xF8, 0x2A, 0xC7, 0x54, 0xDB, 0x96, 0x18, 0xAA,
67*a9de470cSBruce Richardson 			0xC3, 0xA1, 0x53, 0xF6, 0x1F, 0x17, 0x60, 0xBD
68*a9de470cSBruce Richardson 		},
69*a9de470cSBruce Richardson 		.len = 32
70*a9de470cSBruce Richardson 	},
71*a9de470cSBruce Richardson 	.plaintext = {
72*a9de470cSBruce Richardson 		.data = {
73*a9de470cSBruce Richardson 			0x87, 0x4D, 0x61, 0x91, 0xB6, 0x20, 0xE3, 0x26,
74*a9de470cSBruce Richardson 			0x1B, 0xEF, 0x68, 0x64, 0x99, 0x0D, 0xB6, 0xCE,
75*a9de470cSBruce Richardson 			0x98, 0x06, 0xF6, 0x6B, 0x79, 0x70, 0xFD, 0xFF,
76*a9de470cSBruce Richardson 			0x86, 0x17, 0x18, 0x7B, 0xB9, 0xFF, 0xFD, 0xFF,
77*a9de470cSBruce Richardson 			0x5A, 0xE4, 0xDF, 0x3E, 0xDB, 0xD5, 0xD3, 0x5E,
78*a9de470cSBruce Richardson 			0x5B, 0x4F, 0x09, 0x02, 0x0D, 0xB0, 0x3E, 0xAB,
79*a9de470cSBruce Richardson 			0x1E, 0x03, 0x1D, 0xDA, 0x2F, 0xBE, 0x03, 0xD1,
80*a9de470cSBruce Richardson 			0x79, 0x21, 0x70, 0xA0, 0xF3, 0x00, 0x9C, 0xEE
81*a9de470cSBruce Richardson 		},
82*a9de470cSBruce Richardson 		.len = 64
83*a9de470cSBruce Richardson 	},
84*a9de470cSBruce Richardson 	.auth_tag = {
85*a9de470cSBruce Richardson 		.data = {
86*a9de470cSBruce Richardson 			0x39, 0x24, 0x70, 0x7A, 0x30, 0x38, 0x1E, 0x2B,
87*a9de470cSBruce Richardson 			0x9F, 0x6B, 0xD9, 0x3C, 0xAD, 0xC2, 0x73, 0x52
88*a9de470cSBruce Richardson 		},
89*a9de470cSBruce Richardson 		.len = MD5_DIGEST_LEN
90*a9de470cSBruce Richardson 	}
91*a9de470cSBruce Richardson };
92*a9de470cSBruce Richardson 
93*a9de470cSBruce Richardson #endif /* APP_TEST_TEST_CRYPTODEV_HMAC_TEST_VECTORS_H_ */
94