1 Index: hostap-driver-0.4.4/driver/modules/hostap_cs.c
2 ===================================================================
3 --- hostap-driver-0.4.4.orig/driver/modules/hostap_cs.c 2005-08-21 20:23:21.000000000 +0100
4 +++ hostap-driver-0.4.4/driver/modules/hostap_cs.c 2005-09-17 17:09:05.000000000 +0100
10 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
11 static void prism2_detach(dev_link_t *link);
13 +static void prism2_detach(struct pcmcia_device *p_dev);
16 static void prism2_release(u_long arg);
17 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
18 static int prism2_event(event_t event, int priority,
19 event_callback_args_t *args);
23 static int prism2_pccard_card_present(local_info_t *local)
29 +static int prism2_config(dev_link_t *link);
31 /* allocate local data and register with CardServices
32 * initialize dev_link structure, but do not configure the card yet */
33 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
34 static dev_link_t *prism2_attach(void)
36 +static int prism2_attach(struct pcmcia_device *p_dev)
40 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
41 client_reg_t client_reg;
45 link = kmalloc(sizeof(dev_link_t), GFP_KERNEL);
47 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
53 memset(link, 0, sizeof(dev_link_t));
55 PDEBUG(DEBUG_HW, "%s: setting Vcc=33 (constant)\n", dev_info);
57 link->conf.IntType = INT_MEMORY_AND_IO;
59 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
60 /* register with CardServices */
61 link->next = dev_list;
71 + link->handle = p_dev;
72 + p_dev->instance = link;
74 + link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
75 + prism2_config(link);
81 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
82 static void prism2_detach(dev_link_t *link)
84 +static void prism2_detach(struct pcmcia_device *p_dev)
87 +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
88 + dev_link_t *link = dev_to_instance(p_dev);
92 PDEBUG(DEBUG_FLOW, "prism2_detach\n");
94 prism2_release((u_long)link);
97 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
99 int res = pcmcia_deregister_client(link->handle);
102 cs_error(link->handle, DeregisterClient, res);
108 /* release net devices */
110 PDEBUG(DEBUG_FLOW, "release - done\n");
113 +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
114 +static int prism2_suspend1(struct pcmcia_device *dev)
116 + dev_link_t *link = dev_to_instance(dev);
117 + struct net_device *ndev = (struct net_device *) link->priv;
119 + PDEBUG(DEBUG_EXTRA, "%s: CS_EVENT_PM_SUSPEND\n", dev_info);
120 + link->state |= DEV_SUSPEND;
123 + if (link->state & DEV_CONFIG) {
125 + netif_stop_queue(ndev);
126 + netif_device_detach(ndev);
128 + prism2_suspend(ndev);
129 + pcmcia_release_configuration(link->handle);
135 +static int prism2_resume1(struct pcmcia_device *dev)
137 + dev_link_t *link = dev_to_instance(dev);
138 + struct net_device *ndev = (struct net_device *) link->priv;
140 + PDEBUG(DEBUG_EXTRA, "%s: CS_EVENT_PM_RESUME\n", dev_info);
142 + link->state &= ~DEV_SUSPEND;
145 + if (link->state & DEV_CONFIG) {
146 + pcmcia_request_configuration(link->handle, &link->conf);
147 + prism2_hw_shutdown(ndev, 1);
148 + prism2_hw_config(ndev, link->open ? 0 : 1);
150 + netif_device_attach(ndev);
151 + netif_start_queue(ndev);
159 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
160 static int prism2_event(event_t event, int priority,
161 event_callback_args_t *args)
170 #if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,67)
171 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,13))
172 @@ -983,11 +1063,20 @@
176 +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15))
177 + .probe = prism2_attach,
178 + .remove = prism2_detach,
179 + .suspend = prism2_suspend1,
180 + .resume = prism2_resume1,
182 .attach = prism2_attach,
183 .detach = prism2_detach,
185 .owner = THIS_MODULE,
186 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,13))
187 +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15))
188 .event = prism2_event,
190 .id_table = hostap_cs_ids,