risto-des.shar
上传用户:zhh515
上传日期:2007-01-06
资源大小:966k
文件大小:25k
源码类别:

加密解密

开发平台:

C/C++

  1. #! /bin/sh
  2. # This is a shell archive.  Remove anything before this line, then unpack
  3. # it by saving it into a file and typing "sh file".  To overwrite existing
  4. # files, type "sh file -c".  You can also feed this as standard input via
  5. # unshar, or by typing "sh <file", e.g..  If this archive is complete, you
  6. # will see the following message at the end:
  7. # "End of shell archive."
  8. # Contents:  README.mdes des_test_data destest.c mdes.c mdes.h
  9. # Wrapped by paasivir@tukki on Thu Aug 11 09:33:21 1994
  10. PATH=/bin:/usr/bin:/usr/ucb ; export PATH
  11. if test -f README.mdes -a "${1}" != "-c" ; then 
  12.   echo shar: Will not over-write existing file "README.mdes"
  13. else
  14. echo shar: Extracting "README.mdes" (3025 characters)
  15. sed "s/^X//" >README.mdes <<'END_OF_README.mdes'
  16. X
  17. Xmdes.c, mdes.h, destest, des_test_data
  18. X
  19. X        Public Domain, NO WARRANRY.
  20. X
  21. X        This is a trivial DES implementation I wrote to figure out
  22. X        the algorithm. It's very slow. There are many faster free
  23. X        implementations around.
  24. X
  25. X        In USA this code may or may not be subject of export regulations,
  26. X        etc.
  27. X
  28. XVersion
  29. X
  30. X        1.0, first and probably last if des_cbc_encrypt (untested) works.
  31. X
  32. XAuthor
  33. X        Risto Paasivirta, paasivir@jyu.fi
  34. X
  35. X=============================================================================
  36. X
  37. Xmdes.h
  38. X
  39. X                #define DES_ENCRYPT        1
  40. X                #define DES_DECRYPT        0
  41. X
  42. X        Des encryption flag. Encrypt if DES_ENCRYPT, decrypt if DES_DECRYPT.
  43. X        (Doesn't sound too complex, does it.)
  44. X
  45. X                typedef struct des_key_schedule {
  46. X                        unsigned char b[16][48];
  47. X                } des_key_schedule;
  48. X
  49. X        Key schedule type. Key bits are left unpacked for 'speed'.
  50. X
  51. X
  52. X                typedef struct des_cblock {
  53. X                        unsigned char _[8];
  54. X                } des_cblock;
  55. X
  56. X        Des character block type. Any 8 char block should work fine.
  57. X
  58. Xmdes.c
  59. X
  60. X        Des functions
  61. X
  62. X                void des_set_odd_parity(des_cblock *key);
  63. X
  64. X        Set parity of 56-bit (7bits x 8 bytes) key block. Parity bit is
  65. X        the least significant bit in each byte. This implementation works
  66. X        with incorrect parity key blocks.
  67. X
  68. X                int des_set_key(des_cblock *k, des_key_schedule *key);
  69. X
  70. X        Initialize key schedule from key block k. If key checking would be
  71. X        implemented this probably should return some value.
  72. X
  73. X                int des_ecb_encrypt(des_cblock *input, des_cblock *output,
  74. X                        des_key_schedule *schedule, int encrypt);
  75. X
  76. X        Des encryption in des electronic code book mode. En/decrypt one
  77. X        cblock from input to output using key shedule. Returns number
  78. X        of bytes written to output (8.)
  79. X
  80. X                int des_cbc_encrypt(des_cblock *input, des_cblock *output,
  81. X                        int len, des_key_schedule *key,
  82. X                        des_cblock *ivec, int mode);
  83. X
  84. X        Des encryption in cipher block chaining mode. En/decrypt len bytes
  85. X        from input to output using scheduled key and initial ivec. If len is
  86. X        not multiple of 8, last block is padded with NULL bytes. Output is
  87. X        written always multiple of 8 bytes. Returns number of bytes written
  88. X        to output and final ivec in ivec.
  89. X
  90. Xdestest.c
  91. Xdes_test_data
  92. X
  93. X        Destest reads file des_test_data, converts hex key/plain/cipher
  94. X        cblock to binary and checks that en/decryption works in elecrtoric
  95. X        code book mode. File des_test_data has been posted few times to
  96. X        sci.crypt, only thing I have done to it was that I corrected one 
  97. X        key parity error from line 143:
  98. X        original
  99. X        3107911598090140 0000000000000000 406A9A6AB43399AE
  100. X        changed to:
  101. X        3107911598080140 0000000000000000 406A9A6AB43399AE
  102. X
  103. X(eof)
  104. END_OF_README.mdes
  105. if test 3025 -ne `wc -c <README.mdes`; then
  106.     echo shar: "README.mdes" unpacked with wrong size!
  107. fi
  108. # end of overwriting check
  109. fi
  110. if test -f des_test_data -a "${1}" != "-c" ; then 
  111.   echo shar: Will not over-write existing file "des_test_data"
  112. else
  113. echo shar: Extracting "des_test_data" (8854 characters)
  114. sed "s/^X//" >des_test_data <<'END_OF_des_test_data'
  115. X
  116. XKey              Plain            Cipher
  117. X/* IP and E Test */
  118. X0101010101010101 95F8A5E5DD31D900 8000000000000000
  119. X0101010101010101 DD7F121CA5015619 4000000000000000
  120. X0101010101010101 2E8653104F3834EA 2000000000000000
  121. X0101010101010101 4BD388FF6CD81D4F 1000000000000000
  122. X0101010101010101 20B9E767B2FB1456 0800000000000000
  123. X0101010101010101 55579380D77138EF 0400000000000000
  124. X0101010101010101 6CC5DEFAAF04512F 0200000000000000
  125. X0101010101010101 0D9F279BA5D87260 0100000000000000
  126. X0101010101010101 D9031B0271BD5A0A 0080000000000000
  127. X0101010101010101 424250B37C3DD951 0040000000000000
  128. X0101010101010101 B8061B7ECD9A21E5 0020000000000000
  129. X0101010101010101 F15D0F286B65BD28 0010000000000000
  130. X0101010101010101 ADD0CC8D6E5DEBA1 0008000000000000
  131. X0101010101010101 E6D5F82752AD63D1 0004000000000000
  132. X0101010101010101 ECBFE3BD3F591A5E 0002000000000000
  133. X0101010101010101 F356834379D165CD 0001000000000000
  134. X0101010101010101 2B9F982F20037FA9 0000800000000000
  135. X0101010101010101 889DE068A16F0BE6 0000400000000000
  136. X0101010101010101 E19E275D846A1298 0000200000000000
  137. X0101010101010101 329A8ED523D71AEC 0000100000000000
  138. X0101010101010101 E7FCE22557D23C97 0000080000000000
  139. X0101010101010101 12A9F5817FF2D65D 0000040000000000
  140. X0101010101010101 A484C3AD38DC9C19 0000020000000000
  141. X0101010101010101 FBE00A8A1EF8AD72 0000010000000000
  142. X0101010101010101 750D079407521363 0000008000000000
  143. X0101010101010101 64FEED9C724C2FAF 0000004000000000
  144. X0101010101010101 F02B263B328E2B60 0000002000000000
  145. X0101010101010101 9D64555A9A10B852 0000001000000000
  146. X0101010101010101 D106FF0BED5255D7 0000000800000000
  147. X0101010101010101 E1652C6B138C64A5 0000000400000000
  148. X0101010101010101 E428581186EC8F46 0000000200000000
  149. X0101010101010101 AEB5F5EDE22D1A36 0000000100000000
  150. X0101010101010101 E943D7568AEC0C5C 0000000080000000
  151. X0101010101010101 DF98C8276F54B04B 0000000040000000
  152. X0101010101010101 B160E4680F6C696F 0000000020000000
  153. X0101010101010101 FA0752B07D9C4AB8 0000000010000000
  154. X0101010101010101 CA3A2B036DBC8502 0000000008000000
  155. X0101010101010101 5E0905517BB59BCF 0000000004000000
  156. X0101010101010101 814EEB3B91D90726 0000000002000000
  157. X0101010101010101 4D49DB1532919C9F 0000000001000000
  158. X0101010101010101 25EB5FC3F8CF0621 0000000000800000
  159. X0101010101010101 AB6A20C0620D1C6F 0000000000400000
  160. X0101010101010101 79E90DBC98F92CCA 0000000000200000
  161. X0101010101010101 866ECEDD8072BB0E 0000000000100000
  162. X0101010101010101 8B54536F2F3E64A8 0000000000080000
  163. X0101010101010101 EA51D3975595B86B 0000000000040000
  164. X0101010101010101 CAFFC6AC4542DE31 0000000000020000
  165. X0101010101010101 8DD45A2DDF90796C 0000000000010000
  166. X0101010101010101 1029D55E880EC2D0 0000000000008000
  167. X0101010101010101 5D86CB23639DBEA9 0000000000004000
  168. X0101010101010101 1D1CA853AE7C0C5F 0000000000002000
  169. X0101010101010101 CE332329248F3228 0000000000001000
  170. X0101010101010101 8405D1ABE24FB942 0000000000000800
  171. X0101010101010101 E643D78090CA4207 0000000000000400
  172. X0101010101010101 48221B9937748A23 0000000000000200
  173. X0101010101010101 DD7C0BBD61FAFD54 0000000000000100
  174. X0101010101010101 2FBC291A570DB5C4 0000000000000080
  175. X0101010101010101 E07C30D7E4E26E12 0000000000000040
  176. X0101010101010101 0953E2258E8E90A1 0000000000000020
  177. X0101010101010101 5B711BC4CEEBF2EE 0000000000000010
  178. X0101010101010101 CC083F1E6D9E85F6 0000000000000008
  179. X0101010101010101 D2FD8867D50D2DFE 0000000000000004
  180. X0101010101010101 06E7EA22CE92708F 0000000000000002
  181. X0101010101010101 166B40B44ABA4BD6 0000000000000001
  182. X/* PC1 and PC2 test */
  183. X8001010101010101 0000000000000000 95A8D72813DAA94D
  184. X4001010101010101 0000000000000000 0EEC1487DD8C26D5
  185. X2001010101010101 0000000000000000 7AD16FFB79C45926
  186. X1001010101010101 0000000000000000 D3746294CA6A6CF3
  187. X0801010101010101 0000000000000000 809F5F873C1FD761
  188. X0401010101010101 0000000000000000 C02FAFFEC989D1FC
  189. X0201010101010101 0000000000000000 4615AA1D33E72F10
  190. X0180010101010101 0000000000000000 2055123350C00858
  191. X0140010101010101 0000000000000000 DF3B99D6577397C8
  192. X0120010101010101 0000000000000000 31FE17369B5288C9
  193. X0110010101010101 0000000000000000 DFDD3CC64DAE1642
  194. X0108010101010101 0000000000000000 178C83CE2B399D94
  195. X0104010101010101 0000000000000000 50F636324A9B7F80
  196. X0102010101010101 0000000000000000 A8468EE3BC18F06D
  197. X0101800101010101 0000000000000000 A2DC9E92FD3CDE92
  198. X0101400101010101 0000000000000000 CAC09F797D031287
  199. X0101200101010101 0000000000000000 90BA680B22AEB525
  200. X0101100101010101 0000000000000000 CE7A24F350E280B6
  201. X0101080101010101 0000000000000000 882BFF0AA01A0B87
  202. X0101040101010101 0000000000000000 25610288924511C2
  203. X0101020101010101 0000000000000000 C71516C29C75D170
  204. X0101018001010101 0000000000000000 5199C29A52C9F059
  205. X0101014001010101 0000000000000000 C22F0A294A71F29F
  206. X0101012001010101 0000000000000000 EE371483714C02EA
  207. X0101011001010101 0000000000000000 A81FBD448F9E522F
  208. X0101010801010101 0000000000000000 4F644C92E192DFED
  209. X0101010401010101 0000000000000000 1AFA9A66A6DF92AE
  210. X0101010201010101 0000000000000000 B3C1CC715CB879D8
  211. X0101010180010101 0000000000000000 19D032E64AB0BD8B
  212. X0101010140010101 0000000000000000 3CFAA7A7DC8720DC
  213. X0101010120010101 0000000000000000 B7265F7F447AC6F3
  214. X0101010110010101 0000000000000000 9DB73B3C0D163F54
  215. X0101010108010101 0000000000000000 8181B65BABF4A975
  216. X0101010104010101 0000000000000000 93C9B64042EAA240
  217. X0101010102010101 0000000000000000 5570530829705592
  218. X0101010101800101 0000000000000000 8638809E878787A0
  219. X0101010101400101 0000000000000000 41B9A79AF79AC208
  220. X0101010101200101 0000000000000000 7A9BE42F2009A892
  221. X0101010101100101 0000000000000000 29038D56BA6D2745
  222. X0101010101080101 0000000000000000 5495C6ABF1E5DF51
  223. X0101010101040101 0000000000000000 AE13DBD561488933
  224. X0101010101020101 0000000000000000 024D1FFA8904E389
  225. X0101010101018001 0000000000000000 D1399712F99BF02E
  226. X0101010101014001 0000000000000000 14C1D7C1CFFEC79E
  227. X0101010101012001 0000000000000000 1DE5279DAE3BED6F
  228. X0101010101011001 0000000000000000 E941A33F85501303
  229. X0101010101010801 0000000000000000 DA99DBBC9A03F379
  230. X0101010101010401 0000000000000000 B7FC92F91D8E92E9
  231. X0101010101010201 0000000000000000 AE8E5CAA3CA04E85
  232. X0101010101010180 0000000000000000 9CC62DF43B6EED74
  233. X0101010101010140 0000000000000000 D863DBB5C59A91A0
  234. X0101010101010120 0000000000000000 A1AB2190545B91D7
  235. X0101010101010110 0000000000000000 0875041E64C570F7
  236. X0101010101010108 0000000000000000 5A594528BEBEF1CC
  237. X0101010101010104 0000000000000000 FCDB3291DE21F0C0
  238. X0101010101010102 0000000000000000 869EFD7F9F265A09
  239. X/* P Test */
  240. X1046913489980131 0000000000000000 88D55E54F54C97B4
  241. X1007103489988020 0000000000000000 0C0CC00C83EA48FD
  242. X10071034C8980120 0000000000000000 83BC8EF3A6570183
  243. X1046103489988020 0000000000000000 DF725DCAD94EA2E9
  244. X1086911519190101 0000000000000000 E652B53B550BE8B0
  245. X1086911519580101 0000000000000000 AF527120C485CBB0
  246. X5107B01519580101 0000000000000000 0F04CE393DB926D5
  247. X1007B01519190101 0000000000000000 C9F00FFC74079067
  248. X3107915498080101 0000000000000000 7CFD82A593252B4E
  249. X3107919498080101 0000000000000000 CB49A2F9E91363E3
  250. X10079115B9080140 0000000000000000 00B588BE70D23F56
  251. X3107911598090140 0000000000000000 406A9A6AB43399AE
  252. X1007D01589980101 0000000000000000 6CB773611DCA9ADA
  253. X9107911589980101 0000000000000000 67FD21C17DBB5D70
  254. X9107D01589190101 0000000000000000 9592CB4110430787
  255. X1007D01598980120 0000000000000000 A6B7FF68A318DDD3
  256. X1007940498190101 0000000000000000 4D102196C914CA16
  257. X0107910491190401 0000000000000000 2DFA9F4573594965
  258. X0107910491190101 0000000000000000 B46604816C0E0774
  259. X0107940491190401 0000000000000000 6E7E6221A4F34E87
  260. X19079210981A0101 0000000000000000 AA85E74643233199
  261. X1007911998190801 0000000000000000 2E5A19DB4D1962D6
  262. X10079119981A0801 0000000000000000 23A866A809D30894
  263. X1007921098190101 0000000000000000 D812D961F017D320
  264. X100791159819010B 0000000000000000 055605816E58608F
  265. X1004801598190101 0000000000000000 ABD88E8B1B7716F1
  266. X1004801598190102 0000000000000000 537AC95BE69DA1E1
  267. X1004801598190108 0000000000000000 AED0F6AE3C25CDD8
  268. X1002911598100104 0000000000000000 B3E35A5EE53E7B8D
  269. X1002911598190104 0000000000000000 61C79C71921A2EF8
  270. X1002911598100201 0000000000000000 E2F5728F0995013C
  271. X1002911698100101 0000000000000000 1AEAC39A61F0A464
  272. X/* S-box test */
  273. X7CA110454A1A6E57 01A1D6D039776742 690F5B0D9A26939B
  274. X0131D9619DC1376E 5CD54CA83DEF57DA 7A389D10354BD271
  275. X07A1133E4A0B2686 0248D43806F67172 868EBB51CAB4599A
  276. X3849674C2602319E 51454B582DDF440A 7178876E01F19B2A
  277. X04B915BA43FEB5B6 42FD443059577FA2 AF37FB421F8C4095
  278. X0113B970FD34F2CE 059B5E0851CF143A 86A560F10EC6D85B
  279. X0170F175468FB5E6 0756D8E0774761D2 0CD3DA020021DC09
  280. X43297FAD38E373FE 762514B829BF486A EA676B2CB7DB2B7A
  281. X07A7137045DA2A16 3BDD119049372802 DFD64A815CAF1A0F
  282. X04689104C2FD3B2F 26955F6835AF609A 5C513C9C4886C088
  283. X37D06BB516CB7546 164D5E404F275232 0A2AEEAE3FF4AB77
  284. X1F08260D1AC2465E 6B056E18759F5CCA EF1BF03E5DFA575A
  285. X584023641ABA6176 004BD6EF09176062 88BF0DB6D70DEE56
  286. X025816164629B007 480D39006EE762F2 A1F9915541020B56
  287. X49793EBC79B3258F 437540C8698F3CFA 6FBF1CAFCFFD0556
  288. X4FB05E1515AB73A7 072D43A077075292 2F22E49BAB7CA1AC
  289. X49E95D6D4CA229BF 02FE55778117F12A 5A6B612CC26CCE4A
  290. X018310DC409B26D6 1D9D5C5018F728C2 5F4C038ED12B2E41
  291. X1C587F1C13924FEF 305532286D6F295A 63FAC0D034D9F793
  292. END_OF_des_test_data
  293. if test 8854 -ne `wc -c <des_test_data`; then
  294.     echo shar: "des_test_data" unpacked with wrong size!
  295. fi
  296. # end of overwriting check
  297. fi
  298. if test -f destest.c -a "${1}" != "-c" ; then 
  299.   echo shar: Will not over-write existing file "destest.c"
  300. else
  301. echo shar: Extracting "destest.c" (2103 characters)
  302. sed "s/^X//" >destest.c <<'END_OF_destest.c'
  303. X/*---------------------------------------------------------------------------
  304. X * destest.c
  305. X *
  306. X *
  307. X * 27-Feb-92 RP
  308. X * 06-Jan-93 RP (for libdes)
  309. X */
  310. X
  311. X#include <stdio.h>
  312. X#include <stdlib.h>
  313. X#include <string.h>
  314. X
  315. X#include "mdes.h"
  316. X
  317. X#define ctod(d) ((d) <= '9' ? (d) - '0' : (d) <= 'Z' ? (d) - ('A'-10):
  318. X  (d) - ('a' - 10))
  319. X
  320. Xint des_hex_to_cblock(des_cblock *b, char *c)
  321. X{
  322. X  int i,n,m;
  323. X  for(i = 0; i < 8; i++) {
  324. X    if((n=ctod(c[i*2])) < 0 || n > 15) return 0;
  325. X    if((m=ctod(c[i*2+1])) < 0 || m > 15) return 0;
  326. X    ((char *)b)[i] = (n<<4)|m;
  327. X  }
  328. X  return 1;
  329. X}
  330. X
  331. Xvoid des_print_cblock(des_cblock *b)
  332. X{
  333. X  int i;
  334. X  for(i = 0; i < 8; i++) printf("%02X",((unsigned char *)b)[i]);
  335. X}
  336. X
  337. Xchar linebuf[512];
  338. X
  339. Xstruct Library *ACryptBase=0;
  340. X
  341. X
  342. Xvoid main(int argc,char **argv)
  343. X{
  344. X  FILE *testdata;
  345. X  des_cblock  k,p,c,er,dr;
  346. X  des_key_schedule ks;
  347. X  int line=0,test=0,ok=1;
  348. X  char *fname;
  349. X
  350. X  if(argc<2) fname = "des_test_data";
  351. X    else fname = argv[1];
  352. X
  353. X  if(!(testdata = fopen(fname,"r"))) {
  354. X    printf("destest: can't open file %sn",fname);
  355. X    exit(5);
  356. X  }
  357. X
  358. X  while(fgets(linebuf,512,testdata))
  359. X  {
  360. X    line++;
  361. X    if(des_hex_to_cblock(&k,linebuf) &&
  362. X      des_hex_to_cblock(&p,linebuf+17) &&
  363. X      des_hex_to_cblock(&c,linebuf+34)) {
  364. X      test++;
  365. X      des_set_key(&k,&ks);
  366. X      des_ecb_encrypt(&p,&er,&ks,DES_ENCRYPT);
  367. X      des_ecb_encrypt(&c,&dr,&ks,DES_DECRYPT);
  368. X      if(memcmp(&er,&c,sizeof(des_cblock))||
  369. X        memcmp(&dr,&p,sizeof(des_cblock))) {
  370. X        printf("destest failed '%s' line %d, test %dn",
  371. X          fname,line,test);
  372. X        printf("key= ");
  373. X        des_print_cblock(&k);
  374. X        printf("n plain= ");
  375. X        des_print_cblock(&p);
  376. X        printf("n chipher= ");
  377. X        des_print_cblock(&c);
  378. X        printf("nenc= ");
  379. X        des_print_cblock(&er);
  380. X        printf("ndec= ");
  381. X        des_print_cblock(&er);
  382. X        printf("n");
  383. X        ok = 0;
  384. X        break;
  385. X      } 
  386. X    } else { 
  387. X      fputs(linebuf, stdout);
  388. X      fflush(stdout);
  389. X    }
  390. X  }
  391. X  printf("%s test with file %sn", test?(ok?"successful":"failed"):
  392. X        "nothing to",fname);
  393. X  exit(ok ? EXIT_SUCCESS : EXIT_FAILURE);
  394. X}
  395. X
  396. X
  397. END_OF_destest.c
  398. if test 2103 -ne `wc -c <destest.c`; then
  399.     echo shar: "destest.c" unpacked with wrong size!
  400. fi
  401. # end of overwriting check
  402. fi
  403. if test -f mdes.c -a "${1}" != "-c" ; then 
  404.   echo shar: Will not over-write existing file "mdes.c"
  405. else
  406. echo shar: Extracting "mdes.c" (7722 characters)
  407. sed "s/^X//" >mdes.c <<'END_OF_mdes.c'
  408. X/* mdes.c -- minimal des implementation (and very slow, too)
  409. X * Public Domain, 1993 by Risto Paasivirta, paasivir@jyu.fi
  410. X * No warranty, try with your own risk.
  411. X */
  412. X
  413. X#include <string.h>
  414. X#include "mdes.h"
  415. X
  416. X/*
  417. X * left shift table for key schedule LS
  418. X */
  419. X
  420. Xstatic const unsigned char LS[16] = {
  421. X   1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1
  422. X};
  423. X
  424. X/*
  425. X * permuted-choice tables for key schedule PC1, PC2
  426. X */
  427. X
  428. Xstatic const unsigned char PC1[56] = {
  429. X  57,49,41,33,25,17, 9, 1,58,50,42,34,26,18,10, 2,
  430. X  59,51,43,35,27,19,11, 3,60,52,44,36,63,55,47,39,
  431. X  31,23,15, 7,62,54,46,38,30,22,14, 6,61,53,45,37,
  432. X  29,21,13, 5,28,20,12, 4
  433. X};
  434. X
  435. Xstatic const unsigned char PC2[48] = {
  436. X  14,17,11,24, 1, 5, 3,28,15, 6,21,10,23,19,12, 4,
  437. X  26, 8,16, 7,27,20,13, 2,41,52,31,37,47,55,30,40,
  438. X  51,45,33,48,44,49,39,56,34,53,46,42,50,36,29,32
  439. X};
  440. X
  441. X/*
  442. X * initial permutation IP
  443. X */
  444. X
  445. Xstatic const unsigned char IP[64] = {
  446. X  58,50,42,34,26,18,10, 2,60,52,44,36,28,20,12, 4,
  447. X  62,54,46,38,30,22,14, 6,64,56,48,40,32,24,16, 8,
  448. X  57,49,41,33,25,17, 9, 1,59,51,43,35,27,19,11, 3,
  449. X  61,53,45,37,29,21,13, 5,63,55,47,39,31,23,15, 7
  450. X};
  451. X
  452. X/*
  453. X * bit-selection table E
  454. X */
  455. X
  456. Xstatic const unsigned char E[48] = {
  457. X  32, 1, 2, 3, 4, 5, 4, 5, 6, 7, 8, 9, 8, 9,10,11,
  458. X  12,13,12,13,14,15,16,17,16,17,18,19,20,21,20,21,
  459. X  22,23,24,25,24,25,26,27,28,29,28,29,30,31,32, 1
  460. X};
  461. X
  462. X/*
  463. X * substitution tables ST
  464. X */
  465. X
  466. Xstatic const unsigned char ST[8][64] = {
  467. X  14, 4,13, 1, 2,15,11, 8, 3,10, 6,12, 5, 9, 0, 7,
  468. X   0,15, 7, 4,14, 2,13, 1,10, 6,12,11, 9, 5, 3, 8,
  469. X   4, 1,14, 8,13, 6, 2,11,15,12, 9, 7, 3,10, 5, 0,
  470. X  15,12, 8, 2, 4, 9, 1, 7, 5,11, 3,14,10, 0, 6,13,
  471. X
  472. X  15, 1, 8,14, 6,11, 3, 4, 9, 7, 2,13,12, 0, 5,10,
  473. X   3,13, 4, 7,15, 2, 8,14,12, 0, 1,10, 6, 9,11, 5,
  474. X   0,14, 7,11,10, 4,13, 1, 5, 8,12, 6, 9, 3, 2,15,
  475. X  13, 8,10, 1, 3,15, 4, 2,11, 6, 7,12, 0, 5,14, 9,
  476. X
  477. X  10, 0, 9,14, 6, 3,15, 5, 1,13,12, 7,11, 4, 2, 8,
  478. X  13, 7, 0, 9, 3, 4, 6,10, 2, 8, 5,14,12,11,15, 1,
  479. X  13, 6, 4, 9, 8,15, 3, 0,11, 1, 2,12, 5,10,14, 7,
  480. X   1,10,13, 0, 6, 9, 8, 7, 4,15,14, 3,11, 5, 2,12,
  481. X
  482. X   7,13,14, 3, 0, 6, 9,10, 1, 2, 8, 5,11,12, 4,15,
  483. X  13, 8,11, 5, 6,15, 0, 3, 4, 7, 2,12, 1,10,14, 9,
  484. X  10, 6, 9, 0,12,11, 7,13,15, 1, 3,14, 5, 2, 8, 4,
  485. X   3,15, 0, 6,10, 1,13, 8, 9, 4, 5,11,12, 7, 2,14,
  486. X
  487. X   2,12, 4, 1, 7,10,11, 6, 8, 5, 3,15,13, 0,14, 9,
  488. X  14,11, 2,12, 4, 7,13, 1, 5, 0,15,10, 3, 9, 8, 6,
  489. X   4, 2, 1,11,10,13, 7, 8,15, 9,12, 5, 6, 3, 0,14,
  490. X  11, 8,12, 7, 1,14, 2,13, 6,15, 0, 9,10, 4, 5, 3,
  491. X
  492. X  12, 1,10,15, 9, 2, 6, 8, 0,13, 3, 4,14, 7, 5,11,
  493. X  10,15, 4, 2, 7,12, 9, 5, 6, 1,13,14, 0,11, 3, 8,
  494. X   9,14,15, 5, 2, 8,12, 3, 7, 0, 4,10, 1,13,11, 6,
  495. X   4, 3, 2,12, 9, 5,15,10,11,14, 1, 7, 6, 0, 8,13,
  496. X
  497. X   4,11, 2,14,15, 0, 8,13, 3,12, 9, 7, 5,10, 6, 1,
  498. X  13, 0,11, 7, 4, 9, 1,10,14, 3, 5,12, 2,15, 8, 6,
  499. X   1, 4,11,13,12, 3, 7,14,10,15, 6, 8, 0, 5, 9, 2,
  500. X   6,11,13, 8, 1, 4,10, 7, 9, 5, 0,15,14, 2, 3,12,
  501. X
  502. X  13, 2, 8, 4, 6,15,11, 1,10, 9, 3,14, 5, 0,12, 7,
  503. X   1,15,13, 8,10, 3, 7, 4,12, 5, 6,11, 0,14, 9, 2,
  504. X   7,11, 4, 1, 9,12,14, 2, 0, 6,10,13,15, 3, 5, 8,
  505. X   2, 1,14, 7, 4,10, 8,13,15,12, 9, 0, 3, 5, 6,11
  506. X};
  507. X
  508. X/*
  509. X * permutation table P
  510. X */
  511. X
  512. Xstatic const unsigned char P[32] = {
  513. X  16, 7,20,21,29,12,28,17, 1,15,23,26, 5,18,31,10,
  514. X   2, 8,24,14,32,27, 3, 9,19,13,30, 6,22,11, 4,25
  515. X};
  516. X
  517. X/*
  518. X * final permutation FP
  519. X */
  520. X
  521. Xstatic const unsigned char FP[64] = {
  522. X  40, 8,48,16,56,24,64,32,39, 7,47,15,55,23,63,31,
  523. X  38, 6,46,14,54,22,62,30,37, 5,45,13,53,21,61,29,
  524. X  36, 4,44,12,52,20,60,28,35, 3,43,11,51,19,59,27,
  525. X  34, 2,42,10,50,18,58,26,33, 1,41, 9,49,17,57,25
  526. X};
  527. X
  528. X/*
  529. X * unbit(to, from, len) -- unpack len bytes to bits
  530. X */
  531. X
  532. Xstatic void
  533. Xunbit(unsigned char *to,unsigned char *from,int len)
  534. X{
  535. X  int j, f;
  536. X
  537. X  while (len--) {
  538. X    for (j = 8, f = *from++; j--;)
  539. X      *to++ =  (f >> j) & 1;
  540. X  }
  541. X}
  542. X
  543. X/*
  544. X * pkbit(to from, len) -- pack bits to len bytes 
  545. X */
  546. X
  547. Xstatic void
  548. Xpkbit(unsigned char *to, unsigned char *from, int len)
  549. X{
  550. X  int j,t;
  551. X
  552. X  while (len--) {
  553. X    for (j = 8, t = 0; j--;)
  554. X      t |= *from++ << j;
  555. X    *to++ = t;
  556. X  }
  557. X}
  558. X
  559. X/*
  560. X * perm(to, OP, from, bits) -- do permutation
  561. X */
  562. X
  563. Xstatic void
  564. Xperm(unsigned char *to, const unsigned char *op,
  565. X  unsigned char *from, int bits)
  566. X{
  567. X  int i;
  568. X
  569. X  for (i = 0; i < bits; i++)
  570. X    to[i] = from[op[i]-1];
  571. X}
  572. X
  573. X/*
  574. X * rot(to, from, len, bits) -- rotate left
  575. X */
  576. X
  577. Xstatic void
  578. Xrot(unsigned char *r, int len, int bits)
  579. X{
  580. X  int i,t;
  581. X
  582. X  if (len > 1) {
  583. X    for (i = 0; i<bits; i++) {
  584. X      t = r[0];
  585. X      memmove(&r[0], &r[1], len - 1);
  586. X      r[len-1] = t;
  587. X    }
  588. X  }
  589. X}
  590. X
  591. X/*
  592. X * add2(to, from, bits) -- add bits modulo 2 (that is, eor)
  593. X */
  594. X
  595. Xstatic void
  596. Xadd2(unsigned char *to, unsigned char *from, int bits)
  597. X{
  598. X  int i;
  599. X
  600. X  for (i=0; i<bits; i++)
  601. X    to[i] ^= from[i];
  602. X}
  603. X
  604. X/*
  605. X * subs(o,i,s) -- substitute 6 bits to 4 bits using ST[s]
  606. X */
  607. X
  608. Xstatic void
  609. Xsubs(unsigned char *o, unsigned char *i, int s) 
  610. X{
  611. X  int t;
  612. X
  613. X  t = ST[s][
  614. X    (i[0] << 5) | (i[5] << 4) | /* 1st and 6th bit, row index */
  615. X    (i[1] << 3) | (i[2] << 2) | /* 2nd to 5th bit, col index */
  616. X    (i[3] << 1) |  i[4]];
  617. X  o[0] = (t >> 3) & 1;
  618. X  o[1] = (t >> 2) & 1;
  619. X  o[2] = (t >> 1) & 1;
  620. X  o[3] =  t & 1;
  621. X}
  622. X
  623. X/*
  624. X * des_set_key(key,ks) -- generate a keyschedule
  625. X */
  626. X
  627. Xint
  628. Xdes_set_key(des_cblock *key, des_key_schedule *ks)
  629. X{
  630. X  int i;
  631. X  unsigned char k[64],cd[56];
  632. X
  633. X  unbit(k,(char *)key,8);
  634. X  perm(cd, PC1, k, 56);
  635. X  for (i = 0; i < 16; i++) {
  636. X    rot(&cd[0], 28, LS[i]);
  637. X    rot(&cd[28], 28, LS[i]);
  638. X    perm(ks->b[i], PC2, cd, 48);
  639. X  }
  640. X  return 1;
  641. X}
  642. X
  643. X/*
  644. X * des_func(in,out,ks) -- des core function
  645. X */
  646. X
  647. Xstatic void
  648. Xdes_func(unsigned char in[64], unsigned char out[64],
  649. X  unsigned char b[16][48], int enc)
  650. X{
  651. X  int i,j;
  652. X  unsigned char lr[64], rsto[32], si[48], so[32];
  653. X#define LEFT  lr
  654. X#define RIGHT  &lr[32]
  655. X
  656. X  perm(lr, IP, in, 64); /* initial permutation */
  657. X  for (i = 0; i < 16; i++) { /* 16 rounds */
  658. X    memcpy(rsto, RIGHT,32); /* store right part */
  659. X    perm(si, E, RIGHT, 48); /* F-box: permute to subst. input */
  660. X    add2(si, b[enc ? i : 15-i], 48); /* add key (enc/dec order) */
  661. X    for (j = 0; j < 8; j++) /* 48 to 32 bit substitute */
  662. X      subs(&so[j*4],&si[j*6],j);
  663. X    perm(RIGHT, P, so, 32); /* permute substitution output: end F*/
  664. X    add2(RIGHT, LEFT, 32); /* add left part */
  665. X        memcpy(LEFT, rsto, 32); /* old right part will be new left */
  666. X  }
  667. X  memcpy(LEFT, RIGHT, 32); /* swap left and right part */
  668. X  memcpy(RIGHT,rsto, 32);
  669. X  perm(out,FP,lr,64); /* final permutation */
  670. X}
  671. X
  672. X/*
  673. X * des_ecb_encrypt(in, out, ks, enc) -- des electronic code book mode
  674. X */
  675. X
  676. Xint
  677. Xdes_ecb_encrypt(des_cblock *in, des_cblock *out,
  678. X  des_key_schedule *ks, int enc)
  679. X{
  680. X  unsigned char o[64];
  681. X
  682. X  unbit(o, (char *)in, 8);
  683. X  des_func(o, o, ks->b, enc);
  684. X  pkbit((char *)out, o, 8);
  685. X  return 8;
  686. X}
  687. X
  688. X/*
  689. X * des_cbc_encrypt(in, out, len, ks, iv, enc) -- cipher block chaining mode
  690. X */
  691. X
  692. Xint
  693. Xdes_cbc_encrypt(des_cblock *in, des_cblock *out,
  694. X  int len, des_key_schedule *ks, des_cblock *iv, int enc)
  695. X{
  696. X  int i;
  697. X  unsigned char ivb[64], ob[64], ib[64];
  698. X
  699. X  unbit(ivb,(char *)iv,8);
  700. X  for (i = 0; i < len-8; i+=8) {
  701. X    unbit(ib,(char *)in++,8);
  702. X    if (enc)
  703. X      add2(ib, ivb, 64);
  704. X    des_func(ib, ob, ks->b, enc);
  705. X    if (enc) {
  706. X      memcpy(ivb, ob, 64);
  707. X    } else {
  708. X      add2(ob, ivb, 64);
  709. X      memcpy(ivb, ib, 64);
  710. X    }
  711. X    pkbit((char *)out++, ob, 8);
  712. X  }
  713. X  memset(ib,0,64); /* pad with zeroes */
  714. X  unbit(ib,(char *)in,len-i);
  715. X  if (enc)
  716. X    add2(ib, ivb, 64);
  717. X  des_func(ib, ob, ks->b, enc);
  718. X  if (enc) {
  719. X    pkbit((char *)iv, ob, 64);
  720. X  } else {
  721. X    add2(ob, ivb, 64);
  722. X    pkbit((char *)iv, ib, 64);
  723. X  }
  724. X  pkbit((char *)out, ob, 8);
  725. X  return (i+8);
  726. X}
  727. X
  728. Xvoid
  729. Xdes_set_odd_parity(des_cblock *key)
  730. X{
  731. X  int i;
  732. X  unsigned char c;
  733. X
  734. X  for (i = 0; i < 8; i++) {
  735. X    c = key->_[i] & 0xfe;
  736. X    c = (c >> 4) ^ (c & 0x0f);
  737. X    c = (c >> 2) ^ (c & 3);
  738. X    key->_[i] = (key->_[i] & 0xfe) |
  739. X      ((c >> 1) ^ (c & 1)) ^ 1 ;
  740. X  }
  741. X}
  742. X
  743. END_OF_mdes.c
  744. if test 7722 -ne `wc -c <mdes.c`; then
  745.     echo shar: "mdes.c" unpacked with wrong size!
  746. fi
  747. # end of overwriting check
  748. fi
  749. if test -f mdes.h -a "${1}" != "-c" ; then 
  750.   echo shar: Will not over-write existing file "mdes.h"
  751. else
  752. echo shar: Extracting "mdes.h" (747 characters)
  753. sed "s/^X//" >mdes.h <<'END_OF_mdes.h'
  754. X/*
  755. X * mdes.h -- header for minimal des
  756. X * 1993 Risto Paasivirta, paasivir@jyu.fi
  757. X * Public Domain, no warranty. 
  758. X */
  759. X
  760. X#ifndef MDES_H
  761. X#define MDES_H
  762. X
  763. X#define DES_ENCRYPT  1
  764. X#define DES_DECRYPT  0
  765. X
  766. Xtypedef struct des_key_schedule {
  767. X  unsigned char b[16][48];
  768. X} des_key_schedule;
  769. X
  770. Xtypedef struct des_cblock {
  771. X  unsigned char _[8];
  772. X} des_cblock;
  773. X
  774. Xvoid des_string_to_key(char *str, des_cblock *key);
  775. Xvoid des_set_odd_parity(des_cblock *key);
  776. X
  777. Xint des_set_key(des_cblock *k, des_key_schedule *key);
  778. Xint des_ecb_encrypt(des_cblock *input, des_cblock *output,
  779. X  des_key_schedule *schedule, int mode);
  780. Xint des_cbc_encrypt(des_cblock *input, des_cblock *output,
  781. X  int length, des_key_schedule *schedule,
  782. X  des_cblock *ivec, int mode);
  783. X
  784. X#endif /* MDES_H */
  785. X
  786. END_OF_mdes.h
  787. if test 747 -ne `wc -c <mdes.h`; then
  788.     echo shar: "mdes.h" unpacked with wrong size!
  789. fi
  790. # end of overwriting check
  791. fi
  792. echo shar: End of shell archive.
  793. exit 0
  794. -- 
  795. /*paasivir@jyu.fi*/int a[3302],b=3301,*c=a,d,e,f;main(){for(e=b;--e;*c++=1);*c
  796. =2;for(d=2001;d--;printf("%05d",f))for(c=a,e=b;e;f/=e--){f+=*c*1e5;*c++=f%e;}}