[bcm47xx] Stopgap compilation fixes for diag and switch under 2.6.25
authornoz <noz@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Tue, 20 May 2008 22:33:45 +0000 (22:33 +0000)
committernoz <noz@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Tue, 20 May 2008 22:33:45 +0000 (22:33 +0000)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@11231 3c298f89-4303-0410-b956-a3cf2f4a3e73

package/broadcom-diag/src/diag.c
package/broadcom-diag/src/gpio.h
package/switch/src/gpio-bcm947xx.h

index e1655d0..a1ee842 100644 (file)
@@ -682,7 +682,7 @@ static struct platform_t __init *platform_detect(void)
        /* Look for a model identifier */
 
        /* Based on "model_name" */
-       if (buf = nvram_get("model_name")) {
+       if ((buf = nvram_get("model_name"))) {
                if (!strcmp(buf, "DIR-130"))
                        return &platforms[DIR130];
                if (!strcmp(buf, "DIR-330"))
@@ -690,13 +690,13 @@ static struct platform_t __init *platform_detect(void)
        }
 
        /* Based on "model_no" */
-       if (buf = nvram_get("model_no")) {
+       if ((buf = nvram_get("model_no"))) {
                if (startswith(buf,"WL700")) /* WL700* */
                        return &platforms[WL700GE];
        }
 
        /* Based on "hardware_version" */
-       if (buf = nvram_get("hardware_version")) {
+       if ((buf = nvram_get("hardware_version"))) {
                if (startswith(buf,"WL500GPV2-")) /* WL500GPV2-* */
                        return &platforms[WL500GPV2];
                if (startswith(buf,"WL520GC-")) /* WL520GU-* */
@@ -706,7 +706,7 @@ static struct platform_t __init *platform_detect(void)
        }
 
        /* Based on "ModelId" */
-       if (buf = nvram_get("ModelId")) {
+       if ((buf = nvram_get("ModelId"))) {
                if (!strcmp(buf, "WR850GP"))
                        return &platforms[WR850GP];
                if (!strcmp(buf,"WX-5565"))
index 2284e98..6b1b2ad 100644 (file)
@@ -5,6 +5,10 @@
 #ifndef BCMDRIVER
 #include <linux/ssb/ssb_embedded.h>
 
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,25)
+#include <linux/gpio.h>
+#define ssb ssb_bcm47xx
+#endif
 extern struct ssb_bus ssb;
 
 
@@ -51,11 +55,16 @@ static void gpio_set_irqenable(int enabled, irqreturn_t (*handler)(int, void *))
 {
        int irq;
 
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,25)
+       irq = gpio_to_irq(0);
+       if (irq == -EINVAL) return;
+#else
        if (ssb.chipco.dev)
                irq = ssb_mips_irq(ssb.chipco.dev) + 2;
        else if (ssb.extif.dev)
                irq = ssb_mips_irq(ssb.extif.dev) + 2;
        else return;
+#endif
        
        if (enabled) {
                if (request_irq(irq, handler, IRQF_SHARED | IRQF_SAMPLE_RANDOM, "gpio", handler))
index 9417bce..9135f91 100644 (file)
@@ -5,6 +5,10 @@
 #ifndef BCMDRIVER
 #include <linux/ssb/ssb_embedded.h>
 
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,25)
+#define ssb ssb_bcm47xx
+#endif
+
 extern struct ssb_bus ssb;