bcm53xx: bgmac: add support for the 3rd core
Signed-off-by: Rafał Miłecki <zajec5@gmail.com> SVN-Revision: 45680
This commit is contained in:
parent
a11d2f1cb2
commit
45ec92fa30
1 changed files with 68 additions and 0 deletions
|
@ -0,0 +1,68 @@
|
||||||
|
From f5d5afc0b1402aae0f6a2350e43241603dbaff1e Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <zajec5@gmail.com>
|
||||||
|
Date: Wed, 13 May 2015 10:46:47 +0200
|
||||||
|
Subject: [PATCH] bgmac: add support for the 3rd bus core (device)
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
So far we were supporting up to 2 cores but recent devices (e.g. Netgear
|
||||||
|
R8000) may use 3rd as well. Lower ones (1st, 2nd) are usually used for
|
||||||
|
some offloading then.
|
||||||
|
|
||||||
|
Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
|
||||||
|
---
|
||||||
|
drivers/net/ethernet/broadcom/bgmac.c | 28 +++++++++++++++++++++++-----
|
||||||
|
1 file changed, 23 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/drivers/net/ethernet/broadcom/bgmac.c b/drivers/net/ethernet/broadcom/bgmac.c
|
||||||
|
index f66c416..0614cae 100644
|
||||||
|
--- a/drivers/net/ethernet/broadcom/bgmac.c
|
||||||
|
+++ b/drivers/net/ethernet/broadcom/bgmac.c
|
||||||
|
@@ -1561,11 +1561,20 @@ static int bgmac_probe(struct bcma_device *core)
|
||||||
|
struct net_device *net_dev;
|
||||||
|
struct bgmac *bgmac;
|
||||||
|
struct ssb_sprom *sprom = &core->bus->sprom;
|
||||||
|
- u8 *mac = core->core_unit ? sprom->et1mac : sprom->et0mac;
|
||||||
|
+ u8 *mac;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
- /* We don't support 2nd, 3rd, ... units, SPROM has to be adjusted */
|
||||||
|
- if (core->core_unit > 1) {
|
||||||
|
+ switch (core->core_unit) {
|
||||||
|
+ case 0:
|
||||||
|
+ mac = sprom->et0mac;
|
||||||
|
+ break;
|
||||||
|
+ case 1:
|
||||||
|
+ mac = sprom->et1mac;
|
||||||
|
+ break;
|
||||||
|
+ case 2:
|
||||||
|
+ mac = sprom->et2mac;
|
||||||
|
+ break;
|
||||||
|
+ default:
|
||||||
|
pr_err("Unsupported core_unit %d\n", core->core_unit);
|
||||||
|
return -ENOTSUPP;
|
||||||
|
}
|
||||||
|
@@ -1600,8 +1609,17 @@ static int bgmac_probe(struct bcma_device *core)
|
||||||
|
}
|
||||||
|
bgmac->cmn = core->bus->drv_gmac_cmn.core;
|
||||||
|
|
||||||
|
- bgmac->phyaddr = core->core_unit ? sprom->et1phyaddr :
|
||||||
|
- sprom->et0phyaddr;
|
||||||
|
+ switch (core->core_unit) {
|
||||||
|
+ case 0:
|
||||||
|
+ bgmac->phyaddr = sprom->et0phyaddr;
|
||||||
|
+ break;
|
||||||
|
+ case 1:
|
||||||
|
+ bgmac->phyaddr = sprom->et1phyaddr;
|
||||||
|
+ break;
|
||||||
|
+ case 2:
|
||||||
|
+ bgmac->phyaddr = sprom->et2phyaddr;
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
bgmac->phyaddr &= BGMAC_PHY_MASK;
|
||||||
|
if (bgmac->phyaddr == BGMAC_PHY_MASK) {
|
||||||
|
bgmac_err(bgmac, "No PHY found\n");
|
||||||
|
--
|
||||||
|
1.8.4.5
|
||||||
|
|
Loading…
Reference in a new issue