2 * Copyright (C) 2010, Romain Tartiere.
4 * This program is free software: you can redistribute it and/or modify it
5 * under the terms of the GNU Lesser General Public License as published by the
6 * Free Software Foundation, either version 3 of the License, or (at your
7 * option) any later version.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 * You should have received a copy of the GNU Lesser General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>
21 * This implementation was written based on information provided by the
22 * following documents:
24 * NIST Special Publication 800-38B
25 * Recommendation for Block Cipher Modes of Operation: The CMAC Mode for Authentication
28 #include "desfire_crypto.h"
32 #include "commonutil.h"
35 #include "crc16.h" // crc16 ccitt
37 #include "iso14443a.h"
42 # define AddCrc14A(data, len) compute_crc(CRC_14443_A, (data), (len), (data)+(len), (data)+(len)+1)
45 static mbedtls_des_context ctx
;
46 static mbedtls_des3_context ctx3
;
47 static mbedtls_aes_context actx
;
49 static void update_key_schedules(desfirekey_t key
);
51 static void update_key_schedules(desfirekey_t key
) {
52 // DES_set_key ((DES_cblock *)key->data, &(key->ks1));
53 // DES_set_key ((DES_cblock *)(key->data + 8), &(key->ks2));
54 // if (T_3K3DES == key->type) {
55 // DES_set_key ((DES_cblock *)(key->data + 16), &(key->ks3));
59 /******************************************************************************/
60 void des_encrypt(void *out
, const void *in
, const void *key
) {
61 mbedtls_des_setkey_enc(&ctx
, key
);
62 mbedtls_des_crypt_ecb(&ctx
, in
, out
);
65 void des_decrypt(void *out
, const void *in
, const void *key
) {
66 mbedtls_des_setkey_dec(&ctx
, key
);
67 mbedtls_des_crypt_ecb(&ctx
, in
, out
);
70 void tdes_nxp_receive(const void *in
, void *out
, size_t length
, const void *key
, unsigned char iv
[8], int keymode
) {
71 if (length
% 8) return;
72 if (keymode
== 2) mbedtls_des3_set2key_dec(&ctx3
, key
);
73 else mbedtls_des3_set3key_dec(&ctx3
, key
);
76 unsigned char temp
[8];
77 uint8_t *tin
= (uint8_t *) in
;
78 uint8_t *tout
= (uint8_t *) out
;
83 mbedtls_des3_crypt_ecb(&ctx3
, tin
, tout
);
85 for (i
= 0; i
< 8; i
++)
86 tout
[i
] = (unsigned char)(tout
[i
] ^ iv
[i
]);
96 void tdes_nxp_send(const void *in
, void *out
, size_t length
, const void *key
, unsigned char iv
[8], int keymode
) {
97 if (length
% 8) return;
98 if (keymode
== 2) mbedtls_des3_set2key_enc(&ctx3
, key
);
99 else mbedtls_des3_set3key_enc(&ctx3
, key
);
102 uint8_t *tin
= (uint8_t *) in
;
103 uint8_t *tout
= (uint8_t *) out
;
106 for (i
= 0; i
< 8; i
++) {
107 tin
[i
] = (unsigned char)(tin
[i
] ^ iv
[i
]);
110 mbedtls_des3_crypt_ecb(&ctx3
, tin
, tout
);
122 void Desfire_des_key_new(const uint8_t value
[8], desfirekey_t key
) {
124 memcpy(data
, value
, 8);
125 for (int n
= 0; n
< 8; n
++) {
128 Desfire_des_key_new_with_version(data
, key
);
131 void Desfire_des_key_new_with_version(const uint8_t value
[8], desfirekey_t key
) {
134 memcpy(key
->data
, value
, 8);
135 memcpy(key
->data
+ 8, value
, 8);
136 update_key_schedules(key
);
140 void Desfire_3des_key_new(const uint8_t value
[16], desfirekey_t key
) {
142 memcpy(data
, value
, 16);
143 for (int n
= 0; n
< 8; n
++) {
146 for (int n
= 8; n
< 16; n
++) {
149 Desfire_3des_key_new_with_version(data
, key
);
152 void Desfire_3des_key_new_with_version(const uint8_t value
[16], desfirekey_t key
) {
155 memcpy(key
->data
, value
, 16);
156 update_key_schedules(key
);
160 void Desfire_3k3des_key_new(const uint8_t value
[24], desfirekey_t key
) {
162 memcpy(data
, value
, 24);
163 for (int n
= 0; n
< 8; n
++) {
166 Desfire_3k3des_key_new_with_version(data
, key
);
169 void Desfire_3k3des_key_new_with_version(const uint8_t value
[24], desfirekey_t key
) {
171 key
->type
= T_3K3DES
;
172 memcpy(key
->data
, value
, 24);
173 update_key_schedules(key
);
177 void Desfire_aes_key_new(const uint8_t value
[16], desfirekey_t key
) {
178 Desfire_aes_key_new_with_version(value
, 0, key
);
181 void Desfire_aes_key_new_with_version(const uint8_t value
[16], uint8_t version
, desfirekey_t key
) {
184 memcpy(key
->data
, value
, 16);
186 key
->aes_version
= version
;
190 uint8_t Desfire_key_get_version(desfirekey_t key
) {
193 for (int n
= 0; n
< 8; n
++) {
194 version
|= ((key
->data
[n
] & 1) << (7 - n
));
199 void Desfire_key_set_version(desfirekey_t key
, uint8_t version
) {
200 for (int n
= 0; n
< 8; n
++) {
201 uint8_t version_bit
= ((version
& (1 << (7 - n
))) >> (7 - n
));
202 key
->data
[n
] &= 0xFE;
203 key
->data
[n
] |= version_bit
;
204 if (key
->type
== T_DES
) {
205 key
->data
[n
+ 8] = key
->data
[n
];
207 // Write ~version to avoid turning a 3DES key into a DES key
208 key
->data
[n
+ 8] &= 0xFE;
209 key
->data
[n
+ 8] |= ~version_bit
;
214 void Desfire_session_key_new(const uint8_t rnda
[], const uint8_t rndb
[], desfirekey_t authkey
, desfirekey_t key
) {
218 switch (authkey
->type
) {
220 memcpy(buffer
, rnda
, 4);
221 memcpy(buffer
+ 4, rndb
, 4);
222 Desfire_des_key_new_with_version(buffer
, key
);
225 memcpy(buffer
, rnda
, 4);
226 memcpy(buffer
+ 4, rndb
, 4);
227 memcpy(buffer
+ 8, rnda
+ 4, 4);
228 memcpy(buffer
+ 12, rndb
+ 4, 4);
229 Desfire_3des_key_new_with_version(buffer
, key
);
232 memcpy(buffer
, rnda
, 4);
233 memcpy(buffer
+ 4, rndb
, 4);
234 memcpy(buffer
+ 8, rnda
+ 6, 4);
235 memcpy(buffer
+ 12, rndb
+ 6, 4);
236 memcpy(buffer
+ 16, rnda
+ 12, 4);
237 memcpy(buffer
+ 20, rndb
+ 12, 4);
238 Desfire_3k3des_key_new(buffer
, key
);
241 memcpy(buffer
, rnda
, 4);
242 memcpy(buffer
+ 4, rndb
, 4);
243 memcpy(buffer
+ 8, rnda
+ 12, 4);
244 memcpy(buffer
+ 12, rndb
+ 12, 4);
245 Desfire_aes_key_new(buffer
, key
);
250 static size_t key_macing_length(desfirekey_t key
);
252 // iceman, see memxor inside string.c, dest/src swapped..
253 static void xor(const uint8_t *ivect
, uint8_t *data
, const size_t len
) {
254 for (size_t i
= 0; i
< len
; i
++) {
259 void cmac_generate_subkeys(desfirekey_t key
) {
260 int kbs
= key_block_size(key
);
261 const uint8_t R
= (kbs
== 8) ? 0x1B : 0x87;
267 memset(ivect
, 0, kbs
);
269 mifare_cypher_blocks_chained(NULL
, key
, ivect
, l
, kbs
, MCD_RECEIVE
, MCO_ENCYPHER
);
273 // Used to compute CMAC on complete blocks
274 memcpy(key
->cmac_sk1
, l
, kbs
);
278 lsl(key
->cmac_sk1
, kbs
);
281 key
->cmac_sk1
[kbs
- 1] ^= R
;
284 // Used to compute CMAC on the last block if non-complete
285 memcpy(key
->cmac_sk2
, key
->cmac_sk1
, kbs
);
287 txor
= key
->cmac_sk1
[0] & 0x80;
289 lsl(key
->cmac_sk2
, kbs
);
292 key
->cmac_sk2
[kbs
- 1] ^= R
;
296 void cmac(const desfirekey_t key
, uint8_t *ivect
, const uint8_t *data
, size_t len
, uint8_t *cmac
) {
297 int kbs
= key_block_size(key
);
302 uint8_t *buffer
= BigBuf_malloc(padded_data_length(len
, kbs
));
304 memcpy(buffer
, data
, len
);
306 if ((!len
) || (len
% kbs
)) {
307 buffer
[len
++] = 0x80;
309 buffer
[len
++] = 0x00;
311 xor(key
->cmac_sk2
, buffer
+ len
- kbs
, kbs
);
313 xor(key
->cmac_sk1
, buffer
+ len
- kbs
, kbs
);
316 mifare_cypher_blocks_chained(NULL
, key
, ivect
, buffer
, len
, MCD_SEND
, MCO_ENCYPHER
);
318 memcpy(cmac
, ivect
, kbs
);
322 size_t key_block_size(const desfirekey_t key
) {
327 size_t block_size
= 8;
342 * Size of MACing produced with the key.
344 static size_t key_macing_length(const desfirekey_t key
) {
345 size_t mac_length
= MAC_LENGTH
;
349 mac_length
= MAC_LENGTH
;
353 mac_length
= CMAC_LENGTH
;
360 * Size required to store nbytes of data in a buffer of size n*block_size.
362 size_t padded_data_length(const size_t nbytes
, const size_t block_size
) {
363 if ((!nbytes
) || (nbytes
% block_size
))
364 return ((nbytes
/ block_size
) + 1) * block_size
;
370 * Buffer size required to MAC nbytes of data
372 size_t maced_data_length(const desfirekey_t key
, const size_t nbytes
) {
373 return nbytes
+ key_macing_length(key
);
376 * Buffer size required to encipher nbytes of data and a two bytes CRC.
378 size_t enciphered_data_length(const desfiretag_t tag
, const size_t nbytes
, int communication_settings
) {
379 size_t crc_length
= 0;
380 if (!(communication_settings
& NO_CRC
)) {
381 switch (DESFIRE(tag
)->authentication_scheme
) {
391 size_t block_size
= DESFIRE(tag
)->session_key
? key_block_size(DESFIRE(tag
)->session_key
) : 1;
393 return padded_data_length(nbytes
+ crc_length
, block_size
);
396 void *mifare_cryto_preprocess_data(desfiretag_t tag
, void *data
, size_t *nbytes
, size_t offset
, int communication_settings
) {
400 bool append_mac
= true;
401 desfirekey_t key
= DESFIRE(tag
)->session_key
;
406 switch (communication_settings
& MDCM_MASK
) {
408 if (AS_LEGACY
== DESFIRE(tag
)->authentication_scheme
)
412 * When using new authentication methods, PLAIN data transmission from
413 * the PICC to the PCD are CMACed, so we have to maintain the
414 * cryptographic initialisation vector up-to-date to check data
417 * The only difference with CMACed data transmission is that the CMAC
418 * is not apended to the data send by the PCD to the PICC.
425 switch (DESFIRE(tag
)->authentication_scheme
) {
427 if (!(communication_settings
& MAC_COMMAND
))
431 edl
= padded_data_length(*nbytes
- offset
, key_block_size(DESFIRE(tag
)->session_key
)) + offset
;
433 // Fill in the crypto buffer with data ...
434 memcpy(res
, data
, *nbytes
);
436 memset(res
+ *nbytes
, 0, edl
- *nbytes
);
438 mifare_cypher_blocks_chained(tag
, NULL
, NULL
, res
+ offset
, edl
- offset
, MCD_SEND
, MCO_ENCYPHER
);
440 memcpy(mac
, res
+ edl
- 8, 4);
442 // Copy again provided data (was overwritten by mifare_cypher_blocks_chained)
443 memcpy(res
, data
, *nbytes
);
445 if (!(communication_settings
& MAC_COMMAND
))
448 size_t bla
= maced_data_length(DESFIRE(tag
)->session_key
, *nbytes
- offset
) + offset
;
451 memcpy(res
+ *nbytes
, mac
, 4);
456 if (!(communication_settings
& CMAC_COMMAND
))
458 cmac(key
, DESFIRE(tag
)->ivect
, res
, *nbytes
, DESFIRE(tag
)->cmac
);
461 size_t len
= maced_data_length(key
, *nbytes
);
463 memcpy(res
, data
, *nbytes
);
464 memcpy(res
+ *nbytes
, DESFIRE(tag
)->cmac
, CMAC_LENGTH
);
465 *nbytes
+= CMAC_LENGTH
;
471 case MDCM_ENCIPHERED
:
472 /* |<-------------- data -------------->|
473 * |<--- offset -->| |
474 * +---------------+--------------------+-----+---------+
475 * | CMD + HEADERS | DATA TO BE SECURED | CRC | PADDING |
476 * +---------------+--------------------+-----+---------+ ----------------
477 * | |<~~~~v~~~~~~~~~~~~~>| ^ | | (DES / 3DES)
478 * | | `---- crc16() ----' | |
479 * | | | ^ | | ----- *or* -----
480 * |<~~~~~~~~~~~~~~~~~~~~v~~~~~~~~~~~~~>| ^ | | (3K3DES / AES)
481 * | `---- crc32() ----' | |
482 * | | ---- *then* ----
483 * |<---------------------------------->|
484 * encypher()/decypher()
487 if (!(communication_settings
& ENC_COMMAND
))
489 edl
= enciphered_data_length(tag
, *nbytes
- offset
, communication_settings
) + offset
;
491 // Fill in the crypto buffer with data ...
492 memcpy(res
, data
, *nbytes
);
493 if (!(communication_settings
& NO_CRC
)) {
495 switch (DESFIRE(tag
)->authentication_scheme
) {
497 AddCrc14A(res
+ offset
, *nbytes
- offset
);
501 crc32_append(res
, *nbytes
);
507 memset(res
+ *nbytes
, 0, edl
- *nbytes
);
511 mifare_cypher_blocks_chained(tag
, NULL
, NULL
, res
+ offset
, *nbytes
- offset
, MCD_SEND
, (AS_NEW
== DESFIRE(tag
)->authentication_scheme
) ? MCO_ENCYPHER
: MCO_DECYPHER
);
524 void *mifare_cryto_postprocess_data(desfiretag_t tag
, void *data
, size_t *nbytes
, int communication_settings
) {
527 uint8_t first_cmac_byte
= 0x00;
529 desfirekey_t key
= DESFIRE(tag
)->session_key
;
534 // Return directly if we just have a status code.
538 switch (communication_settings
& MDCM_MASK
) {
541 if (AS_LEGACY
== DESFIRE(tag
)->authentication_scheme
)
546 switch (DESFIRE(tag
)->authentication_scheme
) {
548 if (communication_settings
& MAC_VERIFY
) {
549 *nbytes
-= key_macing_length(key
);
554 Dbprintf("No room for MAC!");
559 size_t edl
= enciphered_data_length(tag
, *nbytes
- 1, communication_settings
);
560 edata
= BigBuf_malloc(edl
);
562 memcpy(edata
, data
, *nbytes
- 1);
563 memset((uint8_t *)edata
+ *nbytes
- 1, 0, edl
- *nbytes
+ 1);
565 mifare_cypher_blocks_chained(tag
, NULL
, NULL
, edata
, edl
, MCD_SEND
, MCO_ENCYPHER
);
567 if (0 != memcmp((uint8_t *)data
+ *nbytes
- 1, (uint8_t *)edata
+ edl
- 8, 4)) {
569 Dbprintf("MACing not verified");
570 hexdump((uint8_t *)data
+ *nbytes
- 1, key_macing_length(key
), "Expect ", 0);
571 hexdump((uint8_t *)edata
+ edl
- 8, key_macing_length(key
), "Actual ", 0);
573 DESFIRE(tag
)->last_pcd_error
= CRYPTO_ERROR
;
580 if (!(communication_settings
& CMAC_COMMAND
))
582 if (communication_settings
& CMAC_VERIFY
) {
588 first_cmac_byte
= ((uint8_t *)data
)[*nbytes
- 9];
589 ((uint8_t *)data
)[*nbytes
- 9] = ((uint8_t *)data
)[*nbytes
- 1];
592 int n
= (communication_settings
& CMAC_VERIFY
) ? 8 : 0;
593 cmac(key
, DESFIRE(tag
)->ivect
, ((uint8_t *)data
), *nbytes
- n
, DESFIRE(tag
)->cmac
);
595 if (communication_settings
& CMAC_VERIFY
) {
596 ((uint8_t *)data
)[*nbytes
- 9] = first_cmac_byte
;
597 if (0 != memcmp(DESFIRE(tag
)->cmac
, (uint8_t *)data
+ *nbytes
- 9, 8)) {
599 Dbprintf("CMAC NOT verified :-(");
600 hexdump((uint8_t *)data
+ *nbytes
- 9, 8, "Expect ", 0);
601 hexdump(DESFIRE(tag
)->cmac
, 8, "Actual ", 0);
603 DESFIRE(tag
)->last_pcd_error
= CRYPTO_ERROR
;
616 case MDCM_ENCIPHERED
:
618 bool verified
= false;
620 int end_crc_pos
= 0x00;
625 * ,-----------------+-------------------------------+--------+
626 * \ BLOCK n-1 | BLOCK n | STATUS |
627 * / PAYLOAD | CRC0 | CRC1 | 0x80? | 0x000000000000 | 0x9100 |
628 * `-----------------+-------------------------------+--------+
630 * <------------ DATA ------------>
631 * FRAME = PAYLOAD + CRC(PAYLOAD) + PADDING
634 * ,-------------------------------+-----------------------------------------------+--------+
635 * \ BLOCK n-1 | BLOCK n | STATUS |
636 * / PAYLOAD | CRC0 | CRC1 | CRC2 | CRC3 | 0x80? | 0x0000000000000000000000000000 | 0x9100 |
637 * `-------------------------------+-----------------------------------------------+--------+
638 * <----------------------------------- DATA ------------------------------------->|
640 * <----------------- DATA ---------------->
641 * FRAME = PAYLOAD + CRC(PAYLOAD + STATUS) + PADDING + STATUS
642 * `------------------'
645 mifare_cypher_blocks_chained(tag
, NULL
, NULL
, res
, *nbytes
, MCD_RECEIVE
, MCO_DECYPHER
);
648 * Look for the CRC and ensure it is followed by NULL padding. We
649 * can't start by the end because the CRC is supposed to be 0 when
650 * verified, and accumulating 0's in it should not change it.
652 switch (DESFIRE(tag
)->authentication_scheme
) {
654 crc_pos
= *nbytes
- 8 - 1; // The CRC can be over two blocks
661 /* Move status between payload and CRC */
662 res
= DESFIRE(tag
)->crypto_buffer
;
663 memcpy(res
, data
, *nbytes
);
665 crc_pos
= (*nbytes
) - 16 - 3;
670 memcpy((uint8_t *)res
+ crc_pos
+ 1, (uint8_t *)res
+ crc_pos
, *nbytes
- crc_pos
);
671 ((uint8_t *)res
)[crc_pos
] = 0x00;
678 uint16_t crc_16
= 0x00;
680 switch (DESFIRE(tag
)->authentication_scheme
) {
682 AddCrc14A((uint8_t *)res
, end_crc_pos
);
683 end_crc_pos
= crc_pos
+ 2;
690 end_crc_pos
= crc_pos
+ 4;
691 crc32_ex(res
, end_crc_pos
, (uint8_t *)&crc
);
696 for (int n
= end_crc_pos
; n
< *nbytes
- 1; n
++) {
697 uint8_t byte
= ((uint8_t *)res
)[n
];
698 if (!((0x00 == byte
) || ((0x80 == byte
) && (n
== end_crc_pos
))))
704 switch (DESFIRE(tag
)->authentication_scheme
) {
706 ((uint8_t *)data
)[(*nbytes
)++] = 0x00;
709 /* The status byte was already before the CRC */
713 switch (DESFIRE(tag
)->authentication_scheme
) {
717 x
= ((uint8_t *)res
)[crc_pos
- 1];
718 ((uint8_t *)res
)[crc_pos
- 1] = ((uint8_t *)res
)[crc_pos
];
719 ((uint8_t *)res
)[crc_pos
] = x
;
724 } while (!verified
&& (end_crc_pos
< *nbytes
));
728 /* FIXME In some configurations, the file is transmitted PLAIN */
729 Dbprintf("CRC not verified in decyphered stream");
731 DESFIRE(tag
)->last_pcd_error
= CRYPTO_ERROR
;
738 Dbprintf("Unknown communication settings");
748 void mifare_cypher_single_block(desfirekey_t key
, uint8_t *data
, uint8_t *ivect
, MifareCryptoDirection direction
, MifareCryptoOperation operation
, size_t block_size
) {
749 uint8_t ovect
[MAX_CRYPTO_BLOCK_SIZE
];
750 if (direction
== MCD_SEND
) {
751 xor(ivect
, data
, block_size
);
753 memcpy(ovect
, data
, block_size
);
756 uint8_t edata
[MAX_CRYPTO_BLOCK_SIZE
];
762 //DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_ENCRYPT);
763 des_encrypt(edata
, data
, key
->data
);
766 //DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_DECRYPT);
767 des_decrypt(edata
, data
, key
->data
);
774 mbedtls_des3_set2key_enc(&ctx3
, key
->data
);
775 mbedtls_des3_crypt_ecb(&ctx3
, data
, edata
);
776 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_ENCRYPT);
777 // DES_ecb_encrypt ((DES_cblock *) edata, (DES_cblock *) data, &(key->ks2), DES_DECRYPT);
778 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_ENCRYPT);
781 mbedtls_des3_set2key_dec(&ctx3
, key
->data
);
782 mbedtls_des3_crypt_ecb(&ctx3
, data
, edata
);
783 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_DECRYPT);
784 // DES_ecb_encrypt ((DES_cblock *) edata, (DES_cblock *) data, &(key->ks2), DES_ENCRYPT);
785 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_DECRYPT);
792 mbedtls_des3_set3key_enc(&ctx3
, key
->data
);
793 mbedtls_des3_crypt_ecb(&ctx3
, data
, edata
);
794 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_ENCRYPT);
795 // DES_ecb_encrypt ((DES_cblock *) edata, (DES_cblock *) data, &(key->ks2), DES_DECRYPT);
796 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks3), DES_ENCRYPT);
799 mbedtls_des3_set3key_dec(&ctx3
, key
->data
);
800 mbedtls_des3_crypt_ecb(&ctx3
, data
, edata
);
801 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks3), DES_DECRYPT);
802 // DES_ecb_encrypt ((DES_cblock *) edata, (DES_cblock *) data, &(key->ks2), DES_ENCRYPT);
803 // DES_ecb_encrypt ((DES_cblock *) data, (DES_cblock *) edata, &(key->ks1), DES_DECRYPT);
810 mbedtls_aes_init(&actx
);
811 mbedtls_aes_setkey_enc(&actx
, key
->data
, 128);
812 mbedtls_aes_crypt_cbc(&actx
, MBEDTLS_AES_ENCRYPT
, sizeof(edata
), ivect
, data
, edata
);
816 mbedtls_aes_init(&actx
);
817 mbedtls_aes_setkey_dec(&actx
, key
->data
, 128);
818 mbedtls_aes_crypt_cbc(&actx
, MBEDTLS_AES_DECRYPT
, sizeof(edata
), ivect
, edata
, data
);
825 memcpy(data
, edata
, block_size
);
827 if (direction
== MCD_SEND
) {
828 memcpy(ivect
, data
, block_size
);
830 xor(ivect
, data
, block_size
);
831 memcpy(ivect
, ovect
, block_size
);
836 * This function performs all CBC cyphering / deciphering.
838 * The tag argument may be NULL, in which case both key and ivect shall be set.
839 * When using the tag session_key and ivect for processing data, these
840 * arguments should be set to NULL.
842 * Because the tag may contain additional data, one may need to call this
843 * function with tag, key and ivect defined.
845 void mifare_cypher_blocks_chained(desfiretag_t tag
, desfirekey_t key
, uint8_t *ivect
, uint8_t *data
, size_t data_size
, MifareCryptoDirection direction
, MifareCryptoOperation operation
) {
850 key
= DESFIRE(tag
)->session_key
;
853 ivect
= DESFIRE(tag
)->ivect
;
856 switch (DESFIRE(tag
)->authentication_scheme
) {
858 memset(ivect
, 0, MAX_CRYPTO_BLOCK_SIZE
);
865 block_size
= key_block_size(key
);
868 while (offset
< data_size
) {
869 mifare_cypher_single_block(key
, data
+ offset
, ivect
, direction
, operation
, block_size
);
870 offset
+= block_size
;