Fix discarded const qualifier in previous patch

Related: RHEL-22607
This commit is contained in:
Michal Domonkos 2024-08-13 16:18:01 +02:00
parent b082297b5f
commit ad0cd9e4d2
2 changed files with 29 additions and 10 deletions

View File

@ -1,23 +1,39 @@
From 331afbf2b6b32582b29ceadcd37b43a4f905b7f4 Mon Sep 17 00:00:00 2001 From f6ffaacbbf7f5aca45139a612c5dd8db3f2094dc Mon Sep 17 00:00:00 2001
From: Michal Domonkos <mdomonko@redhat.com> From: Michal Domonkos <mdomonko@redhat.com>
Date: Mon, 5 Aug 2024 14:40:57 +0200 Date: Mon, 5 Aug 2024 14:40:57 +0200
Subject: [PATCH] Skip to hashed subpacket data directly Subject: [PATCH] Skip to hashed subpacket data directly
Make OpenScanHub grok the bigger picture here, instead of producing a Let OpenScanHub grok the bigger picture instead of producing a spurious
spurious overrun warning for v->hashlen when we're dereferencing p overrun warning for v->hashlen when we're dereferencing p later.
later.
Casting the v pointer back to uint8_t is unnecessary when we could just
use h directly but it's done this way in the if branch for pgp version 3
in this function as well as in pgpPrtKey() so copy that, just for the
sake of consistency.
Along the same lines (consistency), change the p pointer to a const
pointer.
No functional change. No functional change.
Resolves: RHEL-22607 Resolves: RHEL-22607
--- ---
rpmio/rpmpgp.c | 3 +-- rpmio/rpmpgp.c | 5 ++---
1 file changed, 1 insertion(+), 2 deletions(-) 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/rpmio/rpmpgp.c b/rpmio/rpmpgp.c diff --git a/rpmio/rpmpgp.c b/rpmio/rpmpgp.c
index d0688ebe9..6a7049954 100644 index d0688ebe9..6f044eb1b 100644
--- a/rpmio/rpmpgp.c --- a/rpmio/rpmpgp.c
+++ b/rpmio/rpmpgp.c +++ b/rpmio/rpmpgp.c
@@ -565,7 +565,7 @@ static int pgpPrtSig(pgpTag tag, const uint8_t *h, size_t hlen,
pgpDigParams _digp)
{
uint8_t version = 0;
- uint8_t * p;
+ const uint8_t * p;
unsigned int plen;
int rc = 1;
@@ -618,10 +618,9 @@ static int pgpPrtSig(pgpTag tag, const uint8_t *h, size_t hlen, @@ -618,10 +618,9 @@ static int pgpPrtSig(pgpTag tag, const uint8_t *h, size_t hlen,
pgpPrtVal(" ", pgpSigTypeTbl, v->sigtype); pgpPrtVal(" ", pgpSigTypeTbl, v->sigtype);
pgpPrtNL(); pgpPrtNL();
@ -26,10 +42,10 @@ index d0688ebe9..6a7049954 100644
if (pgpGet(v->hashlen, sizeof(v->hashlen), h + hlen, &plen)) if (pgpGet(v->hashlen, sizeof(v->hashlen), h + hlen, &plen))
return 1; return 1;
- p += sizeof(v->hashlen); - p += sizeof(v->hashlen);
+ p = h + sizeof(*v); + p = ((uint8_t *)v) + sizeof(*v);
if ((p + plen) > (h + hlen)) if ((p + plen) > (h + hlen))
return 1; return 1;
-- --
2.45.2 2.46.0

View File

@ -32,7 +32,7 @@
%global rpmver 4.16.1.3 %global rpmver 4.16.1.3
#global snapver rc1 #global snapver rc1
%global rel 33 %global rel 34
%global sover 9 %global sover 9
%global srcver %{rpmver}%{?snapver:-%{snapver}} %global srcver %{rpmver}%{?snapver:-%{snapver}}
@ -665,6 +665,9 @@ fi
%doc doc/librpm/html/* %doc doc/librpm/html/*
%changelog %changelog
* Tue Aug 13 2024 Michal Domonkos <mdomonko@redhat.com> - 4.16.1.3-34
- Fix discarded const qualifier in previous patch (RHEL-22607)
* Mon Aug 05 2024 Michal Domonkos <mdomonko@redhat.com> - 4.16.1.3-33 * Mon Aug 05 2024 Michal Domonkos <mdomonko@redhat.com> - 4.16.1.3-33
- Fix root relocation regression (RHEL-28967) - Fix root relocation regression (RHEL-28967)
- Don't confuse OpenScanHub with false array overrun (RHEL-22607) - Don't confuse OpenScanHub with false array overrun (RHEL-22607)