Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
R
riscv-gcc-1
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
riscv-gcc-1
Commits
d29899ba
Commit
d29899ba
authored
May 20, 2008
by
Kai Tietz
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
2008-05-20 Kai Tietz <kai.tietz@onevision.com>
Reverted escaped patch. From-SVN: r135606
parent
4628e602
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
39 additions
and
61 deletions
+39
-61
gcc/config/i386/cygming.h
+8
-5
gcc/config/i386/i386-protos.h
+3
-3
gcc/config/i386/i386.c
+0
-0
gcc/config/i386/i386.h
+27
-52
gcc/config/i386/mingw32.h
+1
-1
No files found.
gcc/config/i386/cygming.h
View file @
d29899ba
...
...
@@ -34,10 +34,7 @@ along with GCC; see the file COPYING3. If not see
#endif
#undef TARGET_64BIT_MS_ABI
#define TARGET_64BIT_MS_ABI (!cfun ? DEFAULT_ABI == MS_ABI : TARGET_64BIT && cfun->machine->call_abi == MS_ABI)
#undef DEFAULT_ABI
#define DEFAULT_ABI (TARGET_64BIT ? MS_ABI : SYSV_ABI)
#define TARGET_64BIT_MS_ABI TARGET_64BIT
#undef DBX_REGISTER_NUMBER
#define DBX_REGISTER_NUMBER(n) \
...
...
@@ -126,6 +123,12 @@ along with GCC; see the file COPYING3. If not see
#undef LONG_TYPE_SIZE
#define LONG_TYPE_SIZE 32
#undef REG_PARM_STACK_SPACE
#define REG_PARM_STACK_SPACE(FNDECL) (TARGET_64BIT_MS_ABI ? 32 : 0)
#undef OUTGOING_REG_PARM_STACK_SPACE
#define OUTGOING_REG_PARM_STACK_SPACE(FNTYPE) (TARGET_64BIT_MS_ABI ? 1 : 0)
#undef REGPARM_MAX
#define REGPARM_MAX (TARGET_64BIT_MS_ABI ? 4 : 3)
...
...
@@ -211,7 +214,7 @@ do { \
#define CHECK_STACK_LIMIT 4000
#undef STACK_BOUNDARY
#define STACK_BOUNDARY (
DEFAULT_ABI ==
MS_ABI ? 128 : BITS_PER_WORD)
#define STACK_BOUNDARY (
TARGET_64BIT_
MS_ABI ? 128 : BITS_PER_WORD)
/* By default, target has a 80387, uses IEEE compatible arithmetic,
returns float values in the 387 and needs stack probes.
...
...
gcc/config/i386/i386-protos.h
View file @
d29899ba
...
...
@@ -134,12 +134,12 @@ extern rtx ix86_libcall_value (enum machine_mode);
extern
bool
ix86_function_value_regno_p
(
int
);
extern
bool
ix86_function_arg_regno_p
(
int
);
extern
int
ix86_function_arg_boundary
(
enum
machine_mode
,
tree
);
extern
bool
ix86_return_in_memory
(
const_tree
,
const_tree
);
extern
bool
ix86_sol10_return_in_memory
(
const_tree
,
const_tree
);
extern
bool
ix86_i386elf_return_in_memory
(
const_tree
,
const_tree
);
extern
bool
ix86_i386interix_return_in_memory
(
const_tree
,
const_tree
);
extern
rtx
ix86_force_to_memory
(
enum
machine_mode
,
rtx
);
extern
void
ix86_free_from_memory
(
enum
machine_mode
);
extern
int
ix86_cfun_abi
(
void
);
extern
int
ix86_function_abi
(
const_tree
);
extern
int
ix86_function_type_abi
(
const_tree
);
extern
void
ix86_split_fp_branch
(
enum
rtx_code
code
,
rtx
,
rtx
,
rtx
,
rtx
,
rtx
,
rtx
);
extern
bool
ix86_hard_regno_mode_ok
(
int
,
enum
machine_mode
);
...
...
gcc/config/i386/i386.c
View file @
d29899ba
This diff is collapsed.
Click to expand it.
gcc/config/i386/i386.h
View file @
d29899ba
...
...
@@ -446,17 +446,7 @@ extern tree x86_mfence;
#define TARGET_MACHO 0
/* Likewise, for the Windows 64-bit ABI. */
#define TARGET_64BIT_MS_ABI (TARGET_64BIT && ix86_cfun_abi () == MS_ABI)
/* Available call abi. */
enum
{
SYSV_ABI
=
0
,
MS_ABI
=
1
};
/* The default abi form used by target. */
#define DEFAULT_ABI SYSV_ABI
#define TARGET_64BIT_MS_ABI 0
/* Subtargets may reset this to 1 in order to enable 96-bit long double
with the rounding mode forced to 53 bits. */
...
...
@@ -814,8 +804,7 @@ enum target_cpu_default
#define PARM_BOUNDARY BITS_PER_WORD
/* Boundary (in *bits*) on which stack pointer should be aligned. */
#define STACK_BOUNDARY (TARGET_64BIT && DEFAULT_ABI == MS_ABI ? 128 \
: BITS_PER_WORD)
#define STACK_BOUNDARY BITS_PER_WORD
/* Boundary (in *bits*) on which the stack pointer prefers to be
aligned; the compiler cannot rely on having this alignment. */
...
...
@@ -1040,35 +1029,6 @@ enum target_cpu_default
#define ORDER_REGS_FOR_LOCAL_ALLOC x86_order_regs_for_local_alloc ()
/* regclass.c */
extern
void
init_regs
(
void
);
#define OVERRIDE_ABI_FORMAT(FNDECL) \
do { \
if (FNDECL == NULL) \
cfun->machine->call_abi = DEFAULT_ABI; \
else \
cfun->machine->call_abi = ix86_function_type_abi (TREE_TYPE (FNDECL)); \
if (cfun->machine->call_abi == MS_ABI && call_used_regs) \
{ \
if (call_used_regs[4
/*RSI*/
] != 0 || call_used_regs[5
/*RDI*/
] != 0) \
{ \
call_used_regs[4
/*RSI*/
] = 0; \
call_used_regs[5
/*RDI*/
] = 0; \
init_regs (); \
} \
} \
else if (TARGET_64BIT && call_used_regs) \
{ \
if (call_used_regs[4
/*RSI*/
] != 1 || call_used_regs[5
/*RDI*/
] != 1) \
{ \
call_used_regs[4
/*RSI*/
] = 1; \
call_used_regs[5
/*RDI*/
] = 1; \
init_regs (); \
} \
} \
} while (0)
/* Macro to conditionally modify fixed_regs/call_used_regs. */
#define CONDITIONAL_REGISTER_USAGE \
do { \
...
...
@@ -1119,6 +1079,11 @@ do { \
for (i = FIRST_REX_SSE_REG; i <= LAST_REX_SSE_REG; i++) \
reg_names[i] = ""; \
} \
if (TARGET_64BIT_MS_ABI) \
{ \
call_used_regs[4
/*RSI*/
] = 0; \
call_used_regs[5
/*RDI*/
] = 0; \
} \
} while (0)
/* Return number of consecutive hard regs needed starting at reg REGNO
...
...
@@ -1296,6 +1261,25 @@ do { \
#define GOT_SYMBOL_NAME "_GLOBAL_OFFSET_TABLE_"
/* A C expression which can inhibit the returning of certain function
values in registers, based on the type of value. A nonzero value
says to return the function value in memory, just as large
structures are always returned. Here TYPE will be a C expression
of type `tree', representing the data type of the value.
Note that values of mode `BLKmode' must be explicitly handled by
this macro. Also, the option `-fpcc-struct-return' takes effect
regardless of this macro. On most systems, it is possible to
leave the macro undefined; this causes a default definition to be
used, whose value is the constant 1 for `BLKmode' values, and 0
otherwise.
Do not use this macro to indicate that structures and unions
should always be returned in memory. You should instead use
`DEFAULT_PCC_STRUCT_RETURN' to indicate this. */
#define TARGET_RETURN_IN_MEMORY ix86_return_in_memory
/* This is overridden by <cygwin.h>. */
#define MS_AGGREGATE_RETURN 0
...
...
@@ -1644,11 +1628,7 @@ enum reg_class
This space can be allocated by the caller, or be a part of the
machine-dependent stack frame: `OUTGOING_REG_PARM_STACK_SPACE' says
which. */
#define REG_PARM_STACK_SPACE(FNDECL) ix86_reg_parm_stack_space (FNDECL)
#define OUTGOING_REG_PARM_STACK_SPACE(FNTYPE) (ix86_function_type_abi (FNTYPE) == MS_ABI ? 1 : 0)
extern
unsigned
int
ix86_reg_parm_stack_space
(
const_tree
);
#define REG_PARM_STACK_SPACE(FNDECL) 0
/* Value is the number of bytes of arguments automatically
popped when returning from a subroutine call.
...
...
@@ -1710,8 +1690,6 @@ typedef struct ix86_args {
int
maybe_vaarg
;
/* true for calls to possibly vardic fncts. */
int
float_in_sse
;
/* 1 if in 32-bit mode SFmode (2 for DFmode) should
be passed in SSE registers. Otherwise 0. */
int
call_abi
;
/* Set to SYSV_ABI for sysv abi. Otherwise
MS_ABI for ms abi. */
}
CUMULATIVE_ARGS
;
/* Initialize a variable CUM of type CUMULATIVE_ARGS
...
...
@@ -2489,9 +2467,6 @@ struct machine_function GTY(())
ix86_current_function_calls_tls_descriptor macro for a better
approximation. */
int
tls_descriptor_call_expanded_p
;
/* This value is used for amd64 targets and specifies the current abi
to be used. MS_ABI means ms abi. Otherwise SYSV_ABI means sysv abi. */
int
call_abi
;
};
#define ix86_stack_locals (cfun->machine->stack_locals)
...
...
gcc/config/i386/mingw32.h
View file @
d29899ba
...
...
@@ -38,7 +38,7 @@ along with GCC; see the file COPYING3. If not see
builtin_define_std ("WINNT"); \
builtin_define_with_int_value ("_INTEGRAL_MAX_BITS", \
TYPE_PRECISION (intmax_type_node));\
if (TARGET_64BIT
&& DEFAULT_ABI == MS_ABI)
\
if (TARGET_64BIT
_MS_ABI)
\
{ \
builtin_define ("__MINGW64__"); \
builtin_define_std ("WIN64"); \
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment