mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-01-22 17:11:06 +02:00
c848213af9
This patch prevents switch-robo.c from attempting robo_probe on a port that is already registered. robo_probe will adjust kernel reference counts if it detects a switch on the port. If this patch wasn't applied, the wrt350n would hang on reboot, waiting for the network driver reference count to reach zero indefinitely. Signed-off-by: Ben Pfountz <netprince (at) vt (dot) edu> git-svn-id: svn://svn.openwrt.org/openwrt/trunk@11469 3c298f89-4303-0410-b956-a3cf2f4a3e73
61 lines
1.3 KiB
C
61 lines
1.3 KiB
C
#ifndef __SWITCH_CORE_H
|
|
#define __SWITCH_CORE_H
|
|
|
|
#include <linux/version.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
|
|
|
|
#ifndef KERNEL_VERSION
|
|
#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))
|
|
#endif
|
|
|
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)
|
|
#define LINUX_2_4
|
|
#endif
|
|
|
|
typedef int (*switch_handler)(void *driver, char *buf, int nr);
|
|
|
|
typedef struct {
|
|
const char *name;
|
|
switch_handler read, write;
|
|
} switch_config;
|
|
|
|
typedef struct {
|
|
struct list_head list;
|
|
const char *name;
|
|
const char *version;
|
|
const char *interface;
|
|
int cpuport;
|
|
int ports;
|
|
int vlans;
|
|
const switch_config *driver_handlers, *port_handlers, *vlan_handlers;
|
|
void *data;
|
|
void *priv;
|
|
} switch_driver;
|
|
|
|
typedef struct {
|
|
u32 port, untag, pvid;
|
|
} switch_vlan_config;
|
|
|
|
|
|
extern int switch_device_registered (char* device);
|
|
extern int switch_register_driver(switch_driver *driver);
|
|
extern void switch_unregister_driver(char *name);
|
|
extern switch_vlan_config *switch_parse_vlan(switch_driver *driver, char *buf);
|
|
extern int switch_parse_media(char *buf);
|
|
extern int switch_print_media(char *buf, int media);
|
|
|
|
static inline char *strdup(const char *str)
|
|
{
|
|
char *new = kmalloc(strlen(str) + 1, GFP_KERNEL);
|
|
strcpy(new, str);
|
|
return new;
|
|
}
|
|
|
|
|
|
#endif
|