mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-06 22:42:10 +00:00
Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
This commit is contained in:
commit
1a324727ca
16 changed files with 70 additions and 45 deletions
|
@ -237,8 +237,10 @@ X!Ilib/string.c
|
||||||
<sect1><title>Driver Support</title>
|
<sect1><title>Driver Support</title>
|
||||||
!Enet/core/dev.c
|
!Enet/core/dev.c
|
||||||
!Enet/ethernet/eth.c
|
!Enet/ethernet/eth.c
|
||||||
!Einclude/linux/etherdevice.h
|
!Iinclude/linux/etherdevice.h
|
||||||
!Enet/core/wireless.c
|
<!-- FIXME: Removed for now since no structured comments in source
|
||||||
|
X!Enet/core/wireless.c
|
||||||
|
-->
|
||||||
</sect1>
|
</sect1>
|
||||||
<sect1><title>Synchronous PPP</title>
|
<sect1><title>Synchronous PPP</title>
|
||||||
!Edrivers/net/wan/syncppp.c
|
!Edrivers/net/wan/syncppp.c
|
||||||
|
|
|
@ -686,7 +686,8 @@ static int dev_ifconf(unsigned int fd, unsigned int cmd, unsigned long arg)
|
||||||
|
|
||||||
ifr = ifc.ifc_req;
|
ifr = ifc.ifc_req;
|
||||||
ifr32 = compat_ptr(ifc32.ifcbuf);
|
ifr32 = compat_ptr(ifc32.ifcbuf);
|
||||||
for (i = 0, j = 0; i < ifc32.ifc_len && j < ifc.ifc_len;
|
for (i = 0, j = 0;
|
||||||
|
i + sizeof (struct ifreq32) < ifc32.ifc_len && j < ifc.ifc_len;
|
||||||
i += sizeof (struct ifreq32), j += sizeof (struct ifreq)) {
|
i += sizeof (struct ifreq32), j += sizeof (struct ifreq)) {
|
||||||
if (copy_in_user(ifr32, ifr, sizeof (struct ifreq32)))
|
if (copy_in_user(ifr32, ifr, sizeof (struct ifreq32)))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
@ -702,10 +703,7 @@ static int dev_ifconf(unsigned int fd, unsigned int cmd, unsigned long arg)
|
||||||
i = ((i / sizeof(struct ifreq)) * sizeof(struct ifreq32));
|
i = ((i / sizeof(struct ifreq)) * sizeof(struct ifreq32));
|
||||||
ifc32.ifc_len = i;
|
ifc32.ifc_len = i;
|
||||||
} else {
|
} else {
|
||||||
if (i <= ifc32.ifc_len)
|
|
||||||
ifc32.ifc_len = i;
|
ifc32.ifc_len = i;
|
||||||
else
|
|
||||||
ifc32.ifc_len = i - sizeof (struct ifreq32);
|
|
||||||
}
|
}
|
||||||
if (copy_to_user(compat_ptr(arg), &ifc32, sizeof(struct ifconf32)))
|
if (copy_to_user(compat_ptr(arg), &ifc32, sizeof(struct ifconf32)))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
|
|
@ -7,8 +7,6 @@
|
||||||
|
|
||||||
#define IPT_SCTP_VALID_FLAGS 0x07
|
#define IPT_SCTP_VALID_FLAGS 0x07
|
||||||
|
|
||||||
#define ELEMCOUNT(x) (sizeof(x)/sizeof(x[0]))
|
|
||||||
|
|
||||||
|
|
||||||
struct ipt_sctp_flag_info {
|
struct ipt_sctp_flag_info {
|
||||||
u_int8_t chunktype;
|
u_int8_t chunktype;
|
||||||
|
@ -59,21 +57,21 @@ struct ipt_sctp_info {
|
||||||
#define SCTP_CHUNKMAP_RESET(chunkmap) \
|
#define SCTP_CHUNKMAP_RESET(chunkmap) \
|
||||||
do { \
|
do { \
|
||||||
int i; \
|
int i; \
|
||||||
for (i = 0; i < ELEMCOUNT(chunkmap); i++) \
|
for (i = 0; i < ARRAY_SIZE(chunkmap); i++) \
|
||||||
chunkmap[i] = 0; \
|
chunkmap[i] = 0; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define SCTP_CHUNKMAP_SET_ALL(chunkmap) \
|
#define SCTP_CHUNKMAP_SET_ALL(chunkmap) \
|
||||||
do { \
|
do { \
|
||||||
int i; \
|
int i; \
|
||||||
for (i = 0; i < ELEMCOUNT(chunkmap); i++) \
|
for (i = 0; i < ARRAY_SIZE(chunkmap); i++) \
|
||||||
chunkmap[i] = ~0; \
|
chunkmap[i] = ~0; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define SCTP_CHUNKMAP_COPY(destmap, srcmap) \
|
#define SCTP_CHUNKMAP_COPY(destmap, srcmap) \
|
||||||
do { \
|
do { \
|
||||||
int i; \
|
int i; \
|
||||||
for (i = 0; i < ELEMCOUNT(chunkmap); i++) \
|
for (i = 0; i < ARRAY_SIZE(chunkmap); i++) \
|
||||||
destmap[i] = srcmap[i]; \
|
destmap[i] = srcmap[i]; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
@ -81,7 +79,7 @@ struct ipt_sctp_info {
|
||||||
({ \
|
({ \
|
||||||
int i; \
|
int i; \
|
||||||
int flag = 1; \
|
int flag = 1; \
|
||||||
for (i = 0; i < ELEMCOUNT(chunkmap); i++) { \
|
for (i = 0; i < ARRAY_SIZE(chunkmap); i++) { \
|
||||||
if (chunkmap[i]) { \
|
if (chunkmap[i]) { \
|
||||||
flag = 0; \
|
flag = 0; \
|
||||||
break; \
|
break; \
|
||||||
|
@ -94,7 +92,7 @@ struct ipt_sctp_info {
|
||||||
({ \
|
({ \
|
||||||
int i; \
|
int i; \
|
||||||
int flag = 1; \
|
int flag = 1; \
|
||||||
for (i = 0; i < ELEMCOUNT(chunkmap); i++) { \
|
for (i = 0; i < ARRAY_SIZE(chunkmap); i++) { \
|
||||||
if (chunkmap[i] != ~0) { \
|
if (chunkmap[i] != ~0) { \
|
||||||
flag = 0; \
|
flag = 0; \
|
||||||
break; \
|
break; \
|
||||||
|
|
|
@ -206,6 +206,7 @@ enum {
|
||||||
* @nfct: Associated connection, if any
|
* @nfct: Associated connection, if any
|
||||||
* @ipvs_property: skbuff is owned by ipvs
|
* @ipvs_property: skbuff is owned by ipvs
|
||||||
* @nfctinfo: Relationship of this skb to the connection
|
* @nfctinfo: Relationship of this skb to the connection
|
||||||
|
* @nfct_reasm: netfilter conntrack re-assembly pointer
|
||||||
* @nf_bridge: Saved data about a bridged frame - see br_netfilter.c
|
* @nf_bridge: Saved data about a bridged frame - see br_netfilter.c
|
||||||
* @tc_index: Traffic control index
|
* @tc_index: Traffic control index
|
||||||
* @tc_verd: traffic control verdict
|
* @tc_verd: traffic control verdict
|
||||||
|
@ -264,16 +265,14 @@ struct sk_buff {
|
||||||
nohdr:1,
|
nohdr:1,
|
||||||
nfctinfo:3;
|
nfctinfo:3;
|
||||||
__u8 pkt_type:3,
|
__u8 pkt_type:3,
|
||||||
fclone:2;
|
fclone:2,
|
||||||
|
ipvs_property:1;
|
||||||
__be16 protocol;
|
__be16 protocol;
|
||||||
|
|
||||||
void (*destructor)(struct sk_buff *skb);
|
void (*destructor)(struct sk_buff *skb);
|
||||||
#ifdef CONFIG_NETFILTER
|
#ifdef CONFIG_NETFILTER
|
||||||
__u32 nfmark;
|
__u32 nfmark;
|
||||||
struct nf_conntrack *nfct;
|
struct nf_conntrack *nfct;
|
||||||
#if defined(CONFIG_IP_VS) || defined(CONFIG_IP_VS_MODULE)
|
|
||||||
__u8 ipvs_property:1;
|
|
||||||
#endif
|
|
||||||
#if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE)
|
#if defined(CONFIG_NF_CONNTRACK) || defined(CONFIG_NF_CONNTRACK_MODULE)
|
||||||
struct sk_buff *nfct_reasm;
|
struct sk_buff *nfct_reasm;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -237,6 +237,8 @@ extern struct ipv6_txoptions * ipv6_renew_options(struct sock *sk, struct ipv6_t
|
||||||
int newtype,
|
int newtype,
|
||||||
struct ipv6_opt_hdr __user *newopt,
|
struct ipv6_opt_hdr __user *newopt,
|
||||||
int newoptlen);
|
int newoptlen);
|
||||||
|
struct ipv6_txoptions *ipv6_fixup_options(struct ipv6_txoptions *opt_space,
|
||||||
|
struct ipv6_txoptions *opt);
|
||||||
|
|
||||||
extern int ip6_frag_nqueues;
|
extern int ip6_frag_nqueues;
|
||||||
extern atomic_t ip6_frag_mem;
|
extern atomic_t ip6_frag_mem;
|
||||||
|
|
|
@ -116,8 +116,6 @@ int sk_run_filter(struct sk_buff *skb, struct sock_filter *filter, int flen)
|
||||||
A /= X;
|
A /= X;
|
||||||
continue;
|
continue;
|
||||||
case BPF_ALU|BPF_DIV|BPF_K:
|
case BPF_ALU|BPF_DIV|BPF_K:
|
||||||
if (fentry->k == 0)
|
|
||||||
return 0;
|
|
||||||
A /= fentry->k;
|
A /= fentry->k;
|
||||||
continue;
|
continue;
|
||||||
case BPF_ALU|BPF_AND|BPF_X:
|
case BPF_ALU|BPF_AND|BPF_X:
|
||||||
|
@ -320,6 +318,10 @@ int sk_chk_filter(struct sock_filter *filter, int flen)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* check for division by zero -Kris Katterjohn 2005-10-30 */
|
||||||
|
if (ftest->code == (BPF_ALU|BPF_DIV|BPF_K) && ftest->k == 0)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
/* check that memory operations use valid addresses. */
|
/* check that memory operations use valid addresses. */
|
||||||
if (ftest->k >= BPF_MEMWORDS) {
|
if (ftest->k >= BPF_MEMWORDS) {
|
||||||
/* but it might not be a memory operation... */
|
/* but it might not be a memory operation... */
|
||||||
|
|
|
@ -46,6 +46,7 @@ atomic_t dccp_orphan_count = ATOMIC_INIT(0);
|
||||||
static struct net_protocol dccp_protocol = {
|
static struct net_protocol dccp_protocol = {
|
||||||
.handler = dccp_v4_rcv,
|
.handler = dccp_v4_rcv,
|
||||||
.err_handler = dccp_v4_err,
|
.err_handler = dccp_v4_err,
|
||||||
|
.no_policy = 1,
|
||||||
};
|
};
|
||||||
|
|
||||||
const char *dccp_packet_name(const int type)
|
const char *dccp_packet_name(const int type)
|
||||||
|
|
|
@ -2378,6 +2378,7 @@ static unsigned fib_flag_trans(int type, u32 mask, const struct fib_info *fi)
|
||||||
*/
|
*/
|
||||||
static int fib_route_seq_show(struct seq_file *seq, void *v)
|
static int fib_route_seq_show(struct seq_file *seq, void *v)
|
||||||
{
|
{
|
||||||
|
const struct fib_trie_iter *iter = seq->private;
|
||||||
struct leaf *l = v;
|
struct leaf *l = v;
|
||||||
int i;
|
int i;
|
||||||
char bf[128];
|
char bf[128];
|
||||||
|
@ -2389,6 +2390,8 @@ static int fib_route_seq_show(struct seq_file *seq, void *v)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (iter->trie == trie_local)
|
||||||
|
return 0;
|
||||||
if (IS_TNODE(l))
|
if (IS_TNODE(l))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
|
@ -440,7 +440,7 @@ config IP_NF_MATCH_COMMENT
|
||||||
config IP_NF_MATCH_CONNMARK
|
config IP_NF_MATCH_CONNMARK
|
||||||
tristate 'Connection mark match support'
|
tristate 'Connection mark match support'
|
||||||
depends on IP_NF_IPTABLES
|
depends on IP_NF_IPTABLES
|
||||||
depends on IP_NF_CONNTRACK_MARK || (NF_CONNTRACK_MARK && NF_CONNTRACK_IPV4)
|
depends on (IP_NF_CONNTRACK && IP_NF_CONNTRACK_MARK) || (NF_CONNTRACK_MARK && NF_CONNTRACK_IPV4)
|
||||||
help
|
help
|
||||||
This option adds a `connmark' match, which allows you to match the
|
This option adds a `connmark' match, which allows you to match the
|
||||||
connection mark value previously set for the session by `CONNMARK'.
|
connection mark value previously set for the session by `CONNMARK'.
|
||||||
|
@ -452,7 +452,7 @@ config IP_NF_MATCH_CONNMARK
|
||||||
config IP_NF_MATCH_CONNBYTES
|
config IP_NF_MATCH_CONNBYTES
|
||||||
tristate 'Connection byte/packet counter match support'
|
tristate 'Connection byte/packet counter match support'
|
||||||
depends on IP_NF_IPTABLES
|
depends on IP_NF_IPTABLES
|
||||||
depends on IP_NF_CT_ACCT || (NF_CT_ACCT && NF_CONNTRACK_IPV4)
|
depends on (IP_NF_CONNTRACK && IP_NF_CT_ACCT) || (NF_CT_ACCT && NF_CONNTRACK_IPV4)
|
||||||
help
|
help
|
||||||
This option adds a `connbytes' match, which allows you to match the
|
This option adds a `connbytes' match, which allows you to match the
|
||||||
number of bytes and/or packets for each direction within a connection.
|
number of bytes and/or packets for each direction within a connection.
|
||||||
|
@ -767,7 +767,7 @@ config IP_NF_TARGET_TTL
|
||||||
config IP_NF_TARGET_CONNMARK
|
config IP_NF_TARGET_CONNMARK
|
||||||
tristate 'CONNMARK target support'
|
tristate 'CONNMARK target support'
|
||||||
depends on IP_NF_MANGLE
|
depends on IP_NF_MANGLE
|
||||||
depends on IP_NF_CONNTRACK_MARK || (NF_CONNTRACK_MARK && NF_CONNTRACK_IPV4)
|
depends on (IP_NF_CONNTRACK && IP_NF_CONNTRACK_MARK) || (NF_CONNTRACK_MARK && NF_CONNTRACK_IPV4)
|
||||||
help
|
help
|
||||||
This option adds a `CONNMARK' target, which allows one to manipulate
|
This option adds a `CONNMARK' target, which allows one to manipulate
|
||||||
the connection mark value. Similar to the MARK target, but
|
the connection mark value. Similar to the MARK target, but
|
||||||
|
@ -779,8 +779,8 @@ config IP_NF_TARGET_CONNMARK
|
||||||
|
|
||||||
config IP_NF_TARGET_CLUSTERIP
|
config IP_NF_TARGET_CLUSTERIP
|
||||||
tristate "CLUSTERIP target support (EXPERIMENTAL)"
|
tristate "CLUSTERIP target support (EXPERIMENTAL)"
|
||||||
depends on IP_NF_IPTABLES && EXPERIMENTAL
|
depends on IP_NF_MANGLE && EXPERIMENTAL
|
||||||
depends on IP_NF_CONNTRACK_MARK || (NF_CONNTRACK_MARK && NF_CONNTRACK_IPV4)
|
depends on (IP_NF_CONNTRACK && IP_NF_CONNTRACK_MARK) || (NF_CONNTRACK_MARK && NF_CONNTRACK_IPV4)
|
||||||
help
|
help
|
||||||
The CLUSTERIP target allows you to build load-balancing clusters of
|
The CLUSTERIP target allows you to build load-balancing clusters of
|
||||||
network servers without having a dedicated load-balancing
|
network servers without having a dedicated load-balancing
|
||||||
|
|
|
@ -2627,7 +2627,7 @@ static void addrconf_verify(unsigned long foo)
|
||||||
for (i=0; i < IN6_ADDR_HSIZE; i++) {
|
for (i=0; i < IN6_ADDR_HSIZE; i++) {
|
||||||
|
|
||||||
restart:
|
restart:
|
||||||
write_lock(&addrconf_hash_lock);
|
read_lock(&addrconf_hash_lock);
|
||||||
for (ifp=inet6_addr_lst[i]; ifp; ifp=ifp->lst_next) {
|
for (ifp=inet6_addr_lst[i]; ifp; ifp=ifp->lst_next) {
|
||||||
unsigned long age;
|
unsigned long age;
|
||||||
#ifdef CONFIG_IPV6_PRIVACY
|
#ifdef CONFIG_IPV6_PRIVACY
|
||||||
|
@ -2649,7 +2649,7 @@ restart:
|
||||||
if (age >= ifp->valid_lft) {
|
if (age >= ifp->valid_lft) {
|
||||||
spin_unlock(&ifp->lock);
|
spin_unlock(&ifp->lock);
|
||||||
in6_ifa_hold(ifp);
|
in6_ifa_hold(ifp);
|
||||||
write_unlock(&addrconf_hash_lock);
|
read_unlock(&addrconf_hash_lock);
|
||||||
ipv6_del_addr(ifp);
|
ipv6_del_addr(ifp);
|
||||||
goto restart;
|
goto restart;
|
||||||
} else if (age >= ifp->prefered_lft) {
|
} else if (age >= ifp->prefered_lft) {
|
||||||
|
@ -2668,7 +2668,7 @@ restart:
|
||||||
|
|
||||||
if (deprecate) {
|
if (deprecate) {
|
||||||
in6_ifa_hold(ifp);
|
in6_ifa_hold(ifp);
|
||||||
write_unlock(&addrconf_hash_lock);
|
read_unlock(&addrconf_hash_lock);
|
||||||
|
|
||||||
ipv6_ifa_notify(0, ifp);
|
ipv6_ifa_notify(0, ifp);
|
||||||
in6_ifa_put(ifp);
|
in6_ifa_put(ifp);
|
||||||
|
@ -2686,7 +2686,7 @@ restart:
|
||||||
in6_ifa_hold(ifp);
|
in6_ifa_hold(ifp);
|
||||||
in6_ifa_hold(ifpub);
|
in6_ifa_hold(ifpub);
|
||||||
spin_unlock(&ifp->lock);
|
spin_unlock(&ifp->lock);
|
||||||
write_unlock(&addrconf_hash_lock);
|
read_unlock(&addrconf_hash_lock);
|
||||||
ipv6_create_tempaddr(ifpub, ifp);
|
ipv6_create_tempaddr(ifpub, ifp);
|
||||||
in6_ifa_put(ifpub);
|
in6_ifa_put(ifpub);
|
||||||
in6_ifa_put(ifp);
|
in6_ifa_put(ifp);
|
||||||
|
@ -2703,7 +2703,7 @@ restart:
|
||||||
spin_unlock(&ifp->lock);
|
spin_unlock(&ifp->lock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
write_unlock(&addrconf_hash_lock);
|
read_unlock(&addrconf_hash_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
addr_chk_timer.expires = time_before(next, jiffies + HZ) ? jiffies + HZ : next;
|
addr_chk_timer.expires = time_before(next, jiffies + HZ) ? jiffies + HZ : next;
|
||||||
|
|
|
@ -437,7 +437,7 @@ int datagram_recv_ctl(struct sock *sk, struct msghdr *msg, struct sk_buff *skb)
|
||||||
break;
|
break;
|
||||||
case IPPROTO_AH:
|
case IPPROTO_AH:
|
||||||
nexthdr = ptr[0];
|
nexthdr = ptr[0];
|
||||||
len = (ptr[1] + 1) << 2;
|
len = (ptr[1] + 2) << 2;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
nexthdr = ptr[0];
|
nexthdr = ptr[0];
|
||||||
|
|
|
@ -628,6 +628,7 @@ ipv6_renew_options(struct sock *sk, struct ipv6_txoptions *opt,
|
||||||
if (!tot_len)
|
if (!tot_len)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
tot_len += sizeof(*opt2);
|
||||||
opt2 = sock_kmalloc(sk, tot_len, GFP_ATOMIC);
|
opt2 = sock_kmalloc(sk, tot_len, GFP_ATOMIC);
|
||||||
if (!opt2)
|
if (!opt2)
|
||||||
return ERR_PTR(-ENOBUFS);
|
return ERR_PTR(-ENOBUFS);
|
||||||
|
@ -668,7 +669,26 @@ ipv6_renew_options(struct sock *sk, struct ipv6_txoptions *opt,
|
||||||
|
|
||||||
return opt2;
|
return opt2;
|
||||||
out:
|
out:
|
||||||
sock_kfree_s(sk, p, tot_len);
|
sock_kfree_s(sk, opt2, opt2->tot_len);
|
||||||
return ERR_PTR(err);
|
return ERR_PTR(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct ipv6_txoptions *ipv6_fixup_options(struct ipv6_txoptions *opt_space,
|
||||||
|
struct ipv6_txoptions *opt)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* ignore the dest before srcrt unless srcrt is being included.
|
||||||
|
* --yoshfuji
|
||||||
|
*/
|
||||||
|
if (opt && opt->dst0opt && !opt->srcrt) {
|
||||||
|
if (opt_space != opt) {
|
||||||
|
memcpy(opt_space, opt, sizeof(*opt_space));
|
||||||
|
opt = opt_space;
|
||||||
|
}
|
||||||
|
opt->opt_nflen -= ipv6_optlen(opt->dst0opt);
|
||||||
|
opt->dst0opt = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return opt;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -225,20 +225,16 @@ struct ipv6_txoptions *fl6_merge_options(struct ipv6_txoptions * opt_space,
|
||||||
struct ip6_flowlabel * fl,
|
struct ip6_flowlabel * fl,
|
||||||
struct ipv6_txoptions * fopt)
|
struct ipv6_txoptions * fopt)
|
||||||
{
|
{
|
||||||
struct ipv6_txoptions * fl_opt = fl ? fl->opt : NULL;
|
struct ipv6_txoptions * fl_opt = fl->opt;
|
||||||
|
|
||||||
if (fopt == NULL || fopt->opt_flen == 0) {
|
if (fopt == NULL || fopt->opt_flen == 0)
|
||||||
if (!fl_opt || !fl_opt->dst0opt || fl_opt->srcrt)
|
|
||||||
return fl_opt;
|
return fl_opt;
|
||||||
}
|
|
||||||
|
|
||||||
if (fl_opt != NULL) {
|
if (fl_opt != NULL) {
|
||||||
opt_space->hopopt = fl_opt->hopopt;
|
opt_space->hopopt = fl_opt->hopopt;
|
||||||
opt_space->dst0opt = fl_opt->srcrt ? fl_opt->dst0opt : NULL;
|
opt_space->dst0opt = fl_opt->dst0opt;
|
||||||
opt_space->srcrt = fl_opt->srcrt;
|
opt_space->srcrt = fl_opt->srcrt;
|
||||||
opt_space->opt_nflen = fl_opt->opt_nflen;
|
opt_space->opt_nflen = fl_opt->opt_nflen;
|
||||||
if (fl_opt->dst0opt && !fl_opt->srcrt)
|
|
||||||
opt_space->opt_nflen -= ipv6_optlen(fl_opt->dst0opt);
|
|
||||||
} else {
|
} else {
|
||||||
if (fopt->opt_nflen == 0)
|
if (fopt->opt_nflen == 0)
|
||||||
return fopt;
|
return fopt;
|
||||||
|
|
|
@ -748,7 +748,9 @@ static int rawv6_sendmsg(struct kiocb *iocb, struct sock *sk,
|
||||||
}
|
}
|
||||||
if (opt == NULL)
|
if (opt == NULL)
|
||||||
opt = np->opt;
|
opt = np->opt;
|
||||||
|
if (flowlabel)
|
||||||
opt = fl6_merge_options(&opt_space, flowlabel, opt);
|
opt = fl6_merge_options(&opt_space, flowlabel, opt);
|
||||||
|
opt = ipv6_fixup_options(&opt_space, opt);
|
||||||
|
|
||||||
fl.proto = proto;
|
fl.proto = proto;
|
||||||
rawv6_probe_proto_opt(&fl, msg);
|
rawv6_probe_proto_opt(&fl, msg);
|
||||||
|
|
|
@ -771,7 +771,9 @@ do_udp_sendmsg:
|
||||||
}
|
}
|
||||||
if (opt == NULL)
|
if (opt == NULL)
|
||||||
opt = np->opt;
|
opt = np->opt;
|
||||||
|
if (flowlabel)
|
||||||
opt = fl6_merge_options(&opt_space, flowlabel, opt);
|
opt = fl6_merge_options(&opt_space, flowlabel, opt);
|
||||||
|
opt = ipv6_fixup_options(&opt_space, opt);
|
||||||
|
|
||||||
fl->proto = IPPROTO_UDP;
|
fl->proto = IPPROTO_UDP;
|
||||||
ipv6_addr_copy(&fl->fl6_dst, daddr);
|
ipv6_addr_copy(&fl->fl6_dst, daddr);
|
||||||
|
|
|
@ -464,7 +464,7 @@ static int tfifo_enqueue(struct sk_buff *nskb, struct Qdisc *sch)
|
||||||
const struct netem_skb_cb *cb
|
const struct netem_skb_cb *cb
|
||||||
= (const struct netem_skb_cb *)skb->cb;
|
= (const struct netem_skb_cb *)skb->cb;
|
||||||
|
|
||||||
if (PSCHED_TLESS(cb->time_to_send, ncb->time_to_send))
|
if (!PSCHED_TLESS(ncb->time_to_send, cb->time_to_send))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue