blob: 5ecf38e355a8e02c77da3ea851336b1e3be382c0 [file] [log] [blame]
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -07001/*
2 * Copyright (c) 2007-2008 Atheros Communications Inc.
3 *
4 * Permission to use, copy, modify, and/or distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
7 *
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15 */
16/* */
17/* Module Name : wrap_pkt.c */
18/* */
19/* Abstract */
20/* This module contains wrapper functions for packet handling */
21/* */
22/* NOTES */
23/* Platform dependent. */
24/* */
25/************************************************************************/
26
27#include "oal_dt.h"
28#include "usbdrv.h"
29
30#include <linux/netlink.h>
Tejun Heo5a0e3ad2010-03-24 17:04:11 +090031#include <linux/gfp.h>
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070032#include <net/iw_handler.h>
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070033
34
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070035/* extern struct zsWdsStruct wds[ZM_WDS_PORT_NUMBER]; */
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070036extern struct zsVapStruct vap[ZM_VAP_PORT_NUMBER];
37
38
39/***** Rx *****/
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070040void zfLnxRecv80211(zdev_t *dev, zbuf_t *buf, struct zsAdditionInfo *addInfo)
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070041{
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070042 u16_t frameType;
43 u16_t frameCtrl;
44 u16_t frameSubtype;
45 zbuf_t *skb1;
46 struct usbdrv_private *macp = dev->ml_priv;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070047
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070048 /* frameCtrl = zmw_buf_readb(dev, buf, 0); */
49 frameCtrl = *(u8_t *)((u8_t *)buf->data);
50 frameType = frameCtrl & 0xf;
51 frameSubtype = frameCtrl & 0xf0;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070052
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070053 if ((frameType == 0x0) && (macp->forwardMgmt)) {
54 switch (frameSubtype) {
55 /* Beacon */
56 case 0x80:
57 /* Probe response */
58 case 0x50:
59 skb1 = skb_copy(buf, GFP_ATOMIC);
60 if (skb1 != NULL) {
61 skb1->dev = dev;
Jeff Mahoney23639122010-01-11 10:54:30 -050062 skb_reset_mac_header(skb1);
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070063 skb1->ip_summed = CHECKSUM_NONE;
64 skb1->pkt_type = PACKET_OTHERHOST;
65 /* ETH_P_80211_RAW */
66 skb1->protocol = __constant_htons(0x0019);
67 netif_rx(skb1);
68 }
69 break;
70 default:
71 break;
72 }
73 }
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070074
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070075 zfiRecv80211(dev, buf, addInfo);
76 return;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070077}
78
79#define ZM_AVOID_UDP_LARGE_PACKET_FAIL
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070080void zfLnxRecvEth(zdev_t *dev, zbuf_t *buf, u16_t port)
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070081{
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070082 struct usbdrv_private *macp = dev->ml_priv;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070083#ifdef ZM_AVOID_UDP_LARGE_PACKET_FAIL
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070084 zbuf_t *new_buf;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070085
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070086 /* new_buf = dev_alloc_skb(2048); */
87 new_buf = dev_alloc_skb(buf->len);
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070088
Jeff Mahoney23639122010-01-11 10:54:30 -050089 skb_reset_tail_pointer(new_buf);
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070090
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070091 skb_put(new_buf, buf->len);
92 memcpy(new_buf->data, buf->data, buf->len);
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070093
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070094 /* Free buffer */
95 dev_kfree_skb_any(buf);
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -070096
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -070097 if (port == 0) {
98 new_buf->dev = dev;
99 new_buf->protocol = eth_type_trans(new_buf, dev);
100 } else {
101 /* VAP */
102 if (vap[0].dev != NULL) {
103 new_buf->dev = vap[0].dev;
104 new_buf->protocol = eth_type_trans(new_buf, vap[0].dev);
105 } else {
106 new_buf->dev = dev;
107 new_buf->protocol = eth_type_trans(new_buf, dev);
108 }
109 }
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700110
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -0700111 new_buf->ip_summed = CHECKSUM_NONE;
112 dev->last_rx = jiffies;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700113
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -0700114 switch (netif_rx(new_buf))
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700115#else
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -0700116 if (port == 0) {
117 buf->dev = dev;
118 buf->protocol = eth_type_trans(buf, dev);
119 } else {
120 /* VAP */
121 if (vap[0].dev != NULL) {
122 buf->dev = vap[0].dev;
123 buf->protocol = eth_type_trans(buf, vap[0].dev);
124 } else {
125 buf->dev = dev;
126 buf->protocol = eth_type_trans(buf, dev);
127 }
128 }
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700129
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -0700130 buf->ip_summed = CHECKSUM_NONE;
131 dev->last_rx = jiffies;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700132
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -0700133 switch (netif_rx(buf))
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700134#endif
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -0700135 {
136 case NET_RX_DROP:
137 break;
138 default:
139 macp->drv_stats.net_stats.rx_packets++;
140 macp->drv_stats.net_stats.rx_bytes += buf->len;
141 break;
142 }
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700143
Mithlesh Thukral2bef7a02009-10-26 21:22:55 -0700144 return;
Luis R. Rodriguez4bd43f52008-10-27 22:44:22 -0700145}
146
147/* Leave an empty line below to remove warning message on some compiler */