futex_op.c 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <linux/futex.h>
  3. #ifndef FUTEX_WAIT_BITSET
  4. #define FUTEX_WAIT_BITSET 9
  5. #endif
  6. #ifndef FUTEX_WAKE_BITSET
  7. #define FUTEX_WAKE_BITSET 10
  8. #endif
  9. #ifndef FUTEX_WAIT_REQUEUE_PI
  10. #define FUTEX_WAIT_REQUEUE_PI 11
  11. #endif
  12. #ifndef FUTEX_CMP_REQUEUE_PI
  13. #define FUTEX_CMP_REQUEUE_PI 12
  14. #endif
  15. #ifndef FUTEX_CLOCK_REALTIME
  16. #define FUTEX_CLOCK_REALTIME 256
  17. #endif
  18. static size_t syscall_arg__scnprintf_futex_op(char *bf, size_t size, struct syscall_arg *arg)
  19. {
  20. enum syscall_futex_args {
  21. SCF_UADDR = (1 << 0),
  22. SCF_OP = (1 << 1),
  23. SCF_VAL = (1 << 2),
  24. SCF_TIMEOUT = (1 << 3),
  25. SCF_UADDR2 = (1 << 4),
  26. SCF_VAL3 = (1 << 5),
  27. };
  28. int op = arg->val;
  29. int cmd = op & FUTEX_CMD_MASK;
  30. size_t printed = 0;
  31. switch (cmd) {
  32. #define P_FUTEX_OP(n) case FUTEX_##n: printed = scnprintf(bf, size, #n);
  33. P_FUTEX_OP(WAIT); arg->mask |= SCF_VAL3|SCF_UADDR2; break;
  34. P_FUTEX_OP(WAKE); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
  35. P_FUTEX_OP(FD); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
  36. P_FUTEX_OP(REQUEUE); arg->mask |= SCF_VAL3|SCF_TIMEOUT; break;
  37. P_FUTEX_OP(CMP_REQUEUE); arg->mask |= SCF_TIMEOUT; break;
  38. P_FUTEX_OP(CMP_REQUEUE_PI); arg->mask |= SCF_TIMEOUT; break;
  39. P_FUTEX_OP(WAKE_OP); break;
  40. P_FUTEX_OP(LOCK_PI); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
  41. P_FUTEX_OP(UNLOCK_PI); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
  42. P_FUTEX_OP(TRYLOCK_PI); arg->mask |= SCF_VAL3|SCF_UADDR2; break;
  43. P_FUTEX_OP(WAIT_BITSET); arg->mask |= SCF_UADDR2; break;
  44. P_FUTEX_OP(WAKE_BITSET); arg->mask |= SCF_UADDR2; break;
  45. P_FUTEX_OP(WAIT_REQUEUE_PI); break;
  46. default: printed = scnprintf(bf, size, "%#x", cmd); break;
  47. }
  48. if (op & FUTEX_PRIVATE_FLAG)
  49. printed += scnprintf(bf + printed, size - printed, "|PRIV");
  50. if (op & FUTEX_CLOCK_REALTIME)
  51. printed += scnprintf(bf + printed, size - printed, "|CLKRT");
  52. return printed;
  53. }
  54. #define SCA_FUTEX_OP syscall_arg__scnprintf_futex_op