diff options
author | pkoning <pkoning@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-29 15:29:51 +0000 |
---|---|---|
committer | pkoning <pkoning@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-29 15:29:51 +0000 |
commit | 4dce1bf89c4eda777896ae58931dfe0b9fbec4d9 (patch) | |
tree | 7ad21904379806856571c1252895bc65c4804d01 | |
parent | d16566579cf1b541813986dc43183428789ad43c (diff) | |
download | gcc-4dce1bf89c4eda777896ae58931dfe0b9fbec4d9.tar.gz |
* config/pdp11/pdp11.c (pdp11_trampoline_init): Correct
instruction encoding.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@166063 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/config/pdp11/pdp11.c | 8 |
2 files changed, 9 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 89bc104e227..2a9150e6613 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2010-10-29 Paul Koning <ni1d@arrl.net> + + * config/pdp11/pdp11.c (pdp11_trampoline_init): Correct + instruction encoding. + 2010-10-29 Artjoms Sinkarovs <artyom.shinakroff@gmail.com> Andrew Pinski <pinskia@gmail.com> diff --git a/gcc/config/pdp11/pdp11.c b/gcc/config/pdp11/pdp11.c index c586b9ccf6d..6a5e8ea1cf9 100644 --- a/gcc/config/pdp11/pdp11.c +++ b/gcc/config/pdp11/pdp11.c @@ -1908,8 +1908,8 @@ pdp11_function_value_regno_p (const unsigned int regno) the following should work for shared I/D: - MV #STATIC, $4 0x940Y 0x0000 <- STATIC; Y = STATIC_CHAIN_REGNUM - JMP FUNCTION 0x0058 0x0000 <- FUNCTION + MOV #STATIC, $4 01270Y 0x0000 <- STATIC; Y = STATIC_CHAIN_REGNUM + JMP @#FUNCTION 000137 0x0000 <- FUNCTION */ static void @@ -1921,11 +1921,11 @@ pdp11_trampoline_init (rtx m_tramp, tree fndecl, rtx chain_value) gcc_assert (!TARGET_SPLIT); mem = adjust_address (m_tramp, HImode, 0); - emit_move_insn (mem, GEN_INT (0x9400+STATIC_CHAIN_REGNUM)); + emit_move_insn (mem, GEN_INT (012700+STATIC_CHAIN_REGNUM)); mem = adjust_address (m_tramp, HImode, 2); emit_move_insn (mem, chain_value); mem = adjust_address (m_tramp, HImode, 4); - emit_move_insn (mem, GEN_INT (0x0058)); + emit_move_insn (mem, GEN_INT (000137)); emit_move_insn (mem, fnaddr); } |