diff options
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 7 | ||||
-rw-r--r-- | gdb/gdbarch-selftests.c | 17 |
2 files changed, 16 insertions, 8 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index ab91107..6854b8f 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,12 @@ 2020-06-18 Pedro Alves <palves@redhat.com> + * gdbarch-selftests.c: Include "progspace-and-thread.h". + (register_to_value_test): Mock a program_space too. Heap-allocate + the address space. Don't write to inferior_ptid. Use + switch_to_thread instead. + +2020-06-18 Pedro Alves <palves@redhat.com> + * linux-tdep.c (find_signalled_thread(thread_info *,void *)): Delete. (find_signalled_thread()): New, factored out from diff --git a/gdb/gdbarch-selftests.c b/gdb/gdbarch-selftests.c index 24a7515..91aa9d8 100644 --- a/gdb/gdbarch-selftests.c +++ b/gdb/gdbarch-selftests.c @@ -27,6 +27,7 @@ #include "target-float.h" #include "gdbsupport/def-vector.h" #include "gdbarch.h" +#include "progspace-and-thread.h" namespace selftests { @@ -75,24 +76,25 @@ register_to_value_test (struct gdbarch *gdbarch) test_target_ops mock_target; ptid_t mock_ptid (1, 1); + program_space mock_pspace (new_address_space ()); inferior mock_inferior (mock_ptid.pid ()); - address_space mock_aspace {}; mock_inferior.gdbarch = gdbarch; - mock_inferior.aspace = &mock_aspace; + mock_inferior.aspace = mock_pspace.aspace; + mock_inferior.pspace = &mock_pspace; thread_info mock_thread (&mock_inferior, mock_ptid); + scoped_restore_current_pspace_and_thread restore_pspace_thread; + scoped_restore restore_thread_list = make_scoped_restore (&mock_inferior.thread_list, &mock_thread); /* Add the mock inferior to the inferior list so that look ups by target+ptid can find it. */ scoped_restore restore_inferior_list - = make_scoped_restore (&inferior_list); - inferior_list = &mock_inferior; + = make_scoped_restore (&inferior_list, &mock_inferior); /* Switch to the mock inferior. */ - scoped_restore_current_inferior restore_current_inferior; - set_current_inferior (&mock_inferior); + switch_to_inferior_no_thread (&mock_inferior); /* Push the process_stratum target so we can mock accessing registers. */ @@ -102,8 +104,7 @@ register_to_value_test (struct gdbarch *gdbarch) SCOPE_EXIT { pop_all_targets_at_and_above (process_stratum); }; /* Switch to the mock thread. */ - scoped_restore restore_inferior_ptid - = make_scoped_restore (&inferior_ptid, mock_ptid); + switch_to_thread (&mock_thread); struct frame_info *frame = get_current_frame (); const int num_regs = gdbarch_num_cooked_regs (gdbarch); |