6
6
* The library is free for all purposes without any express
7
7
* guarantee it works.
9
* Tom St Denis, tomstdenis@gmail.com, http://libtomcrypt.org
9
* Tom St Denis, tomstdenis@gmail.com, http://libtomcrypt.com
11
11
#include "tomcrypt.h"
53
53
return CRYPT_INVALID_ARG;
56
if (len % sizeof(LTC_FAST_TYPE)) {
56
if (cbc->blocklen % sizeof(LTC_FAST_TYPE)) {
57
57
return CRYPT_INVALID_ARG;
61
61
if (cipher_descriptor[cbc->cipher].accel_cbc_decrypt != NULL) {
62
cipher_descriptor[cbc->cipher].accel_cbc_decrypt(ct, pt, len / cbc->blocklen, cbc->IV, &cbc->key);
62
return cipher_descriptor[cbc->cipher].accel_cbc_decrypt(ct, pt, len / cbc->blocklen, cbc->IV, &cbc->key);
66
cipher_descriptor[cbc->cipher].ecb_decrypt(ct, tmp, &cbc->key);
66
if ((err = cipher_descriptor[cbc->cipher].ecb_decrypt(ct, tmp, &cbc->key)) != CRYPT_OK) {
68
70
/* xor IV against plaintext */
69
71
#if defined(LTC_FAST)
70
for (x = 0; x < cbc->blocklen; x += sizeof(LTC_FAST_TYPE)) {
71
tmpy = *((LTC_FAST_TYPE*)((unsigned char *)cbc->IV + x)) ^ *((LTC_FAST_TYPE*)((unsigned char *)tmp + x));
72
*((LTC_FAST_TYPE*)((unsigned char *)cbc->IV + x)) = *((LTC_FAST_TYPE*)((unsigned char *)ct + x));
73
*((LTC_FAST_TYPE*)((unsigned char *)pt + x)) = tmpy;
72
for (x = 0; x < cbc->blocklen; x += sizeof(LTC_FAST_TYPE)) {
73
tmpy = *((LTC_FAST_TYPE*)((unsigned char *)cbc->IV + x)) ^ *((LTC_FAST_TYPE*)((unsigned char *)tmp + x));
74
*((LTC_FAST_TYPE*)((unsigned char *)cbc->IV + x)) = *((LTC_FAST_TYPE*)((unsigned char *)ct + x));
75
*((LTC_FAST_TYPE*)((unsigned char *)pt + x)) = tmpy;
76
78
for (x = 0; x < cbc->blocklen; x++) {
77
79
tmpy = tmp[x] ^ cbc->IV[x];
78
80
cbc->IV[x] = ct[x];
83
85
ct += cbc->blocklen;
84
86
pt += cbc->blocklen;