From: Ulf Hermann Date: Thu, 20 Apr 2017 14:54:26 +0000 (+0200) Subject: Make elf section sorting more deterministic X-Git-Tag: elfutils-0.169~1 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d7e1e08f68afd6c3363231e3100fa0124a2d5cb6;p=thirdparty%2Felfutils.git Make elf section sorting more deterministic At least one test (dwfl-addr-sect) depends on the order of elf sections with equal addresses. This is not guaranteed by the code. Compare also by end address and section index to tell entries apart. Signed-off-by: Ulf Hermann Signed-off-by: Mark Wielaard --- diff --git a/libdwfl/ChangeLog b/libdwfl/ChangeLog index 859b2ff56..9bce6b1ee 100644 --- a/libdwfl/ChangeLog +++ b/libdwfl/ChangeLog @@ -1,3 +1,9 @@ +2017-04-20 Ulf Hermann + Mark Wielaard + + * derelocate.c (compare_secrefs): Compare by end address and then by + section number if addresses are equal. + 2017-04-20 Ulf Hermann Mark Wielaard diff --git a/libdwfl/derelocate.c b/libdwfl/derelocate.c index e5c3e12e1..2f80b20fc 100644 --- a/libdwfl/derelocate.c +++ b/libdwfl/derelocate.c @@ -67,7 +67,13 @@ compare_secrefs (const void *a, const void *b) if ((*p1)->start > (*p2)->start) return 1; - return 0; + if ((*p1)->end < (*p2)->end) + return -1; + if ((*p1)->end > (*p2)->end) + return 1; + + /* Same start/end, then just compare which section came first. */ + return elf_ndxscn ((*p1)->scn) - elf_ndxscn ((*p2)->scn); } static int