3 Copyright (C) Stefan Metzmacher 2012
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
19 #include "../lib/util/samba_util.h"
20 #include "../lib/crypto/crypto.h"
22 struct torture_context
;
23 bool torture_local_crypto_aes_cmac_128(struct torture_context
*torture
);
26 This uses the test values from rfc 4493
28 bool torture_local_crypto_aes_cmac_128(struct torture_context
*torture
)
38 TALLOC_CTX
*tctx
= talloc_new(torture
);
39 if (!tctx
) { return false; };
41 key
= strhex_to_data_blob(tctx
, "2b7e151628aed2a6abf7158809cf4f3c");
43 testarray
[0].data
= data_blob_null
;
44 testarray
[0].cmac
= strhex_to_data_blob(tctx
,
45 "bb1d6929e95937287fa37d129b756746");
47 testarray
[1].data
= strhex_to_data_blob(tctx
,
48 "6bc1bee22e409f96e93d7e117393172a");
49 testarray
[1].cmac
= strhex_to_data_blob(tctx
,
50 "070a16b46b4d4144f79bdd9dd04a287c");
52 testarray
[2].data
= strhex_to_data_blob(tctx
,
53 "6bc1bee22e409f96e93d7e117393172a"
54 "ae2d8a571e03ac9c9eb76fac45af8e51"
56 testarray
[2].cmac
= strhex_to_data_blob(tctx
,
57 "dfa66747de9ae63030ca32611497c827");
59 testarray
[3].data
= strhex_to_data_blob(tctx
,
60 "6bc1bee22e409f96e93d7e117393172a"
61 "ae2d8a571e03ac9c9eb76fac45af8e51"
62 "30c81c46a35ce411e5fbc1191a0a52ef"
63 "f69f2445df4f9b17ad2b417be66c3710");
64 testarray
[3].cmac
= strhex_to_data_blob(tctx
,
65 "51f0bebf7e3b9d92fc49741779363cfe");
67 ZERO_STRUCT(testarray
[4]);
69 for (i
=0; testarray
[i
].cmac
.length
!= 0; i
++) {
70 struct aes_cmac_128_context ctx
;
71 uint8_t cmac
[AES_BLOCK_SIZE
];
74 aes_cmac_128_init(&ctx
, key
.data
);
75 aes_cmac_128_update(&ctx
,
76 testarray
[i
].data
.data
,
77 testarray
[i
].data
.length
);
78 aes_cmac_128_final(&ctx
, cmac
);
80 e
= memcmp(testarray
[i
].cmac
.data
, cmac
, sizeof(cmac
));
82 printf("aes_cmac_128 test[%u]: failed\n", i
);
83 dump_data(0, key
.data
, key
.length
);
84 dump_data(0, testarray
[i
].data
.data
, testarray
[i
].data
.length
);
85 dump_data(0, testarray
[i
].cmac
.data
, testarray
[i
].cmac
.length
);
86 dump_data(0, cmac
, sizeof(cmac
));
90 for (i
=0; testarray
[i
].cmac
.length
!= 0; i
++) {
91 struct aes_cmac_128_context ctx
;
92 uint8_t cmac
[AES_BLOCK_SIZE
];
96 aes_cmac_128_init(&ctx
, key
.data
);
97 for (j
=0; j
< testarray
[i
].data
.length
; j
++) {
98 aes_cmac_128_update(&ctx
, NULL
, 0);
99 aes_cmac_128_update(&ctx
,
100 &testarray
[i
].data
.data
[j
],
102 aes_cmac_128_update(&ctx
, NULL
, 0);
104 aes_cmac_128_final(&ctx
, cmac
);
106 e
= memcmp(testarray
[i
].cmac
.data
, cmac
, sizeof(cmac
));
108 printf("aes_cmac_128 chunked test[%u]: failed\n", i
);
109 dump_data(0, key
.data
, key
.length
);
110 dump_data(0, testarray
[i
].data
.data
, testarray
[i
].data
.length
);
111 dump_data(0, testarray
[i
].cmac
.data
, testarray
[i
].cmac
.length
);
112 dump_data(0, cmac
, sizeof(cmac
));