mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-01-23 04:31:06 +02:00
broadcom-diag cleanup
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10691 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
8d00b42964
commit
f09be1cdd6
@ -3,6 +3,7 @@
|
||||
*
|
||||
* Copyright (C) 2006 Mike Baker <mbm@openwrt.org>,
|
||||
* Copyright (C) 2006-2007 Felix Fietkau <nbd@openwrt.org>
|
||||
* Copyright (C) 2008 Andy Boyett <agb@openwrt.org>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License
|
||||
@ -46,6 +47,7 @@ extern u64 uevent_next_seqnum(void);
|
||||
#include "diag.h"
|
||||
#define getvar(str) (nvram_get(str)?:"")
|
||||
|
||||
static inline int startswith (char *source, char *cmp) { return !strncmp(source,cmp,strlen(cmp)); }
|
||||
static int fill_event(struct event_t *);
|
||||
static unsigned int gpiomask = 0;
|
||||
module_param(gpiomask, int, 0644);
|
||||
@ -59,7 +61,7 @@ enum {
|
||||
WRTSL54GS,
|
||||
WRT54G3G,
|
||||
WRT350N,
|
||||
|
||||
|
||||
/* ASUS */
|
||||
WLHDD,
|
||||
WL300G,
|
||||
@ -69,7 +71,7 @@ enum {
|
||||
WL500W,
|
||||
ASUS_4702,
|
||||
WL700GE,
|
||||
|
||||
|
||||
/* Buffalo */
|
||||
WBR2_G54,
|
||||
WHR_G54S,
|
||||
@ -86,7 +88,7 @@ enum {
|
||||
/* Siemens */
|
||||
SE505V1,
|
||||
SE505V2,
|
||||
|
||||
|
||||
/* US Robotics */
|
||||
USR5461,
|
||||
|
||||
@ -107,7 +109,7 @@ enum {
|
||||
|
||||
/* Trendware */
|
||||
TEW411BRPP,
|
||||
|
||||
|
||||
/* SimpleTech */
|
||||
STI_NAS,
|
||||
|
||||
@ -161,7 +163,7 @@ static struct platform_t __initdata platforms[] = {
|
||||
{ .name = "reset", .gpio = 1 << 7 },
|
||||
{ .name = "ses", .gpio = 1 << 0 },
|
||||
},
|
||||
.leds = {
|
||||
.leds = {
|
||||
/* FIXME: diag? */
|
||||
{ .name = "ses", .gpio = 1 << 1 },
|
||||
},
|
||||
@ -171,7 +173,7 @@ static struct platform_t __initdata platforms[] = {
|
||||
.buttons = {
|
||||
{ .name = "reset", .gpio = 1 << 6 },
|
||||
},
|
||||
.leds = {
|
||||
.leds = {
|
||||
{ .name = "diag", .gpio = 0x13 | GPIO_TYPE_EXTIF, .polarity = NORMAL },
|
||||
{ .name = "dmz", .gpio = 0x12 | GPIO_TYPE_EXTIF, .polarity = NORMAL },
|
||||
},
|
||||
@ -595,7 +597,7 @@ static struct platform_t __initdata platforms[] = {
|
||||
{ .name = "reserved", .gpio = 1 << 7},
|
||||
},
|
||||
.leds = {
|
||||
{ .name = "diag", .gpio = 1 << 0},
|
||||
{ .name = "diag", .gpio = 1 << 0},
|
||||
{ .name = "blue", .gpio = 1 << 6},
|
||||
},
|
||||
},
|
||||
@ -606,8 +608,8 @@ static struct platform_t __initdata platforms[] = {
|
||||
{ .name = "reserved", .gpio = 1 << 7},
|
||||
},
|
||||
.leds = {
|
||||
{ .name = "diag", .gpio = 1 << 0},
|
||||
{ .name = "usb", .gpio = 1 << 4},
|
||||
{ .name = "diag", .gpio = 1 << 0},
|
||||
{ .name = "usb", .gpio = 1 << 4},
|
||||
{ .name = "blue", .gpio = 1 << 6},
|
||||
},
|
||||
},
|
||||
@ -653,7 +655,7 @@ static struct platform_t __init *platform_detect(void)
|
||||
|
||||
/* Based on "model_no" */
|
||||
if (buf = nvram_get("model_no")) {
|
||||
if (!strncmp(buf,"WL700", 5)) /* WL700* */
|
||||
if (startswith(buf,"WL700")) /* WL700* */
|
||||
return &platforms[WL700GE];
|
||||
}
|
||||
|
||||
@ -663,7 +665,7 @@ static struct platform_t __init *platform_detect(void)
|
||||
return &platforms[WR850GP];
|
||||
if (!strcmp(buf,"WX-5565"))
|
||||
return &platforms[TM2300];
|
||||
if (!strncmp(buf,"WE800G", 6)) /* WE800G* */
|
||||
if (startswith(buf,"WE800G")) /* WE800G* */
|
||||
return &platforms[WE800G];
|
||||
}
|
||||
|
||||
@ -694,7 +696,7 @@ static struct platform_t __init *platform_detect(void)
|
||||
boardnum = getvar("boardnum");
|
||||
boardtype = getvar("boardtype");
|
||||
|
||||
if (strncmp(getvar("pmon_ver"), "CFE", 3) == 0) {
|
||||
if (startswith(getvar("pmon_ver"), "CFE")) {
|
||||
/* CFE based - newer hardware */
|
||||
if (!strcmp(boardnum, "42")) { /* Linksys */
|
||||
if (!strcmp(boardtype, "0x478") && !strcmp(getvar("cardbus"), "1"))
|
||||
@ -705,11 +707,11 @@ static struct platform_t __init *platform_detect(void)
|
||||
|
||||
if (!strcmp(getvar("et1phyaddr"),"5") && !strcmp(getvar("et1mdcport"), "1"))
|
||||
return &platforms[WRTSL54GS];
|
||||
|
||||
|
||||
/* default to WRT54G */
|
||||
return &platforms[WRT54G];
|
||||
}
|
||||
|
||||
|
||||
if (!strcmp(boardnum, "45")) { /* ASUS */
|
||||
if (!strcmp(boardtype,"0x042f"))
|
||||
return &platforms[WL500GP];
|
||||
@ -718,7 +720,7 @@ static struct platform_t __init *platform_detect(void)
|
||||
else
|
||||
return &platforms[WL500GD];
|
||||
}
|
||||
|
||||
|
||||
if (!strcmp(boardnum, "10496"))
|
||||
return &platforms[USR5461];
|
||||
|
||||
@ -727,15 +729,15 @@ static struct platform_t __init *platform_detect(void)
|
||||
(simple_strtoul(getvar("et0phyaddr"), NULL, 0) == 30)) {
|
||||
return &platforms[WR850GV1];
|
||||
}
|
||||
if (!strncmp(boardtype, "bcm94710dev", 11)) {
|
||||
if (startswith(boardtype, "bcm94710dev")) {
|
||||
if (!strcmp(boardnum, "42"))
|
||||
return &platforms[WRT54GV1];
|
||||
if (simple_strtoul(boardnum, NULL, 0) == 2)
|
||||
return &platforms[WAP54GV1];
|
||||
}
|
||||
if (!strncmp(getvar("hardware_version"), "WL500-", 6))
|
||||
if (startswith(getvar("hardware_version"), "WL500-"))
|
||||
return &platforms[WL500G];
|
||||
if (!strncmp(getvar("hardware_version"), "WL300-", 6)) {
|
||||
if (startswith(getvar("hardware_version"), "WL300-")) {
|
||||
/* Either WL-300g or WL-HDD, do more extensive checks */
|
||||
if ((simple_strtoul(getvar("et0phyaddr"), NULL, 0) == 0) &&
|
||||
(simple_strtoul(getvar("et1phyaddr"), NULL, 0) == 1))
|
||||
@ -745,23 +747,23 @@ static struct platform_t __init *platform_detect(void)
|
||||
return &platforms[WL300G];
|
||||
}
|
||||
/* Sitecom WL-105b */
|
||||
if (!strncmp(boardnum, "2", 1) && simple_strtoul(getvar("GemtekPmonVer"), NULL, 0) == 1)
|
||||
if (startswith(boardnum, "2") && simple_strtoul(getvar("GemtekPmonVer"), NULL, 0) == 1)
|
||||
return &platforms[WL105B];
|
||||
|
||||
/* unknown asus stuff, probably bcm4702 */
|
||||
if (!strncmp(boardnum, "asusX", 5))
|
||||
if (startswith(boardnum, "asusX"))
|
||||
return &platforms[ASUS_4702];
|
||||
}
|
||||
|
||||
if (buf || !strcmp(boardnum, "00")) {/* probably buffalo */
|
||||
if (!strncmp(boardtype, "bcm94710ap", 10))
|
||||
if (startswith(boardtype, "bcm94710ap"))
|
||||
return &platforms[BUFFALO_UNKNOWN_4710];
|
||||
else
|
||||
return &platforms[BUFFALO_UNKNOWN];
|
||||
}
|
||||
|
||||
if (!strncmp(getvar("CFEver"), "MotoWRv2", 8) ||
|
||||
!strncmp(getvar("CFEver"), "MotoWRv3", 8) ||
|
||||
if (startswith(getvar("CFEver"), "MotoWRv2") ||
|
||||
startswith(getvar("CFEver"), "MotoWRv3") ||
|
||||
!strcmp(getvar("MOTO_BOARD_TYPE"), "WR_FEM1")) {
|
||||
|
||||
return &platforms[WR850GV2V3];
|
||||
@ -771,7 +773,7 @@ static struct platform_t __init *platform_detect(void)
|
||||
return &platforms[TEW411BRPP];
|
||||
}
|
||||
|
||||
if (!strncmp(boardnum, "04FN52", 6)) /* SimpleTech SimpleShare */
|
||||
if (startswith(boardnum, "04FN52")) /* SimpleTech SimpleShare */
|
||||
return &platforms[STI_NAS];
|
||||
|
||||
if (!strcmp(getvar("boardnum"), "10") && !strcmp(getvar("boardrev"), "0x13")) /* D-Link DWL-3150 */
|
||||
@ -945,13 +947,13 @@ static void register_leds(struct led_t *l)
|
||||
u32 val = 0;
|
||||
|
||||
leds = proc_mkdir("led", diag);
|
||||
if (!leds)
|
||||
if (!leds)
|
||||
return;
|
||||
|
||||
for(; l->name; l++) {
|
||||
if (l->gpio & gpiomask)
|
||||
continue;
|
||||
|
||||
|
||||
if (l->gpio & GPIO_TYPE_EXTIF) {
|
||||
l->state = 0;
|
||||
set_led_extif(l);
|
||||
@ -1029,10 +1031,10 @@ static ssize_t diag_proc_read(struct file *file, char *buf, size_t count, loff_t
|
||||
#endif
|
||||
char *page;
|
||||
int len = 0;
|
||||
|
||||
|
||||
if ((page = kmalloc(1024, GFP_KERNEL)) == NULL)
|
||||
return -ENOBUFS;
|
||||
|
||||
|
||||
if (dent->data != NULL) {
|
||||
struct prochandler_t *handler = (struct prochandler_t *) dent->data;
|
||||
switch (handler->type) {
|
||||
@ -1096,14 +1098,14 @@ static ssize_t diag_proc_write(struct file *file, const char *buf, size_t count,
|
||||
return -EINVAL;
|
||||
}
|
||||
page[count] = 0;
|
||||
|
||||
|
||||
if (dent->data != NULL) {
|
||||
struct prochandler_t *handler = (struct prochandler_t *) dent->data;
|
||||
switch (handler->type) {
|
||||
case PROC_LED: {
|
||||
struct led_t *led = (struct led_t *) handler->ptr;
|
||||
int p = (led->polarity == NORMAL ? 0 : 1);
|
||||
|
||||
|
||||
if (page[0] == 'f') {
|
||||
led->flash = 1;
|
||||
led_flash(0);
|
||||
|
Loading…
x
Reference in New Issue
Block a user