summaryrefslogtreecommitdiff
path: root/package/broadcom-wl/patches/003-compat-2.6.35.patch
blob: 564007b800f08f0c074eda3867242a17b767b9f4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
--- a/driver/wl_linux.c
+++ b/driver/wl_linux.c
@@ -2082,8 +2082,12 @@ static void
 _wl_set_multicast_list(struct net_device *dev)
 {
 	wl_info_t *wl;
+#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,34)
 	struct dev_mc_list *mclist;
-	int i;
+#else
+	struct netdev_hw_addr *ha;
+#endif
+	int i = 0;
 
 	if (!dev)
 		return;
@@ -2098,14 +2102,23 @@ _wl_set_multicast_list(struct net_device
 		wl->pub->allmulti = (dev->flags & IFF_ALLMULTI)? TRUE: FALSE;
 
 		/* copy the list of multicasts into our private table */
+#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,34)
 		for (i = 0, mclist = dev->mc_list; mclist && (i < dev->mc_count);
 			i++, mclist = mclist->next) {
+#else
+		netdev_for_each_mc_addr(ha, dev) {
+#endif
 			if (i >= MAXMULTILIST) {
 				wl->pub->allmulti = TRUE;
 				i = 0;
 				break;
 			}
+#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,34)
 			wl->pub->multicast[i] = *((struct ether_addr*) mclist->dmi_addr);
+#else
+			wl->pub->multicast[i] = *((struct ether_addr*) ha->addr);
+			i++;
+#endif
 		}
 		wl->pub->nmulticast = i;
 		wlc_set(wl->wlc, WLC_SET_PROMISC, (dev->flags & IFF_PROMISC));
--- a/driver/linux_osl.c
+++ b/driver/linux_osl.c
@@ -65,7 +65,9 @@ struct osl_info {
 #if defined(CONFIG_PCMCIA) || defined(CONFIG_PCMCIA_MODULE)
 struct pcmcia_dev {
 	dev_link_t link;	/* PCMCIA device pointer */
+#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,34)
 	dev_node_t node;	/* PCMCIA node structure */
+#endif
 	void *base;		/* Mapped attribute memory window */
 	size_t size;		/* Size of window */
 	void *drv;		/* Driver data */