xref: /openbmc/linux/include/net/af_unix.h (revision 1fd05ba5a2f2aa8e7b9b52ef55df850e2e7d54c9)
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