mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-23 07:22:33 +00:00
852f7b37ed
Backport patches from r24162 brcm47xx: reorder patches like they were commitet upstream SVN-Revision: 24266
52 lines
1.7 KiB
Diff
52 lines
1.7 KiB
Diff
From 99dfec6e793651963ede3c2721b9ff3c81e3aeac Mon Sep 17 00:00:00 2001
|
|
From: Hauke Mehrtens <hauke@hauke-m.de>
|
|
Date: Sat, 27 Nov 2010 14:04:36 +0100
|
|
Subject: [PATCH 6/6] sb: fix nvram_get on bcm47xx platform
|
|
|
|
The nvram_get function was never in the mainline kernel, it only
|
|
existed in an external OpenWrt patch. Use nvram_getenv function, which
|
|
is in mainline and use an include instead of an extra function
|
|
declaration.
|
|
et0macaddr contains the mac address in text from like
|
|
00:11:22:33:44:55. We have to parse it before adding it into macaddr.
|
|
|
|
nvram_parse_macaddr will be merged into asm/mach-bcm47xx/nvram.h though
|
|
the MIPS git tree and will be available soon. It will not build now
|
|
without nvram_parse_macaddr, but it haven't done before.
|
|
|
|
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
|
|
---
|
|
include/linux/ssb/ssb_driver_gige.h | 17 +++++++++++------
|
|
1 files changed, 11 insertions(+), 6 deletions(-)
|
|
|
|
--- a/include/linux/ssb/ssb_driver_gige.h
|
|
+++ b/include/linux/ssb/ssb_driver_gige.h
|
|
@@ -96,16 +96,21 @@ static inline bool ssb_gige_must_flush_p
|
|
return 0;
|
|
}
|
|
|
|
-extern char * nvram_get(const char *name);
|
|
+#ifdef CONFIG_BCM47XX
|
|
+#include <asm/mach-bcm47xx/nvram.h>
|
|
/* Get the device MAC address */
|
|
static inline void ssb_gige_get_macaddr(struct pci_dev *pdev, u8 *macaddr)
|
|
{
|
|
-#ifdef CONFIG_BCM47XX
|
|
- char *res = nvram_get("et0macaddr");
|
|
- if (res)
|
|
- memcpy(macaddr, res, 6);
|
|
-#endif
|
|
+ char buf[20];
|
|
+ if (nvram_getenv("et0macaddr", buf, sizeof(buf)) < 0)
|
|
+ return;
|
|
+ nvram_parse_macaddr(buf, macaddr);
|
|
}
|
|
+#else
|
|
+static inline void ssb_gige_get_macaddr(struct pci_dev *pdev, u8 *macaddr)
|
|
+{
|
|
+}
|
|
+#endif
|
|
|
|
extern int ssb_gige_pcibios_plat_dev_init(struct ssb_device *sdev,
|
|
struct pci_dev *pdev);
|