See ChangeLog: Tue Oct 26 14:10:21 CEST 1999 Werner Koch
[gnupg.git] / cipher / ChangeLog
1 Tue Oct 26 14:10:21 CEST 1999  Werner Koch  <wk@gnupg.de>
2
3         * elgamal.c (sign): Hugh found strange code here. Replaced by BUG().
4
5         * cipher.c: Merged with gcrypt/symapi.c.
6
7         * pubkey.c (string_to_pubkey_algo): Renamed function to ...
8         (gcry_pk_map_name): ... this.
9         (pubkey_algo_to_string): Renamed function to ...
10         (gcry_pk_algo_name): ... this.
11         (gcry_pk_algo_info): New.
12         * pubkey.c: Merged with gcrypt/pkapi.c.
13
14         * md.c (md_reset): Clear finalized; thanks to Ulf Moeller for
15         fixing this bug.
16
17         * md.c: Merged with gcrypt/mdapi.c
18
19 Wed Sep 15 14:39:59 CEST 1999  Michael Roth <mroth@nessie.de>
20
21         * des.c: Various speed improvements: One bit pre rotation
22           trick after initial permutation (Richard Outerbridge).
23           Finished test of SSLeay Tripple-DES patterns.
24
25 Wed Sep 15 16:22:17 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
26
27         * rndw32.c: New.
28
29 Mon Sep 13 10:51:29 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
30
31         * bithelp.h: New.
32         * rmd160.h, sha1.h, md5.h: Use the rol macro from bithelp.h
33
34 Tue Sep  7 16:23:36 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
35
36         * Makefile.am: Fixed seds for latest egcc. By Ollivier Robert.
37
38 Mon Sep  6 19:59:08 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
39
40         * des.c (selftest): Add some testpattern
41
42 Mon Aug 30 20:38:33 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
43
44         * cipher.c (do_cbc_encrypt): Fixed serious bug occuring when not using
45         in place encryption. Pointed out by Frank Stajano.
46
47 Mon Jul 26 09:34:46 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
48
49         * md5.c (md5_final): Fix for a SCO cpp bug.
50
51 Thu Jul 15 10:15:35 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
52
53         * elgamal.c (elg_check_secret_key,elg_encrypt
54         elg_decrypt,elg_sign,elg_verify): Sanity check on the args.
55         * dsa.c (dsa_check_secret_key,dsa_sign,dsa_verify): Ditto.
56
57         * pubkey.c (disable_pubkey_algo): New.
58         (check_pubkey_algo2): Look at disabled algo table.
59         * cipher.c (disable_cipher_algo): New.
60         (check_cipher_algo): Look at disabled algo table.
61
62 Wed Jul  7 13:08:40 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
63
64         * Makefile.am: Support for libtool.
65
66 Fri Jul  2 11:45:54 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
67
68         * dsa.c (gen_k): Changed algorithm to consume less random bytes
69         * elgamal.c (gen_k): Ditto.
70
71         * random.c (random_dump_stats): New.
72
73 Thu Jul  1 12:47:31 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
74
75         * primegen.c, elgamal.c, dsa.c (progess): New and replaced all
76         fputc with a call to this function.
77
78 Sat Jun 26 12:15:59 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
79
80         * rndegd.c (do_write): s/ssize_t/int/ due to SunOS 4.1 probs.
81
82         * cipher.c (do_cbc_encrypt, do_cbc_decrypt): New.
83
84         * dynload.c (HAVE_DL_SHL_LOAD): Map hpux API to dlopen (Dave Dykstra).
85         * Makefile.am (install-exec-hook): Removed.
86
87 Sun May 23 14:20:22 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
88
89         * cipher.c (setup_cipher_table): Enable Twofish
90
91         * random.c (fast_random_poll): Disable use of times() for mingw32.
92
93 Mon May 17 21:54:43 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
94
95         * dynload.c (register_internal_cipher_extension): Minor init fix.
96
97 Tue May  4 15:47:53 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
98
99         * primegen.c (gen_prime): Readded the Fermat test. Fixed the bug
100         that we didn't correct for step when passing the prime to the
101         Rabin-Miller test which led to bad performance (Stefan Keller).
102         (check_prime): Add a first Fermat test.
103
104 Sun Apr 18 10:11:28 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
105
106         * cipher.c (cipher_setiv): Add ivlen arg, changed all callers.
107
108         * random.c (randomize_buffer): alway use secure memory because
109         we can't use m_is_secure() on a statically allocated buffer.
110
111         * twofish.c: Replaced some macros by a loop to reduce text size.
112         * Makefile.am (twofish): No more need for sed editing.
113
114 Fri Apr  9 12:26:25 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
115
116         * cipher.c (cipher_open): Reversed the changes for AUTO_CFB.
117
118         * blowfish.c: Dropped the Blowfish 160 mode.
119         * cipher.c (cipher_open): Ditto.
120         (setup_cipher_table): Ditto.  And removed support of twofish128
121
122 Wed Apr  7 20:51:39 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
123
124         * random.c (get_random_bits): Can now handle requests > POOLSIZE
125
126         * cipher.c (cipher_open): Now uses standard CFB for automode if
127         the blocksize is gt 8 (according to rfc2440).
128
129         * twofish.c: Applied Matthew Skala's patches for 256 bit key.
130
131 Tue Apr  6 19:58:12 CEST 1999  Werner Koch  <wk@isil.d.shuttle.de>
132
133         * random.c (get_random_bits): Can now handle requests > POOLSIZE
134
135         * cipher.c (cipher_open): Now uses standard CFB for automode if
136         the blocksize is gt 8 (according to rfc2440).
137
138 Sat Mar 20 11:44:21 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
139
140         * rndlinux.c (tty_printf) [IS_MODULE]: Removed.
141
142         * rndegd.c (gather_random): Some fixes.
143
144 Wed Mar 17 13:09:03 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
145
146         * rndegd.c (do_read): New.
147         (gather_random): Changed the implementation.
148
149 Mon Mar  8 20:47:17 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
150
151         * dynload.c (DLSYM_NEEDS_UNDERSCORE): Renamed.
152
153 Fri Feb 26 17:55:41 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
154
155         * md.c: Nearly a total rewrote.
156
157 Wed Feb 24 11:07:27 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
158
159         * cipher.c (context): Fixed alignment
160         * md.c: Ditto.
161
162         * rndegd.c: New
163
164 Mon Feb 22 20:04:00 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
165
166         * rndegd.c: New.
167
168 Wed Feb 10 17:15:39 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
169
170         * Makefile.am: Modules are now figured out by configure
171         * construct.c: New. Generated by configure. Changed all modules
172         to work with that.
173         * sha1.h: Removed.
174         * md5.h: Removed.
175
176         * twofish.c: Changed interface to allow Twofish/256
177
178         * rndunix.c (start_gatherer): Die on SIGPIPE.
179
180 Wed Jan 20 18:59:49 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
181
182         * rndunix.c (gather_random): Fix to avoid infinite loop.
183
184 Sun Jan 17 11:04:33 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
185
186         * des.c (is_weak_key): Replace system memcmp due to bugs
187         in SunOS's memcmp.
188         (des_get_info): Return error on failed selftest.
189         * twofish.c (twofish_setkey): Return error on failed selftest or
190         invalid keylength.
191         * cast5.c (cast_setkey): Ditto.
192         * blowfish.c (bf_setkey): Return error on failed selftest.
193
194 Tue Jan 12 11:17:18 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
195
196         * random.c (random_is_faked): New.
197
198         * tiger.c: Only compile if we have the u64 type
199
200 Sat Jan  9 16:02:23 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
201
202         * rndunix.c (gather_random): check for setuid.
203
204         * Makefile.am: Add a way to staically link random modules
205
206 Thu Jan  7 18:00:58 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
207
208         * md.c (md_stop_debug): Do a flush first.
209         (md_open): size of buffer now depends on the secure parameter
210
211 Sun Jan  3 15:28:44 CET 1999  Werner Koch  <wk@isil.d.shuttle.de>
212
213         * rndunix.c (start_gatherer): Fixed stupid ==/= bug
214
215 1998-12-31  Geoff Keating  <geoffk@ozemail.com.au>
216
217         * des.c (is_weak_key): Rewrite loop end condition.
218
219 Tue Dec 29 14:41:47 CET 1998  Werner Koch  <wk@isil.d.shuttle.de>
220
221         * random.c: add unistd.h for getpid().
222         (RAND_MAX): Fallback value for Sun.
223
224 Wed Dec 23 17:12:24 CET 1998  Werner Koch  <wk@isil.d.shuttle.de>
225
226         * md.c (md_copy): Reset debug.
227
228 Mon Dec 14 21:18:49 CET 1998  Werner Koch  <wk@isil.d.shuttle.de>
229
230         * random.c (read_random_source): Changed the interface to the
231         random gathering function.
232         (gather_faked): Use new interface.
233         * dynload.c (dynload_getfnc_fast_random_poll): Ditto.
234         (dynload_getfnc_gather_random): Ditto.
235         * rndlinux.c (gather_random): Ditto.
236         * rndunix.c (gather_random): Ditto.
237
238 Sat Dec 12 18:40:32 CET 1998  Werner Koch  <wk@isil.d.shuttle.de>
239
240         * dynload.c (SYMBOL_VERSION): New to cope with system which needs
241         underscores.
242
243         * rndunix.c: Rewrote large parts
244
245 Thu Dec 10 20:15:36 CET 1998  Werner Koch  <wk@isil.d.shuttle.de>
246
247         * dynload.c (load_extension): increased needed verbosity level.
248
249         * random.c (fast_random_poll): Fallback to a default fast random
250         poll function.
251         (read_random_source): Always use the faked entroy gatherer if no
252         gather module is available.
253         * rndlinux.c (fast_poll): Removed.
254         * rndunix.c (fast_poll): Removed.
255
256
257 Wed Nov 25 12:33:41 1998  Werner Koch  (wk@isil.d.shuttle.de)
258
259         * rand-*.c: Removed.
260         * rndlinux.c : New.
261         * rndunix.c : New.
262         * random.c : Restructured the interface to the gather modules.
263         (intialize): Call constructor functions
264         (read_radnom_source): Moved to here.
265         * dynload.c (dynload_getfnc_gather_random): New.
266         (dynload_getfnc_fast_random_poll): New.
267         (register_internal_cipher_extension): New.
268         (register_cipher_extension): Support of internal modules.
269
270 Sun Nov  8 17:44:36 1998  Werner Koch  (wk@isil.d.shuttle.de)
271
272         * rand-unix.c (read_random_source): Removed the assert.
273
274 Mon Oct 19 18:34:30 1998  me,,,  (wk@tobold)
275
276         * pubkey.c: Hack to allow us to give some info about RSA keys back.
277
278 Thu Oct 15 11:47:57 1998  Werner Koch  (wk@isil.d.shuttle.de)
279
280         * dynload.c: Support for DLD
281
282 Wed Oct 14 12:13:07 1998  Werner Koch  (wk@isil.d.shuttle.de)
283
284         * rand-unix.c: Now uses names from configure for /dev/random.
285
286 1998-10-10  SL Baur  <steve@altair.xemacs.org>
287
288         * Makefile.am: fix sed -O substitutions to catch -O6, etc.
289
290 Tue Oct  6 10:06:32 1998  Werner Koch  (wk@isil.d.shuttle.de)
291
292         * rand-unix.c (HAVE_GETTIMEOFDAY): Fixed (was ..GETTIMEOFTIME :-)
293         * rand-dummy.c (HAVE_GETTIMEOFDAY): Ditto.
294
295 Mon Sep 28 13:23:09 1998  Werner Koch  (wk@isil.d.shuttle.de)
296
297         * md.c (md_digest): New.
298         (md_reset): New.
299
300 Wed Sep 23 12:27:02 1998  Werner Koch  (wk@isil.d.shuttle.de)
301
302         * tiger.c (TIGER_CONTEXT): moved "buf", so that it is 64 bit aligned.
303
304 Mon Sep 21 06:22:53 1998  Werner Koch  (wk@(none))
305
306         * des.c: Some patches from Michael.
307
308 Thu Sep 17 19:00:06 1998  Werner Koch  (wk@(none))
309
310         * des.c : New file from Michael Roth <mroth@nessie.de>
311
312 Mon Sep 14 11:10:55 1998  Werner Koch  (wk@(none))
313
314         * blowfish.c (bf_setkey): Niklas Hernaeus patch to detect weak keys.
315
316 Mon Sep 14 09:19:25 1998  Werner Koch  (wk@(none))
317
318         * dynload.c (RTLD_NOW): Now defined to 1 if it is undefined.
319
320 Mon Sep  7 17:04:33 1998  Werner Koch  (wk@(none))
321
322         * Makefile.am: Fixes to allow a different build directory
323
324 Thu Aug  6 17:25:38 1998  Werner Koch,mobil,,,  (wk@tobold)
325
326         * random.c (get_random_byte): Removed and changed all callers
327         to use get_random_bits()
328
329 Mon Jul 27 10:30:22 1998  Werner Koch  (wk@(none))
330
331         * cipher.c : Support for other blocksizes
332         (cipher_get_blocksize): New.
333         * twofish.c: New.
334         * Makefile.am: Add twofish module.
335
336 Mon Jul 13 21:30:52 1998  Werner Koch  (wk@isil.d.shuttle.de)
337
338         * random.c (read_pool): Simple alloc if secure_alloc is not set.
339         (get_random_bits): Ditto.
340
341 Thu Jul  9 13:01:14 1998  Werner Koch  (wk@isil.d.shuttle.de)
342
343         * dynload.c (load_extension): Function now nbails out if
344         the program is run setuid.
345
346 Wed Jul  8 18:58:23 1998  Werner Koch  (wk@isil.d.shuttle.de)
347
348         * rmd160.c (rmd160_hash_buffer): New.
349
350 Thu Jul  2 10:50:30 1998  Werner Koch  (wk@isil.d.shuttle.de)
351
352         * cipher.c (cipher_open): algos >=100 use standard CFB
353
354 Thu Jun 25 11:18:25 1998  Werner Koch  (wk@isil.d.shuttle.de)
355
356         * Makefile.am: Support for extensions
357
358 Thu Jun 18 12:09:38 1998  Werner Koch  (wk@isil.d.shuttle.de)
359
360         * random.c (mix_pool): simpler handling for level 0
361
362 Mon Jun 15 14:40:48 1998  Werner Koch  (wk@isil.d.shuttle.de)
363
364         * tiger.c: Removed from dist, will reappear as dynload module
365
366 Sat Jun 13 14:16:57 1998  Werner Koch  (wk@isil.d.shuttle.de)
367
368         * pubkey.c: Major changes to allow extensions. Changed the inteface
369         of all public key ciphers and added the ability to load extensions
370         on demand.
371
372         * misc.c: Removed.
373
374 Wed Jun 10 07:52:08 1998  Werner Koch,mobil,,,  (wk@tobold)
375
376         * dynload.c: New.
377         * cipher.c: Major changes to allow extensions.
378
379 Mon Jun  8 22:43:00 1998  Werner Koch  (wk@isil.d.shuttle.de)
380
381         * cipher.c: Major internal chnages to support extensions.
382         * blowfish.c (blowfish_get_info): New and made all internal
383         functions static, changed heder.
384         * cast5.c (cast5_get_info): Likewise.
385
386 Mon Jun  8 12:27:52 1998  Werner Koch  (wk@isil.d.shuttle.de)
387
388         * tiger.c (transform): Fix for big endian
389
390         * cipher.c (do_cfb_decrypt): Big endian fix.
391
392 Fri May 22 07:30:39 1998  Werner Koch  (wk@isil.d.shuttle.de)
393
394         * md.c (md_get_oid): Add a new one for TIGER.
395
396 Thu May 21 13:24:52 1998  Werner Koch  (wk@isil.d.shuttle.de)
397
398         * cipher.c: Add support for a dummy cipher
399
400 Thu May 14 15:40:36 1998  Werner Koch  (wk@isil.d.shuttle.de)
401
402         * rmd160.c (transform): fixed sigbus - I should better
403         add Christian von Roques's new implemenation of rmd160_write.
404
405 Fri May  8 18:07:44 1998  Werner Koch  (wk@isil.d.shuttle.de)
406
407         * rand-internal.h, rand-unix.c, rand-w32.c, rand_dummy.c: New
408         * random.c: Moved system specific functions to rand-****.c
409
410 Fri May  8 14:01:17 1998  Werner Koch  (wk@isil.d.shuttle.de)
411
412         * random.c (fast_random_poll): add call to gethrtime.
413
414 Tue May  5 21:28:55 1998  Werner Koch  (wk@isil.d.shuttle.de)
415
416         * elgamal.c (elg_generate): choosing x was not correct, could
417         yield 6 bytes which are not from the random pool, tsss, tsss..
418
419 Tue May  5 14:09:06 1998  Werner Koch  (wk@isil.d.shuttle.de)
420
421         * primegen.c (generate_elg_prime): Add arg mode, changed all
422         callers and implemented mode 1.
423
424 Mon Apr 27 14:41:58 1998  Werner Koch  (wk@isil.d.shuttle.de)
425
426         * cipher.c (cipher_get_keylen): New.
427
428 Sun Apr 26 14:44:52 1998  Werner Koch  (wk@isil.d.shuttle.de)
429
430         * tiger.c, tiger.h: New.
431
432 Wed Apr  8 14:57:11 1998  Werner Koch  (wk@isil.d.shuttle.de)
433
434         * misc.c (check_pubkey_algo2): New.
435
436 Tue Apr  7 18:46:49 1998  Werner Koch  (wk@isil.d.shuttle.de)
437
438         * cipher.c: New
439         * misc.c (check_cipher_algo): Moved to cipher.c
440         * cast5.c: Moved many functions to cipher.c
441         * blowfish.c: Likewise.
442
443 Sat Apr  4 19:52:08 1998  Werner Koch  (wk@isil.d.shuttle.de)
444
445         * cast5.c: Implemented and tested.
446
447 Wed Apr  1 16:38:27 1998  Werner Koch  (wk@isil.d.shuttle.de)
448
449         * elgamal.c (elg_generate): Faster generation of x in some cases.
450
451 Thu Mar 19 13:54:48 1998  Werner Koch  (wk@isil.d.shuttle.de)
452
453         * blowfish.c (blowfish_decode_cfb): changed XOR operation
454         (blowfish_encode_cfb): Ditto.
455
456 Thu Mar 12 14:04:05 1998  Werner Koch  (wk@isil.d.shuttle.de)
457
458         * sha1.c (transform): Rewrote
459
460         * blowfish.c (encrypt): Unrolled for rounds == 16
461         (decrypt): Ditto.
462
463 Tue Mar 10 16:32:08 1998  Werner Koch  (wk@isil.d.shuttle.de)
464
465         * rmd160.c (transform): Unrolled the loop.
466
467 Tue Mar 10 13:05:14 1998  Werner Koch  (wk@isil.d.shuttle.de)
468
469         * random.c (read_pool): Add pool_balance stuff.
470         (get_random_bits): New.
471
472         * elgamal.c (elg_generate): Now uses get_random_bits to generate x.
473
474
475 Tue Mar 10 11:33:51 1998  Werner Koch  (wk@isil.d.shuttle.de)
476
477         * md.c (md_digest_length): New.
478
479 Tue Mar 10 11:27:41 1998  Werner Koch  (wk@isil.d.shuttle.de)
480
481         * dsa.c (dsa_verify): Works.
482
483 Mon Mar  9 12:59:08 1998  Werner Koch  (wk@isil.d.shuttle.de)
484
485         * dsa.c, dsa.h: Removed some unused code.
486
487 Wed Mar  4 10:39:22 1998  Werner Koch  (wk@isil.d.shuttle.de)
488
489         * md.c (md_open): Add call to fast_random_poll.
490         blowfish.c (blowfish_setkey): Ditto.
491
492 Tue Mar  3 13:32:54 1998  Werner Koch  (wk@isil.d.shuttle.de)
493
494         * rmd160.c (rmd160_mixblock): New.
495         * random.c: Restructured to start with a new RNG implementation.
496         * random.h: New.
497
498 Mon Mar  2 19:21:46 1998  Werner Koch  (wk@isil.d.shuttle.de)
499
500         * gost.c, gost.h: Removed because they did only conatin trash.
501
502 Sun Mar  1 16:42:29 1998  Werner Koch  (wk@isil.d.shuttle.de)
503
504         * random.c (fill_buffer): removed error message if n == -1.
505
506 Fri Feb 27 16:39:34 1998  Werner Koch  (wk@isil.d.shuttle.de)
507
508         * md.c (md_enable): No init if called twice.
509
510 Thu Feb 26 07:57:02 1998  Werner Koch  (wk@isil.d.shuttle.de)
511
512         * primegen.c (generate_elg_prime): Changed the progress printing.
513         (gen_prime): Ditto.
514
515 Tue Feb 24 12:28:42 1998  Werner Koch  (wk@isil.d.shuttle.de)
516
517         * md5.c, md.5 : Replaced by a modified version of md5.c from
518         GNU textutils 1.22.
519
520 Wed Feb 18 14:08:30 1998  Werner Koch  (wk@isil.d.shuttle.de)
521
522         * md.c, md.h : New debugging support
523
524 Mon Feb 16 10:08:47 1998  Werner Koch  (wk@isil.d.shuttle.de)
525
526         * misc.c (cipher_algo_to_string): New
527         (pubkey_algo_to_string): New.
528         (digest_algo_to_string): New.
529
530