mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-30 07:37:49 +00:00
Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
* master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6: [BNX2]: Fix occasional NETDEV WATCHDOG on 5709. [IPV6]: Disallow RH0 by default. [XFRM]: beet: fix pseudo header length value [TCP]: Congestion control initialization.
This commit is contained in:
commit
12145387a0
@ -851,6 +851,15 @@ accept_redirects - BOOLEAN
|
|||||||
Functional default: enabled if local forwarding is disabled.
|
Functional default: enabled if local forwarding is disabled.
|
||||||
disabled if local forwarding is enabled.
|
disabled if local forwarding is enabled.
|
||||||
|
|
||||||
|
accept_source_route - INTEGER
|
||||||
|
Accept source routing (routing extension header).
|
||||||
|
|
||||||
|
> 0: Accept routing header.
|
||||||
|
= 0: Accept only routing header type 2.
|
||||||
|
< 0: Do not accept routing header.
|
||||||
|
|
||||||
|
Default: 0
|
||||||
|
|
||||||
autoconf - BOOLEAN
|
autoconf - BOOLEAN
|
||||||
Autoconfigure addresses using Prefix Information in Router
|
Autoconfigure addresses using Prefix Information in Router
|
||||||
Advertisements.
|
Advertisements.
|
||||||
|
@ -54,8 +54,8 @@
|
|||||||
|
|
||||||
#define DRV_MODULE_NAME "bnx2"
|
#define DRV_MODULE_NAME "bnx2"
|
||||||
#define PFX DRV_MODULE_NAME ": "
|
#define PFX DRV_MODULE_NAME ": "
|
||||||
#define DRV_MODULE_VERSION "1.5.7"
|
#define DRV_MODULE_VERSION "1.5.8"
|
||||||
#define DRV_MODULE_RELDATE "March 29, 2007"
|
#define DRV_MODULE_RELDATE "April 24, 2007"
|
||||||
|
|
||||||
#define RUN_AT(x) (jiffies + (x))
|
#define RUN_AT(x) (jiffies + (x))
|
||||||
|
|
||||||
@ -3421,6 +3421,9 @@ bnx2_init_chip(struct bnx2 *bp)
|
|||||||
val = REG_RD(bp, BNX2_MQ_CONFIG);
|
val = REG_RD(bp, BNX2_MQ_CONFIG);
|
||||||
val &= ~BNX2_MQ_CONFIG_KNL_BYP_BLK_SIZE;
|
val &= ~BNX2_MQ_CONFIG_KNL_BYP_BLK_SIZE;
|
||||||
val |= BNX2_MQ_CONFIG_KNL_BYP_BLK_SIZE_256;
|
val |= BNX2_MQ_CONFIG_KNL_BYP_BLK_SIZE_256;
|
||||||
|
if (CHIP_ID(bp) == CHIP_ID_5709_A0 || CHIP_ID(bp) == CHIP_ID_5709_A1)
|
||||||
|
val |= BNX2_MQ_CONFIG_HALT_DIS;
|
||||||
|
|
||||||
REG_WR(bp, BNX2_MQ_CONFIG, val);
|
REG_WR(bp, BNX2_MQ_CONFIG, val);
|
||||||
|
|
||||||
val = 0x10000 + (MAX_CID_CNT * MB_KERNEL_CTX_SIZE);
|
val = 0x10000 + (MAX_CID_CNT * MB_KERNEL_CTX_SIZE);
|
||||||
|
@ -6518,6 +6518,7 @@ struct bnx2 {
|
|||||||
#define CHIP_ID_5708_B0 0x57081000
|
#define CHIP_ID_5708_B0 0x57081000
|
||||||
#define CHIP_ID_5708_B1 0x57081010
|
#define CHIP_ID_5708_B1 0x57081010
|
||||||
#define CHIP_ID_5709_A0 0x57090000
|
#define CHIP_ID_5709_A0 0x57090000
|
||||||
|
#define CHIP_ID_5709_A1 0x57090010
|
||||||
|
|
||||||
#define CHIP_BOND_ID(bp) (((bp)->chip_id) & 0xf)
|
#define CHIP_BOND_ID(bp) (((bp)->chip_id) & 0xf)
|
||||||
|
|
||||||
|
@ -177,6 +177,7 @@ struct ipv6_devconf {
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
__s32 proxy_ndp;
|
__s32 proxy_ndp;
|
||||||
|
__s32 accept_source_route;
|
||||||
void *sysctl;
|
void *sysctl;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -205,6 +206,8 @@ enum {
|
|||||||
DEVCONF_RTR_PROBE_INTERVAL,
|
DEVCONF_RTR_PROBE_INTERVAL,
|
||||||
DEVCONF_ACCEPT_RA_RT_INFO_MAX_PLEN,
|
DEVCONF_ACCEPT_RA_RT_INFO_MAX_PLEN,
|
||||||
DEVCONF_PROXY_NDP,
|
DEVCONF_PROXY_NDP,
|
||||||
|
__DEVCONF_OPTIMISTIC_DAD,
|
||||||
|
DEVCONF_ACCEPT_SOURCE_ROUTE,
|
||||||
DEVCONF_MAX
|
DEVCONF_MAX
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -580,6 +580,7 @@ enum {
|
|||||||
NET_IPV6_RTR_PROBE_INTERVAL=21,
|
NET_IPV6_RTR_PROBE_INTERVAL=21,
|
||||||
NET_IPV6_ACCEPT_RA_RT_INFO_MAX_PLEN=22,
|
NET_IPV6_ACCEPT_RA_RT_INFO_MAX_PLEN=22,
|
||||||
NET_IPV6_PROXY_NDP=23,
|
NET_IPV6_PROXY_NDP=23,
|
||||||
|
NET_IPV6_ACCEPT_SOURCE_ROUTE=25,
|
||||||
__NET_IPV6_MAX
|
__NET_IPV6_MAX
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -77,18 +77,19 @@ void tcp_init_congestion_control(struct sock *sk)
|
|||||||
struct inet_connection_sock *icsk = inet_csk(sk);
|
struct inet_connection_sock *icsk = inet_csk(sk);
|
||||||
struct tcp_congestion_ops *ca;
|
struct tcp_congestion_ops *ca;
|
||||||
|
|
||||||
if (icsk->icsk_ca_ops != &tcp_init_congestion_ops)
|
/* if no choice made yet assign the current value set as default */
|
||||||
return;
|
if (icsk->icsk_ca_ops == &tcp_init_congestion_ops) {
|
||||||
|
rcu_read_lock();
|
||||||
|
list_for_each_entry_rcu(ca, &tcp_cong_list, list) {
|
||||||
|
if (try_module_get(ca->owner)) {
|
||||||
|
icsk->icsk_ca_ops = ca;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
rcu_read_lock();
|
/* fallback to next available */
|
||||||
list_for_each_entry_rcu(ca, &tcp_cong_list, list) {
|
|
||||||
if (try_module_get(ca->owner)) {
|
|
||||||
icsk->icsk_ca_ops = ca;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
rcu_read_unlock();
|
||||||
}
|
}
|
||||||
rcu_read_unlock();
|
|
||||||
|
|
||||||
if (icsk->icsk_ca_ops->init)
|
if (icsk->icsk_ca_ops->init)
|
||||||
icsk->icsk_ca_ops->init(sk);
|
icsk->icsk_ca_ops->init(sk);
|
||||||
@ -236,6 +237,7 @@ int tcp_set_congestion_control(struct sock *sk, const char *name)
|
|||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
ca = tcp_ca_find(name);
|
ca = tcp_ca_find(name);
|
||||||
|
|
||||||
/* no change asking for existing value */
|
/* no change asking for existing value */
|
||||||
if (ca == icsk->icsk_ca_ops)
|
if (ca == icsk->icsk_ca_ops)
|
||||||
goto out;
|
goto out;
|
||||||
@ -261,7 +263,8 @@ int tcp_set_congestion_control(struct sock *sk, const char *name)
|
|||||||
else {
|
else {
|
||||||
tcp_cleanup_congestion_control(sk);
|
tcp_cleanup_congestion_control(sk);
|
||||||
icsk->icsk_ca_ops = ca;
|
icsk->icsk_ca_ops = ca;
|
||||||
if (icsk->icsk_ca_ops->init)
|
|
||||||
|
if (sk->sk_state != TCP_CLOSE && icsk->icsk_ca_ops->init)
|
||||||
icsk->icsk_ca_ops->init(sk);
|
icsk->icsk_ca_ops->init(sk);
|
||||||
}
|
}
|
||||||
out:
|
out:
|
||||||
|
@ -52,7 +52,7 @@ static int xfrm4_beet_output(struct xfrm_state *x, struct sk_buff *skb)
|
|||||||
|
|
||||||
ph = (struct ip_beet_phdr *)skb->h.raw;
|
ph = (struct ip_beet_phdr *)skb->h.raw;
|
||||||
ph->padlen = 4 - (optlen & 4);
|
ph->padlen = 4 - (optlen & 4);
|
||||||
ph->hdrlen = (optlen + ph->padlen + sizeof(*ph)) / 8;
|
ph->hdrlen = optlen / 8;
|
||||||
ph->nexthdr = top_iph->protocol;
|
ph->nexthdr = top_iph->protocol;
|
||||||
if (ph->padlen)
|
if (ph->padlen)
|
||||||
memset(ph + 1, IPOPT_NOP, ph->padlen);
|
memset(ph + 1, IPOPT_NOP, ph->padlen);
|
||||||
@ -85,7 +85,7 @@ static int xfrm4_beet_input(struct xfrm_state *x, struct sk_buff *skb)
|
|||||||
ph = (struct ip_beet_phdr *)(skb->h.ipiph + 1);
|
ph = (struct ip_beet_phdr *)(skb->h.ipiph + 1);
|
||||||
|
|
||||||
phlen = sizeof(*ph) + ph->padlen;
|
phlen = sizeof(*ph) + ph->padlen;
|
||||||
optlen = ph->hdrlen * 8 - phlen;
|
optlen = ph->hdrlen * 8 + (IPV4_BEET_PHMAXLEN - phlen);
|
||||||
if (optlen < 0 || optlen & 3 || optlen > 250)
|
if (optlen < 0 || optlen & 3 || optlen > 250)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
@ -172,6 +172,7 @@ struct ipv6_devconf ipv6_devconf __read_mostly = {
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
.proxy_ndp = 0,
|
.proxy_ndp = 0,
|
||||||
|
.accept_source_route = 0, /* we do not accept RH0 by default. */
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct ipv6_devconf ipv6_devconf_dflt __read_mostly = {
|
static struct ipv6_devconf ipv6_devconf_dflt __read_mostly = {
|
||||||
@ -203,6 +204,7 @@ static struct ipv6_devconf ipv6_devconf_dflt __read_mostly = {
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
.proxy_ndp = 0,
|
.proxy_ndp = 0,
|
||||||
|
.accept_source_route = 0, /* we do not accept RH0 by default. */
|
||||||
};
|
};
|
||||||
|
|
||||||
/* IPv6 Wildcard Address and Loopback Address defined by RFC2553 */
|
/* IPv6 Wildcard Address and Loopback Address defined by RFC2553 */
|
||||||
@ -3356,6 +3358,7 @@ static inline void ipv6_store_devconf(struct ipv6_devconf *cnf,
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
array[DEVCONF_PROXY_NDP] = cnf->proxy_ndp;
|
array[DEVCONF_PROXY_NDP] = cnf->proxy_ndp;
|
||||||
|
array[DEVCONF_ACCEPT_SOURCE_ROUTE] = cnf->accept_source_route;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline size_t inet6_if_nlmsg_size(void)
|
static inline size_t inet6_if_nlmsg_size(void)
|
||||||
@ -3883,6 +3886,14 @@ static struct addrconf_sysctl_table
|
|||||||
.mode = 0644,
|
.mode = 0644,
|
||||||
.proc_handler = &proc_dointvec,
|
.proc_handler = &proc_dointvec,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.ctl_name = NET_IPV6_ACCEPT_SOURCE_ROUTE,
|
||||||
|
.procname = "accept_source_route",
|
||||||
|
.data = &ipv6_devconf.accept_source_route,
|
||||||
|
.maxlen = sizeof(int),
|
||||||
|
.mode = 0644,
|
||||||
|
.proc_handler = &proc_dointvec,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.ctl_name = 0, /* sentinel */
|
.ctl_name = 0, /* sentinel */
|
||||||
}
|
}
|
||||||
|
@ -362,10 +362,27 @@ static int ipv6_rthdr_rcv(struct sk_buff **skbp)
|
|||||||
struct inet6_skb_parm *opt = IP6CB(skb);
|
struct inet6_skb_parm *opt = IP6CB(skb);
|
||||||
struct in6_addr *addr = NULL;
|
struct in6_addr *addr = NULL;
|
||||||
struct in6_addr daddr;
|
struct in6_addr daddr;
|
||||||
|
struct inet6_dev *idev;
|
||||||
int n, i;
|
int n, i;
|
||||||
|
|
||||||
struct ipv6_rt_hdr *hdr;
|
struct ipv6_rt_hdr *hdr;
|
||||||
struct rt0_hdr *rthdr;
|
struct rt0_hdr *rthdr;
|
||||||
|
int accept_source_route = ipv6_devconf.accept_source_route;
|
||||||
|
|
||||||
|
if (accept_source_route < 0 ||
|
||||||
|
((idev = in6_dev_get(skb->dev)) == NULL)) {
|
||||||
|
kfree_skb(skb);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (idev->cnf.accept_source_route < 0) {
|
||||||
|
in6_dev_put(idev);
|
||||||
|
kfree_skb(skb);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (accept_source_route > idev->cnf.accept_source_route)
|
||||||
|
accept_source_route = idev->cnf.accept_source_route;
|
||||||
|
|
||||||
|
in6_dev_put(idev);
|
||||||
|
|
||||||
if (!pskb_may_pull(skb, (skb->h.raw-skb->data)+8) ||
|
if (!pskb_may_pull(skb, (skb->h.raw-skb->data)+8) ||
|
||||||
!pskb_may_pull(skb, (skb->h.raw-skb->data)+((skb->h.raw[1]+1)<<3))) {
|
!pskb_may_pull(skb, (skb->h.raw-skb->data)+((skb->h.raw[1]+1)<<3))) {
|
||||||
@ -377,6 +394,22 @@ static int ipv6_rthdr_rcv(struct sk_buff **skbp)
|
|||||||
|
|
||||||
hdr = (struct ipv6_rt_hdr *) skb->h.raw;
|
hdr = (struct ipv6_rt_hdr *) skb->h.raw;
|
||||||
|
|
||||||
|
switch (hdr->type) {
|
||||||
|
#ifdef CONFIG_IPV6_MIP6
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
case IPV6_SRCRT_TYPE_0:
|
||||||
|
if (accept_source_route <= 0)
|
||||||
|
break;
|
||||||
|
kfree_skb(skb);
|
||||||
|
return -1;
|
||||||
|
default:
|
||||||
|
IP6_INC_STATS_BH(ip6_dst_idev(skb->dst),
|
||||||
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, (&hdr->type) - skb->nh.raw);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
if (ipv6_addr_is_multicast(&skb->nh.ipv6h->daddr) ||
|
if (ipv6_addr_is_multicast(&skb->nh.ipv6h->daddr) ||
|
||||||
skb->pkt_type != PACKET_HOST) {
|
skb->pkt_type != PACKET_HOST) {
|
||||||
IP6_INC_STATS_BH(ip6_dst_idev(skb->dst),
|
IP6_INC_STATS_BH(ip6_dst_idev(skb->dst),
|
||||||
@ -434,11 +467,6 @@ looped_back:
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
default:
|
|
||||||
IP6_INC_STATS_BH(ip6_dst_idev(skb->dst),
|
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, (&hdr->type) - skb->nh.raw);
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user