hc
2023-12-11 d2ccde1c8e90d38cee87a1b0309ad2827f3fd30d
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
From 4face627f2a2e113f169f4358f44adc54bbf858d Mon Sep 17 00:00:00 2001
From: Changbin Du <changbin.du@gmail.com>
Date: Tue, 28 Jan 2020 23:29:38 +0800
Subject: [PATCH 2/7] perf: Make perf able to build with latest libbfd
 
libbfd has changed the bfd_section_* macros to inline functions
bfd_section_<field> since 2019-09-18. See below two commits:
  o http://www.sourceware.org/ml/gdb-cvs/2019-09/msg00064.html
  o https://www.sourceware.org/ml/gdb-cvs/2019-09/msg00072.html
 
This fix make perf able to build with both old and new libbfd.
 
Signed-off-by: Changbin Du <changbin.du@gmail.com>
Acked-by: Jiri Olsa <jolsa@redhat.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lore.kernel.org/lkml/20200128152938.31413-1-changbin.du@gmail.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
(cherry picked from commit 0ada120c883d4f1f6aafd01cf0fbb10d8bbba015)
---
 tools/perf/util/srcline.c | 16 +++++++++++++++-
 1 file changed, 15 insertions(+), 1 deletion(-)
 
diff --git a/tools/perf/util/srcline.c b/tools/perf/util/srcline.c
index b4db3f48e3b0..2853d4728ab9 100644
--- a/tools/perf/util/srcline.c
+++ b/tools/perf/util/srcline.c
@@ -86,16 +86,30 @@ static void find_address_in_section(bfd *abfd, asection *section, void *data)
     bfd_vma pc, vma;
     bfd_size_type size;
     struct a2l_data *a2l = data;
+    flagword flags;
 
     if (a2l->found)
         return;
 
-    if ((bfd_get_section_flags(abfd, section) & SEC_ALLOC) == 0)
+#ifdef bfd_get_section_flags
+    flags = bfd_get_section_flags(abfd, section);
+#else
+    flags = bfd_section_flags(section);
+#endif
+    if ((flags & SEC_ALLOC) == 0)
         return;
 
     pc = a2l->addr;
+#ifdef bfd_get_section_vma
     vma = bfd_get_section_vma(abfd, section);
+#else
+    vma = bfd_section_vma(section);
+#endif
+#ifdef bfd_get_section_size
     size = bfd_get_section_size(section);
+#else
+    size = bfd_section_size(section);
+#endif
 
     if (pc < vma || pc >= vma + size)
         return;
-- 
2.20.1