From 128434cb236523f4cec881622b8606cb1533b677 Mon Sep 17 00:00:00 2001 From: nbd Date: Sun, 15 Jun 2008 11:11:28 +0000 Subject: (6/6) bcm57xx: package This is the bcm57xx package. I have tested default vlan functions, but I dont have the equipment to test more advanced setups. The default vlan setup seems to be working fine. I also added the activate_gpio parameter which will make the driver activate the switch via gpio before probing for it. I'm not sure which method is best for autoload. For the wrt350n, I need the activate_gpio parameter. But its probably not a good idea to add that to the autoload file. On a system without a bcm57xx switch, isn't it a bad idea to mess with the gpios looking for the switch? Ideally, wouldn't it be best to load the bcm57xx module from broadcom-diag, after it has determined which router its on? I tried using 'request_module' from there, but had no success. For now, I am relying on preinit to load the bcm57xx module with activate_gpio param, after it has failed to load switch_robo and switch_adm. Signed-off-by: Ben Pfountz git-svn-id: svn://svn.openwrt.org/openwrt/trunk@11471 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- package/broadcom-57xx/src/bcmrobo.h | 70 +++++++++++++++++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 package/broadcom-57xx/src/bcmrobo.h (limited to 'package/broadcom-57xx/src/bcmrobo.h') diff --git a/package/broadcom-57xx/src/bcmrobo.h b/package/broadcom-57xx/src/bcmrobo.h new file mode 100644 index 000000000..ce9659bba --- /dev/null +++ b/package/broadcom-57xx/src/bcmrobo.h @@ -0,0 +1,70 @@ +/* + * RoboSwitch setup functions + * + * Copyright 2007, Broadcom Corporation + * All Rights Reserved. + * + * THIS SOFTWARE IS OFFERED "AS IS", AND BROADCOM GRANTS NO WARRANTIES OF ANY + * KIND, EXPRESS OR IMPLIED, BY STATUTE, COMMUNICATION OR OTHERWISE. BROADCOM + * SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS + * FOR A SPECIFIC PURPOSE OR NONINFRINGEMENT CONCERNING THIS SOFTWARE. + * + * $Id: bcmrobo.h,v 1.1.1.6 2007/05/31 08:00:41 michael Exp $ + */ + +#ifndef _bcm_robo_h_ +#define _bcm_robo_h_ +#include + +#define DEVID5325 0x25 /* 5325 (Not really be we fake it) */ + +/* Forward declaration */ +typedef struct robo_info_s robo_info_t; + +/* Device access/config oprands */ +typedef struct { + /* low level routines */ + void (*enable_mgmtif)(robo_info_t *robo); /* enable mgmt i/f, optional */ + void (*disable_mgmtif)(robo_info_t *robo); /* disable mgmt i/f, optional */ + int (*write_reg)(robo_info_t *robo, uint8 page, uint8 reg, void *val, int len); + int (*read_reg)(robo_info_t *robo, uint8 page, uint8 reg, void *val, int len); + /* description */ + char *desc; +} dev_ops_t; + + +typedef uint16 (*miird_f)(void *h, int add, int off); +typedef void (*miiwr_f)(void *h, int add, int off, uint16 val); + +/* Private state per RoboSwitch */ +struct robo_info_s { + sb_t *sbh; /* SiliconBackplane handle */ + char *vars; /* nvram variables handle */ + void *h; /* dev handle */ + uint16 devid; /* Device id for the switch */ + char *name; /* Linux device name */ + char macaddr[6]; + + dev_ops_t *ops; /* device ops */ + uint8 page; /* current page */ + + /* SPI */ + uint32 ss, sck, mosi, miso; /* GPIO mapping */ + + /* MII */ + miird_f miird; + miiwr_f miiwr; +}; + +extern robo_info_t *bcm_robo_attach(sb_t *sbh, void *h, char *name, char *vars, miird_f miird, miiwr_f miiwr); +extern void bcm_robo_detach(robo_info_t *robo); +extern int bcm_robo_enable_device(robo_info_t *robo); +extern int bcm_robo_config_vlan(robo_info_t *robo, uint8 *mac_addr); +extern int bcm_robo_enable_switch(robo_info_t *robo); +extern void bcm_robo_set_macaddr(robo_info_t *robo, char *macaddr); + +#ifdef BCMDBG +extern void robo_dump_regs(robo_info_t *robo, struct bcmstrbuf *b); +#endif /* BCMDBG */ + +#endif /* _bcm_robo_h_ */ -- cgit v1.2.3