errqueue.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2. #ifndef _UAPI_LINUX_ERRQUEUE_H
  3. #define _UAPI_LINUX_ERRQUEUE_H
  4. #include <linux/types.h>
  5. struct sock_extended_err {
  6. __u32 ee_errno;
  7. __u8 ee_origin;
  8. __u8 ee_type;
  9. __u8 ee_code;
  10. __u8 ee_pad;
  11. __u32 ee_info;
  12. __u32 ee_data;
  13. };
  14. #define SO_EE_ORIGIN_NONE 0
  15. #define SO_EE_ORIGIN_LOCAL 1
  16. #define SO_EE_ORIGIN_ICMP 2
  17. #define SO_EE_ORIGIN_ICMP6 3
  18. #define SO_EE_ORIGIN_TXSTATUS 4
  19. #define SO_EE_ORIGIN_ZEROCOPY 5
  20. #define SO_EE_ORIGIN_TIMESTAMPING SO_EE_ORIGIN_TXSTATUS
  21. #define SO_EE_OFFENDER(ee) ((struct sockaddr*)((ee)+1))
  22. #define SO_EE_CODE_ZEROCOPY_COPIED 1
  23. /**
  24. * struct scm_timestamping - timestamps exposed through cmsg
  25. *
  26. * The timestamping interfaces SO_TIMESTAMPING, MSG_TSTAMP_*
  27. * communicate network timestamps by passing this struct in a cmsg with
  28. * recvmsg(). See Documentation/networking/timestamping.txt for details.
  29. */
  30. struct scm_timestamping {
  31. struct timespec ts[3];
  32. };
  33. /* The type of scm_timestamping, passed in sock_extended_err ee_info.
  34. * This defines the type of ts[0]. For SCM_TSTAMP_SND only, if ts[0]
  35. * is zero, then this is a hardware timestamp and recorded in ts[2].
  36. */
  37. enum {
  38. SCM_TSTAMP_SND, /* driver passed skb to NIC, or HW */
  39. SCM_TSTAMP_SCHED, /* data entered the packet scheduler */
  40. SCM_TSTAMP_ACK, /* data acknowledged by peer */
  41. };
  42. #endif /* _UAPI_LINUX_ERRQUEUE_H */