From 6015a10899d38110bced4ca7e9b758b409a2f062 Mon Sep 17 00:00:00 2001 From: Qing He Date: Fri, 27 May 2011 17:03:18 +0800 Subject: rpm: fix fprint pointer issue [YOCTO #1030] (From OE-Core rev: bc4b86639a713c877dbe5e0f984873915d1578d4) Signed-off-by: Qing He Signed-off-by: Richard Purdie --- .../rpm/rpm/fprint-pointer-fix.patch | 35 ++++++++++++++++++++++ meta/recipes-devtools/rpm/rpm_5.4.0.bb | 3 +- 2 files changed, 37 insertions(+), 1 deletion(-) create mode 100644 meta/recipes-devtools/rpm/rpm/fprint-pointer-fix.patch (limited to 'meta/recipes-devtools/rpm') diff --git a/meta/recipes-devtools/rpm/rpm/fprint-pointer-fix.patch b/meta/recipes-devtools/rpm/rpm/fprint-pointer-fix.patch new file mode 100644 index 0000000000..87a92eb9a1 --- /dev/null +++ b/meta/recipes-devtools/rpm/rpm/fprint-pointer-fix.patch @@ -0,0 +1,35 @@ +Upstream-Status: Submitted + +From: Qing He +Subject: [PATCH] rpm 5.4.0: Fix pointer mishandling + +In fpLookupSubdir, data returned by hash should be of type +"struct rpmffi_s **" instead of "struct rpmffi_s *" to avoid +segfault. + +Signed-off-by: Qing He + +diff --git a/rpmdb/fprint.c b/rpmdb/fprint.c +index 0e76148..82b8f45 100644 +--- a/rpmdb/fprint.c ++++ b/rpmdb/fprint.c +@@ -333,7 +333,7 @@ restart: + *te = '\0'; + + while (te < se) { +- struct rpmffi_s * recs; ++ struct rpmffi_s ** recs; + int numRecs; + int i; + +@@ -346,8 +346,8 @@ restart: + const char * link; + int fx; + +- fx = recs[i].fileno; +- fi = recs[i].p->fi; ++ fx = recs[i]->fileno; ++ fi = recs[i]->p->fi; + flink = fi->flinks[fx]; + if (!(flink && *flink != '\0')) + continue; diff --git a/meta/recipes-devtools/rpm/rpm_5.4.0.bb b/meta/recipes-devtools/rpm/rpm_5.4.0.bb index ff55469d20..d3f85f22a1 100644 --- a/meta/recipes-devtools/rpm/rpm_5.4.0.bb +++ b/meta/recipes-devtools/rpm/rpm_5.4.0.bb @@ -43,7 +43,7 @@ LICENSE = "LGPL 2.1" LIC_FILES_CHKSUM = "file://COPYING.LIB;md5=2d5025d4aa3495befef8f17206a5b0a1" DEPENDS = "bzip2 zlib python perl db openssl elfutils expat libpcre attr acl popt" -PR = "r15" +PR = "r16" # rpm2cpio is a shell script, which is part of the rpm src.rpm. It is needed # in order to extract the distribution SRPM into a format we can extract... @@ -57,6 +57,7 @@ SRC_URI = "http://www.rpm5.org/files/rpm/rpm-5.4/rpm-5.4.0-0.20101229.src.rpm;ex file://rpm-nofsync.patch \ file://rpm-solvedb.patch \ file://rpm-tools-mtree-LDFLAGS.patch \ + file://fprint-pointer-fix.patch \ " # file://hdraddorappend.patch \ -- cgit v1.2.3-54-g00ecf