Make soem omnikey readers work with extended length APDUs.
[gnupg.git] / scd / ChangeLog
1 2009-06-29  Werner Koch  <wk@g10code.com>
2
3         * ccid-driver.c (ccid_transceive): Add a hack to support extended
4         length for Omnikey readers.
5         (is_exlen_apdu): New.
6         (parse_ccid_descriptor): Track short+extended apdu exchange level.
7
8 2009-06-18  Werner Koch  <wk@g10code.com>
9
10         * app-openpgp.c (verify_chv2): Remove special case for v2 cards.
11         (get_public_key): Use extended mode.
12
13 2009-06-17  Werner Koch  <wk@g10code.com>
14
15         * iso7816.c (iso7816_get_data): Add arg EXTENDED_MODE.  Change all
16         callers.
17         * app-openpgp.c (data_objects): Use bit flags.  Add flag
18         TRY_EXTLENGTH.
19         (get_cached_data): Add arg TRY_EXTLEN and use it for iso7816_get_data.
20         (get_one_do): Use extended length APDU if necessary.
21
22 2009-06-10  Werner Koch  <wk@g10code.com>
23
24         * app-openpgp.c (store_fpr): Change first arg to app_t; adjust
25         callers.  Flush the cache.
26
27 2009-06-09  Werner Koch  <wk@g10code.com>
28
29         * app-openpgp.c (do_readcert): Return NOT_FOUND if the retrieved
30         data has a length of zero.
31         (do_getattr): Add EXTCAP subkey "sm".
32
33 2009-05-20  Werner Koch  <wk@g10code.com>
34
35         * app-openpgp.c (verify_chv2): Add case for v2 cards.
36         (verify_chv3): Factor some code out to ..
37         (build_enter_admin_pin_prompt): .. new.
38         (do_change_pin): Properly handle v2 cards.
39
40 2009-05-19  Werner Koch  <wk@g10code.com>
41
42         * scdaemon.c (create_server_socket): Use SUN_LEN.
43         (JNLIB_NEED_AFLOCAL): Define.
44
45 2009-05-13  Werner Koch  <wk@g10code.com>
46
47         * ccid-driver.c (abort_cmd): Add arg SEQNO and change callers.
48         (bulk_in): Retry on seqno mismatch.
49
50         * apdu.c (send_le): Release result_buffer.
51         (apdu_send_direct): Implemend extended length.
52         * command.c (cmd_apdu): Add option "--exlen".
53
54 2009-05-11  Werner Koch  <wk@g10code.com>
55
56         * apdu.c (send_le): Replace log_error by log_info.
57
58 2009-05-08  Werner Koch  <wk@g10code.com>
59
60         * app-openpgp.c (do_genkey): Allow larger key sizes.
61         (do_decipher): Ditto.
62         * iso7816.c (do_generate_keypair): Add arg EXTENDED_MODE an LE.
63         (iso7816_generate_keypair, iso7816_read_public_key): Ditto.
64         Changed all callers.
65         * apdu.c (send_le): Implement extended length return values.
66         
67         * ccid-driver.c (bulk_in): Retry on EAGAIN.
68         (abort_cmd): Change seqno handling.
69
70 2009-04-28  Werner Koch  <wk@g10code.com>
71
72         * app-help.c (app_help_count_bits): New.
73
74         * app-nks.c (switch_application): Detect mass signature cards.
75         Take care of new NEED_APP_SELECT flag.
76         (do_sign): Don't allow mass signature cards.
77         (all_zero_p): New.
78         (do_readkey): New.
79         (app_select_nks): Register do_readkey.
80
81 2009-04-01  Werner Koch  <wk@g10code.com>
82
83         * app-openpgp.c (do_setattr, do_writekey): Prepare for extended
84         length cards.
85
86 2009-03-31  Werner Koch  <wk@g10code.com>
87
88         * command.c (percent_plus_unescape): Remove.
89         (cmd_setattr): Use percent_plus_unescape_inplace.
90
91 2009-03-30  Werner Koch  <wk@g10code.com>
92
93         * app-nks.c (do_decipher): Make it work for TCOS 3.
94         * iso7816.c (iso7816_decipher): Add arg EXTENDED_MODE.
95         * apdu.c (apdu_send): Add arg EXTENDED_MODE and change all callers.
96         (apdu_send_le):  Ditto. 
97         (apdu_send_direct): Ditto, but not yet functional.
98         (send_le): Fix command chaining.  Implement extended length option.
99         * ccid-driver.c (ccid_transceive): Remove restriction on apdu length.
100         (struct ccid_driver_s): Add field IFSC.
101         (ccid_get_atr): Set IFSC.
102         (ccid_transceive): Use negotiated IFSC and support S(IFS) command.
103
104 2009-03-26  Werner Koch  <wk@g10code.com>
105
106         * command.c (cmd_pksign): Allow more hash algorithms.
107
108         * scdaemon.h (MAX_DIGEST_LEN): Change to 64.
109
110         * apdu.c (open_ccid_reader): Clear the is_to flag.
111
112         * app-nks.c (filelist): Add field KID.
113         (do_getattr): Change standard authentication key.
114         (do_sign): Setup a security environment for TCOS 3 cards and support
115         all SHA-2 algorithms.
116
117 2009-03-24  Werner Koch  <wk@g10code.com>
118
119         * command.c (struct server_local_s): Add flag
120         APP_CTX_MARKED_FOR_RELEASE.
121         (do_reset): Set the flag.
122         (open_card): Act on this flag.
123         * app-common.h (struct app_ctx_s): Add flag NO_REUSE.
124         (application_notify_card_reset): Set the flag.
125         * app.c (select_application, release_application): Take care of
126         that flag.
127
128 2009-03-20  Werner Koch  <wk@g10code.com>
129
130         * app-nks.c (keygripstr_from_pk_file): Fix for TCOS 3 cards.
131
132 2009-03-18  Werner Koch  <wk@g10code.com>
133
134         * apdu.c (open_pcsc_reader_wrapped): Use close_all_fds.
135
136         * command.c (cmd_learn): Add option --keypairinfo.
137         * app.c (app_write_learn_status): Add arg FLAGS.
138         * app-common.h (struct app_ctx_s): Add arg FLAGS to LEARN_STATUS.
139         Change all implementors.
140         * app-p15.c (do_learn_status): Take care of flag bit 0.
141         * app-nks.c (do_learn_status, do_learn_status_core): Ditto.
142
143 2009-03-10  Werner Koch  <wk@g10code.com>
144
145         * app-openpgp.c (send_key_attr): New.
146         (do_getattr): New attribute KEY_ATTR.
147         * command.c (send_status_direct): New.
148
149 2009-03-06  Werner Koch  <wk@g10code.com>
150
151         * app-nks.c (do_learn_status): Factor code out to..
152         (do_learn_status_core): .. new.
153         (do_readcert, do_sign, do_decipher): Switch to SigG if needed.
154         (verify_pin): Use DESC also for keypad based verify.
155
156 2009-03-05  Werner Koch  <wk@g10code.com>
157
158         * app-openpgp.c (verify_a_chv): Remove special case for keypads.
159         (verify_chv3): Ditto.
160
161         * app-nks.c (get_chv_status): New.
162         (parse_pwidstr): New.
163         (verify_pin): Add args PWID and DESC and use them.  Remove the
164         CHV1 caching.
165         (do_change_pin): Allow PIN selection and add reset mode.
166         (do_learn_status): Use NKS-NKS3 tag for TCOS 3 cards.
167         (do_readcert, do_sign): Allow NKS-NKS3 tag.
168
169 2009-03-04  Werner Koch  <wk@g10code.com>
170
171         * app-nks.c (do_getattr): New.
172         (app_select_nks): Register it.
173         (verify_pin): Factor some code out to...
174         (basic_pin_checks): New.
175         (do_change_pin): Call the basic check.
176         (app_select_nks): Move AID to ..
177         (aid_nks): .. new.
178         (aid_sigg): New.
179         (switch_application): New.
180         (do_getattr, do_learn_status, do_readcert, do_sign, do_decipher) 
181         (do_change_pin, do_check_pin): Make sure we are in NKS mode.
182
183 2009-03-03  Werner Koch  <wk@g10code.com>
184
185         * command.c (scd_command_handler): Remove dereference of STOPME
186         after free.
187
188 2009-02-27  Werner Koch  <wk@g10code.com>
189
190         * app.c (get_supported_applications): New.
191         * command.c (cmd_getinfo): New subcommand "app_list"
192         (cmd_killscd): New.
193         (register_commands): Register command KILLSCD.
194         (struct server_local_s): Add field STOPME.
195         (scd_command_handler): Act upon this.
196
197 2009-02-25  Werner Koch  <wk@g10code.com>
198
199         * apdu.c (apdu_get_status): Factor all code out to ...
200         (apdu_private_get_status): .. new.  Add arg NO_ATR_RESET.
201         (apdu_connect): Call new function.
202
203         * scdaemon.c: New option --debug-log-tid.
204         (tid_log_callback): New.
205         (main): Move debug-wait code after debug stream init.
206
207 2009-02-24  Werner Koch  <wk@g10code.com>
208
209         * ccid-driver.c (ccid_get_atr): Move debug output to ..
210         (print_r2p_parameters): .. new.
211         (print_r2p_header, print_pr_data, print_r2p_unknown)
212         (print_r2p_datablock, print_r2p_slotstatus, print_r2p_escape) 
213         (print_r2p_datarate): New.
214         (bulk_in): Call parameter printing.
215         (ccid_set_debug_level): Add debug level 3.
216         (convert_le_u16): New.
217         (print_p2r_header, print_p2r_iccpoweron, print_p2r_iccpoweroff) 
218         (print_p2r_getslotstatus, print_p2r_xfrblock) 
219         (print_p2r_getparameters, print_p2r_resetparameters) 
220         (print_p2r_setparameters, print_p2r_escape, print_p2r_iccclock) 
221         (print_p2r_to0apdu, print_p2r_secure, print_p2r_mechanical) 
222         (print_p2r_abort, print_p2r_setdatarate, print_r2p_unknown): New.
223         (bulk_out): Add arg NO_DEBUG and change all callers to pass 0.
224         Call parameter printing.
225         (ccid_slot_status): Call with NO_DEBUG set.
226         (abort_cmd, send_escape_cmd, ccid_get_atr, ccid_get_atr) 
227         (ccid_transceive_apdu_level, ccid_transceive) 
228         (ccid_transceive_secure): Remove old debug print code.
229
230 2009-02-12  Werner Koch  <wk@g10code.com>
231
232         * command.c (cmd_getinfo): Add new subcommand "deny_admin".
233
234 2009-01-28  Werner Koch  <wk@g10code.com>
235
236         * scdaemon.c (main): Make --allow-admin the default and make the
237         option a dummy.
238
239 2009-01-27  Werner Koch  <wk@g10code.com>
240
241         * app-geldkarte.c: Changed to use an AID.
242
243         * app.c (app_munge_serialno): Add case for no serialno.
244         (app_get_serial_and_stamp): Ditto.
245
246 2009-01-26  Werner Koch  <wk@g10code.com>
247
248         * app-geldkarte.c: New.
249         * Makefile.am (card_apps): Add new file.
250         * app.c (select_application): Test for geldkarte.
251
252 2009-01-12  Werner Koch  <wk@g10code.com>
253
254         * command.c (send_client_notifications) [HAVE_W32_SYSTEM]: Fix
255         brackets.
256
257 2009-01-08  Werner Koch  <wk@g10code.com>
258
259         * iso7816.c (iso7816_read_record, iso7816_read_binary): Pass 0 for
260         L_e because the problem with the CCID driver has gone.
261         (iso7816_apdu_direct): New.
262
263         * app-nks.c (filelist): Add NKS_VER field.  Add NKS 3 specific
264         entries.
265         (app_local_s, do_deinit): New.
266         (get_nks_version): New.
267         (app_select_nks): Setup local data.
268         (keygripstr_from_pk_file): Replace SLOT by APP and take care of
269         NKS version > 2.
270         (do_learn_status): Take care of NKS version.
271
272 2009-01-05  Werner Koch  <wk@g10code.com>
273
274         * apdu.c (apdu_get_status): Save the last status.
275
276 2008-12-18  Werner Koch  <wk@g10code.com>
277
278         * ccid-driver.c (abort_cmd): New. 
279         (bulk_in): Call abort_cmd after severe errors.
280
281         * apdu.c (reader_table_s): Add field ANY_STATUS.
282         (new_reader_slot): Clear it.
283         (apdu_get_status): Use ANY_STATUS to update the change counter.
284         Remove the use of the flag bit from LAST_STATUS everywhere.
285         * command.c (update_reader_status_file): Factor code out to ...
286         (send_client_notifications): New.  Track signals already sent.
287         (update_reader_status_file): Shutdown the reader  after a failed
288         apdu_get_status.
289
290 2008-12-09  Werner Koch  <wk@g10code.com>
291
292         * scdaemon.c (main): Call i18n_init before init_common_subsystems.
293
294 2008-12-08  Werner Koch  <wk@g10code.com>
295
296         * scdaemon.c (handle_connections): Sync ticker to the next full
297         interval.
298         (TIMERTICK_INTERVAL_USEC): Change to 500ms.
299
300 2008-12-05  Werner Koch  <wk@g10code.com>
301
302         * app-openpgp.c (app_local_s): Add field ALGO_ATTR_CHANGE.
303         (app_select_openpgp): Parse new capability.
304         (show_caps): Show new capability.
305
306 2008-12-03  Werner Koch  <wk@g10code.com>
307
308         * scdaemon.c (opts): Use ARGPARSE_ macros.  Add option
309         --card-timeout.
310         * command.c (update_reader_status_file): Implement it.
311
312 2008-11-18  Werner Koch  <wk@g10code.com>
313
314         * scdaemon.c (make_libversion): New.
315         (my_strusage): Print libgcrypt and libksba version.
316
317 2008-11-03  Werner Koch  <wk@g10code.com>
318
319         * command.c (server_local_s): Add field DISCONNECT_ALLOWED.
320         (cmd_disconnect): Implement command.
321         (open_card): Reset disconnect flag.
322         (update_reader_status_file): Disconnect if allowed.
323
324         * app-common.h (app_ctx_s): Remove INITIALIZED.  Make REF_COUNT
325         unsigned. 
326         * app.c (select_application): Remove INITIALIZED.
327         (app_write_learn_status, app_readcert, app_readkey, app_getattr)
328         (app_setattr, app_sign, app_decipher, app_writecert)
329         (app_writekey, app_get_challenge, app_change_pin, app_check_pin):
330         Replace INITIALIZED by REF_COUNT check.
331         (application_notify_card_removed): Rename to ..
332         (application_notify_card_reset): .. this.  Change all callers.
333         * command.c (do_reset): Call application_notify_card_reset after
334         sending a reset.
335         (update_reader_status_file): Add arg SET_CARD_REMOVED.
336         (scd_update_reader_status_file): Pass true for new flag.
337         (do_reset): Pass false for new flag.
338
339         * app.c (app_get_serial_and_stamp): Use bin2hex.
340         * app-help.c (app_help_get_keygrip_string): Ditto.
341         * app-p15.c (send_certinfo, send_keypairinfo, do_getattr): Ditto.
342         * app-openpgp.c (send_fpr_if_not_null, send_key_data) 
343         (retrieve_fpr_from_card, send_keypair_info): Ditto.
344         * app-nks.c (keygripstr_from_pk_file): Ditto.
345         * command.c (cmd_apdu): Ditto.
346
347 2008-10-21  Marcus Brinkmann  <marcus@g10code.com>
348
349         * command.c (open_card): If connect error is SW_HOST_NO_CARD,
350         return a more descriptive error.
351
352 2008-10-20  Werner Koch  <wk@g10code.com>
353
354         * pcsc-wrapper.c (read_32): Use provided arg and not stdin.  Is
355         called with stdin, though.
356         (handle_close): Mark unused arg.
357         (handle_status, handle_reset): Ditto.
358
359         * ccid-driver.c (ccid_check_card_presence): Mark not yet used arg.
360
361         * scdaemon.c (scd_deinit_default_ctrl): Mark unused arg.
362         * command.c (cmd_unlock, cmd_restart, cmd_disconnect): Ditto.
363         * apdu.c (ct_get_status): Ditto.
364         (ct_send_apdu, pcsc_send_apdu_wrapped)
365         (apdu_open_remote_reader): Ditto.
366         * app.c (select_application): Ditto.
367         * app-openpgp.c (do_writecert, do_change_pin, do_writekey): Ditto.
368         * app-nks.c (do_change_pin, do_check_pin): Ditto.
369
370 2008-10-16  Werner Koch  <wk@g10code.com>
371
372         * command.c (cmd_disconnect): New dummy command.
373         (register_commands): Register command.
374
375 2008-10-15  Werner Koch  <wk@g10code.com>
376
377         * command.c (scd_command_handler): Return true if there is no more
378         active session.
379         * scdaemon.c (start_connection_thread): Set shutdown flag if
380         requested by command handler.
381         (main): Make PIPE_SERVER module global.
382         (handle_connections): Disable listen_fd if a shutdown is pending.
383
384 2008-10-14  Werner Koch  <wk@g10code.com>
385
386         * apdu.c (reader_table_s): Add fields connect_card and
387         disconnect_card.
388         (new_reader_slot): Set them to NULL.
389         (apdu_connect, apdu_disconnect): New.
390         (apdu_close_reader, apdu_shutdown_reader): Call apdu_disconnect.
391         (connect_pcsc_card, disconnect_pcsc_card): new.
392         (reset_pcsc_reader_direct): Implement in terms of
393         disconnect_pcsc_card and connect_pcsc_card.
394         (apdu_get_atr): Return NULL if there is no ATR.
395         * sc-copykeys.c (main): Add call to apdu_connect.
396         * command.c (open_card): Ditto.
397
398         * apdu.h (SW_HOST_ALREADY_CONNECTED): New.
399         (APDU_CARD_USABLE, APDU_CARD_PRESENT, APDU_CARD_ACTIVE): New.
400         * apdu.c: Replace constants by the new macros.
401         (open_pcsc_reader): Factor  code out to ...
402         (open_pcsc_reader_direct, open_pcsc_reader_wrapped): New.
403         (reset_pcsc_reader): Factor code out to ...
404         (reset_pcsc_reader_direct, reset_pcsc_reader_wrapped): New.
405         (pcsc_get_status): Factor code out to ...
406         (pcsc_get_status_direct, pcsc_get_status_wrapped): New.
407         (pcsc_send_apdu): Factor code out to ...
408         (pcsc_send_apdu_direct, pcsc_send_apdu_wrapped): New.
409         (close_pcsc_reader): Factor code out to ...
410         (close_pcsc_reader_direct, close_pcsc_reader_wrapped): New.
411
412         * command.c (update_reader_status_file): Open the reader if not
413         yet done.
414
415         * scdaemon.c (TIMERTICK_INTERVAL_SEC, TIMERTICK_INTERVAL_USEC):
416         New to replace TIMERTICK_INTERVAL.  Chnage from 2s (4 under W32)
417         to 250ms.
418
419 2008-10-13  Werner Koch  <wk@g10code.com>
420
421         * command.c (option_handler) [W32]: Use strtoul with base 16.
422         (update_reader_status_file) [W32]: Set Event.
423         (scd_command_handler): Use INT2FD to silent warning.
424
425 2008-09-29  Werner Koch  <wk@g10code.com>
426
427         * scdaemon.h (GCRY_MD_USER): Rename to GCRY_MODULE_ID_USER.
428         (GCRY_MD_USER_TLS_MD5SHA1): Rename to MD_USER_TLS_MD5SHA1 and
429         change all users.
430
431 2008-09-28  Marcus Brinkmann  <marcus@g10code.com>
432
433         * apdu.c (pcsc_get_status): Fix last change.
434
435 2008-09-25  Werner Koch  <wk@g10code.com>
436
437         * app-openpgp.c (do_setattr): Do not allow setting of the reset
438         code.
439         (do_change_pin): Allow setting of the reset code.
440
441 2008-09-24  Werner Koch  <wk@g10code.com>
442
443         * app-openpgp.c (verify_chv3): Set the did_chv3 flag which was
444         accidently removed on 2008-03-26.
445         (verify_chv2): Revert last change.
446         (do_change_pin): Do not change CHV2. Add reset code logic for v2
447         cards.
448         * iso7816.c (iso7816_reset_retry_counter_with_rc): New.
449         
450         * app-openpgp.c (add_tlv, build_privkey_template): New.
451         (do_writekey): Support v2 keys and other key lengths than 1024.
452         * iso7816.c (iso7816_put_data_odd): New.
453
454 2008-09-23  Werner Koch  <wk@g10code.com>
455
456         * app-openpgp.c (do_sign): Support SHA-2 digests.
457         (verify_chv2): No CHV auto-sync for v2 cards.
458         (do_auth): Allow 2048 bit keys.
459         (parse_algorithm_attribute): New.
460         (rsa_key_format_t): New.
461         (struct app_local_s): Add struct KEYATTR.
462
463 2008-09-23  Marcus Brinkmann  <marcus@g10code.com>
464
465         * apdu.c (pcsc_get_status): Be more relaxed with the usable flag
466         under Windows.
467
468 2008-09-23  Werner Koch  <wk@g10code.com>
469
470         * app-openpgp.c (do_setattr): Use command chaining for long
471         values.
472         * iso7816.c (iso7816_put_data): Add arg EXTENDED_MODE. Change all
473         callers.
474         * apdu.c (apdu_send_simple): Add arg EXTENDED_MODE. Change all
475         callers.
476         (send_le): Implement command chaining.
477         * ccid-driver.c (ccid_transceive_apdu_level): Increase allowed
478         APDU size.
479         (ccid_transceive): Alow for APDUS of up to 259 bytes.
480         * apdu.h: Add new SW_ codes.
481
482 2008-09-16  Werner Koch  <wk@g10code.com>
483
484         * command.c (cmd_writecert): New.
485         (register_commands): Register it.
486         * app-common.h (app_ctx_s): Add member WRITECERT.
487         * app.c (app_writecert): New.
488         * app-openpgp.c (do_writecert): New.
489         (parse_historical): New.
490         (show_extcap): New.
491         (dump_all_do): Print only the length of longs DOs.
492         * command.c (cmd_writekey, cmd_apdu, cmd_pksign)
493         (cmd_passwd): Replace open coding by skip_options.
494
495 2008-08-30  Moritz  <moritz@gnu.org>
496
497         * scdaemon.c (main): Use estream_asprintf instead of asprintf.
498         * command.c (update_reader_status_file): Likewise.
499         (cmd_serialno): Use estream_asprintf instead of asprintf
500         and xfree instead of free to release memory allocated
501         through (estream_)asprintf.
502         (cmd_learn): Likewise.
503         (pin_cb): Likewise.
504         * app-openpgp.c (get_public_key): Likewise.
505
506 2008-08-18  Werner Koch  <wk@g10code.com>
507
508         * app-openpgp.c (do_setattr): Fix test for v2 cards.
509
510 2008-08-11  Werner Koch  <wk@g10code.com>
511
512         * apdu.c (reset_pcsc_reader, open_pcsc_reader)
513         (reset_rapdu_reader, open_rapdu_reader): Allow ATRs of up to 33
514         bytes.  Provide maximum size of ATR buffer using DIM.  Such long
515         ATR are never seen in reality but the PC/SC library of MAC OS X is
516         just too buggy.  Reported by Ludovic Rousseau.  Fixes bug #948.
517
518 2008-07-30  Werner Koch  <wk@g10code.com>
519
520         * app-openpgp.c (verify_a_chv): Use xtrymalloc and make the prompt
521         for CHV2 more user friendly.
522
523 2008-07-03  Werner Koch  <wk@g10code.com>
524
525         * app-openpgp.c (do_readcert): New.
526         (app_local_s): Add fields IS_V2 and MAX_CERTLEN_3.
527         (app_select_openpgp): Set them and register do_readcert.
528         (do_setattr): Allow storing of the certificate.
529
530 2008-06-25  Werner Koch  <wk@g10code.com>
531
532         * app-dinsig.c (do_sign): Allow for SHA256.
533
534 2008-06-24  Werner Koch  <wk@g10code.com>
535
536         * app-common.h (app_ctx_s): Renamed reset_mode parameter of
537         change_pin to mode_Flags and make it an unsigned int.
538         (APP_CHANGE_FLAG_RESET, APP_CHANGE_FLAG_NULLPIN): New.
539         * app-openpgp.c (do_change_pin): Adjust for that.
540
541         * command.c (cmd_passwd): Add option --nullpin.
542         * app-nks.c (do_check_pin, do_change_pin): New.
543         (app_select_nks): Register new functions.
544
545 2008-04-21  Moritz Schulte  <mo@g10code.com>  (wk)
546
547         * app-openpgp.c (verify_a_chv): Make use of the default CHV flag.
548
549 2008-03-26  Werner Koch  <wk@g10code.com>
550
551         * app-openpgp.c (verify_chv3): Support the keypad.
552
553 2008-02-09  Marcus Brinkmann  <marcus@g10code.de>
554
555         * scdaemon.c (main): Use CONFIG_FILENAME as filename if it is set
556         in gpgconf-list output.
557
558 2007-12-10  Werner Koch  <wk@g10code.com>
559
560         * app-openpgp.c (do_decipher): Take care of cryptograms shorter
561         that 128 bytes.  Fixes bug#851.
562
563 2007-11-14  Werner Koch  <wk@g10code.com>
564
565         * scdaemon.c (main): Pass STANDARD_SOCKET flag to
566         create_server_socket.
567         
568 2007-11-13  Werner Koch  <wk@g10code.com>
569
570         * scdaemon.c (start_connection_thread): Do not call
571         assuan_sock_check_nonce if we are running in --server mode.
572
573 2007-11-07  Werner Koch  <wk@g10code.com>
574
575         * scdaemon.h: Remove errors.h.
576
577 2007-10-02  Werner Koch  <wk@g10code.com>
578
579         * command.c (cmd_getinfo): Add "pid" subcommand.
580
581 2007-10-01  Werner Koch  <wk@g10code.com>
582
583         * scdaemon.c (create_server_socket): Use Assuan socket wrappers
584         and remove Windows specific code.
585         (socket_nonce): New.
586         (start_connection_thread): Check nonce.
587
588 2007-09-14  Marcus Brinkmann  <marcus@g10code.de>
589
590         * scdaemon.c (main): New variable STANDARD_SOCKET, which is 1 for
591         W32 targets.  Use it for create_socket_name.
592
593 2007-08-07  Werner Koch  <wk@g10code.com>
594
595         * tlv.c, tlv.h:  Move to ../common/.
596
597 2007-08-02  Werner Koch  <wk@g10code.com>
598
599         * scdaemon.c: Include gc-opt-flags.h and remove their definition
600         here.
601
602 2007-08-01  Werner Koch  <wk@g10code.com>
603
604         * apdu.c (send_le): Implement exact length hack.  Suggested by
605         Sten Lindgren.
606
607 2007-07-05  Werner Koch  <wk@g10code.com>
608
609         * command.c (has_option_name, skip_options): New.
610         (cmd_genkey): Add option --timestamp.
611         (cmd_writekey): Enter confidential mode while inquiring the key data.
612
613         * app.c (app_genkey): Add arg CREATETIME.
614         * app-common.h (app_ctx_s): Likewise
615         * app-openpgp.c (do_genkey): Ditto.  Use it.
616
617
618 2007-07-04  Werner Koch  <wk@g10code.com>
619
620         * command.c (cmd_getinfo): New subcommand "version".
621
622         * scdaemon.c (TIMERTICK_INTERVAL): New.
623         (handle_connections) [W32]: Enable a dummy sigs event.
624         (handle_connections): Use a proper count for select and not
625         FD_SETSIZE.
626         (fixed_gcry_pth_init, main): Kludge to fix pth initialization.
627
628 2007-06-21  Werner Koch  <wk@g10code.com>
629
630         * scdaemon.h (ctrl_t): Remove.  It is now declared in ../common/util.h.
631
632 2007-06-18  Marcus Brinkmann  <marcus@g10code.de>
633
634         * scdaemon.c (main): Percent escape output of --gpgconf-list.
635
636 2007-06-12  Werner Koch  <wk@g10code.com>
637
638         * scdaemon.c (main): Replace some calls by init_common_subsystems.
639
640 2007-06-11  Werner Koch  <wk@g10code.com>
641
642         * Makefile.am (scdaemon_LDADD): Use libcommonpth macro.
643
644         * command.c (initialize_module_command): New.
645         * scdaemon.c (main) [W32]: Do not use sigpipe code.
646         (main): Call initialize_module_command.
647
648 2007-06-06  Werner Koch  <wk@g10code.com>
649
650         * app-openpgp.c (do_sign): Fix arithmetic on void*.
651
652         * app.c (dump_mutex_state) [W32]: Handle the W32Pth case.
653
654         * apdu.c: Remove dynload.h.
655
656         * scdaemon.c (i18n_init): Remove.
657
658 2007-04-20  Werner Koch  <wk@g10code.com>
659
660         * sc-copykeys.c (my_gcry_logger): Removed.
661         (main): Call setup_libgcrypt_logging helper.
662         * scdaemon.c (my_gcry_logger): Removed.
663         (main): Call setup_libgcrypt_logging helper.
664
665 2007-04-03  Werner Koch  <wk@g10code.com>
666
667         * command.c (cmd_getinfo): New subcommand "reader_list".
668         * ccid-driver.c (scan_or_find_devices): Ignore EBUSY in scan mode
669         for special transports.
670
671 2007-03-07  Werner Koch  <wk@g10code.com>
672
673         * app-dinsig.c: Include i18n.h.
674         (verify_pin): Support PIN pads.
675         * app-nks.c (verify_pin): Ditto.
676
677         * ccid-driver.c (bulk_in): Handle time extension before checking
678         the message type.
679         (ccid_transceive_secure): Support the Cherry XX44 keyboard.
680         Kudos to the nice folks at Cherry for helping with that.
681
682 2007-02-18  Werner Koch  <wk@g10code.com>
683
684         * scdaemon.c (DEFAULT_PCSC_DRIVER): Add a default for OS X.
685
686 2007-01-25  Werner Koch  <wk@g10code.com>
687
688         * Makefile.am (scdaemon_LDADD): Added LIBICONV.  Noted by Billy
689         Halsey.
690
691 2006-12-21  Werner Koch  <wk@g10code.com>
692
693         * app-openpgp.c (verify_chv2): Factored most code out into...
694         (verify_a_chv): ... new.
695         (do_sign): Factored verification code out to new function and
696         take care of a keypad entered PIN.
697         (compare_fingerprint): Print an additional diagnostic.
698
699 2006-11-28  Werner Koch  <wk@g10code.com>
700
701         * apdu.c (send_le, apdu_send_direct): Increase RESULTLEN to 258 to
702         allow for full 256 byte and the status word.  This might break
703         some old PC/SC drivers or cards, but we will see.  Suggested by
704         Kenneth Wang.
705
706 2006-11-23  Werner Koch  <wk@g10code.com>
707
708         * command.c (scd_command_handler): Fixed use of CTRL.
709
710 2006-11-21  Werner Koch  <wk@g10code.com>
711
712         * Makefile.am (libexec_PROGRAMS): Put pscs-wrapper into libexec.
713         Renamed to gnupg-pcsc-wrapper.
714         * apdu.c (open_pcsc_reader): Use GNUPG_LIBEXECDIR to accces the
715         wrapper.  Suggested by Eric Dorland.
716
717 2006-11-20  Werner Koch  <wk@g10code.com>
718
719         * app-openpgp.c (verify_chv2): Support for keypads (only CHV2).
720
721         * ccid-driver.c (ccid_transceive_secure): Made it work for Kaan
722         and SCM.
723
724 2006-11-17  Werner Koch  <wk@g10code.com>
725
726         * ccid-driver.c (scan_or_find_devices): Use DEBUGOUT_2 instead of
727         log_debug.  Removed few other log_debug.
728
729         * iso7816.c (iso7816_check_keypad): Allow for a SW of 0.
730
731         * command.c (pin_cb): New mode to prompt for a keypad entry.
732
733         * scdaemon.c (main) <gpgconf-list>: Add disable-keypad.
734
735 2006-11-15  Werner Koch  <wk@g10code.com>
736
737         * app-p15.c (read_ef_odf): Cast one printf arg.
738
739         * scdaemon.h (struct server_control_s): Add field THREAD_STARTUP.
740         * command.c (scd_command_handler): Add new arg CTRL.
741         * scdaemon.c (scd_init_default_ctrl): Made static.
742         (scd_deinit_default_ctrl): New.
743         (start_connection_thread): Call init/deinit of ctrl.
744         (handle_connections): Allocate CTRL.
745
746         * apdu.c (PCSC_ERR_MASK): New.
747         (reset_pcsc_reader, pcsc_get_status, pcsc_send_apdu)
748         (close_pcsc_reader, open_pcsc_reader): Use it after shifting error
749         values.  Reported by Henrik Nordstrom.  Fixes bug #724.
750
751 2006-10-24  Werner Koch  <wk@g10code.com>
752
753         * scdaemon.h (GCRY_MD_USER_TLS_MD5SHA1): New.
754         (MAX_DIGEST_LEN): Increased to 36.
755         * app-p15.c (do_sign): Support for TLS_MD5SHA1.
756         (do_auth): Detect TLS_MD5SHA1.
757         (do_sign): Tweaks for that digest.
758
759 2006-10-23  Werner Koch  <wk@g10code.com>
760
761         * scdaemon.c (main): New command --gpgconf-test.
762
763 2006-10-17  Werner Koch  <wk@g10code.com>
764
765         * Makefile.am (scdaemon_LDADD): Link against libcommonpth.
766
767 2006-10-12  Werner Koch  <wk@g10code.com>
768
769         * apdu.c: Include pth.h after unistd.h for the sake of newer Pth
770         versions.
771
772 2006-10-11  Werner Koch  <wk@g10code.com>
773
774         * app-openpgp.c (do_sign): Redirect to do_auth for OpenPGP.3.
775
776 2006-10-06  Werner Koch  <wk@g10code.com>
777
778         * Makefile.am (AM_CFLAGS): Use PTH version of libassuan.
779         (scdaemon_LDADD): Ditto.
780
781         * scdaemon.h (send_status_info): Mark with sentinel attribute.
782
783 2006-10-02  Marcus Brinkmann  <marcus@g10code.de>
784
785         * command.c (update_reader_status_file): Increase buffer of
786         NUMBUF2 (fixing typo).
787
788 2006-09-24  Marcus Brinkmann  <marcus@g10code.de>
789
790         * app-openpgp.c (do_sign): Advance INDATA by the SHA1 resp. RMD160
791         prefix length.
792
793 2006-09-14  Werner Koch  <wk@g10code.com>
794
795         Replaced all call gpg_error_from_errno(errno) by
796         gpg_error_from_syserror().
797
798         * command.c (scd_command_handler): Replaced
799         init_connected_socket_server by init_socket_server_ext.
800
801 2006-09-07  Werner Koch  <wk@g10code.com>
802
803         * command.c (update_reader_status_file): Execute an event handler
804         if available.
805
806 2006-09-06  Werner Koch  <wk@g10code.com>
807
808         * apdu.c (pcsc_end_transaction): 
809         * pcsc-wrapper.c (pcsc_end_transaction: Fixed dclaration.
810         Reported by Bob Dunlop.
811
812         * scdaemon.h (CTRL,APP): Removed and changed everywhere to
813         ctrl_t/app_t.
814
815         Replaced all Assuan error codes by libgpg-error codes.  Removed
816         all map_to_assuan_status and map_assuan_err.
817         
818         * scdaemon.c (main): Call assuan_set_assuan_err_source to have Assuan
819         switch to gpg-error codes.
820         * command.c (set_error): Adjusted.
821
822 2006-09-02  Marcus Brinkmann  <marcus@g10code.de>
823
824         * command.c (get_reader_slot): Return the slot_table index, not
825         the APDU slot number.
826         (update_reader_status_file): Use the slot_table index in the
827         update_card_removed invocation.
828
829 2006-09-01  Marcus Brinkmann  <marcus@g10code.de>
830
831         * command.c (cmd_getinfo): Handle status command.
832
833 2006-08-30  Marcus Brinkmann  <marcus@g10code.de>
834
835         * command.c (do_reset): Delay resetting CTRL->reader_slot until
836         after update_card_removed invocation.
837
838 2006-08-28  Marcus Brinkmann  <marcus@g10code.de>
839
840         * app-openpgp.c (do_decipher, do_sign): Allow "OPENPGP.2"
841         resp. "OPENPGP.1" for KEYIDSTR.
842
843 2006-08-21  Werner Koch  <wk@g10code.com>
844
845         * pcsc-wrapper.c (handle_open, handle_close): Reset card and
846         protocol on error/close.
847         (handle_status): Don't set the state if the state is unknown.
848         (handle_reset): Ignore an error if already disconnected.  May
849         happen due to system wake-up after hibernation.  Suggested by Bob
850         Dunlop.
851
852 2006-06-28  Werner Koch  <wk@g10code.com>
853
854         * app-openpgp.c (do_writekey): Fixed computation of memmove
855         length.  This led to garbled keys if E was larger than one byte.
856         Thanks to Achim Pietig for hinting at the garbled E.
857
858 2006-06-09  Marcus Brinkmann  <marcus@g10code.de>
859
860         * Makefile.am (scdaemon_LDADD): Add $(NETLIBS).
861
862 2006-04-14  Marcus Brinkmann  <marcus@g10code.de>
863
864         * app.c (select_application): Cover up a slot mismatch error in
865         case it happens (it shouldn't happen).
866         (release_application): Use APP->slot.  Lock the reader.
867         (application_notify_card_removed): Lock the reader.
868
869 2006-04-11  Werner Koch  <wk@g10code.com>
870
871         * command.c (hex_to_buffer): New.
872         (cmd_apdu): New.
873
874 2006-04-03  Werner Koch  <wk@g10code.com>
875
876         * scdaemon.c [__GLIBC__]: Default to libpcsclite.so.1.
877
878 2006-03-21  Werner Koch  <wk@g10code.com>
879
880         * command.c (cmd_pksign): Add --hash option.
881
882 2006-03-01  Werner Koch  <wk@g10code.com>
883
884         * command.c (status_file_update_lock): New.
885         (scd_update_reader_status_file): Use lock and factor existing code
886         out to ..
887         (update_reader_status_file): .. this.
888         (do_reset): Use the lock and call update_reader_status_file.
889
890 2006-02-20  Werner Koch  <wk@g10code.com>
891
892         * apdu.c (open_pcsc_reader): Fixed double free.  Thanks to Moritz.
893
894 2006-02-09  Werner Koch  <wk@g10code.com>
895
896         * command.c (get_reader_slot, do_reset) 
897         (scd_update_reader_status_file): Rewrote.
898
899         * app.c (release_application): Factored code out to ..
900         (deallocate_app): new function.
901         (select_application): Introduce new saved application stuff.
902         (application_notify_card_removed): New.
903         * command.c (update_card_removed): Call it here.
904         (do_reset): And here.
905
906         * app.c (check_application_conflict): New.
907         * command.c (open_card): Use it here.
908         (cmd_restart): New command.
909
910         * command.c (cmd_lock): Fixed --wait option to actually terminate.
911
912 2006-02-08  Werner Koch  <wk@g10code.com>
913
914         * ccid-driver.c (ccid_get_atr): Read Parameter and select T=1
915         using these parameters.
916         (scan_or_find_devices): Check for NULL r_fd.
917
918 2006-02-02  Werner Koch  <wk@g10code.com>
919
920         * ccid-driver.c (special_transport): New
921         (ccid_open_reader, do_close_reader, ccid_shutdown_reader)
922         (bulk_out, bulk_in): Add support for CardMan 4040 reader.
923
924         * ccid-driver.c (scan_or_find_devices): Factored most code out to
925         (scan_or_find_usb_device): .. new.
926         (make_reader_id): Fixed vendor mask.
927
928 2006-01-01  Werner Koch  <wk@g10code.com>
929
930         * app-openpgp.c (do_sign): Give user error if hash algorithm is
931         not supported by the card.
932
933 2005-12-06  Werner Koch  <wk@g10code.com>
934
935         * apdu.c (open_pcsc_reader): Check that pcsc-wrapper is actually
936         installed.
937
938 2005-11-23  Werner Koch  <wk@g10code.com>
939
940         * app-nks.c (verify_pin): Give a special error message for a Nullpin.
941
942 2005-10-29  Werner Koch  <wk@g10code.com>
943
944         * ccid-driver.c (send_escape_cmd): New args RESULT, RESULTLEN and
945         RESULTMAX.  Changed all callers.
946         (ccid_transceive_escape): New.
947
948 2005-10-27  Werner Koch  <wk@g10code.com>
949
950         * apdu.c [__CYGWIN__]: Make cygwin environment similar to _WIN32.
951         Suggested by John P. Clizbe.
952         * scdaemon.c [__CYGWIN__]: Set default PC/SC driver to winscard.dll.
953
954 2005-10-19  Werner Koch  <wk@g10code.com>
955
956         * ccid-driver.h (CCID_DRIVER_ERR_NO_KEYPAD): New.
957         * apdu.h (SW_HOST_NO_KEYPAD): New.
958         * iso7816.h (struct iso7816_pininfo_s): New.
959         * iso7816.c (map_sw): Support new code.
960         (iso7816_check_keypad): New.
961         (iso7816_verify_kp, iso7816_change_reference_data_kp) 
962         (iso7816_reset_retry_counter_kp): New.  Extended versions of the
963         original functions.
964         * apdu.c (host_sw_string): Support new code. 
965         (reader_table_s): New field CHECK_KEYPAD.
966         (new_reader_slot, open_ct_reader, open_pcsc_reader) 
967         (open_ccid_reader, open_rapdu_reader): Initialize it.
968         (check_ccid_keypad): New.
969         (apdu_check_keypad): New.
970         (apdu_send_le): Factored all code out to ...
971         (send_le): .. new.  Takes an additional arg; changed all callers
972         of the orginal function to use this one with a NULL for the new
973         arg.
974         (apdu_send_simple_kp): New.
975         (ct_send_apdu, pcsc_send_apdu, my_rapdu_send_apdu) 
976         (send_apdu_ccid): New arg PININFO.
977         (send_apdu_ccid): Use the new arg.
978
979         * scdaemon.c: New option --disable-keypad.
980
981 2005-10-08  Marcus Brinkmann  <marcus@g10code.de>
982
983         * Makefile.am (scdaemon_LDADD): Add ../gl/libgnu.a after
984         ../common/libcommon.a.
985
986 2005-09-20  Werner Koch  <wk@g10code.com>
987
988         * app-dinsig.c (verify_pin): Try ISO 9564 BCD encoding.
989
990         * iso7816.c (iso7816_select_application): Add arg FLAGS.  Changed
991         all callers to pass 0.
992         * app-openpgp.c (app_select_openpgp): But this one requires a
993         special flag.
994
995         * app-p15.c (app_select_p15): Don't use select application for the
996         BELPIC.
997
998 2005-09-09  Werner Koch  <wk@g10code.com>
999
1000         * pcsc-wrapper.c (main): Removed bogus free.
1001
1002         * app-p15.c (do_auth): New.
1003         (do_getattr): New attribs $AUTHKEYID and $DISPSERIALNO.
1004         * app-openpgp.c (do_getattr): Ditto.
1005
1006 2005-09-08  Werner Koch  <wk@g10code.com>
1007
1008         * app-openpgp.c (do_getattr): New key $AUTHKEYID.
1009
1010 2005-09-06  Werner Koch  <wk@g10code.com>
1011
1012         * app-p15.c (do_sign): Tweaked for BELPIC cards.
1013         (read_home_df): New arg R_BELPIC.
1014         (app_select_p15): Set card type for BELPIC.
1015
1016 2005-09-05  Werner Koch  <wk@g10code.com>
1017
1018         * iso7816.c (iso7816_select_path): New.
1019         * app-p15.c (select_ef_by_path): Allow for direct path selection.
1020         (app_select_p15): Try using the Belgian variant of pkcs#15.
1021         (read_home_df): New.
1022         (read_ef_odf): Generalized.
1023         (read_ef_tokeninfo): New.
1024         (read_p15_info): Set serialnumber from TokenInfo.
1025         (app_select_p15): Don't munge serialNumber - that must be done
1026         only once.
1027
1028         * iso7816.c (iso7816_read_binary): Use Le=0 when reading all
1029         data.  Handle 6C00 error and take 6B00 as indication for EOF.
1030         * apdu.h (SW_EXACT_LENGTH_P): New.
1031         * apdu.c (new_reader_slot, reset_pcsc_reader, pcsc_get_status) 
1032         (open_pcsc_reader): Set new reader state IS_T0.
1033         (apdu_send_le): When doing T=0 make sure not to send Lc and Le.
1034         Problem reported by Carl Meijer.
1035         (apdu_send_direct): Initialize RESULTLEN.
1036         * pcsc-wrapper.c (handle_status): Return the current protocol as
1037         a new third word.
1038
1039 2005-08-05  Werner Koch  <wk@g10code.com>
1040
1041         * apdu.c (open_rapdu_reader): Set the reader number.
1042
1043 2005-07-05  Werner Koch  <wk@g10code.com>
1044
1045         * app-openpgp.c (do_readkey): Return a mallcoed copy of the key as
1046         required by the description.  Thanks to Moritz for tracking this
1047         problem down.
1048
1049 2005-06-21  Werner Koch  <wk@g10code.com>
1050
1051         * scdaemon.c (main): ifdef call to ccid_set_debug_level.
1052
1053         * apdu.c (reset_pcsc_reader, open_pcsc_reader): Cast size_t to
1054         ulong for printf.
1055
1056 2005-06-06  Werner Koch  <wk@g10code.com>
1057
1058         * scdaemon.c (main): New option --debug-allow-core-dump. 
1059
1060 2005-06-03  Werner Koch  <wk@g10code.com>
1061
1062         * scdaemon.c (handle_connections): Make sure that the signals we
1063         are handling are not blocked.Block signals while creating new
1064         threads.
1065         (handle_connections): Include the file descriptor into the name of
1066         the thread.
1067
1068 2005-06-02  Werner Koch  <wk@g10code.com>
1069
1070         * app.c (app_dump_state, dump_mutex_state): New.
1071         * scdaemon.c (handle_signal): Print it on SIGUSR1.
1072
1073         * app-openpgp.c (do_writekey): Typo fix.
1074
1075         * command.c (open_card): Check for locked state even if an
1076         application context is available.
1077
1078         * app-common.h: Add REF_COUNT field.
1079         * app.c (release_application, select_application): Implement
1080         reference counting to share the context beween connections.
1081
1082         * app.c (lock_reader, unlock_reader): Take SLOT instead of APP as
1083         argument.  Changed all callers.
1084         (select_application): Unlock the reader on error.  This should fix
1085         the hangs I noticed last week.
1086
1087         * scdaemon.h: Removed card_ctx_t cruft.
1088
1089 2005-06-01  Werner Koch  <wk@g10code.com>
1090
1091         * scdaemon.c: Include mkdtemp.h.
1092
1093 2005-05-31  Werner Koch  <wk@g10code.com>
1094
1095         * tlv.c [GNUPG_MAJOR_VERSION==1]: Define constants instead of
1096         including a gnupg 1.4 header.
1097
1098 2005-05-30  Werner Koch  <wk@g10code.com>
1099
1100         * tlv.c: Add hack to compile without gpg-error.h when used with
1101         GnuPG 1.4.
1102
1103 2005-05-23  Werner Koch  <wk@g10code.com>
1104
1105         * Makefile.am: Do not build sc-copykeys anymore.
1106
1107         * app-openpgp.c (app_openpgp_storekey, app_openpgp_readkey)
1108         (app_openpgp_cardinfo): Removed.
1109
1110         * ccid-driver.c (parse_ccid_descriptor): SCR335 FW version 5.14 is
1111         good.
1112         (do_close_reader): Never do a reset. The caller should instead
1113         make sure that the reader has been closed properly.  The new retry
1114         code in ccid_slot_status will make sure that the readersatrts up
1115         fine even if the last process didn't closed the USB connection
1116         properly.
1117         (ccid_get_atr): For certain readers try switching to ISO mode.
1118         Thanks to Ludovic Rousseau for this hint and the magic numbers.
1119         (print_command_failed): New.
1120         (bulk_in): Use it here. Add new arg NO_DEBUG.
1121         (ccid_slot_status): Disabled debugging.
1122
1123 2005-05-21  Werner Koch  <wk@g10code.com>
1124
1125         * scdaemon.c (handle_signal): Print thread info on SIGUSR1.
1126
1127 2005-05-20  Werner Koch  <wk@g10code.com>
1128
1129         * ccid-driver.c: Replaced macro DEBUG_T1 by a new debug level.
1130         (parse_ccid_descriptor): Mark SCR335 firmware version 5.18 good.
1131         (ccid_transceive): Arghhh.  The seqno is another bit in the
1132         R-block than in the I block, this was wrong at one place.
1133
1134         * scdaemon.c: New options --debug-ccid-driver and
1135         --debug-disable-ticker.
1136
1137         * app-openpgp.c (do_genkey, do_writekey): Factored code to check
1138         for existing key out into ..
1139         (does_key_exist): .. New function.
1140
1141 2005-05-19  Werner Koch  <wk@g10code.com>
1142
1143         * tlv.c (parse_sexp): New.
1144
1145         * command.c (cmd_writekey): New.
1146         * app.c (app_writekey): New.
1147         * app-common.c (app_t): Add function ptr WRITEKEY.
1148         * app-openpgp.c (do_writekey): New.
1149
1150         * app-openpgp.c (do_readkey) [GNUPG_MAJOR_VERSION==1]: Return error.
1151         * app-common.h (app_t) [GNUPG_MAJOR_VERSION==1]: Add a field to
1152         store the Assuan context.
1153
1154 2005-05-17  Werner Koch  <wk@g10code.com>
1155
1156         * scdaemon.c: Removed non-pth code paths.
1157         (create_socket_name, create_server_socket): New.  Taken from
1158         ../agent/gpg-agent.
1159         (cleanup): Changed to adjust for SOCKET_NAME now being malloced.
1160         (ticker_thread): Always use pth_event_occurred; it is again
1161         defined for all decent PTH versions.
1162         (handle_connections): New. Based on the gpg-agent code.
1163         (start_connection_thread): Ditto.
1164         (ticker_thread): Removed.
1165         (cleanup_sh): Removed.
1166         (main): Run the handler for the pipe server in a separate
1167         thread.  This replaces the old ticker thread.
1168         (scd_get_socket_name): New.
1169         * command.c (cmd_getinfo): New command GETINFO.
1170         (scd_command_handler): Renamed argument and changed code to use an
1171         already connected FD.
1172
1173 2005-05-15  Werner Koch  <wk@g10code.com>
1174
1175         * app.c, app-common.h, app-nks.c, app-p15.c, app-dinsig.c
1176         * app-openpgp.c: Change most function return types from int to
1177         gpg_error_t.
1178         * command.c (pin_cb): Ditto.
1179         * sc-copykeys.c (pincb): Ditto.
1180
1181         * app.c (lock_reader, unlock_reader): New.  Changed call handler
1182         wrappers to make use of these functions.
1183
1184 2005-05-07  Werner Koch  <wk@g10code.com>
1185
1186         * ccid-driver.c (do_close_reader): Don't do a reset before close.
1187         Some folks reported that it makes the SCR335 hang less often.
1188         Look at the source on how to re-enable it.
1189
1190 2005-04-27  Werner Koch  <wk@g10code.com>
1191
1192         * app-p15.c (micardo_mse): New.
1193         (do_sign): Call it.
1194         * iso7816.c (iso7816_manage_security_env): Allow passing DATA as
1195         NULL to indicate an empty Lc.
1196         * tlv.c (find_tlv): Check that a found object fits into the
1197         buffer.
1198         (find_tlv_unchecked): New as replacement for the old non-checking
1199         variant.
1200         * app.c (select_application): Keep on using the non-checking
1201         variant.
1202         * app-openpgp.c (get_one_do, dump_all_do): Ditto.
1203
1204         
1205         Removal of the old OpenSC based code.
1206         
1207         * app-p15.c: New.  Basic support for pkcs15 cards without OpenSC.
1208         There are quite a couple of things missing but at least I can use
1209         my old TCOS cards from the Aegypten-1 development for signing.
1210         * app.c (select_application): Detect pkcs15 applications.
1211         * Makefile.am (scdaemon_SOURCES): Removed card.c, card-common.h
1212         and card-p15.c because they are now obsolete. Added app-p15.c.
1213         Removed all OpenSC stuff.
1214         * command.c (do_reset, open_card, cmd_serialno, cmd_learn) 
1215         (cmd_readcert, cmd_readkey, cmd_pksign, cmd_pkdecrypt): Removed
1216         all special cases for the old card.c based mechanisms.
1217         * scdaemon.c, apdu.c: Removed all special cases for OpenSC.
1218
1219 2005-04-20  Werner Koch  <wk@g10code.com>
1220
1221         * command.c: Use GPG_ERR_LOCKED instead of EBUSY.
1222
1223 2005-04-14  Werner Koch  <wk@g10code.com>
1224
1225         * app-openpgp.c (retrieve_key_material): Rewritten.  Return a
1226         proper error code.
1227         (retrieve_next_token): Removed.
1228         (retrieve_fpr_from_card): Rewritten to make use of DO caching and
1229         to take the KEYNO as arg.
1230         (get_public_key): Renamed variable for clarity.
1231
1232 2005-04-12  Werner Koch  <wk@g10code.com>
1233
1234         Basic support for several sessions.
1235         
1236         * command.c (scd_command_handler): Replace the primary_connection
1237         stuff by a real connection list.  Release the local context on
1238         exit.
1239         (scd_update_reader_status_file): Update accordingly.  Send signal
1240         to all connections who registered an event signal.
1241         (cmd_lock, cmd_unlock, register_commands): New commands LOCK and
1242         UNLOCK.
1243         (cmd_setdata, cmd_pksign, cmd_pkauth, cmd_pkdecrypt, cmd_setattr) 
1244         (cmd_genkey, cmd_passwd, cmd_checkpin): Return an error if reader
1245         is locked.
1246         (do_reset): Handle locking.
1247         (open_card): Ditto.  Share the reader slot with other sessions.
1248         (get_reader_slot): New.
1249         (update_card_removed): New.  Use it in the TEST_CARD_REMOVAL macro.
1250
1251 2005-04-07  Werner Koch  <wk@g10code.com>
1252
1253         * app-openpgp.c (do_check_pin): Add hack to allow verification of
1254         CHV3.
1255         (get_public_key): Don't use gcry functions to create S-expressions.
1256         (do_deinit, do_readkey, do_genkey, send_keypair_info): Adjust for
1257         above change.
1258
1259 2005-03-29  Moritz Schulte  <moritz@g10code.com>
1260
1261         * app-openpgp.c (retrieve_fpr_from_card): New function.
1262         (retrieve_next_token): New function.
1263         (retrieve_key_material): New function.
1264         (get_public_key): Implement retrival of key through expernal
1265         helper (gpg) in case the openpgp card is not cooperative enough.
1266
1267 2005-03-16  Werner Koch  <wk@g10code.com>
1268
1269         * ccid-driver.c (parse_ccid_descriptor): Make SCM workaround
1270         reader type specific.
1271         (scan_or_find_devices): Do not check the interface subclass in the
1272         SPR532 kludge, as this depends on the firmware version.
1273         (ccid_get_atr): Get the Slot status first.  This solves the
1274         problem with readers hanging on recent Linux 2.6.x.
1275         (bulk_in): Add argument TIMEOUT and changed all callers to pass an
1276         appropriate one.  Change the standard timeout from 10 to 5 seconds.
1277         (ccid_slot_status): Add a retry code with an initial short timeout.
1278         (do_close_reader): Do an usb_reset before closing the reader.
1279
1280 2005-02-25  Werner Koch  <wk@g10code.com>
1281
1282         * app-openpgp.c (get_public_key): Make sure not to return negative
1283         numbers.
1284         (do_sign): Allow passing of indata with algorithm prefix.
1285         (do_auth): Allow OPENPGP.3 as an alternative ID.
1286
1287         * app.c (app_getattr): Return just the S/N but not the timestamp.
1288
1289 2005-02-24  Werner Koch  <wk@g10code.com>
1290
1291         * app.c (app_getattr): Return APPTYPE or SERIALNO type even if the
1292         application does dot support the getattr call.
1293
1294         * app-openpgp.c (get_one_do): Never try to get a non cacheable
1295         object from the cache.
1296         (get_one_do): Add new arg to return an error code.  Changed all
1297         callers.
1298         (do_getattr): Let it return a proper error code.
1299
1300         * app.c (select_application): Return an error code and the
1301         application context in an new arg.
1302         * command.c (open_card): Adjusted for that.  Don't use the
1303         fallback if no card is present.  Return an error if the card has
1304         been removed without a reset.
1305         (do_reset, cmd_serialno): Clear that error flag.
1306         (TEST_CARD_REMOVAL): New. Use it with all command handlers.
1307         (scd_update_reader_status_file): Set the error flag on all changes.
1308
1309         * scdaemon.c (ticker_thread): Termintate if a shutdown is pending.
1310
1311         * apdu.c: Added some PCSC error codes.
1312         (pcsc_error_to_sw): New.
1313         (reset_pcsc_reader, pcsc_get_status, pcsc_send_apdu) 
1314         (open_pcsc_reader): Do proper error code mapping.
1315
1316 2005-03-16  Werner Koch  <wk@g10code.com>
1317
1318         * ccid-driver.c (parse_ccid_descriptor): Make SCM workaround
1319         reader type specific.
1320         (scan_or_find_devices): Do not check the interface subclass in the
1321         SPR532 kludge, as this depends on the firmware version.
1322         (ccid_get_atr): Get the Slot status first.  This solves the
1323         problem with readers hanging on recent Linux 2.6.x.
1324
1325 2005-02-22  Werner Koch  <wk@g10code.com>
1326
1327         * app-openpgp.c (app_local_s): New field PK.
1328         (do_deinit, do_genkey, app_openpgp_storekey): Clear it.
1329         (get_public_key, send_keypair_info): New.
1330         (do_learn_status): Send KEYPAIR info
1331
1332         * app-common.h (app_ctx_t): Add function pointer READKEY.
1333         * app.c (app_readkey): New.
1334         * command.c (cmd_readkey): Use READKEY function if possible.
1335
1336 2005-01-26  Werner Koch  <wk@g10code.com>
1337
1338         * ccid-driver.c (parse_ccid_descriptor): Need the CSM workaround
1339         also for newer firmware versions.  Need to get a list of fixed
1340         firmware versions and use that.
1341
1342 2005-01-25  Werner Koch  <wk@g10code.com>
1343
1344         * apdu.c (apdu_send_le, apdu_send_direct): Fix some compiler
1345         warnings.
1346
1347         * app-openpgp.c (get_cached_data): New arg GET_IMMEDIATE to bypass
1348         the cache.  Changed all callers.
1349         (get_one_do): Bypass the cache if the value would have been read
1350         directly for v1.1 cards.It makes things a bit slower but obnly for
1351         1.0 cards and there are not that many cards out in the wild.  This
1352         is required to fix a caching bug when generating new keys; as a
1353         side effect of the retrieval of the the C4 DO from the 6E DO the
1354         cached fingerprint will get updated to the old value and later
1355         when signing the generated key the checking of the fingerprint
1356         fails because it won't match the new one.  Thanks to Moritz for
1357         analyzing this problem.
1358         (verify_chv3): Removed the CHV status reread logic because we
1359         won't cache the C4 DO anymore.
1360
1361 2004-12-28  Werner Koch  <wk@g10code.com>
1362
1363         * ccid-driver.c (find_endpoint): New.
1364         (scan_or_find_devices): Add new args to return endpoint info and
1365         interface number.
1366         (ccid_open_reader, ccid_shutdown_reader): Take care of these new
1367         args.
1368         (bulk_in, bulk_out): Use the correct endpoints.
1369         (ccid_transceive_apdu_level): New.
1370         (ccid_transceive): Divert to above.
1371         (parse_ccid_descriptor): Allow APDU level exchange mode.
1372         (do_close_reader): Pass the interface number to usb_release_interface.
1373
1374 2004-12-21  Werner Koch  <wk@g10code.com>
1375
1376         * scdaemon.c (main): Use default_homedir().
1377
1378 2004-12-18  Werner Koch  <wk@g10code.com>
1379
1380         * scdaemon.c (main) [W32]: Remove special Pth initialize..
1381
1382         * scdaemon.h (map_assuan_err): Define in terms of
1383         map_assuan_err_with_source.
1384
1385 2004-12-15  Werner Koch  <wk@g10code.com>
1386
1387         * scdaemon.c [W32]: Various hacks to make it run under W32.
1388
1389         * command.c (scd_update_reader_status_file) [W32]: Don't use kill.
1390
1391         * apdu.c [W32]: Disable use of pcsc_wrapper.
1392
1393         * Makefile.am (scdaemon_LDADD): Reorder libs.
1394         (sc_copykeys_LDADD): Add libassuan because it is needed for W32. 
1395
1396 2004-12-06  Werner Koch  <wk@g10code.com>
1397
1398         * Makefile.am (pkglib_PROGRAMS): Build only for W32.
1399
1400 2004-10-22  Werner Koch  <wk@g10code.com>
1401
1402         * app-openpgp.c (verify_chv3): The minium length for CHV3 is
1403         8. Changed string to match the other ones.
1404
1405 2004-10-21  Werner Koch  <wk@g10code.com>
1406
1407         * app-openpgp.c (do_sign): Replace asprintf by direct allocation.
1408         This avoids problems with missing vasprintf implementations in
1409         gnupg 1.4.
1410
1411         * app-common.h (app_openpgp_storekey: Add prototype. 
1412
1413 2004-10-20  Werner Koch  <wk@g10code.com>
1414
1415         * sc-investigate: Removed.
1416         * Makefile.am (sc_investigate): Removed.
1417         
1418         * pcsc-wrapper.c (load_pcsc_driver): Load get_status_change func.
1419         (handle_open): Succeed even without a present card.
1420         (handle_status, handle_reset): New.
1421         
1422         * apdu.c (apdu_open_reader): Load pcsc_get_status_change fucntion.
1423         (pcsc_get_status): Implemented.
1424         (reset_pcsc_reader): Implemented.
1425         (open_pcsc_reader): Succeed even with no card inserted.
1426         (open_ccid_reader): Set LAST_STATUS.
1427
1428         * iso7816.c (iso7816_select_application): Always use 0 for P1.
1429
1430 2004-10-18  Werner Koch  <wk@g10code.com>
1431
1432         * ccid-driver.c (ccid_get_atr): Reset T=1 state info.
1433
1434 2004-10-14  Werner Koch  <wk@g10code.com>
1435
1436         * app-openpgp.c (parse_login_data): New. 
1437         (app_select_openpgp): Call it.
1438         (do_setattr): Reparse it after change.
1439
1440 2004-10-06  Werner Koch  <wk@g10code.de>
1441
1442         * ccid-driver.c (ccid_open_reader): Store the vendor ID.
1443         (ccid_transceive_secure): New.
1444         (parse_ccid_descriptor): Workaround for an SCM reader problem.
1445
1446 2004-10-04  Werner Koch  <wk@g10code.de>
1447
1448         * ccid-driver.c (send_escape_cmd): New.
1449
1450 2004-09-30  Werner Koch  <wk@g10code.com>
1451
1452         * Makefile.am: Adjusted for gettext 0.14.
1453
1454         * app-openpgp.c (do_sign): Add the error string to the verify
1455         failed messages.
1456
1457 2004-09-27  Werner Koch  <wk@g10code.com>
1458
1459         From gnupg 1.3
1460
1461         * app-openpgp.c: Made all strings translatable.
1462         (verify_chv3) [GNUPG_MAJOR_VERSION]: Make opt.allow_admin
1463         available for use in gnupg 2. 
1464         (verify_chv3): Reimplemented countdown showing to use only
1465         functions from this module.  Flush the CVH status cache on a
1466         successful read.
1467         (get_one_do): Hack to bypass the cache for cards versions > 1.0.
1468         (store_fpr): Store the creation date for card version > 1.0.
1469
1470         * app-openpgp.c (app_openpgp_storekey): Call flush_cache.
1471         (get_cached_data): Move local data initialization to ..
1472         (app_select_openpgp): .. here. Read some flags for later use.
1473         (do_getattr): New read-only attribute EXTCAP.
1474         
1475         * apdu.c (open_pcsc_reader): Do not print empty reader string.
1476
1477         * ccid-driver.c (do_close_reader): Factored some code out from ...
1478         (ccid_close_reader): ..here.
1479         (ccid_shutdown_reader): New.
1480
1481         * apdu.c (apdu_shutdown_reader): New.
1482         (shutdown_ccid_reader): New.
1483
1484         * apdu.c (open_ccid_reader): New arg PORTSTR.  Pass it to
1485         ccid_open_reader.
1486         (apdu_open_reader): Pass portstr to open_ccid_reader.
1487         (apdu_open_reader): No fallback if a full CCID reader id has been
1488         given.
1489
1490         * ccid-driver.c (ccid_get_reader_list): New.
1491         (ccid_open_reader): Changed API to take a string for the reader.
1492         Removed al the cruft for the libusb development vesion which seems
1493         not to be maintained anymore and there are no packages anyway.
1494         The stable library works just fine.
1495         (struct ccid_reader_id_s): Deleted and replaced everywhere by a
1496         simple string.
1497         (usb_get_string_simple): Removed.
1498         (bulk_in): Do valgrind hack here and not just everywhere.
1499
1500         * ccid-driver.c (read_device_info): Removed.
1501         (make_reader_id, scan_or_find_devices): New.
1502         (ccid_open_reader): Simplified by make use of the new functions.
1503         (ccid_set_debug_level): New.  Changed the macros to make use of
1504         it.  It has turned out that it is often useful to enable debugging
1505         at runtime so I added this option.
1506
1507         From gnupg 1.3 - David Shaw  <dshaw@jabberwocky.com>
1508
1509         * app-openpgp.c (verify_chv3): Show a countdown of how many wrong
1510         admin PINs can be entered before the card is locked.
1511
1512         * app-openpgp.c (get_cached_data): Avoid mallocing zero since it
1513         breaks us when using --enable-m-guard.
1514
1515         * ccid-driver.c (usb_get_string_simple): Replacement function to
1516         work with older libusb.
1517
1518         * ccid-driver.c (read_device_info): Fix segfault when usb device
1519         is not accessible.
1520         (ccid_open_reader): Allow working with an even older version of
1521         libusb (usb_busses global instead of usb_get_busses()).
1522
1523 2004-09-11  Werner Koch  <wk@g10code.com>
1524
1525         * app-openpgp.c (app_select_openpgp): Its app_munge_serialno and
1526         not app_number_serialno.
1527
1528 2004-08-20  Werner Koch  <wk@g10code.de>
1529
1530         * app.c (select_application): Fixed serial number extraction and
1531         added the BMI card workaround.
1532         (app_munge_serialno): New.
1533         * app-openpgp.c (app_select_openpgp): Try munging serialno.
1534
1535 2004-08-05  Werner Koch  <wk@g10code.de>
1536
1537         * scdaemon.c (main): New option --disable-application.
1538         * app.c (is_app_allowed): New.
1539         (select_application): Use it to check for disabled applications.
1540
1541         * ccid-driver.h (CCID_DRIVER_ERR_ABORTED): New.
1542         * ccid-driver.c (ccid_open_reader): Support the stable 0.1 version
1543         of libusb.
1544         (ccid_get_atr): Handle short messages.
1545
1546         * apdu.c (my_rapdu_get_status): Implemented.
1547
1548 2004-07-27  Moritz Schulte  <moritz@g10code.com>
1549
1550         * apdu.c: Include <signal.h>.
1551
1552         * Makefile.am: Use @DL_LIBS@ instead of -ldl.
1553
1554 2004-07-22  Werner Koch  <wk@g10code.de>
1555
1556         * Makefile.am: Make OpenSC lib link after libgcrypt. Do not link
1557         to pth.
1558         * apdu.c: Don't use Pth if we use OpenSC.
1559         * sc-investigate.c, scdaemon.c: Disable use of pth if OpenSC is used. 
1560
1561         * scdaemon.c (main): Bumbed thread stack size up to 512k.
1562
1563 2004-07-16  Werner Koch  <wk@gnupg.org>
1564
1565         * apdu.c (reader_table_s):  Add function pointers for the backends.
1566         (apdu_close_reader, apdu_get_status, apdu_activate) 
1567         (send_apdu): Make use of them.
1568         (new_reader_slot): Intialize them to NULL.
1569         (dump_ccid_reader_status, ct_dump_reader_status): New.
1570         (dump_pcsc_reader_status): New.
1571         (open_ct_reader, open_pcsc_reader, open_ccid_reader) 
1572         (open_osc_reader, open_rapdu_reader): Intialize function pointers.
1573         (ct_activate_card, ct_send_apdu, pcsc_send_apdu, osc_send_apdu) 
1574         (error_string): Removed.  Replaced by apdu_strerror.
1575         (get_ccid_error_string): Removed.
1576         (ct_activate_card): Remove the unused loop.
1577         (reset_ct_reader): Implemented.
1578         (ct_send_apdu): Activate the card if not yet done.
1579         (pcsc_send_apdu): Ditto.
1580
1581 2004-07-15  Werner Koch  <wk@gnupg.org>
1582
1583         * ccid-driver.h: Add error codes.
1584         * ccid-driver.c: Implement more or less proper error codes all
1585         over the place.
1586
1587         * apdu.c (apdu_send_direct): New.
1588         (get_ccid_error_string): Add some error code mappings.
1589         (send_apdu): Pass error codes along for drivers already supporting
1590         them.
1591         (host_sw_string): New.
1592         (get_ccid_error_string): Use above.
1593         (send_apdu_ccid): Reset the reader if it has not yet been done.
1594         (open_ccid_reader): Don't care if the ATR can't be read.
1595         (apdu_activate_card): New.
1596         (apdu_strerror): New.
1597         (dump_reader_status): Only enable it with opt.VERBOSE.
1598         * iso7816.c (map_sw): Add mappings for the new error codes.
1599
1600 2004-07-02  Werner Koch  <wk@gnupg.org>
1601
1602         * apdu.c (open_ct_reader, open_pcsc_reader, open_ccid_reader)
1603         (reset_ccid_reader, open_osc_reader): Call dump_reader_status only
1604         in verbose mode.
1605
1606 2004-07-01  Werner Koch  <wk@gnupg.org>
1607
1608         * sc-investigate.c: Initialize Pth which is now required.
1609         (interactive_shell): New command "readpk".
1610
1611         * app-openpgp.c (do_getattr): Fix for sending CA-FPR.
1612
1613 2004-06-30  Werner Koch  <wk@gnupg.org>
1614
1615         * app-openpgp.c (app_openpgp_readkey): Fixed check for valid
1616         exponent.
1617
1618 2004-06-18  Werner Koch  <wk@g10code.com>
1619
1620         * sc-investigate.c (my_read_line): Renamed from read_line.
1621
1622 2004-06-16  Werner Koch  <wk@gnupg.org>
1623
1624         * apdu.c (osc_get_status): Fixed type in function name. Noted by
1625         Axel Thimm.  Yes, I didn't tested it with OpenSC :-(.
1626
1627 2004-04-28  Werner Koch  <wk@gnupg.org>
1628
1629         * app-openpgp.c (do_setattr): Sync FORCE_CHV1.
1630
1631 2004-04-27  Werner Koch  <wk@gnupg.org>
1632
1633         * app-common.h: Do not include ksba.h for gnupg 1.
1634
1635 2004-04-26  Werner Koch  <wk@gnupg.org>
1636
1637         * app-common.h: New members FNC.DEINIT and APP_LOCAL.
1638         * app.c (release_application): Call new deconstructor.
1639         * app-openpgp.c (do_deinit): New.
1640         (get_cached_data, flush_cache_item, flush_cache_after_error)
1641         (flush_cache): New.
1642         (get_one_do): Replaced arg SLOT by APP.  Make used of cached data.
1643         (verify_chv2, verify_chv3): Flush some cache item after error.
1644         (do_change_pin): Ditto.
1645         (do_sign): Ditto.
1646         (do_setattr): Flush cache item.
1647         (do_genkey): Flush the entire cache.
1648         (compare_fingerprint): Use cached data.
1649
1650         * scdaemon.c (main): Do the last change the usual way. This is so
1651         that we can easily test for versioned config files above.
1652
1653 2004-04-26  Marcus Brinkmann  <marcus@g10code.de>
1654
1655         * scdaemon.c (main): For now, always print default filename for
1656         --gpgconf-list, and never /dev/null.
1657
1658 2004-04-21  Werner Koch  <wk@gnupg.org>
1659
1660         * command.c (scd_update_reader_status_file): Send a signal back to
1661         the client.
1662         (option_handler): Parse the new event-signal option.
1663
1664         * scdaemon.c (handle_signal): Do not use SIGUSR{1,2} anymore for
1665         changing the verbosity.
1666
1667 2004-04-20  Werner Koch  <wk@gnupg.org>
1668
1669         * command.c (scd_update_reader_status_file): Write status files.
1670
1671         * app-help.c (app_help_read_length_of_cert): Fixed calculation of
1672         R_CERTOFF.
1673
1674         * pcsc-wrapper.c: New.
1675         * Makefile.am (pkglib_PROGRAMS): Install it here.
1676         * apdu.c (writen, readn): New.
1677         (open_pcsc_reader, pcsc_send_apdu, close_pcsc_reader): Use the
1678         pcsc-wrapper if we are using Pth.
1679         (apdu_send_le): Reinitialize RESULTLEN.  Handle SW_EOF_REACHED
1680         like SW_SUCCESS.
1681
1682 2004-04-19  Werner Koch  <wk@gnupg.org>
1683
1684         * ccid-driver.c (parse_ccid_descriptor): Store some of the reader
1685         features away.  New arg HANDLE
1686         (read_device_info): New arg HANDLE. Changed caller.
1687         (bulk_in): Handle time extension requests.
1688         (ccid_get_atr): Setup parameters and the IFSD.
1689         (compute_edc): New. Factored out code.
1690         (ccid_transceive): Use default NADs when required.
1691
1692 2004-04-14  Werner Koch  <wk@gnupg.org>
1693
1694         * scdaemon.h (server_control_s): Add member READER_SLOT.
1695         * scdaemon.c (scd_init_default_ctrl): Initialize READER_SLOT to -1.
1696         * command.c (open_card): Reuse an open slot.
1697         (reset_notify): Just reset the slot if supported by the reader.
1698         (do_reset): Factored code from above out.
1699         (scd_command_handler): Use it for cleanup.
1700
1701         * apdu.h: New pseudo stati SW_HOST_NOT_SUPPORTED,
1702         SW_HOST_LOCKING_FAILED and SW_HOST_BUSY.
1703         * iso7816.c (map_sw): Map it.
1704         
1705         * ccid-driver.c (ccid_slot_status): Add arg STATUSBITS.
1706         * apdu.c (apdu_get_status): New.
1707         (ct_get_status, pcsc_get_status, ocsc_get_status): New stubs.
1708         (get_status_ccid): New.
1709         (apdu_reset): New.
1710         (reset_ct_reader, reset_pcsc_reader, reset_osc_reader): New stubs.
1711         (reset_ccid_reader): New.
1712         (apdu_enum_reader): New.
1713         
1714         * apdu.c (lock_slot, trylock_slot, unlock_slot): New helpers.
1715         (new_reader_slot) [USE_GNU_PTH]: Init mutex.
1716         (apdu_reset, apdu_get_status, apdu_send_le): Run functions
1717         in locked mode.
1718
1719         * command.c (scd_update_reader_status_file): New.
1720         * scdaemon.c (handle_tick): Call it.
1721
1722 2004-04-13  Werner Koch  <wk@gnupg.org>
1723
1724         * scdaemon.c: Convert to a Pth application.
1725         (handle_signal, ticker_thread, handle_tick): New.
1726         (main): Fire up the ticker thread in server mode.
1727
1728 2004-03-23  Werner Koch  <wk@gnupg.org>
1729
1730         * scdaemon.c (main) <gpgconf_list>: Fixed output for pcsc_driver.
1731
1732 2004-03-17  Werner Koch  <wk@gnupg.org>
1733
1734         * tlv.c (parse_ber_header): Do not check for tag overflow - it
1735         does not make sense.  Simplified the check for length overflow.
1736
1737         * scdaemon.c (main) <gpgconf>: Fixed default value quoting.
1738
1739 2004-03-16  Werner Koch  <wk@gnupg.org>
1740
1741         * app-dinsig.c: Implemented. Based on app-nks.c and card-dinsig.c
1742         * app-nks.c (get_length_of_cert): Removed.
1743         * app-help.c: New.
1744         (app_help_read_length_of_cert): New.  Code taken from above.  New
1745         optional arg R_CERTOFF.
1746
1747         * card-dinsig.c: Removed.
1748         * card.c (card_get_serial_and_stamp): Do not bind to the old and
1749         never finsiged card-dinsig.c.
1750
1751         * iso7816.c (iso7816_read_binary): Allow for an NMAX > 254.
1752
1753 2004-03-11  Werner Koch  <wk@gnupg.org>
1754
1755         * scdaemon.h (out_of_core): Removed.  Replaced callers by standard
1756         gpg_error function.
1757
1758         * apdu.c, iso7816.c, ccid-driver.c [GNUPG_SCD_MAIN_HEADER]: Allow
1759         to include a header defined by the compiler.  This helps us to
1760         reuse the source in other software.
1761
1762 2004-03-10  Werner Koch  <wk@gnupg.org>
1763
1764         * iso7816.c (iso7816_read_record): New arg SHORT_EF.  Changed all
1765         callers.
1766
1767 2004-02-18  Werner Koch  <wk@gnupg.org>
1768
1769         * sc-investigate.c (main): Setup the used character set.
1770         * scdaemon.c (main): Ditto.
1771
1772         * scdaemon.c (set_debug): New.  Add option --debug-level.
1773         (main): Add option --gpgconf-list.
1774
1775 2004-02-12  Werner Koch  <wk@gnupg.org>
1776
1777         * Makefile.am: Include cmacros.am for common flags.
1778
1779 2004-01-29  Werner Koch  <wk@gnupg.org>
1780
1781         * command.c (reset_notify): Release the application context and
1782         close the reader.
1783
1784 2004-01-28  Werner Koch  <wk@gnupg.org>
1785
1786         * iso7816.c (iso7816_manage_security_env): New.
1787         (iso7816_decipher): Add PADIND argument.
1788
1789 2004-01-27  Werner Koch  <wk@gnupg.org>
1790
1791         * command.c (cmd_readcert, cmd_readkey): Work on a copy of LINE.
1792
1793         * app-common.h (app_ctx_s): Added readcert field.
1794         * app.c (app_readcert): New.
1795         * tlv.c (parse_ber_header): Added; taken from libksba.
1796
1797 2004-01-26  Werner Koch  <wk@gnupg.org>
1798
1799         * card.c (map_sc_err): Use SCD as the error source.
1800
1801         * command.c (open_card): ADD arg NAME to allow requesting a
1802         specific application.  Changed all callers.
1803         (cmd_serialno): Allow optional argument to select the desired
1804         application.
1805
1806         * app-nks.c: New. 
1807
1808         * scdaemon.h (opt): Add READER_PORT.
1809         * scdaemon.c (main): Set it here.
1810         * app.c (app_set_default_reader_port): Removed.
1811         (select_application): Add NAME arg and figure out a
1812         default serial number from the GDO. Add SLOT arg and remove all
1813         reader management.
1814         (release_application): New.
1815         (app_write_learn_status): Output an APPTYPE status line.
1816         * command.c (open_card): Adapt for select_application change.
1817         * app-openpgp.c (app_select_openpgp): Removed SN and SNLEN args
1818         and set it directly.  Changed all callers.
1819
1820 2004-01-25  Werner Koch  <wk@gnupg.org>
1821
1822         * iso7816.c (iso7816_select_application): P1 kludge for OpenPGP
1823         card.
1824         * app-openpgp.c (find_tlv): Factor out this function to ..
1825         * tlv.c, tlv.h: .. new.
1826
1827         * scdaemon.h: Introduced app_t and ctrl_t as the new types for APP
1828         and CTRL.
1829
1830 2004-01-21  Werner Koch  <wk@gnupg.org>
1831
1832         * apdu.c (apdu_send_le): Treat SW_EOF_REACHED as a warning.
1833
1834 2004-01-20  Werner Koch  <wk@gnupg.org>
1835
1836         * iso7816.c (iso7816_read_binary): New.
1837         (iso7816_select_file): New.
1838         (iso7816_list_directory): New.
1839
1840         * sc-investigate.c: Add option -i.
1841         (select_app, read_line, interactive_shell): New.
1842
1843 2004-01-16  Werner Koch  <wk@gnupg.org>
1844
1845         * apdu.h: Add SW_FILE_NOT_FOUND.
1846         * iso7816.c (map_sw): Map it to GPG_ERR_ENOENT.
1847         * iso7816.c (iso7816_select_file): New.
1848
1849         * app-dinsig.c: New file w/o any real code yet.
1850         * Makefile.am (scdaemon_SOURCES,sc_investigate_SOURCES): Add file.
1851
1852         * sc-investigate.c: Add option --disable-ccid.
1853
1854 2003-12-19  Werner Koch  <wk@gnupg.org>
1855
1856         * apdu.c (apdu_send_le): Send a get_response with the indicated
1857         length and not the 64 bytes we used for testing.
1858
1859         * app-openpgp.c (verify_chv2, verify_chv3, do_sign): Check the
1860         minimum length of the passphrase, so that we don't need to
1861         decrement the retry counter.
1862
1863 2003-12-17  Werner Koch  <wk@gnupg.org>
1864
1865         * card-p15.c (p15_enum_keypairs): Replaced KRC by RC.
1866         * card-dinsig.c (dinsig_enum_keypairs): Ditto.
1867
1868 2003-12-16  Werner Koch  <wk@gnupg.org>
1869
1870         * scdaemon.c (main): Set the prefixes for assuan logging.
1871
1872 2003-11-17  Werner Koch  <wk@gnupg.org>
1873
1874         * scdaemon.c, scdaemon.h: New options --allow-admin and --deny-admin.
1875         * app-openpgp.c (verify_chv3): Check it here.
1876
1877 2003-11-12  Werner Koch  <wk@gnupg.org>
1878
1879         Adjusted for API changes in Libksba.
1880
1881 2003-10-30  Werner Koch  <wk@gnupg.org>
1882
1883         * apdu.c (close_ct_reader, close_pcsc_reader): Implemented.
1884         (get_ccid_error_string): New.  Not very useful messages, though.
1885
1886 2003-10-25  Werner Koch  <wk@gnupg.org>
1887
1888         * ccid-driver.c (ccid_open_reader): Return an error if no USB
1889         devices are found.
1890
1891         * command.c (cmd_genkey, cmd_passwd): Fixed faulty use of
1892         !spacep().
1893
1894         * apdu.c (apdu_open_reader): Hacks for PC/SC under Windows.
1895
1896 2003-10-20  Werner Koch  <wk@gnupg.org>
1897
1898         * command.c (cmd_checkpin): New.
1899         (register_commands): Add command CHECKPIN.
1900         * app.c (app_check_pin): New.
1901         * app-openpgp.c (check_against_given_fingerprint): New. Factored
1902         out that code elsewhere.
1903         (do_check_pin): New.
1904
1905 2003-10-10  Werner Koch  <wk@gnupg.org>
1906
1907         * ccid-driver.c (ccid_close_reader): New.
1908
1909         * apdu.c (close_ccid_reader, close_ct_reader, close_csc_reader)
1910         (close_osc_reader, apdu_close_reader): New.  Not all are properly
1911         implemented yet.
1912
1913 2003-10-09  Werner Koch  <wk@gnupg.org>
1914
1915         * ccid-driver.c (ccid_transceive): Add T=1 chaining for sending.
1916
1917 2003-10-08  Werner Koch  <wk@gnupg.org>
1918
1919         * app-openpgp.c (do_getattr): Support SERIALNO and AID.
1920
1921 2003-10-01  Werner Koch  <wk@gnupg.org>
1922
1923         * ccid-driver.c: Detect GnuPG 1.3 and include appropriate files.
1924         * apdu.c: Ditto.
1925         * app-openpgp.c: Ditto.
1926         * iso7816.c: Ditto.
1927         (generate_keypair): Renamed to ..
1928         (do_generate_keypair): .. this.
1929         * app-common.h [GNUPG_MAJOR_VERSION]: New.
1930         * iso7816.h [GNUPG_MAJOR_VERSION]: Include cardglue.h
1931
1932 2003-09-30  Werner Koch  <wk@gnupg.org>
1933
1934         * command.c (cmd_getattr): New command GETATTR.
1935         * app.c (app_setattr): New.
1936         (do_getattr): New.
1937         (do_learn_status): Reimplemented in terms of do_getattr.
1938
1939         * app-openpgp.c (do_change_pin): Make sure CVH1 and CHV2 are
1940         always synced.
1941         (verify_chv2, verify_chv3): New. Factored out common code.
1942         (do_setattr, do_sign, do_auth, do_decipher): Change the names of
1943         the prompts to match that we have only 2 different PINs.
1944         (app_select_openpgp): Check whether the card enforced CHV1.
1945         (convert_sig_counter_value): New. Factor out code from
1946         get_sig_counter.
1947
1948 2003-09-28  Werner Koch  <wk@gnupg.org>
1949
1950         * app-openpgp.c (dump_all_do): Use gpg_err_code and not gpg_error.
1951
1952 2003-09-19  Werner Koch  <wk@gnupg.org>
1953
1954         * ccid-driver.c (parse_ccid_descriptor): New.
1955         (read_device_info): New.
1956         (ccid_open_reader): Check that the device has all required features.
1957
1958 2003-09-06  Werner Koch  <wk@gnupg.org>
1959
1960         * scdaemon.c (main): --pcsc-driver again defaults to pcsclite.
1961         David Corcoran was so kind to remove the GPL incompatible
1962         advertisng clause from pcsclite.
1963         * apdu.c (apdu_open_reader): Actually make pcsc-driver option work.
1964
1965 2003-09-05  Werner Koch  <wk@gnupg.org>
1966
1967         * ccid-driver.c: More work, data can now actually be retrieved.
1968         * ccid-driver.c, ccid-driver.h: Alternativley allow use under BSD
1969         conditions.
1970
1971 2003-09-02  Werner Koch  <wk@gnupg.org>
1972
1973         * scdaemon.c, scdaemon.h: New option --pcsc-ccid.
1974         * ccid-driver.c, ccid-driver.h: New but far from being useful.
1975         * Makefile.am: Add above.
1976         * apdu.c: Add support for that ccid driver.
1977         
1978 2003-08-26  Timo Schulz  <twoaday@freakmail.de>
1979
1980         * apdu.c (new_reader_slot): Only set 'is_osc' when OpenSC
1981         is used.
1982         
1983 2003-08-25  Werner Koch  <wk@gnupg.org>
1984
1985         * command.c (cmd_setattr): Use a copy of LINE.
1986         (cmd_genkey): Use a copy of KEYNO.
1987         (cmd_passwd): Use a copy of CHVNOSTR.
1988         (cmd_pksign, cmd_pkauth, cmd_pkdecrypt): s/strdup/xtrystrdup/.
1989
1990 2003-08-19  Werner Koch  <wk@gnupg.org>
1991
1992         * scdaemon.c, scdaemon.h: New option --pcsc-driver.
1993         * apdu.c (apdu_open_reader): Use that option here instead of a
1994         hardcoded one.
1995
1996 2003-08-18  Werner Koch  <wk@gnupg.org>
1997
1998         * Makefile.am: Add OPENSC_LIBS to all programs. 
1999
2000         * scdaemon.c, scdaemon.h: New option --disable-opensc.
2001         * card.c (card_open): Implement it.
2002         * apdu.c (open_osc_reader, osc_send_apdu): New.
2003         (apdu_open_reader) [HAVE_OPENSC]: Use the opensc driver if not
2004         disabled.
2005         (error_string) [HAVE_OPENSC]: Use sc_strerror.
2006         (send_apdu) [HAVE_OPENSC]: Call osc_apdu_send.
2007
2008         * card-p15.c (p15_enum_keypairs, p15_prepare_key): Adjusted for
2009         libgpg-error.
2010
2011 2003-08-14  Timo Schulz  <twoaday@freakmail.de>
2012
2013         * apdu.c (ct_activate_card): Change the code a little to avoid
2014         problems with other readers.
2015         * Always use 'dynload.h' instead of 'dlfcn.h'.
2016
2017 2003-08-05  Werner Koch  <wk@gnupg.org>
2018
2019         * app-openpgp.c (dump_all_do): Don't analyze constructed DOs after
2020         an error.
2021
2022 2003-08-04  Werner Koch  <wk@gnupg.org>
2023
2024         * app.c (app_set_default_reader_port): New.
2025         (select_application): Use it here.
2026         * scdaemon.c (main): and here.
2027         * sc-copykeys.c: --reader-port does now take a string.
2028         * sc-investigate.c, scdaemon.c: Ditto.
2029         * apdu.c (apdu_open_reader): Ditto.  Load pcsclite if no ctapi
2030         driver is configured.  Always include code for ctapi.
2031         (new_reader_slot): Don't test for already used ports and remove
2032         port arg.
2033         (open_pcsc_reader, pcsc_send_apdu, pcsc_error_string): New.
2034         (apdu_send_le): Changed RC to long to cope with PC/SC.
2035
2036         * scdaemon.c, scdaemon.h: New option --ctapi-driver.
2037         * sc-investigate.c, sc-copykeys.c: Ditto.
2038         
2039 2003-07-31  Werner Koch  <wk@gnupg.org>
2040
2041         * Makefile.am (scdaemon_LDADD): Added INTLLIBS.
2042
2043 2003-07-28  Werner Koch  <wk@gnupg.org>
2044
2045         * app-openpgp.c (do_setattr): Change implementation.  Allow all
2046         useful DOs.
2047
2048 2003-07-27  Werner Koch  <wk@gnupg.org>
2049
2050         Adjusted for gcry_mpi_print and gcry_mpi_scan API change.
2051
2052 2003-07-24  Werner Koch  <wk@gnupg.org>
2053
2054         * app-openpgp.c (do_learn_status): Print more status information.
2055         (app_select_openpgp): Store the card version.
2056         (store_fpr): Add argument card_version and fix DOs for old cards.
2057         (app_openpgp_storekey): Likewise.
2058
2059 2003-07-23  Werner Koch  <wk@gnupg.org>
2060
2061         * command.c (cmd_pkauth): New.
2062         (cmd_setdata): Check whether data was given at all to avoid
2063         passing 0 to malloc.
2064
2065         * app.c (app_auth): New.
2066         * app-openpgp.c (do_auth): New.
2067
2068 2003-07-22  Werner Koch  <wk@gnupg.org>
2069
2070         * command.c (cmd_passwd): New.
2071         * app.c (app_change_pin): New.
2072         * app-openpgp.c (do_change_pin): New.
2073         * iso7816.c (iso7816_reset_retry_counter): Implemented.
2074
2075         * sc-investigate.c (main): New option --gen-random.
2076         * iso7816.c (iso7816_get_challenge): Don't create APDUs with a
2077         length larger than 255.
2078
2079 2003-07-17  Werner Koch  <wk@gnupg.org>
2080
2081         * command.c (cmd_random): New command RANDOM.
2082
2083         * iso7816.c (map_sw): New. Use it in this file to return
2084         meaningful error messages.  Changed all public fucntions to return
2085         a gpg_error_t.
2086         (iso7816_change_reference_data): New.
2087         * apdu.c (apdu_open_reader): Use faked status words for soem
2088         system errors.
2089
2090 2003-07-16  Werner Koch  <wk@gnupg.org>
2091
2092         * apdu.c (apdu_send_simple): Use apdu_send_le so that we can
2093         specify not to send Le as it should be.
2094
2095 2003-07-15  Werner Koch  <wk@gnupg.org>
2096
2097         * Makefile.am: Add sc-copykeys program.
2098         * sc-copykeys.c: New.
2099         * app-openpgp.c (app_openpgp_storekey): New.
2100         (app_openpgp_cardinfo): New.
2101         (count_bits): New.
2102         (store_fpr): And use it here to get the actual length in bit.
2103
2104 2003-07-03  Werner Koch  <wk@gnupg.org>
2105
2106         * app-openpgp.c (do_setattr): Add setting of the URL.
2107         (app_select_openpgp): Dump card data only in very verbose mode.
2108         (do_decipher): New.
2109
2110 2003-07-02  Werner Koch  <wk@gnupg.org>
2111
2112         * app-openpgp.c (get_sig_counter): New.
2113         (do_sign): Print the signature counter and enable the PIN callback.
2114         (do_genkey): Implement the PIN callback. 
2115
2116 2003-07-01  Werner Koch  <wk@gnupg.org>
2117
2118         * app-openpgp.c (store_fpr): Fixed fingerprint calculation.
2119
2120 2003-06-26  Werner Koch  <wk@gnupg.org>
2121
2122         * app-openpgp.c (find_tlv): Fixed length header parsing.
2123
2124         * app.c (app_genkey): New.
2125         * command.c (cmd_genkey): New.
2126
2127 2003-06-25  Werner Koch  <wk@gnupg.org>
2128
2129         * command.c (percent_plus_unescape): New.
2130         (cmd_setattr): New.
2131
2132 2003-06-24  Werner Koch  <wk@gnupg.org>
2133
2134         * command.c (send_status_info): New.
2135
2136         * app-openpgp.c (app_select_openpgp): Replace SLOT arg by APP arg
2137         and setup the function pointers in APP on success. Changed callers.
2138         * app.c: New.
2139         * app-common.h: New.
2140         * scdaemon.h (APP): New type to handle applications.
2141         (server_control_s): Add an APP context field.
2142
2143         * command.c (cmd_serialno): Handle applications.
2144         (cmd_pksign): Ditto.
2145         (cmd_pkdecrypt): Ditto.
2146         (reset_notify): Ditto.
2147         (cmd_learn): For now return error for application contexts.
2148         (cmd_readcert): Ditto.
2149         (cmd_readkey): Ditto.
2150
2151 2003-06-04  Werner Koch  <wk@gnupg.org>
2152
2153         * card.c (map_sc_err): Renamed gpg_make_err to gpg_err_make.
2154
2155         Renamed error codes from INVALID to INV and removed _ERROR suffixes.
2156
2157 2003-06-03  Werner Koch  <wk@gnupg.org>
2158
2159         Changed all error codes in all files to the new libgpg-error scheme.
2160
2161         * scdaemon.h: Include gpg-error.h and errno.h
2162         * card.c (map_sc_err): Use unknown for the error source.
2163         * Makefile.am: Link with libgpg-error
2164
2165 2003-05-14  Werner Koch  <wk@gnupg.org>
2166
2167         * atr.c, atr.h: New.
2168         * sc-investigate.c: Dump the ATR in a human readable format.
2169
2170 2003-05-08  Werner Koch  <wk@gnupg.org>
2171
2172         * scdaemon.h (DBG_CARD_IO_VALUE): New.
2173
2174         * sc-investigate.c: New.
2175         * scdaemon.c (main): Removed --print-atr option.
2176
2177         * iso7816.c, iso7816.h, app-openpgp.c: New.
2178
2179 2003-04-29  Werner Koch  <wk@gnupg.org>
2180
2181         * scdaemon.c: New options --print-atr and --reader-port
2182         * apdu.c, apdu.h: New
2183
2184         * card.c, card-p15.c, card-dinsig.c: Allow build without OpenSC.
2185         
2186         * Makefile.am (LDFLAGS): Removed.
2187
2188         * command.c (register_commands): Adjusted for new Assuan semantics.
2189
2190 2002-08-21  Werner Koch  <wk@gnupg.org>
2191
2192         * scdaemon.c (main): New option --daemon so that the program is
2193         not accidently started in the background.
2194
2195 2002-08-16  Werner Koch  <wk@gnupg.org>
2196
2197         * scdaemon.c: Include i18n.h.
2198
2199         * card-common.h (struct p15_private_s): Forward declaration.  Add
2200         it to card_ctx_s.
2201         * card.c (card_close): Make sure private data is released.
2202         (card_enum_certs): New.
2203         * card-p15.c (p15_release_private_data): New.
2204         (init_private_data): New to work around an OpenSC weirdness.
2205         (p15_enum_keypairs): Do an OpenSC get_objects only once.
2206         (p15_enum_certs): New.
2207         (card_p15_bind): Bind new function.
2208         * command.c (cmd_learn): Return information about the certificates.
2209
2210 2002-08-09  Werner Koch  <wk@gnupg.org>
2211
2212         * card.c (card_get_serial_and_stamp): Use the tokeinfo serial
2213         number as a fallback. Add a special prefix for serial numbers.
2214
2215 2002-07-30  Werner Koch  <wk@gnupg.org>
2216
2217         Changes to cope with OpenSC 0.7.0:
2218         
2219         * card.c: Removed the check for the packed opensc version.
2220         Changed include file names of opensc.
2221         (map_sc_err): Adjusted error codes for new opensc version.
2222         * card-p15.c: Changed include filename of opensc.
2223         * card-dinsig.c: Ditto.
2224
2225         * card-p15.c (p15_decipher): Add flags argument to OpenSC call.
2226         
2227 2002-07-24  Werner Koch  <wk@gnupg.org>
2228
2229         * card.c (find_simple_tlv, find_iccsn): New.
2230         (card_get_serial_and_stamp): Improved serial number parser.
2231
2232 2002-06-27  Werner Koch  <wk@gnupg.org>
2233
2234         * scdaemon.c (main): Use GNUPG_DEFAULT_HOMEDIR constant.
2235
2236 2002-06-15  Werner Koch  <wk@gnupg.org>
2237
2238         * card-dinsig.c: Documented some stuff from the DIN norm.
2239
2240 2002-04-15  Werner Koch  <wk@gnupg.org>
2241
2242         * command.c (cmd_pksign, cmd_pkdecrypt): Use a copy of the key ID.
2243
2244 2002-04-12  Werner Koch  <wk@gnupg.org>
2245
2246         * scdaemon.c: New option --debug-sc N.
2247         * card.c (card_open): set it here.
2248
2249         * card-p15.c (p15_prepare_key): Factored out common code from ...
2250         (p15_sign, p15_decipher): here and made the decryption work the
2251         regular way.
2252
2253 2002-04-10  Werner Koch  <wk@gnupg.org>
2254
2255         * card.c (card_open): Return immediately when no reader is available.
2256
2257 2002-03-27  Werner Koch  <wk@gnupg.org>
2258
2259         * card.c (card_open, card_close): Adjusted for changes in OpenSC.
2260
2261 2002-03-10  Werner Koch  <wk@gnupg.org>
2262
2263         * card-p15.c, card-dinsig.c, card-common.h: New.
2264         * card.c: Factored most code out to the new modules, so that we
2265         can better support different types of card applications.
2266
2267 2002-01-26  Werner Koch  <wk@gnupg.org>
2268
2269         * scdaemon.c scdaemon.h, command.c: New. Based on the code from
2270         the gpg-agent.
2271
2272         
2273  Copyright 2002, 2003, 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
2274
2275  This file is free software; as a special exception the author gives
2276  unlimited permission to copy and/or distribute it, with or without
2277  modifications, as long as this notice is preserved.
2278
2279  This file is distributed in the hope that it will be useful, but
2280  WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
2281  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.