12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- /* LibTomCrypt, modular cryptographic library -- Tom St Denis
- *
- * LibTomCrypt is a library that provides various cryptographic
- * algorithms in a highly modular and flexible manner.
- *
- * The library is free for all purposes without any express
- * guarantee it works.
- */
- #include "tomcrypt.h"
- #ifdef LTC_CCM_MODE
- /**
- Process plaintext/ciphertext through CCM
- @param ccm The CCM state
- @param pt The plaintext
- @param ptlen The plaintext length (ciphertext length is the same)
- @param ct The ciphertext
- @param direction Encrypt or Decrypt mode (CCM_ENCRYPT or CCM_DECRYPT)
- @return CRYPT_OK on success
- */
- int ccm_process(ccm_state *ccm,
- unsigned char *pt, unsigned long ptlen,
- unsigned char *ct,
- int direction)
- {
- unsigned char z, b;
- unsigned long y;
- int err;
- LTC_ARGCHK(ccm != NULL);
- /* Check aad has been correctly added */
- if (ccm->aadlen != ccm->current_aadlen) {
- return CRYPT_ERROR;
- }
- /* Check we do not process too much data */
- if (ccm->ptlen < ccm->current_ptlen + ptlen) {
- return CRYPT_ERROR;
- }
- ccm->current_ptlen += ptlen;
- /* now handle the PT */
- if (ptlen > 0) {
- LTC_ARGCHK(pt != NULL);
- LTC_ARGCHK(ct != NULL);
- for (y = 0; y < ptlen; y++) {
- /* increment the ctr? */
- if (ccm->CTRlen == 16) {
- for (z = 15; z > 15-ccm->L; z--) {
- ccm->ctr[z] = (ccm->ctr[z] + 1) & 255;
- if (ccm->ctr[z]) break;
- }
- if ((err = cipher_descriptor[ccm->cipher].ecb_encrypt(ccm->ctr, ccm->CTRPAD, &ccm->K)) != CRYPT_OK) {
- return err;
- }
- ccm->CTRlen = 0;
- }
- /* if we encrypt we add the bytes to the MAC first */
- if (direction == CCM_ENCRYPT) {
- b = pt[y];
- ct[y] = b ^ ccm->CTRPAD[ccm->CTRlen++];
- } else {
- b = ct[y] ^ ccm->CTRPAD[ccm->CTRlen++];
- pt[y] = b;
- }
- if (ccm->x == 16) {
- if ((err = cipher_descriptor[ccm->cipher].ecb_encrypt(ccm->PAD, ccm->PAD, &ccm->K)) != CRYPT_OK) {
- return err;
- }
- ccm->x = 0;
- }
- ccm->PAD[ccm->x++] ^= b;
- }
- }
- return CRYPT_OK;
- }
- #endif
- /* ref: $Format:%D$ */
- /* git commit: $Format:%H$ */
- /* commit time: $Format:%ai$ */
|