summaryrefslogtreecommitdiff
path: root/libdde-linux26/contrib/include/linux/errqueue.h
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2013-07-27 22:15:10 +0000
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2013-07-27 22:15:10 +0000
commitb5875be0451b92bdd99663c8305ae46bd6a7d90c (patch)
tree68a6a5f79ac618c79ba3777c21faaea9aec2f0b4 /libdde-linux26/contrib/include/linux/errqueue.h
parentce6a36c7f7c88e7ca0fda816f9282237bb86829d (diff)
parent7996a3d79d55b7f879dfd62e202bbfe2963718d3 (diff)
Merge branch 'upstream-merged'
Diffstat (limited to 'libdde-linux26/contrib/include/linux/errqueue.h')
-rw-r--r--libdde-linux26/contrib/include/linux/errqueue.h48
1 files changed, 48 insertions, 0 deletions
diff --git a/libdde-linux26/contrib/include/linux/errqueue.h b/libdde-linux26/contrib/include/linux/errqueue.h
new file mode 100644
index 00000000..ceb1454b
--- /dev/null
+++ b/libdde-linux26/contrib/include/linux/errqueue.h
@@ -0,0 +1,48 @@
+#ifndef _LINUX_ERRQUEUE_H
+#define _LINUX_ERRQUEUE_H 1
+
+#include <linux/types.h>
+
+struct sock_extended_err
+{
+ __u32 ee_errno;
+ __u8 ee_origin;
+ __u8 ee_type;
+ __u8 ee_code;
+ __u8 ee_pad;
+ __u32 ee_info;
+ __u32 ee_data;
+};
+
+#define SO_EE_ORIGIN_NONE 0
+#define SO_EE_ORIGIN_LOCAL 1
+#define SO_EE_ORIGIN_ICMP 2
+#define SO_EE_ORIGIN_ICMP6 3
+
+#define SO_EE_OFFENDER(ee) ((struct sockaddr*)((ee)+1))
+
+#ifdef __KERNEL__
+
+#include <net/ip.h>
+#if defined(CONFIG_IPV6) || defined (CONFIG_IPV6_MODULE)
+#include <linux/ipv6.h>
+#endif
+
+#define SKB_EXT_ERR(skb) ((struct sock_exterr_skb *) ((skb)->cb))
+
+struct sock_exterr_skb
+{
+ union {
+ struct inet_skb_parm h4;
+#if defined(CONFIG_IPV6) || defined (CONFIG_IPV6_MODULE)
+ struct inet6_skb_parm h6;
+#endif
+ } header;
+ struct sock_extended_err ee;
+ u16 addr_offset;
+ __be16 port;
+};
+
+#endif
+
+#endif