diff options
| author | djm <> | 2005-04-29 05:39:33 +0000 |
|---|---|---|
| committer | djm <> | 2005-04-29 05:39:33 +0000 |
| commit | 68edd00d9258df93b1366c71ac124e0cadf7bc08 (patch) | |
| tree | 3ce4ae2a9747bbc11aed1f95f9bbea92c41f8683 /src/lib/libcrypto/des | |
| parent | f396ed0f5ce0af56bfde2e75e15cf1f52924c779 (diff) | |
| download | openbsd-68edd00d9258df93b1366c71ac124e0cadf7bc08.tar.gz openbsd-68edd00d9258df93b1366c71ac124e0cadf7bc08.tar.bz2 openbsd-68edd00d9258df93b1366c71ac124e0cadf7bc08.zip | |
resolve conflicts
Diffstat (limited to 'src/lib/libcrypto/des')
| -rw-r--r-- | src/lib/libcrypto/des/cfb64ede.c | 112 | ||||
| -rw-r--r-- | src/lib/libcrypto/des/des.h | 6 | ||||
| -rw-r--r-- | src/lib/libcrypto/des/des_enc.c | 8 | ||||
| -rw-r--r-- | src/lib/libcrypto/des/des_old.c | 2 | ||||
| -rw-r--r-- | src/lib/libcrypto/des/destest.c | 4 | ||||
| -rw-r--r-- | src/lib/libcrypto/des/ecb3_enc.c | 4 | ||||
| -rw-r--r-- | src/lib/libcrypto/des/set_key.c | 4 |
7 files changed, 133 insertions, 7 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 | |||
diff --git a/src/lib/libcrypto/des/des.h b/src/lib/libcrypto/des/des.h index dfe5ff64e4..81bd874edd 100644 --- a/src/lib/libcrypto/des/des.h +++ b/src/lib/libcrypto/des/des.h | |||
| @@ -130,7 +130,7 @@ OPENSSL_DECLARE_GLOBAL(int,DES_rw_mode); /* defaults to DES_PCBC_MODE */ | |||
| 130 | #define DES_rw_mode OPENSSL_GLOBAL_REF(DES_rw_mode) | 130 | #define DES_rw_mode OPENSSL_GLOBAL_REF(DES_rw_mode) |
| 131 | 131 | ||
| 132 | const char *DES_options(void); | 132 | const char *DES_options(void); |
| 133 | void DES_ecb3_encrypt(const_DES_cblock *input, DES_cblock *output, | 133 | void DES_ecb3_encrypt(const unsigned char *input, unsigned char *output, |
| 134 | DES_key_schedule *ks1,DES_key_schedule *ks2, | 134 | DES_key_schedule *ks1,DES_key_schedule *ks2, |
| 135 | DES_key_schedule *ks3, int enc); | 135 | DES_key_schedule *ks3, int enc); |
| 136 | DES_LONG DES_cbc_cksum(const unsigned char *input,DES_cblock *output, | 136 | DES_LONG DES_cbc_cksum(const unsigned char *input,DES_cblock *output, |
| @@ -189,6 +189,10 @@ void DES_ede3_cfb64_encrypt(const unsigned char *in,unsigned char *out, | |||
| 189 | long length,DES_key_schedule *ks1, | 189 | long length,DES_key_schedule *ks1, |
| 190 | DES_key_schedule *ks2,DES_key_schedule *ks3, | 190 | DES_key_schedule *ks2,DES_key_schedule *ks3, |
| 191 | DES_cblock *ivec,int *num,int enc); | 191 | DES_cblock *ivec,int *num,int enc); |
| 192 | void DES_ede3_cfb_encrypt(const unsigned char *in,unsigned char *out, | ||
| 193 | int numbits,long length,DES_key_schedule *ks1, | ||
| 194 | DES_key_schedule *ks2,DES_key_schedule *ks3, | ||
| 195 | DES_cblock *ivec,int enc); | ||
| 192 | void DES_ede3_ofb64_encrypt(const unsigned char *in,unsigned char *out, | 196 | void DES_ede3_ofb64_encrypt(const unsigned char *in,unsigned char *out, |
| 193 | long length,DES_key_schedule *ks1, | 197 | long length,DES_key_schedule *ks1, |
| 194 | DES_key_schedule *ks2,DES_key_schedule *ks3, | 198 | DES_key_schedule *ks2,DES_key_schedule *ks3, |
diff --git a/src/lib/libcrypto/des/des_enc.c b/src/lib/libcrypto/des/des_enc.c index 4f09804c44..6a49ec4a55 100644 --- a/src/lib/libcrypto/des/des_enc.c +++ b/src/lib/libcrypto/des/des_enc.c | |||
| @@ -58,7 +58,9 @@ | |||
| 58 | 58 | ||
| 59 | #include "des_locl.h" | 59 | #include "des_locl.h" |
| 60 | 60 | ||
| 61 | #ifndef OPENSSL_FIPS | ||
| 61 | #ifndef OPENBSD_DES_ASM | 62 | #ifndef OPENBSD_DES_ASM |
| 63 | |||
| 62 | void DES_encrypt1(DES_LONG *data, DES_key_schedule *ks, int enc) | 64 | void DES_encrypt1(DES_LONG *data, DES_key_schedule *ks, int enc) |
| 63 | { | 65 | { |
| 64 | register DES_LONG l,r,t,u; | 66 | register DES_LONG l,r,t,u; |
| @@ -289,8 +291,12 @@ void DES_decrypt3(DES_LONG *data, DES_key_schedule *ks1, | |||
| 289 | data[1]=r; | 291 | data[1]=r; |
| 290 | } | 292 | } |
| 291 | 293 | ||
| 294 | #endif /* ndef OPENSSL_FIPS */ | ||
| 295 | |||
| 292 | #ifndef DES_DEFAULT_OPTIONS | 296 | #ifndef DES_DEFAULT_OPTIONS |
| 293 | 297 | ||
| 298 | #if !defined(OPENSSL_FIPS_DES_ASM) | ||
| 299 | |||
| 294 | #undef CBC_ENC_C__DONT_UPDATE_IV | 300 | #undef CBC_ENC_C__DONT_UPDATE_IV |
| 295 | #include "ncbc_enc.c" /* DES_ncbc_encrypt */ | 301 | #include "ncbc_enc.c" /* DES_ncbc_encrypt */ |
| 296 | 302 | ||
| @@ -406,4 +412,6 @@ void DES_ede3_cbc_encrypt(const unsigned char *input, unsigned char *output, | |||
| 406 | tin[0]=tin[1]=0; | 412 | tin[0]=tin[1]=0; |
| 407 | } | 413 | } |
| 408 | 414 | ||
| 415 | #endif /* !defined(OPENSSL_FIPS_DES_ASM) */ | ||
| 416 | |||
| 409 | #endif /* DES_DEFAULT_OPTIONS */ | 417 | #endif /* DES_DEFAULT_OPTIONS */ |
diff --git a/src/lib/libcrypto/des/des_old.c b/src/lib/libcrypto/des/des_old.c index 7e4cd7180d..88e9802aad 100644 --- a/src/lib/libcrypto/des/des_old.c +++ b/src/lib/libcrypto/des/des_old.c | |||
| @@ -84,7 +84,7 @@ void _ossl_old_des_ecb3_encrypt(_ossl_old_des_cblock *input,_ossl_old_des_cblock | |||
| 84 | des_key_schedule ks1,des_key_schedule ks2, | 84 | des_key_schedule ks1,des_key_schedule ks2, |
| 85 | des_key_schedule ks3, int enc) | 85 | des_key_schedule ks3, int enc) |
| 86 | { | 86 | { |
| 87 | DES_ecb3_encrypt((const_DES_cblock *)input, output, | 87 | DES_ecb3_encrypt((const unsigned char *)input, (unsigned char *)output, |
| 88 | (DES_key_schedule *)ks1, (DES_key_schedule *)ks2, | 88 | (DES_key_schedule *)ks1, (DES_key_schedule *)ks2, |
| 89 | (DES_key_schedule *)ks3, enc); | 89 | (DES_key_schedule *)ks3, enc); |
| 90 | } | 90 | } |
diff --git a/src/lib/libcrypto/des/destest.c b/src/lib/libcrypto/des/destest.c index 3983ac8e5f..e3e9d77f14 100644 --- a/src/lib/libcrypto/des/destest.c +++ b/src/lib/libcrypto/des/destest.c | |||
| @@ -439,8 +439,8 @@ int main(int argc, char *argv[]) | |||
| 439 | memcpy(in,plain_data[i],8); | 439 | memcpy(in,plain_data[i],8); |
| 440 | memset(out,0,8); | 440 | memset(out,0,8); |
| 441 | memset(outin,0,8); | 441 | memset(outin,0,8); |
| 442 | des_ecb2_encrypt(&in,&out,ks,ks2,DES_ENCRYPT); | 442 | des_ecb2_encrypt(in,out,ks,ks2,DES_ENCRYPT); |
| 443 | des_ecb2_encrypt(&out,&outin,ks,ks2,DES_DECRYPT); | 443 | des_ecb2_encrypt(out,outin,ks,ks2,DES_DECRYPT); |
| 444 | 444 | ||
| 445 | if (memcmp(out,cipher_ecb2[i],8) != 0) | 445 | if (memcmp(out,cipher_ecb2[i],8) != 0) |
| 446 | { | 446 | { |
diff --git a/src/lib/libcrypto/des/ecb3_enc.c b/src/lib/libcrypto/des/ecb3_enc.c index c3437bc606..fa0c9c4d4f 100644 --- a/src/lib/libcrypto/des/ecb3_enc.c +++ b/src/lib/libcrypto/des/ecb3_enc.c | |||
| @@ -58,15 +58,13 @@ | |||
| 58 | 58 | ||
| 59 | #include "des_locl.h" | 59 | #include "des_locl.h" |
| 60 | 60 | ||
| 61 | void DES_ecb3_encrypt(const_DES_cblock *input, DES_cblock *output, | 61 | void DES_ecb3_encrypt(const unsigned char *in, unsigned char *out, |
| 62 | DES_key_schedule *ks1, DES_key_schedule *ks2, | 62 | DES_key_schedule *ks1, DES_key_schedule *ks2, |
| 63 | DES_key_schedule *ks3, | 63 | DES_key_schedule *ks3, |
| 64 | int enc) | 64 | int enc) |
| 65 | { | 65 | { |
| 66 | register DES_LONG l0,l1; | 66 | register DES_LONG l0,l1; |
| 67 | DES_LONG ll[2]; | 67 | DES_LONG ll[2]; |
| 68 | const unsigned char *in = &(*input)[0]; | ||
| 69 | unsigned char *out = &(*output)[0]; | ||
| 70 | 68 | ||
| 71 | c2l(in,l0); | 69 | c2l(in,l0); |
| 72 | c2l(in,l1); | 70 | c2l(in,l1); |
diff --git a/src/lib/libcrypto/des/set_key.c b/src/lib/libcrypto/des/set_key.c index 143008ed9c..8881d46a7a 100644 --- a/src/lib/libcrypto/des/set_key.c +++ b/src/lib/libcrypto/des/set_key.c | |||
| @@ -65,6 +65,8 @@ | |||
| 65 | */ | 65 | */ |
| 66 | #include "des_locl.h" | 66 | #include "des_locl.h" |
| 67 | 67 | ||
| 68 | #ifndef OPENSSL_FIPS | ||
| 69 | |||
| 68 | OPENSSL_IMPLEMENT_GLOBAL(int,DES_check_key); /* defaults to false */ | 70 | OPENSSL_IMPLEMENT_GLOBAL(int,DES_check_key); /* defaults to false */ |
| 69 | 71 | ||
| 70 | static const unsigned char odd_parity[256]={ | 72 | static const unsigned char odd_parity[256]={ |
| @@ -405,3 +407,5 @@ void des_fixup_key_parity(des_cblock *key) | |||
| 405 | des_set_odd_parity(key); | 407 | des_set_odd_parity(key); |
| 406 | } | 408 | } |
| 407 | */ | 409 | */ |
| 410 | |||
| 411 | #endif /* ndef OPENSSL_FIPS */ | ||
