diff options
author | Zdenek Radouch <radouch@cygnus> | 1999-01-07 22:54:18 +0000 |
---|---|---|
committer | Zdenek Radouch <radouch@cygnus> | 1999-01-07 22:54:18 +0000 |
commit | 1c3101060cb8d12b022a9475395230909cc59c03 (patch) | |
tree | dc339af262829464eefe1eb1ae84cea674bb1df6 /gdb/config/fr30/tm-fr30.h | |
parent | 0e854a20193e4be40f5632fa4c7f50597042ac84 (diff) | |
download | gdb-1c3101060cb8d12b022a9475395230909cc59c03.zip gdb-1c3101060cb8d12b022a9475395230909cc59c03.tar.gz gdb-1c3101060cb8d12b022a9475395230909cc59c03.tar.bz2 |
Beta version of the FR30 port.
Diffstat (limited to 'gdb/config/fr30/tm-fr30.h')
-rw-r--r-- | gdb/config/fr30/tm-fr30.h | 27 |
1 files changed, 9 insertions, 18 deletions
diff --git a/gdb/config/fr30/tm-fr30.h b/gdb/config/fr30/tm-fr30.h index 8214f77..3870f88 100644 --- a/gdb/config/fr30/tm-fr30.h +++ b/gdb/config/fr30/tm-fr30.h @@ -102,13 +102,9 @@ extern void fr30_pop_frame PARAMS ((void)); #define CALL_DUMMY_LOCATION AT_ENTRY_POINT #define FIX_CALL_DUMMY(DUMMY, START, FUNADDR, NARGS, ARGS, TYPE, GCCP) #define CALL_DUMMY_ADDRESS() entry_point_address () -extern CORE_ADDR fr30_push_return_address PARAMS ((CORE_ADDR, CORE_ADDR)); -#define PUSH_RETURN_ADDRESS(PC, SP) fr30_push_return_address (PC, SP) - - +#define PUSH_RETURN_ADDRESS(PC, SP) (write_register(RP_REGNUM, CALL_DUMMY_ADDRESS()), SP) #define PUSH_DUMMY_FRAME generic_push_dummy_frame () - /* Number of bytes at start of arglist that are not really args. */ #define FRAME_ARGS_SKIP 0 @@ -120,7 +116,8 @@ extern CORE_ADDR fr30_push_return_address PARAMS ((CORE_ADDR, CORE_ADDR)); a function return value of type TYPE, and copy that, in virtual format, into VALBUF. */ #define EXTRACT_RETURN_VALUE(TYPE,REGBUF,VALBUF) \ - memcpy (VALBUF, REGBUF + REGISTER_BYTE(RETVAL_REG), TYPE_LENGTH (TYPE)) + memcpy (VALBUF, REGBUF + REGISTER_BYTE(RETVAL_REG) + \ + (TYPE_LENGTH(TYPE) < 4 ? 4 - TYPE_LENGTH(TYPE) : 0), TYPE_LENGTH (TYPE)) /* Extract from an array REGBUF containing the (raw) register state the address in which a function should return its structure value, @@ -132,8 +129,6 @@ extern CORE_ADDR fr30_push_return_address PARAMS ((CORE_ADDR, CORE_ADDR)); #define STORE_STRUCT_RETURN(ADDR, SP) \ { write_register (RETVAL_REG, (ADDR)); } - - #define FRAME_ARGS_ADDRESS(fi) (fi->frame) #define FRAME_LOCALS_ADDRESS(fi) ((fi)->frame) @@ -186,10 +181,6 @@ extern CORE_ADDR fr30_skip_prologue PARAMS ((CORE_ADDR pc)); /* Define this for Wingdb */ #define TARGET_FR30 -#if(1) /* Z.R. */ - -/*ARM example*/ - /* IEEE format floating point */ #define IEEE_FLOAT @@ -208,8 +199,6 @@ extern CORE_ADDR fr30_skip_prologue PARAMS ((CORE_ADDR pc)); (FRAMELESS) = (after_prologue == func_start); \ } -/*V850 example*/ - extern void fr30_init_extra_frame_info PARAMS ((struct frame_info *fi)); #define INIT_EXTRA_FRAME_INFO(fromleaf, fi) fr30_init_extra_frame_info (fi) @@ -224,7 +213,9 @@ fr30_push_arguments PARAMS ((int nargs, struct value **args, CORE_ADDR sp, #define PC_IN_CALL_DUMMY(PC, SP, FP) generic_pc_in_call_dummy (PC, SP) -#define USE_STRUCT_CONVENTION(GCC_P, TYPE) \ - (TYPE_NFIELDS (TYPE) > 1 || TYPE_LENGTH (TYPE) > 4) - -#endif /* Z.R. */ +/* always pass struct by value as a pointer */ +/* XXX Z.R. GCC does not do that today */ +#define REG_STRUCT_HAS_ADDR(gcc_p,type) \ + ((TYPE_LENGTH(type) > 4) && (TYPE_LENGTH(type) & 0x3)) +/* alway return struct by value by input pointer */ +#define USE_STRUCT_CONVENTION(GCC_P, TYPE) 1 |