diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-12-08 10:55:01 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-12-08 10:55:01 -0500 |
| commit | d7fc02c7bae7b1cf69269992cf880a43a350cdaa (patch) | |
| tree | a43d56fa72913a1cc98a0bbebe054d08581b3a7c /net/netrom | |
| parent | ee1262dbc65ce0b6234a915d8432171e8d77f518 (diff) | |
| parent | 28b4d5cc17c20786848cdc07b7ea237a309776bb (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next-2.6
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next-2.6: (1815 commits)
mac80211: fix reorder buffer release
iwmc3200wifi: Enable wimax core through module parameter
iwmc3200wifi: Add wifi-wimax coexistence mode as a module parameter
iwmc3200wifi: Coex table command does not expect a response
iwmc3200wifi: Update wiwi priority table
iwlwifi: driver version track kernel version
iwlwifi: indicate uCode type when fail dump error/event log
iwl3945: remove duplicated event logging code
b43: fix two warnings
ipw2100: fix rebooting hang with driver loaded
cfg80211: indent regulatory messages with spaces
iwmc3200wifi: fix NULL pointer dereference in pmkid update
mac80211: Fix TX status reporting for injected data frames
ath9k: enable 2GHz band only if the device supports it
airo: Fix integer overflow warning
rt2x00: Fix padding bug on L2PAD devices.
WE: Fix set events not propagated
b43legacy: avoid PPC fault during resume
b43: avoid PPC fault during resume
tcp: fix a timewait refcnt race
...
Fix up conflicts due to sysctl cleanups (dead sysctl_check code and
CTL_UNNUMBERED removed) in
kernel/sysctl_check.c
net/ipv4/sysctl_net_ipv4.c
net/ipv6/addrconf.c
net/sctp/sysctl.c
Diffstat (limited to 'net/netrom')
| -rw-r--r-- | net/netrom/af_netrom.c | 7 | ||||
| -rw-r--r-- | net/netrom/nr_route.c | 15 |
2 files changed, 12 insertions, 10 deletions
diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c index 7a834952f67f..71604c6613b5 100644 --- a/net/netrom/af_netrom.c +++ b/net/netrom/af_netrom.c | |||
| @@ -425,12 +425,13 @@ static struct proto nr_proto = { | |||
| 425 | .obj_size = sizeof(struct nr_sock), | 425 | .obj_size = sizeof(struct nr_sock), |
| 426 | }; | 426 | }; |
| 427 | 427 | ||
| 428 | static int nr_create(struct net *net, struct socket *sock, int protocol) | 428 | static int nr_create(struct net *net, struct socket *sock, int protocol, |
| 429 | int kern) | ||
| 429 | { | 430 | { |
| 430 | struct sock *sk; | 431 | struct sock *sk; |
| 431 | struct nr_sock *nr; | 432 | struct nr_sock *nr; |
| 432 | 433 | ||
| 433 | if (net != &init_net) | 434 | if (!net_eq(net, &init_net)) |
| 434 | return -EAFNOSUPPORT; | 435 | return -EAFNOSUPPORT; |
| 435 | 436 | ||
| 436 | if (sock->type != SOCK_SEQPACKET || protocol != 0) | 437 | if (sock->type != SOCK_SEQPACKET || protocol != 0) |
| @@ -1372,7 +1373,7 @@ static const struct file_operations nr_info_fops = { | |||
| 1372 | }; | 1373 | }; |
| 1373 | #endif /* CONFIG_PROC_FS */ | 1374 | #endif /* CONFIG_PROC_FS */ |
| 1374 | 1375 | ||
| 1375 | static struct net_proto_family nr_family_ops = { | 1376 | static const struct net_proto_family nr_family_ops = { |
| 1376 | .family = PF_NETROM, | 1377 | .family = PF_NETROM, |
| 1377 | .create = nr_create, | 1378 | .create = nr_create, |
| 1378 | .owner = THIS_MODULE, | 1379 | .owner = THIS_MODULE, |
diff --git a/net/netrom/nr_route.c b/net/netrom/nr_route.c index 4eb1ac9a7679..aacba76070fc 100644 --- a/net/netrom/nr_route.c +++ b/net/netrom/nr_route.c | |||
| @@ -597,15 +597,15 @@ struct net_device *nr_dev_first(void) | |||
| 597 | { | 597 | { |
| 598 | struct net_device *dev, *first = NULL; | 598 | struct net_device *dev, *first = NULL; |
| 599 | 599 | ||
| 600 | read_lock(&dev_base_lock); | 600 | rcu_read_lock(); |
| 601 | for_each_netdev(&init_net, dev) { | 601 | for_each_netdev_rcu(&init_net, dev) { |
| 602 | if ((dev->flags & IFF_UP) && dev->type == ARPHRD_NETROM) | 602 | if ((dev->flags & IFF_UP) && dev->type == ARPHRD_NETROM) |
| 603 | if (first == NULL || strncmp(dev->name, first->name, 3) < 0) | 603 | if (first == NULL || strncmp(dev->name, first->name, 3) < 0) |
| 604 | first = dev; | 604 | first = dev; |
| 605 | } | 605 | } |
| 606 | if (first) | 606 | if (first) |
| 607 | dev_hold(first); | 607 | dev_hold(first); |
| 608 | read_unlock(&dev_base_lock); | 608 | rcu_read_unlock(); |
| 609 | 609 | ||
| 610 | return first; | 610 | return first; |
| 611 | } | 611 | } |
| @@ -617,16 +617,17 @@ struct net_device *nr_dev_get(ax25_address *addr) | |||
| 617 | { | 617 | { |
| 618 | struct net_device *dev; | 618 | struct net_device *dev; |
| 619 | 619 | ||
| 620 | read_lock(&dev_base_lock); | 620 | rcu_read_lock(); |
| 621 | for_each_netdev(&init_net, dev) { | 621 | for_each_netdev_rcu(&init_net, dev) { |
| 622 | if ((dev->flags & IFF_UP) && dev->type == ARPHRD_NETROM && ax25cmp(addr, (ax25_address *)dev->dev_addr) == 0) { | 622 | if ((dev->flags & IFF_UP) && dev->type == ARPHRD_NETROM && |
| 623 | ax25cmp(addr, (ax25_address *)dev->dev_addr) == 0) { | ||
| 623 | dev_hold(dev); | 624 | dev_hold(dev); |
| 624 | goto out; | 625 | goto out; |
| 625 | } | 626 | } |
| 626 | } | 627 | } |
| 627 | dev = NULL; | 628 | dev = NULL; |
| 628 | out: | 629 | out: |
| 629 | read_unlock(&dev_base_lock); | 630 | rcu_read_unlock(); |
| 630 | return dev; | 631 | return dev; |
| 631 | } | 632 | } |
| 632 | 633 | ||
