diff options
author | mrs <mrs@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-04-08 23:30:23 +0000 |
---|---|---|
committer | mrs <mrs@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-04-08 23:30:23 +0000 |
commit | 8063e5585821f56bf97ab509d7bd00cbdccc153a (patch) | |
tree | 1245474678eecc85ea556c534606a1cccf0d1de2 | |
parent | 988f49167193cf59485a83697c4be0e6352f5ee1 (diff) | |
download | gcc-8063e5585821f56bf97ab509d7bd00cbdccc153a.tar.gz |
* config/rs6000/rs6000.c (rs6000_emit_prologue): Use 5 nops,
instead of 4.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@97871 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 3 | ||||
-rw-r--r-- | gcc/config/darwin.c | 4 | ||||
-rw-r--r-- | gcc/config/rs6000/darwin.h | 2 | ||||
-rw-r--r-- | gcc/config/rs6000/rs6000.c | 3 |
4 files changed, 8 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 73ec69f286d..3f99ac1b203 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -8,6 +8,9 @@ 2005-04-08 Mike Stump <mrs@apple.com> * config/darwin.c (indirect_data): Fix typo in strncmp logic. + + * config/rs6000/rs6000.c (rs6000_emit_prologue): Use 5 nops, + instead of 4. 2005-04-08 Kazu Hirata <kazu@cs.umass.edu> diff --git a/gcc/config/darwin.c b/gcc/config/darwin.c index 0b2ddc3677a..d3cafb165e4 100644 --- a/gcc/config/darwin.c +++ b/gcc/config/darwin.c @@ -59,8 +59,8 @@ Boston, MA 02111-1307, USA. */ existed in the unit to be replaced, and from the new translation unit, for new data. - The changes are to insert 4 nops at the beginning of all functions - and to use indirection to get at static duration data. The 4 nops + The changes are to insert 5 nops at the beginning of all functions + and to use indirection to get at static duration data. The 5 nops are required by consumers of the generated code. Currently, gdb uses this to patch in a jump to the overriding function, this allows all uses of the old name to forward to the replacement, diff --git a/gcc/config/rs6000/darwin.h b/gcc/config/rs6000/darwin.h index a6e3fde7966..3d646043ab1 100644 --- a/gcc/config/rs6000/darwin.h +++ b/gcc/config/rs6000/darwin.h @@ -406,7 +406,7 @@ extern const char *darwin_one_byte_bool; #define HAS_MD_FALLBACK_FRAME_STATE_FOR 1 /* True, iff we're generating fast turn around debugging code. When - true, we arrange for function prologues to start with 4 nops so + true, we arrange for function prologues to start with 5 nops so that gdb may insert code to redirect them, and for data to be accessed indirectly. The runtime uses this indirection to forward references for data to the original instance of that data. */ diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index 8ca07a24211..c75c272abc3 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -12565,7 +12565,7 @@ rs6000_emit_prologue (void) if (TARGET_FIX_AND_CONTINUE) { /* gdb on darwin arranges to forward a function from the old - address by modifying the first 4 instructions of the function + address by modifying the first 5 instructions of the function to branch to the overriding function. This is necessary to permit function pointers that point to the old function to actually forward to the new function. */ @@ -12573,6 +12573,7 @@ rs6000_emit_prologue (void) emit_insn (gen_nop ()); emit_insn (gen_nop ()); emit_insn (gen_nop ()); + emit_insn (gen_nop ()); } if (TARGET_SPE_ABI && info->spe_64bit_regs_used != 0) |