summaryrefslogtreecommitdiffstats
path: root/meta/recipes-devtools/elfutils/files/0002-Fix-elf_cvt_gunhash-if-dest-and-src-are-same.patch
blob: be48ef010bfecca41c5b3b2b2f9d4a3d94298fb6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
From 1643d793761216252bb654e28aaa5b8eb1536bca Mon Sep 17 00:00:00 2001
From: Hongxu Jia <hongxu.jia@windriver.com>
Date: Tue, 15 Aug 2017 17:13:59 +0800
Subject: [PATCH] Fix elf_cvt_gunhash if dest and src are same.

Upstream-Status: Pending

The 'dest' and 'src' can be same, we need to save the value of src32[2]
before swaping it.

Signed-off-by: Baoshan Pang <BaoShan.Pang@windriver.com>

Rebase to 0.170
Signed-off-by: Hongxu Jia <hongxu.jia@windriver.com>

---
 libelf/gnuhash_xlate.h | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/libelf/gnuhash_xlate.h b/libelf/gnuhash_xlate.h
index 6faf113..04d9ca1 100644
--- a/libelf/gnuhash_xlate.h
+++ b/libelf/gnuhash_xlate.h
@@ -40,6 +40,7 @@ elf_cvt_gnuhash (void *dest, const void *src, size_t len, int encode)
      words.  We must detangle them here.   */
   Elf32_Word *dest32 = dest;
   const Elf32_Word *src32 = src;
+  Elf32_Word save_src32_2 = src32[2]; // dest could be equal to src
 
   /* First four control words, 32 bits.  */
   for (unsigned int cnt = 0; cnt < 4; ++cnt)
@@ -50,7 +51,7 @@ elf_cvt_gnuhash (void *dest, const void *src, size_t len, int encode)
       len -= 4;
     }
 
-  Elf32_Word bitmask_words = encode ? src32[2] : dest32[2];
+  Elf32_Word bitmask_words = encode ? save_src32_2 : dest32[2];
 
   /* Now the 64 bit words.  */
   Elf64_Xword *dest64 = (Elf64_Xword *) &dest32[4];