aboutsummaryrefslogtreecommitdiff
path: root/gas/config
diff options
context:
space:
mode:
authorBob Wilson <bob.wilson@acm.org>2007-12-12 21:16:47 +0000
committerBob Wilson <bob.wilson@acm.org>2007-12-12 21:16:47 +0000
commit8e6bc631a97c9cbf7b267b02bac14ffbc928b723 (patch)
tree41fb25813f375674694043005643960ac59922ac /gas/config
parentc46082c8d595fcaa9e6df24e7dee18de6bc33354 (diff)
downloadgdb-8e6bc631a97c9cbf7b267b02bac14ffbc928b723.zip
gdb-8e6bc631a97c9cbf7b267b02bac14ffbc928b723.tar.gz
gdb-8e6bc631a97c9cbf7b267b02bac14ffbc928b723.tar.bz2
* config/tc-xtensa.c (xg_symbolic_immeds_fit): Do not relax calls to weak symbols if longcalls are disabled.
Diffstat (limited to 'gas/config')
-rw-r--r--gas/config/tc-xtensa.c24
1 files changed, 10 insertions, 14 deletions
diff --git a/gas/config/tc-xtensa.c b/gas/config/tc-xtensa.c
index 699eb7c..051f79f 100644
--- a/gas/config/tc-xtensa.c
+++ b/gas/config/tc-xtensa.c
@@ -3235,23 +3235,19 @@ xg_symbolic_immeds_fit (const TInsn *insn,
|| xtensa_operand_is_PCrelative (isa, insn->opcode, i) == 0)
return FALSE;
- /* If it is a weak symbol, then assume it won't reach. */
- if (S_IS_WEAK (expr->X_add_symbol))
- return FALSE;
-
- if (is_direct_call_opcode (insn->opcode)
- && ! pc_frag->tc_frag_data.use_longcalls)
+ /* If it is a weak symbol or a symbol in a different section,
+ it cannot be known to fit at assembly time. */
+ if (S_IS_WEAK (expr->X_add_symbol)
+ || S_GET_SEGMENT (expr->X_add_symbol) != pc_seg)
{
- /* If callee is undefined or in a different segment, be
- optimistic and assume it will be in range. */
- if (S_GET_SEGMENT (expr->X_add_symbol) != pc_seg)
+ /* For a direct call with --no-longcalls, be optimistic and
+ assume it will be in range. */
+ if (is_direct_call_opcode (insn->opcode)
+ && ! pc_frag->tc_frag_data.use_longcalls)
return TRUE;
- }
- /* Only references within a segment can be known to fit in the
- operands at assembly time. */
- if (S_GET_SEGMENT (expr->X_add_symbol) != pc_seg)
- return FALSE;
+ return FALSE;
+ }
symbolP = expr->X_add_symbol;
sym_frag = symbol_get_frag (symbolP);