提交 69336bd2 编写于 作者: J Joe Perches 提交者: David S. Miller

sock.h: Remove extern from function prototypes

There are a mix of function prototypes with and without extern
in the kernel sources.  Standardize on not using extern for
function prototypes.

Function prototypes don't need to be written with extern.
extern is assumed by the compiler.  Its use is as unnecessary as
using auto to declare automatic/local variables in a block.
Signed-off-by: NJoe Perches <joe@perches.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 a4ea1fef
...@@ -746,7 +746,7 @@ static inline int sk_stream_wspace(const struct sock *sk) ...@@ -746,7 +746,7 @@ static inline int sk_stream_wspace(const struct sock *sk)
return sk->sk_sndbuf - sk->sk_wmem_queued; return sk->sk_sndbuf - sk->sk_wmem_queued;
} }
extern void sk_stream_write_space(struct sock *sk); void sk_stream_write_space(struct sock *sk);
/* OOB backlog add */ /* OOB backlog add */
static inline void __sk_add_backlog(struct sock *sk, struct sk_buff *skb) static inline void __sk_add_backlog(struct sock *sk, struct sk_buff *skb)
...@@ -788,7 +788,7 @@ static inline __must_check int sk_add_backlog(struct sock *sk, struct sk_buff *s ...@@ -788,7 +788,7 @@ static inline __must_check int sk_add_backlog(struct sock *sk, struct sk_buff *s
return 0; return 0;
} }
extern int __sk_backlog_rcv(struct sock *sk, struct sk_buff *skb); int __sk_backlog_rcv(struct sock *sk, struct sk_buff *skb);
static inline int sk_backlog_rcv(struct sock *sk, struct sk_buff *skb) static inline int sk_backlog_rcv(struct sock *sk, struct sk_buff *skb)
{ {
...@@ -853,15 +853,15 @@ static inline void sock_rps_reset_rxhash(struct sock *sk) ...@@ -853,15 +853,15 @@ static inline void sock_rps_reset_rxhash(struct sock *sk)
__rc; \ __rc; \
}) })
extern int sk_stream_wait_connect(struct sock *sk, long *timeo_p); int sk_stream_wait_connect(struct sock *sk, long *timeo_p);
extern int sk_stream_wait_memory(struct sock *sk, long *timeo_p); int sk_stream_wait_memory(struct sock *sk, long *timeo_p);
extern void sk_stream_wait_close(struct sock *sk, long timeo_p); void sk_stream_wait_close(struct sock *sk, long timeo_p);
extern int sk_stream_error(struct sock *sk, int flags, int err); int sk_stream_error(struct sock *sk, int flags, int err);
extern void sk_stream_kill_queues(struct sock *sk); void sk_stream_kill_queues(struct sock *sk);
extern void sk_set_memalloc(struct sock *sk); void sk_set_memalloc(struct sock *sk);
extern void sk_clear_memalloc(struct sock *sk); void sk_clear_memalloc(struct sock *sk);
extern int sk_wait_data(struct sock *sk, long *timeo); int sk_wait_data(struct sock *sk, long *timeo);
struct request_sock_ops; struct request_sock_ops;
struct timewait_sock_ops; struct timewait_sock_ops;
...@@ -1031,8 +1031,8 @@ struct cg_proto { ...@@ -1031,8 +1031,8 @@ struct cg_proto {
struct mem_cgroup *memcg; struct mem_cgroup *memcg;
}; };
extern int proto_register(struct proto *prot, int alloc_slab); int proto_register(struct proto *prot, int alloc_slab);
extern void proto_unregister(struct proto *prot); void proto_unregister(struct proto *prot);
static inline bool memcg_proto_active(struct cg_proto *cg_proto) static inline bool memcg_proto_active(struct cg_proto *cg_proto)
{ {
...@@ -1287,8 +1287,8 @@ proto_memory_pressure(struct proto *prot) ...@@ -1287,8 +1287,8 @@ proto_memory_pressure(struct proto *prot)
#ifdef CONFIG_PROC_FS #ifdef CONFIG_PROC_FS
/* Called with local bh disabled */ /* Called with local bh disabled */
extern void sock_prot_inuse_add(struct net *net, struct proto *prot, int inc); void sock_prot_inuse_add(struct net *net, struct proto *prot, int inc);
extern int sock_prot_inuse_get(struct net *net, struct proto *proto); int sock_prot_inuse_get(struct net *net, struct proto *proto);
#else #else
static inline void sock_prot_inuse_add(struct net *net, struct proto *prot, static inline void sock_prot_inuse_add(struct net *net, struct proto *prot,
int inc) int inc)
...@@ -1364,8 +1364,8 @@ static inline struct inode *SOCK_INODE(struct socket *socket) ...@@ -1364,8 +1364,8 @@ static inline struct inode *SOCK_INODE(struct socket *socket)
/* /*
* Functions for memory accounting * Functions for memory accounting
*/ */
extern int __sk_mem_schedule(struct sock *sk, int size, int kind); int __sk_mem_schedule(struct sock *sk, int size, int kind);
extern void __sk_mem_reclaim(struct sock *sk); void __sk_mem_reclaim(struct sock *sk);
#define SK_MEM_QUANTUM ((int)PAGE_SIZE) #define SK_MEM_QUANTUM ((int)PAGE_SIZE)
#define SK_MEM_QUANTUM_SHIFT ilog2(SK_MEM_QUANTUM) #define SK_MEM_QUANTUM_SHIFT ilog2(SK_MEM_QUANTUM)
...@@ -1473,14 +1473,14 @@ do { \ ...@@ -1473,14 +1473,14 @@ do { \
lockdep_init_map(&(sk)->sk_lock.dep_map, (name), (key), 0); \ lockdep_init_map(&(sk)->sk_lock.dep_map, (name), (key), 0); \
} while (0) } while (0)
extern void lock_sock_nested(struct sock *sk, int subclass); void lock_sock_nested(struct sock *sk, int subclass);
static inline void lock_sock(struct sock *sk) static inline void lock_sock(struct sock *sk)
{ {
lock_sock_nested(sk, 0); lock_sock_nested(sk, 0);
} }
extern void release_sock(struct sock *sk); void release_sock(struct sock *sk);
/* BH context may only use the following locking interface. */ /* BH context may only use the following locking interface. */
#define bh_lock_sock(__sk) spin_lock(&((__sk)->sk_lock.slock)) #define bh_lock_sock(__sk) spin_lock(&((__sk)->sk_lock.slock))
...@@ -1489,7 +1489,7 @@ extern void release_sock(struct sock *sk); ...@@ -1489,7 +1489,7 @@ extern void release_sock(struct sock *sk);
SINGLE_DEPTH_NESTING) SINGLE_DEPTH_NESTING)
#define bh_unlock_sock(__sk) spin_unlock(&((__sk)->sk_lock.slock)) #define bh_unlock_sock(__sk) spin_unlock(&((__sk)->sk_lock.slock))
extern bool lock_sock_fast(struct sock *sk); bool lock_sock_fast(struct sock *sk);
/** /**
* unlock_sock_fast - complement of lock_sock_fast * unlock_sock_fast - complement of lock_sock_fast
* @sk: socket * @sk: socket
...@@ -1507,108 +1507,84 @@ static inline void unlock_sock_fast(struct sock *sk, bool slow) ...@@ -1507,108 +1507,84 @@ static inline void unlock_sock_fast(struct sock *sk, bool slow)
} }
extern struct sock *sk_alloc(struct net *net, int family, struct sock *sk_alloc(struct net *net, int family, gfp_t priority,
gfp_t priority, struct proto *prot);
struct proto *prot); void sk_free(struct sock *sk);
extern void sk_free(struct sock *sk); void sk_release_kernel(struct sock *sk);
extern void sk_release_kernel(struct sock *sk); struct sock *sk_clone_lock(const struct sock *sk, const gfp_t priority);
extern struct sock *sk_clone_lock(const struct sock *sk,
const gfp_t priority); struct sk_buff *sock_wmalloc(struct sock *sk, unsigned long size, int force,
gfp_t priority);
extern struct sk_buff *sock_wmalloc(struct sock *sk, struct sk_buff *sock_rmalloc(struct sock *sk, unsigned long size, int force,
unsigned long size, int force, gfp_t priority);
gfp_t priority); void sock_wfree(struct sk_buff *skb);
extern struct sk_buff *sock_rmalloc(struct sock *sk, void skb_orphan_partial(struct sk_buff *skb);
unsigned long size, int force, void sock_rfree(struct sk_buff *skb);
gfp_t priority); void sock_edemux(struct sk_buff *skb);
extern void sock_wfree(struct sk_buff *skb);
extern void skb_orphan_partial(struct sk_buff *skb); int sock_setsockopt(struct socket *sock, int level, int op,
extern void sock_rfree(struct sk_buff *skb); char __user *optval, unsigned int optlen);
extern void sock_edemux(struct sk_buff *skb);
int sock_getsockopt(struct socket *sock, int level, int op,
extern int sock_setsockopt(struct socket *sock, int level, char __user *optval, int __user *optlen);
int op, char __user *optval, struct sk_buff *sock_alloc_send_skb(struct sock *sk, unsigned long size,
unsigned int optlen); int noblock, int *errcode);
struct sk_buff *sock_alloc_send_pskb(struct sock *sk, unsigned long header_len,
extern int sock_getsockopt(struct socket *sock, int level, unsigned long data_len, int noblock,
int op, char __user *optval, int *errcode, int max_page_order);
int __user *optlen); void *sock_kmalloc(struct sock *sk, int size, gfp_t priority);
extern struct sk_buff *sock_alloc_send_skb(struct sock *sk, void sock_kfree_s(struct sock *sk, void *mem, int size);
unsigned long size, void sk_send_sigurg(struct sock *sk);
int noblock,
int *errcode);
extern struct sk_buff *sock_alloc_send_pskb(struct sock *sk,
unsigned long header_len,
unsigned long data_len,
int noblock,
int *errcode,
int max_page_order);
extern void *sock_kmalloc(struct sock *sk, int size,
gfp_t priority);
extern void sock_kfree_s(struct sock *sk, void *mem, int size);
extern void sk_send_sigurg(struct sock *sk);
/* /*
* Functions to fill in entries in struct proto_ops when a protocol * Functions to fill in entries in struct proto_ops when a protocol
* does not implement a particular function. * does not implement a particular function.
*/ */
extern int sock_no_bind(struct socket *, int sock_no_bind(struct socket *, struct sockaddr *, int);
struct sockaddr *, int); int sock_no_connect(struct socket *, struct sockaddr *, int, int);
extern int sock_no_connect(struct socket *, int sock_no_socketpair(struct socket *, struct socket *);
struct sockaddr *, int, int); int sock_no_accept(struct socket *, struct socket *, int);
extern int sock_no_socketpair(struct socket *, int sock_no_getname(struct socket *, struct sockaddr *, int *, int);
struct socket *); unsigned int sock_no_poll(struct file *, struct socket *,
extern int sock_no_accept(struct socket *, struct poll_table_struct *);
struct socket *, int); int sock_no_ioctl(struct socket *, unsigned int, unsigned long);
extern int sock_no_getname(struct socket *, int sock_no_listen(struct socket *, int);
struct sockaddr *, int *, int); int sock_no_shutdown(struct socket *, int);
extern unsigned int sock_no_poll(struct file *, struct socket *, int sock_no_getsockopt(struct socket *, int , int, char __user *, int __user *);
struct poll_table_struct *); int sock_no_setsockopt(struct socket *, int, int, char __user *, unsigned int);
extern int sock_no_ioctl(struct socket *, unsigned int, int sock_no_sendmsg(struct kiocb *, struct socket *, struct msghdr *, size_t);
unsigned long); int sock_no_recvmsg(struct kiocb *, struct socket *, struct msghdr *, size_t,
extern int sock_no_listen(struct socket *, int); int);
extern int sock_no_shutdown(struct socket *, int); int sock_no_mmap(struct file *file, struct socket *sock,
extern int sock_no_getsockopt(struct socket *, int , int, struct vm_area_struct *vma);
char __user *, int __user *); ssize_t sock_no_sendpage(struct socket *sock, struct page *page, int offset,
extern int sock_no_setsockopt(struct socket *, int, int, size_t size, int flags);
char __user *, unsigned int);
extern int sock_no_sendmsg(struct kiocb *, struct socket *,
struct msghdr *, size_t);
extern int sock_no_recvmsg(struct kiocb *, struct socket *,
struct msghdr *, size_t, int);
extern int sock_no_mmap(struct file *file,
struct socket *sock,
struct vm_area_struct *vma);
extern ssize_t sock_no_sendpage(struct socket *sock,
struct page *page,
int offset, size_t size,
int flags);
/* /*
* Functions to fill in entries in struct proto_ops when a protocol * Functions to fill in entries in struct proto_ops when a protocol
* uses the inet style. * uses the inet style.
*/ */
extern int sock_common_getsockopt(struct socket *sock, int level, int optname, int sock_common_getsockopt(struct socket *sock, int level, int optname,
char __user *optval, int __user *optlen); char __user *optval, int __user *optlen);
extern int sock_common_recvmsg(struct kiocb *iocb, struct socket *sock, int sock_common_recvmsg(struct kiocb *iocb, struct socket *sock,
struct msghdr *msg, size_t size, int flags); struct msghdr *msg, size_t size, int flags);
extern int sock_common_setsockopt(struct socket *sock, int level, int optname, int sock_common_setsockopt(struct socket *sock, int level, int optname,
char __user *optval, unsigned int optlen); char __user *optval, unsigned int optlen);
extern int compat_sock_common_getsockopt(struct socket *sock, int level, int compat_sock_common_getsockopt(struct socket *sock, int level,
int optname, char __user *optval, int __user *optlen); int optname, char __user *optval, int __user *optlen);
extern int compat_sock_common_setsockopt(struct socket *sock, int level, int compat_sock_common_setsockopt(struct socket *sock, int level,
int optname, char __user *optval, unsigned int optlen); int optname, char __user *optval, unsigned int optlen);
extern void sk_common_release(struct sock *sk); void sk_common_release(struct sock *sk);
/* /*
* Default socket callbacks and setup code * Default socket callbacks and setup code
*/ */
/* Initialise core socket variables */ /* Initialise core socket variables */
extern void sock_init_data(struct socket *sock, struct sock *sk); void sock_init_data(struct socket *sock, struct sock *sk);
extern void sk_filter_release_rcu(struct rcu_head *rcu); void sk_filter_release_rcu(struct rcu_head *rcu);
/** /**
* sk_filter_release - release a socket filter * sk_filter_release - release a socket filter
...@@ -1669,8 +1645,7 @@ static inline void sock_put(struct sock *sk) ...@@ -1669,8 +1645,7 @@ static inline void sock_put(struct sock *sk)
sk_free(sk); sk_free(sk);
} }
extern int sk_receive_skb(struct sock *sk, struct sk_buff *skb, int sk_receive_skb(struct sock *sk, struct sk_buff *skb, const int nested);
const int nested);
static inline void sk_tx_queue_set(struct sock *sk, int tx_queue) static inline void sk_tx_queue_set(struct sock *sk, int tx_queue)
{ {
...@@ -1724,8 +1699,8 @@ static inline void sock_graft(struct sock *sk, struct socket *parent) ...@@ -1724,8 +1699,8 @@ static inline void sock_graft(struct sock *sk, struct socket *parent)
write_unlock_bh(&sk->sk_callback_lock); write_unlock_bh(&sk->sk_callback_lock);
} }
extern kuid_t sock_i_uid(struct sock *sk); kuid_t sock_i_uid(struct sock *sk);
extern unsigned long sock_i_ino(struct sock *sk); unsigned long sock_i_ino(struct sock *sk);
static inline struct dst_entry * static inline struct dst_entry *
__sk_dst_get(struct sock *sk) __sk_dst_get(struct sock *sk)
...@@ -1747,7 +1722,7 @@ sk_dst_get(struct sock *sk) ...@@ -1747,7 +1722,7 @@ sk_dst_get(struct sock *sk)
return dst; return dst;
} }
extern void sk_reset_txq(struct sock *sk); void sk_reset_txq(struct sock *sk);
static inline void dst_negative_advice(struct sock *sk) static inline void dst_negative_advice(struct sock *sk)
{ {
...@@ -1800,16 +1775,16 @@ sk_dst_reset(struct sock *sk) ...@@ -1800,16 +1775,16 @@ sk_dst_reset(struct sock *sk)
spin_unlock(&sk->sk_dst_lock); spin_unlock(&sk->sk_dst_lock);
} }
extern struct dst_entry *__sk_dst_check(struct sock *sk, u32 cookie); struct dst_entry *__sk_dst_check(struct sock *sk, u32 cookie);
extern struct dst_entry *sk_dst_check(struct sock *sk, u32 cookie); struct dst_entry *sk_dst_check(struct sock *sk, u32 cookie);
static inline bool sk_can_gso(const struct sock *sk) static inline bool sk_can_gso(const struct sock *sk)
{ {
return net_gso_ok(sk->sk_route_caps, sk->sk_gso_type); return net_gso_ok(sk->sk_route_caps, sk->sk_gso_type);
} }
extern void sk_setup_caps(struct sock *sk, struct dst_entry *dst); void sk_setup_caps(struct sock *sk, struct dst_entry *dst);
static inline void sk_nocaps_add(struct sock *sk, netdev_features_t flags) static inline void sk_nocaps_add(struct sock *sk, netdev_features_t flags)
{ {
...@@ -2022,14 +1997,14 @@ static inline void skb_set_owner_r(struct sk_buff *skb, struct sock *sk) ...@@ -2022,14 +1997,14 @@ static inline void skb_set_owner_r(struct sk_buff *skb, struct sock *sk)
sk_mem_charge(sk, skb->truesize); sk_mem_charge(sk, skb->truesize);
} }
extern void sk_reset_timer(struct sock *sk, struct timer_list *timer, void sk_reset_timer(struct sock *sk, struct timer_list *timer,
unsigned long expires); unsigned long expires);
extern void sk_stop_timer(struct sock *sk, struct timer_list *timer); void sk_stop_timer(struct sock *sk, struct timer_list *timer);
extern int sock_queue_rcv_skb(struct sock *sk, struct sk_buff *skb); int sock_queue_rcv_skb(struct sock *sk, struct sk_buff *skb);
extern int sock_queue_err_skb(struct sock *sk, struct sk_buff *skb); int sock_queue_err_skb(struct sock *sk, struct sk_buff *skb);
/* /*
* Recover an error report and clear atomically * Recover an error report and clear atomically
...@@ -2097,7 +2072,7 @@ static inline struct page_frag *sk_page_frag(struct sock *sk) ...@@ -2097,7 +2072,7 @@ static inline struct page_frag *sk_page_frag(struct sock *sk)
return &sk->sk_frag; return &sk->sk_frag;
} }
extern bool sk_page_frag_refill(struct sock *sk, struct page_frag *pfrag); bool sk_page_frag_refill(struct sock *sk, struct page_frag *pfrag);
/* /*
* Default write policy as shown to user space via poll/select/SIGIO * Default write policy as shown to user space via poll/select/SIGIO
...@@ -2135,10 +2110,10 @@ static inline int sock_intr_errno(long timeo) ...@@ -2135,10 +2110,10 @@ static inline int sock_intr_errno(long timeo)
return timeo == MAX_SCHEDULE_TIMEOUT ? -ERESTARTSYS : -EINTR; return timeo == MAX_SCHEDULE_TIMEOUT ? -ERESTARTSYS : -EINTR;
} }
extern void __sock_recv_timestamp(struct msghdr *msg, struct sock *sk, void __sock_recv_timestamp(struct msghdr *msg, struct sock *sk,
struct sk_buff *skb); struct sk_buff *skb);
extern void __sock_recv_wifi_status(struct msghdr *msg, struct sock *sk, void __sock_recv_wifi_status(struct msghdr *msg, struct sock *sk,
struct sk_buff *skb); struct sk_buff *skb);
static inline void static inline void
sock_recv_timestamp(struct msghdr *msg, struct sock *sk, struct sk_buff *skb) sock_recv_timestamp(struct msghdr *msg, struct sock *sk, struct sk_buff *skb)
...@@ -2171,8 +2146,8 @@ sock_recv_timestamp(struct msghdr *msg, struct sock *sk, struct sk_buff *skb) ...@@ -2171,8 +2146,8 @@ sock_recv_timestamp(struct msghdr *msg, struct sock *sk, struct sk_buff *skb)
__sock_recv_wifi_status(msg, sk, skb); __sock_recv_wifi_status(msg, sk, skb);
} }
extern void __sock_recv_ts_and_drops(struct msghdr *msg, struct sock *sk, void __sock_recv_ts_and_drops(struct msghdr *msg, struct sock *sk,
struct sk_buff *skb); struct sk_buff *skb);
static inline void sock_recv_ts_and_drops(struct msghdr *msg, struct sock *sk, static inline void sock_recv_ts_and_drops(struct msghdr *msg, struct sock *sk,
struct sk_buff *skb) struct sk_buff *skb)
...@@ -2197,7 +2172,7 @@ static inline void sock_recv_ts_and_drops(struct msghdr *msg, struct sock *sk, ...@@ -2197,7 +2172,7 @@ static inline void sock_recv_ts_and_drops(struct msghdr *msg, struct sock *sk,
* *
* Currently only depends on SOCK_TIMESTAMPING* flags. * Currently only depends on SOCK_TIMESTAMPING* flags.
*/ */
extern void sock_tx_timestamp(struct sock *sk, __u8 *tx_flags); void sock_tx_timestamp(struct sock *sk, __u8 *tx_flags);
/** /**
* sk_eat_skb - Release a skb if it is no longer needed * sk_eat_skb - Release a skb if it is no longer needed
...@@ -2261,11 +2236,11 @@ static inline struct sock *skb_steal_sock(struct sk_buff *skb) ...@@ -2261,11 +2236,11 @@ static inline struct sock *skb_steal_sock(struct sk_buff *skb)
return NULL; return NULL;
} }
extern void sock_enable_timestamp(struct sock *sk, int flag); void sock_enable_timestamp(struct sock *sk, int flag);
extern int sock_get_timestamp(struct sock *, struct timeval __user *); int sock_get_timestamp(struct sock *, struct timeval __user *);
extern int sock_get_timestampns(struct sock *, struct timespec __user *); int sock_get_timestampns(struct sock *, struct timespec __user *);
extern int sock_recv_errqueue(struct sock *sk, struct msghdr *msg, int len, int sock_recv_errqueue(struct sock *sk, struct msghdr *msg, int len, int level,
int level, int type); int type);
/* /*
* Enable debug/info messages * Enable debug/info messages
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册