diff options
Diffstat (limited to 'src/lib/libcrypto/des/cfb64ede.c')
| -rw-r--r-- | src/lib/libcrypto/des/cfb64ede.c | 112 | 
1 files changed, 112 insertions, 0 deletions
| diff --git a/src/lib/libcrypto/des/cfb64ede.c b/src/lib/libcrypto/des/cfb64ede.c index 60c1aa08db..f3c6018528 100644 --- a/src/lib/libcrypto/des/cfb64ede.c +++ b/src/lib/libcrypto/des/cfb64ede.c | |||
| @@ -57,6 +57,7 @@ | |||
| 57 | */ | 57 | */ | 
| 58 | 58 | ||
| 59 | #include "des_locl.h" | 59 | #include "des_locl.h" | 
| 60 | #include "e_os.h" | ||
| 60 | 61 | ||
| 61 | /* The input and output encrypted as though 64bit cfb mode is being | 62 | /* The input and output encrypted as though 64bit cfb mode is being | 
| 62 | * used. The extra state information to record how much of the | 63 | * used. The extra state information to record how much of the | 
| @@ -140,3 +141,114 @@ void DES_ede2_cfb64_encrypt(unsigned char *in, unsigned char *out, long length, | |||
| 140 | DES_ede3_cfb64_encrypt(in,out,length,ks1,ks2,ks1,ivec,num,enc); | 141 | DES_ede3_cfb64_encrypt(in,out,length,ks1,ks2,ks1,ivec,num,enc); | 
| 141 | } | 142 | } | 
| 142 | #endif | 143 | #endif | 
| 144 | |||
| 145 | /* This is compatible with the single key CFB-r for DES, even thought that's | ||
| 146 | * not what EVP needs. | ||
| 147 | */ | ||
| 148 | |||
| 149 | void DES_ede3_cfb_encrypt(const unsigned char *in,unsigned char *out, | ||
| 150 | int numbits,long length,DES_key_schedule *ks1, | ||
| 151 | DES_key_schedule *ks2,DES_key_schedule *ks3, | ||
| 152 | DES_cblock *ivec,int enc) | ||
| 153 | { | ||
| 154 | register DES_LONG d0,d1,v0,v1; | ||
| 155 | register long l=length; | ||
| 156 | register int num=numbits,n=(numbits+7)/8,i; | ||
| 157 | DES_LONG ti[2]; | ||
| 158 | unsigned char *iv; | ||
| 159 | unsigned char ovec[16]; | ||
| 160 | |||
| 161 | if (num > 64) return; | ||
| 162 | iv = &(*ivec)[0]; | ||
| 163 | c2l(iv,v0); | ||
| 164 | c2l(iv,v1); | ||
| 165 | if (enc) | ||
| 166 | { | ||
| 167 | while (l >= n) | ||
| 168 | { | ||
| 169 | l-=n; | ||
| 170 | ti[0]=v0; | ||
| 171 | ti[1]=v1; | ||
| 172 | DES_encrypt3(ti,ks1,ks2,ks3); | ||
| 173 | c2ln(in,d0,d1,n); | ||
| 174 | in+=n; | ||
| 175 | d0^=ti[0]; | ||
| 176 | d1^=ti[1]; | ||
| 177 | l2cn(d0,d1,out,n); | ||
| 178 | out+=n; | ||
| 179 | /* 30-08-94 - eay - changed because l>>32 and | ||
| 180 | * l<<32 are bad under gcc :-( */ | ||
| 181 | if (num == 32) | ||
| 182 | { v0=v1; v1=d0; } | ||
| 183 | else if (num == 64) | ||
| 184 | { v0=d0; v1=d1; } | ||
| 185 | else | ||
| 186 | { | ||
| 187 | iv=&ovec[0]; | ||
| 188 | l2c(v0,iv); | ||
| 189 | l2c(v1,iv); | ||
| 190 | l2c(d0,iv); | ||
| 191 | l2c(d1,iv); | ||
| 192 | /* shift ovec left most of the bits... */ | ||
| 193 | memmove(ovec,ovec+num/8,8+(num%8 ? 1 : 0)); | ||
| 194 | /* now the remaining bits */ | ||
| 195 | if(num%8 != 0) | ||
| 196 | for(i=0 ; i < 8 ; ++i) | ||
| 197 | { | ||
| 198 | ovec[i]<<=num%8; | ||
| 199 | ovec[i]|=ovec[i+1]>>(8-num%8); | ||
| 200 | } | ||
| 201 | iv=&ovec[0]; | ||
| 202 | c2l(iv,v0); | ||
| 203 | c2l(iv,v1); | ||
| 204 | } | ||
| 205 | } | ||
| 206 | } | ||
| 207 | else | ||
| 208 | { | ||
| 209 | while (l >= n) | ||
| 210 | { | ||
| 211 | l-=n; | ||
| 212 | ti[0]=v0; | ||
| 213 | ti[1]=v1; | ||
| 214 | DES_encrypt3(ti,ks1,ks2,ks3); | ||
| 215 | c2ln(in,d0,d1,n); | ||
| 216 | in+=n; | ||
| 217 | /* 30-08-94 - eay - changed because l>>32 and | ||
| 218 | * l<<32 are bad under gcc :-( */ | ||
| 219 | if (num == 32) | ||
| 220 | { v0=v1; v1=d0; } | ||
| 221 | else if (num == 64) | ||
| 222 | { v0=d0; v1=d1; } | ||
| 223 | else | ||
| 224 | { | ||
| 225 | iv=&ovec[0]; | ||
| 226 | l2c(v0,iv); | ||
| 227 | l2c(v1,iv); | ||
| 228 | l2c(d0,iv); | ||
| 229 | l2c(d1,iv); | ||
| 230 | /* shift ovec left most of the bits... */ | ||
| 231 | memmove(ovec,ovec+num/8,8+(num%8 ? 1 : 0)); | ||
| 232 | /* now the remaining bits */ | ||
| 233 | if(num%8 != 0) | ||
| 234 | for(i=0 ; i < 8 ; ++i) | ||
| 235 | { | ||
| 236 | ovec[i]<<=num%8; | ||
| 237 | ovec[i]|=ovec[i+1]>>(8-num%8); | ||
| 238 | } | ||
| 239 | iv=&ovec[0]; | ||
| 240 | c2l(iv,v0); | ||
| 241 | c2l(iv,v1); | ||
| 242 | } | ||
| 243 | d0^=ti[0]; | ||
| 244 | d1^=ti[1]; | ||
| 245 | l2cn(d0,d1,out,n); | ||
| 246 | out+=n; | ||
| 247 | } | ||
| 248 | } | ||
| 249 | iv = &(*ivec)[0]; | ||
| 250 | l2c(v0,iv); | ||
| 251 | l2c(v1,iv); | ||
| 252 | v0=v1=d0=d1=ti[0]=ti[1]=0; | ||
| 253 | } | ||
| 254 | |||
