diff options
author | Joel Brobecker <brobecker@gnat.com> | 2003-03-18 18:26:41 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2003-03-18 18:26:41 +0000 |
commit | 3371ccc06e3e0c51f5e43ffe228cea7161cbd59d (patch) | |
tree | 5e07d5cc29898a91affa6a06d0c80f9805b1a159 | |
parent | 4fbe891ea11b5631e22e8a9cb2fdc4942d8b15e9 (diff) | |
download | gdb-3371ccc06e3e0c51f5e43ffe228cea7161cbd59d.zip gdb-3371ccc06e3e0c51f5e43ffe228cea7161cbd59d.tar.gz gdb-3371ccc06e3e0c51f5e43ffe228cea7161cbd59d.tar.bz2 |
* hppa-tdep.c (hppa_push_dummy_frame): Remove hack which does not
appear to be working in any case.
-rw-r--r-- | gdb/ChangeLog | 5 | ||||
-rw-r--r-- | gdb/hppa-tdep.c | 18 |
2 files changed, 6 insertions, 17 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 7a472db..1413a38 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,10 @@ 2003-03-18 J. Brobecker <brobecker@gnat.com> + * hppa-tdep.c (hppa_push_dummy_frame): Remove hack which does not + appear to be working in any case. + +2003-03-18 J. Brobecker <brobecker@gnat.com> + * observer.c (observer_test_first_observer): New static variable. (observer_test_second_observer): Likewise. (observer_test_third_observer): Likewise. diff --git a/gdb/hppa-tdep.c b/gdb/hppa-tdep.c index f74dfd1..35ae0a1 100644 --- a/gdb/hppa-tdep.c +++ b/gdb/hppa-tdep.c @@ -1440,31 +1440,15 @@ hppa_push_dummy_frame (struct inferior_status *inf_status) CORE_ADDR int_buffer; double freg_buffer; - /* Oh, what a hack. If we're trying to perform an inferior call - while the inferior is asleep, we have to make sure to clear - the "in system call" bit in the flag register (the call will - start after the syscall returns, so we're no longer in the system - call!) This state is kept in "inf_status", change it there. - - We also need a number of horrid hacks to deal with lossage in the - PC queue registers (apparently they're not valid when the in syscall - bit is set). */ pc = hppa_target_read_pc (inferior_ptid); int_buffer = read_register (FLAGS_REGNUM); if (int_buffer & 0x2) { - unsigned int sid; - int_buffer &= ~0x2; - write_inferior_status_register (inf_status, 0, int_buffer); - write_inferior_status_register (inf_status, PCOQ_HEAD_REGNUM, pc + 0); - write_inferior_status_register (inf_status, PCOQ_TAIL_REGNUM, pc + 4); - sid = (pc >> 30) & 0x3; + const unsigned int sid = (pc >> 30) & 0x3; if (sid == 0) pcspace = read_register (SR4_REGNUM); else pcspace = read_register (SR4_REGNUM + 4 + sid); - write_inferior_status_register (inf_status, PCSQ_HEAD_REGNUM, pcspace); - write_inferior_status_register (inf_status, PCSQ_TAIL_REGNUM, pcspace); } else pcspace = read_register (PCSQ_HEAD_REGNUM); |