wait.c 2.3 KB

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