mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-24 15:17:02 +01:00
g10/mainproc: avoid extra hash contexts when decrypting AEAD input
* g10/mainproc.c (mainproc_context): New member 'seen_pkt_encrypted_aead'. (release_list): Clear 'seen_pkt_encrypted_aead'. (proc_encrypted): Set 'seen_pkt_encrypted_aead'. (have_seen_pkt_encrypted_aead): New. (proc_plaintext): Do not enable extra hash contexts when decryption AEAD input. -- Signed-off-by: Jussi Kivilinna <jussi.kivilinna@iki.fi>
This commit is contained in:
parent
643ec7c642
commit
b46382dd47
@ -86,6 +86,7 @@ struct mainproc_context
|
|||||||
int trustletter; /* Temporary usage in list_node. */
|
int trustletter; /* Temporary usage in list_node. */
|
||||||
ulong symkeys; /* Number of symmetrically encrypted session keys. */
|
ulong symkeys; /* Number of symmetrically encrypted session keys. */
|
||||||
struct pubkey_enc_list *pkenc_list; /* List of encryption packets. */
|
struct pubkey_enc_list *pkenc_list; /* List of encryption packets. */
|
||||||
|
int seen_pkt_encrypted_aead; /* PKT_ENCRYPTED_AEAD packet seen. */
|
||||||
struct {
|
struct {
|
||||||
unsigned int sig_seen:1; /* Set to true if a signature packet
|
unsigned int sig_seen:1; /* Set to true if a signature packet
|
||||||
has been seen. */
|
has been seen. */
|
||||||
@ -137,6 +138,7 @@ release_list( CTX c )
|
|||||||
c->any.data = 0;
|
c->any.data = 0;
|
||||||
c->any.uncompress_failed = 0;
|
c->any.uncompress_failed = 0;
|
||||||
c->last_was_session_key = 0;
|
c->last_was_session_key = 0;
|
||||||
|
c->seen_pkt_encrypted_aead = 0;
|
||||||
xfree (c->dek);
|
xfree (c->dek);
|
||||||
c->dek = NULL;
|
c->dek = NULL;
|
||||||
}
|
}
|
||||||
@ -536,6 +538,9 @@ proc_encrypted (CTX c, PACKET *pkt)
|
|||||||
int result = 0;
|
int result = 0;
|
||||||
int early_plaintext = literals_seen;
|
int early_plaintext = literals_seen;
|
||||||
|
|
||||||
|
if (pkt->pkttype == PKT_ENCRYPTED_AEAD)
|
||||||
|
c->seen_pkt_encrypted_aead = 1;
|
||||||
|
|
||||||
if (early_plaintext)
|
if (early_plaintext)
|
||||||
{
|
{
|
||||||
log_info (_("WARNING: multiple plaintexts seen\n"));
|
log_info (_("WARNING: multiple plaintexts seen\n"));
|
||||||
@ -704,7 +709,6 @@ proc_encrypted (CTX c, PACKET *pkt)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (!result)
|
if (!result)
|
||||||
result = decrypt_data (c->ctrl, c, pkt->pkt.encrypted, c->dek );
|
result = decrypt_data (c->ctrl, c, pkt->pkt.encrypted, c->dek );
|
||||||
|
|
||||||
@ -804,6 +808,21 @@ proc_encrypted (CTX c, PACKET *pkt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
have_seen_pkt_encrypted_aead( CTX c )
|
||||||
|
{
|
||||||
|
CTX cc;
|
||||||
|
|
||||||
|
for (cc = c; cc; cc = cc->anchor)
|
||||||
|
{
|
||||||
|
if (cc->seen_pkt_encrypted_aead)
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
proc_plaintext( CTX c, PACKET *pkt )
|
proc_plaintext( CTX c, PACKET *pkt )
|
||||||
{
|
{
|
||||||
@ -874,7 +893,7 @@ proc_plaintext( CTX c, PACKET *pkt )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!any && !opt.skip_verify)
|
if (!any && !opt.skip_verify && !have_seen_pkt_encrypted_aead(c))
|
||||||
{
|
{
|
||||||
/* This is for the old GPG LITERAL+SIG case. It's not legal
|
/* This is for the old GPG LITERAL+SIG case. It's not legal
|
||||||
according to 2440, so hopefully it won't come up that often.
|
according to 2440, so hopefully it won't come up that often.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user