mirror of git://gcc.gnu.org/git/gcc.git
rs6000.c (rs6000_option_override_internal): Don't override user -mfp-in-toc.
* config/rs6000/rs6000.c (rs6000_option_override_internal): Don't override user -mfp-in-toc. (offsettable_ok_by_alignment): Consider just the current access rather than the whole object, unless BLKmode. Handle CONSTANT_POOL_ADDRESS_P constants that lack a decl too. (use_toc_relative_ref): Allow CONSTANT_POOL_ADDRESS_P constants for -mcmodel=medium. * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Don't override user -mfp-in-toc or -msum-in-toc. Default to -mno-fp-in-toc for -mcmodel=medium. From-SVN: r199781
This commit is contained in:
parent
a9429737bd
commit
acd17ae6c8
|
|
@ -1,3 +1,16 @@
|
|||
2013-06-07 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* config/rs6000/rs6000.c (rs6000_option_override_internal): Don't
|
||||
override user -mfp-in-toc.
|
||||
(offsettable_ok_by_alignment): Consider just the current access
|
||||
rather than the whole object, unless BLKmode. Handle
|
||||
CONSTANT_POOL_ADDRESS_P constants that lack a decl too.
|
||||
(use_toc_relative_ref): Allow CONSTANT_POOL_ADDRESS_P constants
|
||||
for -mcmodel=medium.
|
||||
* config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Don't
|
||||
override user -mfp-in-toc or -msum-in-toc. Default to
|
||||
-mno-fp-in-toc for -mcmodel=medium.
|
||||
|
||||
2013-06-06 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* config/rl78/rl78.c (rl78_valid_pointer_mode): New, implements
|
||||
|
|
|
|||
|
|
@ -136,7 +136,10 @@ extern int dot_symbols;
|
|||
SET_CMODEL (CMODEL_MEDIUM); \
|
||||
if (rs6000_current_cmodel != CMODEL_SMALL) \
|
||||
{ \
|
||||
TARGET_NO_FP_IN_TOC = 0; \
|
||||
if (!global_options_set.x_TARGET_NO_FP_IN_TOC) \
|
||||
TARGET_NO_FP_IN_TOC \
|
||||
= rs6000_current_cmodel == CMODEL_MEDIUM; \
|
||||
if (!global_options_set.x_TARGET_NO_SUM_IN_TOC) \
|
||||
TARGET_NO_SUM_IN_TOC = 0; \
|
||||
} \
|
||||
} \
|
||||
|
|
|
|||
|
|
@ -3052,7 +3052,8 @@ rs6000_option_override_internal (bool global_init_p)
|
|||
|
||||
/* Place FP constants in the constant pool instead of TOC
|
||||
if section anchors enabled. */
|
||||
if (flag_section_anchors)
|
||||
if (flag_section_anchors
|
||||
&& !global_options_set.x_TARGET_NO_FP_IN_TOC)
|
||||
TARGET_NO_FP_IN_TOC = 1;
|
||||
|
||||
if (TARGET_DEBUG_REG || TARGET_DEBUG_TARGET)
|
||||
|
|
@ -5519,59 +5520,56 @@ virtual_stack_registers_memory_p (rtx op)
|
|||
&& regnum <= LAST_VIRTUAL_POINTER_REGISTER);
|
||||
}
|
||||
|
||||
/* Return true if memory accesses to OP are known to never straddle
|
||||
a 32k boundary. */
|
||||
/* Return true if a MODE sized memory accesses to OP plus OFFSET
|
||||
is known to not straddle a 32k boundary. */
|
||||
|
||||
static bool
|
||||
offsettable_ok_by_alignment (rtx op, HOST_WIDE_INT offset,
|
||||
enum machine_mode mode)
|
||||
{
|
||||
tree decl, type;
|
||||
unsigned HOST_WIDE_INT dsize, dalign;
|
||||
unsigned HOST_WIDE_INT dsize, dalign, lsb, mask;
|
||||
|
||||
if (GET_CODE (op) != SYMBOL_REF)
|
||||
return false;
|
||||
|
||||
dsize = GET_MODE_SIZE (mode);
|
||||
decl = SYMBOL_REF_DECL (op);
|
||||
if (!decl)
|
||||
{
|
||||
if (GET_MODE_SIZE (mode) == 0)
|
||||
if (dsize == 0)
|
||||
return false;
|
||||
|
||||
/* -fsection-anchors loses the original SYMBOL_REF_DECL when
|
||||
replacing memory addresses with an anchor plus offset. We
|
||||
could find the decl by rummaging around in the block->objects
|
||||
VEC for the given offset but that seems like too much work. */
|
||||
dalign = 1;
|
||||
dalign = BITS_PER_UNIT;
|
||||
if (SYMBOL_REF_HAS_BLOCK_INFO_P (op)
|
||||
&& SYMBOL_REF_ANCHOR_P (op)
|
||||
&& SYMBOL_REF_BLOCK (op) != NULL)
|
||||
{
|
||||
struct object_block *block = SYMBOL_REF_BLOCK (op);
|
||||
HOST_WIDE_INT lsb, mask;
|
||||
|
||||
/* Given the alignment of the block.. */
|
||||
dalign = block->alignment;
|
||||
mask = dalign / BITS_PER_UNIT - 1;
|
||||
|
||||
/* ..and the combined offset of the anchor and any offset
|
||||
to this block object.. */
|
||||
offset += SYMBOL_REF_BLOCK_OFFSET (op);
|
||||
lsb = offset & -offset;
|
||||
|
||||
/* ..find how many bits of the alignment we know for the
|
||||
object. */
|
||||
mask &= lsb - 1;
|
||||
dalign = mask + 1;
|
||||
}
|
||||
return dalign >= GET_MODE_SIZE (mode);
|
||||
}
|
||||
|
||||
if (DECL_P (decl))
|
||||
else if (CONSTANT_POOL_ADDRESS_P (op))
|
||||
{
|
||||
if (TREE_CODE (decl) == FUNCTION_DECL)
|
||||
return true;
|
||||
/* It would be nice to have get_pool_align().. */
|
||||
enum machine_mode cmode = get_pool_mode (op);
|
||||
|
||||
dalign = GET_MODE_ALIGNMENT (cmode);
|
||||
}
|
||||
}
|
||||
else if (DECL_P (decl))
|
||||
{
|
||||
dalign = DECL_ALIGN (decl);
|
||||
|
||||
if (dsize == 0)
|
||||
{
|
||||
/* Allow BLKmode when the entire object is known to not
|
||||
cross a 32k boundary. */
|
||||
if (!DECL_SIZE_UNIT (decl))
|
||||
return false;
|
||||
|
||||
|
|
@ -5582,12 +5580,22 @@ offsettable_ok_by_alignment (rtx op, HOST_WIDE_INT offset,
|
|||
if (dsize > 32768)
|
||||
return false;
|
||||
|
||||
dalign = DECL_ALIGN_UNIT (decl);
|
||||
return dalign >= dsize;
|
||||
return dalign / BITS_PER_UNIT >= dsize;
|
||||
}
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
type = TREE_TYPE (decl);
|
||||
|
||||
dalign = TYPE_ALIGN (type);
|
||||
if (CONSTANT_CLASS_P (decl))
|
||||
dalign = CONSTANT_ALIGNMENT (decl, dalign);
|
||||
else
|
||||
dalign = DATA_ALIGNMENT (decl, dalign);
|
||||
|
||||
if (dsize == 0)
|
||||
{
|
||||
/* BLKmode, check the entire object. */
|
||||
if (TREE_CODE (decl) == STRING_CST)
|
||||
dsize = TREE_STRING_LENGTH (decl);
|
||||
else if (TYPE_SIZE_UNIT (type)
|
||||
|
|
@ -5598,12 +5606,16 @@ offsettable_ok_by_alignment (rtx op, HOST_WIDE_INT offset,
|
|||
if (dsize > 32768)
|
||||
return false;
|
||||
|
||||
dalign = TYPE_ALIGN (type);
|
||||
if (CONSTANT_CLASS_P (decl))
|
||||
dalign = CONSTANT_ALIGNMENT (decl, dalign);
|
||||
else
|
||||
dalign = DATA_ALIGNMENT (decl, dalign);
|
||||
dalign /= BITS_PER_UNIT;
|
||||
return dalign / BITS_PER_UNIT >= dsize;
|
||||
}
|
||||
}
|
||||
|
||||
/* Find how many bits of the alignment we know for this access. */
|
||||
mask = dalign / BITS_PER_UNIT - 1;
|
||||
lsb = offset & -offset;
|
||||
mask &= lsb - 1;
|
||||
dalign = mask + 1;
|
||||
|
||||
return dalign >= dsize;
|
||||
}
|
||||
|
||||
|
|
@ -6549,7 +6561,6 @@ use_toc_relative_ref (rtx sym)
|
|||
&& ASM_OUTPUT_SPECIAL_POOL_ENTRY_P (get_pool_constant (sym),
|
||||
get_pool_mode (sym)))
|
||||
|| (TARGET_CMODEL == CMODEL_MEDIUM
|
||||
&& !CONSTANT_POOL_ADDRESS_P (sym)
|
||||
&& SYMBOL_REF_LOCAL_P (sym)));
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue