blob: 5081930038b3b4a54858e5ab39fb7ec9f516b157 (
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
|
From 7f4c17e26065d8194a2512f2982c245afa0e7e40 Mon Sep 17 00:00:00 2001
From: Mahesh Bodapati <mbodapat@xilinx.com>
Date: Wed, 17 Jun 2020 21:20:26 +0530
Subject: [PATCH 27/34] [Patch,MicroBlaze] : improper address mapping of
PROVIDE directive symbols[DTOR_END] are causing runtime loops and we don't
need to override PROVIDE symbols if symbols are defined in libraries and
linker so I am disabling override for PROVIDE symbols.
---
ld/ldlang.c | 12 +++++++++---
1 file changed, 9 insertions(+), 3 deletions(-)
diff --git a/ld/ldlang.c b/ld/ldlang.c
index f12c09633a7..4a71abc7cbc 100644
--- a/ld/ldlang.c
+++ b/ld/ldlang.c
@@ -3692,10 +3692,16 @@ open_input_bfds (lang_statement_union_type *s, enum open_bfd_mode mode)
plugin_insert = NULL;
#endif
break;
+ /* This is from a --defsym on the command line. */
case lang_assignment_statement_enum:
- if (s->assignment_statement.exp->type.node_class != etree_assert)
- exp_fold_tree_no_dot (s->assignment_statement.exp);
- break;
+ if (s->assignment_statement.exp->type.node_class != etree_assert)
+ {
+ if(!(s->assignment_statement.exp->assign.defsym) && (s->assignment_statement.exp->type.node_class == etree_provide))
+ ;
+ else
+ exp_fold_tree_no_dot (s->assignment_statement.exp);
+ }
+ break;
default:
break;
}
--
2.37.1 (Apple Git-137.1)
|