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
 };