1
0

wait4.c 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. #define _GNU_SOURCE
  2. #include <sys/wait.h>
  3. #include <sys/resource.h>
  4. #include <string.h>
  5. #include <errno.h>
  6. #include "syscall.h"
  7. pid_t wait4(pid_t pid, int *status, int options, struct rusage *ru)
  8. {
  9. int r;
  10. #ifdef SYS_wait4_time64
  11. if (ru) {
  12. long long kru64[18];
  13. r = __syscall(SYS_wait4_time64, pid, status, options, kru64);
  14. if (!r) {
  15. ru->ru_utime = (struct timeval)
  16. { .tv_sec = kru64[0], .tv_usec = kru64[1] };
  17. ru->ru_stime = (struct timeval)
  18. { .tv_sec = kru64[2], .tv_usec = kru64[3] };
  19. char *slots = (char *)&ru->ru_maxrss;
  20. for (int i=0; i<14; i++)
  21. *(long *)(slots + i*sizeof(long)) = kru64[4+i];
  22. }
  23. if (SYS_wait4_time64 == SYS_wait4 || r != -ENOSYS)
  24. return __syscall_ret(r);
  25. }
  26. #endif
  27. char *dest = ru ? (char *)&ru->ru_maxrss - 4*sizeof(long) : 0;
  28. r = __syscall(SYS_wait4, pid, status, options, dest);
  29. if (r>0 && ru && sizeof(time_t) > sizeof(long)) {
  30. long kru[4];
  31. memcpy(kru, dest, 4*sizeof(long));
  32. ru->ru_utime = (struct timeval)
  33. { .tv_sec = kru[0], .tv_usec = kru[1] };
  34. ru->ru_stime = (struct timeval)
  35. { .tv_sec = kru[2], .tv_usec = kru[3] };
  36. }
  37. return __syscall_ret(r);
  38. }