ia64.c: Include libfuncs.h.

* config/ia64/ia64.c: Include libfuncs.h.
	(TARGET_PROMOTE_FUNCITON_MODE): Define target macro.
	(ia64_expand_call): Use reg 25 on VMS.
	(ia64_initialize_trampoline): Fix for VMS ABI.
	(ia64_function_arg_offset): Always returns 0 when TARGET_ABI_OPEN_VMS.
	(ia64_function_arg): Initialize reg 25 on VMS.
	Fix OpenVMS ABI issues for varargs.
	For OpenVMS, emit the Argument Information register set in the
	incoming/sibcall case as well.
	(ia64_arg_type): New function.
	(ia64_function_arg_advance): Keep track of cum->words.
	Fix OpenVMS ABI issues for varargs.
	(ia64_function_value): On VMS, promote mode of non-aggregate types.
	(ia64_override_options): Set flag_no_common on VMS.
	(ia64_init_builtins): Disable FWRITE builtin.
	(ia64_asm_output_external): Call DO_CRTL_NAMES.
	(ia64_vms_init_libfuncs): Add decc$ routines.
	(ia64_vms_valid_pointer_mode): New function.
	(ia64_struct_value_rtx): Allways NULL_RTX on VMS.
	(ia64_promote_function_mode): New function
	* config/ia64/ia64.h (TARGET_ABI_OPEN_VMS): Define as 0 for default.
	(LONG_DOUBLE_TYPE_SIZE): Force to 64 on VMS.
	(LIBCGC2_LONG_DOUBLE_TYPE_SIZE): Likewise.
	(INIT_CUMULATIVE_ARGS): Add atypes for VMS.
	(INIT_CUMULATIVE_INCOMING_ARGS): Likewise.
	(ASM_OUTPUT_DEF): Use ISDIGIT instead of isdigit.
	Suppress trailing '#' if VALUE is numeric.
	* config/ia64/vms.h (PROMOTE_FUNCTION_MODE): Remove, code moved to
	ia64_promote_function_mode.
	(TARGET_VALID_POINTER_MODE): Define.


Co-Authored-By: Olivier Hainque <hainque@adacore.com>

From-SVN: r151009
This commit is contained in:
Douglas B Rupp 2009-08-22 02:50:30 +00:00 committed by Douglas Rupp
parent 124b06300a
commit f2972bf8bf
4 changed files with 217 additions and 35 deletions

View File

@ -1,3 +1,37 @@
2009-08-21 Douglas B Rupp <rupp@gnat.com>
Olivier Hainque <hainque@adacore.com>
* config/ia64/ia64.c: Include libfuncs.h.
(TARGET_PROMOTE_FUNCITON_MODE): Define target macro.
(ia64_expand_call): Use reg 25 on VMS.
(ia64_initialize_trampoline): Fix for VMS ABI.
(ia64_function_arg_offset): Always returns 0 when TARGET_ABI_OPEN_VMS.
(ia64_function_arg): Initialize reg 25 on VMS.
Fix OpenVMS ABI issues for varargs.
For OpenVMS, emit the Argument Information register set in the
incoming/sibcall case as well.
(ia64_arg_type): New function.
(ia64_function_arg_advance): Keep track of cum->words.
Fix OpenVMS ABI issues for varargs.
(ia64_function_value): On VMS, promote mode of non-aggregate types.
(ia64_override_options): Set flag_no_common on VMS.
(ia64_init_builtins): Disable FWRITE builtin.
(ia64_asm_output_external): Call DO_CRTL_NAMES.
(ia64_vms_init_libfuncs): Add decc$ routines.
(ia64_vms_valid_pointer_mode): New function.
(ia64_struct_value_rtx): Allways NULL_RTX on VMS.
(ia64_promote_function_mode): New function
* config/ia64/ia64.h (TARGET_ABI_OPEN_VMS): Define as 0 for default.
(LONG_DOUBLE_TYPE_SIZE): Force to 64 on VMS.
(LIBCGC2_LONG_DOUBLE_TYPE_SIZE): Likewise.
(INIT_CUMULATIVE_ARGS): Add atypes for VMS.
(INIT_CUMULATIVE_INCOMING_ARGS): Likewise.
(ASM_OUTPUT_DEF): Use ISDIGIT instead of isdigit.
Suppress trailing '#' if VALUE is numeric.
* config/ia64/vms.h (PROMOTE_FUNCTION_MODE): Remove, code moved to
ia64_promote_function_mode.
(TARGET_VALID_POINTER_MODE): Define.
2009-08-21 Michael Meissner <meissner@linux.vnet.ibm.com> 2009-08-21 Michael Meissner <meissner@linux.vnet.ibm.com>
PR target/40671 PR target/40671

View File

@ -41,6 +41,7 @@ along with GCC; see the file COPYING3. If not see
#include "function.h" #include "function.h"
#include "ggc.h" #include "ggc.h"
#include "basic-block.h" #include "basic-block.h"
#include "libfuncs.h"
#include "toplev.h" #include "toplev.h"
#include "sched-int.h" #include "sched-int.h"
#include "timevar.h" #include "timevar.h"
@ -276,6 +277,8 @@ static void ia64_vms_init_libfuncs (void)
ATTRIBUTE_UNUSED; ATTRIBUTE_UNUSED;
static void ia64_soft_fp_init_libfuncs (void) static void ia64_soft_fp_init_libfuncs (void)
ATTRIBUTE_UNUSED; ATTRIBUTE_UNUSED;
static bool ia64_vms_valid_pointer_mode (enum machine_mode mode)
ATTRIBUTE_UNUSED;
static tree ia64_handle_model_attribute (tree *, tree, tree, int, bool *); static tree ia64_handle_model_attribute (tree *, tree, tree, int, bool *);
static tree ia64_handle_version_id_attribute (tree *, tree, tree, int, bool *); static tree ia64_handle_version_id_attribute (tree *, tree, tree, int, bool *);
@ -290,6 +293,11 @@ static const char *ia64_invalid_conversion (const_tree, const_tree);
static const char *ia64_invalid_unary_op (int, const_tree); static const char *ia64_invalid_unary_op (int, const_tree);
static const char *ia64_invalid_binary_op (int, const_tree, const_tree); static const char *ia64_invalid_binary_op (int, const_tree, const_tree);
static enum machine_mode ia64_c_mode_for_suffix (char); static enum machine_mode ia64_c_mode_for_suffix (char);
static enum machine_mode ia64_promote_function_mode (const_tree,
enum machine_mode,
int *,
const_tree,
int);
/* Table of valid machine attributes. */ /* Table of valid machine attributes. */
static const struct attribute_spec ia64_attribute_table[] = static const struct attribute_spec ia64_attribute_table[] =
@ -457,11 +465,8 @@ static const struct attribute_spec ia64_attribute_table[] =
#define TARGET_ASM_OUTPUT_DWARF_DTPREL ia64_output_dwarf_dtprel #define TARGET_ASM_OUTPUT_DWARF_DTPREL ia64_output_dwarf_dtprel
#endif #endif
/* ??? ABI doesn't allow us to define this. */
#if 0
#undef TARGET_PROMOTE_FUNCTION_MODE #undef TARGET_PROMOTE_FUNCTION_MODE
#define TARGET_PROMOTE_FUNCTION_MODE default_promote_function_mode_always_promote #define TARGET_PROMOTE_FUNCTION_MODE ia64_promote_function_mode
#endif
/* ??? Investigate. */ /* ??? Investigate. */
#if 0 #if 0
@ -1918,6 +1923,10 @@ ia64_expand_call (rtx retval, rtx addr, rtx nextarg ATTRIBUTE_UNUSED,
if (sibcall_p) if (sibcall_p)
use_reg (&CALL_INSN_FUNCTION_USAGE (insn), b0); use_reg (&CALL_INSN_FUNCTION_USAGE (insn), b0);
if (TARGET_ABI_OPEN_VMS)
use_reg (&CALL_INSN_FUNCTION_USAGE (insn),
gen_rtx_REG (DImode, GR_REG (25)));
} }
static void static void
@ -3832,7 +3841,7 @@ ia64_dbx_register_number (int regno)
void void
ia64_initialize_trampoline (rtx addr, rtx fnaddr, rtx static_chain) ia64_initialize_trampoline (rtx addr, rtx fnaddr, rtx static_chain)
{ {
rtx addr_reg, eight = GEN_INT (8); rtx addr_reg, tramp, eight = GEN_INT (8);
/* The Intel assembler requires that the global __ia64_trampoline symbol /* The Intel assembler requires that the global __ia64_trampoline symbol
be declared explicitly */ be declared explicitly */
@ -3859,8 +3868,21 @@ ia64_initialize_trampoline (rtx addr, rtx fnaddr, rtx static_chain)
/* The first two words are the fake descriptor: /* The first two words are the fake descriptor:
__ia64_trampoline, ADDR+16. */ __ia64_trampoline, ADDR+16. */
emit_move_insn (gen_rtx_MEM (Pmode, addr_reg), tramp = gen_rtx_SYMBOL_REF (Pmode, "__ia64_trampoline");
gen_rtx_SYMBOL_REF (Pmode, "__ia64_trampoline")); if (TARGET_ABI_OPEN_VMS)
{
/* HP decided to break the ELF ABI on VMS (to deal with an ambiguity
in the Macro-32 compiler) and changed the semantics of the LTOFF22
relocation against function symbols to make it identical to the
LTOFF_FPTR22 relocation. Emit the latter directly to stay within
strict ELF and dereference to get the bare code address. */
rtx reg = gen_reg_rtx (Pmode);
SYMBOL_REF_FLAGS (tramp) |= SYMBOL_FLAG_FUNCTION;
emit_move_insn (reg, tramp);
emit_move_insn (reg, gen_rtx_MEM (Pmode, reg));
tramp = reg;
}
emit_move_insn (gen_rtx_MEM (Pmode, addr_reg), tramp);
emit_insn (gen_adddi3 (addr_reg, addr_reg, eight)); emit_insn (gen_adddi3 (addr_reg, addr_reg, eight));
emit_move_insn (gen_rtx_MEM (Pmode, addr_reg), emit_move_insn (gen_rtx_MEM (Pmode, addr_reg),
@ -4017,7 +4039,8 @@ ia64_function_arg_words (tree type, enum machine_mode mode)
static int static int
ia64_function_arg_offset (CUMULATIVE_ARGS *cum, tree type, int words) ia64_function_arg_offset (CUMULATIVE_ARGS *cum, tree type, int words)
{ {
if ((cum->words & 1) == 0) /* No registers are skipped on VMS. */
if (TARGET_ABI_OPEN_VMS || (cum->words & 1) == 0)
return 0; return 0;
if (type if (type
@ -4042,6 +4065,24 @@ ia64_function_arg (CUMULATIVE_ARGS *cum, enum machine_mode mode, tree type,
int offset = ia64_function_arg_offset (cum, type, words); int offset = ia64_function_arg_offset (cum, type, words);
enum machine_mode hfa_mode = VOIDmode; enum machine_mode hfa_mode = VOIDmode;
/* For OPEN VMS, emit the instruction setting up the argument register here,
when we know this will be together with the other arguments setup related
insns. This is not the conceptually best place to do this, but this is
the easiest as we have convenient access to cumulative args info. */
if (TARGET_ABI_OPEN_VMS && mode == VOIDmode && type == void_type_node
&& named == 1)
{
unsigned HOST_WIDE_INT regval = cum->words;
int i;
for (i = 0; i < 8; i++)
regval |= ((int) cum->atypes[i]) << (i * 3 + 8);
emit_move_insn (gen_rtx_REG (DImode, GR_REG (25)),
GEN_INT (regval));
}
/* If all argument slots are used, then it must go on the stack. */ /* If all argument slots are used, then it must go on the stack. */
if (cum->words + offset >= MAX_ARGUMENT_SLOTS) if (cum->words + offset >= MAX_ARGUMENT_SLOTS)
return 0; return 0;
@ -4131,6 +4172,15 @@ ia64_function_arg (CUMULATIVE_ARGS *cum, enum machine_mode mode, tree type,
} }
return gen_rtx_PARALLEL (mode, gen_rtvec_v (i, loc)); return gen_rtx_PARALLEL (mode, gen_rtvec_v (i, loc));
} }
/* On OpenVMS variable argument is either in Rn or Fn. */
else if (TARGET_ABI_OPEN_VMS && named == 0)
{
if (FLOAT_MODE_P (mode))
return gen_rtx_REG (mode, FR_ARG_FIRST + cum->words);
else
return gen_rtx_REG (mode, basereg + cum->words);
}
/* Integral and aggregates go in general registers. If we have run out of /* Integral and aggregates go in general registers. If we have run out of
FR registers, then FP values must also go in general registers. This can FR registers, then FP values must also go in general registers. This can
@ -4223,6 +4273,22 @@ ia64_arg_partial_bytes (CUMULATIVE_ARGS *cum, enum machine_mode mode,
return (MAX_ARGUMENT_SLOTS - cum->words - offset) * UNITS_PER_WORD; return (MAX_ARGUMENT_SLOTS - cum->words - offset) * UNITS_PER_WORD;
} }
/* Return ivms_arg_type based on machine_mode. */
static enum ivms_arg_type
ia64_arg_type (enum machine_mode mode)
{
switch (mode)
{
case SFmode:
return FS;
case DFmode:
return FT;
default:
return I64;
}
}
/* Update CUM to point after this argument. This is patterned after /* Update CUM to point after this argument. This is patterned after
ia64_function_arg. */ ia64_function_arg. */
@ -4236,8 +4302,12 @@ ia64_function_arg_advance (CUMULATIVE_ARGS *cum, enum machine_mode mode,
/* If all arg slots are already full, then there is nothing to do. */ /* If all arg slots are already full, then there is nothing to do. */
if (cum->words >= MAX_ARGUMENT_SLOTS) if (cum->words >= MAX_ARGUMENT_SLOTS)
return; {
cum->words += words + offset;
return;
}
cum->atypes[cum->words] = ia64_arg_type (mode);
cum->words += words + offset; cum->words += words + offset;
/* Check for and handle homogeneous FP aggregates. */ /* Check for and handle homogeneous FP aggregates. */
@ -4280,6 +4350,13 @@ ia64_function_arg_advance (CUMULATIVE_ARGS *cum, enum machine_mode mode,
cum->fp_regs = fp_regs; cum->fp_regs = fp_regs;
} }
/* On OpenVMS variable argument is either in Rn or Fn. */
else if (TARGET_ABI_OPEN_VMS && named == 0)
{
cum->int_regs = cum->words;
cum->fp_regs = cum->words;
}
/* Integral and aggregates go in general registers. So do TFmode FP values. /* Integral and aggregates go in general registers. So do TFmode FP values.
If we have run out of FR registers, then other FP values must also go in If we have run out of FR registers, then other FP values must also go in
general registers. This can happen when we have a SFmode HFA. */ general registers. This can happen when we have a SFmode HFA. */
@ -4424,10 +4501,11 @@ ia64_return_in_memory (const_tree valtype, const_tree fntype ATTRIBUTE_UNUSED)
/* Return rtx for register that holds the function return value. */ /* Return rtx for register that holds the function return value. */
rtx rtx
ia64_function_value (const_tree valtype, const_tree func ATTRIBUTE_UNUSED) ia64_function_value (const_tree valtype, const_tree func)
{ {
enum machine_mode mode; enum machine_mode mode;
enum machine_mode hfa_mode; enum machine_mode hfa_mode;
int unsignedp;
mode = TYPE_MODE (valtype); mode = TYPE_MODE (valtype);
hfa_mode = hfa_element_mode (valtype, 0); hfa_mode = hfa_element_mode (valtype, 0);
@ -4498,6 +4576,10 @@ ia64_function_value (const_tree valtype, const_tree func ATTRIBUTE_UNUSED)
return gen_rtx_PARALLEL (mode, gen_rtvec_v (i, loc)); return gen_rtx_PARALLEL (mode, gen_rtvec_v (i, loc));
} }
mode = ia64_promote_function_mode (valtype, mode, &unsignedp,
func ? TREE_TYPE (func) : NULL_TREE,
true);
return gen_rtx_REG (mode, GR_RET_FIRST); return gen_rtx_REG (mode, GR_RET_FIRST);
} }
} }
@ -5306,6 +5388,9 @@ ia64_override_options (void)
align_functions = 64; align_functions = 64;
if (align_loops <= 0) if (align_loops <= 0)
align_loops = 32; align_loops = 32;
if (TARGET_ABI_OPEN_VMS)
flag_no_common = 1;
} }
/* Initialize the record of emitted frame related registers. */ /* Initialize the record of emitted frame related registers. */
@ -9830,6 +9915,13 @@ ia64_init_builtins (void)
(*lang_hooks.types.register_builtin_type) (long_double_type_node, (*lang_hooks.types.register_builtin_type) (long_double_type_node,
"__float128"); "__float128");
/* Fwrite on VMS is non-standard. */
if (TARGET_ABI_OPEN_VMS)
{
implicit_built_in_decls[(int) BUILT_IN_FWRITE] = NULL_TREE;
implicit_built_in_decls[(int) BUILT_IN_FWRITE_UNLOCKED] = NULL_TREE;
}
#define def_builtin(name, type, code) \ #define def_builtin(name, type, code) \
add_builtin_function ((name), (type), (code), BUILT_IN_MD, \ add_builtin_function ((name), (type), (code), BUILT_IN_MD, \
NULL, NULL_TREE) NULL, NULL_TREE)
@ -9942,6 +10034,10 @@ ia64_asm_output_external (FILE *file, tree decl, const char *name)
int need_visibility = ((*targetm.binds_local_p) (decl) int need_visibility = ((*targetm.binds_local_p) (decl)
&& maybe_assemble_visibility (decl)); && maybe_assemble_visibility (decl));
#ifdef DO_CRTL_NAMES
DO_CRTL_NAMES;
#endif
/* GNU as does not need anything here, but the HP linker does /* GNU as does not need anything here, but the HP linker does
need something for external functions. */ need something for external functions. */
if ((TARGET_HPUX_LD || !TARGET_GNU_AS) if ((TARGET_HPUX_LD || !TARGET_GNU_AS)
@ -10044,6 +10140,11 @@ ia64_vms_init_libfuncs (void)
set_optab_libfunc (smod_optab, DImode, "OTS$REM_L"); set_optab_libfunc (smod_optab, DImode, "OTS$REM_L");
set_optab_libfunc (umod_optab, SImode, "OTS$REM_UI"); set_optab_libfunc (umod_optab, SImode, "OTS$REM_UI");
set_optab_libfunc (umod_optab, DImode, "OTS$REM_UL"); set_optab_libfunc (umod_optab, DImode, "OTS$REM_UL");
abort_libfunc = init_one_libfunc ("decc$abort");
memcmp_libfunc = init_one_libfunc ("decc$memcmp");
#ifdef MEM_LIBFUNCS_INIT
MEM_LIBFUNCS_INIT;
#endif
} }
/* Rename the TFmode libfuncs available from soft-fp in glibc using /* Rename the TFmode libfuncs available from soft-fp in glibc using
@ -10074,6 +10175,12 @@ static void
ia64_soft_fp_init_libfuncs (void) ia64_soft_fp_init_libfuncs (void)
{ {
} }
static bool
ia64_vms_valid_pointer_mode (enum machine_mode mode)
{
return (mode == SImode || mode == DImode);
}
/* For HPUX, it is illegal to have relocations in shared segments. */ /* For HPUX, it is illegal to have relocations in shared segments. */
@ -10299,7 +10406,8 @@ static rtx
ia64_struct_value_rtx (tree fntype, ia64_struct_value_rtx (tree fntype,
int incoming ATTRIBUTE_UNUSED) int incoming ATTRIBUTE_UNUSED)
{ {
if (fntype && ia64_struct_retval_addr_is_first_parm_p (fntype)) if (TARGET_ABI_OPEN_VMS ||
(fntype && ia64_struct_retval_addr_is_first_parm_p (fntype)))
return NULL_RTX; return NULL_RTX;
return gen_rtx_REG (Pmode, GR_REG (8)); return gen_rtx_REG (Pmode, GR_REG (8));
} }
@ -10564,6 +10672,42 @@ ia64_c_mode_for_suffix (char suffix)
return VOIDmode; return VOIDmode;
} }
static enum machine_mode
ia64_promote_function_mode (const_tree type,
enum machine_mode mode,
int *punsignedp,
const_tree funtype ATTRIBUTE_UNUSED,
int for_return ATTRIBUTE_UNUSED)
{
/* Special processing required for OpenVMS ... */
if (!TARGET_ABI_OPEN_VMS)
return mode;
/* HP OpenVMS Calling Standard dated June, 2004, that describes
HP OpenVMS I64 Version 8.2EFT,
chapter 4 "OpenVMS I64 Conventions"
section 4.7 "Procedure Linkage"
subsection 4.7.5.2, "Normal Register Parameters"
"Unsigned integral (except unsigned 32-bit), set, and VAX floating-point
values passed in registers are zero-filled; signed integral values as
well as unsigned 32-bit integral values are sign-extended to 64 bits.
For all other types passed in the general registers, unused bits are
undefined." */
if (!AGGREGATE_TYPE_P (type)
&& GET_MODE_CLASS (mode) == MODE_INT
&& GET_MODE_SIZE (mode) < UNITS_PER_WORD)
{
if (mode == SImode)
*punsignedp = 0;
return DImode;
}
else
return promote_mode (type, mode, punsignedp);
}
static GTY(()) rtx ia64_dconst_0_5_rtx; static GTY(()) rtx ia64_dconst_0_5_rtx;
rtx rtx

View File

@ -73,6 +73,8 @@ extern unsigned int ia64_section_threshold;
#define TARGET_HPUX 0 #define TARGET_HPUX 0
#define TARGET_HPUX_LD 0 #define TARGET_HPUX_LD 0
#define TARGET_ABI_OPEN_VMS 0
#ifndef TARGET_ILP32 #ifndef TARGET_ILP32
#define TARGET_ILP32 0 #define TARGET_ILP32 0
#endif #endif
@ -279,11 +281,17 @@ while (0)
#define DOUBLE_TYPE_SIZE 64 #define DOUBLE_TYPE_SIZE 64
/* long double is XFmode normally, TFmode for HPUX. */ /* long double is XFmode normally, and TFmode for HPUX. It should be
#define LONG_DOUBLE_TYPE_SIZE (TARGET_HPUX ? 128 : 80) TFmode for VMS as well but we only support up to DFmode now. */
#define LONG_DOUBLE_TYPE_SIZE \
(TARGET_HPUX ? 128 \
: TARGET_ABI_OPEN_VMS ? 64 \
: 80)
/* We always want the XFmode operations from libgcc2.c, except on VMS
where this yields references to unimplemented "insns". */
#define LIBGCC2_LONG_DOUBLE_TYPE_SIZE (TARGET_ABI_OPEN_VMS ? 64 : 80)
/* We always want the XFmode operations from libgcc2.c. */
#define LIBGCC2_LONG_DOUBLE_TYPE_SIZE 80
/* On HP-UX, we use the l suffix for TFmode in libgcc2.c. */ /* On HP-UX, we use the l suffix for TFmode in libgcc2.c. */
#define LIBGCC2_TF_CEXT l #define LIBGCC2_TF_CEXT l
@ -1077,12 +1085,16 @@ enum reg_class
`FUNCTION_ARG' and other related values. For some target machines, the type `FUNCTION_ARG' and other related values. For some target machines, the type
`int' suffices and can hold the number of bytes of argument so far. */ `int' suffices and can hold the number of bytes of argument so far. */
enum ivms_arg_type {I64, FF, FD, FG, FS, FT};
/* VMS floating point formats VAX F, VAX D, VAX G, IEEE S, IEEE T. */
typedef struct ia64_args typedef struct ia64_args
{ {
int words; /* # words of arguments so far */ int words; /* # words of arguments so far */
int int_regs; /* # GR registers used so far */ int int_regs; /* # GR registers used so far */
int fp_regs; /* # FR registers used so far */ int fp_regs; /* # FR registers used so far */
int prototype; /* whether function prototyped */ int prototype; /* whether function prototyped */
enum ivms_arg_type atypes[8]; /* which VMS float type or if not float */
} CUMULATIVE_ARGS; } CUMULATIVE_ARGS;
/* A C statement (sans semicolon) for initializing the variable CUM for the /* A C statement (sans semicolon) for initializing the variable CUM for the
@ -1094,6 +1106,9 @@ do { \
(CUM).int_regs = 0; \ (CUM).int_regs = 0; \
(CUM).fp_regs = 0; \ (CUM).fp_regs = 0; \
(CUM).prototype = ((FNTYPE) && TYPE_ARG_TYPES (FNTYPE)) || (LIBNAME); \ (CUM).prototype = ((FNTYPE) && TYPE_ARG_TYPES (FNTYPE)) || (LIBNAME); \
(CUM).atypes[0] = (CUM).atypes[1] = (CUM).atypes[2] = I64; \
(CUM).atypes[3] = (CUM).atypes[4] = (CUM).atypes[5] = I64; \
(CUM).atypes[6] = (CUM).atypes[7] = I64; \
} while (0) } while (0)
/* Like `INIT_CUMULATIVE_ARGS' but overrides it for the purposes of finding the /* Like `INIT_CUMULATIVE_ARGS' but overrides it for the purposes of finding the
@ -1108,6 +1123,9 @@ do { \
(CUM).int_regs = 0; \ (CUM).int_regs = 0; \
(CUM).fp_regs = 0; \ (CUM).fp_regs = 0; \
(CUM).prototype = 1; \ (CUM).prototype = 1; \
(CUM).atypes[0] = (CUM).atypes[1] = (CUM).atypes[2] = I64; \
(CUM).atypes[3] = (CUM).atypes[4] = (CUM).atypes[5] = I64; \
(CUM).atypes[6] = (CUM).atypes[7] = I64; \
} while (0) } while (0)
/* A C statement (sans semicolon) to update the summarizer variable CUM to /* A C statement (sans semicolon) to update the summarizer variable CUM to
@ -1496,8 +1514,11 @@ do { \
do { \ do { \
assemble_name (STREAM, NAME); \ assemble_name (STREAM, NAME); \
fputs (" = ", STREAM); \ fputs (" = ", STREAM); \
if (ISDIGIT (*VALUE)) \
ia64_asm_output_label = 1; \
assemble_name (STREAM, VALUE); \ assemble_name (STREAM, VALUE); \
fputc ('\n', STREAM); \ fputc ('\n', STREAM); \
ia64_asm_output_label = 0; \
} while (0) } while (0)

View File

@ -66,26 +66,6 @@ along with GCC; see the file COPYING3. If not see
#undef WIDEST_HARDWARE_FP_SIZE #undef WIDEST_HARDWARE_FP_SIZE
#define WIDEST_HARDWARE_FP_SIZE 64 #define WIDEST_HARDWARE_FP_SIZE 64
/* HP OpenVMS Calling Standard dated June, 2004, that describes
HP OpenVMS I64 Version 8.2EFT
chapter 4 "OpenVMS I64 Conventions"
section 4.7 "Procedure Linkage"
subsection 4.7.5.2, "Normal Register Parameters"
"Unsigned integral (except unsigned 32-bit), set, and VAX
floating-point values passed in registers are zero-filled;
signed integral values as well as unsigned 32-bit integral
values are sign-extended to 64 bits. For all other types
passed in the general registers, unused bits are undefined." */
#define PROMOTE_FUNCTION_MODE(MODE,UNSIGNEDP,TYPE) \
if (GET_MODE_CLASS (MODE) == MODE_INT \
&& GET_MODE_SIZE (MODE) < UNITS_PER_WORD) \
{ \
if ((MODE) == SImode) \
(UNSIGNEDP) = 0; \
(MODE) = DImode; \
}
/* The structure return address arrives as an "argument" on VMS. */ /* The structure return address arrives as an "argument" on VMS. */
#undef PCC_STATIC_STRUCT_RETURN #undef PCC_STATIC_STRUCT_RETURN
@ -227,5 +207,8 @@ typedef struct crtl_name_spec
#define ASM_OUTPUT_ALIGNED_DECL_COMMON(FILE, DECL, NAME, SIZE, ALIGN) \ #define ASM_OUTPUT_ALIGNED_DECL_COMMON(FILE, DECL, NAME, SIZE, ALIGN) \
ia64_vms_output_aligned_decl_common (FILE, DECL, NAME, SIZE, ALIGN) ia64_vms_output_aligned_decl_common (FILE, DECL, NAME, SIZE, ALIGN)
#undef TARGET_VALID_POINTER_MODE
#define TARGET_VALID_POINTER_MODE ia64_vms_valid_pointer_mode
#undef TARGET_ASM_NAMED_SECTION #undef TARGET_ASM_NAMED_SECTION
#define TARGET_ASM_NAMED_SECTION ia64_vms_elf_asm_named_section #define TARGET_ASM_NAMED_SECTION ia64_vms_elf_asm_named_section