mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-10 13:04:23 +01:00
scd: Fix flushing of CA-FPR data objects
* scd/app-openpgp.c (do_setattr): Add new table item to flush a different tag. -- For whatever reasons the OpenPGP card reads the 3 CA fingerprints from one object but sets them individually using 3 different tags. The cache flushing was not prepared for this and so a changed CA fingerprint showed only up after a card reset. This patch fixes it. Signed-off-by: Werner Koch <wk@gnupg.org> (cherry picked from commit c9f4c1f0de06672c6ae2b793d86cc001d131f9a6) Fixed conflict by removing the UIF-* entries from the table.
This commit is contained in:
parent
77a285a0a9
commit
e7eafe1019
@ -2439,29 +2439,30 @@ do_setattr (app_t app, const char *name,
|
||||
static struct {
|
||||
const char *name;
|
||||
int tag;
|
||||
int flush_tag; /* The tag which needs to be flushed or 0. */
|
||||
int need_chv;
|
||||
int special;
|
||||
unsigned int need_v2:1;
|
||||
} table[] = {
|
||||
{ "DISP-NAME", 0x005B, 3 },
|
||||
{ "LOGIN-DATA", 0x005E, 3, 2 },
|
||||
{ "DISP-LANG", 0x5F2D, 3 },
|
||||
{ "DISP-SEX", 0x5F35, 3 },
|
||||
{ "PUBKEY-URL", 0x5F50, 3 },
|
||||
{ "CHV-STATUS-1", 0x00C4, 3, 1 },
|
||||
{ "CA-FPR-1", 0x00CA, 3 },
|
||||
{ "CA-FPR-2", 0x00CB, 3 },
|
||||
{ "CA-FPR-3", 0x00CC, 3 },
|
||||
{ "PRIVATE-DO-1", 0x0101, 2 },
|
||||
{ "PRIVATE-DO-2", 0x0102, 3 },
|
||||
{ "PRIVATE-DO-3", 0x0103, 2 },
|
||||
{ "PRIVATE-DO-4", 0x0104, 3 },
|
||||
{ "CERT-3", 0x7F21, 3, 0, 1 },
|
||||
{ "SM-KEY-ENC", 0x00D1, 3, 0, 1 },
|
||||
{ "SM-KEY-MAC", 0x00D2, 3, 0, 1 },
|
||||
{ "KEY-ATTR", 0, 0, 3, 1 },
|
||||
{ "AESKEY", 0x00D5, 3, 0, 1 },
|
||||
{ "KDF", 0x00F9, 3, 4, 1 },
|
||||
{ "DISP-NAME", 0x005B, 0, 3 },
|
||||
{ "LOGIN-DATA", 0x005E, 0, 3, 2 },
|
||||
{ "DISP-LANG", 0x5F2D, 0, 3 },
|
||||
{ "DISP-SEX", 0x5F35, 0, 3 },
|
||||
{ "PUBKEY-URL", 0x5F50, 0, 3 },
|
||||
{ "CHV-STATUS-1", 0x00C4, 0, 3, 1 },
|
||||
{ "CA-FPR-1", 0x00CA, 0x00C6, 3 },
|
||||
{ "CA-FPR-2", 0x00CB, 0x00C6, 3 },
|
||||
{ "CA-FPR-3", 0x00CC, 0x00C6, 3 },
|
||||
{ "PRIVATE-DO-1", 0x0101, 0, 2 },
|
||||
{ "PRIVATE-DO-2", 0x0102, 0, 3 },
|
||||
{ "PRIVATE-DO-3", 0x0103, 0, 2 },
|
||||
{ "PRIVATE-DO-4", 0x0104, 0, 3 },
|
||||
{ "CERT-3", 0x7F21, 0, 3, 0, 1 },
|
||||
{ "SM-KEY-ENC", 0x00D1, 0, 3, 0, 1 },
|
||||
{ "SM-KEY-MAC", 0x00D2, 0, 3, 0, 1 },
|
||||
{ "KEY-ATTR", 0, 0, 0, 3, 1 },
|
||||
{ "AESKEY", 0x00D5, 0, 3, 0, 1 },
|
||||
{ "KDF", 0x00F9, 0, 3, 4, 1 },
|
||||
{ NULL, 0 }
|
||||
};
|
||||
int exmode;
|
||||
@ -2493,7 +2494,8 @@ do_setattr (app_t app, const char *name,
|
||||
/* Flush the cache before writing it, so that the next get operation
|
||||
will reread the data from the card and thus get synced in case of
|
||||
errors (e.g. data truncated by the card). */
|
||||
flush_cache_item (app, table[idx].tag);
|
||||
flush_cache_item (app, table[idx].flush_tag? table[idx].flush_tag
|
||||
/* */ : table[idx].tag);
|
||||
|
||||
if (app->app_local->cardcap.ext_lc_le && valuelen > 254)
|
||||
exmode = 1; /* Use extended length w/o a limit. */
|
||||
|
Loading…
x
Reference in New Issue
Block a user