]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/commitdiff
Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
authorDavid S. Miller <davem@davemloft.net>
Thu, 26 Mar 2009 08:22:01 +0000 (01:22 -0700)
committerDavid S. Miller <davem@davemloft.net>
Thu, 26 Mar 2009 08:22:01 +0000 (01:22 -0700)
drivers/net/dnet.c
drivers/net/phy/smsc.c
net/bridge/br_if.c
net/ipv4/udp.c
net/netfilter/nf_conntrack_proto_tcp.c

index c05c2d69fbf6d3999c9decdaf312b7a0639d71e7..db1e31f952003a1100d8954d0fc7b08bd3640eea 100644 (file)
@@ -9,6 +9,7 @@
  * published by the Free Software Foundation.
  */
 #include <linux/version.h>
+#include <linux/io.h>
 #include <linux/module.h>
 #include <linux/moduleparam.h>
 #include <linux/kernel.h>
index 1387187543e413c6159bfd3891cbef70105beb6d..5123bb954dd751e198038fd3cbbc8f445b1208d2 100644 (file)
@@ -159,6 +159,30 @@ static struct phy_driver lan911x_int_driver = {
        .driver         = { .owner = THIS_MODULE, }
 };
 
+static struct phy_driver lan8710_driver = {
+       .phy_id         = 0x0007c0f0, /* OUI=0x00800f, Model#=0x0f */
+       .phy_id_mask    = 0xfffffff0,
+       .name           = "SMSC LAN8710/LAN8720",
+
+       .features       = (PHY_BASIC_FEATURES | SUPPORTED_Pause
+                               | SUPPORTED_Asym_Pause),
+       .flags          = PHY_HAS_INTERRUPT | PHY_HAS_MAGICANEG,
+
+       /* basic functions */
+       .config_aneg    = genphy_config_aneg,
+       .read_status    = genphy_read_status,
+       .config_init    = smsc_phy_config_init,
+
+       /* IRQ related */
+       .ack_interrupt  = smsc_phy_ack_interrupt,
+       .config_intr    = smsc_phy_config_intr,
+
+       .suspend        = genphy_suspend,
+       .resume         = genphy_resume,
+
+       .driver         = { .owner = THIS_MODULE, }
+};
+
 static int __init smsc_init(void)
 {
        int ret;
@@ -179,8 +203,14 @@ static int __init smsc_init(void)
        if (ret)
                goto err4;
 
+       ret = phy_driver_register (&lan8710_driver);
+       if (ret)
+               goto err5;
+
        return 0;
 
+err5:
+       phy_driver_unregister (&lan911x_int_driver);
 err4:
        phy_driver_unregister (&lan8700_driver);
 err3:
@@ -193,6 +223,7 @@ err1:
 
 static void __exit smsc_exit(void)
 {
+       phy_driver_unregister (&lan8710_driver);
        phy_driver_unregister (&lan911x_int_driver);
        phy_driver_unregister (&lan8700_driver);
        phy_driver_unregister (&lan8187_driver);
index 727c5c510a602573b216ec66fb3ce1dbf274b0d5..8a96672e2c5c462fb3f575df3ba4d8c25a03727d 100644 (file)
@@ -426,7 +426,6 @@ err2:
 err1:
        kobject_del(&p->kobj);
 err0:
-       kobject_put(&p->kobj);
        dev_set_promiscuity(dev, -1);
 put_back:
        dev_put(dev);
index ace2ac8a42f7562d76bc73d177ac0535e76bf9a6..bda08a09357d089a0806a6904a0dfaa8e2e5aa6d 100644 (file)
@@ -1618,7 +1618,8 @@ static struct sock *udp_get_next(struct seq_file *seq, struct sock *sk)
        } while (sk && (!net_eq(sock_net(sk), net) || sk->sk_family != state->family));
 
        if (!sk) {
-               spin_unlock_bh(&state->udp_table->hash[state->bucket].lock);
+               if (state->bucket < UDP_HTABLE_SIZE)
+                       spin_unlock_bh(&state->udp_table->hash[state->bucket].lock);
                return udp_get_first(seq, state->bucket + 1);
        }
        return sk;
@@ -1636,6 +1637,9 @@ static struct sock *udp_get_idx(struct seq_file *seq, loff_t pos)
 
 static void *udp_seq_start(struct seq_file *seq, loff_t *pos)
 {
+       struct udp_iter_state *state = seq->private;
+       state->bucket = UDP_HTABLE_SIZE;
+
        return *pos ? udp_get_idx(seq, *pos-1) : SEQ_START_TOKEN;
 }
 
index e46f3b79adb3ade44627d5567c0752921ea2c676..0aeb8b09a1f7eaa6c7aa4bc659a97bdf4f2f6110 100644 (file)
@@ -15,6 +15,7 @@
 #include <linux/skbuff.h>
 #include <linux/ipv6.h>
 #include <net/ip6_checksum.h>
+#include <asm/unaligned.h>
 
 #include <net/tcp.h>
 
@@ -468,7 +469,7 @@ static void tcp_sack(const struct sk_buff *skb, unsigned int dataoff,
                                for (i = 0;
                                     i < (opsize - TCPOLEN_SACK_BASE);
                                     i += TCPOLEN_SACK_PERBLOCK) {
-                                       tmp = ntohl(*((__be32 *)(ptr+i)+1));
+                                       tmp = get_unaligned_be32((__be32 *)(ptr+i)+1);
 
                                        if (after(tmp, *sack))
                                                *sack = tmp;