2013-03-21 23:33:47 +07:00
|
|
|
#ifndef _AF_NETLINK_H
|
|
|
|
#define _AF_NETLINK_H
|
|
|
|
|
2014-08-02 16:47:45 +07:00
|
|
|
#include <linux/rhashtable.h>
|
2015-01-16 17:37:14 +07:00
|
|
|
#include <linux/atomic.h>
|
2013-03-21 23:33:47 +07:00
|
|
|
#include <net/sock.h>
|
|
|
|
|
|
|
|
#define NLGRPSZ(x) (ALIGN(x, sizeof(unsigned long) * 8) / 8)
|
|
|
|
#define NLGRPLONGS(x) (NLGRPSZ(x)/sizeof(unsigned long))
|
|
|
|
|
2013-04-17 13:47:01 +07:00
|
|
|
struct netlink_ring {
|
|
|
|
void **pg_vec;
|
|
|
|
unsigned int head;
|
|
|
|
unsigned int frames_per_block;
|
|
|
|
unsigned int frame_size;
|
|
|
|
unsigned int frame_max;
|
|
|
|
|
|
|
|
unsigned int pg_vec_order;
|
|
|
|
unsigned int pg_vec_pages;
|
|
|
|
unsigned int pg_vec_len;
|
|
|
|
|
|
|
|
atomic_t pending;
|
|
|
|
};
|
|
|
|
|
2013-03-21 23:33:47 +07:00
|
|
|
struct netlink_sock {
|
|
|
|
/* struct sock has to be the first member of netlink_sock */
|
|
|
|
struct sock sk;
|
|
|
|
u32 portid;
|
|
|
|
u32 dst_portid;
|
|
|
|
u32 dst_group;
|
|
|
|
u32 flags;
|
|
|
|
u32 subscriptions;
|
|
|
|
u32 ngroups;
|
|
|
|
unsigned long *groups;
|
|
|
|
unsigned long state;
|
2014-03-08 03:02:33 +07:00
|
|
|
size_t max_recvmsg_len;
|
2013-03-21 23:33:47 +07:00
|
|
|
wait_queue_head_t wait;
|
2013-08-16 05:31:06 +07:00
|
|
|
bool cb_running;
|
|
|
|
struct netlink_callback cb;
|
2013-03-21 23:33:47 +07:00
|
|
|
struct mutex *cb_mutex;
|
|
|
|
struct mutex cb_def_mutex;
|
|
|
|
void (*netlink_rcv)(struct sk_buff *skb);
|
2014-12-24 03:00:06 +07:00
|
|
|
int (*netlink_bind)(struct net *net, int group);
|
|
|
|
void (*netlink_unbind)(struct net *net, int group);
|
2013-03-21 23:33:47 +07:00
|
|
|
struct module *module;
|
2013-04-17 13:47:01 +07:00
|
|
|
#ifdef CONFIG_NETLINK_MMAP
|
|
|
|
struct mutex pg_vec_lock;
|
|
|
|
struct netlink_ring rx_ring;
|
|
|
|
struct netlink_ring tx_ring;
|
|
|
|
atomic_t mapped;
|
|
|
|
#endif /* CONFIG_NETLINK_MMAP */
|
2014-08-02 16:47:45 +07:00
|
|
|
|
|
|
|
struct rhash_head node;
|
2015-01-03 05:00:22 +07:00
|
|
|
struct rcu_head rcu;
|
2013-03-21 23:33:47 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct netlink_sock *nlk_sk(struct sock *sk)
|
|
|
|
{
|
|
|
|
return container_of(sk, struct netlink_sock, sk);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct netlink_table {
|
2014-08-02 16:47:45 +07:00
|
|
|
struct rhashtable hash;
|
2013-03-21 23:33:47 +07:00
|
|
|
struct hlist_head mc_list;
|
|
|
|
struct listeners __rcu *listeners;
|
|
|
|
unsigned int flags;
|
|
|
|
unsigned int groups;
|
|
|
|
struct mutex *cb_mutex;
|
|
|
|
struct module *module;
|
2014-12-24 03:00:06 +07:00
|
|
|
int (*bind)(struct net *net, int group);
|
|
|
|
void (*unbind)(struct net *net, int group);
|
2013-06-06 13:49:11 +07:00
|
|
|
bool (*compare)(struct net *net, struct sock *sock);
|
2013-03-21 23:33:47 +07:00
|
|
|
int registered;
|
|
|
|
};
|
|
|
|
|
|
|
|
extern struct netlink_table *nl_table;
|
|
|
|
extern rwlock_t nl_table_lock;
|
|
|
|
|
|
|
|
#endif
|