From patchwork Mon Jun 11 23:06:03 2012 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: constant that doesn't fit in 32bits in alpha.c Date: Mon, 11 Jun 2012 13:06:03 -0000 From: Richard Henderson X-Patchwork-Id: 164288 Message-Id: <4FD679DB.7010105@redhat.com> To: Jay K Cc: GCC Patches Bah. Wrong patch. r~ * config/alpha/alpha.c (alpha_trampoline_init): Split large constants. diff --git a/gcc/config/alpha/alpha.c b/gcc/config/alpha/alpha.c index 6d15bf7..3dda9fb 100644 --- a/gcc/config/alpha/alpha.c +++ b/gcc/config/alpha/alpha.c @@ -5451,6 +5451,8 @@ alpha_trampoline_init (rtx m_tramp, tree fndecl, rtx chain_value) chain_value = convert_memory_address (Pmode, chain_value); #endif +#define HWI_HEX2(X,Y) (((HOST_WIDE_INT)0x ## X ## u) | 0x ## Y ## u) + if (TARGET_ABI_OPEN_VMS) { const char *fnname; @@ -5468,7 +5470,8 @@ alpha_trampoline_init (rtx m_tramp, tree fndecl, rtx chain_value) the function's procedure descriptor with certain fields zeroed IAW the VMS calling standard. This is stored in the first quadword. */ word1 = force_reg (DImode, gen_const_mem (DImode, fnaddr)); - word1 = expand_and (DImode, word1, GEN_INT (0xffff0fff0000fff0), NULL); + word1 = expand_and (DImode, word1, + GEN_INT (HWI_HEX2(ffff0fff,0000fff0)), NULL); } else { @@ -5479,10 +5482,12 @@ alpha_trampoline_init (rtx m_tramp, tree fndecl, rtx chain_value) nop We don't bother setting the HINT field of the jump; the nop is merely there for padding. */ - word1 = GEN_INT (0xa77b0010a43b0018); - word2 = GEN_INT (0x47ff041f6bfb0000); + word1 = GEN_INT (HWI_HEX2 (a77b0010,a43b0018)); + word2 = GEN_INT (HWI_HEX2 (47ff041f,6bfb0000)); } +#undef HWI_HEX2 + /* Store the first two words, as computed above. */ mem = adjust_address (m_tramp, DImode, 0); emit_move_insn (mem, word1);