diff options
author | wbx <wbx@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2005-12-25 14:18:55 +0000 |
---|---|---|
committer | wbx <wbx@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2005-12-25 14:18:55 +0000 |
commit | fa8fb4e7c3be746703fee0dd34285f462ba104ec (patch) | |
tree | 38d2e6fe4d6e5dda5d3d514bedd9c2f38ef610ed /openwrt/target/linux/package/switch/src/switch-core.h | |
parent | 4d747a7b6c5cf6f8415131a7e8b33a11c6788d5b (diff) |
first try to integrate nbds great new switch drivers for 2.4/2.6 with full vlan support for Netgear and Linksys routers, robo and adm switch, tada
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@2776 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'openwrt/target/linux/package/switch/src/switch-core.h')
-rw-r--r-- | openwrt/target/linux/package/switch/src/switch-core.h | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/openwrt/target/linux/package/switch/src/switch-core.h b/openwrt/target/linux/package/switch/src/switch-core.h new file mode 100644 index 000000000..c878d4786 --- /dev/null +++ b/openwrt/target/linux/package/switch/src/switch-core.h @@ -0,0 +1,35 @@ +#ifndef __SWITCH_CORE_H +#define __SWITCH_CORE_H + +#include <linux/list.h> +#define SWITCH_MAX_BUFSZ 4096 + +#define SWITCH_MEDIA_AUTO 1 +#define SWITCH_MEDIA_100 2 +#define SWITCH_MEDIA_FD 4 + +typedef int (*switch_handler)(char *buf, int nr); + +typedef struct { + char *name; + switch_handler read, write; +} switch_config; + + +typedef struct { + struct list_head list; + char *name; + int ports; + int vlans; + switch_config *driver_handlers, *port_handlers, *vlan_handlers; + void *data; +} switch_driver; + + +extern int switch_register_driver(switch_driver *driver); +extern void switch_unregister_driver(char *name); +extern int switch_parse_vlan(char *buf); +extern int switch_parse_media(char *buf); +extern int switch_print_media(char *buf, int media); + +#endif |