wait.c 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /**********************************************************************
  2. wait.c
  3. Copyright (C) 1999 Lars Brinkhoff. See the file COPYING for licensing
  4. terms and conditions.
  5. **********************************************************************/
  6. #include <errno.h>
  7. #include <signal.h>
  8. #include <sys/wait.h>
  9. #include "ptproxy.h"
  10. #include "sysdep.h"
  11. #include "wait.h"
  12. #include "user_util.h"
  13. #include "ptrace_user.h"
  14. #include "sysdep/ptrace.h"
  15. #include "sysdep/sigcontext.h"
  16. int proxy_wait_return(struct debugger *debugger, pid_t unused)
  17. {
  18. debugger->waiting = 0;
  19. if(debugger->debugee->died || (debugger->wait_options & __WCLONE)){
  20. debugger_cancelled_return(debugger, -ECHILD);
  21. return(0);
  22. }
  23. if(debugger->debugee->zombie && debugger->debugee->event)
  24. debugger->debugee->died = 1;
  25. if(debugger->debugee->event){
  26. debugger->debugee->event = 0;
  27. ptrace(PTRACE_POKEDATA, debugger->pid,
  28. debugger->wait_status_ptr,
  29. debugger->debugee->wait_status);
  30. /* if (wait4)
  31. ptrace (PTRACE_POKEDATA, pid, rusage_ptr, ...); */
  32. debugger_cancelled_return(debugger, debugger->debugee->pid);
  33. return(0);
  34. }
  35. /* pause will return -EINTR, which happens to be right for wait */
  36. debugger_normal_return(debugger, -1);
  37. return(0);
  38. }
  39. int parent_wait_return(struct debugger *debugger, pid_t unused)
  40. {
  41. return(debugger_normal_return(debugger, -1));
  42. }
  43. int real_wait_return(struct debugger *debugger)
  44. {
  45. unsigned long ip;
  46. int pid;
  47. pid = debugger->pid;
  48. ip = ptrace(PTRACE_PEEKUSR, pid, PT_IP_OFFSET, 0);
  49. IP_RESTART_SYSCALL(ip);
  50. if(ptrace(PTRACE_POKEUSR, pid, PT_IP_OFFSET, ip) < 0)
  51. tracer_panic("real_wait_return : Failed to restart system "
  52. "call, errno = %d\n", errno);
  53. if((ptrace(PTRACE_SYSCALL, debugger->pid, 0, SIGCHLD) < 0) ||
  54. (ptrace(PTRACE_SYSCALL, debugger->pid, 0, 0) < 0) ||
  55. (ptrace(PTRACE_SYSCALL, debugger->pid, 0, 0) < 0) ||
  56. debugger_normal_return(debugger, -1))
  57. tracer_panic("real_wait_return : gdb failed to wait, "
  58. "errno = %d\n", errno);
  59. return(0);
  60. }
  61. /*
  62. * Overrides for Emacs so that we follow Linus's tabbing style.
  63. * Emacs will notice this stuff at the end of the file and automatically
  64. * adjust the settings for this buffer only. This must remain at the end
  65. * of the file.
  66. * ---------------------------------------------------------------------------
  67. * Local variables:
  68. * c-file-style: "linux"
  69. * End:
  70. */