Commit 8d50e0e0 authored by David Gibson's avatar David Gibson Committed by Jeff Garzik

[PATCH] orinoco merge preliminaries - squash backwards compatibility

Remove various bits of code in the orinoco driver for backwards
compatibility with older kernels: old versions of the wireless
extensions, lack of MODULE_LICENSE, older PCMCIA interfaces.
Signed-off-by: default avatarDavid Gibson <hermes@gibson.dropbear.id.au>

Index: working-2.6/drivers/net/wireless/orinoco.c
===================================================================
parent 628505a0
...@@ -54,9 +54,7 @@ ...@@ -54,9 +54,7 @@
MODULE_DESCRIPTION("Low-level driver helper for Lucent Hermes chipset and Prism II HFA384x wireless MAC controller"); MODULE_DESCRIPTION("Low-level driver helper for Lucent Hermes chipset and Prism II HFA384x wireless MAC controller");
MODULE_AUTHOR("David Gibson <hermes@gibson.dropbear.id.au>"); MODULE_AUTHOR("David Gibson <hermes@gibson.dropbear.id.au>");
#ifdef MODULE_LICENSE
MODULE_LICENSE("Dual MPL/GPL"); MODULE_LICENSE("Dual MPL/GPL");
#endif
/* These are maximum timeouts. Most often, card wil react much faster */ /* These are maximum timeouts. Most often, card wil react much faster */
#define CMD_BUSY_TIMEOUT (100) /* In iterations of ~1us */ #define CMD_BUSY_TIMEOUT (100) /* In iterations of ~1us */
......
...@@ -446,9 +446,7 @@ ...@@ -446,9 +446,7 @@
MODULE_AUTHOR("David Gibson <hermes@gibson.dropbear.id.au>"); MODULE_AUTHOR("David Gibson <hermes@gibson.dropbear.id.au>");
MODULE_DESCRIPTION("Driver for Lucent Orinoco, Prism II based and similar wireless cards"); MODULE_DESCRIPTION("Driver for Lucent Orinoco, Prism II based and similar wireless cards");
#ifdef MODULE_LICENSE
MODULE_LICENSE("Dual MPL/GPL"); MODULE_LICENSE("Dual MPL/GPL");
#endif
/* Level of debugging. Used in the macros in orinoco.h */ /* Level of debugging. Used in the macros in orinoco.h */
#ifdef ORINOCO_DEBUG #ifdef ORINOCO_DEBUG
...@@ -464,11 +462,6 @@ MODULE_PARM(suppress_linkstatus, "i"); ...@@ -464,11 +462,6 @@ MODULE_PARM(suppress_linkstatus, "i");
/* Compile time configuration and compatibility stuff */ /* Compile time configuration and compatibility stuff */
/********************************************************************/ /********************************************************************/
/* Wireless extensions backwards compatibility */
#ifndef SIOCIWFIRSTPRIV
#define SIOCIWFIRSTPRIV SIOCDEVPRIVATE
#endif /* SIOCIWFIRSTPRIV */
/* We do this this way to avoid ifdefs in the actual code */ /* We do this this way to avoid ifdefs in the actual code */
#ifdef WIRELESS_SPY #ifdef WIRELESS_SPY
#define SPY_NUMBER(priv) (priv->spy_number) #define SPY_NUMBER(priv) (priv->spy_number)
...@@ -1614,13 +1607,11 @@ static void __orinoco_ev_info(struct net_device *dev, hermes_t *hw) ...@@ -1614,13 +1607,11 @@ static void __orinoco_ev_info(struct net_device *dev, hermes_t *hw)
le16_to_cpu(tallies.RxDiscards_WEPExcluded); le16_to_cpu(tallies.RxDiscards_WEPExcluded);
wstats->discard.misc += wstats->discard.misc +=
le16_to_cpu(tallies.TxDiscardsWrongSA); le16_to_cpu(tallies.TxDiscardsWrongSA);
#if WIRELESS_EXT > 11
wstats->discard.fragment += wstats->discard.fragment +=
le16_to_cpu(tallies.RxMsgInBadMsgFragments); le16_to_cpu(tallies.RxMsgInBadMsgFragments);
wstats->discard.retries += wstats->discard.retries +=
le16_to_cpu(tallies.TxRetryLimitExceeded); le16_to_cpu(tallies.TxRetryLimitExceeded);
/* wstats->miss.beacon - no match */ /* wstats->miss.beacon - no match */
#endif /* WIRELESS_EXT > 11 */
} }
break; break;
case HERMES_INQ_LINKSTATUS: { case HERMES_INQ_LINKSTATUS: {
...@@ -2582,10 +2573,8 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq ...@@ -2582,10 +2573,8 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq
/* Much of this shamelessly taken from wvlan_cs.c. No idea /* Much of this shamelessly taken from wvlan_cs.c. No idea
* what it all means -dgibson */ * what it all means -dgibson */
#if WIRELESS_EXT > 10
range.we_version_compiled = WIRELESS_EXT; range.we_version_compiled = WIRELESS_EXT;
range.we_version_source = 11; range.we_version_source = 11;
#endif /* WIRELESS_EXT > 10 */
range.min_nwid = range.max_nwid = 0; /* We don't use nwids */ range.min_nwid = range.max_nwid = 0; /* We don't use nwids */
...@@ -2612,22 +2601,17 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq ...@@ -2612,22 +2601,17 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq
range.max_qual.qual = 0; range.max_qual.qual = 0;
range.max_qual.level = 0; range.max_qual.level = 0;
range.max_qual.noise = 0; range.max_qual.noise = 0;
#if WIRELESS_EXT > 11
range.avg_qual.qual = 0; range.avg_qual.qual = 0;
range.avg_qual.level = 0; range.avg_qual.level = 0;
range.avg_qual.noise = 0; range.avg_qual.noise = 0;
#endif /* WIRELESS_EXT > 11 */
} else { } else {
range.max_qual.qual = 0x8b - 0x2f; range.max_qual.qual = 0x8b - 0x2f;
range.max_qual.level = 0x2f - 0x95 - 1; range.max_qual.level = 0x2f - 0x95 - 1;
range.max_qual.noise = 0x2f - 0x95 - 1; range.max_qual.noise = 0x2f - 0x95 - 1;
#if WIRELESS_EXT > 11
/* Need to get better values */ /* Need to get better values */
range.avg_qual.qual = 0x24; range.avg_qual.qual = 0x24;
range.avg_qual.level = 0xC2; range.avg_qual.level = 0xC2;
range.avg_qual.noise = 0x9E; range.avg_qual.noise = 0x9E;
#endif /* WIRELESS_EXT > 11 */
} }
err = orinoco_hw_get_bitratelist(priv, &numrates, err = orinoco_hw_get_bitratelist(priv, &numrates,
...@@ -2680,7 +2664,6 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq ...@@ -2680,7 +2664,6 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq
range.txpower[0] = 15; /* 15dBm */ range.txpower[0] = 15; /* 15dBm */
range.txpower_capa = IW_TXPOW_DBM; range.txpower_capa = IW_TXPOW_DBM;
#if WIRELESS_EXT > 10
range.retry_capa = IW_RETRY_LIMIT | IW_RETRY_LIFETIME; range.retry_capa = IW_RETRY_LIMIT | IW_RETRY_LIFETIME;
range.retry_flags = IW_RETRY_LIMIT; range.retry_flags = IW_RETRY_LIMIT;
range.r_time_flags = IW_RETRY_LIFETIME; range.r_time_flags = IW_RETRY_LIFETIME;
...@@ -2688,7 +2671,6 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq ...@@ -2688,7 +2671,6 @@ static int orinoco_ioctl_getiwrange(struct net_device *dev, struct iw_point *rrq
range.max_retry = 65535; /* ??? */ range.max_retry = 65535; /* ??? */
range.min_r_time = 0; range.min_r_time = 0;
range.max_r_time = 65535 * 1000; /* ??? */ range.max_r_time = 65535 * 1000; /* ??? */
#endif /* WIRELESS_EXT > 10 */
if (copy_to_user(rrq->pointer, &range, sizeof(range))) if (copy_to_user(rrq->pointer, &range, sizeof(range)))
return -EFAULT; return -EFAULT;
...@@ -3354,7 +3336,6 @@ static int orinoco_ioctl_getpower(struct net_device *dev, struct iw_param *prq) ...@@ -3354,7 +3336,6 @@ static int orinoco_ioctl_getpower(struct net_device *dev, struct iw_param *prq)
return err; return err;
} }
#if WIRELESS_EXT > 10
static int orinoco_ioctl_getretry(struct net_device *dev, struct iw_param *rrq) static int orinoco_ioctl_getretry(struct net_device *dev, struct iw_param *rrq)
{ {
struct orinoco_private *priv = netdev_priv(dev); struct orinoco_private *priv = netdev_priv(dev);
...@@ -3406,7 +3387,6 @@ static int orinoco_ioctl_getretry(struct net_device *dev, struct iw_param *rrq) ...@@ -3406,7 +3387,6 @@ static int orinoco_ioctl_getretry(struct net_device *dev, struct iw_param *rrq)
return err; return err;
} }
#endif /* WIRELESS_EXT > 10 */
static int orinoco_ioctl_setibssport(struct net_device *dev, struct iwreq *wrq) static int orinoco_ioctl_setibssport(struct net_device *dev, struct iwreq *wrq)
{ {
...@@ -3790,7 +3770,6 @@ orinoco_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) ...@@ -3790,7 +3770,6 @@ orinoco_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
wrq->u.txpower.flags = IW_TXPOW_DBM; wrq->u.txpower.flags = IW_TXPOW_DBM;
break; break;
#if WIRELESS_EXT > 10
case SIOCSIWRETRY: case SIOCSIWRETRY:
err = -EOPNOTSUPP; err = -EOPNOTSUPP;
break; break;
...@@ -3798,7 +3777,6 @@ orinoco_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) ...@@ -3798,7 +3777,6 @@ orinoco_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
case SIOCGIWRETRY: case SIOCGIWRETRY:
err = orinoco_ioctl_getretry(dev, &wrq->u.retry); err = orinoco_ioctl_getretry(dev, &wrq->u.retry);
break; break;
#endif /* WIRELESS_EXT > 10 */
case SIOCSIWSPY: case SIOCSIWSPY:
err = orinoco_ioctl_setspy(dev, &wrq->u.data); err = orinoco_ioctl_setspy(dev, &wrq->u.data);
......
...@@ -14,32 +14,9 @@ ...@@ -14,32 +14,9 @@
#include <linux/version.h> #include <linux/version.h>
#include "hermes.h" #include "hermes.h"
/* Workqueue / task queue backwards compatibility stuff */
#if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,41)
#include <linux/workqueue.h>
#else
#include <linux/tqueue.h>
#define work_struct tq_struct
#define INIT_WORK INIT_TQUEUE
#define schedule_work schedule_task
#endif
/* Interrupt handler backwards compatibility stuff */
#ifndef IRQ_NONE
#define IRQ_NONE
#define IRQ_HANDLED
typedef void irqreturn_t;
#endif
/* To enable debug messages */ /* To enable debug messages */
//#define ORINOCO_DEBUG 3 //#define ORINOCO_DEBUG 3
#if (! defined (WIRELESS_EXT)) || (WIRELESS_EXT < 10)
#error "orinoco driver requires Wireless extensions v10 or later."
#endif /* (! defined (WIRELESS_EXT)) || (WIRELESS_EXT < 10) */
#define WIRELESS_SPY // enable iwspy support #define WIRELESS_SPY // enable iwspy support
#define ORINOCO_MAX_KEY_SIZE 14 #define ORINOCO_MAX_KEY_SIZE 14
......
...@@ -47,9 +47,7 @@ ...@@ -47,9 +47,7 @@
MODULE_AUTHOR("David Gibson <hermes@gibson.dropbear.id.au>"); MODULE_AUTHOR("David Gibson <hermes@gibson.dropbear.id.au>");
MODULE_DESCRIPTION("Driver for PCMCIA Lucent Orinoco, Prism II based and similar wireless cards"); MODULE_DESCRIPTION("Driver for PCMCIA Lucent Orinoco, Prism II based and similar wireless cards");
#ifdef MODULE_LICENSE
MODULE_LICENSE("Dual MPL/GPL"); MODULE_LICENSE("Dual MPL/GPL");
#endif
/* Module parameters */ /* Module parameters */
...@@ -144,15 +142,6 @@ orinoco_cs_hard_reset(struct orinoco_private *priv) ...@@ -144,15 +142,6 @@ orinoco_cs_hard_reset(struct orinoco_private *priv)
/* PCMCIA stuff */ /* PCMCIA stuff */
/********************************************************************/ /********************************************************************/
/* In 2.5 (as of 2.5.69 at least) there is a cs_error exported which
* does this, but it's not in 2.4 so we do our own for now. */
static void
orinoco_cs_error(client_handle_t handle, int func, int ret)
{
error_info_t err = { func, ret };
pcmcia_report_error(handle, &err);
}
/* /*
* This creates an "instance" of the driver, allocating local data * This creates an "instance" of the driver, allocating local data
* structures for one device. The device is registered with Card * structures for one device. The device is registered with Card
...@@ -216,7 +205,7 @@ orinoco_cs_attach(void) ...@@ -216,7 +205,7 @@ orinoco_cs_attach(void)
ret = pcmcia_register_client(&link->handle, &client_reg); ret = pcmcia_register_client(&link->handle, &client_reg);
if (ret != CS_SUCCESS) { if (ret != CS_SUCCESS) {
orinoco_cs_error(link->handle, RegisterClient, ret); cs_error(link->handle, RegisterClient, ret);
orinoco_cs_detach(link); orinoco_cs_detach(link);
return NULL; return NULL;
} }
...@@ -495,7 +484,7 @@ orinoco_cs_config(dev_link_t *link) ...@@ -495,7 +484,7 @@ orinoco_cs_config(dev_link_t *link)
return; return;
cs_failed: cs_failed:
orinoco_cs_error(link->handle, last_fn, last_ret); cs_error(link->handle, last_fn, last_ret);
failed: failed:
orinoco_cs_release(link); orinoco_cs_release(link);
......
...@@ -329,9 +329,7 @@ static struct pci_driver orinoco_plx_driver = { ...@@ -329,9 +329,7 @@ static struct pci_driver orinoco_plx_driver = {
static char version[] __initdata = "orinoco_plx.c 0.13e (Daniel Barlow <dan@telent.net>, David Gibson <hermes@gibson.dropbear.id.au>)"; static char version[] __initdata = "orinoco_plx.c 0.13e (Daniel Barlow <dan@telent.net>, David Gibson <hermes@gibson.dropbear.id.au>)";
MODULE_AUTHOR("Daniel Barlow <dan@telent.net>"); MODULE_AUTHOR("Daniel Barlow <dan@telent.net>");
MODULE_DESCRIPTION("Driver for wireless LAN cards using the PLX9052 PCI bridge"); MODULE_DESCRIPTION("Driver for wireless LAN cards using the PLX9052 PCI bridge");
#ifdef MODULE_LICENSE
MODULE_LICENSE("Dual MPL/GPL"); MODULE_LICENSE("Dual MPL/GPL");
#endif
static int __init orinoco_plx_init(void) static int __init orinoco_plx_init(void)
{ {
......
...@@ -207,9 +207,7 @@ static struct pci_driver orinoco_tmd_driver = { ...@@ -207,9 +207,7 @@ static struct pci_driver orinoco_tmd_driver = {
static char version[] __initdata = "orinoco_tmd.c 0.01 (Joerg Dorchain <joerg@dorchain.net>)"; static char version[] __initdata = "orinoco_tmd.c 0.01 (Joerg Dorchain <joerg@dorchain.net>)";
MODULE_AUTHOR("Joerg Dorchain <joerg@dorchain.net>"); MODULE_AUTHOR("Joerg Dorchain <joerg@dorchain.net>");
MODULE_DESCRIPTION("Driver for wireless LAN cards using the TMD7160 PCI bridge"); MODULE_DESCRIPTION("Driver for wireless LAN cards using the TMD7160 PCI bridge");
#ifdef MODULE_LICENSE
MODULE_LICENSE("Dual MPL/GPL"); MODULE_LICENSE("Dual MPL/GPL");
#endif
static int __init orinoco_tmd_init(void) static int __init orinoco_tmd_init(void)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment