2 * Copyright (c) 2010-2011 Atheros Communications Inc.
3 * Copyright (c) 2011 Qualcomm Atheros, Inc.
5 * Permission to use, copy, modify, and/or distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
21 #include <net/netlink.h>
24 __ATH6KL_TM_ATTR_INVALID
= 0,
25 ATH6KL_TM_ATTR_CMD
= 1,
26 ATH6KL_TM_ATTR_DATA
= 2,
29 __ATH6KL_TM_ATTR_AFTER_LAST
,
30 ATH6KL_TM_ATTR_MAX
= __ATH6KL_TM_ATTR_AFTER_LAST
- 1,
34 ATH6KL_TM_CMD_TCMD
= 0,
35 ATH6KL_TM_CMD_RX_REPORT
= 1, /* not used anymore */
38 #define ATH6KL_TM_DATA_MAX_LEN 5000
40 static const struct nla_policy ath6kl_tm_policy
[ATH6KL_TM_ATTR_MAX
+ 1] = {
41 [ATH6KL_TM_ATTR_CMD
] = { .type
= NLA_U32
},
42 [ATH6KL_TM_ATTR_DATA
] = { .type
= NLA_BINARY
,
43 .len
= ATH6KL_TM_DATA_MAX_LEN
},
46 void ath6kl_tm_rx_event(struct ath6kl
*ar
, void *buf
, size_t buf_len
)
50 if (!buf
|| buf_len
== 0)
53 skb
= cfg80211_testmode_alloc_event_skb(ar
->wiphy
, buf_len
, GFP_KERNEL
);
55 ath6kl_warn("failed to allocate testmode rx skb!\n");
58 if (nla_put_u32(skb
, ATH6KL_TM_ATTR_CMD
, ATH6KL_TM_CMD_TCMD
) ||
59 nla_put(skb
, ATH6KL_TM_ATTR_DATA
, buf_len
, buf
))
61 cfg80211_testmode_event(skb
, GFP_KERNEL
);
66 ath6kl_warn("nla_put failed on testmode rx skb!\n");
69 int ath6kl_tm_cmd(struct wiphy
*wiphy
, struct wireless_dev
*wdev
,
72 struct ath6kl
*ar
= wiphy_priv(wiphy
);
73 struct nlattr
*tb
[ATH6KL_TM_ATTR_MAX
+ 1];
77 err
= nla_parse_deprecated(tb
, ATH6KL_TM_ATTR_MAX
, data
, len
,
78 ath6kl_tm_policy
, NULL
);
82 if (!tb
[ATH6KL_TM_ATTR_CMD
])
85 switch (nla_get_u32(tb
[ATH6KL_TM_ATTR_CMD
])) {
86 case ATH6KL_TM_CMD_TCMD
:
87 if (!tb
[ATH6KL_TM_ATTR_DATA
])
90 buf
= nla_data(tb
[ATH6KL_TM_ATTR_DATA
]);
91 buf_len
= nla_len(tb
[ATH6KL_TM_ATTR_DATA
]);
93 ath6kl_wmi_test_cmd(ar
->wmi
, buf
, buf_len
);
97 case ATH6KL_TM_CMD_RX_REPORT
: