mirror of
https://git.yoctoproject.org/poky
synced 2026-02-11 11:13:04 +01:00
git-svn-id: https://svn.o-hand.com/repos/poky/trunk@530 311d38ba-8fff-0310-9ca6-ca027cbcb966
193 lines
4.5 KiB
Diff
193 lines
4.5 KiB
Diff
Index: hostap-driver-0.4.4/driver/modules/hostap_cs.c
|
|
===================================================================
|
|
--- hostap-driver-0.4.4.orig/driver/modules/hostap_cs.c 2005-08-21 20:23:21.000000000 +0100
|
|
+++ hostap-driver-0.4.4/driver/modules/hostap_cs.c 2005-09-17 17:09:05.000000000 +0100
|
|
@@ -207,12 +207,17 @@
|
|
#include "hostap_hw.c"
|
|
|
|
|
|
-
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
static void prism2_detach(dev_link_t *link);
|
|
+#else
|
|
+static void prism2_detach(struct pcmcia_device *p_dev);
|
|
+#endif
|
|
+
|
|
static void prism2_release(u_long arg);
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
static int prism2_event(event_t event, int priority,
|
|
event_callback_args_t *args);
|
|
-
|
|
+#endif
|
|
|
|
static int prism2_pccard_card_present(local_info_t *local)
|
|
{
|
|
@@ -508,25 +513,36 @@
|
|
}
|
|
#endif
|
|
|
|
+static int prism2_config(dev_link_t *link);
|
|
|
|
/* allocate local data and register with CardServices
|
|
* initialize dev_link structure, but do not configure the card yet */
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
static dev_link_t *prism2_attach(void)
|
|
+#else
|
|
+static int prism2_attach(struct pcmcia_device *p_dev)
|
|
+#endif
|
|
{
|
|
dev_link_t *link;
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
client_reg_t client_reg;
|
|
int ret;
|
|
+#endif
|
|
|
|
link = kmalloc(sizeof(dev_link_t), GFP_KERNEL);
|
|
if (link == NULL)
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
return NULL;
|
|
-
|
|
+#else
|
|
+ return -ENOMEM;
|
|
+#endif
|
|
memset(link, 0, sizeof(dev_link_t));
|
|
|
|
PDEBUG(DEBUG_HW, "%s: setting Vcc=33 (constant)\n", dev_info);
|
|
link->conf.Vcc = 33;
|
|
link->conf.IntType = INT_MEMORY_AND_IO;
|
|
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
/* register with CardServices */
|
|
link->next = dev_list;
|
|
dev_list = link;
|
|
@@ -547,12 +563,28 @@
|
|
prism2_detach(link);
|
|
return NULL;
|
|
}
|
|
+
|
|
return link;
|
|
-}
|
|
+#else
|
|
+ link->handle = p_dev;
|
|
+ p_dev->instance = link;
|
|
+
|
|
+ link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
|
+ prism2_config(link);
|
|
|
|
+ return 0;
|
|
+#endif
|
|
+}
|
|
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
static void prism2_detach(dev_link_t *link)
|
|
+#else
|
|
+static void prism2_detach(struct pcmcia_device *p_dev)
|
|
+#endif
|
|
{
|
|
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
|
|
+ dev_link_t *link = dev_to_instance(p_dev);
|
|
+#endif
|
|
dev_link_t **linkp;
|
|
|
|
PDEBUG(DEBUG_FLOW, "prism2_detach\n");
|
|
@@ -570,6 +602,7 @@
|
|
prism2_release((u_long)link);
|
|
}
|
|
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
if (link->handle) {
|
|
int res = pcmcia_deregister_client(link->handle);
|
|
if (res) {
|
|
@@ -577,6 +610,7 @@
|
|
cs_error(link->handle, DeregisterClient, res);
|
|
}
|
|
}
|
|
+#endif
|
|
|
|
*linkp = link->next;
|
|
/* release net devices */
|
|
@@ -855,7 +889,53 @@
|
|
PDEBUG(DEBUG_FLOW, "release - done\n");
|
|
}
|
|
|
|
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
|
|
+static int prism2_suspend1(struct pcmcia_device *dev)
|
|
+{
|
|
+ dev_link_t *link = dev_to_instance(dev);
|
|
+ struct net_device *ndev = (struct net_device *) link->priv;
|
|
+
|
|
+ PDEBUG(DEBUG_EXTRA, "%s: CS_EVENT_PM_SUSPEND\n", dev_info);
|
|
+ link->state |= DEV_SUSPEND;
|
|
+ /* fall through */
|
|
|
|
+ if (link->state & DEV_CONFIG) {
|
|
+ if (link->open) {
|
|
+ netif_stop_queue(ndev);
|
|
+ netif_device_detach(ndev);
|
|
+ }
|
|
+ prism2_suspend(ndev);
|
|
+ pcmcia_release_configuration(link->handle);
|
|
+ }
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
+static int prism2_resume1(struct pcmcia_device *dev)
|
|
+{
|
|
+ dev_link_t *link = dev_to_instance(dev);
|
|
+ struct net_device *ndev = (struct net_device *) link->priv;
|
|
+
|
|
+ PDEBUG(DEBUG_EXTRA, "%s: CS_EVENT_PM_RESUME\n", dev_info);
|
|
+
|
|
+ link->state &= ~DEV_SUSPEND;
|
|
+ /* fall through */
|
|
+
|
|
+ if (link->state & DEV_CONFIG) {
|
|
+ pcmcia_request_configuration(link->handle, &link->conf);
|
|
+ prism2_hw_shutdown(ndev, 1);
|
|
+ prism2_hw_config(ndev, link->open ? 0 : 1);
|
|
+ if (link->open) {
|
|
+ netif_device_attach(ndev);
|
|
+ netif_start_queue(ndev);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+#endif
|
|
+
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
static int prism2_event(event_t event, int priority,
|
|
event_callback_args_t *args)
|
|
{
|
|
@@ -924,7 +1004,7 @@
|
|
}
|
|
return 0;
|
|
}
|
|
-
|
|
+#endif
|
|
|
|
#if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,67)
|
|
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,13))
|
|
@@ -983,11 +1063,20 @@
|
|
.drv = {
|
|
.name = "hostap_cs",
|
|
},
|
|
+#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
|
|
+ .probe = prism2_attach,
|
|
+ .remove = prism2_detach,
|
|
+ .suspend = prism2_suspend1,
|
|
+ .resume = prism2_resume1,
|
|
+#else
|
|
.attach = prism2_attach,
|
|
.detach = prism2_detach,
|
|
+#endif
|
|
.owner = THIS_MODULE,
|
|
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,13))
|
|
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
|
|
.event = prism2_event,
|
|
+#endif
|
|
.id_table = hostap_cs_ids,
|
|
#endif
|
|
};
|