Pavel Emelyanov | d366477 | 2011-12-06 07:58:03 +0000 | [diff] [blame] | 1 | #ifndef __SOCK_DIAG_H__ |
| 2 | #define __SOCK_DIAG_H__ |
Pavel Emelyanov | e7c466e | 2011-12-15 02:42:42 +0000 | [diff] [blame] | 3 | |
Pavel Emelyanov | e6fe237 | 2011-12-30 00:52:21 +0000 | [diff] [blame^] | 4 | #include <linux/types.h> |
Pavel Emelyanov | e7c466e | 2011-12-15 02:42:42 +0000 | [diff] [blame] | 5 | |
Pavel Emelyanov | e6fe237 | 2011-12-30 00:52:21 +0000 | [diff] [blame^] | 6 | #define SOCK_DIAG_BY_FAMILY 20 |
Pavel Emelyanov | d366477 | 2011-12-06 07:58:03 +0000 | [diff] [blame] | 7 | |
| 8 | struct sock_diag_req { |
| 9 | __u8 sdiag_family; |
| 10 | __u8 sdiag_protocol; |
| 11 | }; |
| 12 | |
Pavel Emelyanov | e6fe237 | 2011-12-30 00:52:21 +0000 | [diff] [blame^] | 13 | #ifdef __KERNEL__ |
| 14 | struct sk_buff; |
| 15 | struct nlmsghdr; |
| 16 | |
Pavel Emelyanov | d366477 | 2011-12-06 07:58:03 +0000 | [diff] [blame] | 17 | struct sock_diag_handler { |
| 18 | __u8 family; |
| 19 | int (*dump)(struct sk_buff *skb, struct nlmsghdr *nlh); |
| 20 | }; |
| 21 | |
| 22 | int sock_diag_register(struct sock_diag_handler *h); |
| 23 | void sock_diag_unregister(struct sock_diag_handler *h); |
| 24 | |
| 25 | void sock_diag_register_inet_compat(int (*fn)(struct sk_buff *skb, struct nlmsghdr *nlh)); |
| 26 | void sock_diag_unregister_inet_compat(int (*fn)(struct sk_buff *skb, struct nlmsghdr *nlh)); |
| 27 | |
Pavel Emelyanov | f65c1b5 | 2011-12-15 02:43:44 +0000 | [diff] [blame] | 28 | int sock_diag_check_cookie(void *sk, __u32 *cookie); |
| 29 | void sock_diag_save_cookie(void *sk, __u32 *cookie); |
| 30 | |
Pavel Emelyanov | d366477 | 2011-12-06 07:58:03 +0000 | [diff] [blame] | 31 | extern struct sock *sock_diag_nlsk; |
Pavel Emelyanov | e6fe237 | 2011-12-30 00:52:21 +0000 | [diff] [blame^] | 32 | #endif /* KERNEL */ |
Pavel Emelyanov | d366477 | 2011-12-06 07:58:03 +0000 | [diff] [blame] | 33 | #endif |