2
0

fcrypt_b.c 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*
  2. * Copyright 1995-2020 The OpenSSL Project Authors. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License 2.0 (the "License"). You may not use
  5. * this file except in compliance with the License. You can obtain a copy
  6. * in the file LICENSE in the source distribution or at
  7. * https://www.openssl.org/source/license.html
  8. */
  9. /*
  10. * DES low level APIs are deprecated for public use, but still ok for internal
  11. * use.
  12. */
  13. #include "internal/deprecated.h"
  14. #include <stdio.h>
  15. #define DES_FCRYPT
  16. #include "des_local.h"
  17. #undef DES_FCRYPT
  18. #undef PERM_OP
  19. #define PERM_OP(a,b,t,n,m) ((t)=((((a)>>(n))^(b))&(m)),\
  20. (b)^=(t),\
  21. (a)^=((t)<<(n)))
  22. #undef HPERM_OP
  23. #define HPERM_OP(a,t,n,m) ((t)=((((a)<<(16-(n)))^(a))&(m)),\
  24. (a)=(a)^(t)^(t>>(16-(n))))\
  25. void fcrypt_body(DES_LONG *out, DES_key_schedule *ks, DES_LONG Eswap0,
  26. DES_LONG Eswap1)
  27. {
  28. register DES_LONG l, r, t, u;
  29. register DES_LONG *s;
  30. register int j;
  31. register DES_LONG E0, E1;
  32. l = 0;
  33. r = 0;
  34. s = (DES_LONG *)ks;
  35. E0 = Eswap0;
  36. E1 = Eswap1;
  37. for (j = 0; j < 25; j++) {
  38. D_ENCRYPT(l, r, 0); /* 1 */
  39. D_ENCRYPT(r, l, 2); /* 2 */
  40. D_ENCRYPT(l, r, 4); /* 3 */
  41. D_ENCRYPT(r, l, 6); /* 4 */
  42. D_ENCRYPT(l, r, 8); /* 5 */
  43. D_ENCRYPT(r, l, 10); /* 6 */
  44. D_ENCRYPT(l, r, 12); /* 7 */
  45. D_ENCRYPT(r, l, 14); /* 8 */
  46. D_ENCRYPT(l, r, 16); /* 9 */
  47. D_ENCRYPT(r, l, 18); /* 10 */
  48. D_ENCRYPT(l, r, 20); /* 11 */
  49. D_ENCRYPT(r, l, 22); /* 12 */
  50. D_ENCRYPT(l, r, 24); /* 13 */
  51. D_ENCRYPT(r, l, 26); /* 14 */
  52. D_ENCRYPT(l, r, 28); /* 15 */
  53. D_ENCRYPT(r, l, 30); /* 16 */
  54. t = l;
  55. l = r;
  56. r = t;
  57. }
  58. l = ROTATE(l, 3) & 0xffffffffL;
  59. r = ROTATE(r, 3) & 0xffffffffL;
  60. PERM_OP(l, r, t, 1, 0x55555555L);
  61. PERM_OP(r, l, t, 8, 0x00ff00ffL);
  62. PERM_OP(l, r, t, 2, 0x33333333L);
  63. PERM_OP(r, l, t, 16, 0x0000ffffL);
  64. PERM_OP(l, r, t, 4, 0x0f0f0f0fL);
  65. out[0] = r;
  66. out[1] = l;
  67. }