Commit 3ca3167c authored by David S. Miller's avatar David S. Miller

Merge bk://kernel.bkbits.net/acme/connection_sock-2.6

into nuts.davemloft.net:/disk1/BK/net-2.6
parents 812ab7f3 dfdae3a1
...@@ -262,8 +262,7 @@ struct raw6_sock { ...@@ -262,8 +262,7 @@ struct raw6_sock {
}; };
struct udp6_sock { struct udp6_sock {
struct inet_sock inet; struct udp_sock udp;
struct udp_opt udp;
struct ipv6_pinfo inet6; struct ipv6_pinfo inet6;
}; };
......
...@@ -40,26 +40,22 @@ struct udphdr { ...@@ -40,26 +40,22 @@ struct udphdr {
#include <net/sock.h> #include <net/sock.h>
#include <linux/ip.h> #include <linux/ip.h>
struct udp_opt { struct udp_sock {
int pending; /* Any pending frames ? */ /* inet_sock has to be the first member */
unsigned int corkflag; /* Cork is required */ struct inet_sock inet;
__u16 encap_type; /* Is this an Encapsulation socket? */ int pending; /* Any pending frames ? */
unsigned int corkflag; /* Cork is required */
__u16 encap_type; /* Is this an Encapsulation socket? */
/* /*
* Following member retains the infomation to create a UDP header * Following member retains the infomation to create a UDP header
* when the socket is uncorked. * when the socket is uncorked.
*/ */
__u16 len; /* total length of pending frames */ __u16 len; /* total length of pending frames */
};
/* WARNING: don't change the layout of the members in udp_sock! */
struct udp_sock {
struct inet_sock inet;
struct udp_opt udp;
}; };
static inline struct udp_opt * udp_sk(const struct sock *__sk) static inline struct udp_sock *udp_sk(const struct sock *sk)
{ {
return &((struct udp_sock *)__sk)->udp; return (struct udp_sock *)sk;
} }
#endif #endif
......
...@@ -386,7 +386,7 @@ void udp_err(struct sk_buff *skb, u32 info) ...@@ -386,7 +386,7 @@ void udp_err(struct sk_buff *skb, u32 info)
*/ */
static void udp_flush_pending_frames(struct sock *sk) static void udp_flush_pending_frames(struct sock *sk)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
if (up->pending) { if (up->pending) {
up->len = 0; up->len = 0;
...@@ -398,7 +398,7 @@ static void udp_flush_pending_frames(struct sock *sk) ...@@ -398,7 +398,7 @@ static void udp_flush_pending_frames(struct sock *sk)
/* /*
* Push out all pending data as one UDP datagram. Socket is locked. * Push out all pending data as one UDP datagram. Socket is locked.
*/ */
static int udp_push_pending_frames(struct sock *sk, struct udp_opt *up) static int udp_push_pending_frames(struct sock *sk, struct udp_sock *up)
{ {
struct inet_sock *inet = inet_sk(sk); struct inet_sock *inet = inet_sk(sk);
struct flowi *fl = &inet->cork.fl; struct flowi *fl = &inet->cork.fl;
...@@ -483,7 +483,7 @@ int udp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg, ...@@ -483,7 +483,7 @@ int udp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,
size_t len) size_t len)
{ {
struct inet_sock *inet = inet_sk(sk); struct inet_sock *inet = inet_sk(sk);
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
int ulen = len; int ulen = len;
struct ipcm_cookie ipc; struct ipcm_cookie ipc;
struct rtable *rt = NULL; struct rtable *rt = NULL;
...@@ -672,7 +672,7 @@ int udp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg, ...@@ -672,7 +672,7 @@ int udp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,
static int udp_sendpage(struct sock *sk, struct page *page, int offset, static int udp_sendpage(struct sock *sk, struct page *page, int offset,
size_t size, int flags) size_t size, int flags)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
int ret; int ret;
if (!up->pending) { if (!up->pending) {
...@@ -902,7 +902,7 @@ static int udp_encap_rcv(struct sock * sk, struct sk_buff *skb) ...@@ -902,7 +902,7 @@ static int udp_encap_rcv(struct sock * sk, struct sk_buff *skb)
#ifndef CONFIG_XFRM #ifndef CONFIG_XFRM
return 1; return 1;
#else #else
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
struct udphdr *uh = skb->h.uh; struct udphdr *uh = skb->h.uh;
struct iphdr *iph; struct iphdr *iph;
int iphlen, len; int iphlen, len;
...@@ -988,7 +988,7 @@ static int udp_encap_rcv(struct sock * sk, struct sk_buff *skb) ...@@ -988,7 +988,7 @@ static int udp_encap_rcv(struct sock * sk, struct sk_buff *skb)
*/ */
static int udp_queue_rcv_skb(struct sock * sk, struct sk_buff *skb) static int udp_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
/* /*
* Charge it to the socket, dropping if the queue is full. * Charge it to the socket, dropping if the queue is full.
...@@ -1223,7 +1223,7 @@ static int udp_destroy_sock(struct sock *sk) ...@@ -1223,7 +1223,7 @@ static int udp_destroy_sock(struct sock *sk)
static int udp_setsockopt(struct sock *sk, int level, int optname, static int udp_setsockopt(struct sock *sk, int level, int optname,
char __user *optval, int optlen) char __user *optval, int optlen)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
int val; int val;
int err = 0; int err = 0;
...@@ -1272,7 +1272,7 @@ static int udp_setsockopt(struct sock *sk, int level, int optname, ...@@ -1272,7 +1272,7 @@ static int udp_setsockopt(struct sock *sk, int level, int optname,
static int udp_getsockopt(struct sock *sk, int level, int optname, static int udp_getsockopt(struct sock *sk, int level, int optname,
char __user *optval, int __user *optlen) char __user *optval, int __user *optlen)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
int val, len; int val, len;
if (level != SOL_UDP) if (level != SOL_UDP)
......
...@@ -549,7 +549,7 @@ static int udpv6_rcv(struct sk_buff **pskb, unsigned int *nhoffp) ...@@ -549,7 +549,7 @@ static int udpv6_rcv(struct sk_buff **pskb, unsigned int *nhoffp)
*/ */
static void udp_v6_flush_pending_frames(struct sock *sk) static void udp_v6_flush_pending_frames(struct sock *sk)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
if (up->pending) { if (up->pending) {
up->len = 0; up->len = 0;
...@@ -562,7 +562,7 @@ static void udp_v6_flush_pending_frames(struct sock *sk) ...@@ -562,7 +562,7 @@ static void udp_v6_flush_pending_frames(struct sock *sk)
* Sending * Sending
*/ */
static int udp_v6_push_pending_frames(struct sock *sk, struct udp_opt *up) static int udp_v6_push_pending_frames(struct sock *sk, struct udp_sock *up)
{ {
struct sk_buff *skb; struct sk_buff *skb;
struct udphdr *uh; struct udphdr *uh;
...@@ -623,7 +623,7 @@ static int udpv6_sendmsg(struct kiocb *iocb, struct sock *sk, ...@@ -623,7 +623,7 @@ static int udpv6_sendmsg(struct kiocb *iocb, struct sock *sk,
struct msghdr *msg, size_t len) struct msghdr *msg, size_t len)
{ {
struct ipv6_txoptions opt_space; struct ipv6_txoptions opt_space;
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
struct inet_sock *inet = inet_sk(sk); struct inet_sock *inet = inet_sk(sk);
struct ipv6_pinfo *np = inet6_sk(sk); struct ipv6_pinfo *np = inet6_sk(sk);
struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *) msg->msg_name; struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *) msg->msg_name;
...@@ -878,7 +878,7 @@ static int udpv6_destroy_sock(struct sock *sk) ...@@ -878,7 +878,7 @@ static int udpv6_destroy_sock(struct sock *sk)
static int udpv6_setsockopt(struct sock *sk, int level, int optname, static int udpv6_setsockopt(struct sock *sk, int level, int optname,
char __user *optval, int optlen) char __user *optval, int optlen)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
int val; int val;
int err = 0; int err = 0;
...@@ -925,7 +925,7 @@ static int udpv6_setsockopt(struct sock *sk, int level, int optname, ...@@ -925,7 +925,7 @@ static int udpv6_setsockopt(struct sock *sk, int level, int optname,
static int udpv6_getsockopt(struct sock *sk, int level, int optname, static int udpv6_getsockopt(struct sock *sk, int level, int optname,
char __user *optval, int __user *optlen) char __user *optval, int __user *optlen)
{ {
struct udp_opt *up = udp_sk(sk); struct udp_sock *up = udp_sk(sk);
int val, len; int val, len;
if (level != SOL_UDP) if (level != SOL_UDP)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment