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