11da177e4SLinus Torvalds #ifndef __LINUX_NET_AFUNIX_H 21da177e4SLinus Torvalds #define __LINUX_NET_AFUNIX_H 320380731SArnaldo Carvalho de Melo 420380731SArnaldo Carvalho de Melo #include <linux/socket.h> 520380731SArnaldo Carvalho de Melo #include <linux/un.h> 657b47a53SIngo Molnar #include <linux/mutex.h> 720380731SArnaldo Carvalho de Melo #include <net/sock.h> 820380731SArnaldo Carvalho de Melo 91da177e4SLinus Torvalds extern void unix_inflight(struct file *fp); 101da177e4SLinus Torvalds extern void unix_notinflight(struct file *fp); 111da177e4SLinus Torvalds extern void unix_gc(void); 121da177e4SLinus Torvalds 131da177e4SLinus Torvalds #define UNIX_HASH_SIZE 256 141da177e4SLinus Torvalds 151da177e4SLinus Torvalds extern struct hlist_head unix_socket_table[UNIX_HASH_SIZE + 1]; 16fbe9cc4aSDavid S. Miller extern spinlock_t unix_table_lock; 171da177e4SLinus Torvalds 181da177e4SLinus Torvalds extern atomic_t unix_tot_inflight; 191da177e4SLinus Torvalds 201da177e4SLinus Torvalds static inline struct sock *first_unix_socket(int *i) 211da177e4SLinus Torvalds { 221da177e4SLinus Torvalds for (*i = 0; *i <= UNIX_HASH_SIZE; (*i)++) { 231da177e4SLinus Torvalds if (!hlist_empty(&unix_socket_table[*i])) 241da177e4SLinus Torvalds return __sk_head(&unix_socket_table[*i]); 251da177e4SLinus Torvalds } 261da177e4SLinus Torvalds return NULL; 271da177e4SLinus Torvalds } 281da177e4SLinus Torvalds 291da177e4SLinus Torvalds static inline struct sock *next_unix_socket(int *i, struct sock *s) 301da177e4SLinus Torvalds { 311da177e4SLinus Torvalds struct sock *next = sk_next(s); 321da177e4SLinus Torvalds /* More in this chain? */ 331da177e4SLinus Torvalds if (next) 341da177e4SLinus Torvalds return next; 351da177e4SLinus Torvalds /* Look for next non-empty chain. */ 361da177e4SLinus Torvalds for ((*i)++; *i <= UNIX_HASH_SIZE; (*i)++) { 371da177e4SLinus Torvalds if (!hlist_empty(&unix_socket_table[*i])) 381da177e4SLinus Torvalds return __sk_head(&unix_socket_table[*i]); 391da177e4SLinus Torvalds } 401da177e4SLinus Torvalds return NULL; 411da177e4SLinus Torvalds } 421da177e4SLinus Torvalds 431da177e4SLinus Torvalds #define forall_unix_sockets(i, s) \ 441da177e4SLinus Torvalds for (s = first_unix_socket(&(i)); s; s = next_unix_socket(&(i),(s))) 451da177e4SLinus Torvalds 461da177e4SLinus Torvalds struct unix_address { 471da177e4SLinus Torvalds atomic_t refcnt; 481da177e4SLinus Torvalds int len; 491da177e4SLinus Torvalds unsigned hash; 501da177e4SLinus Torvalds struct sockaddr_un name[0]; 511da177e4SLinus Torvalds }; 521da177e4SLinus Torvalds 531da177e4SLinus Torvalds struct unix_skb_parms { 541da177e4SLinus Torvalds struct ucred creds; /* Skb credentials */ 551da177e4SLinus Torvalds struct scm_fp_list *fp; /* Passed files */ 56877ce7c1SCatherine Zhang #ifdef CONFIG_SECURITY_NETWORK 57dc49c1f9SCatherine Zhang u32 secid; /* Security ID */ 58877ce7c1SCatherine Zhang #endif 591da177e4SLinus Torvalds }; 601da177e4SLinus Torvalds 611da177e4SLinus Torvalds #define UNIXCB(skb) (*(struct unix_skb_parms*)&((skb)->cb)) 621da177e4SLinus Torvalds #define UNIXCREDS(skb) (&UNIXCB((skb)).creds) 63dc49c1f9SCatherine Zhang #define UNIXSID(skb) (&UNIXCB((skb)).secid) 641da177e4SLinus Torvalds 651c92b4e5SDavid S. Miller #define unix_state_lock(s) spin_lock(&unix_sk(s)->lock) 661c92b4e5SDavid S. Miller #define unix_state_unlock(s) spin_unlock(&unix_sk(s)->lock) 671c92b4e5SDavid S. Miller #define unix_state_lock_nested(s) \ 68a09785a2SIngo Molnar spin_lock_nested(&unix_sk(s)->lock, \ 69a09785a2SIngo Molnar SINGLE_DEPTH_NESTING) 701da177e4SLinus Torvalds 711da177e4SLinus Torvalds #ifdef __KERNEL__ 721da177e4SLinus Torvalds /* The AF_UNIX socket */ 731da177e4SLinus Torvalds struct unix_sock { 741da177e4SLinus Torvalds /* WARNING: sk has to be the first member */ 751da177e4SLinus Torvalds struct sock sk; 761da177e4SLinus Torvalds struct unix_address *addr; 771da177e4SLinus Torvalds struct dentry *dentry; 781da177e4SLinus Torvalds struct vfsmount *mnt; 7957b47a53SIngo Molnar struct mutex readlock; 801da177e4SLinus Torvalds struct sock *peer; 811da177e4SLinus Torvalds struct sock *other; 82*1fd05ba5SMiklos Szeredi struct list_head link; 831da177e4SLinus Torvalds atomic_t inflight; 84fd19f329SBenjamin LaHaise spinlock_t lock; 85*1fd05ba5SMiklos Szeredi unsigned int gc_candidate : 1; 861da177e4SLinus Torvalds wait_queue_head_t peer_wait; 871da177e4SLinus Torvalds }; 881da177e4SLinus Torvalds #define unix_sk(__sk) ((struct unix_sock *)__sk) 8920380731SArnaldo Carvalho de Melo 9020380731SArnaldo Carvalho de Melo #ifdef CONFIG_SYSCTL 9120380731SArnaldo Carvalho de Melo extern int sysctl_unix_max_dgram_qlen; 9220380731SArnaldo Carvalho de Melo extern void unix_sysctl_register(void); 9320380731SArnaldo Carvalho de Melo extern void unix_sysctl_unregister(void); 9420380731SArnaldo Carvalho de Melo #else 9520380731SArnaldo Carvalho de Melo static inline void unix_sysctl_register(void) {} 9620380731SArnaldo Carvalho de Melo static inline void unix_sysctl_unregister(void) {} 9720380731SArnaldo Carvalho de Melo #endif 981da177e4SLinus Torvalds #endif 991da177e4SLinus Torvalds #endif 100