ath79: rename downstream ag71xx driver
authorOskari Lemmela <oskari@lemmela.net>
Wed, 10 Jul 2024 07:55:16 +0000 (10:55 +0300)
committerHauke Mehrtens <hauke@hauke-m.de>
Sun, 22 Sep 2024 16:42:34 +0000 (18:42 +0200)
Rename the downstream ag71xx driver to ag71xx-legacy.
It allows both upstream and downstream drivers to be compiled into modules.

Signed-off-by: Oskari Lemmela <oskari@lemmela.net>
Link: https://github.com/openwrt/openwrt/pull/15926
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
target/linux/ath79/config-6.6
target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/Kconfig
target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/Makefile
target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx.h
target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_debugfs.c [deleted file]
target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_legacy_debugfs.c [new file with mode: 0644]
target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_legacy_mdio.c [new file with mode: 0644]
target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_mdio.c [deleted file]
target/linux/ath79/patches-6.6/710-net-use-downstream-ag71xx.patch

index f2d06460394f0993f5b06e544fc66cfe4d26ca4f..ed0e84e316cdb3dcd2ef7126633f414727dbd2b1 100644 (file)
@@ -1,6 +1,7 @@
-CONFIG_AG71XX=y
-# CONFIG_AG71XX_DEBUG is not set
-CONFIG_AG71XX_DEBUG_FS=y
+# CONFIG_AG71XX is not set
+CONFIG_AG71XX_LEGACY=y
+# CONFIG_AG71XX_LEGACY_DEBUG is not set
+CONFIG_AG71XX_LEGACY_DEBUG_FS=y
 CONFIG_AR8216_PHY=y
 CONFIG_AR8216_PHY_LEDS=y
 CONFIG_ARCH_32BIT_OFF_T=y
index dfcedcf70e853c1332c7ef2d4e4e7d9c17357c00..e1504b92347ff01475973e4cccb8a47b7aa2076c 100644 (file)
@@ -1,4 +1,4 @@
-config AG71XX
+config AG71XX_LEGACY
        tristate "Atheros AR7XXX/AR9XXX built-in ethernet mac support"
        depends on ATH79
        select PHYLIB
@@ -6,14 +6,14 @@ config AG71XX
          If you wish to compile a kernel for AR7XXX/91XXX and enable
          ethernet support, then you should always answer Y to this.
 
-if AG71XX
+if AG71XX_LEGACY
 
-config AG71XX_DEBUG
+config AG71XX_LEGACY_DEBUG
        bool "Atheros AR71xx built-in ethernet driver debugging"
        help
          Atheros AR71xx built-in ethernet driver debugging messages.
 
-config AG71XX_DEBUG_FS
+config AG71XX_LEGACY_DEBUG_FS
        bool "Atheros AR71xx built-in ethernet driver debugfs support"
        depends on DEBUG_FS
        help
index 87add0d208a6fda49d42c93f91ef3e77cb59a34f..86e47290e652276d1d8be8a833309feabd59dd4b 100644 (file)
@@ -2,12 +2,12 @@
 # Makefile for the Atheros AR71xx built-in ethernet macs
 #
 
-ag71xx-y       += ag71xx_main.o
-ag71xx-y       += ag71xx_gmac.o
-ag71xx-y       += ag71xx_ethtool.o
-ag71xx-y       += ag71xx_phy.o
+ag71xx_legacy-y        += ag71xx_main.o
+ag71xx_legacy-y        += ag71xx_gmac.o
+ag71xx_legacy-y        += ag71xx_ethtool.o
+ag71xx_legacy-y        += ag71xx_phy.o
 
-ag71xx-$(CONFIG_AG71XX_DEBUG_FS)       += ag71xx_debugfs.o
+ag71xx_legacy-$(CONFIG_AG71XX_LEGACY_DEBUG_FS) += ag71xx_legacy_debugfs.o
 
-obj-$(CONFIG_AG71XX)   += ag71xx_mdio.o
-obj-$(CONFIG_AG71XX)   += ag71xx.o
+obj-$(CONFIG_AG71XX_LEGACY)    += ag71xx_legacy_mdio.o
+obj-$(CONFIG_AG71XX_LEGACY)    += ag71xx_legacy.o
index fca072a83a4d3b9fbc7074822188b1fa1820d06a..da716d94c39eca727e1bef9de1d64eb84f35877b 100644 (file)
@@ -40,7 +40,7 @@
 #include <asm/mach-ath79/ar71xx_regs.h>
 #include <asm/mach-ath79/ath79.h>
 
-#define AG71XX_DRV_NAME                "ag71xx"
+#define AG71XX_DRV_NAME                "ag71xx-legacy"
 
 /*
  * For our NAPI weight bigger does *NOT* mean better - it means more
@@ -68,7 +68,7 @@
 #define AG71XX_TX_RING_SIZE_MAX                256
 #define AG71XX_RX_RING_SIZE_MAX                256
 
-#ifdef CONFIG_AG71XX_DEBUG
+#ifdef CONFIG_AG71XX_LEGACY_DEBUG
 #define DBG(fmt, args...)      pr_debug(fmt, ## args)
 #else
 #define DBG(fmt, args...)      do {} while (0)
@@ -195,7 +195,7 @@ struct ag71xx {
        u32                     pllreg[3];
        struct regmap           *pllregmap;
 
-#ifdef CONFIG_AG71XX_DEBUG_FS
+#ifdef CONFIG_AG71XX_LEGACY_DEBUG_FS
        struct ag71xx_debug     debug;
 #endif
 };
@@ -425,7 +425,7 @@ static inline void ag71xx_int_disable(struct ag71xx *ag, u32 ints)
        ag71xx_cb(ag, AG71XX_REG_INT_ENABLE, ints);
 }
 
-#ifdef CONFIG_AG71XX_DEBUG_FS
+#ifdef CONFIG_AG71XX_LEGACY_DEBUG_FS
 int ag71xx_debugfs_root_init(void);
 void ag71xx_debugfs_root_exit(void);
 int ag71xx_debugfs_init(struct ag71xx *ag);
@@ -441,7 +441,7 @@ static inline void ag71xx_debugfs_update_int_stats(struct ag71xx *ag,
                                                   u32 status) {}
 static inline void ag71xx_debugfs_update_napi_stats(struct ag71xx *ag,
                                                    int rx, int tx) {}
-#endif /* CONFIG_AG71XX_DEBUG_FS */
+#endif /* CONFIG_AG71XX_LEGACY_DEBUG_FS */
 
 int ag71xx_ar7240_init(struct ag71xx *ag, struct device_node *np);
 void ag71xx_ar7240_cleanup(struct ag71xx *ag);
diff --git a/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_debugfs.c b/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_debugfs.c
deleted file mode 100644 (file)
index 20cf1c1..0000000
+++ /dev/null
@@ -1,285 +0,0 @@
-/*
- *  Atheros AR71xx built-in ethernet mac driver
- *
- *  Copyright (C) 2008-2010 Gabor Juhos <juhosg@openwrt.org>
- *  Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
- *
- *  Based on Atheros' AG7100 driver
- *
- *  This program is free software; you can redistribute it and/or modify it
- *  under the terms of the GNU General Public License version 2 as published
- *  by the Free Software Foundation.
- */
-
-#include <linux/debugfs.h>
-
-#include "ag71xx.h"
-
-static struct dentry *ag71xx_debugfs_root;
-
-static int ag71xx_debugfs_generic_open(struct inode *inode, struct file *file)
-{
-       file->private_data = inode->i_private;
-       return 0;
-}
-
-void ag71xx_debugfs_update_int_stats(struct ag71xx *ag, u32 status)
-{
-       if (status)
-               ag->debug.int_stats.total++;
-       if (status & AG71XX_INT_TX_PS)
-               ag->debug.int_stats.tx_ps++;
-       if (status & AG71XX_INT_TX_UR)
-               ag->debug.int_stats.tx_ur++;
-       if (status & AG71XX_INT_TX_BE)
-               ag->debug.int_stats.tx_be++;
-       if (status & AG71XX_INT_RX_PR)
-               ag->debug.int_stats.rx_pr++;
-       if (status & AG71XX_INT_RX_OF)
-               ag->debug.int_stats.rx_of++;
-       if (status & AG71XX_INT_RX_BE)
-               ag->debug.int_stats.rx_be++;
-}
-
-static ssize_t read_file_int_stats(struct file *file, char __user *user_buf,
-                                  size_t count, loff_t *ppos)
-{
-#define PR_INT_STAT(_label, _field)                                    \
-       len += snprintf(buf + len, sizeof(buf) - len,                   \
-               "%20s: %10lu\n", _label, ag->debug.int_stats._field);
-
-       struct ag71xx *ag = file->private_data;
-       char buf[256];
-       unsigned int len = 0;
-
-       PR_INT_STAT("TX Packet Sent", tx_ps);
-       PR_INT_STAT("TX Underrun", tx_ur);
-       PR_INT_STAT("TX Bus Error", tx_be);
-       PR_INT_STAT("RX Packet Received", rx_pr);
-       PR_INT_STAT("RX Overflow", rx_of);
-       PR_INT_STAT("RX Bus Error", rx_be);
-       len += snprintf(buf + len, sizeof(buf) - len, "\n");
-       PR_INT_STAT("Total", total);
-
-       return simple_read_from_buffer(user_buf, count, ppos, buf, len);
-#undef PR_INT_STAT
-}
-
-static const struct file_operations ag71xx_fops_int_stats = {
-       .open   = ag71xx_debugfs_generic_open,
-       .read   = read_file_int_stats,
-       .owner  = THIS_MODULE
-};
-
-void ag71xx_debugfs_update_napi_stats(struct ag71xx *ag, int rx, int tx)
-{
-       struct ag71xx_napi_stats *stats = &ag->debug.napi_stats;
-
-       if (rx) {
-               stats->rx_count++;
-               stats->rx_packets += rx;
-               if (rx <= AG71XX_NAPI_WEIGHT)
-                       stats->rx[rx]++;
-               if (rx > stats->rx_packets_max)
-                       stats->rx_packets_max = rx;
-       }
-
-       if (tx) {
-               stats->tx_count++;
-               stats->tx_packets += tx;
-               if (tx <= AG71XX_NAPI_WEIGHT)
-                       stats->tx[tx]++;
-               if (tx > stats->tx_packets_max)
-                       stats->tx_packets_max = tx;
-       }
-}
-
-static ssize_t read_file_napi_stats(struct file *file, char __user *user_buf,
-                                   size_t count, loff_t *ppos)
-{
-       struct ag71xx *ag = file->private_data;
-       struct ag71xx_napi_stats *stats = &ag->debug.napi_stats;
-       char *buf;
-       unsigned int buflen;
-       unsigned int len = 0;
-       unsigned long rx_avg = 0;
-       unsigned long tx_avg = 0;
-       int ret;
-       int i;
-
-       buflen = 2048;
-       buf = kmalloc(buflen, GFP_KERNEL);
-       if (!buf)
-               return -ENOMEM;
-
-       if (stats->rx_count)
-               rx_avg = stats->rx_packets / stats->rx_count;
-
-       if (stats->tx_count)
-               tx_avg = stats->tx_packets / stats->tx_count;
-
-       len += snprintf(buf + len, buflen - len, "%3s  %10s %10s\n",
-                       "len", "rx", "tx");
-
-       for (i = 1; i <= AG71XX_NAPI_WEIGHT; i++)
-               len += snprintf(buf + len, buflen - len,
-                               "%3d: %10lu %10lu\n",
-                               i, stats->rx[i], stats->tx[i]);
-
-       len += snprintf(buf + len, buflen - len, "\n");
-
-       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
-                       "sum", stats->rx_count, stats->tx_count);
-       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
-                       "avg", rx_avg, tx_avg);
-       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
-                       "max", stats->rx_packets_max, stats->tx_packets_max);
-       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
-                       "pkt", stats->rx_packets, stats->tx_packets);
-
-       ret = simple_read_from_buffer(user_buf, count, ppos, buf, len);
-       kfree(buf);
-
-       return ret;
-}
-
-static const struct file_operations ag71xx_fops_napi_stats = {
-       .open   = ag71xx_debugfs_generic_open,
-       .read   = read_file_napi_stats,
-       .owner  = THIS_MODULE
-};
-
-#define DESC_PRINT_LEN 64
-
-static ssize_t read_file_ring(struct file *file, char __user *user_buf,
-                             size_t count, loff_t *ppos,
-                             struct ag71xx *ag,
-                             struct ag71xx_ring *ring,
-                             unsigned desc_reg)
-{
-       int ring_size = BIT(ring->order);
-       int ring_mask = ring_size - 1;
-       char *buf;
-       unsigned int buflen;
-       unsigned int len = 0;
-       unsigned long flags;
-       ssize_t ret;
-       int curr;
-       int dirty;
-       u32 desc_hw;
-       int i;
-
-       buflen = (ring_size * DESC_PRINT_LEN);
-       buf = kmalloc(buflen, GFP_KERNEL);
-       if (!buf)
-               return -ENOMEM;
-
-       len += snprintf(buf + len, buflen - len,
-                       "Idx ... %-8s %-8s %-8s %-8s .\n",
-                       "desc", "next", "data", "ctrl");
-
-       spin_lock_irqsave(&ag->lock, flags);
-
-       curr = (ring->curr & ring_mask);
-       dirty = (ring->dirty & ring_mask);
-       desc_hw = ag71xx_rr(ag, desc_reg);
-       for (i = 0; i < ring_size; i++) {
-               struct ag71xx_desc *desc = ag71xx_ring_desc(ring, i);
-               u32 desc_dma = ((u32) ring->descs_dma) + i * AG71XX_DESC_SIZE;
-
-               len += snprintf(buf + len, buflen - len,
-                       "%3d %c%c%c %08x %08x %08x %08x %c\n",
-                       i,
-                       (i == curr) ? 'C' : ' ',
-                       (i == dirty) ? 'D' : ' ',
-                       (desc_hw == desc_dma) ? 'H' : ' ',
-                       desc_dma,
-                       desc->next,
-                       desc->data,
-                       desc->ctrl,
-                       (desc->ctrl & DESC_EMPTY) ? 'E' : '*');
-       }
-
-       spin_unlock_irqrestore(&ag->lock, flags);
-
-       ret = simple_read_from_buffer(user_buf, count, ppos, buf, len);
-       kfree(buf);
-
-       return ret;
-}
-
-static ssize_t read_file_tx_ring(struct file *file, char __user *user_buf,
-                                size_t count, loff_t *ppos)
-{
-       struct ag71xx *ag = file->private_data;
-
-       return read_file_ring(file, user_buf, count, ppos, ag, &ag->tx_ring,
-                             AG71XX_REG_TX_DESC);
-}
-
-static const struct file_operations ag71xx_fops_tx_ring = {
-       .open   = ag71xx_debugfs_generic_open,
-       .read   = read_file_tx_ring,
-       .owner  = THIS_MODULE
-};
-
-static ssize_t read_file_rx_ring(struct file *file, char __user *user_buf,
-                                size_t count, loff_t *ppos)
-{
-       struct ag71xx *ag = file->private_data;
-
-       return read_file_ring(file, user_buf, count, ppos, ag, &ag->rx_ring,
-                             AG71XX_REG_RX_DESC);
-}
-
-static const struct file_operations ag71xx_fops_rx_ring = {
-       .open   = ag71xx_debugfs_generic_open,
-       .read   = read_file_rx_ring,
-       .owner  = THIS_MODULE
-};
-
-void ag71xx_debugfs_exit(struct ag71xx *ag)
-{
-       debugfs_remove_recursive(ag->debug.debugfs_dir);
-}
-
-int ag71xx_debugfs_init(struct ag71xx *ag)
-{
-       struct device *dev = &ag->pdev->dev;
-
-       ag->debug.debugfs_dir = debugfs_create_dir(dev_name(dev),
-                                                  ag71xx_debugfs_root);
-       if (!ag->debug.debugfs_dir) {
-               dev_err(dev, "unable to create debugfs directory\n");
-               return -ENOENT;
-       }
-
-       debugfs_create_file("int_stats", S_IRUGO, ag->debug.debugfs_dir,
-                           ag, &ag71xx_fops_int_stats);
-       debugfs_create_file("napi_stats", S_IRUGO, ag->debug.debugfs_dir,
-                           ag, &ag71xx_fops_napi_stats);
-       debugfs_create_file("tx_ring", S_IRUGO, ag->debug.debugfs_dir,
-                           ag, &ag71xx_fops_tx_ring);
-       debugfs_create_file("rx_ring", S_IRUGO, ag->debug.debugfs_dir,
-                           ag, &ag71xx_fops_rx_ring);
-
-       return 0;
-}
-
-int ag71xx_debugfs_root_init(void)
-{
-       if (ag71xx_debugfs_root)
-               return -EBUSY;
-
-       ag71xx_debugfs_root = debugfs_create_dir(KBUILD_MODNAME, NULL);
-       if (!ag71xx_debugfs_root)
-               return -ENOENT;
-
-       return 0;
-}
-
-void ag71xx_debugfs_root_exit(void)
-{
-       debugfs_remove(ag71xx_debugfs_root);
-       ag71xx_debugfs_root = NULL;
-}
diff --git a/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_legacy_debugfs.c b/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_legacy_debugfs.c
new file mode 100644 (file)
index 0000000..20cf1c1
--- /dev/null
@@ -0,0 +1,285 @@
+/*
+ *  Atheros AR71xx built-in ethernet mac driver
+ *
+ *  Copyright (C) 2008-2010 Gabor Juhos <juhosg@openwrt.org>
+ *  Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
+ *
+ *  Based on Atheros' AG7100 driver
+ *
+ *  This program is free software; you can redistribute it and/or modify it
+ *  under the terms of the GNU General Public License version 2 as published
+ *  by the Free Software Foundation.
+ */
+
+#include <linux/debugfs.h>
+
+#include "ag71xx.h"
+
+static struct dentry *ag71xx_debugfs_root;
+
+static int ag71xx_debugfs_generic_open(struct inode *inode, struct file *file)
+{
+       file->private_data = inode->i_private;
+       return 0;
+}
+
+void ag71xx_debugfs_update_int_stats(struct ag71xx *ag, u32 status)
+{
+       if (status)
+               ag->debug.int_stats.total++;
+       if (status & AG71XX_INT_TX_PS)
+               ag->debug.int_stats.tx_ps++;
+       if (status & AG71XX_INT_TX_UR)
+               ag->debug.int_stats.tx_ur++;
+       if (status & AG71XX_INT_TX_BE)
+               ag->debug.int_stats.tx_be++;
+       if (status & AG71XX_INT_RX_PR)
+               ag->debug.int_stats.rx_pr++;
+       if (status & AG71XX_INT_RX_OF)
+               ag->debug.int_stats.rx_of++;
+       if (status & AG71XX_INT_RX_BE)
+               ag->debug.int_stats.rx_be++;
+}
+
+static ssize_t read_file_int_stats(struct file *file, char __user *user_buf,
+                                  size_t count, loff_t *ppos)
+{
+#define PR_INT_STAT(_label, _field)                                    \
+       len += snprintf(buf + len, sizeof(buf) - len,                   \
+               "%20s: %10lu\n", _label, ag->debug.int_stats._field);
+
+       struct ag71xx *ag = file->private_data;
+       char buf[256];
+       unsigned int len = 0;
+
+       PR_INT_STAT("TX Packet Sent", tx_ps);
+       PR_INT_STAT("TX Underrun", tx_ur);
+       PR_INT_STAT("TX Bus Error", tx_be);
+       PR_INT_STAT("RX Packet Received", rx_pr);
+       PR_INT_STAT("RX Overflow", rx_of);
+       PR_INT_STAT("RX Bus Error", rx_be);
+       len += snprintf(buf + len, sizeof(buf) - len, "\n");
+       PR_INT_STAT("Total", total);
+
+       return simple_read_from_buffer(user_buf, count, ppos, buf, len);
+#undef PR_INT_STAT
+}
+
+static const struct file_operations ag71xx_fops_int_stats = {
+       .open   = ag71xx_debugfs_generic_open,
+       .read   = read_file_int_stats,
+       .owner  = THIS_MODULE
+};
+
+void ag71xx_debugfs_update_napi_stats(struct ag71xx *ag, int rx, int tx)
+{
+       struct ag71xx_napi_stats *stats = &ag->debug.napi_stats;
+
+       if (rx) {
+               stats->rx_count++;
+               stats->rx_packets += rx;
+               if (rx <= AG71XX_NAPI_WEIGHT)
+                       stats->rx[rx]++;
+               if (rx > stats->rx_packets_max)
+                       stats->rx_packets_max = rx;
+       }
+
+       if (tx) {
+               stats->tx_count++;
+               stats->tx_packets += tx;
+               if (tx <= AG71XX_NAPI_WEIGHT)
+                       stats->tx[tx]++;
+               if (tx > stats->tx_packets_max)
+                       stats->tx_packets_max = tx;
+       }
+}
+
+static ssize_t read_file_napi_stats(struct file *file, char __user *user_buf,
+                                   size_t count, loff_t *ppos)
+{
+       struct ag71xx *ag = file->private_data;
+       struct ag71xx_napi_stats *stats = &ag->debug.napi_stats;
+       char *buf;
+       unsigned int buflen;
+       unsigned int len = 0;
+       unsigned long rx_avg = 0;
+       unsigned long tx_avg = 0;
+       int ret;
+       int i;
+
+       buflen = 2048;
+       buf = kmalloc(buflen, GFP_KERNEL);
+       if (!buf)
+               return -ENOMEM;
+
+       if (stats->rx_count)
+               rx_avg = stats->rx_packets / stats->rx_count;
+
+       if (stats->tx_count)
+               tx_avg = stats->tx_packets / stats->tx_count;
+
+       len += snprintf(buf + len, buflen - len, "%3s  %10s %10s\n",
+                       "len", "rx", "tx");
+
+       for (i = 1; i <= AG71XX_NAPI_WEIGHT; i++)
+               len += snprintf(buf + len, buflen - len,
+                               "%3d: %10lu %10lu\n",
+                               i, stats->rx[i], stats->tx[i]);
+
+       len += snprintf(buf + len, buflen - len, "\n");
+
+       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
+                       "sum", stats->rx_count, stats->tx_count);
+       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
+                       "avg", rx_avg, tx_avg);
+       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
+                       "max", stats->rx_packets_max, stats->tx_packets_max);
+       len += snprintf(buf + len, buflen - len, "%3s: %10lu %10lu\n",
+                       "pkt", stats->rx_packets, stats->tx_packets);
+
+       ret = simple_read_from_buffer(user_buf, count, ppos, buf, len);
+       kfree(buf);
+
+       return ret;
+}
+
+static const struct file_operations ag71xx_fops_napi_stats = {
+       .open   = ag71xx_debugfs_generic_open,
+       .read   = read_file_napi_stats,
+       .owner  = THIS_MODULE
+};
+
+#define DESC_PRINT_LEN 64
+
+static ssize_t read_file_ring(struct file *file, char __user *user_buf,
+                             size_t count, loff_t *ppos,
+                             struct ag71xx *ag,
+                             struct ag71xx_ring *ring,
+                             unsigned desc_reg)
+{
+       int ring_size = BIT(ring->order);
+       int ring_mask = ring_size - 1;
+       char *buf;
+       unsigned int buflen;
+       unsigned int len = 0;
+       unsigned long flags;
+       ssize_t ret;
+       int curr;
+       int dirty;
+       u32 desc_hw;
+       int i;
+
+       buflen = (ring_size * DESC_PRINT_LEN);
+       buf = kmalloc(buflen, GFP_KERNEL);
+       if (!buf)
+               return -ENOMEM;
+
+       len += snprintf(buf + len, buflen - len,
+                       "Idx ... %-8s %-8s %-8s %-8s .\n",
+                       "desc", "next", "data", "ctrl");
+
+       spin_lock_irqsave(&ag->lock, flags);
+
+       curr = (ring->curr & ring_mask);
+       dirty = (ring->dirty & ring_mask);
+       desc_hw = ag71xx_rr(ag, desc_reg);
+       for (i = 0; i < ring_size; i++) {
+               struct ag71xx_desc *desc = ag71xx_ring_desc(ring, i);
+               u32 desc_dma = ((u32) ring->descs_dma) + i * AG71XX_DESC_SIZE;
+
+               len += snprintf(buf + len, buflen - len,
+                       "%3d %c%c%c %08x %08x %08x %08x %c\n",
+                       i,
+                       (i == curr) ? 'C' : ' ',
+                       (i == dirty) ? 'D' : ' ',
+                       (desc_hw == desc_dma) ? 'H' : ' ',
+                       desc_dma,
+                       desc->next,
+                       desc->data,
+                       desc->ctrl,
+                       (desc->ctrl & DESC_EMPTY) ? 'E' : '*');
+       }
+
+       spin_unlock_irqrestore(&ag->lock, flags);
+
+       ret = simple_read_from_buffer(user_buf, count, ppos, buf, len);
+       kfree(buf);
+
+       return ret;
+}
+
+static ssize_t read_file_tx_ring(struct file *file, char __user *user_buf,
+                                size_t count, loff_t *ppos)
+{
+       struct ag71xx *ag = file->private_data;
+
+       return read_file_ring(file, user_buf, count, ppos, ag, &ag->tx_ring,
+                             AG71XX_REG_TX_DESC);
+}
+
+static const struct file_operations ag71xx_fops_tx_ring = {
+       .open   = ag71xx_debugfs_generic_open,
+       .read   = read_file_tx_ring,
+       .owner  = THIS_MODULE
+};
+
+static ssize_t read_file_rx_ring(struct file *file, char __user *user_buf,
+                                size_t count, loff_t *ppos)
+{
+       struct ag71xx *ag = file->private_data;
+
+       return read_file_ring(file, user_buf, count, ppos, ag, &ag->rx_ring,
+                             AG71XX_REG_RX_DESC);
+}
+
+static const struct file_operations ag71xx_fops_rx_ring = {
+       .open   = ag71xx_debugfs_generic_open,
+       .read   = read_file_rx_ring,
+       .owner  = THIS_MODULE
+};
+
+void ag71xx_debugfs_exit(struct ag71xx *ag)
+{
+       debugfs_remove_recursive(ag->debug.debugfs_dir);
+}
+
+int ag71xx_debugfs_init(struct ag71xx *ag)
+{
+       struct device *dev = &ag->pdev->dev;
+
+       ag->debug.debugfs_dir = debugfs_create_dir(dev_name(dev),
+                                                  ag71xx_debugfs_root);
+       if (!ag->debug.debugfs_dir) {
+               dev_err(dev, "unable to create debugfs directory\n");
+               return -ENOENT;
+       }
+
+       debugfs_create_file("int_stats", S_IRUGO, ag->debug.debugfs_dir,
+                           ag, &ag71xx_fops_int_stats);
+       debugfs_create_file("napi_stats", S_IRUGO, ag->debug.debugfs_dir,
+                           ag, &ag71xx_fops_napi_stats);
+       debugfs_create_file("tx_ring", S_IRUGO, ag->debug.debugfs_dir,
+                           ag, &ag71xx_fops_tx_ring);
+       debugfs_create_file("rx_ring", S_IRUGO, ag->debug.debugfs_dir,
+                           ag, &ag71xx_fops_rx_ring);
+
+       return 0;
+}
+
+int ag71xx_debugfs_root_init(void)
+{
+       if (ag71xx_debugfs_root)
+               return -EBUSY;
+
+       ag71xx_debugfs_root = debugfs_create_dir(KBUILD_MODNAME, NULL);
+       if (!ag71xx_debugfs_root)
+               return -ENOENT;
+
+       return 0;
+}
+
+void ag71xx_debugfs_root_exit(void)
+{
+       debugfs_remove(ag71xx_debugfs_root);
+       ag71xx_debugfs_root = NULL;
+}
diff --git a/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_legacy_mdio.c b/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_legacy_mdio.c
new file mode 100644 (file)
index 0000000..fda561a
--- /dev/null
@@ -0,0 +1,250 @@
+/*
+ *  Atheros AR71xx built-in ethernet mac driver
+ *
+ *  Copyright (C) 2008-2010 Gabor Juhos <juhosg@openwrt.org>
+ *  Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
+ *
+ *  Based on Atheros' AG7100 driver
+ *
+ *  This program is free software; you can redistribute it and/or modify it
+ *  under the terms of the GNU General Public License version 2 as published
+ *  by the Free Software Foundation.
+ */
+
+#include <linux/clk.h>
+#include <linux/of_mdio.h>
+#include "ag71xx.h"
+
+#define AG71XX_MDIO_RETRY      1000
+#define AG71XX_MDIO_DELAY      5
+
+static int bus_count;
+
+static int ag71xx_mdio_wait_busy(struct ag71xx_mdio *am)
+{
+       int i;
+
+       for (i = 0; i < AG71XX_MDIO_RETRY; i++) {
+               u32 busy;
+
+               udelay(AG71XX_MDIO_DELAY);
+
+               regmap_read(am->mii_regmap, AG71XX_REG_MII_IND, &busy);
+               if (!busy)
+                       return 0;
+
+               udelay(AG71XX_MDIO_DELAY);
+       }
+
+       pr_err("%s: MDIO operation timed out\n", am->mii_bus->name);
+
+       return -ETIMEDOUT;
+}
+
+static int ag71xx_mdio_mii_read(struct mii_bus *bus, int addr, int reg)
+{
+       struct ag71xx_mdio *am = bus->priv;
+       int err;
+       int ret;
+
+       err = ag71xx_mdio_wait_busy(am);
+       if (err)
+               return 0xffff;
+
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_CMD, MII_CMD_WRITE);
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_ADDR,
+                       ((addr & 0xff) << MII_ADDR_SHIFT) | (reg & 0xff));
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_CMD, MII_CMD_READ);
+
+       err = ag71xx_mdio_wait_busy(am);
+       if (err)
+               return 0xffff;
+
+       regmap_read(am->mii_regmap, AG71XX_REG_MII_STATUS, &ret);
+       ret &= 0xffff;
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_CMD, MII_CMD_WRITE);
+
+       DBG("mii_read: addr=%04x, reg=%04x, value=%04x\n", addr, reg, ret);
+
+       return ret;
+}
+
+static int ag71xx_mdio_mii_write(struct mii_bus *bus, int addr, int reg, u16 val)
+{
+       struct ag71xx_mdio *am = bus->priv;
+
+       DBG("mii_write: addr=%04x, reg=%04x, value=%04x\n", addr, reg, val);
+
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_ADDR,
+                       ((addr & 0xff) << MII_ADDR_SHIFT) | (reg & 0xff));
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_CTRL, val);
+
+       ag71xx_mdio_wait_busy(am);
+
+       return 0;
+}
+
+static const u32 ar71xx_mdio_div_table[] = {
+       4, 4, 6, 8, 10, 14, 20, 28,
+};
+
+static const u32 ar7240_mdio_div_table[] = {
+       2, 2, 4, 6, 8, 12, 18, 26, 32, 40, 48, 56, 62, 70, 78, 96,
+};
+
+static const u32 ar933x_mdio_div_table[] = {
+       4, 4, 6, 8, 10, 14, 20, 28, 34, 42, 50, 58, 66, 74, 82, 98,
+};
+
+static int ag71xx_mdio_get_divider(struct device_node *np, u32 *div)
+{
+       struct clk *ref_clk = of_clk_get(np, 0);
+       unsigned long ref_clock;
+       u32 mdio_clock;
+       const u32 *table;
+       int ndivs, i;
+
+       if (IS_ERR(ref_clk))
+               return -EINVAL;
+
+       ref_clock = clk_get_rate(ref_clk);
+       clk_put(ref_clk);
+
+       if(of_property_read_u32(np, "qca,mdio-max-frequency", &mdio_clock)) {
+               if (of_property_read_bool(np, "builtin-switch"))
+                       mdio_clock = 5000000;
+               else
+                       mdio_clock = 2000000;
+       }
+
+       if (of_device_is_compatible(np, "qca,ar9330-mdio") ||
+               of_device_is_compatible(np, "qca,ar9340-mdio")) {
+               table = ar933x_mdio_div_table;
+               ndivs = ARRAY_SIZE(ar933x_mdio_div_table);
+       } else if (of_device_is_compatible(np, "qca,ar7240-mdio")) {
+               table = ar7240_mdio_div_table;
+               ndivs = ARRAY_SIZE(ar7240_mdio_div_table);
+       } else {
+               table = ar71xx_mdio_div_table;
+               ndivs = ARRAY_SIZE(ar71xx_mdio_div_table);
+       }
+
+       for (i = 0; i < ndivs; i++) {
+               unsigned long t;
+
+               t = ref_clock / table[i];
+               if (t <= mdio_clock) {
+                       *div = i;
+                       return 0;
+               }
+       }
+
+       return -ENOENT;
+}
+
+static int ag71xx_mdio_reset(struct mii_bus *bus)
+{
+       struct device_node *np = bus->dev.of_node;
+       struct ag71xx_mdio *am = bus->priv;
+       bool builtin_switch;
+       u32 t;
+
+       builtin_switch = of_property_read_bool(np, "builtin-switch");
+
+       if (ag71xx_mdio_get_divider(np, &t)) {
+               if (of_device_is_compatible(np, "qca,ar9340-mdio"))
+                       t = MII_CFG_CLK_DIV_58;
+               else if (builtin_switch)
+                       t = MII_CFG_CLK_DIV_10;
+               else
+                       t = MII_CFG_CLK_DIV_28;
+       }
+
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_CFG, t | MII_CFG_RESET);
+       udelay(100);
+
+       regmap_write(am->mii_regmap, AG71XX_REG_MII_CFG, t);
+       udelay(100);
+
+       return 0;
+}
+
+static int ag71xx_mdio_probe(struct platform_device *pdev)
+{
+       struct device *amdev = &pdev->dev;
+       struct device_node *np = pdev->dev.of_node;
+       struct ag71xx_mdio *am;
+       struct mii_bus *mii_bus;
+       bool builtin_switch;
+       int i, err;
+
+       am = devm_kzalloc(amdev, sizeof(*am), GFP_KERNEL);
+       if (!am)
+               return -ENOMEM;
+
+       am->mii_regmap = syscon_regmap_lookup_by_phandle(np, "regmap");
+       if (IS_ERR(am->mii_regmap))
+               return PTR_ERR(am->mii_regmap);
+
+       mii_bus = devm_mdiobus_alloc(amdev);
+       if (!mii_bus)
+               return -ENOMEM;
+
+       am->mdio_reset = devm_reset_control_get_exclusive(amdev, "mdio");
+       builtin_switch = of_property_read_bool(np, "builtin-switch");
+
+       mii_bus->name = "ag71xx_mdio";
+       mii_bus->read = ag71xx_mdio_mii_read;
+       mii_bus->write = ag71xx_mdio_mii_write;
+       mii_bus->reset = ag71xx_mdio_reset;
+       mii_bus->priv = am;
+       mii_bus->parent = amdev;
+       snprintf(mii_bus->id, MII_BUS_ID_SIZE, "%s.%d", np->name, bus_count++);
+
+       for (i = 0; i < PHY_MAX_ADDR; i++)
+               mii_bus->irq[i] = PHY_POLL;
+
+       if (!IS_ERR(am->mdio_reset)) {
+               reset_control_assert(am->mdio_reset);
+               msleep(100);
+               reset_control_deassert(am->mdio_reset);
+               msleep(200);
+       }
+
+       err = of_mdiobus_register(mii_bus, np);
+       if (err)
+               return err;
+
+       am->mii_bus = mii_bus;
+       platform_set_drvdata(pdev, am);
+
+       return 0;
+}
+
+static int ag71xx_mdio_remove(struct platform_device *pdev)
+{
+       struct ag71xx_mdio *am = platform_get_drvdata(pdev);
+
+       mdiobus_unregister(am->mii_bus);
+       return 0;
+}
+
+static const struct of_device_id ag71xx_mdio_match[] = {
+       { .compatible = "qca,ar7240-mdio" },
+       { .compatible = "qca,ar9330-mdio" },
+       { .compatible = "qca,ar9340-mdio" },
+       { .compatible = "qca,ath79-mdio" },
+       {}
+};
+
+static struct platform_driver ag71xx_mdio_driver = {
+       .probe          = ag71xx_mdio_probe,
+       .remove         = ag71xx_mdio_remove,
+       .driver = {
+               .name    = "ag71xx-legacy-mdio",
+               .of_match_table = ag71xx_mdio_match,
+       }
+};
+
+module_platform_driver(ag71xx_mdio_driver);
+MODULE_LICENSE("GPL");
diff --git a/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_mdio.c b/target/linux/ath79/files/drivers/net/ethernet/atheros/ag71xx/ag71xx_mdio.c
deleted file mode 100644 (file)
index fd05dbd..0000000
+++ /dev/null
@@ -1,250 +0,0 @@
-/*
- *  Atheros AR71xx built-in ethernet mac driver
- *
- *  Copyright (C) 2008-2010 Gabor Juhos <juhosg@openwrt.org>
- *  Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
- *
- *  Based on Atheros' AG7100 driver
- *
- *  This program is free software; you can redistribute it and/or modify it
- *  under the terms of the GNU General Public License version 2 as published
- *  by the Free Software Foundation.
- */
-
-#include <linux/clk.h>
-#include <linux/of_mdio.h>
-#include "ag71xx.h"
-
-#define AG71XX_MDIO_RETRY      1000
-#define AG71XX_MDIO_DELAY      5
-
-static int bus_count;
-
-static int ag71xx_mdio_wait_busy(struct ag71xx_mdio *am)
-{
-       int i;
-
-       for (i = 0; i < AG71XX_MDIO_RETRY; i++) {
-               u32 busy;
-
-               udelay(AG71XX_MDIO_DELAY);
-
-               regmap_read(am->mii_regmap, AG71XX_REG_MII_IND, &busy);
-               if (!busy)
-                       return 0;
-
-               udelay(AG71XX_MDIO_DELAY);
-       }
-
-       pr_err("%s: MDIO operation timed out\n", am->mii_bus->name);
-
-       return -ETIMEDOUT;
-}
-
-static int ag71xx_mdio_mii_read(struct mii_bus *bus, int addr, int reg)
-{
-       struct ag71xx_mdio *am = bus->priv;
-       int err;
-       int ret;
-
-       err = ag71xx_mdio_wait_busy(am);
-       if (err)
-               return 0xffff;
-
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_CMD, MII_CMD_WRITE);
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_ADDR,
-                       ((addr & 0xff) << MII_ADDR_SHIFT) | (reg & 0xff));
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_CMD, MII_CMD_READ);
-
-       err = ag71xx_mdio_wait_busy(am);
-       if (err)
-               return 0xffff;
-
-       regmap_read(am->mii_regmap, AG71XX_REG_MII_STATUS, &ret);
-       ret &= 0xffff;
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_CMD, MII_CMD_WRITE);
-
-       DBG("mii_read: addr=%04x, reg=%04x, value=%04x\n", addr, reg, ret);
-
-       return ret;
-}
-
-static int ag71xx_mdio_mii_write(struct mii_bus *bus, int addr, int reg, u16 val)
-{
-       struct ag71xx_mdio *am = bus->priv;
-
-       DBG("mii_write: addr=%04x, reg=%04x, value=%04x\n", addr, reg, val);
-
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_ADDR,
-                       ((addr & 0xff) << MII_ADDR_SHIFT) | (reg & 0xff));
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_CTRL, val);
-
-       ag71xx_mdio_wait_busy(am);
-
-       return 0;
-}
-
-static const u32 ar71xx_mdio_div_table[] = {
-       4, 4, 6, 8, 10, 14, 20, 28,
-};
-
-static const u32 ar7240_mdio_div_table[] = {
-       2, 2, 4, 6, 8, 12, 18, 26, 32, 40, 48, 56, 62, 70, 78, 96,
-};
-
-static const u32 ar933x_mdio_div_table[] = {
-       4, 4, 6, 8, 10, 14, 20, 28, 34, 42, 50, 58, 66, 74, 82, 98,
-};
-
-static int ag71xx_mdio_get_divider(struct device_node *np, u32 *div)
-{
-       struct clk *ref_clk = of_clk_get(np, 0);
-       unsigned long ref_clock;
-       u32 mdio_clock;
-       const u32 *table;
-       int ndivs, i;
-
-       if (IS_ERR(ref_clk))
-               return -EINVAL;
-
-       ref_clock = clk_get_rate(ref_clk);
-       clk_put(ref_clk);
-
-       if(of_property_read_u32(np, "qca,mdio-max-frequency", &mdio_clock)) {
-               if (of_property_read_bool(np, "builtin-switch"))
-                       mdio_clock = 5000000;
-               else
-                       mdio_clock = 2000000;
-       }
-
-       if (of_device_is_compatible(np, "qca,ar9330-mdio") ||
-               of_device_is_compatible(np, "qca,ar9340-mdio")) {
-               table = ar933x_mdio_div_table;
-               ndivs = ARRAY_SIZE(ar933x_mdio_div_table);
-       } else if (of_device_is_compatible(np, "qca,ar7240-mdio")) {
-               table = ar7240_mdio_div_table;
-               ndivs = ARRAY_SIZE(ar7240_mdio_div_table);
-       } else {
-               table = ar71xx_mdio_div_table;
-               ndivs = ARRAY_SIZE(ar71xx_mdio_div_table);
-       }
-
-       for (i = 0; i < ndivs; i++) {
-               unsigned long t;
-
-               t = ref_clock / table[i];
-               if (t <= mdio_clock) {
-                       *div = i;
-                       return 0;
-               }
-       }
-
-       return -ENOENT;
-}
-
-static int ag71xx_mdio_reset(struct mii_bus *bus)
-{
-       struct device_node *np = bus->dev.of_node;
-       struct ag71xx_mdio *am = bus->priv;
-       bool builtin_switch;
-       u32 t;
-
-       builtin_switch = of_property_read_bool(np, "builtin-switch");
-
-       if (ag71xx_mdio_get_divider(np, &t)) {
-               if (of_device_is_compatible(np, "qca,ar9340-mdio"))
-                       t = MII_CFG_CLK_DIV_58;
-               else if (builtin_switch)
-                       t = MII_CFG_CLK_DIV_10;
-               else
-                       t = MII_CFG_CLK_DIV_28;
-       }
-
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_CFG, t | MII_CFG_RESET);
-       udelay(100);
-
-       regmap_write(am->mii_regmap, AG71XX_REG_MII_CFG, t);
-       udelay(100);
-
-       return 0;
-}
-
-static int ag71xx_mdio_probe(struct platform_device *pdev)
-{
-       struct device *amdev = &pdev->dev;
-       struct device_node *np = pdev->dev.of_node;
-       struct ag71xx_mdio *am;
-       struct mii_bus *mii_bus;
-       bool builtin_switch;
-       int i, err;
-
-       am = devm_kzalloc(amdev, sizeof(*am), GFP_KERNEL);
-       if (!am)
-               return -ENOMEM;
-
-       am->mii_regmap = syscon_regmap_lookup_by_phandle(np, "regmap");
-       if (IS_ERR(am->mii_regmap))
-               return PTR_ERR(am->mii_regmap);
-
-       mii_bus = devm_mdiobus_alloc(amdev);
-       if (!mii_bus)
-               return -ENOMEM;
-
-       am->mdio_reset = devm_reset_control_get_exclusive(amdev, "mdio");
-       builtin_switch = of_property_read_bool(np, "builtin-switch");
-
-       mii_bus->name = "ag71xx_mdio";
-       mii_bus->read = ag71xx_mdio_mii_read;
-       mii_bus->write = ag71xx_mdio_mii_write;
-       mii_bus->reset = ag71xx_mdio_reset;
-       mii_bus->priv = am;
-       mii_bus->parent = amdev;
-       snprintf(mii_bus->id, MII_BUS_ID_SIZE, "%s.%d", np->name, bus_count++);
-
-       for (i = 0; i < PHY_MAX_ADDR; i++)
-               mii_bus->irq[i] = PHY_POLL;
-
-       if (!IS_ERR(am->mdio_reset)) {
-               reset_control_assert(am->mdio_reset);
-               msleep(100);
-               reset_control_deassert(am->mdio_reset);
-               msleep(200);
-       }
-
-       err = of_mdiobus_register(mii_bus, np);
-       if (err)
-               return err;
-
-       am->mii_bus = mii_bus;
-       platform_set_drvdata(pdev, am);
-
-       return 0;
-}
-
-static int ag71xx_mdio_remove(struct platform_device *pdev)
-{
-       struct ag71xx_mdio *am = platform_get_drvdata(pdev);
-
-       mdiobus_unregister(am->mii_bus);
-       return 0;
-}
-
-static const struct of_device_id ag71xx_mdio_match[] = {
-       { .compatible = "qca,ar7240-mdio" },
-       { .compatible = "qca,ar9330-mdio" },
-       { .compatible = "qca,ar9340-mdio" },
-       { .compatible = "qca,ath79-mdio" },
-       {}
-};
-
-static struct platform_driver ag71xx_mdio_driver = {
-       .probe          = ag71xx_mdio_probe,
-       .remove         = ag71xx_mdio_remove,
-       .driver = {
-               .name    = "ag71xx-mdio",
-               .of_match_table = ag71xx_mdio_match,
-       }
-};
-
-module_platform_driver(ag71xx_mdio_driver);
-MODULE_LICENSE("GPL");
index 54e64fb11cf8e9ef10930fcccb0bef4ed77c4e54..0997aa1ab85271e3c4fca001a1fff56dd8447574 100644 (file)
@@ -13,30 +13,22 @@ Submitted-by: John Crispin <john@phrozen.org>
 
 --- a/drivers/net/ethernet/atheros/Kconfig
 +++ b/drivers/net/ethernet/atheros/Kconfig
-@@ -17,14 +17,7 @@ config NET_VENDOR_ATHEROS
+@@ -26,6 +26,8 @@ config AG71XX
+         If you wish to compile a kernel for AR7XXX/91XXX and enable
+         ethernet support, then you should always answer Y to this.
  
- if NET_VENDOR_ATHEROS
--config AG71XX
--      tristate "Atheros AR7XXX/AR9XXX built-in ethernet mac support"
--      depends on ATH79
--      select PHYLINK
--      imply NET_SELFTESTS
--      help
--        If you wish to compile a kernel for AR7XXX/91XXX and enable
--        ethernet support, then you should always answer Y to this.
 +source "drivers/net/ethernet/atheros/ag71xx/Kconfig"
++
  config ATL2
        tristate "Atheros L2 Fast Ethernet support"
+       depends on PCI
 --- a/drivers/net/ethernet/atheros/Makefile
 +++ b/drivers/net/ethernet/atheros/Makefile
-@@ -3,7 +3,7 @@
- # Makefile for the Atheros network device drivers.
+@@ -4,6 +4,7 @@
  #
  
--obj-$(CONFIG_AG71XX) += ag71xx.o
-+obj-$(CONFIG_AG71XX) += ag71xx/
+ obj-$(CONFIG_AG71XX) += ag71xx.o
++obj-$(CONFIG_AG71XX_LEGACY) += ag71xx/
  obj-$(CONFIG_ATL1) += atlx/
  obj-$(CONFIG_ATL2) += atlx/
  obj-$(CONFIG_ATL1E) += atl1e/