11da177e4SLinus Torvalds #ifndef __LINUX_NET_AFUNIX_H 21da177e4SLinus Torvalds #define __LINUX_NET_AFUNIX_H 3*20380731SArnaldo Carvalho de Melo 4*20380731SArnaldo Carvalho de Melo #include <linux/config.h> 5*20380731SArnaldo Carvalho de Melo #include <linux/socket.h> 6*20380731SArnaldo Carvalho de Melo #include <linux/un.h> 7*20380731SArnaldo Carvalho de Melo #include <net/sock.h> 8*20380731SArnaldo 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]; 161da177e4SLinus Torvalds extern rwlock_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 */ 561da177e4SLinus Torvalds }; 571da177e4SLinus Torvalds 581da177e4SLinus Torvalds #define UNIXCB(skb) (*(struct unix_skb_parms*)&((skb)->cb)) 591da177e4SLinus Torvalds #define UNIXCREDS(skb) (&UNIXCB((skb)).creds) 601da177e4SLinus Torvalds 611da177e4SLinus Torvalds #define unix_state_rlock(s) read_lock(&unix_sk(s)->lock) 621da177e4SLinus Torvalds #define unix_state_runlock(s) read_unlock(&unix_sk(s)->lock) 631da177e4SLinus Torvalds #define unix_state_wlock(s) write_lock(&unix_sk(s)->lock) 641da177e4SLinus Torvalds #define unix_state_wunlock(s) write_unlock(&unix_sk(s)->lock) 651da177e4SLinus Torvalds 661da177e4SLinus Torvalds #ifdef __KERNEL__ 671da177e4SLinus Torvalds /* The AF_UNIX socket */ 681da177e4SLinus Torvalds struct unix_sock { 691da177e4SLinus Torvalds /* WARNING: sk has to be the first member */ 701da177e4SLinus Torvalds struct sock sk; 711da177e4SLinus Torvalds struct unix_address *addr; 721da177e4SLinus Torvalds struct dentry *dentry; 731da177e4SLinus Torvalds struct vfsmount *mnt; 741da177e4SLinus Torvalds struct semaphore readsem; 751da177e4SLinus Torvalds struct sock *peer; 761da177e4SLinus Torvalds struct sock *other; 771da177e4SLinus Torvalds struct sock *gc_tree; 781da177e4SLinus Torvalds atomic_t inflight; 791da177e4SLinus Torvalds rwlock_t lock; 801da177e4SLinus Torvalds wait_queue_head_t peer_wait; 811da177e4SLinus Torvalds }; 821da177e4SLinus Torvalds #define unix_sk(__sk) ((struct unix_sock *)__sk) 83*20380731SArnaldo Carvalho de Melo 84*20380731SArnaldo Carvalho de Melo #ifdef CONFIG_SYSCTL 85*20380731SArnaldo Carvalho de Melo extern int sysctl_unix_max_dgram_qlen; 86*20380731SArnaldo Carvalho de Melo extern void unix_sysctl_register(void); 87*20380731SArnaldo Carvalho de Melo extern void unix_sysctl_unregister(void); 88*20380731SArnaldo Carvalho de Melo #else 89*20380731SArnaldo Carvalho de Melo static inline void unix_sysctl_register(void) {} 90*20380731SArnaldo Carvalho de Melo static inline void unix_sysctl_unregister(void) {} 91*20380731SArnaldo Carvalho de Melo #endif 921da177e4SLinus Torvalds #endif 931da177e4SLinus Torvalds #endif 94