For nest-cam v350 release
Bug: 259322762
diff --git a/artagent/Android.mk b/artagent/Android.mk
new file mode 100755
index 0000000..dc09243
--- /dev/null
+++ b/artagent/Android.mk
@@ -0,0 +1,27 @@
+#-------------------------------------------------
+# Copyright (c) 2012 Qualcomm Atheros, Inc..
+# All Rights Reserved.
+# Qualcomm Atheros Confidential and Proprietary.
+#-------------------------------------------------
+
+LOCAL_PATH := $(call my-dir)
+
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := artagent
+
+LOCAL_C_INCLUDES += $(TARGET_OUT_HEADERS)/libtcmd \
+
+LOCAL_CFLAGS+=
+
+LOCAL_SRC_FILES:= \ artagent.c
+
+LOCAL_LDLIBS += -lpthread -lrt
+
+LOCAL_MODULE_TAGS := optional eng
+
+LOCAL_SHARED_LIBRARIES += libcutils
+LOCAL_SHARED_LIBRARIES += libnl_2
+LOCAL_STATIC_LIBRARIES += libtcmd
+
+include $(BUILD_EXECUTABLE)
diff --git a/artagent/COPYING b/artagent/COPYING
new file mode 100644
index 0000000..77650bc
--- /dev/null
+++ b/artagent/COPYING
@@ -0,0 +1,13 @@
+Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+
+Permission to use, copy, modify, and/or distribute this software for any
+purpose with or without fee is hereby granted, provided that the above
+copyright notice and this permission notice appear in all copies.
+
+THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
diff --git a/artagent/Makefile b/artagent/Makefile
new file mode 100644
index 0000000..8f4e719
--- /dev/null
+++ b/artagent/Makefile
@@ -0,0 +1,23 @@
+CC = gcc
+CFLAGS += -Wall -g
+
+PREFIX ?= /usr
+SBINDIR ?= $(PREFIX)/sbin
+INSTALL ?= install
+
+NLLIBNAME = libnl-1
+LIBTCMD_DIR := ../libtcmd
+
+#LDLIBS += -L/home/mattwagner/ambarella-a5s-sdk/packages/wireless/dist/usr/lib/libnl-3.so -lrt -ltcmd
+override LDLIBS += -lrt -ltcmd $(shell pkg-config --libs $(NLLIBNAME))
+override CFLAGS += $(shell pkg-config --cflags $(NLLIBNAME)) -I$(LIBTCMD_DIR) -L$(LIBTCMD_DIR) -L../../dist/usr/lib/
+
+artagent: artagent.c artagent.h
+ $(MAKE) -C $(LIBTCMD_DIR)
+ $(CC) $(CFLAGS) -o $@ $^ $(LDLIBS)
+
+install: artagent
+ install -m 755 artagent $(DESTDIR)$(SBINDIR)
+
+clean:
+ rm -f artagent
diff --git a/artagent/artagent b/artagent/artagent
new file mode 100755
index 0000000..1a0e2de
--- /dev/null
+++ b/artagent/artagent
Binary files differ
diff --git a/artagent/artagent.c b/artagent/artagent.c
new file mode 100755
index 0000000..ab1ee57
--- /dev/null
+++ b/artagent/artagent.c
@@ -0,0 +1,383 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#include <sys/types.h>
+#include <sys/file.h>
+#include <sys/ioctl.h>
+#include <sys/errno.h>
+#include <sys/socket.h>
+#include <linux/types.h>
+#include <netinet/in.h>
+#include <netinet/tcp.h>
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <getopt.h>
+#include <sys/time.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <signal.h>
+
+#include <time.h>
+#include "artagent.h"
+#include "libtcmd.h"
+
+static int sid, cid, aid;
+static char ar6kifname[32];
+unsigned int readLength = 0;
+unsigned char line[LINE_ARRAY_SIZE];
+int cmdId,cmdLen;
+
+void callback_rx(void *buf, int len)
+{
+ int length, version;
+
+ /* skip cmd id, act */
+ buf += 2 * sizeof(unsigned int);
+ unsigned char *reply = (unsigned char*)buf;
+ length = *(unsigned short *)&(reply[0]);
+ version = (unsigned char)(reply[2]);
+
+ readLength = *(unsigned int *)&(reply[4]);
+ //printf("Version %d rx length %d read Length %d\n",version,length,readLength);
+ memcpy((void*)line, (void*)&(reply[8]),readLength);
+}
+
+static int initInterface(char *ifname)
+{
+ int err = 0;
+ err = tcmd_tx_init(ifname, callback_rx);
+ return err;
+}
+
+static int wmiSend(unsigned char *cmdBuf, unsigned int len, unsigned int totalLen, unsigned char version, bool resp)
+{
+ TC_CMDS tCmd;
+ int err=0;
+
+ memset(&tCmd,0,sizeof(tCmd));
+
+ tCmd.hdr.testCmdId = TC_CMDS_ID;
+ tCmd.hdr.u.parm.length = totalLen;
+ tCmd.hdr.u.parm.version = version;
+ tCmd.hdr.u.parm.bufLen = len; // less than 256
+ memcpy((void*)tCmd.buf, (void*)cmdBuf, len);
+
+ if ((err = tcmd_tx((char*)&tCmd, sizeof(tCmd), resp))) {
+ fprintf(stderr, "tcmd_tx had error: %s!\n", strerror(err));
+ return 0;
+ }
+
+ return 1;
+}
+
+static void cleanup(int sig)
+{
+ if (cid>=0) {
+ close(cid);
+ }
+ if (sid>=0) {
+ close(sid);
+ }
+}
+
+int sock_init(int port)
+{
+ int sockid;
+ struct sockaddr_in myaddr;
+ socklen_t sinsize;
+ int i, res;
+
+ /* Create socket */
+ sockid = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
+ if (sockid == -1) {
+ perror(__FUNCTION__);
+ printf("Create socket to PC failed\n");
+ return -1;
+ }
+
+ i = 1;
+ res = setsockopt(sockid, SOL_SOCKET, SO_REUSEADDR, (char *)&i, sizeof(i));
+ if (res == -1) {
+ close(sockid);
+ return -1;
+ }
+
+ i = 1;
+ res = setsockopt(sockid, IPPROTO_TCP, TCP_NODELAY, (char *)&i, sizeof(i));
+ if (res == -1) {
+ close(sockid);
+ return -1;
+ }
+
+ myaddr.sin_family = AF_INET;
+ myaddr.sin_port = htons(port);
+ myaddr.sin_addr.s_addr = htonl(INADDR_ANY);
+
+ memset(&(myaddr.sin_zero), 0, 8);
+
+ res = bind(sockid, (struct sockaddr *)&myaddr, sizeof(struct sockaddr));
+
+ if (res != 0) {
+ perror(__FUNCTION__);
+ printf("Bind failed\n");
+ close(sockid);
+ return -1;
+ }
+
+ if (listen(sockid, 4) == -1) {
+ perror(__FUNCTION__);
+ printf("Listen failed\n");
+ close(sockid);
+ return -1;
+ }
+
+ printf("Waiting for client to connect...\n");
+
+ sinsize = sizeof(struct sockaddr_in);
+ if ((cid = accept(sockid, (struct sockaddr *)&myaddr, &sinsize)) == -1) {
+ printf("Accept failed\n");
+ close(sockid);
+ return -1;
+ }
+
+ i = 1;
+ res = setsockopt(cid, IPPROTO_TCP, TCP_NODELAY, (char *)&i, sizeof(i));
+ if (res == -1) {
+ printf("cannot set NOdelay for cid\n");
+ close(sockid);
+ return -1;
+ }
+ printf("Client connected!\n");
+
+ return sockid;
+}
+
+int sock_recv(int sockid, unsigned char *buf, int buflen)
+{
+ int recvbytes;
+ recvbytes = recv(sockid, buf, buflen, 0);
+ if (recvbytes == 0) {
+ printf("Connection close!? zero bytes received\n");
+ return -1;
+ } else if (recvbytes > 0) {
+ return recvbytes;
+ }
+ return -1;
+}
+
+int sock_send(int sockid, unsigned char *buf, int bytes)
+{
+ int cnt;
+ unsigned char* bufpos = buf;
+ while (bytes) {
+ cnt = write(sockid, bufpos, bytes);
+
+ if (!cnt) {
+ break;
+ }
+ if (cnt == -1) {
+ if (errno == EINTR) {
+ continue;
+ } else {
+ return -1;
+ }
+ }
+
+ bytes -= cnt;
+ bufpos += cnt;
+ }
+ return (bufpos - buf);
+}
+
+static void print_help(char *pname)
+{
+ printf("An agent program to connect ART host and AR6K device, must be\n");
+ printf("started after AR6K device driver is installed.\n\n");
+ printf("Usage: %s ifname fragsize\n\n", pname);
+ printf(" ifname AR6K interface name\n");
+ printf(" fragsize Fragment size, must be multiple of 4\n\n");
+ printf("Example:\n");
+ printf("%s eth1 80\n\n", pname);
+}
+
+int main (int argc, char **argv)
+{
+ int recvbytes=0,bytesRcvd=0;
+ int chunkLen = 0;
+ unsigned char *bufpos;
+ int reducedARTPacket = 1;
+ int frag_size = 200;
+ //int i=0;
+ int port = ART_PORT;
+ bool resp = false;
+ bool firstpacket = true;
+
+ struct sigaction sa;
+
+ printf("setup signal\n");
+ memset(&sa, 0, sizeof(struct sigaction));
+
+ sa.sa_flags = SA_NOCLDSTOP;
+ sa.sa_handler = cleanup;
+
+ printf("before call sigaction\n");
+ sigaction(SIGTERM, &sa, NULL);
+ sigaction(SIGINT, &sa, NULL);
+ sigaction(SIGHUP, &sa, NULL);
+ sigaction(SIGABRT, &sa, NULL);
+
+ cid = sid = aid = -1;
+ printf("setup ifname\n");
+ memset(ar6kifname, '\0', sizeof(ar6kifname));
+
+ if (argc == 1 ) {
+ print_help(argv[0]);
+ return -1;
+ }
+
+ if (argc > 1 ) {
+ strcpy(ar6kifname, argv[1]);
+ }
+ else {
+ strcpy(ar6kifname, "wlan0");
+ }
+
+ if (argc > 2) {
+ frag_size = atoi(argv[2]);
+ }
+
+ if (argc > 3) {
+ port = atoi(argv[3]);
+ }
+
+ if (port == 0)
+ port = ART_PORT;
+ else if (port < 0 || port >65534) {
+ printf("Invalid port number\n");
+ goto main_exit;
+ }
+
+ //NOTE: issue with bigger size on ath6kl driver..
+ if ( ((frag_size == 0) || ((frag_size % 4) != 0)) || (frag_size > 200) ) {
+ printf("Invalid fragsize, should be multiple of 4 and frag size less than 200\n");
+ goto main_exit;
+ }
+
+ if ( initInterface(ar6kifname) ) {
+ printf("Init interface cfg80211 failed\n");
+ cleanup(0);
+ return -1;
+ }
+
+ printf("open sock\n");
+ sid = sock_init(port);
+ if (sid < 0) {
+ printf("Create socket to ART failed\n");
+ cleanup(0);
+ return -1;
+ }
+
+ if ((recvbytes=sock_recv(cid, line, LINE_ARRAY_SIZE)) < 0) {
+ printf("Cannot nego packet size\n");
+ cleanup(0);
+ return -1;
+ }
+
+ printf("Get nego bytes %d\n", recvbytes);
+
+ if (1 == (*(unsigned int *)line)) {
+ reducedARTPacket = 1;
+ printf("Not supporting reducedARTPacket\n");
+ goto main_exit;
+ }
+ else {
+ reducedARTPacket = 0;
+ }
+
+ sock_send(cid, &(line[0]), 1);
+
+ printf("Ready to loop for art packet reduce %d\n", reducedARTPacket);
+
+ while (1) {
+ //printf("wait for tcp socket\n");
+ if ((recvbytes = sock_recv(cid, line, LINE_ARRAY_SIZE)) < 0) {
+ printf("Cannot recv packet size %d\n", recvbytes);
+ cleanup(0);
+ return -1;
+ }
+
+ bytesRcvd = recvbytes;
+ readLength = 0;
+ resp = false;
+
+ if ( firstpacket == true )
+ {
+ cmdLen = *(unsigned short *)&(line[0]);
+ cmdId = *(unsigned char *)&(line[2]);
+
+ printf("->FW len %d Command %d recvbytes %d\n",cmdLen,cmdId,recvbytes);
+ firstpacket = false;
+ }
+
+ if (!reducedARTPacket) {
+ //printf("Recived bytes from NART %d frag size %d\n",recvbytes,frag_size);
+ bufpos = line;
+
+ while (recvbytes) {
+ if (recvbytes > frag_size) {
+ chunkLen = frag_size;
+ } else {
+ chunkLen = recvbytes;
+ }
+
+ //we have to find out whether we need a resp or not for the last packet..
+ recvbytes-=chunkLen;
+
+ if ( recvbytes <=0 )
+ {
+ resp = true;
+ firstpacket = true; //look for first packet again..
+ }
+
+ //printf("Chunk Len %d total size %d respNeeded %d\n",chunkLen,bytesRcvd,resp);
+ wmiSend(bufpos, chunkLen, bytesRcvd, 1, resp);
+
+ bufpos+=chunkLen;
+ }
+ }
+
+ //line and readLength is populated in the callback
+ if ((REG_WRITE_CMD_ID != line[0]) && (MEM_WRITE_CMD_ID != line[0]) &&
+ (M_PCI_WRITE_CMD_ID != line[0]) && (M_PLL_PROGRAM_CMD_ID != line[0]) &&
+ (M_CREATE_DESC_CMD_ID != line[0])) {
+ printf("<- N/ART len %d Command %d status %d\n", readLength,(int)line[0],(int)line[4]);
+ sock_send(cid, line, readLength);
+ } else {
+ printf("<- N/ART ACK Command %d\n", (int)line[0]);
+ sock_send(cid, &(line[0]), 1);
+ }
+ }
+
+
+main_exit:
+ printf("Normal exit\n");
+ cleanup(0);
+ return 0;
+}
diff --git a/artagent/artagent.h b/artagent/artagent.h
new file mode 100755
index 0000000..0aa3227
--- /dev/null
+++ b/artagent/artagent.h
@@ -0,0 +1,237 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#ifndef _ARTAGENT_H_
+#define _ARTAGENT_H_
+
+/* ATHENV */
+#define ART_PORT 5454
+//#define ART_PORT 33120
+/* ATHENV */
+#define LINE_ARRAY_SIZE 4096
+#define SEND_ENDPOINT 0
+#define HTC_RAW_WRITE_MAX_LEN (16 * 5) // 96, 112
+#define TC_CMDS_SIZE_MAX 255
+
+#ifndef POSTPACK
+#ifdef __GNUC__
+#define POSTPACK __attribute__ ((packed))
+#else
+#define POSTPACK
+#endif
+#endif
+
+#ifndef PREPACK
+#ifdef __GNUC__
+#define PREPACK
+#else
+#define PREPACK
+#endif
+#endif
+
+typedef enum {
+ TCMD_CONT_TX_ID,
+ TCMD_CONT_RX_ID,
+ TCMD_PM_ID,
+ TC_CMDS_ID,
+ TCMD_SET_REG_ID,
+
+ INVALID_CMD_ID=255,
+} TCMD_ID;
+
+typedef enum {
+ TCMD_CONT_RX_PROMIS =0,
+ TCMD_CONT_RX_FILTER,
+ TCMD_CONT_RX_REPORT,
+ TCMD_CONT_RX_SETMAC,
+ TCMD_CONT_RX_SET_ANT_SWITCH_TABLE,
+
+ TC_CMD_RESP,
+} TCMD_CONT_RX_ACT;
+
+typedef struct cmdReply {
+ unsigned int replyCmdLen;
+ unsigned int replyCmdId; // command ID of command to which this is a reply
+ unsigned int status; // status of the command
+ unsigned char cmdBytes[4000]; // bytes of the command reply
+} CMD_REPLY;
+
+typedef PREPACK struct {
+ unsigned int testCmdId;
+ unsigned int act;
+ PREPACK union {
+ unsigned int enANI; // to be identical to CONT_RX struct
+ struct PREPACK {
+ unsigned short length;
+ unsigned char version;
+ unsigned char bufLen;
+ } POSTPACK parm;
+ } POSTPACK u;
+} POSTPACK TC_CMDS_HDR;
+
+typedef PREPACK struct {
+ TC_CMDS_HDR hdr;
+ unsigned char buf[TC_CMDS_SIZE_MAX+1];
+} POSTPACK TC_CMDS;
+
+
+enum COMMAND_IDS {
+ INIT_F2_CMD_ID, //0
+ SELECT_HW_CMD_ID, //1
+ MEM_WRITE_CMD_ID, //2
+ MEM_READ_CMD_ID, //3
+ REG_READ_CMD_ID, //4
+ REG_WRITE_CMD_ID, //5
+ CFG_READ_CMD_ID, //6
+ CFG_WRITE_CMD_ID, //7
+ MEM_ALLOC_CMD_ID, //8
+ MEM_FREE_CMD_ID, //9
+ MEM_WRITE_BLOCK_CMD_ID, //10
+ MEM_READ_BLOCK_CMD_ID, //11
+ REMAP_HW_CMD_ID, //12
+ CREATE_EVENT_CMD_ID, //13
+ ANY_EVENTS_CMD_ID, //14
+ GET_EVENT_CMD_ID, //15
+ DISCONNECT_PIPE_CMD_ID, //16
+ CLOSE_PIPE_CMD_ID, //17
+ ISR_FEATURE_ENABLE_CMD_ID, //18
+ ISR_GET_RX_STATS_CMD_ID, //19
+ ISR_GET_TX_STATS_CMD_ID, //20
+ ISR_SINGLE_RX_STAT_CMD_ID, //21
+ ISR_SINGLE_TX_STAT_CMD_ID, //22
+ WAIT_ON_EVENT_CMD_ID, //23
+ WAIT_ON_TIME_CMD_ID, //24
+ ISR_FEATURE_DISABLE_CMD_ID, //25
+ M_EEPROM_READ_CMD_ID, //26
+ M_EEPROM_WRITE_CMD_ID, //27
+ M_EEPROM_READ_BLOCK_CMD_ID, //28
+ M_EEPROM_WRITE_BLOCK_CMD_ID, //29
+ M_RESET_DEVICE_CMD_ID, //30
+ M_GENERIC_CMD_ID, //31
+ M_CHECK_REGS_CMD_ID, //31
+ M_CHANGE_CHANNEL_CMD_ID, //33
+ M_CHECK_PROM_CMD_ID, //34
+ M_REREAD_PROM_CMD_ID, //35
+ M_TX_DATA_SETUP_CMD_ID, //36
+ M_TX_DATA_BEGIN_CMD_ID, //37
+ M_TX_DATA_START_CMD_ID, //38
+ M_TX_DATA_COMPLETE_CMD_ID, //39
+ M_RX_DATA_SETUP_CMD_ID, //40
+ M_RX_DATA_BEGIN_CMD_ID, //41
+ M_RX_DATA_START_CMD_ID, //42
+ M_RX_DATA_COMPLETE_CMD_ID, //43
+ M_RX_STATS_SNAPSHOT_CMD_ID, //44
+ M_TXRX_DATA_BEGIN_CMD_ID, //45
+ M_CLEANUP_TXRX_MEMORY_CMD_ID, //46
+ M_TX_GET_STATS_CMD_ID, //47
+ M_RX_GET_STATS_CMD_ID, //48
+ M_RX_GET_DATA_CMD_ID, //49
+ M_TX_CONT_BEGIN_CMD_ID, //50
+ M_TX_CONT_FRAME_BEGIN_CMD_ID, //51
+ M_TX_CONT_END_CMD_ID, //52
+ M_SET_ANTENNA_CMD_ID, //53
+ M_SET_POWER_SCALE_CMD_ID, //54
+ M_SET_TRANSMIT_POWER_CMD_ID, //55
+ M_SET_SINGLE_TRANSMIT_POWER_CMD_ID, //56
+ M_DEV_SLEEP_CMD_ID, //57
+ M_CLOSE_DEVICE_CMD_ID, //58
+ M_CHANGE_FIELD_CMD_ID, //59
+ M_ENABLE_WEP_CMD_ID, //60
+ M_ENABLE_PA_PRE_DIST_CMD_ID, //61
+ M_DUMP_REGS_CMD_ID, //62
+ M_DUMP_PCI_WRITES_CMD_ID, //63
+ M_TEST_LIB_CMD_ID, //64
+ M_DISPLAY_FIELD_VALUES_CMD_ID, //65
+ M_GET_FIELD_VALUE_CMD_ID, //66
+ M_READ_FIELD_CMD_ID, //67
+ M_WRITE_FIELD_CMD_ID, //68
+ M_SET_RESET_PARAMS_CMD_ID, //69
+ M_CHANGE_MULTIPLE_FIELDS_ALL_MODES_CMD_ID, //70
+ M_CHANGE_MULTIPLE_FIELDS_CMD_ID, //71
+ M_GET_FIELD_FOR_MODE_CMD_ID, //72
+ LOAD_AND_RUN_CODE_CMD_ID, //73
+ M_FORCE_SINGLE_PCDAC_TABLE_CMD_ID, //74
+ M_FORCE_PCDAC_TABLE_CMD_ID, //75
+ M_FORCE_POWER_TX_MAX_CMD_ID, //76
+ M_GET_EEPROM_STRUCT_CMD_ID, //77
+ M_GET_DEVICE_INFO_CMD_ID, //78
+ M_WRITE_PROD_DATA_CMD_ID, //79
+ M_WRITE_NEW_PROD_DATA_CMD_ID, //80
+ M_SPECIFY_SUBSYSTEM_CMD_ID, //81
+ M_FORCE_SINGLE_POWER_TX_MAX_CMD_ID, //82
+ M_SET_QUEUE_CMD_ID, //83
+ M_MAP_QUEUE_CMD_ID, //84
+ M_CLEAR_KEY_CACHE_CMD_ID, //85
+ RUN_SCREENING_TEST_CMD_ID, //86
+ DIAG_CMD, //87
+ ENABLE_HW_CAL_CMD, //88
+ TRAM_WRITE_BLOCK_CMD_ID, //89
+ TRAM_READ_BLOCK_CMD_ID, //90
+ M_GET_MAX_POWER_CMD_ID, //91
+ M_GET_PCDAC_FOR_POWER_CMD_ID, //92
+ M_FALSE_DETECT_BACKOFF_VALS_CMD_ID, //93
+ M_GET_MAC_ADDR_CMD_ID, //94
+ M_MASK_TRIGGER_SWEEP_CMD_ID, //95
+ M_MASK_DETECT_SIGNAL_CMD_ID, //96
+ M_MASK_SET_DEV_NUMS_CMD_ID, //97
+ M_MASK_FORCE_MIN_CCAPWR_CMD_ID, //98
+ M_MASK_CONFIG_CAPTURE_CMD_ID, //99
+ AP_REG_READ_CMD_ID, //100
+ AP_REG_WRITE_CMD_ID, //101
+ M_SET_LIB_CONFIG_CMD_ID, //102
+ M_GET_XPDGAIN_CMD_ID, //103
+ M_SELECT_DEV_NUM_CMD_ID, //104
+ M_GET_POWER_INDEX_CMD_ID, //105
+ M_GET_ART_ANI_LEVEL_CMD_ID, //106
+ M_SET_ART_ANI_LEVEL_CMD_ID, //107
+ M_FTP_DOWNLOAD_FILE_CMD_ID, //108
+ M_GET_CTL_INFO_CMD_ID, //109
+ M_GET_MAX_LIN_PWR_CMD_ID, //110
+ M_HW_RESET_CMD_ID, //111
+ M_PLL_PROGRAM_CMD_ID, //112
+ M_PCI_WRITE_CMD_ID, //113
+ M_CAL_CHECK_CMD_ID, //114
+ M_FILL_TX_STATS_CMD_ID, //115
+ M_CREATE_DESC_CMD_ID, //116
+ LOAD_AND_PROGRAM_CODE_CMD_ID, //117
+ M_FORCE_SINGLE_PCDAC_TABLE_GRIFFIN_CMD_ID, //118
+ PHS_CHANNEL_TOGGLE_CMD_ID, //119
+ STOP_PHS_CHANNEL_TOGGLE_CMD_ID, //120
+ GENERIC_FN_CALL_CMD_ID, //121
+ SEND_FRAME_CMD_ID, // 122
+ RECV_FRAME_CMD_ID, // 123
+ M_EEPROM_READ_LOCS_CMD_ID, //124
+ GET_REF_CLK_SPEED_CMD_ID, //125
+ SLEEP_CMD_ID, //126
+
+ ART_IMAGE_DOWNLOAD_ID, //127
+ ART_TEST_UITRON, //128
+ ART_TEST_CLIENT, //129
+
+ ART_CLIENT_REWIND_ID, //130
+ ART_THROUGHPUT_TEST_CMD_ID, //131
+ ART_THROUGHPUT_TEST_CMD_ID_1, //132
+
+ ART_BMI_WRITE_SOC_REGISTER_ID, //133
+ ART_BMI_WRITE_SOC_MEMORY_ID, //134
+ ART_BMI_OP_DONE_ID, //135
+ ART_BMI_READ_SOC_REGISTER_ID, //136
+ ART_BMI_READ_SOC_TARGET_ID //137
+
+};
+
+
+#endif /* _ARTAGENT_H_ */
diff --git a/ath6kl-tcmd/.gitignore b/ath6kl-tcmd/.gitignore
new file mode 100644
index 0000000..1a72503
--- /dev/null
+++ b/ath6kl-tcmd/.gitignore
@@ -0,0 +1,2 @@
+/athtestcmd
+*~
diff --git a/ath6kl-tcmd/Android.mk b/ath6kl-tcmd/Android.mk
new file mode 100755
index 0000000..214f4ba
--- /dev/null
+++ b/ath6kl-tcmd/Android.mk
@@ -0,0 +1,52 @@
+#-------------------------------------------------
+# Copyright (c) 2012 Qualcomm Atheros, Inc..
+# All Rights Reserved.
+# Qualcomm Atheros Confidential and Proprietary.
+#-------------------------------------------------
+
+LOCAL_PATH := $(call my-dir)
+
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := athtestcmd
+
+LOCAL_C_INCLUDES += $(TARGET_OUT_HEADERS)/libtcmd \
+
+LOCAL_CFLAGS+=
+
+LOCAL_SRC_FILES:= \
+ athtestcmd.c \
+ sinit_common.c
+
+LOCAL_LDLIBS += -lpthread -lrt
+
+LOCAL_MODULE_TAGS := optional eng
+
+LOCAL_SHARED_LIBRARIES += libcutils
+LOCAL_SHARED_LIBRARIES += libnl_2
+LOCAL_STATIC_LIBRARIES += libtcmd
+
+include $(BUILD_EXECUTABLE)
+
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := psatUtil
+
+LOCAL_C_INCLUDES += $(TARGET_OUT_HEADERS)/libtcmd \
+
+LOCAL_CFLAGS+=
+
+LOCAL_SRC_FILES:= \
+ psatUtil.c \
+ sinit_common.c
+
+LOCAL_LDLIBS += -lpthread -lrt
+
+LOCAL_MODULE_TAGS := optional eng
+
+LOCAL_SHARED_LIBRARIES += libcutils
+LOCAL_SHARED_LIBRARIES += libnl_2
+LOCAL_STATIC_LIBRARIES += libtcmd
+
+include $(BUILD_EXECUTABLE)
+
diff --git a/ath6kl-tcmd/COPYING b/ath6kl-tcmd/COPYING
new file mode 100644
index 0000000..77650bc
--- /dev/null
+++ b/ath6kl-tcmd/COPYING
@@ -0,0 +1,13 @@
+Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+
+Permission to use, copy, modify, and/or distribute this software for any
+purpose with or without fee is hereby granted, provided that the above
+copyright notice and this permission notice appear in all copies.
+
+THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
diff --git a/ath6kl-tcmd/Makefile b/ath6kl-tcmd/Makefile
new file mode 100644
index 0000000..00d99fc
--- /dev/null
+++ b/ath6kl-tcmd/Makefile
@@ -0,0 +1,31 @@
+CC = gcc
+CFLAGS = -Wall -g
+
+NLLIBNAME = libnl-1
+LIBTCMD_DIR := ../libtcmd
+
+PREFIX ?= /usr
+SBINDIR ?= $(PREFIX)/sbin
+INSTALL ?= install
+
+override LDLIBS += $(shell pkg-config --libs $(NLLIBNAME)) -lrt -ltcmd -lm
+override CFLAGS += $(shell pkg-config --cflags $(NLLIBNAME)) -I$(LIBTCMD_DIR) -L$(LIBTCMD_DIR)
+
+all:
+ $(MAKE) athtestcmd
+ $(MAKE) psatUtil
+
+athtestcmd: athtestcmd.c athtestcmd.h testcmd.h sinit_common.h sinit_common.c sinit_eep.h
+ $(MAKE) -C $(LIBTCMD_DIR)
+ $(CC) $(CFLAGS) -o $@ $^ $(LDLIBS)
+
+psatUtil: psatUtil.c athtestcmd.h testcmd.h sinit_common.h sinit_common.c
+ $(CC) $(CFLAGS) -o $@ $^ $(LDLIBS)
+
+install: psatUtil athtestcmd
+ install -m 755 psatUtil $(DESTDIR)$(SBINDIR)
+ install -m 755 athtestcmd $(DESTDIR)$(SBINDIR)
+
+clean:
+ rm -f athtestcmd
+ rm -f psatUtil
diff --git a/ath6kl-tcmd/athtestcmd.c b/ath6kl-tcmd/athtestcmd.c
new file mode 100644
index 0000000..ecd6bc4
--- /dev/null
+++ b/ath6kl-tcmd/athtestcmd.c
@@ -0,0 +1,1557 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#include <sys/types.h>
+#include <sys/file.h>
+#include <sys/ioctl.h>
+#include <sys/socket.h>
+#include <linux/types.h>
+#include <net/if.h>
+
+#include <errno.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <getopt.h>
+#include <stdint.h>
+#include <stdbool.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <assert.h>
+#include <ctype.h>
+#include <math.h>
+#include <time.h>
+
+#include "athtestcmd.h"
+#include "libtcmd.h"
+#include "testcmd.h"
+#include "sinit_eep.h"
+#include "sinit_common.h"
+
+const char *progname;
+const char commands[] = "commands:\n"
+ "--tx <sine/frame/tx99/tx100/off>\n"
+ "--txfreq <Tx channel or freq(default 2412)>\n"
+ "--txrate <rate index>\n"
+ "--txpwr <frame/tx99/tx100: 0-30dBm,0.5dBm resolution; sine: 0-60, PCDAC vaule>\n"
+ "--txantenna <1/2/0 (auto)>\n"
+ "--txpktsz <pkt size, [32-1500](default 1500)>\n"
+ "--txpattern <tx data pattern, 0: all zeros; 1: all ones;"
+ " 2: repeating 10; 3: PN7; 4: PN9; 5: PN15\n"
+ "--ani (Enable ANI. The ANI is disabled if this option is not specified)\n"
+ "--scrambleroff (Disable scrambler. The scrambler is enabled by default)\n"
+ "--aifsn <AIFS slots num,[0-252](Used only under '--tx frame' mode)>\n"
+ "--shortguard (use short guard)\n"
+ "--mode <ht40plus/ht40minus/ht20>\n"
+ "--setlongpreamble <1/0>\n"
+ "--numpackets <number of packets to send 0-65535>\n"
+ "--tx sine --txfreq <Tx channel or freq(default 2412)>\n"
+ "--rx <promis/filter/report>\n"
+ "--rxfreq <Rx channel or freq(default 2412)>\n"
+ "--rxantenna <1/2/0 (auto)>\n"
+ "--mode <ht40plus/ht40minus>\n"
+ "--pm <wakeup/sleep/deepsleep>\n"
+ "--setmac <mac addr like 00:03:7f:be:ef:11>\n"
+ "--getmac\n"
+ "--SetAntSwitchTable <table1 in decimal value>"
+ " <table2 in decimal value> (Set table1=0 and table2=0 will"
+ " restore the default AntSwitchTable)\n"
+ "--efusedump --start <start address> --end <end address>\n"
+ "--efusewrite --start <start address> --data <data> (could be one or multiple data in quotation marks)\n"
+ "--otpwrite --data (could be one or multiple data in quotation marks)\n"
+ "--otpdump\n";
+
+#define A_ERR(ret, args...) printf(args); exit(ret);
+
+#define A_FREQ_MIN 4920
+#define A_FREQ_MAX 5825
+
+#define A_CHAN0_FREQ 5000
+#define A_CHAN_MAX ((A_FREQ_MAX - A_CHAN0_FREQ)/5)
+
+#define BG_FREQ_MIN 2412
+#define BG_FREQ_MAX 2484
+
+#define BG_CHAN0_FREQ 2407
+#define BG_CHAN_MIN ((BG_FREQ_MIN - BG_CHAN0_FREQ)/5)
+#define BG_CHAN_MAX 14 /* corresponding to 2484 MHz */
+
+#define A_20MHZ_BAND_FREQ_MAX 5000
+
+#define INVALID_FREQ 0
+#define A_OK 0
+
+#define ATH6KL_INTERFACE "wlan0"
+
+#define A_RATE_NUM 28
+#define G_RATE_NUM 28
+
+#define RATE_STR_LEN 20
+#define VENUS_OTP_SIZE 512
+typedef const char RATE_STR[RATE_STR_LEN];
+
+const RATE_STR bgRateStrTbl[G_RATE_NUM] = {
+ {"1 Mb"},
+ {"2 Mb"},
+ {"5.5 Mb"},
+ {"11 Mb"},
+ {"6 Mb"},
+ {"9 Mb"},
+ {"12 Mb"},
+ {"18 Mb"},
+ {"24 Mb"},
+ {"36 Mb"},
+ {"48 Mb"},
+ {"54 Mb"},
+ {"HT20 MCS0 6.5 Mb"},
+ {"HT20 MCS1 13 Mb"},
+ {"HT20 MCS2 19.5 Mb"},
+ {"HT20 MCS3 26 Mb"},
+ {"HT20 MCS4 39 Mb"},
+ {"HT20 MCS5 52 Mb"},
+ {"HT20 MCS6 58.5 Mb"},
+ {"HT20 MCS7 65 Mb"},
+ {"HT40 MCS0 13.5 Mb"},
+ {"HT40 MCS1 27.0 Mb"},
+ {"HT40 MCS2 40.5 Mb"},
+ {"HT40 MCS3 54 Mb"},
+ {"HT40 MCS4 81 Mb"},
+ {"HT40 MCS5 108 Mb"},
+ {"HT40 MCS6 121.5 Mb"},
+ {"HT40 MCS7 135 Mb"}
+};
+#if !defined(_printf)
+#define _printf printf
+#endif
+
+#define _NAME_MAX 256
+#define _LABEL_MAX 16
+
+typedef struct _calSetup {
+ double attenDUT2PM_5G;
+ double attenDUT2PM_2G;
+ char testflowBinFilename[_NAME_MAX];
+ char goldenBinFilename[_NAME_MAX];
+ char outputBinFilename[_NAME_MAX];
+ char label[_LABEL_MAX];
+} _CAL_SETUP;
+_CAL_SETUP calSetup = {
+ 19.0,
+ 18.0,
+ "calTestFlow.bin",
+#ifdef ANDROID
+ "/system/etc/firmware/ath6k/AR6003/hw2.1.1/bdata.bin",
+#else
+ "/lib/firmware/ath6k/AR6003/hw2.1.1/bdata.bin",
+#endif
+#ifdef ANDROID
+ "/persist/bdata.bin",
+#else
+ "new_bdata.bin",
+#endif
+ "wbgf10_010_d0001",
+};
+
+uint32_t AR6003_EEPROM_SIZE;
+uint32_t AR6K_EEPROM_SIZE;
+static bool bCalResult;
+#define FIRST_WAIT_INTERVAL 2
+#define POLLING_INTERVAL 1
+#define MAX_WAIT_CYCLE 20
+
+static time_t startTime, endTime;
+static void rxReport(void *buf);
+static void rx_cb(void *buf, int len);
+static uint32_t freqValid(uint32_t val);
+static uint16_t wmic_ieee2freq(uint32_t chan);
+static void prtRateTbl(uint32_t freq);
+static uint32_t rateValid(uint32_t val, uint32_t freq);
+static uint32_t antValid(uint32_t val);
+static bool txPwrValid(TCMD_CONT_TX * txCmd);
+static int ath_ether_aton(const char *orig, uint8_t * eth);
+static uint32_t pktSzValid(uint32_t val);
+static void updateCALData(_CAL_SETUP *pCalSetup, TC_MSG *pTCMsg);
+static bool dumpPSATCharResult2File(TC_MSG *pTCMsg);
+
+static bool isHex(char c) {
+ return (((c >= '0') && (c <= '9')) ||
+ ((c >= 'A') && (c <= 'F')) ||
+ ((c >= 'a') && (c <= 'f')));
+}
+
+static int usage(void)
+{
+ fprintf(stderr, "usage:\n%s [-i device] commands\n", progname);
+ fprintf(stderr, "%s\n", commands);
+ prtRateTbl(INVALID_FREQ);
+ A_ERR(-1, "Incorrect usage");
+}
+
+unsigned int cmd = 0;
+unsigned int act = 0;
+uint16_t data_length = 0;
+uint16_t efuse_begin = 0, efuse_end = (VENUS_OTP_SIZE - 1);
+static TC_CMDS sTcCmds;
+
+int main(int argc, char **argv)
+{
+ int c, err,i;
+ char ifname[IFNAMSIZ];
+ progname = argv[0];
+ char buf[2048];
+ bool resp = false;
+ TCMD_CONT_TX *txCmd = (TCMD_CONT_TX *) buf;
+ TCMD_CONT_RX *rxCmd = (TCMD_CONT_RX *) buf;
+ TCMD_PM *pmCmd = (TCMD_PM *) buf;
+ TCMD_SET_REG *setRegCmd = (TCMD_SET_REG *)buf;
+ TC_CMDS *tCmds = (TC_CMDS *)buf;
+ char efuseBuf[VENUS_OTP_SIZE];
+ char efuseWriteBuf[VENUS_OTP_SIZE];
+ int bufferLength = sizeof(*txCmd);
+
+ txCmd->numPackets = 0;
+ txCmd->wlanMode = TCMD_WLAN_MODE_NOHT;
+ txCmd->tpcm = TPC_TX_PWR;
+ rxCmd->u.para.wlanMode = TCMD_WLAN_MODE_NOHT;
+ rxCmd->u.para.freq = 2412;
+
+ if (argc == 1) {
+ usage();
+ }
+
+ /* Log The Start time */
+ startTime = time(NULL);
+
+ while (1) {
+ int option_index = 0;
+
+ static struct option long_options[] = {
+ {"version", 0, NULL, 'v'},
+ {"interface", 1, NULL, 'i'},
+ {"tx", 1, NULL, 't'},
+ {"txfreq", 1, NULL, 'f'},
+ {"txrate", 1, NULL, 'g'},
+ {"txpwr", 1, NULL, 'h'},
+ {"tgtpwr", 0, NULL, 'H'},
+ {"pcdac", 1, NULL, 'I'},
+ {"txantenna", 1, NULL, 'j'},
+ {"txpktsz", 1, NULL, 'z'},
+ {"txpattern", 1, NULL, 'e'},
+ {"rx", 1, NULL, 'r'},
+ {"rxfreq", 1, NULL, 'p'},
+ {"rxantenna", 1, NULL, 'q'},
+ {"pm", 1, NULL, 'x'},
+ {"setmac", 1, NULL, 's'},
+ {"getmac", 0, NULL, 'C'},
+ {"ani", 0, NULL, 'a'},
+ {"scrambleroff", 0, NULL, 'o'},
+ {"aifsn", 1, NULL, 'u'},
+ {"SetAntSwitchTable", 1, NULL, 'S'},
+ {"shortguard", 0, NULL, 'G'},
+ {"numpackets", 1, NULL, 'n'},
+ {"mode", 1, NULL, 'M'},
+ {"setlongpreamble", 1, NULL, 'l'},
+ {"setreg", 1, NULL, 'R'},
+ {"regval", 1, NULL, 'V'},
+ {"flag", 1, NULL, 'F'},
+ {"writeotp", 0, NULL, 'w'},
+ {"otpregdmn", 1, NULL, 'E'},
+ {"efusedump", 0, NULL, 'm'},
+ {"efusewrite", 0, NULL, 'W'},
+ {"start", 1, NULL, 'A'},
+ {"end", 1, NULL, 'L'},
+ {"data", 1, NULL, 'U'},
+ {"otpwrite", 0, NULL, 'O'},
+ {"otpdump", 0, NULL, 'P'},
+ {"btaddr", 1, NULL, 'B'},
+ {"therm", 0, NULL, 'c'},
+ {"selfInit", 0, NULL, TCMD_PSAT_CAL},
+ {"selfInit_result", 0, NULL, TCMD_PSAT_CAL_RESULT},
+ {"psat_char", 1, NULL, TCMD_CHAR_PSAT},
+ {"psat_char_result", 0, NULL, TCMD_CHAR_PSAT_RESULT},
+ {"sinit", 0, NULL, TCMD_SINIT_WAIT},
+ {0, 0, 0, 0}
+ };
+
+ c = getopt_long(argc, argv, "vi:t:f:g:h:HI:r:p:q:x:u:ao:M:A:L:mU:WOP",
+ long_options, &option_index);
+
+ if (c == -1)
+ break;
+
+ switch (c) {
+ case 'i':
+ memset(ifname, '\0', 8);
+ strcpy(ifname, optarg);
+ break;
+ case 't':
+ cmd = TESTMODE_CONT_TX;
+ txCmd->testCmdId = TCMD_CONT_TX_ID;
+ if (!strcmp(optarg, "sine")) {
+ txCmd->mode = TCMD_CONT_TX_SINE;
+ } else if (!strcmp(optarg, "offset")) {
+ txCmd->mode = TCMD_CONT_TX_OFFSETTONE;
+ } else if (!strcmp(optarg, "frame")) {
+ txCmd->mode = TCMD_CONT_TX_FRAME;
+ } else if (!strcmp(optarg, "tx99")) {
+ txCmd->mode = TCMD_CONT_TX_TX99;
+ } else if (!strcmp(optarg, "tx100")) {
+ txCmd->mode = TCMD_CONT_TX_TX100;
+ } else if (!strcmp(optarg, "off")) {
+ txCmd->mode = TCMD_CONT_TX_OFF;
+ }else {
+ cmd = 0;
+ }
+ break;
+ case 'f':
+ if (TESTMODE_CMDS == cmd) {
+ uint32_t freq = freqValid(atoi(optarg));
+ uint8_t freqBin;
+ // TBD: temporarily borrow the length's high B for freq
+ if (freq < 4900) {
+ freqBin = FREQ2FBIN(atoi(optarg), 1);
+ }
+ else {
+ freqBin = FREQ2FBIN(atoi(optarg), 0);
+ }
+ tCmds->hdr.u.parm.length &= 0x00ff;
+ tCmds->hdr.u.parm.length |= (freqBin << 8) & 0xff00;
+ }
+ else {
+ txCmd->freq = freqValid(atoi(optarg));
+ }
+ break;
+ case 'G':
+ txCmd->shortGuard = 1;
+ break;
+ case 'M':
+ if(cmd == TESTMODE_CONT_TX) {
+ if (!strcmp(optarg, "ht20")) {
+ txCmd->wlanMode = TCMD_WLAN_MODE_HT20;
+ } else if (!strcmp(optarg, "ht40plus")) {
+ txCmd->wlanMode = TCMD_WLAN_MODE_HT40PLUS;
+ } else if (!strcmp(optarg, "ht40minus")) {
+ txCmd->wlanMode = TCMD_WLAN_MODE_HT40MINUS;
+ }
+ } else if(cmd == TESTMODE_CONT_RX) {
+ if (!strcmp(optarg, "ht20")) {
+ rxCmd->u.para.wlanMode = TCMD_WLAN_MODE_HT20;
+ } else if (!strcmp(optarg, "ht40plus")) {
+ rxCmd->u.para.wlanMode = TCMD_WLAN_MODE_HT40PLUS;
+ } else if (!strcmp(optarg, "ht40minus")) {
+ rxCmd->u.para.wlanMode = TCMD_WLAN_MODE_HT40MINUS;
+ }
+ }
+ break;
+ case 'n':
+ txCmd->numPackets = atoi(optarg);
+ break;
+ case 'g':
+ /* let user input index of rateTable instead of string parse */
+ txCmd->dataRate = rateValid(atoi(optarg), txCmd->freq);
+ break;
+ case 'h':
+ {
+ int txPowerAsInt;
+ /* Get tx power from user. This is given in the form of a number
+ * that's supposed to be either an integer, or an integer + 0.5
+ */
+ double txPowerIndBm = atof(optarg);
+
+ /*
+ * Check to make sure that the number given is either an integer
+ * or an integer + 0.5
+ */
+ txPowerAsInt = (int)txPowerIndBm;
+ if (((txPowerIndBm - (double)txPowerAsInt) == 0) ||
+ (((txPowerIndBm - (double)txPowerAsInt)) == 0.5) ||
+ (((txPowerIndBm - (double)txPowerAsInt)) == -0.5)) {
+ if ((txCmd->mode != TCMD_CONT_TX_SINE) && (txCmd->mode != TCMD_CONT_TX_OFFSETTONE)) {
+ txCmd->txPwr = txPowerIndBm * 2;
+ } else {
+ txCmd->txPwr = txPowerIndBm;
+ }
+ } else {
+ printf("Bad argument to --txpwr, must be in steps of 0.5 dBm\n");
+ cmd = 0;
+ }
+
+ txCmd->tpcm = TPC_TX_PWR;
+ }
+ break;
+ case 'H':
+ txCmd->tpcm = TPC_TGT_PWR;
+ break;
+ case 'I':
+ txCmd->tpcm = TPC_FORCED_GAIN;
+ txCmd->txPwr = atof(optarg);
+ break;
+ case 'j':
+ txCmd->antenna = antValid(atoi(optarg));
+ break;
+ case 'z':
+ txCmd->pktSz = pktSzValid(atoi(optarg));
+ break;
+ case 'e':
+ txCmd->txPattern = atoi(optarg);
+ break;
+ case 'r':
+ cmd = TESTMODE_CONT_RX;
+ rxCmd->testCmdId = TCMD_CONT_RX_ID;
+ if (!strcmp(optarg, "promis")) {
+ rxCmd->act = TCMD_CONT_RX_PROMIS;
+ printf(" Its cont Rx promis mode \n");
+ } else if (!strcmp(optarg, "filter")) {
+ rxCmd->act = TCMD_CONT_RX_FILTER;
+ printf(" Its cont Rx filter mode \n");
+ } else if (!strcmp(optarg, "report")) {
+ printf(" Its cont Rx report mode \n");
+ rxCmd->act = TCMD_CONT_RX_REPORT;
+ resp = true;
+ } else {
+ cmd = 0;
+ }
+ break;
+ case 'p':
+ rxCmd->u.para.freq = freqValid(atoi(optarg));
+ break;
+ case 'q':
+ rxCmd->u.para.antenna = antValid(atoi(optarg));
+ break;
+ case 'x':
+ cmd = TESTMODE_PM;
+ pmCmd->testCmdId = TCMD_PM_ID;
+ if (!strcmp(optarg, "wakeup")) {
+ pmCmd->mode = TCMD_PM_WAKEUP;
+ } else if (!strcmp(optarg, "sleep")) {
+ pmCmd->mode = TCMD_PM_SLEEP;
+ } else if (!strcmp(optarg, "deepsleep")) {
+ pmCmd->mode = TCMD_PM_DEEPSLEEP;
+ } else {
+ cmd = 0;
+ }
+ break;
+ case 's':
+ {
+ uint8_t mac[ATH_MAC_LEN];
+
+ cmd = TESTMODE_CONT_RX;
+ rxCmd->testCmdId = TCMD_CONT_RX_ID;
+ rxCmd->act = TCMD_CONT_RX_SETMAC;
+ if (ath_ether_aton(optarg, mac) != 0) {
+ printf("Invalid mac address format! \n");
+ }
+ memcpy(rxCmd->u.mac.addr, mac, ATH_MAC_LEN);
+ printf("JLU: tcmd: setmac 0x%02x, 0x%02x, 0x%02x, 0x%02x, 0x%02x, 0x%02x\n",
+ mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
+ break;
+ }
+ case 'C':
+ cmd = TESTMODE_CONT_RX;
+ rxCmd->testCmdId = TCMD_CONT_RX_ID;
+ act = rxCmd->act = TCMD_CONT_RX_GETMAC;
+ resp = true;
+ break;
+ case 'u':
+ {
+ txCmd->aifsn = atoi(optarg) & 0xff;
+ printf("AIFS:%d\n", txCmd->aifsn);
+ }
+ break;
+ case 'a':
+ if(cmd == TESTMODE_CONT_TX) {
+ txCmd->enANI = true;
+ } else if(cmd == TESTMODE_CONT_RX) {
+ rxCmd->enANI = true;
+ }
+ break;
+ case 'o':
+ txCmd->scramblerOff = true;
+ break;
+ case 'S':
+ if (argc < 4)
+ usage();
+ cmd = TESTMODE_CONT_RX;
+ rxCmd->testCmdId = TCMD_CONT_RX_ID;
+ rxCmd->act = TCMD_CONT_RX_SET_ANT_SWITCH_TABLE;
+ rxCmd->u.antswitchtable.antswitch1 = strtoul(argv[2], (char **)NULL,0);
+ rxCmd->u.antswitchtable.antswitch2 = strtoul(argv[3], (char **)NULL,0);
+ break;
+ case 'l':
+ printf("Not supported\n");
+ return 0;
+ break;
+ case 'R':
+ if (argc < 5) {
+ printf("usage:athtestcmd -i wlan0 --setreg 0x1234 --regval 0x01 --flag 0\n");
+ }
+ cmd = TESTMODE_SETREG;
+ setRegCmd->testCmdId = TCMD_SET_REG_ID;
+ setRegCmd->regAddr = strtoul(optarg, (char **)NULL, 0);//atoi(optarg);
+ break;
+ case 'V':
+ setRegCmd->val = strtoul(optarg, (char **)NULL, 0);
+ break;
+ case 'F':
+ setRegCmd->flag = atoi(optarg);
+ break;
+ case 'w':
+ rxCmd->u.mac.otpWriteFlag = 1;
+ break;
+ case 'E':
+ rxCmd->u.mac.regDmn[0] = 0xffff&(strtoul(optarg, (char **)NULL, 0));
+ rxCmd->u.mac.regDmn[1] = 0xffff&(strtoul(optarg, (char **)NULL, 0)>>16);
+ break;
+ case 'B':
+ {
+ uint8_t btaddr[ATH_MAC_LEN];
+ if (ath_ether_aton(optarg, btaddr) != 0) {
+ printf("Invalid mac address format! \n");
+ }
+ memcpy(rxCmd->u.mac.btaddr, btaddr, ATH_MAC_LEN);
+ printf("JLU: tcmd: setbtaddr 0x%02x, 0x%02x, 0x%02x, 0x%02x, 0x%02x, 0x%02x\n",
+ btaddr[0], btaddr[1], btaddr[2], btaddr[3], btaddr[4], btaddr[5]);
+ }
+ break;
+ case 'c':
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ {
+ tCmds->hdr.u.parm.length = 0;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ act = tCmds->hdr.act = TC_CMDS_READTHERMAL;//TC_CMDS_CAL_THERMALVOLT;
+ resp = true;
+ }
+ break;
+ case 'A':
+ efuse_begin = atoi(optarg);
+ break;
+
+ case 'L':
+ efuse_end = atoi(optarg);
+ break;
+
+ case 'U':
+ {
+ uint8_t* pucArg = (uint8_t*)optarg;
+ uint8_t c;
+ uint8_t strBuf[256];
+ uint8_t pos = 0;
+ uint16_t length = 0;
+ uint32_t data;
+
+ /* Sweep string to end */
+ while (1) {
+ c = *pucArg++;
+ if (isHex(c)) {
+ strBuf[pos++] = c;
+ } else {
+ strBuf[pos] = '\0';
+ pos = 0;
+ sscanf(((char *)&strBuf), "%x", &data);
+ efuseWriteBuf[length++] = (data & 0xFF);
+
+ /* End of arg string */
+ if (c == '\0') {
+ break;
+ }
+ }
+ }
+
+ data_length = length;
+ }
+ break;
+
+ case 'm':
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ act = tCmds->hdr.act = TC_CMDS_EFUSEDUMP;
+ resp = true;
+ break;
+
+ case 'W':
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ act = tCmds->hdr.act = TC_CMDS_EFUSEWRITE;
+ resp = true;
+ break;
+
+ case 'O':
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ act = tCmds->hdr.act = TC_CMDS_OTPSTREAMWRITE;
+ resp = true;
+ break;
+
+ case 'P':
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ act = tCmds->hdr.act = TC_CMDS_OTPDUMP;
+ resp = true;
+ break;
+
+ case TCMD_PSAT_CAL:
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ tCmds->hdr.u.parm.length = 0;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ tCmds->hdr.act = TC_CMDS_PSAT_CAL;
+ resp = true;
+ break;
+
+ case TCMD_SINIT_WAIT:
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ tCmds->hdr.u.parm.length = (uint16_t)0;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ tCmds->hdr.act = TC_CMDS_SINIT_WAIT;
+ resp = true;
+ break;
+
+ case TCMD_PSAT_CAL_RESULT:
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ {
+ tCmds->hdr.u.parm.length = 0;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ tCmds->hdr.act = TC_CMDS_PSAT_CAL_RESULT;
+ }
+ resp = true;
+ bCalResult = false;
+ break;
+
+ case TCMD_CHAR_PSAT:
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ {
+ tCmds->hdr.u.parm.length = 0;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ tCmds->hdr.act = TC_CMDS_CHAR_PSAT;
+ }
+ // TBD: temporarily borrow the length's lower B for sweep entry
+ tCmds->hdr.u.parm.length &= 0xff00;
+ tCmds->hdr.u.parm.length |= (atoi(optarg)) & 0xff;
+ printf("optarg %s %d\n", optarg, tCmds->hdr.u.parm.length );
+
+ break;
+
+ case TCMD_CHAR_PSAT_RESULT:
+ cmd = TESTMODE_CMDS;
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ {
+ tCmds->hdr.u.parm.length = NUM_PSAT_CHAR_PARMS;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ tCmds->hdr.act = TC_CMDS_CHAR_PSAT_RESULT;
+ }
+ resp = true;
+ break;
+
+ default:
+ usage();
+ }
+ }
+
+ if ( cmd == TESTMODE_CMDS )
+ {
+ if ( tCmds->hdr.act == TC_CMDS_EFUSEWRITE )
+ {
+ int i;
+ /* Error check */
+ if (data_length == 0) {
+ printf("No data to write, exit..\n");
+ return 0;
+ } else if ((efuse_begin + data_length + 4) > TC_CMDS_SIZE_MAX) {
+ printf("Exceed eFuse border: %d, exit..\n", (TC_CMDS_SIZE_MAX - 1));
+ return 0;
+ }
+
+ /* PRINT */
+ printf("eFuse data (%d Bytes): ", data_length);
+ for (i = 0; i < data_length; i++) {
+ printf("%02X ", efuseWriteBuf[i]);
+ }
+ printf("\n");
+
+ /* Write address and data length */
+ tCmds->buf[0] = (efuse_begin & 0xFF);
+ tCmds->buf[1] = (efuse_begin >> 8) & 0xFF;
+ tCmds->buf[2] = (data_length & 0xFF);
+ tCmds->buf[3] = (data_length >> 8) & 0xFF;
+
+ /* Copy data to tcmd buffer. The first 4 bytes are the ID and length */
+ memcpy((void*)&(tCmds->buf[4]), (void*)&(efuseWriteBuf[0]), data_length);
+
+ /* Construct eFuse Write */
+ tCmds->hdr.u.parm.length = (4 + data_length);
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ }
+ else if ( tCmds->hdr.act == TC_CMDS_OTPSTREAMWRITE )
+ {
+ int i;
+
+ /* Error check */
+ if (data_length == 0) {
+ printf("No data to write, exit..\n");
+ return 0;
+ } else if ((data_length + 4) > TC_CMDS_SIZE_MAX) {
+ printf("Exceed OTP size: %d, exit..\n", data_length);
+ return 0;
+ }
+
+ /* PRINT */
+ printf("Write OTP data (%d Bytes): ", data_length);
+ for (i = 0; i < data_length; i++) {
+ printf("%02X ", efuseWriteBuf[i]);
+ }
+ printf("\n");
+
+ /* Copy data to tcmd buffer. The first 4 bytes are the ID and length */
+ memcpy((void*)&(tCmds->buf[0]), (void*)&(efuseWriteBuf[0]), data_length);
+
+ /* Construct eFuse Write */
+ tCmds->hdr.u.parm.length = data_length;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ }
+ else if ( tCmds->hdr.act == TC_CMDS_OTPDUMP )
+ {
+ tCmds->hdr.u.parm.length = 0;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ }
+ else if ( tCmds->hdr.act == TC_CMDS_CHAR_PSAT )
+ {
+ uint32_t ii = tCmds->hdr.u.parm.length & 0xff;
+ uint8_t freq= (uint8_t)((tCmds->hdr.u.parm.length >> 8) & 0xff);
+ tCmds->hdr.u.parm.length = NUM_PSAT_CHAR_PARMS;
+ tCmds->buf[0] = psatSweepTbl[ii].an_txrf3_rdiv2g;
+ tCmds->buf[1] = psatSweepTbl[ii].an_txrf3_pdpredist2g;
+ tCmds->buf[2] = psatSweepTbl[ii].an_rxtx2_mxrgain;
+ tCmds->buf[3] = psatSweepTbl[ii].an_rxrf_bias1_pwd_ic25mxr2gh;
+ tCmds->buf[4] = psatSweepTbl[ii].an_bias2_pwd_ic25rxrf;
+ tCmds->buf[5] = psatSweepTbl[ii].an_bb1_i2v_curr2x;
+ tCmds->buf[6] = psatSweepTbl[ii].an_txrf3_capdiv2g;
+ tCmds->buf[7] = freq;
+ printf("freq %d %d %d %d %d %d %d %d\n", tCmds->buf[7], tCmds->buf[0], tCmds->buf[1], tCmds->buf[2], tCmds->buf[3],tCmds->buf[4], tCmds->buf[5], tCmds->buf[6]);
+ }
+ }
+
+ /* default bufferLength = sizeof(*txCmd)*/
+ if ( cmd == TESTMODE_CONT_TX )
+ {
+ bufferLength = sizeof(*txCmd);
+ }
+ else if ( cmd == TESTMODE_CONT_RX )
+ {
+ bufferLength = sizeof(*rxCmd);
+ }
+ else if ( cmd == TESTMODE_PM )
+ {
+ bufferLength = sizeof(*pmCmd);
+ }
+ else if ( cmd == TESTMODE_SETREG)
+ {
+ bufferLength = sizeof(*setRegCmd);
+ }
+ else if ( cmd == TESTMODE_CMDS )
+ {
+ bufferLength = sizeof(*tCmds);
+ }
+
+ printf("Cmd %d length %d respNeeded %d\n",cmd,bufferLength,resp);
+
+ err = tcmd_tx_init(ATH6KL_INTERFACE, rx_cb);
+
+ if (err)
+ return err;
+
+ if ( (cmd == TESTMODE_CMDS) && (tCmds->hdr.act == TC_CMDS_EFUSEDUMP) )
+ {
+ int i, k;
+ int blkNum;
+ uint16_t efuseEnd = efuse_end;
+ uint16_t efuseBegin = efuse_begin;
+ uint16_t efusePrintAnkor;
+ uint16_t numPlaceHolder;
+
+ /* Input check */
+ if (efuseEnd > (VENUS_OTP_SIZE - 1)) {
+ efuseEnd = (VENUS_OTP_SIZE - 1);
+ }
+
+ if (efuseBegin > efuseEnd) {
+ efuseBegin = efuseEnd;
+ }
+
+ efusePrintAnkor = efuseBegin;
+
+ blkNum = ((efuseEnd - efuseBegin) / TC_CMDS_SIZE_MAX) + 1;
+
+ /* Request data in several trys */
+ for (i = 0; i < blkNum; i++) {
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ tCmds->hdr.act = TC_CMDS_EFUSEDUMP;
+ tCmds->hdr.u.parm.length = 4;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+
+ tCmds->buf[0] = (efuseBegin & 0xFF);
+ tCmds->buf[1] = (efuseBegin >> 8) & 0xFF;
+ tCmds->buf[2] = (efuseEnd & 0xFF);
+ tCmds->buf[3] = (efuseEnd >> 8) & 0xFF;
+
+ /* This field may get polluted so needs a refresh here */
+ tCmds->hdr.u.parm.bufLen = 4;
+
+ if ((err = tcmd_tx(buf, bufferLength /* weak */, resp))) {
+ fprintf(stderr, "tcmd_tx had error: %s!\n", strerror(-err));
+ return 0;
+ }
+
+ /* Last block? */
+ //sTcCmds populated in the callback..
+ if ((efuseEnd - efuseBegin + 1) < TC_CMDS_SIZE_MAX) {
+ memcpy((void*)(efuseBuf + efuseBegin), (void*)&(sTcCmds.buf[0]), (efuseEnd - efuseBegin + 1));
+ } else {
+ memcpy((void*)(efuseBuf + efuseBegin), (void*)&(sTcCmds.buf[0]), TC_CMDS_SIZE_MAX);
+ }
+
+ /* Adjust the efuseBegin but keep efuseEnd unchanged */
+ efuseBegin += TC_CMDS_SIZE_MAX;
+ }
+
+ /* Output Dump */
+ printf("------------------- eFuse Dump ----------------------");
+ for (i = efusePrintAnkor; i <= efuseEnd; i++) {
+ /* Cosmetics */
+ if (i == efusePrintAnkor) {
+ numPlaceHolder = (efusePrintAnkor & 0x0F);
+ printf("\n%04X:", (efusePrintAnkor & 0xFFF0));
+ for (k = 0; k < numPlaceHolder; k++) {
+ printf(" ");
+ }
+ } else if ((i & 0x0F) == 0) {
+ printf("\n%04X:", i);
+ }
+
+ printf(" %02X", efuseBuf[i]);
+ }
+ printf("\n\n");
+ }
+ else if ( (cmd == TESTMODE_CMDS) && (tCmds->hdr.act == TC_CMDS_SINIT_WAIT) )
+ {
+ if ((err = tcmd_tx(buf, bufferLength /* weak */, resp))) {
+ fprintf(stderr, "tcmd_tx had error: %s!\n", strerror(-err));
+ return 0;
+ }
+
+ sleep(FIRST_WAIT_INTERVAL); /* Wait 2s first */
+
+ /* Request data in several trys */
+ for (i = 0; i < MAX_WAIT_CYCLE; i++) {
+ tCmds->hdr.testCmdId = TC_CMDS_ID;
+ tCmds->hdr.u.parm.length = (uint16_t)0;
+ tCmds->hdr.u.parm.version = TC_CMDS_VERSION_TS;
+ tCmds->hdr.act = TC_CMDS_PSAT_CAL_RESULT;
+ resp = true;
+ bCalResult = false;
+
+ if ((err = tcmd_tx(buf, bufferLength /* weak */, resp))) {
+ /*don't let main return bcs the reply may not be ready. Try again.*/
+ /*fprintf(stderr, "tcmd_tx had error: %s!\n", strerror(-err));*/
+ /*return 0;*/
+ }
+ if (!bCalResult) {
+ sleep(POLLING_INTERVAL);
+ printf(".");
+ } else {
+ endTime = time(NULL);
+ printf("Wait time = %ld(s)\n", (endTime - startTime));
+ break;
+ }
+ }
+ }
+ else
+ {
+ if ((err = tcmd_tx(buf, bufferLength /* weak */, resp))) {
+ fprintf(stderr, "tcmd_tx had error: %s!\n", strerror(-err));
+ }
+ }
+
+ return 0;
+}
+
+static void rxReport(void *buf)
+{
+ struct TCMD_CONT_RX_REPORT *report = &((TCMD_CONT_RX *) buf)->u.report;
+ uint32_t pkt = report->totalPkt;
+ int32_t rssi = report->rssiInDBm;
+ uint32_t crcError = report->crcErrPkt;
+ uint32_t secErr = report->secErrPkt;
+ uint16_t *rateCnt = report->rateCnt;
+ uint16_t *rateCntShortGuard = report->rateCntShortGuard;
+
+ printf
+ ("total pkt %d ; crcError pkt %d ; secErr pkt %d ; average rssi %d\n",
+ pkt, crcError, secErr,
+ (int32_t) (pkt ? (rssi / (int32_t) pkt) : 0));
+
+ printf("1Mbps %d\n", rateCnt[0]);
+ printf("2Mbps %d\n", rateCnt[1]);
+ printf("5.5Mbps %d\n", rateCnt[2]);
+ printf("11Mbps %d\n", rateCnt[3]);
+ printf("6Mbps %d\n", rateCnt[4]);
+ printf("9Mbps %d\n", rateCnt[5]);
+ printf("12Mbps %d\n", rateCnt[6]);
+ printf("18Mbps %d\n", rateCnt[7]);
+ printf("24Mbps %d\n", rateCnt[8]);
+ printf("36Mbps %d\n", rateCnt[9]);
+ printf("48Mbps %d\n", rateCnt[10]);
+ printf("54Mbps %d\n", rateCnt[11]);
+ printf("\n");
+ printf("HT20 MCS0 6.5Mbps %d (SGI: %d)\n", rateCnt[12],
+ rateCntShortGuard[12]);
+ printf("HT20 MCS1 13Mbps %d (SGI: %d)\n", rateCnt[13],
+ rateCntShortGuard[13]);
+ printf("HT20 MCS2 19.5Mbps %d (SGI: %d)\n", rateCnt[14],
+ rateCntShortGuard[14]);
+ printf("HT20 MCS3 26Mbps %d (SGI: %d)\n", rateCnt[15],
+ rateCntShortGuard[15]);
+ printf("HT20 MCS4 39Mbps %d (SGI: %d)\n", rateCnt[16],
+ rateCntShortGuard[16]);
+ printf("HT20 MCS5 52Mbps %d (SGI: %d)\n", rateCnt[17],
+ rateCntShortGuard[17]);
+ printf("HT20 MCS6 58.5Mbps %d (SGI: %d)\n", rateCnt[18],
+ rateCntShortGuard[18]);
+ printf("HT20 MCS7 65Mbps %d (SGI: %d)\n", rateCnt[19],
+ rateCntShortGuard[19]);
+ printf("\n");
+ printf("HT40 MCS0 13.5Mbps %d (SGI: %d)\n", rateCnt[20],
+ rateCntShortGuard[20]);
+ printf("HT40 MCS1 27.0Mbps %d (SGI: %d)\n", rateCnt[21],
+ rateCntShortGuard[21]);
+ printf("HT40 MCS2 40.5Mbps %d (SGI: %d)\n", rateCnt[22],
+ rateCntShortGuard[22]);
+ printf("HT40 MCS3 54Mbps %d (SGI: %d)\n", rateCnt[23],
+ rateCntShortGuard[23]);
+ printf("HT40 MCS4 81Mbps %d (SGI: %d)\n", rateCnt[24],
+ rateCntShortGuard[24]);
+ printf("HT40 MCS5 108Mbps %d (SGI: %d)\n", rateCnt[25],
+ rateCntShortGuard[25]);
+ printf("HT40 MCS6 121.5Mbps %d (SGI: %d)\n", rateCnt[26],
+ rateCntShortGuard[26]);
+ printf("HT40 MCS7 135Mbps %d (SGI: %d)\n", rateCnt[27],
+ rateCntShortGuard[27]);
+
+}
+
+static void readThermal(void *buf,int len)
+{
+ TC_CMDS *tCmd;
+
+ tCmd = (TC_CMDS *)buf;
+
+ printf("Length rx cb rcvd %d\n",len);
+ printf("act %d version %d length %d\n",tCmd->hdr.act,tCmd->hdr.u.parm.version,tCmd->hdr.u.parm.length);
+ printf("chip thermal value:%d\n", tCmd->buf[0]);
+ return;
+}
+
+static void getMac(void *buf,int len)
+{
+ TC_CMDS *tCmd;
+
+ tCmd = (TC_CMDS *)buf;
+
+ printf("Length rx cb rcvd %d\n",len);
+ printf("act %d version %d length %d\n",tCmd->hdr.act,tCmd->hdr.u.parm.version,tCmd->hdr.u.parm.length);
+ printf("MAC address : %02x:%02x:%02x:%02x:%02x:%02x\n", tCmd->buf[0], tCmd->buf[1], tCmd->buf[2], tCmd->buf[3], tCmd->buf[4], tCmd->buf[5]);
+ return;
+}
+
+static void cmdReply(void *buf, int len)
+{
+ TC_CMDS tCmdReply;
+ TC_MSG *pTCMsg;
+ uint32_t act;
+ uint16_t wBytes;
+ int i=0;
+
+ printf("Length rx cb rcvd %d\n",len);
+
+ buf = (void*)((uint8_t*)buf + (2 * sizeof(unsigned int)));
+
+ uint8_t *reply = (uint8_t*)buf;
+
+ tCmdReply.hdr.u.parm.length = *(uint16_t *)&(reply[0]);
+ tCmdReply.hdr.u.parm.version = (uint8_t)(reply[2]);
+ act = tCmdReply.hdr.u.parm.version;
+ pTCMsg = (TC_MSG *)&(tCmdReply.buf[0]);
+
+ /* Error Check */
+ if (tCmdReply.hdr.u.parm.length > (TC_CMDS_SIZE_MAX + 1)) {
+ printf("Error: Reply lenth=%d, limit=%d\n", tCmdReply.hdr.u.parm.length, TC_CMDS_SIZE_MAX);
+ return;
+ } else {
+ ;
+ }
+
+ if (tCmdReply.hdr.u.parm.length > 0) {
+ memcpy((void*)&(tCmdReply.buf), (void*)((uint8_t*)buf+4), tCmdReply.hdr.u.parm.length);
+ memcpy((void*)&(sTcCmds.buf[0]), (void*)&(tCmdReply.buf[0]), tCmdReply.hdr.u.parm.length);
+ sTcCmds.hdr.u.parm.length = tCmdReply.hdr.u.parm.length;
+ }
+
+ switch (act) {
+ case TC_CMDS_EFUSEDUMP:
+ printf("eFuse data:\n");
+ break;
+ case TC_CMDS_EFUSEWRITE:
+ printf("(write eFuse data)\n");
+ wBytes = ((sTcCmds.buf[1] << 8) | sTcCmds.buf[0]);
+ printf("%d bytes written to eFuse.\n", wBytes);
+ break;
+ case TC_CMDS_OTPSTREAMWRITE:
+ printf("(OTP stream write)\n");
+
+ if (sTcCmds.buf[0] == A_OK) {
+ printf("Write %d bytes to OTP\n", data_length);
+ } else {
+ printf("Failed to write OTP\n");
+ }
+ break;
+ case TC_CMDS_OTPDUMP:
+ printf("OTP Dump\n");
+ if (sTcCmds.hdr.u.parm.length) {
+ /* Received bytes are in sTcCmds */
+ for (i = 0; i < sTcCmds.hdr.u.parm.length; i++) {
+ printf("%02x ", sTcCmds.buf[i]);
+ }
+ printf("\n");
+ } else {
+ printf("No valid stream found in OTP!\n");
+ }
+ break;
+ case TC_CMDS_PSAT_CAL:
+ break;
+ case TC_CMDS_SINIT_WAIT:
+ if (TC_MSG_PSAT_CAL_ACK == (TC_MSG_ID)pTCMsg->msgId) {
+ printf("ACK Received.\n");
+ }
+ break;
+ case TC_CMDS_PSAT_CAL_RESULT:
+ if (TC_MSG_PSAT_CAL_RESULTS == (TC_MSG_ID)pTCMsg->msgId) {
+ // update CAL data, read eeprom bin, re-generate eeprom bin
+ updateCALData(&calSetup, pTCMsg);
+ bCalResult = true;
+ }
+ break;
+ case TC_CMDS_CHAR_PSAT:
+ break;
+ case TC_CMDS_CHAR_PSAT_RESULT:
+ if (TC_MSG_CHAR_PSAT_RESULTS == (TC_MSG_ID)pTCMsg->msgId) {
+ dumpPSATCharResult2File(pTCMsg);
+ }
+ break;
+ default:
+ printf("Invalid action!\n");
+ break;
+ }
+}
+
+static void rx_cb(void *buf, int len)
+{
+ TCMD_ID tcmd;
+
+ if ( cmd == TESTMODE_CMDS )
+ {
+ if ( act == TC_CMDS_READTHERMAL )
+ {
+ readThermal(buf,len);
+ }
+ else
+ {
+ cmdReply(buf,len);
+ }
+
+ return;
+ }
+
+ if ( cmd == TESTMODE_CONT_RX )
+ {
+ if ( act == TCMD_CONT_RX_GETMAC )
+ {
+ getMac(buf, len);
+ }
+ }
+
+ tcmd = * ((uint32_t *) buf + 1);
+
+ switch (tcmd) {
+ case TCMD_CONT_RX_REPORT:
+ rxReport(buf);
+ break;
+ default:
+ break;
+ }
+
+}
+
+static uint32_t freqValid(uint32_t val)
+{
+ do {
+ if (val <= A_CHAN_MAX) {
+ uint16_t freq;
+
+ if (val < BG_CHAN_MIN)
+ break;
+
+ freq = wmic_ieee2freq(val);
+ if (INVALID_FREQ == freq)
+ break;
+ else
+ return freq;
+ }
+
+ if ((val == BG_FREQ_MAX) ||
+ ((val < BG_FREQ_MAX) && (val >= BG_FREQ_MIN)
+ && !((val - BG_FREQ_MIN) % 5)))
+ return val;
+ else if ((val >= A_FREQ_MIN) && (val < A_20MHZ_BAND_FREQ_MAX)
+ && !((val - A_FREQ_MIN) % 20))
+ return val;
+ else if ((val >= A_20MHZ_BAND_FREQ_MAX) && (val <= A_FREQ_MAX)
+ && !((val - A_20MHZ_BAND_FREQ_MAX) % 5))
+ return val;
+ } while (false);
+
+ A_ERR(-1, "Invalid channel or freq #: %d !\n", val);
+ return 0;
+}
+
+static uint32_t rateValid(uint32_t val, uint32_t freq)
+{
+ if (((freq >= A_FREQ_MIN) && (freq <= A_FREQ_MAX)
+ && (val >= A_RATE_NUM)) || ((freq >= BG_FREQ_MIN)
+ && (freq <= BG_FREQ_MAX)
+ && (val >= G_RATE_NUM))) {
+ printf("Invalid rate value %d for frequency %d! \n", val, freq);
+ prtRateTbl(freq);
+ A_ERR(-1, "Invalid rate value %d for frequency %d! \n", val,
+ freq);
+ }
+
+ return val;
+}
+
+static void prtRateTbl(uint32_t freq)
+{
+ int i;
+
+ for (i = 0; i < G_RATE_NUM; i++) {
+ printf("<rate> %d \t \t %s \n", i, bgRateStrTbl[i]);
+ }
+ printf("\n");
+}
+
+/*
+ * converts ieee channel number to frequency
+ */
+static uint16_t wmic_ieee2freq(uint32_t chan)
+{
+ if (chan == BG_CHAN_MAX) {
+ return BG_FREQ_MAX;
+ }
+ if (chan < BG_CHAN_MAX) { /* 0-13 */
+ return (BG_CHAN0_FREQ + (chan * 5));
+ }
+ if (chan <= A_CHAN_MAX) {
+ return (A_CHAN0_FREQ + (chan * 5));
+ } else {
+ return INVALID_FREQ;
+ }
+}
+
+static uint32_t antValid(uint32_t val)
+{
+ if (val > 2) {
+ A_ERR(-1,
+ "Invalid antenna setting! <0: auto; 1/2: ant 1/2>\n");
+ }
+
+ return val;
+}
+
+static bool txPwrValid(TCMD_CONT_TX * txCmd)
+{
+ bool rc = false;
+ if (txCmd->mode == TCMD_CONT_TX_SINE) {
+ if ((txCmd->txPwr >= 0) && (txCmd->txPwr <= 150))
+ rc = true;
+ } else if (txCmd->mode == TCMD_CONT_TX_OFFSETTONE) {
+ if ((txCmd->txPwr >= 0) && (txCmd->txPwr <= 150))
+ rc = true;
+ } else if (txCmd->mode != TCMD_CONT_TX_OFF) {
+ if (txCmd->tpcm != TPC_FORCED_GAIN) {
+ if ((txCmd->txPwr >= -30) && (txCmd->txPwr <= 60))
+ rc = true;
+ } else {
+ if ((txCmd->txPwr >= 0) && (txCmd->txPwr <= 120))
+ rc = true;
+ }
+ } else if (txCmd->mode == TCMD_CONT_TX_OFF) {
+ rc = true;
+ }
+
+ if (!rc)
+ A_ERR(1,
+ "Invalid Tx Power value! \nTx data: [-15 - 14]dBm \nTx sine: [ 0 - 150]PCDAC value\n");
+ return rc;
+}
+
+static uint32_t pktSzValid(uint32_t val)
+{
+ if ((val < 32) || (val > 1500)) {
+ A_ERR(-1, "Invalid package size! < 32 - 1500 >\n");
+ }
+ return val;
+}
+
+#ifdef NOTYET
+
+// Validate a hex character
+static bool _is_hex(char c)
+{
+ return (((c >= '0') && (c <= '9')) ||
+ ((c >= 'A') && (c <= 'F')) || ((c >= 'a') && (c <= 'f')));
+}
+
+// Convert a single hex nibble
+static int _from_hex(char c)
+{
+ int ret = 0;
+
+ if ((c >= '0') && (c <= '9')) {
+ ret = (c - '0');
+ } else if ((c >= 'a') && (c <= 'f')) {
+ ret = (c - 'a' + 0x0a);
+ } else if ((c >= 'A') && (c <= 'F')) {
+ ret = (c - 'A' + 0x0A);
+ }
+ return ret;
+}
+
+// Convert a character to lower case
+static char _tolower(char c)
+{
+ if ((c >= 'A') && (c <= 'Z')) {
+ c = (c - 'A') + 'a';
+ }
+ return c;
+}
+
+// Validate alpha
+static bool isalpha(int c)
+{
+ return (((c >= 'a') && (c <= 'z')) || ((c >= 'A') && (c <= 'Z')));
+}
+
+// Validate digit
+static bool isdigit(int c)
+{
+ return ((c >= '0') && (c <= '9'));
+}
+
+// Validate alphanum
+static bool isalnum(int c)
+{
+ return (isalpha(c) || isdigit(c));
+}
+#endif
+
+/*------------------------------------------------------------------*/
+/*
+ * Input an Ethernet address and convert to binary.
+ */
+static int ath_ether_aton(const char *orig, uint8_t * eth)
+{
+ int mac[6];
+ if (sscanf(orig, "%02x:%02x:%02X:%02X:%02X:%02X",
+ &mac[0], &mac[1], &mac[2], &mac[3], &mac[4], &mac[5]) == 6) {
+ int i;
+#ifdef DEBUG
+ if (*(orig + 12 + 5) != 0) {
+ fprintf(stderr, "%s: trailing junk '%s'!\n", __func__,
+ orig);
+ return -1;
+ }
+#endif
+ for (i = 0; i < 6; ++i)
+ eth[i] = mac[i] & 0xff;
+ return 0;
+ }
+ return -1;
+}
+
+// Read "golden" eeprom bin
+// Update it with CAL data
+
+bool readCalDataFromFileBin(char *fileName, AR6003_EEPROM *eepromData)
+{
+ FILE *fp;
+ bool rc=true;
+ uint32_t numBytes;
+
+ printf("readCalDataFromFile - reading EEPROM file %s\n",fileName);
+ if( (fp = fopen(fileName, "rb")) == NULL) {
+ _printf("Could not open %s to read\n", fileName);
+ return false;
+ }
+
+ if (AR6K_EEPROM_SIZE_LARGEST == (numBytes = fread((uint8_t *)eepromData, 1, AR6K_EEPROM_SIZE_LARGEST, fp))) {
+ printf("Read %d from %s\n", numBytes, fileName);
+ rc = true;
+ }
+ else {
+ if (feof(fp)) {
+ printf("good Read %d from %s\n", numBytes, fileName);
+ rc = true;
+ }
+ else if (ferror(fp)) {
+ _printf("Error reading %s\n", fileName);
+ rc = false;
+ }
+ else { _printf("Unknown fread rc\n"); rc = false; }
+ }
+ if (fp) fclose(fp);
+
+ if (rc) {
+ if ((eepromData->baseEepHeader.version & AR6003_EEP_VER_MINOR_MASK) >= AR6003_EEP_MINOR_VER10) {
+ if (AR6K_EEPROM_SIZE_LARGEST != numBytes) {
+ printf("Num of bytes read %d mismatch expected %d\n", numBytes, AR6K_EEPROM_SIZE_LARGEST);
+ rc = false;
+ }
+ else {
+ AR6K_EEPROM_SIZE = AR6003_EEPROM_SIZE = AR6K_EEPROM_SIZE_LARGEST;
+ printf("New TPC scheme selected! %x %d\n", eepromData->baseEepHeader.version, AR6K_EEPROM_SIZE);
+ }
+ }
+ else {
+ _printf("EEPROM file version %d not supported, please re-calibrate it.\n", eepromData->baseEepHeader.version);
+ rc = false;
+ }
+ }
+ return rc;
+}
+
+#define _PSAT_COMMON_4_HOST
+
+// if host doesn't support math.h, this section can be skipped, it is purely for data gathering
+static double cmacPwr(double cmac)
+{
+ double pwr;
+ double vfull=1.0, cycles = -15.0;
+
+ pwr = 10*log10(4*((double)cmac)*((double)pow(2.0, cycles))*((double)pow(vfull/512, 2)));
+ return(pwr);
+}
+static bool dumpPSATCharResult2File(TC_MSG *pTCMsg)
+{
+ FILE *dbgFp;
+ int i;
+ uint32_t cmac_i;
+
+#ifdef ANDROID
+ if ( (dbgFp = fopen("/persist/psatCharData.csv", "a+")) == NULL) {
+ printf("Error: open _psatCharData.csv\n");
+ return(false);
+ }
+#else
+ if ( (dbgFp = fopen("_psatCharData.csv", "a+")) == NULL) {
+ printf("Error: open _psatCharData.csv\n");
+ return(false);
+ }
+#endif
+
+ fprintf(dbgFp, "%d, %d, %d, %d, %d, %d, %d, %d\n",
+ pTCMsg->msg.psatCharResults.freq,
+ pTCMsg->msg.psatCharResults.an_txrf3_rdiv2g,
+ pTCMsg->msg.psatCharResults.an_txrf3_pdpredist2g,
+ pTCMsg->msg.psatCharResults.an_rxtx2_mxrgain,
+ pTCMsg->msg.psatCharResults.an_rxrf_bias1_pwd_ic25mxr2gh,
+ pTCMsg->msg.psatCharResults.an_bias2_pwd_ic25rxrf,
+ pTCMsg->msg.psatCharResults.an_bb1_i2v_curr2x,
+ pTCMsg->msg.psatCharResults.an_txrf3_capdiv2g);
+ for (i=0;i<_MAX_TX_GAIN_ENTRIES;i++) {
+ cmac_i = pTCMsg->msg.psatCharResults.cmac_i[i];
+ fprintf(dbgFp, "%d, %d, %f, %d\n", pTCMsg->msg.psatCharResults.pcdac[i], cmac_i, cmacPwr(cmac_i), cmac2Pwr_t10(cmac_i));
+ }
+
+ if (dbgFp) fclose(dbgFp);
+ return(true);
+}
+
+uint16_t computeChecksumOnly(uint16_t *pHalf, uint16_t length)
+{
+ uint16_t sum = 0, i;
+ for (i = 0; i < length; i++) { sum ^= *pHalf++; }
+ return(sum);
+}
+
+void computeChecksum(AR6003_EEPROM *pEepStruct)
+{
+ uint16_t sum, *pHalf;
+ uint8_t eepromVersion;
+
+ eepromVersion = pEepStruct->baseEepHeader.version & AR6003_EEP_VER_MINOR_MASK;
+ if (eepromVersion >= AR6003_EEP_MINOR_VER5) {
+ // first checksum
+ pEepStruct->baseEepHeader.checksum = 0x0000;
+ pHalf = (uint16_t *)pEepStruct;
+ sum = computeChecksumOnly(pHalf, AR6K_EEPROM_SIZE_PRIOR_VER4/2);
+ pEepStruct->baseEepHeader.checksum = 0xFFFF ^ sum;
+
+ // second (expanded checksum)
+ pEepStruct->checksumExpanded = 0x0000;
+ pHalf = (uint16_t *)pEepStruct;
+ pHalf += AR6K_EEPROM_SIZE_PRIOR_VER4/2;
+ sum = computeChecksumOnly(pHalf, (AR6003_EEPROM_SIZE - AR6K_EEPROM_SIZE_PRIOR_VER4)/2);
+ pEepStruct->checksumExpanded = 0xFFFF ^ sum;
+
+ _printf("--computeChecksum old 0x%x expanded 0x%x\n", pEepStruct->baseEepHeader.checksum, pEepStruct->checksumExpanded);
+ }
+ else {
+ pEepStruct->baseEepHeader.checksum = 0x0000;
+ pHalf = (uint16_t *)pEepStruct;
+ sum = computeChecksumOnly(pHalf, AR6K_EEPROM_SIZE_PRIOR_VER4/2);
+ pEepStruct->baseEepHeader.checksum = 0xFFFF ^ sum;
+ _printf("--computeChecksum old 0x%x\n", pEepStruct->baseEepHeader.checksum);
+ }
+}
+
+bool genEepromBinFile(char *fileName, AR6003_EEPROM *pEepStruct)
+{
+ FILE *fp;
+
+ // re-computing checksum
+ pEepStruct->baseEepHeader.checksum = 0;
+ computeChecksum(pEepStruct);
+
+ if ( (fp = fopen(fileName, "wb")) == NULL) {
+ _printf("Error: open to write eeprom bin %s \n", fileName);
+ return false;
+ }
+ if (sizeof(AR6003_EEPROM) != fwrite((uint8_t *)pEepStruct, 1, sizeof(AR6003_EEPROM), fp)) {
+ _printf("Error: writing to %s\n", fileName);
+ }
+ if (fp) fclose(fp);
+ return(true);
+}
+
+static void updateCALData(_CAL_SETUP *pCalSetup, TC_MSG *pTCMsg)
+{
+ bool rc;
+ AR6003_EEPROM eepromData, *pEeprom=&eepromData;
+ AR6003_BASE_EEP_HEADER *pBase;
+ AR6003_CAL_DATA_PER_FREQ_OLPC_EXPANDED *pRawDataSet2G_ext, *pRawDataSet5G_ext;
+ uint8_t *pCalChans2G, *pCalChans5G;
+ uint32_t numPiers2G, numPiers5G;
+ uint32_t i;
+
+ // read in golden bin
+ rc = readCalDataFromFileBin(pCalSetup->goldenBinFilename, pEeprom);
+ assert(rc);
+ printf("Read %s\n", pCalSetup->goldenBinFilename);
+
+ numPiers2G = numPiers5G = 0;
+ pBase = &(pEeprom->baseEepHeader);
+
+ {
+ if (pBase->opCapFlags & WLAN_11G_CAPABILITY) {
+ pRawDataSet2G_ext = pEeprom->calPierData2GExpanded;
+ pCalChans2G = pEeprom->calFreqPier2GExpanded;
+ for (numPiers2G = 0; numPiers2G < AR6003_NUM_2G_CAL_PIERS_EXPANDED; numPiers2G++) {
+ if (pCalChans2G[numPiers2G] == AR6003_BCHAN_UNUSED) {
+ break;
+ }
+ }
+ }
+
+ if (pBase->opCapFlags & WLAN_11A_CAPABILITY) {
+ pRawDataSet5G_ext = pEeprom->calPierData5GExpanded;
+ pCalChans5G = pEeprom->calFreqPier5GExpanded;
+ for (numPiers5G = 0; numPiers5G < AR6003_NUM_5G_CAL_PIERS_EXPANDED; numPiers5G++) {
+ if (pCalChans5G[numPiers5G] == AR6003_BCHAN_UNUSED) {
+ break;
+ }
+ }
+ }
+ }
+
+ PSAT_CAL_RESULTS *pPsatCalResults = &(pTCMsg->msg.psatCalResults);
+
+ for (i=0;i<numPiers2G;i++) {
+ printf("%d %d %d %d %d %.2f %.2f %d %d 0x%x %d %d 0x%x\n", pPsatCalResults->olpcGainTherm2G[i].olpcGainDelta_diff, pPsatCalResults->olpcGainTherm2G[i].olpcGainDelta_abs, pPsatCalResults->olpcGainTherm2G[i].thermCalVal,
+ pPsatCalResults->olpcGainTherm2G[i].cmac_psat, pPsatCalResults->olpcGainTherm2G[i].cmac_olpc,
+ cmacPwr(pPsatCalResults->olpcGainTherm2G[i].cmac_psat), cmacPwr(pPsatCalResults->olpcGainTherm2G[i].cmac_olpc),
+ pPsatCalResults->olpcGainTherm2G[i].cmac_psat_pcdac, pPsatCalResults->olpcGainTherm2G[i].cmac_olpc_pcdac,
+ pPsatCalResults->olpcGainTherm2G[i].numTryBF,
+ pPsatCalResults->olpcGainTherm2G[i].lineSlope, pPsatCalResults->olpcGainTherm2G[i].lineVariance,
+ pPsatCalResults->olpcGainTherm2G[i].psatParm);
+ //}
+ }
+ for (i=0;i<numPiers5G ;i++) {
+ printf("%d %d %d %d %d %.2f %.2f %d %d 0x%x\n", pPsatCalResults->olpcGainTherm5G[i].olpcGainDelta_diff, pPsatCalResults->olpcGainTherm5G[i].olpcGainDelta_abs, pPsatCalResults->olpcGainTherm5G[i].thermCalVal,
+ pPsatCalResults->olpcGainTherm5G[i].cmac_psat, pPsatCalResults->olpcGainTherm5G[i].cmac_olpc,
+ cmacPwr(pPsatCalResults->olpcGainTherm5G[i].cmac_psat), cmacPwr(pPsatCalResults->olpcGainTherm5G[i].cmac_olpc),
+ pPsatCalResults->olpcGainTherm5G[i].cmac_psat_pcdac, pPsatCalResults->olpcGainTherm5G[i].cmac_olpc_pcdac,
+ pPsatCalResults->olpcGainTherm5G[i].numTryBF);
+ //}
+ }
+
+ for (i=0;i<numPiers2G;i++) {
+ if (pEeprom->baseEepHeader.boardFlagsExt & AR6003_BOARDFLAGSEXT_PSAT_CAL_ABS) {
+ pRawDataSet2G_ext[i].olpcBasic.olpcGainDelta = (int8_t) (pPsatCalResults->olpcGainTherm2G[i].olpcGainDelta_abs);
+ pRawDataSet2G_ext[i].olpcGainDelta_t10 = (int16_t) (pPsatCalResults->olpcGainTherm2G[i].olpcGainDelta_abs *5);
+ }
+ else {
+ pRawDataSet2G_ext[i].olpcBasic.olpcGainDelta = (int8_t) (pPsatCalResults->olpcGainTherm2G[i].olpcGainDelta_diff);
+ pRawDataSet2G_ext[i].olpcGainDelta_t10 = (int16_t) (pPsatCalResults->olpcGainTherm2G[i].olpcGainDelta_diff *5);
+ }
+ pRawDataSet2G_ext[i].olpcBasic.thermCalVal = (uint8_t) pPsatCalResults->olpcGainTherm2G[i].thermCalVal;
+ }
+
+ for (i=0;i<numPiers5G;i++) {
+ if (pEeprom->baseEepHeader.boardFlagsExt & AR6003_BOARDFLAGSEXT_PSAT_CAL_ABS) {
+ pRawDataSet5G_ext[i].olpcBasic.olpcGainDelta = (int8_t)pPsatCalResults->olpcGainTherm5G[i].olpcGainDelta_abs;
+ }
+ else {
+ pRawDataSet5G_ext[i].olpcBasic.olpcGainDelta = (int8_t)pPsatCalResults->olpcGainTherm5G[i].olpcGainDelta_diff;
+ }
+ pRawDataSet5G_ext[i].olpcBasic.thermCalVal = (uint8_t)pPsatCalResults->olpcGainTherm5G[i].thermCalVal;
+ pRawDataSet5G_ext[i].olpcGainDelta_t10 = (int16_t)(pPsatCalResults->olpcGainTherm5G[i].olpcGainDelta_diff * 5);
+ }
+
+ memcpy((void*)&(pEeprom->baseEepHeader.custData[0]), pCalSetup->label, sizeof(pCalSetup->label));
+
+ // Generate bin
+ if (pEeprom->baseEepHeader.boardFlagsExt & AR6003_BOARDFLAGSEXT_PSAT_CAL_GEN_EEPROM) {
+ rc = genEepromBinFile(pCalSetup->outputBinFilename, pEeprom);
+ assert(rc);
+ }
+
+ return;
+}
+
diff --git a/ath6kl-tcmd/athtestcmd.h b/ath6kl-tcmd/athtestcmd.h
new file mode 100644
index 0000000..0b0977f
--- /dev/null
+++ b/ath6kl-tcmd/athtestcmd.h
@@ -0,0 +1,57 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#ifndef _TCMD_H_
+#define _TCMD_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+enum {
+ TESTMODE_CONT_TX = 801, /* something that doesn't collide with ascii */
+ TESTMODE_CONT_RX,
+ TESTMODE_PM,
+ TESTMODE_SETLPREAMBLE,
+ TESTMODE_SETREG,
+ TESTMODE_CMDS,
+};
+
+enum {
+ TCMD_SET_RX_LPL=501, /* something that doesn't collide with ascii */
+ TCMD_EFUSE_START=502,
+ TCMD_EFUSE_END=503,
+ TCMD_EFUSE_DATA=504,
+ TCMD_EFUSE_DUMP=505,
+ TCMD_EFUSE_WRITE=506,
+ TCMD_OTP_DUMP=507,
+ TCMD_OTP_WRITE=508,
+ TCMD_READ_THERMAL=509,
+ TCMD_PSAT_CAL=510,
+ TCMD_PSAT_CAL_RESULT,
+ TCMD_PM_CAL_RESULT,
+ TCMD_PM_CAL,
+ TCMD_UPDATE_CAL_OTP,
+ TCMD_CHAR_PSAT,
+ TCMD_CHAR_PSAT_RESULT,
+ TCMD_SINIT_WAIT,
+};
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* _TCMD_H_ */
diff --git a/ath6kl-tcmd/psatUtil b/ath6kl-tcmd/psatUtil
new file mode 100755
index 0000000..223a0a9
--- /dev/null
+++ b/ath6kl-tcmd/psatUtil
Binary files differ
diff --git a/ath6kl-tcmd/psatUtil.c b/ath6kl-tcmd/psatUtil.c
new file mode 100644
index 0000000..b8a79ef
--- /dev/null
+++ b/ath6kl-tcmd/psatUtil.c
@@ -0,0 +1,105 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#include <sys/types.h>
+#include <sys/file.h>
+#include <sys/ioctl.h>
+#include <sys/socket.h>
+#include <linux/types.h>
+#include <linux/if.h>
+#include <linux/wireless.h>
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <errno.h>
+#include <getopt.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+
+#include <assert.h>
+#include <ctype.h>
+#include <math.h>
+
+#include "testcmd.h"
+#include "athtestcmd.h"
+#include "sinit_common.h"
+
+#ifdef ATHTESTCMD_LIB
+#include <setjmp.h>
+extern void testcmd_error(int code, const char *fmt, ...);
+#define A_ERR testcmd_error
+#else
+#define A_ERR err
+#endif
+
+// defines
+
+#define strnicmp strncmp
+
+typedef unsigned long A_UINT32;
+typedef unsigned char A_UINT8;
+typedef int A_BOOL;
+
+#ifdef ANDROID
+#define _TCMD_PATH "/system/bin/athtestcmd -i wlan0"
+#else
+#define _TCMD_PATH "./athtestcmd -i wlan0"
+#endif
+
+int main(void)
+{
+ char cmd[128];
+ A_UINT32 i;
+ A_UINT32 freq;
+
+#ifdef ANDROID
+ system("insmod /system/lib/modules/cfg80211.ko");
+ sleep(2);
+
+ system("insmod /system/lib/modules/ath6kl_sdio.ko testmode=2");
+ sleep(3);
+#else
+ system("insmod /lib/modules/`uname -r`/kernel/drivers/net/wireless/ath/ath6kl/ath6kl_sdio.ko testmode=2");
+ sleep(3);
+#endif
+
+ freq=2412;
+
+ for (i = 0; i < NumEntriesPSTSweepTable; i++)
+ {
+ sprintf(cmd, "%s --psat_char %ld --txfreq %ld", _TCMD_PATH, i, freq);
+ //printf("%s\n", cmd);
+ system(cmd);
+ sprintf(cmd, "%s --psat_char_result", _TCMD_PATH);
+ //printf("%s\n", cmd);
+ system(cmd);
+ sleep(1);
+ }
+
+#ifdef ANDROID
+ system("rmmod ath6kl_sdio");
+ sleep(1);
+ system("rmmod cfg80211");
+#else
+ system("rmmod ath6kl_sdio.ko");
+#endif
+
+ return 0;
+}
+
diff --git a/ath6kl-tcmd/sinit_common.c b/ath6kl-tcmd/sinit_common.c
new file mode 100644
index 0000000..56214ce
--- /dev/null
+++ b/ath6kl-tcmd/sinit_common.c
@@ -0,0 +1,309 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#include <stdint.h>
+#include "testcmd.h"
+#include "sinit_common.h"
+
+PSAT_SWEEP_TABLE psatSweepTbl[] = {
+{0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
+{3, 0, 0, 0, 0, 0, 0, 0, 0, 0},
+{0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
+{3, 1, 0, 0, 0, 0, 0, 0, 0, 0},
+{0, 0, 3, 0, 0, 0, 0, 0, 0, 0},
+{3, 0, 3, 0, 0, 0, 0, 0, 0, 0},
+{0, 1, 3, 0, 0, 0, 0, 0, 0, 0},
+{3, 1, 3, 0, 0, 0, 0, 0, 0, 0},
+{0, 0, 0, 3, 0, 0, 0, 0, 0, 0},
+{3, 0, 0, 3, 0, 0, 0, 0, 0, 0},
+{0, 1, 0, 3, 0, 0, 0, 0, 0, 0},
+{3, 1, 0, 3, 0, 0, 0, 0, 0, 0},
+{0, 0, 3, 3, 0, 0, 0, 0, 0, 0},
+{3, 0, 3, 3, 0, 0, 0, 0, 0, 0},
+{0, 1, 3, 3, 0, 0, 0, 0, 0, 0},
+{3, 1, 3, 3, 0, 0, 0, 0, 0, 0},
+{0, 0, 0, 0, 3, 0, 0, 0, 0, 0},
+{3, 0, 0, 0, 3, 0, 0, 0, 0, 0},
+{0, 1, 0, 0, 3, 0, 0, 0, 0, 0},
+{3, 1, 0, 0, 3, 0, 0, 0, 0, 0},
+{0, 0, 3, 0, 3, 0, 0, 0, 0, 0},
+{3, 0, 3, 0, 3, 0, 0, 0, 0, 0},
+{0, 1, 3, 0, 3, 0, 0, 0, 0, 0},
+{3, 1, 3, 0, 3, 0, 0, 0, 0, 0},
+{0, 0, 0, 3, 3, 0, 0, 0, 0, 0},
+{3, 0, 0, 3, 3, 0, 0, 0, 0, 0},
+{0, 1, 0, 3, 3, 0, 0, 0, 0, 0},
+{3, 1, 0, 3, 3, 0, 0, 0, 0, 0},
+{0, 0, 3, 3, 3, 0, 0, 0, 0, 0},
+{3, 0, 3, 3, 3, 0, 0, 0, 0, 0},
+{0, 1, 3, 3, 3, 0, 0, 0, 0, 0},
+{3, 1, 3, 3, 3, 0, 0, 0, 0, 0},
+{0, 0, 0, 0, 0, 1, 0, 0, 0, 0},
+{3, 0, 0, 0, 0, 1, 0, 0, 0, 0},
+{0, 1, 0, 0, 0, 1, 0, 0, 0, 0},
+{3, 1, 0, 0, 0, 1, 0, 0, 0, 0},
+{0, 0, 3, 0, 0, 1, 0, 0, 0, 0},
+{3, 0, 3, 0, 0, 1, 0, 0, 0, 0},
+{0, 1, 3, 0, 0, 1, 0, 0, 0, 0},
+{3, 1, 3, 0, 0, 1, 0, 0, 0, 0},
+{0, 0, 0, 3, 0, 1, 0, 0, 0, 0},
+{3, 0, 0, 3, 0, 1, 0, 0, 0, 0},
+{0, 1, 0, 3, 0, 1, 0, 0, 0, 0},
+{3, 1, 0, 3, 0, 1, 0, 0, 0, 0},
+{0, 0, 3, 3, 0, 1, 0, 0, 0, 0},
+{3, 0, 3, 3, 0, 1, 0, 0, 0, 0},
+{0, 1, 3, 3, 0, 1, 0, 0, 0, 0},
+{3, 1, 3, 3, 0, 1, 0, 0, 0, 0},
+{0, 0, 0, 0, 3, 1, 0, 0, 0, 0},
+{3, 0, 0, 0, 3, 1, 0, 0, 0, 0},
+{0, 1, 0, 0, 3, 1, 0, 0, 0, 0},
+{3, 1, 0, 0, 3, 1, 0, 0, 0, 0},
+{0, 0, 3, 0, 3, 1, 0, 0, 0, 0},
+{3, 0, 3, 0, 3, 1, 0, 0, 0, 0},
+{0, 1, 3, 0, 3, 1, 0, 0, 0, 0},
+{3, 1, 3, 0, 3, 1, 0, 0, 0, 0},
+{0, 0, 0, 3, 3, 1, 0, 0, 0, 0},
+{3, 0, 0, 3, 3, 1, 0, 0, 0, 0},
+{0, 1, 0, 3, 3, 1, 0, 0, 0, 0},
+{3, 1, 0, 3, 3, 1, 0, 0, 0, 0},
+{0, 0, 3, 3, 3, 1, 0, 0, 0, 0},
+{3, 0, 3, 3, 3, 1, 0, 0, 0, 0},
+{0, 1, 3, 3, 3, 1, 0, 0, 0, 0},
+{3, 1, 3, 3, 3, 1, 0, 0, 0, 0},
+{0, 0, 0, 0, 0, 0, 15, 0, 0, 0},
+{3, 0, 0, 0, 0, 0, 15, 0, 0, 0},
+{0, 1, 0, 0, 0, 0, 15, 0, 0, 0},
+{3, 1, 0, 0, 0, 0, 15, 0, 0, 0},
+{0, 0, 3, 0, 0, 0, 15, 0, 0, 0},
+{3, 0, 3, 0, 0, 0, 15, 0, 0, 0},
+{0, 1, 3, 0, 0, 0, 15, 0, 0, 0},
+{3, 1, 3, 0, 0, 0, 15, 0, 0, 0},
+{0, 0, 0, 3, 0, 0, 15, 0, 0, 0},
+{3, 0, 0, 3, 0, 0, 15, 0, 0, 0},
+{0, 1, 0, 3, 0, 0, 15, 0, 0, 0},
+{3, 1, 0, 3, 0, 0, 15, 0, 0, 0},
+{0, 0, 3, 3, 0, 0, 15, 0, 0, 0},
+{3, 0, 3, 3, 0, 0, 15, 0, 0, 0},
+{0, 1, 3, 3, 0, 0, 15, 0, 0, 0},
+{3, 1, 3, 3, 0, 0, 15, 0, 0, 0},
+{0, 0, 0, 0, 3, 0, 15, 0, 0, 0},
+{3, 0, 0, 0, 3, 0, 15, 0, 0, 0},
+{0, 1, 0, 0, 3, 0, 15, 0, 0, 0},
+{3, 1, 0, 0, 3, 0, 15, 0, 0, 0},
+{0, 0, 3, 0, 3, 0, 15, 0, 0, 0},
+{3, 0, 3, 0, 3, 0, 15, 0, 0, 0},
+{0, 1, 3, 0, 3, 0, 15, 0, 0, 0},
+{3, 1, 3, 0, 3, 0, 15, 0, 0, 0},
+{0, 0, 0, 3, 3, 0, 15, 0, 0, 0},
+{3, 0, 0, 3, 3, 0, 15, 0, 0, 0},
+{0, 1, 0, 3, 3, 0, 15, 0, 0, 0},
+{3, 1, 0, 3, 3, 0, 15, 0, 0, 0},
+{0, 0, 3, 3, 3, 0, 15, 0, 0, 0},
+{3, 0, 3, 3, 3, 0, 15, 0, 0, 0},
+{0, 1, 3, 3, 3, 0, 15, 0, 0, 0},
+{3, 1, 3, 3, 3, 0, 15, 0, 0, 0},
+{0, 0, 0, 0, 0, 1, 15, 0, 0, 0},
+{3, 0, 0, 0, 0, 1, 15, 0, 0, 0},
+{0, 1, 0, 0, 0, 1, 15, 0, 0, 0},
+{3, 1, 0, 0, 0, 1, 15, 0, 0, 0},
+{0, 0, 3, 0, 0, 1, 15, 0, 0, 0},
+{3, 0, 3, 0, 0, 1, 15, 0, 0, 0},
+{0, 1, 3, 0, 0, 1, 15, 0, 0, 0},
+{3, 1, 3, 0, 0, 1, 15, 0, 0, 0},
+{0, 0, 0, 3, 0, 1, 15, 0, 0, 0},
+{3, 0, 0, 3, 0, 1, 15, 0, 0, 0},
+{0, 1, 0, 3, 0, 1, 15, 0, 0, 0},
+{3, 1, 0, 3, 0, 1, 15, 0, 0, 0},
+{0, 0, 3, 3, 0, 1, 15, 0, 0, 0},
+{3, 0, 3, 3, 0, 1, 15, 0, 0, 0},
+{0, 1, 3, 3, 0, 1, 15, 0, 0, 0},
+{3, 1, 3, 3, 0, 1, 15, 0, 0, 0},
+{0, 0, 0, 0, 3, 1, 15, 0, 0, 0},
+{3, 0, 0, 0, 3, 1, 15, 0, 0, 0},
+{0, 1, 0, 0, 3, 1, 15, 0, 0, 0},
+{3, 1, 0, 0, 3, 1, 15, 0, 0, 0},
+{0, 0, 3, 0, 3, 1, 15, 0, 0, 0},
+{3, 0, 3, 0, 3, 1, 15, 0, 0, 0},
+{0, 1, 3, 0, 3, 1, 15, 0, 0, 0},
+{3, 1, 3, 0, 3, 1, 15, 0, 0, 0},
+{0, 0, 0, 3, 3, 1, 15, 0, 0, 0},
+{3, 0, 0, 3, 3, 1, 15, 0, 0, 0},
+{0, 1, 0, 3, 3, 1, 15, 0, 0, 0},
+{3, 1, 0, 3, 3, 1, 15, 0, 0, 0},
+{0, 0, 3, 3, 3, 1, 15, 0, 0, 0},
+{3, 0, 3, 3, 3, 1, 15, 0, 0, 0},
+{0, 1, 3, 3, 3, 1, 15, 0, 0, 0},
+{3, 1, 3, 3, 3, 1, 15, 0, 0, 0},
+};
+
+_CMAP_PWR_MAPPING CmacPwrLkupTbl[] = {
+{100000, -433},
+{110000, -429},
+{120000, -425},
+{130000, -421},
+{140000, -418},
+{150000, -415},
+{160000, -412},
+{170000, -410},
+{180000, -407},
+{190000, -405},
+{200000, -403},
+{210000, -400},
+{220000, -398},
+{230000, -397},
+{240000, -395},
+{250000, -393},
+{260000, -391},
+{280000, -388},
+{290000, -386},
+{310000, -384},
+{330000, -381},
+{350000, -378},
+{380000, -375},
+{400000, -372},
+{430000, -369},
+{460000, -366},
+{500000, -363},
+{550000, -359},
+{600000, -355},
+{650000, -351},
+{700000, -348},
+{750000, -345},
+{800000, -342},
+{850000, -340},
+{900000, -337},
+{950000, -335},
+{1000000, -333},
+{1100000, -329},
+{1200000, -325},
+{1300000, -321},
+{1400000, -318},
+{1500000, -315},
+{1600000, -312},
+{1700000, -310},
+{1800000, -307},
+{1900000, -305},
+{2000000, -303},
+{2100000, -300},
+{2200000, -298},
+{2400000, -295},
+{2500000, -293},
+{2700000, -290},
+{2800000, -288},
+{3000000, -285},
+{3200000, -282},
+{3500000, -278},
+{3800000, -275},
+{4000000, -272},
+{4200000, -270},
+{4400000, -268},
+{4800000, -265},
+{5200000, -261},
+{5400000, -259},
+{5800000, -256},
+{6200000, -253},
+{6800000, -249},
+{7400000, -246},
+{7800000, -243},
+{8400000, -240},
+{8600000, -239},
+{9300000, -236},
+{10200000, -232},
+{10800000, -229},
+{11700000, -226},
+{12400000, -223},
+{13600000, -219},
+{14800000, -216},
+{15600000, -213},
+{16800000, -210},
+{17600000, -208},
+{18800000, -205},
+{20500000, -202},
+{21500000, -199},
+{23500000, -196},
+{25000000, -193},
+{26500000, -190},
+{29000000, -186},
+{33500000, -180},
+{42000000, -170},
+{53000000, -160},
+{67000000, -150},
+{84000000, -140},
+{106000000, -130},
+{135000000, -120},
+{155000000, -114},
+{175000000, -109},
+{200000000, -103},
+{230000000, -97},
+{265000000, -91},
+{300000000, -85},
+{330000000, -81},
+{360000000, -78},
+{390000000, -74},
+{430000000, -70},
+{470000000, -66},
+{520000000, -62},
+{570000000, -58},
+{620000000, -54},
+{680000000, -50},
+{750000000, -46},
+};
+
+uint16_t NumEntriesPSTSweepTable = sizeof(psatSweepTbl)/sizeof(PSAT_SWEEP_TABLE);
+
+int32_t
+interpolate_round(int32_t target, int32_t srcLeft, int32_t srcRight,
+ int32_t targetLeft, int32_t targetRight, int32_t roundUp)
+{
+ int32_t rv, tmp;
+
+ if (srcRight == srcLeft) {
+ rv = targetLeft;
+ } else {
+ tmp = srcRight - srcLeft;
+ rv = (((target - srcLeft) * targetRight) / tmp) +
+ (((srcRight - target) * targetLeft) / tmp);
+ }
+
+ return(rv);
+}
+
+
+int16_t cmac2Pwr_t10(uint32_t cmac)
+{
+ uint32_t i;
+ int16_t cmacResult;
+ for (i=0;i<CMAC_PWR_LOOKUP_MAX;i++) {
+ if (cmac < CmacPwrLkupTbl[i].cmac) {
+ break;
+ }
+ }
+ if (0 == i) {
+ return(CmacPwrLkupTbl[0].pwr_t10);
+ }
+ else if (CMAC_PWR_LOOKUP_MAX == i) {
+ return(CmacPwrLkupTbl[CMAC_PWR_LOOKUP_MAX -1].pwr_t10);
+ }
+ else {
+ /* Added a "DEVIDE_COEFF" to avoid the overflow */
+ cmacResult = interpolate_round((cmac / DEVIDE_COEFF), (CmacPwrLkupTbl[i-1].cmac / DEVIDE_COEFF), (CmacPwrLkupTbl[i].cmac / DEVIDE_COEFF),
+ CmacPwrLkupTbl[i-1].pwr_t10, CmacPwrLkupTbl[i].pwr_t10, 10);
+ }
+
+ return(cmacResult);
+}
+
+
diff --git a/ath6kl-tcmd/sinit_common.h b/ath6kl-tcmd/sinit_common.h
new file mode 100644
index 0000000..b19770f
--- /dev/null
+++ b/ath6kl-tcmd/sinit_common.h
@@ -0,0 +1,41 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#ifndef _PSAT_COMMON_H_
+#define _PSAT_COMMON_H_
+
+#include <stdint.h>
+#include "testcmd.h"
+
+#define DEVIDE_COEFF 10000
+
+// CMAC to power lookup table, for platform such as embedded without sophisticated math function
+typedef struct {
+ uint32_t cmac;
+ int32_t pwr_t10;
+} _CMAP_PWR_MAPPING;
+
+extern _CMAP_PWR_MAPPING CmacPwrLkupTbl[];
+#define CMAC_PWR_LOOKUP_MAX (sizeof(CmacPwrLkupTbl) / sizeof(_CMAP_PWR_MAPPING))
+
+extern PSAT_SWEEP_TABLE psatSweepTbl[];
+extern uint16_t NumEntriesPSTSweepTable;
+
+int32_t interpolate_round(int32_t target, int32_t srcLeft, int32_t srcRight,
+ int32_t targetLeft, int32_t targetRight, int32_t roundUp);
+int16_t cmac2Pwr_t10(uint32_t cmac);
+
+#endif //#ifndef _PSAT_COMMON_H_
diff --git a/ath6kl-tcmd/sinit_eep.h b/ath6kl-tcmd/sinit_eep.h
new file mode 100644
index 0000000..709be34
--- /dev/null
+++ b/ath6kl-tcmd/sinit_eep.h
@@ -0,0 +1,359 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#ifndef _AR6003_EEPROM_STRUCT_H_
+#define _AR6003_EEPROM_STRUCT_H_
+
+#include <stdint.h>
+
+#define PREPACK
+#define POSTPACK __attribute__ ((packed))
+
+#define AR6003_EEP_VER_MINOR_MASK 0xFFF
+#define AR6003_EEP_MINOR_VER5 0x5
+#define AR6003_EEP_MINOR_VER10 0xA
+#define AR6K_EEPROM_SIZE_PRIOR_VER4 1024
+#define AR6K_EEPROM_SIZE_LARGEST 2048
+
+#define AR6003_NUM_5G_CAL_PIERS 8
+#define AR6003_NUM_2G_CAL_PIERS 3
+#define AR6003_NUM_5G_CAL_PIERS_EXPANDED 32
+#define AR6003_NUM_2G_CAL_PIERS_EXPANDED 16
+#define AR6003_BCHAN_UNUSED 0xFF
+
+#define AR6003_BOARDFLAGSEXT_PSAT_CAL_GEN_EEPROM 0x04
+#define AR6003_BOARDFLAGSEXT_PSAT_CAL_ABS 0x08
+
+#define FREQ2FBIN(x,y) ((y) ? ((x) - 2300) : (((x) - 4800) / 5))
+#define FBIN2FREQ(x,y) ((y) ? ((x) + 2300) : (((x) * 5) + 4800))
+#define AR6003_MAX_CHAINS 1
+#define AR6003_EEPROM_MODAL_SPURS 5
+#define AR6003_NUM_ALPHATHERM_CHAN_PIERS 4
+#define AR6003_NUM_ALPHATHERM_TEMP_PIERS 4
+#define AR6003_NUM_5G_20_TARGET_POWERS 8
+#define AR6003_NUM_5G_40_TARGET_POWERS 8
+#define AR6003_NUM_2G_CCK_TARGET_POWERS 2
+#define AR6003_NUM_2G_20_TARGET_POWERS 3
+#define AR6003_NUM_2G_40_TARGET_POWERS 3
+#define AR6003_NUM_CTLS 21
+#define AR6003_NUM_BAND_EDGES 8
+#define AR6003_NUM_PD_GAINS 4
+#define NUM_ATECAL_CHANS_2G 4
+#define NUM_ATECAL_CHANS_5G 10
+#define AR6003_PD_GAIN_ICEPTS 5
+#define STICKY_REG_TBL_SIZE_MAX 8
+#define MAX_CUSTDATA_BYTES 16
+
+typedef enum {
+ WLAN_11A_CAPABILITY = 1,
+ WLAN_11G_CAPABILITY = 2,
+ WLAN_11AG_CAPABILITY = 3,
+}WALN_CAPABILITY;
+
+typedef enum {
+ TGTPWR_LEG_6_24 = 0,
+ TGTPWR_LEG_36,
+ TGTPWR_LEG_48,
+ TGTPWR_LEG_54,
+ TGTPWR_LEG_LAST
+} TGTPWR_LEG;
+
+typedef enum {
+ TGTPWR_HT_0 = 0,
+ TGTPWR_HT_1,
+ TGTPWR_HT_2,
+ TGTPWR_HT_3,
+ TGTPWR_HT_4,
+ TGTPWR_HT_5,
+ TGTPWR_HT_6,
+ TGTPWR_HT_7,
+ TGTPWR_HT_LAST
+} TGTPWR_HT;
+
+typedef PREPACK struct Ar6003_spurChanStruct {
+ uint8_t spurChan; /*spur mitigation enabled in the channel bitmap, 1 bit 1 channel*/
+ uint8_t spurABChoose; /*choose which is master spur ,spur_A or spur_B*/
+ uint8_t spurA_PrimSecChoose; /*choose primary and secondary spur which produce by spur_A*/
+ uint8_t spurB_PrimSecChoose; /*choose primary and secondary spur which produce by spur_B*/
+} POSTPACK AR6003_SPUR_CHAN;
+
+typedef union Ar6003_obdbStruct {
+ uint16_t value;
+ struct g_bits {
+ uint16_t paloff : 3,
+ qam : 3,
+ psk : 3,
+ cck : 3,
+ db : 3,
+ unused : 1;
+ } g_obdb;
+ struct a_bits {
+ uint16_t d2b : 3,
+ d3b : 3,
+ d4b : 3,
+ ob : 3,
+ unused : 4;
+ } a_obdb;
+} POSTPACK AR6003_OBDB;
+
+typedef PREPACK struct Ar6003_BaseEepHeader {
+ uint32_t length; // 4 B
+ uint16_t checksum; // 2 B
+ uint16_t version; // 2 B
+ uint16_t opCapFlags; // 2 B
+ uint16_t boardFlags; // 2 B
+ uint16_t regDmn[2]; // 4 B
+ uint16_t subSystemId; // 2 B
+ uint16_t blueToothOptions; // 2 B
+ uint16_t binBuildNumber; // major(4):minor(5):build(7) // 2 B
+ uint8_t macAddr[6]; // 6 B
+ uint8_t bdAddr[6]; // 6 B
+ uint8_t rxMask; // 1 B
+ uint8_t txMask; // 1 B
+ int8_t cckOfdmDelta; // 1 B
+ uint8_t custData[MAX_CUSTDATA_BYTES]; // 16 B
+ uint8_t reserved[4]; // 4 B reserved for custData. Sometimes custData exceed the max bytes
+ uint8_t spurBaseA; // 1 B
+ uint8_t spurBaseB; // 1 B
+ uint8_t spurRssiThresh; // 1 B
+ uint8_t HTCapFlags; // 1 B
+ uint8_t boardFlagsExt; // 1 B
+ uint8_t futureBase[6]; // 6 B
+} POSTPACK AR6003_BASE_EEP_HEADER; // 68 B
+
+// Notes:
+// - IQ CAL is done by sw for every reset, here we store the default values in case IQ CAL
+// is not done for whatever reason.
+typedef PREPACK struct Ar6003_ModalEepHeader {
+ uint32_t antCtrlChain[AR6003_MAX_CHAINS]; // 4B, "chn_b0_switch_table", AntE only
+ uint32_t antCtrlCom1; // 4B, "com1_switch_table", AntA, B, C, D
+ uint32_t antCtrlCom2; // 4B, "com2_switch_table"
+ AR6003_OBDB ob_db; // 2B, a number of ob, db fields
+ uint8_t anaXtalConfig[6]; // 6B, tbd?: for xtal/synth related fields, tobe replaced with a struct
+ int8_t antennaGainCh[AR6003_MAX_CHAINS]; // 1B, affect antenna gain calculation
+ uint8_t switchSettling; // 1B, "time_switch_settling"
+ uint8_t swSettleHt40; // 1B, "time_switch_settling" for HT40
+ uint8_t xatten1Db[AR6003_MAX_CHAINS]; // 1B, "xatten1_db_0"
+ uint8_t xatten1Margin[AR6003_MAX_CHAINS]; // 1B, "xatten1_margin_0"
+ uint8_t xatten1Hyst[AR6003_MAX_CHAINS]; // 1B, "xatten1_hyst_margin_0"
+ uint8_t xatten2Db[AR6003_MAX_CHAINS]; // 1B, "xatten2_db_0"
+ uint8_t xatten2Margin[AR6003_MAX_CHAINS]; // 1B, "xatten2_margin_0"
+ uint8_t xatten2Hyst[AR6003_MAX_CHAINS]; // 1B, "xatten2_hyst_margin_0"
+ int8_t adcDesiredSize; // 1B, "adc_desired_size"
+ uint8_t txEndToXpaOff; // 1B, "tx_end_to_xpaa_off", "tx_end_to_xpab_off"
+ uint8_t txEndToRxOn; // 1B, "tx_end_to_a2_rx_on"
+ uint8_t txFrameToXpaOn; // 1B, "tx_frame_to_xpaa_on", "tx_frame_to_xpab_on"
+ uint8_t txFrameToDataStart; // 1B, "tx_frame_to_tx_d_start"
+ uint8_t txFrameToPaOn; // 1B, "tx_frame_to_pa_on"
+ uint8_t thresh62; // 1B, "cf_thresh62"
+ int8_t noiseFloorThreshCh[AR6003_MAX_CHAINS]; // 1B, tbd?: what to set?
+ int8_t rxIqCalICh[AR6003_MAX_CHAINS]; // 1B, "rx_iqcorr_q_i_coff_0"
+ int8_t rxIqCalQCh[AR6003_MAX_CHAINS]; // 1B, "rx_iqcorr_q_q_coff_0"
+ uint8_t xpaBiasLvl; // 1B, "an_top_xpabiaslvl"
+ uint8_t ht40PowerIncForPdadc; // 1B, affect tx power in HT40
+ uint8_t enableXpa; // 1B, "bb_enable_xpab | bb_enable_xpaa"
+ AR6003_SPUR_CHAN spurChans[AR6003_EEPROM_MODAL_SPURS]; // 4 * 5 = 20 B, tbd?:
+ uint8_t alphaTherm; // 1B, "alpha_therm"
+ uint8_t alphaThermPalOn; // 1B, "alpha_therm_pal_on"
+ uint8_t alphaVolt; // 1B, "alpha_volt"
+ uint8_t alphaVoltPalOn; // 1B, "alpha_volt_pal_on"
+ int8_t adcDesiredSizeHT40; // 1B, "adc_desired_size" for HT40
+ uint8_t paprdQuickDrop; // 1B, "bb_paprd_trainer_cntl3_cf_paprd_quick_drop"
+ uint8_t txGainTbl_0; // bb_tx_gain_table_0
+ uint8_t txGainTblDelta[16]; // bb_tx_gain_table_x (_1 to _32, 4 bits per delta) for PAL OFF??
+ uint8_t reserved[3];
+ uint32_t antCtrlExtCommon1;
+ uint32_t antCtrlExtCommon2;
+ uint8_t alphaThermChans[AR6003_NUM_ALPHATHERM_CHAN_PIERS]; // 4B, "alpha therm channels"
+ uint8_t alphaThermTbl[AR6003_NUM_ALPHATHERM_CHAN_PIERS][AR6003_NUM_ALPHATHERM_TEMP_PIERS]; // 16B, "alpha_therm_tbl" lowtemp midtemp1 midtemp2 hightemp
+ uint8_t areg_lvlctr; // 1 B
+ uint8_t pareg_lvlctr; // 1 B
+ uint8_t txGainTblMax; // 1 B
+ uint8_t cckInitRfGain; // 1 B
+ uint16_t paprdMinCorrThreshold; // 2 B
+ uint8_t an_rxrf_bias1_pwd_ic25vga5g; // 1 B
+ uint8_t futureModal[5]; // 5 B
+} POSTPACK AR6003_MODAL_EEP_HEADER; // 128 B
+
+typedef PREPACK struct Ar6003_calDataPerFreq {
+ uint8_t pwrPdg[AR6003_NUM_PD_GAINS][AR6003_PD_GAIN_ICEPTS]; // 20 B
+ uint8_t vpdPdg[AR6003_NUM_PD_GAINS][AR6003_PD_GAIN_ICEPTS]; // 20 B
+} POSTPACK AR6003_CAL_DATA_PER_FREQ; // 40 B
+
+typedef PREPACK struct Ar6003_calDataPerFreqOlpc {
+ int8_t olpcGainDelta; // 1B, "olpc_gain_delta"
+ uint8_t thermCalVal; // 1B, "therm_cal_value"
+ uint8_t voltCalVal; // 1B, "volt_cal_value"
+ int8_t olpcGainDeltaPALOn; // 1B, "olpc_gain_delta_pal_on"
+} POSTPACK AR6003_CAL_DATA_PER_FREQ_OLPC; // 4 B
+
+typedef PREPACK struct Ar6003_calDataPerFreqOlpcExpanded {
+ AR6003_CAL_DATA_PER_FREQ_OLPC olpcBasic; // 4B
+ int16_t olpcGainDelta_t10; // 2B "untruncated olpc gain delta 0.1dB resolution"
+ uint8_t desiredScaleCck_t10; // 1B, "desired_scale_cck"
+ uint8_t desiredScale6M_t10; // 1B
+ uint8_t desiredScale36M_t10; // 1B
+ uint8_t desiredScale54M_t10; // 1B
+ uint8_t desiredScaleMCS0HT20_t10; // 1B
+ uint8_t desiredScaleMCS7HT20_t10; // 1B
+ uint8_t desiredScaleMCS0HT40_t10; // 1B
+ uint8_t desiredScaleMCS7HT40_t10; // 1B
+} POSTPACK AR6003_CAL_DATA_PER_FREQ_OLPC_EXPANDED; // 14 B
+
+typedef PREPACK struct Ar6003_calDataPerFreqOlpcATEDelta {
+ int16_t olpcGainDelta_t10; // 2B
+} POSTPACK AR6003_CAL_DATA_PER_FREQ_OLPC_FE_DELTA; // 2B
+
+typedef PREPACK struct Ar6003_CalTargetPowerLegacy {
+ uint8_t bChannel;
+ uint8_t tPow2x[4];
+} POSTPACK AR6003_CAL_TARGET_POWER_LEG; // 5B
+
+typedef PREPACK struct Ar6003_CalTargetPowerHt {
+ uint8_t bChannel;
+ uint8_t tPow2x[8];
+} POSTPACK AR6003_CAL_TARGET_POWER_HT;
+
+typedef PREPACK struct Ar6003_CalCtlEdges {
+ uint8_t bChannel;
+ uint8_t tPower :6,
+ flag :2;
+} POSTPACK AR6003_CAL_CTL_EDGES;
+
+typedef PREPACK struct Ar6003_CalCtlData {
+ AR6003_CAL_CTL_EDGES ctlEdges[AR6003_MAX_CHAINS][AR6003_NUM_BAND_EDGES]; // 2 * 8 = 16 B
+} POSTPACK AR6003_CAL_CTL_DATA; // 16 B
+
+typedef PREPACK struct Ar6003_CalDataPerChip {
+ int16_t thermAdcScaledGain; // 2B, "therm_adc_scaled_gain"
+ int8_t thermAdcOffset; // 1B, "therm_adc_offset"
+ uint8_t xtalCapOutDac; // 1B, "xtal_capoutdac"
+ uint8_t xtalCapInDac; // 1B, "xtal_capindac"
+ uint8_t refBiasTrim; // 1B, tbd?: what field?
+} POSTPACK AR6003_CAL_DATA_PER_CHIP; // 6 B
+
+typedef PREPACK struct ateProvided {
+ uint8_t GoldenTherm;
+ uint8_t GoldenVolt;
+ uint8_t pcDac;
+ uint8_t vtestLCodeGolden;
+ int8_t vtestLVoltGolden;
+ uint8_t vtestHCodeGolden;
+ int8_t vtestHVoltGolden;
+ uint8_t numCalChans5G;
+ uint8_t numCalChans2G; // 1B
+ uint8_t calFreqPier5G[NUM_ATECAL_CHANS_5G]; // 10B
+ uint8_t calFreqPier2G[NUM_ATECAL_CHANS_2G]; // 4B
+ uint8_t ateZeroCalFlag; // 1B
+} POSTPACK AR6003_ATE_PROVIDED_DATA; // 24B
+
+typedef PREPACK struct stickyRegTbl {
+ uint32_t address;
+ uint32_t value;
+} POSTPACK AR6003_STICKY_REG_TABLE; // 8B
+
+#define PSAT_AN_TXRF3_RDIV2G_LSB 0 // an_txrf3_rdiv2g;
+#define PSAT_AN_TXRF3_RDIV2G_MASK 0x3 // an_txrf3_rdiv2g;
+#define PSAT_AN_TXRF3_PDPREDIST2G_LSB 2 // an_txrf3_pdpredist2g;
+#define PSAT_AN_TXRF3_PDPREDIST2G_MASK 0x1 // an_txrf3_pdpredist2g;
+#define PSAT_AN_RXTX2_MXRGAIN_LSB 3 // an_rxtx2_mxrgain;
+#define PSAT_AN_RXTX2_MXRGAIN_MASK 0x3 // an_rxtx2_mxrgain;
+#define PSAT_AN_RXRF_BIAS1_PWD_IC25MXR2GH_LSB 5 // an_rxrf_bias1_pwd_ic25mxr2gh;
+#define PSAT_AN_RXRF_BIAS1_PWD_IC25MXR2GH_MASK 0x7 // an_rxrf_bias1_pwd_ic25mxr2gh;
+#define PSAT_AN_BIAS2_PWD_IC25RXRF_LSB 8 // an_bias2_pwd_ic25rxrf;
+#define PSAT_AN_BIAS2_PWD_IC25RXRF_MASK 0x7 // an_bias2_pwd_ic25rxrf;
+#define PSAT_AN_BB1_I2V_CURR2X_LSB 11 // an_bb1_i2v_curr2x;
+#define PSAT_AN_BB1_I2V_CURR2X_MASK 0x1 // an_bb1_i2v_curr2x;
+#define PSAT_AN_TXRF6_CAPDIV2G_LSB 12 // an_txrf6_capdiv2g;
+#define PSAT_AN_TXRF6_CAPDIV2G_MASK 0xF // an_txrf6_capdiv2g;
+
+typedef PREPACK struct ar6kPSATCAL {
+ int16_t psat_t10;
+ int16_t ofdmCwDelta_t10;
+ int16_t cmacOlpcPsatDeltaGu_t10;
+ int16_t olpcGainDeltaGu_t10;
+ uint8_t olpcPcdac;
+ uint8_t psatPcdac;
+ uint16_t psatTuneParms;
+ uint16_t psatTuneParmsAlt1;
+} POSTPACK AR6003_PSAT_CAL_PARMS;
+
+typedef PREPACK struct ar6kEeprom {
+ // base
+ AR6003_BASE_EEP_HEADER baseEepHeader; // 68 B
+ // modal
+ AR6003_MODAL_EEP_HEADER modalHeader[2]; // 256 B
+
+ // CAL section
+ uint8_t calFreqPier5G[AR6003_NUM_5G_CAL_PIERS]; // 8 B
+ uint8_t calFreqPier2G[AR6003_NUM_2G_CAL_PIERS]; // 3 B
+ uint8_t padding1; // 1 B
+ AR6003_CAL_DATA_PER_FREQ_OLPC calPierData5G[AR6003_NUM_5G_CAL_PIERS]; // 4 * 8 = 32 B
+ AR6003_CAL_DATA_PER_FREQ_OLPC calPierData2G[AR6003_NUM_2G_CAL_PIERS]; // 4 * 3 = 12 B
+ // ATE CAL data from OTP
+ AR6003_CAL_DATA_PER_CHIP calPerChip; // 6 B
+ // future expansion of CAL data
+ AR6003_PSAT_CAL_PARMS psatCAL; // 14B
+
+ // target power
+ AR6003_CAL_TARGET_POWER_LEG calTargetPower5G[AR6003_NUM_5G_20_TARGET_POWERS]; // 5 * 8 = 40 B
+ AR6003_CAL_TARGET_POWER_HT calTargetPower5GHT20[AR6003_NUM_5G_20_TARGET_POWERS]; // 9 * 8 = 72 B
+ AR6003_CAL_TARGET_POWER_HT calTargetPower5GHT40[AR6003_NUM_5G_40_TARGET_POWERS]; // 9 * 8 = 72 B
+ AR6003_CAL_TARGET_POWER_LEG calTargetPowerCck[AR6003_NUM_2G_CCK_TARGET_POWERS]; // 5 * 2 = 10 B
+ AR6003_CAL_TARGET_POWER_LEG calTargetPower2G[AR6003_NUM_2G_20_TARGET_POWERS]; // 5 * 3 = 15 B
+ AR6003_CAL_TARGET_POWER_HT calTargetPower2GHT20[AR6003_NUM_2G_20_TARGET_POWERS]; // 9 * 3 = 27 B
+ AR6003_CAL_TARGET_POWER_HT calTargetPower2GHT40[AR6003_NUM_2G_40_TARGET_POWERS]; // 9 * 3 = 27 B // 263B
+ uint8_t psatTuneParmsAlt4_H; // 1 B // 264B
+ // CTL
+ uint8_t ctlIndex[AR6003_NUM_CTLS]; // 21 B
+ uint8_t psatTuneParmsAlt4_L; // 1 B
+ uint16_t psatTuneParmsAlt2; // 2 B
+ AR6003_CAL_CTL_DATA ctlData[AR6003_NUM_CTLS]; // 16 * 21 = 336 B // 360B
+ // total: 1024B
+ uint8_t calFreqPier5GExpanded[AR6003_NUM_5G_CAL_PIERS_EXPANDED]; // 32 B
+ uint8_t calFreqPier2GExpanded[AR6003_NUM_2G_CAL_PIERS_EXPANDED]; // 16 B
+ AR6003_CAL_DATA_PER_FREQ_OLPC_EXPANDED calPierData5GExpanded[AR6003_NUM_5G_CAL_PIERS_EXPANDED]; // 14 * 32 = 448 B
+ AR6003_CAL_DATA_PER_FREQ_OLPC_EXPANDED calPierData2GExpanded[AR6003_NUM_2G_CAL_PIERS_EXPANDED]; // 14 * 16 = 224 B
+
+ AR6003_ATE_PROVIDED_DATA ateProvidedData; // 24B
+
+ int8_t calTgtPwrBkoff2GLeg[TGTPWR_LEG_LAST]; // 4B
+ int8_t calTgtPwrBkoff2GHT20[TGTPWR_HT_LAST]; // 8B
+ int8_t calTgtPwrBkoff2GHT40[TGTPWR_HT_LAST]; // 8B
+
+ uint16_t psatTuneParmsAlt3; // 2B
+ uint16_t checksumExpanded; // 2B
+ // total: 768B
+ AR6003_CAL_DATA_PER_FREQ_OLPC_FE_DELTA calDataFEDelta5G[AR6003_NUM_5G_CAL_PIERS_EXPANDED]; // 2 * 32 = 64 B
+ AR6003_CAL_DATA_PER_FREQ_OLPC_FE_DELTA calDataFEDelta2G[AR6003_NUM_2G_CAL_PIERS_EXPANDED]; // 2 * 16 = 32 B
+ uint16_t psatTuneParmsAlt7; // 2B
+ uint16_t psatTuneParmsAlt8; // 2B
+ uint16_t psatTuneParmsAlt9; // 2B
+ int16_t cmacOlpcPsatDeltaGuMid_t10; // 2B
+ int16_t cmacOlpcPsatDeltaGuHigh_t10; // 2B
+ uint16_t psatTuneParmsAltSet[10]; // 20B
+ int8_t psatTuneParmsOlpcPsatCmacDelta[20]; // 20B
+ uint8_t padding5[42]; // 42B
+ //uint32_t pllClkModa;
+ AR6003_STICKY_REG_TABLE stickyRegTable[STICKY_REG_TBL_SIZE_MAX]; // 64B
+ //uint8_t stickyRegTableSize;
+ uint16_t psatTuneParmsAlt5; // 2B
+ uint16_t psatTuneParmsAlt6; // 2B
+ //uint16_t checksum0CAL;
+ // total: 256B
+} POSTPACK AR6003_EEPROM; // 1024 + 768 + 256 = 2048B
+
+#endif //_AR6003_EEPROM_STRUCT_H_
diff --git a/ath6kl-tcmd/testcmd.h b/ath6kl-tcmd/testcmd.h
new file mode 100644
index 0000000..f543e39
--- /dev/null
+++ b/ath6kl-tcmd/testcmd.h
@@ -0,0 +1,364 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#ifndef TESTCMD_H_
+#define TESTCMD_H_
+
+#include <stdint.h>
+
+#ifdef AR6002_REV2
+#define TCMD_MAX_RATES 12
+#else
+#define TCMD_MAX_RATES 28
+#endif
+
+#define PREPACK
+#define POSTPACK __attribute__ ((packed))
+
+#define ATH_MAC_LEN 6
+#define TC_CMDS_SIZE_MAX 256
+
+typedef enum {
+ ZEROES_PATTERN = 0,
+ ONES_PATTERN,
+ REPEATING_10,
+ PN7_PATTERN,
+ PN9_PATTERN,
+ PN15_PATTERN
+} TX_DATA_PATTERN;
+
+/* Continous tx
+ mode : TCMD_CONT_TX_OFF - Disabling continous tx
+ TCMD_CONT_TX_SINE - Enable continuous unmodulated tx
+ TCMD_CONT_TX_FRAME- Enable continuous modulated tx
+ freq : Channel freq in Mhz. (e.g 2412 for channel 1 in 11 g)
+dataRate: 0 - 1 Mbps
+ 1 - 2 Mbps
+ 2 - 5.5 Mbps
+ 3 - 11 Mbps
+ 4 - 6 Mbps
+ 5 - 9 Mbps
+ 6 - 12 Mbps
+ 7 - 18 Mbps
+ 8 - 24 Mbps
+ 9 - 36 Mbps
+ 10 - 28 Mbps
+ 11 - 54 Mbps
+ txPwr: Tx power in dBm[5 -11] for unmod Tx, [5-14] for mod Tx
+antenna: 1 - one antenna
+ 2 - two antenna
+Note : Enable/disable continuous tx test cmd works only when target is awake.
+*/
+
+typedef enum {
+ TCMD_CONT_TX_OFF = 0,
+ TCMD_CONT_TX_SINE,
+ TCMD_CONT_TX_FRAME,
+ TCMD_CONT_TX_TX99,
+ TCMD_CONT_TX_TX100,
+ TCMD_CONT_TX_OFFSETTONE,
+} TCMD_CONT_TX_MODE;
+
+typedef enum {
+ TCMD_WLAN_MODE_NOHT = 0,
+ TCMD_WLAN_MODE_HT20 = 1,
+ TCMD_WLAN_MODE_HT40PLUS = 2,
+ TCMD_WLAN_MODE_HT40MINUS = 3,
+ TCMD_WLAN_MODE_CCK = 4,
+
+ TCMD_WLAN_MODE_MAX,
+ TCMD_WLAN_MODE_INVALID = TCMD_WLAN_MODE_MAX
+} TCMD_WLAN_MODE;
+
+typedef enum {
+ TPC_TX_PWR = 0,
+ TPC_FORCED_GAIN,
+ TPC_TGT_PWR
+} TPC_TYPE;
+
+typedef PREPACK struct {
+ uint32_t testCmdId;
+ uint32_t mode;
+ uint32_t freq;
+ uint32_t dataRate;
+ int32_t txPwr;
+ uint32_t antenna;
+ uint32_t enANI;
+ uint32_t scramblerOff;
+ uint32_t aifsn;
+ uint16_t pktSz;
+ uint16_t txPattern;
+ uint32_t shortGuard;
+ uint32_t numPackets;
+ uint32_t wlanMode;
+ uint32_t tpcm;
+} POSTPACK TCMD_CONT_TX;
+
+#define TCMD_TXPATTERN_ZERONE 0x1
+#define TCMD_TXPATTERN_ZERONE_DIS_SCRAMBLE 0x2
+
+/* Continuous Rx
+ act: TCMD_CONT_RX_PROMIS - promiscuous mode (accept all incoming frames)
+ TCMD_CONT_RX_FILTER - filter mode (accept only frames with dest
+ address equal specified
+ mac address (set via act =3)
+ TCMD_CONT_RX_REPORT off mode (disable cont rx mode and get the
+ report from the last cont
+ Rx test)
+
+ TCMD_CONT_RX_SETMAC - set MacAddr mode (sets the MAC address for the
+ target. This Overrides
+ the default MAC address.)
+
+*/
+typedef enum {
+ TCMD_CONT_RX_PROMIS = 0,
+ TCMD_CONT_RX_FILTER,
+ TCMD_CONT_RX_REPORT,
+ TCMD_CONT_RX_SETMAC,
+ TCMD_CONT_RX_SET_ANT_SWITCH_TABLE,
+ TC_CMD_RESP,
+ TCMD_CONT_RX_GETMAC,
+} TCMD_CONT_RX_ACT;
+
+typedef PREPACK struct {
+ uint32_t testCmdId;
+ uint32_t act;
+ uint32_t enANI;
+ PREPACK union {
+ struct PREPACK TCMD_CONT_RX_PARA {
+ uint32_t freq;
+ uint32_t antenna;
+ uint32_t wlanMode;
+ } POSTPACK para;
+ struct PREPACK TCMD_CONT_RX_REPORT {
+ uint32_t totalPkt;
+ int32_t rssiInDBm;
+ uint32_t crcErrPkt;
+ uint32_t secErrPkt;
+ uint16_t rateCnt[TCMD_MAX_RATES];
+ uint16_t rateCntShortGuard[TCMD_MAX_RATES];
+ } POSTPACK report;
+ struct PREPACK TCMD_CONT_RX_MAC {
+ char addr[ATH_MAC_LEN];
+ char btaddr[ATH_MAC_LEN];
+ uint16_t regDmn[2];
+ uint32_t otpWriteFlag;
+ } POSTPACK mac;
+ struct PREPACK TCMD_CONT_RX_ANT_SWITCH_TABLE {
+ uint32_t antswitch1;
+ uint32_t antswitch2;
+ } POSTPACK antswitchtable;
+ } POSTPACK u;
+} POSTPACK TCMD_CONT_RX;
+
+/* Force sleep/wake test cmd
+ mode: TCMD_PM_WAKEUP - Wakeup the target
+ TCMD_PM_SLEEP - Force the target to sleep.
+ */
+typedef enum {
+ TCMD_PM_WAKEUP = 1, /* be consistent with target */
+ TCMD_PM_SLEEP,
+ TCMD_PM_DEEPSLEEP
+} TCMD_PM_MODE;
+
+typedef enum {
+ TC_CMDS_VERSION_RESERVED=0,
+ TC_CMDS_VERSION_MDK,
+ TC_CMDS_VERSION_TS,
+ TC_CMDS_VERSION_LAST,
+} TC_CMDS_VERSION;
+
+typedef enum {
+ TC_CMDS_TS =0,
+ TC_CMDS_CAL,
+ TC_CMDS_TPCCAL = TC_CMDS_CAL,
+ TC_CMDS_TPCCAL_WITH_OTPWRITE,
+ TC_CMDS_OTPDUMP,
+ TC_CMDS_OTPSTREAMWRITE,
+ TC_CMDS_EFUSEDUMP,
+ TC_CMDS_EFUSEWRITE,
+ TC_CMDS_READTHERMAL,
+ TC_CMDS_PM_CAL,
+ TC_CMDS_PSAT_CAL,
+ TC_CMDS_PSAT_CAL_RESULT,
+ TC_CMDS_CAL_PWRS,
+ TC_CMDS_WRITE_CAL_2_OTP,
+ TC_CMDS_CHAR_PSAT,
+ TC_CMDS_CHAR_PSAT_RESULT,
+ TC_CMDS_PM_CAL_RESULT,
+ TC_CMDS_SINIT_WAIT,
+ TC_CMDS_COUNT
+} TC_CMDS_ACT;
+
+typedef PREPACK struct {
+ uint32_t testCmdId;
+ uint32_t act;
+ PREPACK union {
+ uint32_t enANI; // to be identical to CONT_RX struct
+ struct PREPACK {
+ uint16_t length;
+ uint8_t version;
+ uint8_t bufLen;
+ } POSTPACK parm;
+ } POSTPACK u;
+} POSTPACK TC_CMDS_HDR;
+
+typedef PREPACK struct {
+ TC_CMDS_HDR hdr;
+ char buf[TC_CMDS_SIZE_MAX];
+} POSTPACK TC_CMDS;
+
+typedef PREPACK struct {
+ uint32_t testCmdId;
+ uint32_t regAddr;
+ uint32_t val;
+ uint16_t flag;
+} POSTPACK TCMD_SET_REG;
+
+typedef PREPACK struct {
+ uint32_t testCmdId;
+ uint32_t mode;
+} POSTPACK TCMD_PM;
+
+typedef enum {
+ TCMD_CONT_TX_ID,
+ TCMD_CONT_RX_ID,
+ TCMD_PM_ID,
+ TC_CMDS_ID,
+ TCMD_SET_REG_ID,
+
+ /*For synergy purpose we added the following tcmd id but these
+ tcmd's will not go to the firmware instead we will write values
+ to the NV area */
+
+ TCMD_NIC_MAC = 100,
+ TCMD_CAL_FILE_INDEX = 101,
+} TCMD_ID;
+
+typedef PREPACK struct
+{
+ uint32_t testCmdId;
+ char mac_address[ATH_MAC_LEN];
+} POSTPACK TCMD_NIC_MAC_S;
+
+typedef PREPACK struct
+{
+ uint32_t testCmdId;
+ uint32_t cal_file_index;
+} POSTPACK TCMD_CAL_FILE_INDEX_S;
+
+typedef PREPACK union {
+ TCMD_CONT_TX contTx;
+ TCMD_CONT_RX contRx;
+ TCMD_PM pm;
+ // New test cmds from ART/MDK ...
+ TC_CMDS tcCmds;
+ TCMD_SET_REG setReg;
+} POSTPACK TEST_CMD;
+
+/* New structure for selfinit */
+typedef enum {
+ TC_MSG_RESERVED,
+ TC_MSG_PSAT_CAL_RESULTS,
+ TC_MSG_CAL_POWER,
+ TC_MSG_CHAR_PSAT_RESULTS,
+ TC_MSG_PM_CAL_RESULTS,
+ TC_MSG_PSAT_CAL_ACK,
+ TC_MSG_COUNT
+} TC_MSG_ID;
+
+typedef PREPACK struct {
+ int8_t olpcGainDelta_diff;
+ int8_t olpcGainDelta_abs;
+ uint8_t thermCalVal;
+ uint8_t numTryBF;
+ uint32_t cmac_olpc;
+ uint32_t cmac_psat;
+ uint16_t cmac_olpc_pcdac;
+ uint16_t cmac_psat_pcdac;
+ int16_t lineSlope;
+ int16_t lineVariance;
+ uint16_t psatParm;
+ uint8_t reserved[2];
+} POSTPACK OLPCGAIN_THERM_DUPLET;
+
+#define WHAL_NUM_11G_CAL_PIERS_EXT 16
+#define WHAL_NUM_11A_CAL_PIERS_EXT 32
+#define PSAT_WHAL_NUM_11G_CAL_PIERS_MAX 3
+#define PSAT_WHAL_NUM_11A_CAL_PIERS_MAX 5
+#define NUM_PSAT_CHAR_PARMS 7
+#define _MAX_TX_GAIN_ENTRIES 32
+
+typedef PREPACK struct {
+ OLPCGAIN_THERM_DUPLET olpcGainTherm2G[PSAT_WHAL_NUM_11G_CAL_PIERS_MAX];
+ OLPCGAIN_THERM_DUPLET olpcGainTherm5G[PSAT_WHAL_NUM_11A_CAL_PIERS_MAX];
+} POSTPACK PSAT_CAL_RESULTS;
+
+typedef PREPACK struct {
+ uint32_t cmac_i[_MAX_TX_GAIN_ENTRIES];
+ uint8_t pcdac[_MAX_TX_GAIN_ENTRIES];
+
+ uint8_t freq;
+ uint8_t an_txrf3_rdiv2g;
+ uint8_t an_txrf3_pdpredist2g;
+ uint8_t an_rxtx2_mxrgain;
+ uint8_t an_rxrf_bias1_pwd_ic25mxr2gh;
+ uint8_t an_bias2_pwd_ic25rxrf;
+ uint8_t an_bb1_i2v_curr2x;
+ uint8_t an_txrf3_capdiv2g;
+
+} POSTPACK CHAR_PSAT_RESULTS;
+
+typedef PREPACK struct {
+ int16_t txPwr2G_t10[WHAL_NUM_11G_CAL_PIERS_EXT];
+ int16_t txPwr5G_t10[WHAL_NUM_11A_CAL_PIERS_EXT];
+} POSTPACK CAL_TXPWR;
+
+typedef PREPACK struct {
+ uint8_t thermCalVal;
+ uint8_t future[3];
+} POSTPACK PM_CAL_RESULTS;
+
+typedef PREPACK struct {
+ TC_MSG_ID msgId;
+ PREPACK union {
+ PSAT_CAL_RESULTS psatCalResults;
+ CAL_TXPWR txPwrs;
+ CHAR_PSAT_RESULTS psatCharResults;
+ PM_CAL_RESULTS pmCalResults;
+ } POSTPACK msg;
+
+} POSTPACK TC_MSG;
+
+typedef struct _psat_sweep_table {
+ uint8_t an_txrf3_rdiv2g;
+ uint8_t an_txrf3_pdpredist2g;
+ uint8_t an_rxtx2_mxrgain;
+ uint8_t an_rxrf_bias1_pwd_ic25mxr2gh;
+ uint8_t an_bias2_pwd_ic25rxrf;
+ uint8_t an_bb1_i2v_curr2x;
+ uint8_t an_txrf3_capdiv2g;
+ int8_t olpcPsatCmacDelta;
+ uint16_t psatParm;
+ uint16_t padding2;
+} PSAT_SWEEP_TABLE;
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* TESTCMD_H_ */
diff --git a/ath6kl-wmiconfig/Android.mk b/ath6kl-wmiconfig/Android.mk
new file mode 100755
index 0000000..9f62851
--- /dev/null
+++ b/ath6kl-wmiconfig/Android.mk
@@ -0,0 +1,28 @@
+#------------------------------------------------
+# Copyright (c) 2012 Qualcomm Atheros, Inc..
+# All Rights Reserved.
+# Qualcomm Atheros Confidential and Proprietary.
+#------------------------------------------------
+
+LOCAL_PATH := $(call my-dir)
+
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := wmiconfig
+LOCAL_C_INCLUDES := \
+ $(TARGET_OUT_HEADERS)/libtcmd \
+ $(LOCAL_PATH)/include \
+ $(LOCAL_PATH)/../../bionic/libc/kernel/common \
+ #$(TARGET_OUT_INTERMEDIATES)/KERNEL_OBJ/usr/include \
+
+
+LOCAL_CFLAGS+=-DUSER_KEYS
+LOCAL_SRC_FILES:= wmiconfig.c
+
+LOCAL_MODULE_TAGS := debug eng optional
+LOCAL_SHARED_LIBRARIES += libcutils
+LOCAL_SHARED_LIBRARIES += libnl_2
+LOCAL_STATIC_LIBRARIES += libtcmd
+include $(BUILD_EXECUTABLE)
+
+
diff --git a/ath6kl-wmiconfig/Makefile b/ath6kl-wmiconfig/Makefile
new file mode 100755
index 0000000..10d4832
--- /dev/null
+++ b/ath6kl-wmiconfig/Makefile
@@ -0,0 +1,31 @@
+#------------------------------------------------
+# Copyright (c) 2012 Qualcomm Atheros, Inc..
+# All Rights Reserved.
+# Qualcomm Atheros Confidential and Proprietary.
+#------------------------------------------------
+-include .config
+
+LDFLAGS += $(shell pkg-config --cflags --libs glib-2.0)
+
+CC :=$(ATH_CROSS_COMPILE_TYPE)gcc
+APP=wmiconfig
+
+NLLIBNAME = libnl-1
+LIBTCMD_DIR := ../libtcmd
+
+PREFIX ?= /usr
+SBINDIR ?= $(PREFIX)/sbin
+INSTALL ?= install
+
+
+override LDFLAGS += -ltcmd $(shell pkg-config --libs $(NLLIBNAME)) -lrt
+override CFLAGS += $(shell pkg-config --cflags $(NLLIBNAME)) -I$(LIBTCMD_DIR) -L$(LIBTCMD_DIR)
+all:
+ $(CC) -Wall -DUSER_KEYS -g -I$(KERNEL_SRC)/include -Iinclude wmiconfig.c -o $(APP) $(CFLAGS) $(LDFLAGS)
+
+install: wmiconfig
+ install -m 755 wmiconfig $(DESTDIR)$(SBINDIR)
+
+
+clean:
+ $(RM) $(APP)
diff --git a/ath6kl-wmiconfig/include/a_config.h b/ath6kl-wmiconfig/include/a_config.h
new file mode 100755
index 0000000..93d3d08
--- /dev/null
+++ b/ath6kl-wmiconfig/include/a_config.h
@@ -0,0 +1,44 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+//==============================================================================
+// This file contains software configuration options that enables
+// specific software "features"
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_CONFIG_H_
+#define _A_CONFIG_H_
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/config.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/config.h"
+#endif
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+//#include "/config_linux.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/config_rexos.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include "../os/windows/include/config.h"
+#pragma warning( disable:4242)
+#pragma warning( disable:4100)
+#pragma warning( disable:4189)
+#pragma warning( disable:4244)
+#pragma warning( disable:4701)
+#pragma warning( disable:4389)
+#pragma warning( disable:4057)
+#pragma warning( disable:28193)
+#endif
+
+#endif
+
diff --git a/ath6kl-wmiconfig/include/a_osapi.h b/ath6kl-wmiconfig/include/a_osapi.h
new file mode 100755
index 0000000..6396255
--- /dev/null
+++ b/ath6kl-wmiconfig/include/a_osapi.h
@@ -0,0 +1,45 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+//==============================================================================
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_OSAPI_H_
+#define _A_OSAPI_H_
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "osapi_linux.h"
+#endif
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/osapi.h"
+#include "../os/windows/include/netbuf.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/osapi.h"
+#include "../os/windows/include/netbuf.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/osapi_rexos.h"
+#endif
+
+#if defined ART_WIN
+#include "../os/win_art/include/osapi_win.h"
+#include "../os/win_art/include/netbuf.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include "../os/windows/include/win/osapi_win.h"
+#include "../os/windows/include/netbuf.h"
+#endif
+
+#endif /* _OSAPI_H_ */
+
diff --git a/ath6kl-wmiconfig/include/a_types.h b/ath6kl-wmiconfig/include/a_types.h
new file mode 100755
index 0000000..d489337
--- /dev/null
+++ b/ath6kl-wmiconfig/include/a_types.h
@@ -0,0 +1,41 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+//==============================================================================
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_TYPES_H_
+#define _A_TYPES_H_
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "athtypes_linux.h"
+#endif
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/athtypes.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/athtypes.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/athtypes_rexos.h"
+#endif
+
+#if defined ART_WIN
+#include "../os/win_art/include/athtypes_win.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include <athtypes_win.h>
+#endif
+
+#endif /* _ATHTYPES_H_ */
+
diff --git a/ath6kl-wmiconfig/include/athdefs.h b/ath6kl-wmiconfig/include/athdefs.h
new file mode 100755
index 0000000..8ba5945
--- /dev/null
+++ b/ath6kl-wmiconfig/include/athdefs.h
@@ -0,0 +1,68 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+#ifndef __ATHDEFS_H__
+#define __ATHDEFS_H__
+
+/*
+ * This file contains definitions that may be used across both
+ * Host and Target software. Nothing here is module-dependent
+ * or platform-dependent.
+ */
+
+/*
+ * Generic error codes that can be used by hw, sta, ap, sim, dk
+ * and any other environments. Since these are enums, feel free to
+ * add any more codes that you need.
+ */
+
+typedef enum {
+ A_ERROR = -1, /* Generic error return */
+ A_OK = 0, /* success */
+ /* Following values start at 1 */
+ A_DEVICE_NOT_FOUND, /* not able to find PCI device */
+ A_NO_MEMORY, /* not able to allocate memory, not available */
+ A_MEMORY_NOT_AVAIL, /* memory region is not free for mapping */
+ A_NO_FREE_DESC, /* no free descriptors available */
+ A_BAD_ADDRESS, /* address does not match descriptor */
+ A_WIN_DRIVER_ERROR, /* used in NT_HW version, if problem at init */
+ A_REGS_NOT_MAPPED, /* registers not correctly mapped */
+ A_EPERM, /* Not superuser */
+ A_EACCES, /* Access denied */
+ A_ENOENT, /* No such entry, search failed, etc. */
+ A_EEXIST, /* The object already exists (can't create) */
+ A_EFAULT, /* Bad address fault */
+ A_EBUSY, /* Object is busy */
+ A_EINVAL, /* Invalid parameter */
+ A_EMSGSIZE, /* Inappropriate message buffer length */
+ A_ECANCELED, /* Operation canceled */
+ A_ENOTSUP, /* Operation not supported */
+ A_ECOMM, /* Communication error on send */
+ A_EPROTO, /* Protocol error */
+ A_ENODEV, /* No such device */
+ A_EDEVNOTUP, /* device is not UP */
+ A_NO_RESOURCE, /* No resources for requested operation */
+ A_HARDWARE, /* Hardware failure */
+ A_PENDING, /* Asynchronous routine; will send up results la
+ter (typically in callback) */
+ A_EBADCHANNEL, /* The channel cannot be used */
+ A_DECRYPT_ERROR, /* Decryption error */
+ A_PHY_ERROR, /* RX PHY error */
+ A_CONSUMED /* Object was consumed */
+} A_STATUS;
+
+#define A_SUCCESS(x) (x == A_OK)
+#define A_FAILED(x) (!A_SUCCESS(x))
+
+#ifndef TRUE
+#define TRUE 1
+#endif
+
+#ifndef FALSE
+#define FALSE 0
+#endif
+
+#endif /* __ATHDEFS_H__ */
+
diff --git a/ath6kl-wmiconfig/include/athdrv_linux.h b/ath6kl-wmiconfig/include/athdrv_linux.h
new file mode 100755
index 0000000..71a7578
--- /dev/null
+++ b/ath6kl-wmiconfig/include/athdrv_linux.h
@@ -0,0 +1,1461 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+#ifndef _ATHDRV_LINUX_H
+#define _ATHDRV_LINUX_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+/*
+ * There are two types of ioctl's here: Standard ioctls and
+ * eXtended ioctls. All extended ioctls (XIOCTL) are multiplexed
+ * off of the single ioctl command, AR6000_IOCTL_EXTENDED. The
+ * arguments for every XIOCTL starts with a 32-bit command word
+ * that is used to select which extended ioctl is in use. After
+ * the command word are command-specific arguments.
+ */
+
+/* Linux standard Wireless Extensions, private ioctl interfaces */
+#define IEEE80211_IOCTL_SETPARAM (SIOCIWFIRSTPRIV+0)
+#define IEEE80211_IOCTL_SETKEY (SIOCIWFIRSTPRIV+1)
+#define IEEE80211_IOCTL_DELKEY (SIOCIWFIRSTPRIV+2)
+#define IEEE80211_IOCTL_SETMLME (SIOCIWFIRSTPRIV+3)
+#define IEEE80211_IOCTL_ADDPMKID (SIOCIWFIRSTPRIV+4)
+#define IEEE80211_IOCTL_SETOPTIE (SIOCIWFIRSTPRIV+5)
+//#define IEEE80211_IOCTL_GETPARAM (SIOCIWFIRSTPRIV+6)
+//#define IEEE80211_IOCTL_SETWMMPARAMS (SIOCIWFIRSTPRIV+7)
+//#define IEEE80211_IOCTL_GETWMMPARAMS (SIOCIWFIRSTPRIV+8)
+//#define IEEE80211_IOCTL_GETOPTIE (SIOCIWFIRSTPRIV+9)
+//#define IEEE80211_IOCTL_SETAUTHALG (SIOCIWFIRSTPRIV+10)
+#define IEEE80211_IOCTL_LASTONE (SIOCIWFIRSTPRIV+10)
+
+
+
+/* ====WMI Ioctls==== */
+/*
+ *
+ * Many ioctls simply provide WMI services to application code:
+ * an application makes such an ioctl call with a set of arguments
+ * that are packaged into the corresponding WMI message, and sent
+ * to the Target.
+ */
+
+#define AR6000_IOCTL_WMI_GETREV (SIOCIWFIRSTPRIV+11)
+/*
+ * arguments:
+ * ar6000_version *revision
+ */
+
+#define AR6000_IOCTL_WMI_SETPWR (SIOCIWFIRSTPRIV+12)
+/*
+ * arguments:
+ * WMI_POWER_MODE_CMD pwrModeCmd (see include/wmi.h)
+ * uses: WMI_SET_POWER_MODE_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SETSCAN (SIOCIWFIRSTPRIV+13)
+/*
+ * arguments:
+ * WMI_SCAN_PARAMS_CMD scanParams (see include/wmi.h)
+ * uses: WMI_SET_SCAN_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SETLISTENINT (SIOCIWFIRSTPRIV+14)
+/*
+ * arguments:
+ * UINT32 listenInterval
+ * uses: WMI_SET_LISTEN_INT_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SETBSSFILTER (SIOCIWFIRSTPRIV+15)
+/*
+ * arguments:
+ * WMI_BSS_FILTER filter (see include/wmi.h)
+ * uses: WMI_SET_BSS_FILTER_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_CHANNELPARAMS (SIOCIWFIRSTPRIV+16)
+/*
+ * arguments:
+ * WMI_CHANNEL_PARAMS_CMD chParams
+ * uses: WMI_SET_CHANNEL_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_PROBEDSSID (SIOCIWFIRSTPRIV+17)
+/*
+ * arguments:
+ * WMI_PROBED_SSID_CMD probedSsids (see include/wmi.h)
+ * uses: WMI_SETPROBED_SSID_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_PMPARAMS (SIOCIWFIRSTPRIV+18)
+/*
+ * arguments:
+ * WMI_POWER_PARAMS_CMD powerParams (see include/wmi.h)
+ * uses: WMI_SET_POWER_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_BADAP (SIOCIWFIRSTPRIV+19)
+/*
+ * arguments:
+ * WMI_ADD_BAD_AP_CMD badAPs (see include/wmi.h)
+ * uses: WMI_ADD_BAD_AP_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_GET_QOS_QUEUE (SIOCIWFIRSTPRIV+20)
+/*
+ * arguments:
+ * ar6000_queuereq queueRequest (see below)
+ */
+
+#define AR6000_IOCTL_WMI_CREATE_QOS (SIOCIWFIRSTPRIV+21)
+/*
+ * arguments:
+ * WMI_CREATE_PSTREAM createPstreamCmd (see include/wmi.h)
+ * uses: WMI_CREATE_PSTREAM_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_DELETE_QOS (SIOCIWFIRSTPRIV+22)
+/*
+ * arguments:
+ * WMI_DELETE_PSTREAM_CMD deletePstreamCmd (see include/wmi.h)
+ * uses: WMI_DELETE_PSTREAM_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_SNRTHRESHOLD (SIOCIWFIRSTPRIV+23)
+/*
+ * arguments:
+ * WMI_SNR_THRESHOLD_PARAMS_CMD thresholdParams (see include/wmi.h)
+ * uses: WMI_SNR_THRESHOLD_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_ERROR_REPORT_BITMASK (SIOCIWFIRSTPRIV+24)
+/*
+ * arguments:
+ * WMI_TARGET_ERROR_REPORT_BITMASK errorReportBitMask (see include/wmi.h)
+ * uses: WMI_TARGET_ERROR_REPORT_BITMASK_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_GET_TARGET_STATS (SIOCIWFIRSTPRIV+25)
+/*
+ * arguments:
+ * TARGET_STATS *targetStats (see below)
+ * uses: WMI_GET_STATISTICS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_ASSOC_INFO (SIOCIWFIRSTPRIV+26)
+/*
+ * arguments:
+ * WMI_SET_ASSOC_INFO_CMD setAssocInfoCmd
+ * uses: WMI_SET_ASSOC_INFO_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_ACCESS_PARAMS (SIOCIWFIRSTPRIV+27)
+/*
+ * arguments:
+ * WMI_SET_ACCESS_PARAMS_CMD setAccessParams (see include/wmi.h)
+ * uses: WMI_SET_ACCESS_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_BMISS_TIME (SIOCIWFIRSTPRIV+28)
+/*
+ * arguments:
+ * UINT32 beaconMissTime
+ * uses: WMI_SET_BMISS_TIME_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_DISC_TIMEOUT (SIOCIWFIRSTPRIV+29)
+/*
+ * arguments:
+ * WMI_DISC_TIMEOUT_CMD disconnectTimeoutCmd (see include/wmi.h)
+ * uses: WMI_SET_DISC_TIMEOUT_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_IBSS_PM_CAPS (SIOCIWFIRSTPRIV+30)
+/*
+ * arguments:
+ * WMI_IBSS_PM_CAPS_CMD ibssPowerMgmtCapsCmd
+ * uses: WMI_SET_IBSS_PM_CAPS_CMDID
+ */
+
+/*
+ * There is a very small space available for driver-private
+ * wireless ioctls. In order to circumvent this limitation,
+ * we multiplex a bunch of ioctls (XIOCTLs) on top of a
+ * single AR6000_IOCTL_EXTENDED ioctl.
+ */
+#define AR6000_IOCTL_EXTENDED (SIOCIWFIRSTPRIV+31)
+
+typedef enum {
+ AR6000_XIOCTL_BMI_DONE = 1,
+ AR6000_XIOCTL_BMI_READ_MEMORY,
+ AR6000_XIOCTL_BMI_WRITE_MEMORY,
+ AR6000_XIOCTL_BMI_EXECUTE,
+ AR6000_XIOCTL_BMI_SET_APP_START,
+ AR6000_XIOCTL_BMI_READ_SOC_REGISTER,
+ AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER,
+ AR6000_XIOCTL_BMI_TEST,
+ AR6000_XIOCTL_UNUSED9,
+ AR6000_XIOCTL_UNUSED10, /* 10 */
+ AR6000_XIOCTL_UNUSED11,
+ AR6000_XIOCTL_FORCE_TARGET_RESET,
+ AR6000_XIOCTL_HTC_RAW_OPEN,
+ AR6000_XIOCTL_HTC_RAW_CLOSE,
+ AR6000_XIOCTL_HTC_RAW_READ,
+ AR6000_XIOCTL_HTC_RAW_WRITE,
+ AR6000_XIOCTL_CHECK_TARGET_READY,
+ AR6000_XIOCTL_GPIO_OUTPUT_SET,
+ AR6000_XIOCTL_GPIO_INPUT_GET,
+ AR6000_XIOCTL_GPIO_REGISTER_SET, /* 20 */
+ AR6000_XIOCTL_GPIO_REGISTER_GET,
+ AR6000_XIOCTL_GPIO_INTR_ACK,
+ AR6000_XIOCTL_GPIO_INTR_WAIT,
+ AR6000_XIOCTL_SET_ADHOC_BSSID,
+ AR6000_XIOCTL_UNUSED25,
+ AR6000_XIOCTL_UNUSED26,
+ AR6000_XIOCTL_SET_BEACON_INTVAL,
+ IEEE80211_IOCTL_SETAUTHALG,
+ AR6000_XIOCTL_SET_VOICE_PKT_SIZE,
+ AR6000_XIOCTL_SET_MAX_SP, /* 30 */
+ AR6000_XIOCTL_WMI_GET_ROAM_TBL,
+ AR6000_XIOCTL_WMI_SET_ROAM_CTRL,
+ AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS,
+ AR6000_XIOCTRL_WMI_GET_POWER_MODE,
+ AR6000_XIOCTRL_WMI_SET_WLAN_STATE,
+ AR6000_XIOCTL_WMI_GET_ROAM_DATA,
+ AR6000_XIOCTL_WMI_SETRETRYLIMITS,
+ AR6000_XIOCTL_TCMD_CONT_TX,
+ AR6000_XIOCTL_TCMD_CONT_RX,
+ AR6000_XIOCTL_TCMD_PM, /* 40 */
+ AR6000_XIOCTL_WMI_STARTSCAN,
+ AR6000_XIOCTL_WMI_SETFIXRATES,
+ AR6000_XIOCTL_WMI_GETFIXRATES,
+ AR6000_XIOCTL_WMI_SET_RSSITHRESHOLD,
+ AR6000_XIOCTL_WMI_CLR_RSSISNR,
+ AR6000_XIOCTL_WMI_SET_LQTHRESHOLD,
+ AR6000_XIOCTL_WMI_SET_RTS,
+ AR6000_XIOCTL_WMI_SET_LPREAMBLE,
+ AR6000_XIOCTL_WMI_SET_AUTHMODE,
+ AR6000_XIOCTL_WMI_SET_REASSOCMODE, /* 50 */
+ AR6000_XIOCTL_WMI_SET_WMM,
+ AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS,
+ AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP,
+ AR6000_XIOCTL_WMI_GET_RD,
+ AR6000_XIOCTL_DIAG_READ,
+ AR6000_XIOCTL_DIAG_WRITE,
+ AR6000_XIOCTL_WMI_SET_TXOP,
+ AR6000_XIOCTL_USER_SETKEYS,
+ AR6000_XIOCTL_WMI_SET_KEEPALIVE,
+ AR6000_XIOCTL_WMI_GET_KEEPALIVE, /* 60 */
+ AR6000_XIOCTL_BMI_ROMPATCH_INSTALL,
+ AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL,
+ AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE,
+ AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE,
+ AR6000_XIOCTL_WMI_SET_APPIE,
+ AR6000_XIOCTL_WMI_SET_MGMT_FRM_RX_FILTER,
+ AR6000_XIOCTL_DBGLOG_CFG_MODULE,
+ AR6000_XIOCTL_DBGLOG_GET_DEBUG_LOGS,
+ AR6000_XIOCTL_WMI_SET_WSC_STATUS = 70, /* 70 */
+ AR6000_XIOCTL_WMI_SET_BT_STATUS,
+ AR6000_XIOCTL_WMI_SET_BT_PARAMS,
+ AR6000_XIOCTL_WMI_SET_HOST_SLEEP_MODE,
+ AR6000_XIOCTL_WMI_SET_WOW_MODE,
+ AR6000_XIOCTL_WMI_GET_WOW_LIST,
+ AR6000_XIOCTL_WMI_ADD_WOW_PATTERN,
+ AR6000_XIOCTL_WMI_DEL_WOW_PATTERN,
+ AR6000_XIOCTL_TARGET_INFO,
+ AR6000_XIOCTL_DUMP_HTC_CREDIT_STATE,
+ AR6000_XIOCTL_TRAFFIC_ACTIVITY_CHANGE, /* 80 */
+ AR6000_XIOCTL_WMI_SET_CONNECT_CTRL_FLAGS,
+ AR6000_XIOCTL_WMI_SET_AKMP_PARAMS,
+ AR6000_XIOCTL_WMI_GET_PMKID_LIST,
+ AR6000_XIOCTL_WMI_SET_PMKID_LIST,
+ AR6000_XIOCTL_WMI_SET_PARAMS,
+ AR6000_XIOCTL_WMI_SET_MCAST_FILTER,
+ AR6000_XIOCTL_WMI_DEL_MCAST_FILTER,
+ AR6000_XIOCTL_UNUSED90 = 90, /* 90 */
+ AR6000_XIOCTL_BMI_LZ_STREAM_START,
+ AR6000_XIOCTL_BMI_LZ_DATA,
+ AR6000_XIOCTL_PROF_CFG,
+ AR6000_XIOCTL_PROF_ADDR_SET,
+ AR6000_XIOCTL_PROF_START,
+ AR6000_XIOCTL_PROF_STOP,
+ AR6000_XIOCTL_PROF_COUNT_GET,
+ AR6000_XIOCTL_WMI_ABORT_SCAN,
+ AR6000_XIOCTL_AP_GET_STA_LIST,
+ AR6000_XIOCTL_AP_HIDDEN_SSID, /* 100 */
+ AR6000_XIOCTL_AP_SET_NUM_STA,
+ AR6000_XIOCTL_AP_SET_ACL_MAC,
+ AR6000_XIOCTL_AP_GET_ACL_LIST,
+ AR6000_XIOCTL_AP_COMMIT_CONFIG,
+ IEEE80211_IOCTL_GETWPAIE,
+ AR6000_XIOCTL_AP_CONN_INACT_TIME,
+ AR6000_XIOCTL_AP_PROT_SCAN_TIME,
+ AR6000_XIOCTL_AP_SET_COUNTRY,
+ AR6000_XIOCTL_AP_SET_DTIM,
+ AR6000_XIOCTL_WMI_TARGET_EVENT_REPORT, /* 110 */
+ AR6000_XIOCTL_SET_IP,
+ AR6000_XIOCTL_AP_SET_ACL_POLICY,
+ AR6000_XIOCTL_AP_CTRL_BSS_COMM,
+ AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO,
+ AR6000_XIOCTL_MODULE_DEBUG_SET_MASK,
+ AR6000_XIOCTL_MODULE_DEBUG_GET_MASK,
+ AR6000_XIOCTL_DUMP_RCV_AGGR_STATS,
+ AR6000_XIOCTL_SET_HT_CAP,
+ AR6000_XIOCTL_SET_HT_OP,
+ AR6000_XIOCTL_AP_GET_STAT, /* 120 */
+ AR6000_XIOCTL_SET_TX_SELECT_RATES,
+ AR6000_XIOCTL_SETUP_AGGR,
+ AR6000_XIOCTL_ALLOW_AGGR,
+ AR6000_XIOCTL_AP_GET_HIDDEN_SSID,
+ AR6000_XIOCTL_AP_GET_COUNTRY,
+ AR6000_XIOCTL_AP_GET_WMODE,
+ AR6000_XIOCTL_AP_GET_DTIM,
+ AR6000_XIOCTL_AP_GET_BINTVL,
+ AR6000_XIOCTL_AP_GET_RTS,
+ AR6000_XIOCTL_DELE_AGGR, /* 130 */
+ AR6000_XIOCTL_FETCH_TARGET_REGS,
+ AR6000_XIOCTL_HCI_CMD,
+ AR6000_XIOCTL_ACL_DATA,
+ AR6000_XIOCTL_WLAN_CONN_PRECEDENCE,
+ AR6000_XIOCTL_AP_SET_11BG_RATESET,
+ AR6000_XIOCTL_WMI_SET_AP_PS,
+ AR6000_XIOCTL_WMI_MCAST_FILTER,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_FE_ANT,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_COLOCATED_BT_DEV,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG, /* 140 */
+ AR6000_XIOCTL_WMI_SET_BTCOEX_SCO_CONFIG,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_A2DP_CONFIG,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_ACLCOEX_CONFIG,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_DEBUG,
+ AR6000_XIOCTL_WMI_SET_BT_OPERATING_STATUS,
+ AR6000_XIOCTL_WMI_GET_BTCOEX_CONFIG,
+ AR6000_XIOCTL_WMI_GET_BTCOEX_STATS,
+ AR6000_XIOCTL_WMI_SET_QOS_SUPP,
+ AR6000_XIOCTL_AP_SET_DFS,
+ AR6000_XIOCTL_WMI_P2P_DISCOVER, /* 150 */
+ AR6000_XIOCTL_WMI_P2P_STOP_FIND,
+ AR6000_XIOCTL_WMI_P2P_CANCEL,
+ AR6000_XIOCTL_WMI_P2P_LISTEN,
+ AR6000_XIOCTL_WMI_P2P_GO_NEG,
+ AR6000_XIOCTL_WMI_P2P_AUTH_GO_NEG,
+ AR6000_XIOCTL_WMI_P2P_REJECT,
+ AR6000_XIOCTL_WMI_P2P_CONFIG,
+ AR6000_XIOCTL_WMI_WPS_CONFIG,
+ AR6000_XIOCTL_WMI_P2P_FINDNODE,
+ AR6000_XIOCTL_WMI_P2P_GRP_INIT, /* 160 */
+ AR6000_XIOCTL_WMI_P2P_GRP_FORMATION_DONE,
+ AR6000_XIOCTL_WMI_P2P_INVITE,
+ AR6000_XIOCTL_WMI_P2P_PROV_DISC,
+ AR6000_XIOCTL_WMI_P2P_SET,
+ AR6000_XIOCTL_WMI_P2P_PEER,
+ AR6000_XIOCTL_WMI_P2P_FLUSH,
+ AR6000_XIOCTL_WMI_GET_GO_PARAMS,
+ AR6000_XIOCTL_P2P_AUTH_INVITE,
+ AR6000_XIOCTL_WMI_P2P_GET_IF_ADDR,
+ AR6000_XIOCTL_WMI_P2P_GET_DEV_ADDR, /* 170 */
+ AR6000_XIOCTL_WMI_P2P_SDPD_TX_CMD,
+ AR6000_XIOTCL_WMI_P2P_SD_CANCEL_REQUEST,
+ AR6000_XIOCTL_SET_BT_HW_POWER_STATE,
+ AR6000_XIOCTL_GET_BT_HW_POWER_STATE,
+ AR6000_XIOCTL_GET_WLAN_SLEEP_STATE,
+ AR6000_XIOCTL_WMI_SET_TX_SGI_PARAM,
+ AR6000_XIOCTL_WMI_ENABLE_WAC_PARAM,
+ AR6000_XIOCTL_WAC_SCAN_REPLY,
+ AR6000_XIOCTL_WMI_WAC_CTRL_REQ,
+ AR6000_XIOCTL_WMI_SET_WPA_OFFLOAD_STATE, /* 180 */
+ AR6000_XIOCTL_WMI_SET_PASSPHRASE,
+ AR6000_XIOCTL_BMI_NVRAM_PROCESS,
+ AR6000_XIOCTL_WMI_SET_DIVERSITY_PARAM,
+ AR6000_XIOCTL_WMI_FORCE_ASSERT,
+ AR6000_XIOCTL_WMI_ENABLE_PKTLOG,
+ AR6000_XIOCTL_WMI_DISABLE_PKTLOG,
+ AR6000_XIOCTL_WMI_GET_PKTLOG,
+ AR6000_XIOCTL_AP_ACS_DISABLE_HI_CHANNELS,
+ AR6000_XIOCTL_TCMD_CMDS,
+ AR6000_XIOCTL_WMI_SET_EXCESS_TX_RETRY_THRES, /* 190 */
+ AR6000_XIOCTL_AP_GET_NUM_STA,
+ AR6000_XIOCTL_SUSPEND_DRIVER,
+ AR6000_XIOCTL_RESUME_DRIVER,
+ AR6000_XIOCTL_GET_SUBMODE,
+ AR6000_XIOCTL_WMI_AP_SET_APSD,
+ AR6000_XIOCTL_TCMD_SETREG,
+ AR6000_XIOCTL_GET_HT_CAP,
+ AR6000_XIOCTL_WMI_GET_P2P_IE, /* 198 */
+ AR6000_XIOCTL_WMI_P2P_GET_OWN_INFO,
+} XTND_IOCLTS;
+
+
+
+///* ====BMI Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_BMI_DONE 1
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_DONE)
+// * uses: BMI_DONE
+// */
+//
+//#define AR6000_XIOCTL_BMI_READ_MEMORY 2
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_READ_MEMORY)
+// * UINT32 address
+// * UINT32 length
+// * }
+// * char results[length]
+// * }
+// * uses: BMI_READ_MEMORY
+// */
+//
+//#define AR6000_XIOCTL_BMI_WRITE_MEMORY 3
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_WRITE_MEMORY)
+// * UINT32 address
+// * UINT32 length
+// * char data[length]
+// * uses: BMI_WRITE_MEMORY
+// */
+//
+//#define AR6000_XIOCTL_BMI_EXECUTE 4
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_EXECUTE)
+// * UINT32 TargetAddress
+// * UINT32 parameter
+// * uses: BMI_EXECUTE
+// */
+//
+//#define AR6000_XIOCTL_BMI_SET_APP_START 5
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_SET_APP_START)
+// * UINT32 TargetAddress
+// * uses: BMI_SET_APP_START
+// */
+//
+//#define AR6000_XIOCTL_BMI_READ_SOC_REGISTER 6
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_READ_SOC_REGISTER)
+// * UINT32 TargetAddress, 32-bit aligned
+// * }
+// * UINT32 result
+// * }
+// * uses: BMI_READ_SOC_REGISTER
+// */
+//
+//#define AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER 7
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER)
+// * UINT32 TargetAddress, 32-bit aligned
+// * UINT32 newValue
+// * }
+// * uses: BMI_WRITE_SOC_REGISTER
+// */
+//
+//#define AR6000_XIOCTL_BMI_TEST 8
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_TEST)
+// * UINT32 address
+// * UINT32 length
+// * UINT32 count
+// */
+//
+//
+//
+///* Historical Host-side DataSet support */
+//#define AR6000_XIOCTL_UNUSED9 9
+//#define AR6000_XIOCTL_UNUSED10 10
+//#define AR6000_XIOCTL_UNUSED11 11
+//
+///* ====Misc Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_FORCE_TARGET_RESET 12
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_FORCE_TARGET_RESET)
+// */
+//
+//
+//#ifdef HTC_RAW_INTERFACE
+///* HTC Raw Interface Ioctls */
+//#define AR6000_XIOCTL_HTC_RAW_OPEN 13
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_OPEN)
+// */
+//
+//#define AR6000_XIOCTL_HTC_RAW_CLOSE 14
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_CLOSE)
+// */
+//
+//#define AR6000_XIOCTL_HTC_RAW_READ 15
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_READ)
+// * UINT32 mailboxID
+// * UINT32 length
+// * }
+// * results[length]
+// * }
+// */
+//
+//#define AR6000_XIOCTL_HTC_RAW_WRITE 16
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_WRITE)
+// * UINT32 mailboxID
+// * UINT32 length
+// * char buffer[length]
+// */
+//#endif /* HTC_RAW_INTERFACE */
+//
+//#define AR6000_XIOCTL_CHECK_TARGET_READY 17
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_CHECK_TARGET_READY)
+// */
+//
+//
+//
+///* ====GPIO (General Purpose I/O) Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_GPIO_OUTPUT_SET 18
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_OUTPUT_SET)
+// * ar6000_gpio_output_set_cmd_s (see below)
+// * uses: WMIX_GPIO_OUTPUT_SET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_INPUT_GET 19
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_INPUT_GET)
+// * uses: WMIX_GPIO_INPUT_GET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_REGISTER_SET 20
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_REGISTER_SET)
+// * ar6000_gpio_register_cmd_s (see below)
+// * uses: WMIX_GPIO_REGISTER_SET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_REGISTER_GET 21
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_REGISTER_GET)
+// * ar6000_gpio_register_cmd_s (see below)
+// * uses: WMIX_GPIO_REGISTER_GET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_INTR_ACK 22
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_INTR_ACK)
+// * ar6000_cpio_intr_ack_cmd_s (see below)
+// * uses: WMIX_GPIO_INTR_ACK_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_INTR_WAIT 23
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_INTR_WAIT)
+// */
+//
+//
+//
+///* ====more wireless commands==== */
+//
+//#define AR6000_XIOCTL_SET_ADHOC_BSSID 24
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_ADHOC_BSSID)
+// * WMI_SET_ADHOC_BSSID_CMD setAdHocBssidCmd (see include/wmi.h)
+// */
+//
+//#define AR6000_XIOCTL_SET_OPT_MODE 25
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_OPT_MODE)
+// * WMI_SET_OPT_MODE_CMD setOptModeCmd (see include/wmi.h)
+// * uses: WMI_SET_OPT_MODE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_OPT_SEND_FRAME 26
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_OPT_SEND_FRAME)
+// * WMI_OPT_TX_FRAME_CMD optTxFrameCmd (see include/wmi.h)
+// * uses: WMI_OPT_TX_FRAME_CMDID
+// */
+//
+//#define AR6000_XIOCTL_SET_BEACON_INTVAL 27
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_BEACON_INTVAL)
+// * WMI_BEACON_INT_CMD beaconIntCmd (see include/wmi.h)
+// * uses: WMI_SET_BEACON_INT_CMDID
+// */
+//
+//
+//#define IEEE80211_IOCTL_SETAUTHALG 28
+//
+//
+//#define AR6000_XIOCTL_SET_VOICE_PKT_SIZE 29
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_VOICE_PKT_SIZE)
+// * WMI_SET_VOICE_PKT_SIZE_CMD setVoicePktSizeCmd (see include/wmi.h)
+// * uses: WMI_SET_VOICE_PKT_SIZE_CMDID
+// */
+//
+//
+//#define AR6000_XIOCTL_SET_MAX_SP 30
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_MAX_SP)
+// * WMI_SET_MAX_SP_LEN_CMD maxSPLen(see include/wmi.h)
+// * uses: WMI_SET_MAX_SP_LEN_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_ROAM_TBL 31
+//
+//#define AR6000_XIOCTL_WMI_SET_ROAM_CTRL 32
+//
+//#define AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS 33
+//
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS)
+// * WMI_SET_POWERSAVE_TIMERS_CMD powerSaveTimers(see include/wmi.h)
+// * WMI_SET_POWERSAVE_TIMERS_CMDID
+// */
+//
+//#define AR6000_XIOCTRL_WMI_GET_POWER_MODE 34
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTRL_WMI_GET_POWER_MODE)
+// */
+//
+//#define AR6000_XIOCTRL_WMI_SET_WLAN_STATE 35
+
+typedef enum {
+ WLAN_DISABLED,
+ WLAN_ENABLED
+} AR6000_WLAN_STATE;
+
+///*
+// * arguments:
+// * enable/disable
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_ROAM_DATA 36
+//
+//#define AR6000_XIOCTL_WMI_SETRETRYLIMITS 37
+///*
+// * arguments:
+// * WMI_SET_RETRY_LIMITS_CMD ibssSetRetryLimitsCmd
+// * uses: WMI_SET_RETRY_LIMITS_CMDID
+// */
+//
+//#ifdef CONFIG_HOST_TCMD_SUPPORT
+///* ====extended commands for radio test ==== */
+//
+//#define AR6000_XIOCTL_TCMD_CONT_TX 38
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_CONT_TX)
+// * WMI_TCMD_CONT_TX_CMD contTxCmd (see include/wmi.h)
+// * uses: WMI_TCMD_CONT_TX_CMDID
+// */
+//
+//#define AR6000_XIOCTL_TCMD_CONT_RX 39
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_CONT_RX)
+// * WMI_TCMD_CONT_RX_CMD rxCmd (see include/wmi.h)
+// * uses: WMI_TCMD_CONT_RX_CMDID
+// */
+//
+//#define AR6000_XIOCTL_TCMD_PM 40
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_PM)
+// * WMI_TCMD_PM_CMD pmCmd (see include/wmi.h)
+// * uses: WMI_TCMD_PM_CMDID
+// */
+//
+//#endif /* CONFIG_HOST_TCMD_SUPPORT */
+//
+//#define AR6000_XIOCTL_WMI_STARTSCAN 41
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_STARTSCAN)
+// * UINT8 scanType
+// * UINT8 scanConnected
+// * A_BOOL forceFgScan
+// * uses: WMI_START_SCAN_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SETFIXRATES 42
+//
+//#define AR6000_XIOCTL_WMI_GETFIXRATES 43
+//
+//
+//#define AR6000_XIOCTL_WMI_SET_RSSITHRESHOLD 44
+///*
+// * arguments:
+// * WMI_RSSI_THRESHOLD_PARAMS_CMD thresholdParams (see include/wmi.h)
+// * uses: WMI_RSSI_THRESHOLD_PARAMS_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_CLR_RSSISNR 45
+///*
+// * arguments:
+// * WMI_CLR_RSSISNR_CMD thresholdParams (see include/wmi.h)
+// * uses: WMI_CLR_RSSISNR_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_LQTHRESHOLD 46
+///*
+// * arguments:
+// * WMI_LQ_THRESHOLD_PARAMS_CMD thresholdParams (see include/wmi.h)
+// * uses: WMI_LQ_THRESHOLD_PARAMS_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_RTS 47
+///*
+// * arguments:
+// * WMI_SET_RTS_MODE_CMD (see include/wmi.h)
+// * uses: WMI_SET_RTS_MODE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_LPREAMBLE 48
+//
+//#define AR6000_XIOCTL_WMI_SET_AUTHMODE 49
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_AUTHMODE)
+// * UINT8 mode
+// * uses: WMI_SET_RECONNECT_AUTH_MODE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_REASSOCMODE 50
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_WMM)
+// * UINT8 mode
+// * uses: WMI_SET_WMM_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_WMM 51
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS)
+// * UINT32 frequency
+// * UINT8 threshold
+// */
+//#define AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS 52
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP)
+// * UINT32 cookie
+// */
+//#define AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP 53
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_GET_RD)
+// * UINT32 regDomain
+// */
+//#define AR6000_XIOCTL_WMI_GET_RD 54
+//
+//#define AR6000_XIOCTL_DIAG_READ 55
+//
+//#define AR6000_XIOCTL_DIAG_WRITE 56
+//
+///*
+// * arguments cmd (AR6000_XIOCTL_SET_TXOP)
+// * WMI_TXOP_CFG txopEnable
+// */
+//#define AR6000_XIOCTL_WMI_SET_TXOP 57
+//
+//#ifdef USER_KEYS
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_USER_SETKEYS)
+// * UINT32 keyOpCtrl
+// * uses AR6000_USER_SETKEYS_INFO
+// */
+//#define AR6000_XIOCTL_USER_SETKEYS 58
+//#endif /* USER_KEYS */
+//
+//#define AR6000_XIOCTL_WMI_SET_KEEPALIVE 59
+///*
+// * arguments:
+// * UINT8 cmd (AR6000_XIOCTL_WMI_SET_KEEPALIVE)
+// * UINT8 keepaliveInterval
+// * uses: WMI_SET_KEEPALIVE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_KEEPALIVE 60
+///*
+// * arguments:
+// * UINT8 cmd (AR6000_XIOCTL_WMI_GET_KEEPALIVE)
+// * UINT8 keepaliveInterval
+// * A_BOOL configured
+// * uses: WMI_GET_KEEPALIVE_CMDID
+// */
+//
+///* ====ROM Patching Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_INSTALL 61
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_INSTALL)
+// * UINT32 ROM Address
+// * UINT32 RAM Address
+// * UINT32 number of bytes
+// * UINT32 activate? (0 or 1)
+// * }
+// * A_UINT32 resulting rompatch ID
+// * }
+// * uses: BMI_ROMPATCH_INSTALL
+// */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL 62
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL)
+// * UINT32 rompatch ID
+// * }
+// * uses: BMI_ROMPATCH_UNINSTALL
+// */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE 63
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE)
+// * UINT32 rompatch count
+// * UINT32 rompatch IDs[rompatch count]
+// * }
+// * uses: BMI_ROMPATCH_ACTIVATE
+// */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE 64
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE)
+// * UINT32 rompatch count
+// * UINT32 rompatch IDs[rompatch count]
+// * }
+// * uses: BMI_ROMPATCH_DEACTIVATE
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_APPIE 65
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_APPIE)
+// * UINT32 app_frmtype;
+// * UINT32 app_buflen;
+// * UINT8 app_buf[];
+// * }
+// */
+//#define AR6000_XIOCTL_WMI_SET_MGMT_FRM_RX_FILTER 66
+///*
+// * arguments:
+// * A_UINT32 filter_type;
+// */
+//
+//#define AR6000_XIOCTL_DBGLOG_CFG_MODULE 67
+//
+//#define AR6000_XIOCTL_DBGLOG_GET_DEBUG_LOGS 68
+//
+//#define AR6000_XIOCTL_WMI_SET_WSC_STATUS 70
+///*
+// * arguments:
+// * A_UINT32 wsc_status;
+// * (WSC_REG_INACTIVE or WSC_REG_ACTIVE)
+// */
+//
+///*
+// * arguments:
+// * struct {
+// * A_UINT8 streamType;
+// * A_UINT8 status;
+// * }
+// * uses: WMI_SET_BT_STATUS_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_BT_STATUS 71
+//
+///*
+// * arguments:
+// * struct {
+// * A_UINT8 paramType;
+// * union {
+// * A_UINT8 noSCOPkts;
+// * BT_PARAMS_A2DP a2dpParams;
+// * BT_COEX_REGS regs;
+// * };
+// * }
+// * uses: WMI_SET_BT_PARAM_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_BT_PARAMS 72
+//
+//#define AR6000_XIOCTL_WMI_SET_HOST_SLEEP_MODE 73
+//#define AR6000_XIOCTL_WMI_SET_WOW_MODE 74
+//#define AR6000_XIOCTL_WMI_GET_WOW_LIST 75
+//#define AR6000_XIOCTL_WMI_ADD_WOW_PATTERN 76
+//#define AR6000_XIOCTL_WMI_DEL_WOW_PATTERN 77
+//
+//
+//
+//#define AR6000_XIOCTL_TARGET_INFO 78
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TARGET_INFO)
+// * A_UINT32 TargetVersion (returned)
+// * A_UINT32 TargetType (returned)
+// * (See also bmi_msg.h target_ver and target_type)
+// */
+//
+//#define AR6000_XIOCTL_DUMP_HTC_CREDIT_STATE 79
+///*
+// * arguments:
+// * none
+// */
+//
+//#define AR6000_XIOCTL_TRAFFIC_ACTIVITY_CHANGE 80
+///*
+// * This ioctl is used to emulate traffic activity
+// * timeouts. Activity/inactivity will trigger the driver
+// * to re-balance credits.
+// *
+// * arguments:
+// * ar6000_traffic_activity_change
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_CONNECT_CTRL_FLAGS 81
+///*
+// * This ioctl is used to set the connect control flags
+// *
+// * arguments:
+// * A_UINT32 connectCtrlFlags
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_AKMP_PARAMS 82
+///*
+// * This IOCTL sets any Authentication,Key Management and Protection
+// * related parameters. This is used along with the information set in
+// * Connect Command.
+// * Currently this enables Multiple PMKIDs to an AP.
+// *
+// * arguments:
+// * struct {
+// * A_UINT32 akmpInfo;
+// * }
+// * uses: WMI_SET_AKMP_PARAMS_CMD
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_PMKID_LIST 83
+//
+//#define AR6000_XIOCTL_WMI_SET_PMKID_LIST 84
+///*
+// * This IOCTL is used to set a list of PMKIDs. This list of
+// * PMKIDs is used in the [Re]AssocReq Frame. This list is used
+// * only if the MultiPMKID option is enabled via the
+// * AR6000_XIOCTL_WMI_SET_AKMP_PARAMS IOCTL.
+// *
+// * arguments:
+// * struct {
+// * A_UINT32 numPMKID;
+// * WMI_PMKID pmkidList[WMI_MAX_PMKID_CACHE];
+// * }
+// * uses: WMI_SET_PMKIDLIST_CMD
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_PARAMS 85
+//#define AR6000_XIOCTL_WMI_SET_MCAST_FILTER 86
+//#define AR6000_XIOCTL_WMI_DEL_MCAST_FILTER 87
+//
+//
+///* Historical DSETPATCH support for INI patches */
+//#define AR6000_XIOCTL_UNUSED90 90
+//
+//
+///* Support LZ-compressed firmware download */
+//#define AR6000_XIOCTL_BMI_LZ_STREAM_START 91
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_LZ_STREAM_START)
+// * UINT32 address
+// * uses: BMI_LZ_STREAM_START
+// */
+//
+//#define AR6000_XIOCTL_BMI_LZ_DATA 92
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_LZ_DATA)
+// * UINT32 length
+// * char data[length]
+// * uses: BMI_LZ_DATA
+// */
+//
+//#define AR6000_XIOCTL_PROF_CFG 93
+///*
+// * arguments:
+// * A_UINT32 period
+// * A_UINT32 nbins
+// */
+//
+//#define AR6000_XIOCTL_PROF_ADDR_SET 94
+///*
+// * arguments:
+// * A_UINT32 Target address
+// */
+//
+//#define AR6000_XIOCTL_PROF_START 95
+//
+//#define AR6000_XIOCTL_PROF_STOP 96
+//
+//#define AR6000_XIOCTL_PROF_COUNT_GET 97
+//
+//#define AR6000_XIOCTL_WMI_ABORT_SCAN 98
+//
+///*
+// * AP mode
+// */
+//#define AR6000_XIOCTL_AP_GET_STA_LIST 99
+//
+//#define AR6000_XIOCTL_AP_HIDDEN_SSID 100
+//
+//#define AR6000_XIOCTL_AP_SET_NUM_STA 101
+//
+//#define AR6000_XIOCTL_AP_SET_ACL_MAC 102
+//
+//#define AR6000_XIOCTL_AP_GET_ACL_LIST 103
+//
+//#define AR6000_XIOCTL_AP_COMMIT_CONFIG 104
+//
+//#define IEEE80211_IOCTL_GETWPAIE 105
+//
+//#define AR6000_XIOCTL_AP_CONN_INACT_TIME 106
+//
+//#define AR6000_XIOCTL_AP_PROT_SCAN_TIME 107
+//
+//#define AR6000_XIOCTL_AP_SET_COUNTRY 108
+//
+//#define AR6000_XIOCTL_AP_SET_DTIM 109
+//
+//
+//
+//
+//#define AR6000_XIOCTL_WMI_TARGET_EVENT_REPORT 110
+//
+//#define AR6000_XIOCTL_SET_IP 111
+//
+//#define AR6000_XIOCTL_AP_SET_ACL_POLICY 112
+//
+//#define AR6000_XIOCTL_AP_CTRL_BSS_COMM 113
+//
+//#define AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO 114
+//
+//#define AR6000_XIOCTL_MODULE_DEBUG_SET_MASK 115
+//
+//#define AR6000_XIOCTL_MODULE_DEBUG_GET_MASK 116
+//
+//#define AR6000_XIOCTL_DUMP_RCV_AGGR_STATS 117
+//
+//#define AR6000_XIOCTL_SET_HT_CAP 118
+//
+//#define AR6000_XIOCTL_SET_HT_OP 119
+//
+//#define AR6000_XIOCTL_AP_GET_STAT 120
+//
+//#define AR6000_XIOCTL_SET_TX_SELECT_RATES 121
+//
+//#define AR6000_XIOCTL_SETUP_AGGR 122
+//
+//#define AR6000_XIOCTL_ALLOW_AGGR 123
+//
+//#define AR6000_XIOCTL_AP_GET_HIDDEN_SSID 124
+//
+//#define AR6000_XIOCTL_AP_GET_COUNTRY 125
+//
+//#define AR6000_XIOCTL_AP_GET_WMODE 126
+//
+//#define AR6000_XIOCTL_AP_GET_DTIM 127
+//
+//#define AR6000_XIOCTL_AP_GET_BINTVL 128
+//
+//#define AR6000_XIOCTL_AP_GET_RTS 129
+//
+//#define AR6000_XIOCTL_DELE_AGGR 130
+//
+//#define AR6000_XIOCTL_FETCH_TARGET_REGS 131
+//
+//#define AR6000_XIOCTL_HCI_CMD 132
+//
+//#define AR6000_XIOCTL_ACL_DATA 133
+//
+//#define AR6000_XIOCTL_WLAN_CONN_PRECEDENCE 134
+//
+//#define AR6000_XIOCTL_AP_SET_11BG_RATESET 135
+//
+//#define AR6000_XIOCTL_WMI_SET_AP_PS 136
+//
+//#define AR6000_XIOCTL_WMI_MCAST_FILTER 137
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_FE_ANT 138
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_COLOCATED_BT_DEV 139
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG 140
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_SCO_CONFIG 141
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_A2DP_CONFIG 142
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_ACLCOEX_CONFIG 143
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_DEBUG 144
+//
+//#define AR6000_XIOCTL_WMI_SET_BT_OPERATING_STATUS 145
+//
+//#define AR6000_XIOCTL_WMI_GET_BTCOEX_CONFIG 146
+//
+//#define AR6000_XIOCTL_WMI_GET_BTCOEX_STATS 147
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_QOS_SUPP)
+// * UINT8 mode
+// * uses: WMI_SET_QOS_SUPP_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_QOS_SUPP 148
+//
+//#define AR6000_XIOCTL_AP_SET_DFS 149
+//
+//#ifdef P2P
+//#define AR6000_XIOCTL_WMI_P2P_DISCOVER 150
+//#define AR6000_XIOCTL_WMI_P2P_LISTEN 151
+//#define AR6000_XIOCTL_WMI_P2P_GO_NEG 152
+//#define AR6000_XIOCTL_WMI_P2P_CONFIG 153
+//#define AR6000_XIOCTL_WMI_WPS_CONFIG 154
+//#define AR6000_XIOCTL_WMI_P2P_FINDNODE 155
+//#endif
+//#define AR6000_XIOCTL_SET_BT_HW_POWER_STATE 156
+//#define AR6000_XIOCTL_GET_BT_HW_POWER_STATE 157
+//#define AR6000_XIOCTL_GET_WLAN_SLEEP_STATE 158
+//#define AR6000_XIOCTL_WMI_SET_TX_SGI_PARAM 159
+///*
+// * arguments:
+// * WMI_AP_PS_CMD apPsCmd
+// * uses: WMI_AP_PS_CMDID
+// */
+//
+//
+//// WAC
+//#define AR6000_XIOCTL_WMI_ENABLE_WAC_PARAM 160
+//
+//#define AR6000_XIOCTL_WAC_SCAN_REPLY 161
+//
+//#define AR6000_XIOCTL_WMI_WAC_CTRL_REQ 162
+//
+//#define AR6000_XIOCTL_WMI_SET_WPA_OFFLOAD_STATE 163
+//
+//#define AR6000_XIOCTL_WMI_SET_PASSPHRASE 164
+//
+//#define AR6000_XIOCTL_BMI_NVRAM_PROCESS 165
+//
+//#define AR6000_XIOCTL_AP_ACS_DISABLE_HI_CHANNELS 166
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_NVRAM_PROCESS)
+// * UINT8 name[BMI_NVRAM_SEG_NAME_SZ]
+// * uses: BMI_NVRAM_PROCESS
+// */
+//
+//
+//#ifdef CONFIG_HOST_TCMD_SUPPORT
+///* ====additional extended commands for radio test ==== */
+//
+//#define AR6000_XIOCTL_TCMD_CMDS 167
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_CMDS)
+// * WMI_TCMD_CMDS_CMD cmdsCmd (see include/wmi.h)
+// * uses: WMI_TCMD_CMDS_CMDID
+// */
+//
+//#endif //ifdef CONFIG_HOST_TCMD_SUPPORT
+//
+//#define AR6000_XIOCTL_WMI_SET_DIVERSITY_PARAM 168
+//
+//#define AR6000_XIOCTL_WMI_FORCE_ASSERT 169
+//
+//#define AR6000_XIOCTL_WMI_SET_EXCESS_TX_RETRY_THRES 170
+//
+//#define AR6000_XIOCTL_AP_GET_NUM_STA 171
+//
+//#define AR6000_XIOCTL_SUSPEND_DRIVER 172
+//
+//#define AR6000_XIOCTL_RESUME_DRIVER 173
+
+/* used by AR6000_IOCTL_WMI_GETREV */
+struct ar6000_version {
+ A_UINT32 host_ver;
+ A_UINT32 target_ver;
+ A_UINT32 wlan_ver;
+ A_UINT32 abi_ver;
+ A_UINT32 targetconf_ver;
+};
+
+/* used by AR6000_IOCTL_WMI_GET_QOS_QUEUE */
+struct ar6000_queuereq {
+ A_UINT8 trafficClass;
+ A_UINT16 activeTsids;
+};
+
+/* used by AR6000_IOCTL_WMI_GET_TARGET_STATS */
+typedef struct targetStats_t {
+ A_UINT64 tx_packets;
+ A_UINT64 tx_bytes;
+ A_UINT64 tx_unicast_pkts;
+ A_UINT64 tx_unicast_bytes;
+ A_UINT64 tx_multicast_pkts;
+ A_UINT64 tx_multicast_bytes;
+ A_UINT64 tx_broadcast_pkts;
+ A_UINT64 tx_broadcast_bytes;
+ A_UINT64 tx_rts_success_cnt;
+ A_UINT64 tx_packet_per_ac[4];
+
+ A_UINT64 tx_errors;
+ A_UINT64 tx_failed_cnt;
+ A_UINT64 tx_retry_cnt;
+ A_UINT64 tx_mult_retry_cnt;
+ A_UINT64 tx_rts_fail_cnt;
+
+ A_UINT64 rx_packets;
+ A_UINT64 rx_bytes;
+ A_UINT64 rx_unicast_pkts;
+ A_UINT64 rx_unicast_bytes;
+ A_UINT64 rx_multicast_pkts;
+ A_UINT64 rx_multicast_bytes;
+ A_UINT64 rx_broadcast_pkts;
+ A_UINT64 rx_broadcast_bytes;
+ A_UINT64 rx_fragment_pkt;
+
+ A_UINT64 rx_errors;
+ A_UINT64 rx_crcerr;
+ A_UINT64 rx_key_cache_miss;
+ A_UINT64 rx_decrypt_err;
+ A_UINT64 rx_duplicate_frames;
+
+ A_UINT64 tkip_local_mic_failure;
+ A_UINT64 tkip_counter_measures_invoked;
+ A_UINT64 tkip_replays;
+ A_UINT64 tkip_format_errors;
+ A_UINT64 ccmp_format_errors;
+ A_UINT64 ccmp_replays;
+
+ A_UINT64 power_save_failure_cnt;
+
+ A_UINT64 cs_bmiss_cnt;
+ A_UINT64 cs_lowRssi_cnt;
+ A_UINT64 cs_connect_cnt;
+ A_UINT64 cs_disconnect_cnt;
+
+ A_INT32 tx_unicast_rate;
+ A_INT32 rx_unicast_rate;
+
+ A_UINT32 lq_val;
+
+ A_UINT32 wow_num_pkts_dropped;
+ A_UINT16 wow_num_events_discarded;
+
+ A_INT16 noise_floor_calibation;
+ A_INT16 cs_rssi;
+ A_INT16 cs_aveBeacon_rssi;
+ A_UINT8 cs_aveBeacon_snr;
+ A_UINT8 cs_lastRoam_msec;
+ A_UINT8 cs_snr;
+
+ A_UINT8 wow_num_host_pkt_wakeups;
+ A_UINT8 wow_num_host_event_wakeups;
+
+ A_UINT32 arp_received;
+ A_UINT32 arp_matched;
+ A_UINT32 arp_replied;
+}TARGET_STATS;
+
+typedef struct targetStats_cmd_t {
+ TARGET_STATS targetStats;
+ int clearStats;
+} TARGET_STATS_CMD;
+
+/* used by AR6000_XIOCTL_USER_SETKEYS */
+
+/*
+ * Setting this bit to 1 doesnot initialize the RSC on the firmware
+ */
+#define AR6000_XIOCTL_USER_SETKEYS_RSC_CTRL 1
+#define AR6000_USER_SETKEYS_RSC_UNCHANGED 0x00000002
+
+typedef struct {
+ A_UINT32 keyOpCtrl; /* Bit Map of Key Mgmt Ctrl Flags */
+} AR6000_USER_SETKEYS_INFO;
+
+
+/* used by AR6000_XIOCTL_GPIO_OUTPUT_SET */
+struct ar6000_gpio_output_set_cmd_s {
+ A_UINT32 set_mask;
+ A_UINT32 clear_mask;
+ A_UINT32 enable_mask;
+ A_UINT32 disable_mask;
+};
+
+/*
+ * used by AR6000_XIOCTL_GPIO_REGISTER_GET and AR6000_XIOCTL_GPIO_REGISTER_SET
+ */
+struct ar6000_gpio_register_cmd_s {
+ A_UINT32 gpioreg_id;
+ A_UINT32 value;
+};
+
+/* used by AR6000_XIOCTL_GPIO_INTR_ACK */
+struct ar6000_gpio_intr_ack_cmd_s {
+ A_UINT32 ack_mask;
+};
+
+/* used by AR6000_XIOCTL_GPIO_INTR_WAIT */
+struct ar6000_gpio_intr_wait_cmd_s {
+ A_UINT32 intr_mask;
+ A_UINT32 input_values;
+};
+
+/* used by the AR6000_XIOCTL_DBGLOG_CFG_MODULE */
+typedef struct ar6000_dbglog_module_config_s {
+ A_UINT32 valid;
+ A_UINT16 mmask;
+ A_UINT16 tsr;
+ A_BOOL rep;
+ A_UINT16 size;
+} DBGLOG_MODULE_CONFIG;
+
+typedef struct user_rssi_thold_t {
+ A_INT16 tag;
+ A_INT16 rssi;
+} USER_RSSI_THOLD;
+
+typedef struct user_rssi_params_t {
+ A_UINT8 weight;
+ A_UINT32 pollTime;
+ USER_RSSI_THOLD tholds[12];
+} USER_RSSI_PARAMS;
+
+typedef struct ar6000_get_btcoex_config_cmd_t{
+ A_UINT32 btProfileType;
+ A_UINT32 linkId;
+ }AR6000_GET_BTCOEX_CONFIG_CMD;
+
+typedef struct ar6000_btcoex_config_t {
+ AR6000_GET_BTCOEX_CONFIG_CMD configCmd;
+ A_UINT32 * configEvent;
+} AR6000_BTCOEX_CONFIG;
+
+typedef struct ar6000_btcoex_stats_t {
+ A_UINT32 * statsEvent;
+ }AR6000_BTCOEX_STATS;
+/*
+ * Host driver may have some config parameters. Typically, these
+ * config params are one time config parameters. These could
+ * correspond to any of the underlying modules. Host driver exposes
+ * an api for the underlying modules to get this config.
+ */
+#define AR6000_DRIVER_CFG_BASE 0x8000
+
+/* Should driver perform wlan node caching? */
+#define AR6000_DRIVER_CFG_GET_WLANNODECACHING 0x8001
+/*Should we log raw WMI msgs */
+#define AR6000_DRIVER_CFG_LOG_RAW_WMI_MSGS 0x8002
+
+/* used by AR6000_XIOCTL_DIAG_READ & AR6000_XIOCTL_DIAG_WRITE */
+struct ar6000_diag_window_cmd_s {
+ unsigned int addr;
+ unsigned int value;
+};
+
+
+struct ar6000_traffic_activity_change {
+ A_UINT32 StreamID; /* stream ID to indicate activity change */
+ A_UINT32 Active; /* active (1) or inactive (0) */
+};
+
+/* Used with AR6000_XIOCTL_PROF_COUNT_GET */
+struct prof_count_s {
+ A_UINT32 addr; /* bin start address */
+ A_UINT32 count; /* hit count */
+};
+
+
+/* used by AR6000_XIOCTL_MODULE_DEBUG_SET_MASK */
+/* AR6000_XIOCTL_MODULE_DEBUG_GET_MASK */
+/* AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO */
+struct drv_debug_module_s {
+ A_CHAR modulename[128]; /* name of module */
+ A_UINT32 mask; /* new mask to set .. or .. current mask */
+};
+
+/* used by AR6000_XIOCTL_P2P_AUTH_INVITE */
+#define ATH_MAC_LEN 6
+typedef PREPACK struct {
+ A_UINT32 auth;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+}POSTPACK P2P_AUTH_INVITE_CMD;
+
+/* All HCI related rx events are sent up to the host app
+ * via a wmi event id. It can contain ACL data or HCI event,
+ * based on which it will be de-multiplexed.
+ */
+typedef enum {
+ PAL_HCI_EVENT = 0,
+ PAL_HCI_RX_DATA,
+} WMI_PAL_EVENT_INFO;
+
+
+#ifdef __cplusplus
+}
+#endif
+#endif
diff --git a/ath6kl-wmiconfig/include/athtypes_linux.h b/ath6kl-wmiconfig/include/athtypes_linux.h
new file mode 100755
index 0000000..b51b053
--- /dev/null
+++ b/ath6kl-wmiconfig/include/athtypes_linux.h
@@ -0,0 +1,40 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+//------------------------------------------------------------------------------
+//
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _ATHTYPES_LINUX_H_
+#define _ATHTYPES_LINUX_H_
+
+#ifdef __KERNEL__
+#include <linux/types.h>
+#else
+#include <sys/types.h>
+#endif
+
+typedef int8_t A_INT8;
+typedef int16_t A_INT16;
+typedef int32_t A_INT32;
+typedef int64_t A_INT64;
+
+typedef u_int8_t A_UINT8;
+typedef u_int16_t A_UINT16;
+typedef u_int32_t A_UINT32;
+typedef u_int64_t A_UINT64;
+
+typedef int A_BOOL;
+typedef char A_CHAR;
+typedef unsigned char A_UCHAR;
+typedef unsigned long A_ATH_TIMER;
+
+#endif /* _ATHTYPES_LINUX_H_ */
+
diff --git a/ath6kl-wmiconfig/include/config_linux.h b/ath6kl-wmiconfig/include/config_linux.h
new file mode 100755
index 0000000..35a5904
--- /dev/null
+++ b/ath6kl-wmiconfig/include/config_linux.h
@@ -0,0 +1,54 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+#ifndef _CONFIG_LINUX_H_
+#define _CONFIG_LINUX_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include <linux/version.h>
+
+/*
+ * Host-side GPIO support is optional.
+ * If run-time access to GPIO pins is not required, then
+ * this should be changed to #undef.
+ */
+#define CONFIG_HOST_GPIO_SUPPORT
+
+/*
+ * Host side Test Command support
+ * Note: when HCI SDIO is enabled, a low stack IRQ or statck overflow is
+ * hit on FC10. So with HCI SDIO, minimize the stack allocation by
+ * mutually exclude TCMD_SUPPORT, which allocates large buffers
+ * in AR_TCMD_RESP in AR_SOFTC_T
+ *
+ */
+#ifndef HCI_TRANSPORT_SDIO
+#define CONFIG_HOST_TCMD_SUPPORT
+#endif
+
+/* Host-side support for Target-side profiling */
+#undef CONFIG_TARGET_PROFILE_SUPPORT
+/*DIX OFFLOAD SUPPORT*/
+/*#define DIX_RX_OFFLOAD*/
+/*#define DIX_TX_OFFLOAD*/
+
+/* IP/TCP checksum offload */
+/* Checksum offload is currently not supported for 64 bit platforms */
+#ifndef __LP64__
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,25)
+#define CONFIG_CHECKSUM_OFFLOAD
+#endif
+#endif /* __LP64__ */
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
+
diff --git a/ath6kl-wmiconfig/include/dbglog.h b/ath6kl-wmiconfig/include/dbglog.h
new file mode 100755
index 0000000..61924dd
--- /dev/null
+++ b/ath6kl-wmiconfig/include/dbglog.h
@@ -0,0 +1,117 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+#ifndef _DBGLOG_H_
+#define _DBGLOG_H_
+
+#ifndef ATH_TARGET
+//#include "athstartpack.h"
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define DBGLOG_TIMESTAMP_OFFSET 0
+#define DBGLOG_TIMESTAMP_MASK 0x0000FFFF /* Bit 0-15. Contains bit
+ 8-23 of the LF0 timer */
+#define DBGLOG_DBGID_OFFSET 16
+#define DBGLOG_DBGID_MASK 0x03FF0000 /* Bit 16-25 */
+#define DBGLOG_DBGID_NUM_MAX 256 /* Upper limit is width of mask */
+
+#define DBGLOG_MODULEID_OFFSET 26
+#define DBGLOG_MODULEID_MASK 0x3C000000 /* Bit 26-29 */
+#define DBGLOG_MODULEID_NUM_MAX 16 /* Upper limit is width of mask */
+
+/*
+ * Please ensure that the definition of any new module intrduced is captured
+ * between the DBGLOG_MODULEID_START and DBGLOG_MODULEID_END defines. The
+ * structure is required for the parser to correctly pick up the values for
+ * different modules.
+ */
+#define DBGLOG_MODULEID_START
+#define DBGLOG_MODULEID_INF 0
+#define DBGLOG_MODULEID_WMI 1
+#define DBGLOG_MODULEID_MISC 2
+#define DBGLOG_MODULEID_PM 3
+#define DBGLOG_MODULEID_TXRX_MGMTBUF 4
+#define DBGLOG_MODULEID_TXRX_TXBUF 5
+#define DBGLOG_MODULEID_TXRX_RXBUF 6
+#define DBGLOG_MODULEID_WOW 7
+#define DBGLOG_MODULEID_WHAL 8
+#define DBGLOG_MODULEID_DC 9
+#define DBGLOG_MODULEID_CO 10
+#define DBGLOG_MODULEID_RO 11
+#define DBGLOG_MODULEID_CM 12
+#define DBGLOG_MODULEID_MGMT 13
+#define DBGLOG_MODULEID_TMR 14
+#define DBGLOG_MODULEID_BTCOEX 15
+#define DBGLOG_MODULEID_END
+
+#define DBGLOG_NUM_ARGS_OFFSET 30
+#define DBGLOG_NUM_ARGS_MASK 0xC0000000 /* Bit 30-31 */
+#define DBGLOG_NUM_ARGS_MAX 2 /* Upper limit is width of mask */
+
+#define DBGLOG_MODULE_LOG_ENABLE_OFFSET 0
+#define DBGLOG_MODULE_LOG_ENABLE_MASK 0x0000FFFF
+
+#define DBGLOG_REPORTING_ENABLED_OFFSET 16
+#define DBGLOG_REPORTING_ENABLED_MASK 0x00010000
+
+#define DBGLOG_TIMESTAMP_RESOLUTION_OFFSET 17
+#define DBGLOG_TIMESTAMP_RESOLUTION_MASK 0x000E0000
+
+#define DBGLOG_REPORT_SIZE_OFFSET 20
+#define DBGLOG_REPORT_SIZE_MASK 0x3FF00000
+
+#define DBGLOG_LOG_BUFFER_SIZE 1500
+#define DBGLOG_DBGID_DEFINITION_LEN_MAX 90
+
+PREPACK struct dbglog_buf_s {
+ struct dbglog_buf_s *next;
+ A_UINT8 *buffer;
+ A_UINT32 bufsize;
+ A_UINT32 length;
+ A_UINT32 count;
+ A_UINT32 free;
+} POSTPACK;
+
+PREPACK struct dbglog_hdr_s {
+ struct dbglog_buf_s *dbuf;
+ A_UINT32 dropped;
+} POSTPACK;
+
+PREPACK struct dbglog_config_s {
+ A_UINT32 cfgvalid; /* Mask with valid config bits */
+ union {
+ /* TODO: Take care of endianness */
+ struct {
+ A_UINT32 mmask:16; /* Mask of modules with logging on */
+ A_UINT32 rep:1; /* Reporting enabled or not */
+ A_UINT32 tsr:3; /* Time stamp resolution. Def: 1 ms */
+ A_UINT32 size:10; /* Report size in number of messages */
+ A_UINT32 reserved:2;
+ } dbglog_config;
+
+ A_UINT32 value;
+ } u;
+} POSTPACK;
+
+#define cfgmmask u.dbglog_config.mmask
+#define cfgrep u.dbglog_config.rep
+#define cfgtsr u.dbglog_config.tsr
+#define cfgsize u.dbglog_config.size
+#define cfgvalue u.value
+
+#ifdef __cplusplus
+}
+#endif
+
+#ifndef ATH_TARGET
+//#include "athendpack.h"
+#endif
+
+#endif /* _DBGLOG_H_ */
diff --git a/ath6kl-wmiconfig/include/dbglog_id.h b/ath6kl-wmiconfig/include/dbglog_id.h
new file mode 100755
index 0000000..8ef7b5f
--- /dev/null
+++ b/ath6kl-wmiconfig/include/dbglog_id.h
@@ -0,0 +1,576 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+#ifndef _DBGLOG_ID_H_
+#define _DBGLOG_ID_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+ * The nomenclature for the debug identifiers is MODULE_DESCRIPTION.
+ * Please ensure that the definition of any new debugid introduced is captured
+ * between the <MODULE>_DBGID_DEFINITION_START and
+ * <MODULE>_DBGID_DEFINITION_END defines. The structure is required for the
+ * parser to correctly pick up the values for different debug identifiers.
+ */
+
+/* INF debug identifier definitions */
+#define INF_DBGID_DEFINITION_START
+#define INF_ASSERTION_FAILED 1
+#define INF_TARGET_ID 2
+#define INF_DBGID_DEFINITION_END
+
+/* WMI debug identifier definitions */
+#define WMI_DBGID_DEFINITION_START
+#define WMI_CMD_RX_XTND_PKT_TOO_SHORT 1
+#define WMI_EXTENDED_CMD_NOT_HANDLED 2
+#define WMI_CMD_RX_PKT_TOO_SHORT 3
+#define WMI_CALLING_WMI_EXTENSION_FN 4
+#define WMI_CMD_NOT_HANDLED 5
+#define WMI_IN_SYNC 6
+#define WMI_TARGET_WMI_SYNC_CMD 7
+#define WMI_SET_SNR_THRESHOLD_PARAMS 8
+#define WMI_SET_RSSI_THRESHOLD_PARAMS 9
+#define WMI_SET_LQ_TRESHOLD_PARAMS 10
+#define WMI_TARGET_CREATE_PSTREAM_CMD 11
+#define WMI_WI_DTM_INUSE 12
+#define WMI_TARGET_DELETE_PSTREAM_CMD 13
+#define WMI_TARGET_IMPLICIT_DELETE_PSTREAM_CMD 14
+#define WMI_TARGET_GET_BIT_RATE_CMD 15
+#define WMI_GET_RATE_MASK_CMD_FIX_RATE_MASK_IS 16
+#define WMI_TARGET_GET_AVAILABLE_CHANNELS_CMD 17
+#define WMI_TARGET_GET_TX_PWR_CMD 18
+#define WMI_FREE_EVBUF_WMIBUF 19
+#define WMI_FREE_EVBUF_DATABUF 20
+#define WMI_FREE_EVBUF_BADFLAG 21
+#define WMI_HTC_RX_ERROR_DATA_PACKET 22
+#define WMI_HTC_RX_SYNC_PAUSING_FOR_MBOX 23
+#define WMI_INCORRECT_WMI_DATA_HDR_DROPPING_PKT 24
+#define WMI_SENDING_READY_EVENT 25
+#define WMI_SETPOWER_MDOE_TO_MAXPERF 26
+#define WMI_SETPOWER_MDOE_TO_REC 27
+#define WMI_BSSINFO_EVENT_FROM 28
+#define WMI_TARGET_GET_STATS_CMD 29
+#define WMI_SENDING_SCAN_COMPLETE_EVENT 30
+#define WMI_SENDING_RSSI_INDB_THRESHOLD_EVENT 31
+#define WMI_SENDING_RSSI_INDBM_THRESHOLD_EVENT 32
+#define WMI_SENDING_LINK_QUALITY_THRESHOLD_EVENT 33
+#define WMI_SENDING_ERROR_REPORT_EVENT 34
+#define WMI_SENDING_CAC_EVENT 35
+#define WMI_TARGET_GET_ROAM_TABLE_CMD 36
+#define WMI_TARGET_GET_ROAM_DATA_CMD 37
+#define WMI_SENDING_GPIO_INTR_EVENT 38
+#define WMI_SENDING_GPIO_ACK_EVENT 39
+#define WMI_SENDING_GPIO_DATA_EVENT 40
+#define WMI_CMD_RX 41
+#define WMI_CMD_RX_XTND 42
+#define WMI_EVENT_SEND 43
+#define WMI_EVENT_SEND_XTND 44
+#define WMI_CMD_PARAMS_DUMP_START 45
+#define WMI_CMD_PARAMS_DUMP_END 46
+#define WMI_CMD_PARAMS 47
+#define WMI_DBGID_DEFINITION_END
+
+/* MISC debug identifier definitions */
+#define MISC_DBGID_DEFINITION_START
+#define MISC_WLAN_SCHEDULER_EVENT_REGISTER_ERROR 1
+#define TLPM_INIT 2
+#define TLPM_FILTER_POWER_STATE 3
+#define TLPM_NOTIFY_NOT_IDLE 4
+#define TLPM_TIMEOUT_IDLE_HANDLER 5
+#define TLPM_TIMEOUT_WAKEUP_HANDLER 6
+#define TLPM_WAKEUP_SIGNAL_HANDLER 7
+#define TLPM_UNEXPECTED_GPIO_INTR_ERROR 8
+#define TLPM_BREAK_ON_NOT_RECEIVED_ERROR 9
+#define TLPM_BREAK_OFF_NOT_RECIVED_ERROR 10
+#define TLPM_ACK_GPIO_INTR 11
+#define TLPM_ON 12
+#define TLPM_OFF 13
+#define TLPM_WAKEUP_FROM_HOST 14
+#define TLPM_WAKEUP_FROM_BT 15
+#define TLPM_TX_BREAK_RECIVED 16
+#define TLPM_IDLE_TIMER_NOT_RUNNING 17
+#define WAC_ENABLE 18
+#define WAC_SCAN_DONE 19
+#define WAC_REPORT_BSS 20
+#define WAC_START_WPS 21
+#define WAC_SCAN_REPLY 22
+#define WAC_UPDATE_BSS 23
+#define WAC_PIN_STATUS 24
+#define WAC_PIN_STATUS_REJECT 25
+#define WAC_RSSI_BELOW_THRESHOLD 26
+#define WAC_CTRL_REQ_CMD 27
+#define WAC_CTRL_REQ_REPLY 28
+#define DV_SET_ANTENNA 29
+#define MISC_DBGID_DEFINITION_END
+
+/* TXRX debug identifier definitions */
+#define TXRX_TXBUF_DBGID_DEFINITION_START
+#define TXRX_TXBUF_ALLOCATE_BUF 1
+#define TXRX_TXBUF_QUEUE_BUF_TO_MBOX 2
+#define TXRX_TXBUF_QUEUE_BUF_TO_TXQ 3
+#define TXRX_TXBUF_TXQ_DEPTH 4
+#define TXRX_TXBUF_IBSS_QUEUE_TO_SFQ 5
+#define TXRX_TXBUF_IBSS_QUEUE_TO_TXQ_FRM_SFQ 6
+#define TXRX_TXBUF_INITIALIZE_TIMER 7
+#define TXRX_TXBUF_ARM_TIMER 8
+#define TXRX_TXBUF_DISARM_TIMER 9
+#define TXRX_TXBUF_UNINITIALIZE_TIMER 10
+#define TXRX_TXBUF_DBGID_DEFINITION_END
+
+#define TXRX_RXBUF_DBGID_DEFINITION_START
+#define TXRX_RXBUF_ALLOCATE_BUF 1
+#define TXRX_RXBUF_QUEUE_TO_HOST 2
+#define TXRX_RXBUF_QUEUE_TO_WLAN 3
+#define TXRX_RXBUF_ZERO_LEN_BUF 4
+#define TXRX_RXBUF_QUEUE_TO_HOST_LASTBUF_IN_RXCHAIN 5
+#define TXRX_RXBUF_LASTBUF_IN_RXCHAIN_ZEROBUF 6
+#define TXRX_RXBUF_QUEUE_EMPTY_QUEUE_TO_WLAN 7
+#define TXRX_RXBUF_SEND_TO_RECV_MGMT 8
+#define TXRX_RXBUF_SEND_TO_IEEE_LAYER 9
+#define TXRX_RXBUF_REQUEUE_ERROR 10
+#define TXRX_RXBUF_DBGID_DEFINITION_END
+
+#define TXRX_MGMTBUF_DBGID_DEFINITION_START
+#define TXRX_MGMTBUF_ALLOCATE_BUF 1
+#define TXRX_MGMTBUF_ALLOCATE_SM_BUF 2
+#define TXRX_MGMTBUF_ALLOCATE_RMBUF 3
+#define TXRX_MGMTBUF_GET_BUF 4
+#define TXRX_MGMTBUF_GET_SM_BUF 5
+#define TXRX_MGMTBUF_QUEUE_BUF_TO_TXQ 6
+#define TXRX_MGMTBUF_REAPED_BUF 7
+#define TXRX_MGMTBUF_REAPED_SM_BUF 8
+#define TXRX_MGMTBUF_WAIT_FOR_TXQ_DRAIN 9
+#define TXRX_MGMTBUF_WAIT_FOR_TXQ_SFQ_DRAIN 10
+#define TXRX_MGMTBUF_ENQUEUE_INTO_DATA_SFQ 11
+#define TXRX_MGMTBUF_DEQUEUE_FROM_DATA_SFQ 12
+#define TXRX_MGMTBUF_PAUSE_DATA_TXQ 13
+#define TXRX_MGMTBUF_RESUME_DATA_TXQ 14
+#define TXRX_MGMTBUF_WAIT_FORTXQ_DRAIN_TIMEOUT 15
+#define TXRX_MGMTBUF_DRAINQ 16
+#define TXRX_MGMTBUF_INDICATE_Q_DRAINED 17
+#define TXRX_MGMTBUF_ENQUEUE_INTO_HW_SFQ 18
+#define TXRX_MGMTBUF_DEQUEUE_FROM_HW_SFQ 19
+#define TXRX_MGMTBUF_PAUSE_HW_TXQ 20
+#define TXRX_MGMTBUF_RESUME_HW_TXQ 21
+#define TXRX_MGMTBUF_TEAR_DOWN_BA 22
+#define TXRX_MGMTBUF_PROCESS_ADDBA_REQ 23
+#define TXRX_MGMTBUF_PROCESS_DELBA 24
+#define TXRX_MGMTBUF_PERFORM_BA 25
+#define TXRX_MGMTBUF_WLAN_RESET_ON_ERROR 26
+#define TXRX_MGMTBUF_DBGID_DEFINITION_END
+
+/* PM (Power Module) debug identifier definitions */
+#define PM_DBGID_DEFINITION_START
+#define PM_INIT 1
+#define PM_ENABLE 2
+#define PM_SET_STATE 3
+#define PM_SET_POWERMODE 4
+#define PM_CONN_NOTIFY 5
+#define PM_REF_COUNT_NEGATIVE 6
+#define PM_INFRA_STA_APSD_ENABLE 7
+#define PM_INFRA_STA_UPDATE_APSD_STATE 8
+#define PM_CHAN_OP_REQ 9
+#define PM_SET_MY_BEACON_POLICY 10
+#define PM_SET_ALL_BEACON_POLICY 11
+#define PM_INFRA_STA_SET_PM_PARAMS1 12
+#define PM_INFRA_STA_SET_PM_PARAMS2 13
+#define PM_ADHOC_SET_PM_CAPS_FAIL 14
+#define PM_ADHOC_UNKNOWN_IBSS_ATTRIB_ID 15
+#define PM_ADHOC_SET_PM_PARAMS 16
+#define PM_ADHOC_STATE1 18
+#define PM_ADHOC_STATE2 19
+#define PM_ADHOC_CONN_MAP 20
+#define PM_FAKE_SLEEP 21
+#define PM_AP_STATE1 22
+#define PM_AP_SET_PM_PARAMS 23
+#define PM_P2P_STATE1 24
+#define PM_DBGID_DEFINITION_END
+
+/* Wake on Wireless debug identifier definitions */
+#define WOW_DBGID_DEFINITION_START
+#define WOW_INIT 1
+#define WOW_GET_CONFIG_DSET 2
+#define WOW_NO_CONFIG_DSET 3
+#define WOW_INVALID_CONFIG_DSET 4
+#define WOW_USE_DEFAULT_CONFIG 5
+#define WOW_SETUP_GPIO 6
+#define WOW_INIT_DONE 7
+#define WOW_SET_GPIO_PIN 8
+#define WOW_CLEAR_GPIO_PIN 9
+#define WOW_SET_WOW_MODE_CMD 10
+#define WOW_SET_HOST_MODE_CMD 11
+#define WOW_ADD_WOW_PATTERN_CMD 12
+#define WOW_NEW_WOW_PATTERN_AT_INDEX 13
+#define WOW_DEL_WOW_PATTERN_CMD 14
+#define WOW_LIST_CONTAINS_PATTERNS 15
+#define WOW_GET_WOW_LIST_CMD 16
+#define WOW_INVALID_FILTER_ID 17
+#define WOW_INVALID_FILTER_LISTID 18
+#define WOW_NO_VALID_FILTER_AT_ID 19
+#define WOW_NO_VALID_LIST_AT_ID 20
+#define WOW_NUM_PATTERNS_EXCEEDED 21
+#define WOW_NUM_LISTS_EXCEEDED 22
+#define WOW_GET_WOW_STATS 23
+#define WOW_CLEAR_WOW_STATS 24
+#define WOW_WAKEUP_HOST 25
+#define WOW_EVENT_WAKEUP_HOST 26
+#define WOW_EVENT_DISCARD 27
+#define WOW_PATTERN_MATCH 28
+#define WOW_PATTERN_NOT_MATCH 29
+#define WOW_PATTERN_NOT_MATCH_OFFSET 30
+#define WOW_DISABLED_HOST_ASLEEP 31
+#define WOW_ENABLED_HOST_ASLEEP_NO_PATTERNS 32
+#define WOW_ENABLED_HOST_ASLEEP_NO_MATCH_FOUND 33
+#define WOW_DBGID_DEFINITION_END
+
+/* WHAL debug identifier definitions */
+#define WHAL_DBGID_DEFINITION_START
+#define WHAL_ERROR_ANI_CONTROL 1
+#define WHAL_ERROR_CHIP_TEST1 2
+#define WHAL_ERROR_CHIP_TEST2 3
+#define WHAL_ERROR_EEPROM_CHECKSUM 4
+#define WHAL_ERROR_EEPROM_MACADDR 5
+#define WHAL_ERROR_INTERRUPT_HIU 6
+#define WHAL_ERROR_KEYCACHE_RESET 7
+#define WHAL_ERROR_KEYCACHE_SET 8
+#define WHAL_ERROR_KEYCACHE_TYPE 9
+#define WHAL_ERROR_KEYCACHE_TKIPENTRY 10
+#define WHAL_ERROR_KEYCACHE_WEPLENGTH 11
+#define WHAL_ERROR_PHY_INVALID_CHANNEL 12
+#define WHAL_ERROR_POWER_AWAKE 13
+#define WHAL_ERROR_POWER_SET 14
+#define WHAL_ERROR_RECV_STOPDMA 15
+#define WHAL_ERROR_RECV_STOPPCU 16
+#define WHAL_ERROR_RESET_CHANNF1 17
+#define WHAL_ERROR_RESET_CHANNF2 18
+#define WHAL_ERROR_RESET_PM 19
+#define WHAL_ERROR_RESET_OFFSETCAL 20
+#define WHAL_ERROR_RESET_RFGRANT 21
+#define WHAL_ERROR_RESET_RXFRAME 22
+#define WHAL_ERROR_RESET_STOPDMA 23
+#define WHAL_ERROR_RESET_RECOVER 24
+#define WHAL_ERROR_XMIT_COMPUTE 25
+#define WHAL_ERROR_XMIT_NOQUEUE 26
+#define WHAL_ERROR_XMIT_ACTIVEQUEUE 27
+#define WHAL_ERROR_XMIT_BADTYPE 28
+#define WHAL_ERROR_XMIT_STOPDMA 29
+#define WHAL_ERROR_INTERRUPT_BB_PANIC 30
+#define WHAL_ERROR_RESET_TXIQCAL 31
+#define WHAL_ERROR_PAPRD_MAXGAIN_ABOVE_WINDOW 32
+#define WHAL_DBGID_DEFINITION_END
+
+/* DC debug identifier definitions */
+#define DC_DBGID_DEFINITION_START
+#define DC_SCAN_CHAN_START 1
+#define DC_SCAN_CHAN_FINISH 2
+#define DC_BEACON_RECEIVE7 3
+#define DC_SSID_PROBE_CB 4
+#define DC_SEND_NEXT_SSID_PROBE 5
+#define DC_START_SEARCH 6
+#define DC_CANCEL_SEARCH_CB 7
+#define DC_STOP_SEARCH 8
+#define DC_END_SEARCH 9
+#define DC_MIN_CHDWELL_TIMEOUT 10
+#define DC_START_SEARCH_CANCELED 11
+#define DC_SET_POWER_MODE 12
+#define DC_INIT 13
+#define DC_SEARCH_OPPORTUNITY 14
+#define DC_RECEIVED_ANY_BEACON 15
+#define DC_RECEIVED_MY_BEACON 16
+#define DC_PROFILE_IS_ADHOC_BUT_BSS_IS_INFRA 17
+#define DC_PS_ENABLED_BUT_ATHEROS_IE_ABSENT 18
+#define DC_BSS_ADHOC_CHANNEL_NOT_ALLOWED 19
+#define DC_SET_BEACON_UPDATE 20
+#define DC_BEACON_UPDATE_COMPLETE 21
+#define DC_END_SEARCH_BEACON_UPDATE_COMP_CB 22
+#define DC_BSSINFO_EVENT_DROPPED 23
+#define DC_IEEEPS_ENABLED_BUT_ATIM_ABSENT 24
+#define DC_DBGID_DEFINITION_END
+
+/* CO debug identifier definitions */
+#define CO_DBGID_DEFINITION_START
+#define CO_INIT 1
+#define CO_ACQUIRE_LOCK 2
+#define CO_START_OP1 3
+#define CO_START_OP2 4
+#define CO_DRAIN_TX_COMPLETE_CB 5
+#define CO_CHANGE_CHANNEL_CB 6
+#define CO_RETURN_TO_HOME_CHANNEL 7
+#define CO_FINISH_OP_TIMEOUT 8
+#define CO_OP_END 9
+#define CO_CANCEL_OP 10
+#define CO_CHANGE_CHANNEL 11
+#define CO_RELEASE_LOCK 12
+#define CO_CHANGE_STATE 13
+#define CO_DBGID_DEFINITION_END
+
+/* RO debug identifier definitions */
+#define RO_DBGID_DEFINITION_START
+#define RO_REFRESH_ROAM_TABLE 1
+#define RO_UPDATE_ROAM_CANDIDATE 2
+#define RO_UPDATE_ROAM_CANDIDATE_CB 3
+#define RO_UPDATE_ROAM_CANDIDATE_FINISH 4
+#define RO_REFRESH_ROAM_TABLE_DONE 5
+#define RO_PERIODIC_SEARCH_CB 6
+#define RO_PERIODIC_SEARCH_TIMEOUT 7
+#define RO_INIT 8
+#define RO_BMISS_STATE1 9
+#define RO_BMISS_STATE2 10
+#define RO_SET_PERIODIC_SEARCH_ENABLE 11
+#define RO_SET_PERIODIC_SEARCH_DISABLE 12
+#define RO_ENABLE_SQ_THRESHOLD 13
+#define RO_DISABLE_SQ_THRESHOLD 14
+#define RO_ADD_BSS_TO_ROAM_TABLE 15
+#define RO_SET_PERIODIC_SEARCH_MODE 16
+#define RO_CONFIGURE_SQ_THRESHOLD1 17
+#define RO_CONFIGURE_SQ_THRESHOLD2 18
+#define RO_CONFIGURE_SQ_PARAMS 19
+#define RO_LOW_SIGNAL_QUALITY_EVENT 20
+#define RO_HIGH_SIGNAL_QUALITY_EVENT 21
+#define RO_REMOVE_BSS_FROM_ROAM_TABLE 22
+#define RO_UPDATE_CONNECTION_STATE_METRIC 23
+#define RO_LOWRSSI_SCAN_PARAMS 24
+#define RO_LOWRSSI_SCAN_START 25
+#define RO_LOWRSSI_SCAN_END 26
+#define RO_LOWRSSI_SCAN_CANCEL 27
+#define RO_LOWRSSI_ROAM_CANCEL 28
+#define RO_REFRESH_ROAM_CANDIDATE 29
+#define RO_DBGID_DEFINITION_END
+
+/* CM debug identifier definitions */
+#define CM_DBGID_DEFINITION_START
+#define CM_INITIATE_HANDOFF 1
+#define CM_INITIATE_HANDOFF_CB 2
+#define CM_CONNECT_EVENT 3
+#define CM_DISCONNECT_EVENT 4
+#define CM_INIT 5
+#define CM_HANDOFF_SOURCE 6
+#define CM_SET_HANDOFF_TRIGGERS 7
+#define CM_CONNECT_REQUEST 8
+#define CM_CONNECT_REQUEST_CB 9
+#define CM_CONTINUE_SCAN_CB 10
+#define CM_DBGID_DEFINITION_END
+
+
+/* mgmt debug identifier definitions */
+#define MGMT_DBGID_DEFINITION_START
+#define KEYMGMT_CONNECTION_INIT 1
+#define KEYMGMT_CONNECTION_COMPLETE 2
+#define KEYMGMT_CONNECTION_CLOSE 3
+#define KEYMGMT_ADD_KEY 4
+#define MLME_NEW_STATE 5
+#define MLME_CONN_INIT 6
+#define MLME_CONN_COMPLETE 7
+#define MLME_CONN_CLOSE 8
+#define MLME_WLAN_OPMODE 9
+#define MLME_WLAN_SLOTTIME 10
+#define MGMT_DBGID_DEFINITION_END
+
+/* TMR debug identifier definitions */
+#define TMR_DBGID_DEFINITION_START
+#define TMR_HANG_DETECTED 1
+#define TMR_WDT_TRIGGERED 2
+#define TMR_WDT_RESET 3
+#define TMR_HANDLER_ENTRY 4
+#define TMR_HANDLER_EXIT 5
+#define TMR_SAVED_START 6
+#define TMR_SAVED_END 7
+#define TMR_DBGID_DEFINITION_END
+
+/* BTCOEX debug identifier definitions */
+#define BTCOEX_DBGID_DEFINITION_START
+#define BTCOEX_STATUS_CMD 1
+#define BTCOEX_PARAMS_CMD 2
+#define BTCOEX_ANT_CONFIG 3
+#define BTCOEX_COLOCATED_BT_DEVICE 4
+#define BTCOEX_CLOSE_RANGE_SCO_ON 5
+#define BTCOEX_CLOSE_RANGE_SCO_OFF 6
+#define BTCOEX_CLOSE_RANGE_A2DP_ON 7
+#define BTCOEX_CLOSE_RANGE_A2DP_OFF 8
+#define BTCOEX_A2DP_PROTECT_ON 9
+#define BTCOEX_A2DP_PROTECT_OFF 10
+#define BTCOEX_SCO_PROTECT_ON 11
+#define BTCOEX_SCO_PROTECT_OFF 12
+#define BTCOEX_CLOSE_RANGE_DETECTOR_START 13
+#define BTCOEX_CLOSE_RANGE_DETECTOR_STOP 14
+#define BTCOEX_CLOSE_RANGE_TOGGLE 15
+#define BTCOEX_CLOSE_RANGE_TOGGLE_RSSI_LRCNT 16
+#define BTCOEX_CLOSE_RANGE_RSSI_THRESH 17
+#define BTCOEX_CLOSE_RANGE_LOW_RATE_THRESH 18
+#define BTCOEX_PTA_PRI_INTR_HANDLER 19
+#define BTCOEX_PSPOLL_QUEUED 20
+#define BTCOEX_PSPOLL_COMPLETE 21
+#define BTCOEX_DBG_PM_AWAKE 22
+#define BTCOEX_DBG_PM_SLEEP 23
+#define BTCOEX_DBG_SCO_COEX_ON 24
+#define BTCOEX_SCO_DATARECEIVE 25
+#define BTCOEX_INTR_INIT 26
+#define BTCOEX_PTA_PRI_DIFF 27
+#define BTCOEX_TIM_NOTIFICATION 28
+#define BTCOEX_SCO_WAKEUP_ON_DATA 29
+#define BTCOEX_SCO_SLEEP 30
+#define BTCOEX_SET_WEIGHTS 31
+#define BTCOEX_SCO_DATARECEIVE_LATENCY_VAL 32
+#define BTCOEX_SCO_MEASURE_TIME_DIFF 33
+#define BTCOEX_SET_EOL_VAL 34
+#define BTCOEX_OPT_DETECT_HANDLER 35
+#define BTCOEX_SCO_TOGGLE_STATE 36
+#define BTCOEX_SCO_STOMP 37
+#define BTCOEX_NULL_COMP_CALLBACK 38
+#define BTCOEX_RX_INCOMING 39
+#define BTCOEX_RX_INCOMING_CTL 40
+#define BTCOEX_RX_INCOMING_MGMT 41
+#define BTCOEX_RX_INCOMING_DATA 42
+#define BTCOEX_RTS_RECEPTION 43
+#define BTCOEX_FRAME_PRI_LOW_RATE_THRES 44
+#define BTCOEX_PM_FAKE_SLEEP 45
+#define BTCOEX_ACL_COEX_STATUS 46
+#define BTCOEX_ACL_COEX_DETECTION 47
+#define BTCOEX_A2DP_COEX_STATUS 48
+#define BTCOEX_SCO_STATUS 49
+#define BTCOEX_WAKEUP_ON_DATA 50
+#define BTCOEX_DATARECEIVE 51
+#define BTCOEX_GET_MAX_AGGR_SIZE 53
+#define BTCOEX_MAX_AGGR_AVAIL_TIME 54
+#define BTCOEX_DBG_WBTIMER_INTR 55
+#define BTCOEX_DBG_SCO_SYNC 57
+#define BTCOEX_UPLINK_QUEUED_RATE 59
+#define BTCOEX_DBG_UPLINK_ENABLE_EOL 60
+#define BTCOEX_UPLINK_FRAME_DURATION 61
+#define BTCOEX_UPLINK_SET_EOL 62
+#define BTCOEX_DBG_EOL_EXPIRED 63
+#define BTCOEX_DBG_DATA_COMPLETE 64
+#define BTCOEX_UPLINK_QUEUED_TIMESTAMP 65
+#define BTCOEX_DBG_DATA_COMPLETE_TIME 66
+#define BTCOEX_DBG_A2DP_ROLE_IS_SLAVE 67
+#define BTCOEX_DBG_A2DP_ROLE_IS_MASTER 68
+#define BTCOEX_DBG_UPLINK_SEQ_NUM 69
+#define BTCOEX_UPLINK_AGGR_SEQ 70
+#define BTCOEX_DBG_TX_COMP_SEQ_NO 71
+#define BTCOEX_DBG_MAX_AGGR_PAUSE_STATE 72
+#define BTCOEX_DBG_ACL_TRAFFIC 73
+#define BTCOEX_CURR_AGGR_PROP 74
+#define BTCOEX_DBG_SCO_GET_PER_TIME_DIFF 75
+#define BTCOEX_PSPOLL_PROCESS 76
+#define BTCOEX_RETURN_FROM_MAC 77
+#define BTCOEX_FREED_REQUEUED_CNT 78
+#define BTCOEX_DBG_TOGGLE_LOW_RATES 79
+#define BTCOEX_MAC_GOES_TO_SLEEP 80
+#define BTCOEX_DBG_A2DP_NO_SYNC 81
+#define BTCOEX_RETURN_FROM_MAC_HOLD_Q_INFO 82
+#define BTCOEX_RETURN_FROM_MAC_AC 83
+#define BTCOEX_DBG_DTIM_RECV 84
+#define BTCOEX_IS_PRE_UPDATE 86
+#define BTCOEX_ENQUEUED_BIT_MAP 87
+#define BTCOEX_TX_COMPLETE_FIRST_DESC_STATS 88
+#define BTCOEX_UPLINK_DESC 89
+#define BTCOEX_SCO_GET_PER_FIRST_FRM_TIMESTAMP 90
+#define BTCOEX_DBG_RECV_ACK 94
+#define BTCOEX_DBG_ADDBA_INDICATION 95
+#define BTCOEX_TX_COMPLETE_EOL_FAILED 96
+#define BTCOEX_DBG_A2DP_USAGE_COMPLETE 97
+#define BTCOEX_DBG_A2DP_STOMP_FOR_BCN_HANDLER 98
+#define BTCOEX_DBG_A2DP_SYNC_INTR 99
+#define BTCOEX_DBG_A2DP_STOMP_FOR_BCN_RECEPTION 100
+#define BTCOEX_FORM_AGGR_CURR_AGGR 101
+#define BTCOEX_DBG_TOGGLE_A2DP_BURST_CNT 102
+#define BTCOEX_DBG_BT_TRAFFIC 103
+#define BTCOEX_DBG_STOMP_BT_TRAFFIC 104
+#define BTCOEX_RECV_NULL 105
+#define BTCOEX_DBG_A2DP_MASTER_BT_END 106
+#define BTCOEX_DBG_A2DP_BT_START 107
+#define BTCOEX_DBG_A2DP_SLAVE_BT_END 108
+#define BTCOEX_DBG_A2DP_STOMP_BT 109
+#define BTCOEX_DBG_GO_TO_SLEEP 110
+#define BTCOEX_DBG_A2DP_PKT 111
+#define BTCOEX_DBG_A2DP_PSPOLL_DATA_RECV 112
+#define BTCOEX_DBG_A2DP_NULL 113
+#define BTCOEX_DBG_UPLINK_DATA 114
+#define BTCOEX_DBG_A2DP_STOMP_LOW_PRIO_NULL 115
+#define BTCOEX_DBG_ADD_BA_RESP_TIMEOUT 116
+#define BTCOEX_DBG_TXQ_STATE 117
+#define BTCOEX_DBG_ALLOW_SCAN 118
+#define BTCOEX_DBG_SCAN_REQUEST 119
+#define BTCOEX_A2DP_SLEEP 127
+#define BTCOEX_DBG_DATA_ACTIV_TIMEOUT 128
+#define BTCOEX_DBG_SWITCH_TO_PSPOLL_ON_MODE 129
+#define BTCOEX_DBG_SWITCH_TO_PSPOLL_OFF_MODE 130
+#define BTCOEX_DATARECEIVE_AGGR 131
+#define BTCOEX_DBG_DATA_RECV_SLEEPING_PENDING 132
+#define BTCOEX_DBG_DATARESP_TIMEOUT 133
+#define BTCOEX_BDG_BMISS 134
+#define BTCOEX_DBG_DATA_RECV_WAKEUP_TIM 135
+#define BTCOEX_DBG_SECOND_BMISS 136
+#define BTCOEX_DBG_SET_WLAN_STATE 138
+#define BTCOEX_BDG_FIRST_BMISS 139
+#define BTCOEX_DBG_A2DP_CHAN_OP 140
+#define BTCOEX_DBG_A2DP_INTR 141
+#define BTCOEX_DBG_BT_INQUIRY 142
+#define BTCOEX_DBG_BT_INQUIRY_DATA_FETCH 143
+#define BTCOEX_DBG_POST_INQUIRY_FINISH 144
+#define BTCOEX_DBG_SCO_OPT_MODE_TIMER_HANDLER 145
+#define BTCOEX_DBG_NULL_FRAME_SLEEP 146
+#define BTCOEX_DBG_NULL_FRAME_AWAKE 147
+#define BTCOEX_DBG_SET_AGGR_SIZE 152
+#define BTCOEX_DBG_TEAR_BA_TIMEOUT 153
+#define BTCOEX_DBG_MGMT_FRAME_SEQ_NO 154
+#define BTCOEX_DBG_SCO_STOMP_HIGH_PRI 155
+#define BTCOEX_DBG_COLOCATED_BT_DEV 156
+#define BTCOEX_DBG_FE_ANT_TYPE 157
+#define BTCOEX_DBG_BT_INQUIRY_CMD 158
+#define BTCOEX_DBG_SCO_CONFIG 159
+#define BTCOEX_DBG_SCO_PSPOLL_CONFIG 160
+#define BTCOEX_DBG_SCO_OPTMODE_CONFIG 161
+#define BTCOEX_DBG_A2DP_CONFIG 162
+#define BTCOEX_DBG_A2DP_PSPOLL_CONFIG 163
+#define BTCOEX_DBG_A2DP_OPTMODE_CONFIG 164
+#define BTCOEX_DBG_ACLCOEX_CONFIG 165
+#define BTCOEX_DBG_ACLCOEX_PSPOLL_CONFIG 166
+#define BTCOEX_DBG_ACLCOEX_OPTMODE_CONFIG 167
+#define BTCOEX_DBG_DEBUG_CMD 168
+#define BTCOEX_DBG_SET_BT_OPERATING_STATUS 169
+#define BTCOEX_DBG_GET_CONFIG 170
+#define BTCOEX_DBG_GET_STATS 171
+#define BTCOEX_DBG_BT_OPERATING_STATUS 172
+#define BTCOEX_DBG_PERFORM_RECONNECT 173
+#define BTCOEX_DBG_ACL_WLAN_MED 175
+#define BTCOEX_DBG_ACL_BT_MED 176
+#define BTCOEX_DBG_WLAN_CONNECT 177
+#define BTCOEX_DBG_A2DP_DUAL_START 178
+#define BTCOEX_DBG_PMAWAKE_NOTIFY 179
+#define BTCOEX_DBG_BEACON_SCAN_ENABLE 180
+#define BTCOEX_DBG_BEACON_SCAN_DISABLE 181
+#define BTCOEX_DBG_RX_NOTIFY 182
+#define BTCOEX_SCO_GET_PER_SECOND_FRM_TIMESTAMP 183
+#define BTCOEX_DBG_TXQ_DETAILS 184
+#define BTCOEX_DBG_SCO_STOMP_LOW_PRI 185
+#define BTCOEX_DBG_A2DP_FORCE_SCAN 186
+#define BTCOEX_DBG_DTIM_STOMP_COMP 187
+#define BTCOEX_ACL_PRESENCE_TIMER 188
+#define BTCOEX_DBG_QUEUE_SELF_CTS 189
+#define BTCOEX_DBG_SELF_CTS_COMP 190
+#define BTCOEX_DBG_APMODE_WAIT_FOR_CTS_COMP_FAILED 191
+#define BTCOEX_DBG_APMODE_A2DP_MED_TO_BT 192
+#define BTCOEX_DBG_APMODE_SET_BTSTATE 193
+#define BTCOEX_DBG_APMODE_A2DP_STATUS 194
+#define BTCOEX_DBG_APMODE_SCO_CTS_HANDLER 195
+#define BTCOEX_DBG_APMODE_SCO_STATUS 196
+#define BTCOEX_DBG_APMODE_TXQ_DRAINED 197
+#define BTCOEX_DBG_APMODE_SCO_ARM_TIMER 198
+#define BTCOEX_DBG_APMODE_SWITCH_MED_TO_WLAN 199
+#define BTCOEX_APMODE_BCN_TX_HANDLER 200
+#define BTCOEX_APMODE_BCN_TX 201
+#define BTCOEX_APMODE_SCO_RTS_HANDLER 202
+#define BTCOEX_DBGID_DEFINITION_END
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _DBGLOG_ID_H_ */
diff --git a/ath6kl-wmiconfig/include/ieee80211.h b/ath6kl-wmiconfig/include/ieee80211.h
new file mode 100755
index 0000000..4824ee0
--- /dev/null
+++ b/ath6kl-wmiconfig/include/ieee80211.h
@@ -0,0 +1,384 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+#ifndef _NET80211_IEEE80211_H_
+#define _NET80211_IEEE80211_H_
+
+//#include "athstartpack.h"
+
+/*
+ * 802.11 protocol definitions.
+ */
+#define IEEE80211_WEP_KEYLEN 5 /* 40bit */
+#define IEEE80211_WEP_IVLEN 3 /* 24bit */
+#define IEEE80211_WEP_KIDLEN 1 /* 1 octet */
+#define IEEE80211_WEP_CRCLEN 4 /* CRC-32 */
+#define IEEE80211_WEP_NKID 4 /* number of key ids */
+
+/*
+ * 802.11i defines an extended IV for use with non-WEP ciphers.
+ * When the EXTIV bit is set in the key id byte an additional
+ * 4 bytes immediately follow the IV for TKIP. For CCMP the
+ * EXTIV bit is likewise set but the 8 bytes represent the
+ * CCMP header rather than IV+extended-IV.
+ */
+#define IEEE80211_WEP_EXTIV 0x20
+#define IEEE80211_WEP_EXTIVLEN 4 /* extended IV length */
+#define IEEE80211_WEP_MICLEN 8 /* trailing MIC */
+
+#define IEEE80211_CRC_LEN 4
+
+#ifdef WAPI_ENABLE
+#define IEEE80211_WAPI_EXTIVLEN 10 /* extended IV length */
+#endif /* WAPI ENABLE */
+
+
+#define IEEE80211_ADDR_LEN 6 /* size of 802.11 address */
+/* is 802.11 address multicast/broadcast? */
+#define IEEE80211_IS_MULTICAST(_a) (*(_a) & 0x01)
+#define IEEE80211_IS_BROADCAST(_a) (*(_a) == 0xFF)
+#define WEP_HEADER (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN)
+#define WEP_TRAILER IEEE80211_WEP_CRCLEN
+#define CCMP_HEADER (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN + \
+ IEEE80211_WEP_EXTIVLEN)
+#define CCMP_TRAILER IEEE80211_WEP_MICLEN
+#define TKIP_HEADER (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN + \
+ IEEE80211_WEP_EXTIVLEN)
+#define TKIP_TRAILER IEEE80211_WEP_CRCLEN
+#define TKIP_MICLEN IEEE80211_WEP_MICLEN
+
+
+#define IEEE80211_ADDR_EQ(addr1, addr2) \
+ (A_MEMCMP(addr1, addr2, IEEE80211_ADDR_LEN) == 0)
+
+#define IEEE80211_ADDR_COPY(dst,src) A_MEMCPY(dst,src,IEEE80211_ADDR_LEN)
+
+#define IEEE80211_KEYBUF_SIZE 16
+#define IEEE80211_MICBUF_SIZE (8+8) /* space for both tx and rx */
+
+/*
+ * NB: these values are ordered carefully; there are lots of
+ * of implications in any reordering. In particular beware
+ * that 4 is not used to avoid conflicting with IEEE80211_F_PRIVACY.
+ */
+#define IEEE80211_CIPHER_WEP 0
+#define IEEE80211_CIPHER_TKIP 1
+#define IEEE80211_CIPHER_AES_OCB 2
+#define IEEE80211_CIPHER_AES_CCM 3
+#define IEEE80211_CIPHER_CKIP 5
+#define IEEE80211_CIPHER_CCKM_KRK 6
+#define IEEE80211_CIPHER_NONE 7 /* pseudo value */
+
+#define IEEE80211_CIPHER_MAX (IEEE80211_CIPHER_NONE+1)
+
+#define IEEE80211_IS_VALID_WEP_CIPHER_LEN(len) \
+ (((len) == 5) || ((len) == 13) || ((len) == 16))
+
+
+
+/*
+ * generic definitions for IEEE 802.11 frames
+ */
+PREPACK struct ieee80211_frame {
+ A_UINT8 i_fc[2];
+ A_UINT8 i_dur[2];
+ A_UINT8 i_addr1[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr2[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr3[IEEE80211_ADDR_LEN];
+ A_UINT8 i_seq[2];
+ /* possibly followed by addr4[IEEE80211_ADDR_LEN]; */
+ /* see below */
+} POSTPACK;
+
+PREPACK struct ieee80211_qosframe {
+ A_UINT8 i_fc[2];
+ A_UINT8 i_dur[2];
+ A_UINT8 i_addr1[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr2[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr3[IEEE80211_ADDR_LEN];
+ A_UINT8 i_seq[2];
+ A_UINT8 i_qos[2];
+} POSTPACK;
+
+#define IEEE80211_FC0_VERSION_MASK 0x03
+#define IEEE80211_FC0_VERSION_SHIFT 0
+#define IEEE80211_FC0_VERSION_0 0x00
+#define IEEE80211_FC0_TYPE_MASK 0x0c
+#define IEEE80211_FC0_TYPE_SHIFT 2
+#define IEEE80211_FC0_TYPE_MGT 0x00
+#define IEEE80211_FC0_TYPE_CTL 0x04
+#define IEEE80211_FC0_TYPE_DATA 0x08
+
+#define IEEE80211_FC0_SUBTYPE_MASK 0xf0
+#define IEEE80211_FC0_SUBTYPE_SHIFT 4
+/* for TYPE_MGT */
+#define IEEE80211_FC0_SUBTYPE_ASSOC_REQ 0x00
+#define IEEE80211_FC0_SUBTYPE_ASSOC_RESP 0x10
+#define IEEE80211_FC0_SUBTYPE_REASSOC_REQ 0x20
+#define IEEE80211_FC0_SUBTYPE_REASSOC_RESP 0x30
+#define IEEE80211_FC0_SUBTYPE_PROBE_REQ 0x40
+#define IEEE80211_FC0_SUBTYPE_PROBE_RESP 0x50
+#define IEEE80211_FC0_SUBTYPE_BEACON 0x80
+#define IEEE80211_FC0_SUBTYPE_ATIM 0x90
+#define IEEE80211_FC0_SUBTYPE_DISASSOC 0xa0
+#define IEEE80211_FC0_SUBTYPE_AUTH 0xb0
+#define IEEE80211_FC0_SUBTYPE_DEAUTH 0xc0
+/* for TYPE_CTL */
+#define IEEE80211_FC0_SUBTYPE_PS_POLL 0xa0
+#define IEEE80211_FC0_SUBTYPE_RTS 0xb0
+#define IEEE80211_FC0_SUBTYPE_CTS 0xc0
+#define IEEE80211_FC0_SUBTYPE_ACK 0xd0
+#define IEEE80211_FC0_SUBTYPE_CF_END 0xe0
+#define IEEE80211_FC0_SUBTYPE_CF_END_ACK 0xf0
+/* for TYPE_DATA (bit combination) */
+#define IEEE80211_FC0_SUBTYPE_DATA 0x00
+#define IEEE80211_FC0_SUBTYPE_CF_ACK 0x10
+#define IEEE80211_FC0_SUBTYPE_CF_POLL 0x20
+#define IEEE80211_FC0_SUBTYPE_CF_ACPL 0x30
+#define IEEE80211_FC0_SUBTYPE_NODATA 0x40
+#define IEEE80211_FC0_SUBTYPE_CFACK 0x50
+#define IEEE80211_FC0_SUBTYPE_CFPOLL 0x60
+#define IEEE80211_FC0_SUBTYPE_CF_ACK_CF_ACK 0x70
+#define IEEE80211_FC0_SUBTYPE_QOS 0x80
+#define IEEE80211_FC0_SUBTYPE_QOS_NULL 0xc0
+
+#define IEEE80211_FC1_DIR_MASK 0x03
+#define IEEE80211_FC1_DIR_NODS 0x00 /* STA->STA */
+#define IEEE80211_FC1_DIR_TODS 0x01 /* STA->AP */
+#define IEEE80211_FC1_DIR_FROMDS 0x02 /* AP ->STA */
+#define IEEE80211_FC1_DIR_DSTODS 0x03 /* AP ->AP */
+
+#define IEEE80211_FC1_MORE_FRAG 0x04
+#define IEEE80211_FC1_RETRY 0x08
+#define IEEE80211_FC1_PWR_MGT 0x10
+#define IEEE80211_FC1_MORE_DATA 0x20
+#define IEEE80211_FC1_WEP 0x40
+#define IEEE80211_FC1_ORDER 0x80
+
+#define IEEE80211_SEQ_FRAG_MASK 0x000f
+#define IEEE80211_SEQ_FRAG_SHIFT 0
+#define IEEE80211_SEQ_SEQ_MASK 0xfff0
+#define IEEE80211_SEQ_SEQ_SHIFT 4
+
+#define IEEE80211_NWID_LEN 32
+
+/*
+ * 802.11 rate set.
+ */
+#define IEEE80211_RATE_SIZE 8 /* 802.11 standard */
+#define IEEE80211_RATE_MAXSIZE 15 /* max rates we'll handle */
+
+#define WMM_NUM_AC 4 /* 4 AC categories */
+
+#define WMM_PARAM_ACI_M 0x60 /* Mask for ACI field */
+#define WMM_PARAM_ACI_S 5 /* Shift for ACI field */
+#define WMM_PARAM_ACM_M 0x10 /* Mask for ACM bit */
+#define WMM_PARAM_ACM_S 4 /* Shift for ACM bit */
+#define WMM_PARAM_AIFSN_M 0x0f /* Mask for aifsn field */
+#define WMM_PARAM_LOGCWMIN_M 0x0f /* Mask for CwMin field (in log) */
+#define WMM_PARAM_LOGCWMAX_M 0xf0 /* Mask for CwMax field (in log) */
+#define WMM_PARAM_LOGCWMAX_S 4 /* Shift for CwMax field */
+
+#define WMM_AC_TO_TID(_ac) ( \
+ ((_ac) == WMM_AC_VO) ? 6 : \
+ ((_ac) == WMM_AC_VI) ? 5 : \
+ ((_ac) == WMM_AC_BK) ? 1 : \
+ 0)
+
+#define TID_TO_WMM_AC(_tid) ( \
+ ((_tid) < 1) ? WMM_AC_BE : \
+ ((_tid) < 3) ? WMM_AC_BK : \
+ ((_tid) < 6) ? WMM_AC_VI : \
+ WMM_AC_VO)
+/*
+ * Management information element payloads.
+ */
+
+enum {
+ IEEE80211_ELEMID_SSID = 0,
+ IEEE80211_ELEMID_RATES = 1,
+ IEEE80211_ELEMID_FHPARMS = 2,
+ IEEE80211_ELEMID_DSPARMS = 3,
+ IEEE80211_ELEMID_CFPARMS = 4,
+ IEEE80211_ELEMID_TIM = 5,
+ IEEE80211_ELEMID_IBSSPARMS = 6,
+ IEEE80211_ELEMID_COUNTRY = 7,
+ IEEE80211_ELEMID_CHALLENGE = 16,
+ /* 17-31 reserved for challenge text extension */
+ IEEE80211_ELEMID_PWRCNSTR = 32,
+ IEEE80211_ELEMID_PWRCAP = 33,
+ IEEE80211_ELEMID_TPCREQ = 34,
+ IEEE80211_ELEMID_TPCREP = 35,
+ IEEE80211_ELEMID_SUPPCHAN = 36,
+ IEEE80211_ELEMID_CHANSWITCH = 37,
+ IEEE80211_ELEMID_MEASREQ = 38,
+ IEEE80211_ELEMID_MEASREP = 39,
+ IEEE80211_ELEMID_QUIET = 40,
+ IEEE80211_ELEMID_IBSSDFS = 41,
+ IEEE80211_ELEMID_ERP = 42,
+ IEEE80211_ELEMID_HTCAP_ANA = 45, /* Address ANA, and non-ANA story, for interop. CL#171733 */
+ IEEE80211_ELEMID_RSN = 48,
+ IEEE80211_ELEMID_XRATES = 50,
+ IEEE80211_ELEMID_HTINFO_ANA = 61,
+#ifdef WAPI_ENABLE
+ IEEE80211_ELEMID_WAPI = 68,
+#endif
+ IEEE80211_ELEMID_TPC = 150,
+ IEEE80211_ELEMID_CCKM = 156,
+ IEEE80211_ELEMID_VENDOR = 221, /* vendor private */
+};
+
+#define ATH_OUI 0x7f0300 /* Atheros OUI */
+#define ATH_OUI_TYPE 0x01
+#define ATH_OUI_SUBTYPE 0x01
+#define ATH_OUI_VERSION 0x00
+
+#define WPA_OUI 0xf25000
+#define WPA_OUI_TYPE 0x01
+#define WPA_VERSION 1 /* current supported version */
+
+#define WPA_CSE_NULL 0x00
+#define WPA_CSE_WEP40 0x01
+#define WPA_CSE_TKIP 0x02
+#define WPA_CSE_CCMP 0x04
+#define WPA_CSE_WEP104 0x05
+
+#define WPA_ASE_NONE 0x00
+#define WPA_ASE_8021X_UNSPEC 0x01
+#define WPA_ASE_8021X_PSK 0x02
+
+#define RSN_OUI 0xac0f00
+#define RSN_VERSION 1 /* current supported version */
+
+#define RSN_CSE_NULL 0x00
+#define RSN_CSE_WEP40 0x01
+#define RSN_CSE_TKIP 0x02
+#define RSN_CSE_WRAP 0x03
+#define RSN_CSE_CCMP 0x04
+#define RSN_CSE_WEP104 0x05
+
+#define RSN_ASE_NONE 0x00
+#define RSN_ASE_8021X_UNSPEC 0x01
+#define RSN_ASE_8021X_PSK 0x02
+
+#define RSN_CAP_PREAUTH 0x01
+
+#define WMM_OUI 0xf25000
+#define WMM_OUI_TYPE 0x02
+#define WMM_INFO_OUI_SUBTYPE 0x00
+#define WMM_PARAM_OUI_SUBTYPE 0x01
+#define WMM_VERSION 1
+
+/* WMM stream classes */
+#define WMM_NUM_AC 4
+#define WMM_AC_BE 0 /* best effort */
+#define WMM_AC_BK 1 /* background */
+#define WMM_AC_VI 2 /* video */
+#define WMM_AC_VO 3 /* voice */
+
+/* TSPEC related */
+#define ACTION_CATEGORY_CODE_TSPEC 17
+#define ACTION_CODE_TSPEC_ADDTS 0
+#define ACTION_CODE_TSPEC_ADDTS_RESP 1
+#define ACTION_CODE_TSPEC_DELTS 2
+
+typedef enum {
+ TSPEC_STATUS_CODE_ADMISSION_ACCEPTED = 0,
+ TSPEC_STATUS_CODE_ADDTS_INVALID_PARAMS = 0x1,
+ TSPEC_STATUS_CODE_ADDTS_REQUEST_REFUSED = 0x3,
+ TSPEC_STATUS_CODE_UNSPECIFIED_QOS_RELATED_FAILURE = 0xC8,
+ TSPEC_STATUS_CODE_REQUESTED_REFUSED_POLICY_CONFIGURATION = 0xC9,
+ TSPEC_STATUS_CODE_INSUFFCIENT_BANDWIDTH = 0xCA,
+ TSPEC_STATUS_CODE_INVALID_PARAMS = 0xCB,
+ TSPEC_STATUS_CODE_DELTS_SENT = 0x30,
+ TSPEC_STATUS_CODE_DELTS_RECV = 0x31,
+} TSPEC_STATUS_CODE;
+
+#define TSPEC_TSID_MASK 0xF
+#define TSPEC_TSID_S 1
+
+/*
+ * WMM/802.11e Tspec Element
+ */
+typedef PREPACK struct wmm_tspec_ie_t {
+ A_UINT8 elementId;
+ A_UINT8 len;
+ A_UINT8 oui[3];
+ A_UINT8 ouiType;
+ A_UINT8 ouiSubType;
+ A_UINT8 version;
+ A_UINT16 tsInfo_info;
+ A_UINT8 tsInfo_reserved;
+ A_UINT16 nominalMSDU;
+ A_UINT16 maxMSDU;
+ A_UINT32 minServiceInt;
+ A_UINT32 maxServiceInt;
+ A_UINT32 inactivityInt;
+ A_UINT32 suspensionInt;
+ A_UINT32 serviceStartTime;
+ A_UINT32 minDataRate;
+ A_UINT32 meanDataRate;
+ A_UINT32 peakDataRate;
+ A_UINT32 maxBurstSize;
+ A_UINT32 delayBound;
+ A_UINT32 minPhyRate;
+ A_UINT16 sba;
+ A_UINT16 mediumTime;
+} POSTPACK WMM_TSPEC_IE;
+
+
+/*
+ * BEACON management packets
+ *
+ * octet timestamp[8]
+ * octet beacon interval[2]
+ * octet capability information[2]
+ * information element
+ * octet elemid
+ * octet length
+ * octet information[length]
+ */
+
+#define IEEE80211_BEACON_INTERVAL(beacon) \
+ ((beacon)[8] | ((beacon)[9] << 8))
+#define IEEE80211_BEACON_CAPABILITY(beacon) \
+ ((beacon)[10] | ((beacon)[11] << 8))
+
+#define IEEE80211_CAPINFO_ESS 0x0001
+#define IEEE80211_CAPINFO_IBSS 0x0002
+#define IEEE80211_CAPINFO_CF_POLLABLE 0x0004
+#define IEEE80211_CAPINFO_CF_POLLREQ 0x0008
+#define IEEE80211_CAPINFO_PRIVACY 0x0010
+#define IEEE80211_CAPINFO_SHORT_PREAMBLE 0x0020
+#define IEEE80211_CAPINFO_PBCC 0x0040
+#define IEEE80211_CAPINFO_CHNL_AGILITY 0x0080
+/* bits 8-9 are reserved */
+#define IEEE80211_CAPINFO_SHORT_SLOTTIME 0x0400
+#define IEEE80211_CAPINFO_APSD 0x0800
+/* bit 12 is reserved */
+#define IEEE80211_CAPINFO_DSSSOFDM 0x2000
+/* bits 14-15 are reserved */
+
+/*
+ * Authentication Modes
+ */
+
+enum ieee80211_authmode {
+ IEEE80211_AUTH_NONE = 0,
+ IEEE80211_AUTH_OPEN = 1,
+ IEEE80211_AUTH_SHARED = 2,
+ IEEE80211_AUTH_8021X = 3,
+ IEEE80211_AUTH_AUTO = 4, /* auto-select/accept */
+ /* NB: these are used only for ioctls */
+ IEEE80211_AUTH_WPA = 5, /* WPA/RSN w/ 802.1x */
+ IEEE80211_AUTH_WPA_PSK = 6, /* WPA/RSN w/ PSK */
+ IEEE80211_AUTH_WPA_CCKM = 7, /* WPA/RSN IE w/ CCKM */
+};
+
+#define IEEE80211_PS_MAX_QUEUE 50 /*Maximum no of buffers that can be queues for PS*/
+
+//#include "athendpack.h"
+
+#endif /* _NET80211_IEEE80211_H_ */
diff --git a/ath6kl-wmiconfig/include/ieee80211_ioctl.h b/ath6kl-wmiconfig/include/ieee80211_ioctl.h
new file mode 100755
index 0000000..c0ff150
--- /dev/null
+++ b/ath6kl-wmiconfig/include/ieee80211_ioctl.h
@@ -0,0 +1,164 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+#ifndef _IEEE80211_IOCTL_H_
+#define _IEEE80211_IOCTL_H_
+
+#include <linux/version.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+ * Extracted from the MADWIFI net80211/ieee80211_ioctl.h
+ */
+
+/*
+ * WPA/RSN get/set key request. Specify the key/cipher
+ * type and whether the key is to be used for sending and/or
+ * receiving. The key index should be set only when working
+ * with global keys (use IEEE80211_KEYIX_NONE for ``no index'').
+ * Otherwise a unicast/pairwise key is specified by the bssid
+ * (on a station) or mac address (on an ap). They key length
+ * must include any MIC key data; otherwise it should be no
+ more than IEEE80211_KEYBUF_SIZE.
+ */
+struct ieee80211req_key {
+ u_int8_t ik_type; /* key/cipher type */
+ u_int8_t ik_pad;
+ u_int16_t ik_keyix; /* key index */
+ u_int8_t ik_keylen; /* key length in bytes */
+ u_int8_t ik_flags;
+#define IEEE80211_KEY_XMIT 0x01
+#define IEEE80211_KEY_RECV 0x02
+#define IEEE80211_KEY_DEFAULT 0x80 /* default xmit key */
+ u_int8_t ik_macaddr[IEEE80211_ADDR_LEN];
+ u_int64_t ik_keyrsc; /* key receive sequence counter */
+ u_int64_t ik_keytsc; /* key transmit sequence counter */
+ u_int8_t ik_keydata[IEEE80211_KEYBUF_SIZE+IEEE80211_MICBUF_SIZE];
+};
+/*
+ * Delete a key either by index or address. Set the index
+ * to IEEE80211_KEYIX_NONE when deleting a unicast key.
+ */
+struct ieee80211req_del_key {
+ u_int8_t idk_keyix; /* key index */
+ u_int8_t idk_macaddr[IEEE80211_ADDR_LEN];
+};
+/*
+ * MLME state manipulation request. IEEE80211_MLME_ASSOC
+ * only makes sense when operating as a station. The other
+ * requests can be used when operating as a station or an
+ * ap (to effect a station).
+ */
+struct ieee80211req_mlme {
+ u_int8_t im_op; /* operation to perform */
+#define IEEE80211_MLME_ASSOC 1 /* associate station */
+#define IEEE80211_MLME_DISASSOC 2 /* disassociate station */
+#define IEEE80211_MLME_DEAUTH 3 /* deauthenticate station */
+#define IEEE80211_MLME_AUTHORIZE 4 /* authorize station */
+#define IEEE80211_MLME_UNAUTHORIZE 5 /* unauthorize station */
+ u_int16_t im_reason; /* 802.11 reason code */
+ u_int8_t im_macaddr[IEEE80211_ADDR_LEN];
+};
+
+struct ieee80211req_addpmkid {
+ u_int8_t pi_bssid[IEEE80211_ADDR_LEN];
+ u_int8_t pi_enable;
+ u_int8_t pi_pmkid[16];
+};
+
+#define AUTH_ALG_OPEN_SYSTEM 0x01
+#define AUTH_ALG_SHARED_KEY 0x02
+#define AUTH_ALG_LEAP 0x04
+
+struct ieee80211req_authalg {
+ u_int8_t auth_alg;
+};
+
+/*
+ * Request to add an IE to a Management Frame
+ */
+enum{
+ IEEE80211_APPIE_FRAME_BEACON = 0,
+ IEEE80211_APPIE_FRAME_PROBE_REQ = 1,
+ IEEE80211_APPIE_FRAME_PROBE_RESP = 2,
+ IEEE80211_APPIE_FRAME_ASSOC_REQ = 3,
+ IEEE80211_APPIE_FRAME_ASSOC_RESP = 4,
+ IEEE80211_APPIE_NUM_OF_FRAME = 5
+};
+
+/*
+ * The Maximum length of the IE that can be added to a Management frame
+ */
+#define IEEE80211_APPIE_FRAME_MAX_LEN 200
+
+struct ieee80211req_getset_appiebuf {
+ u_int32_t app_frmtype; /* management frame type for which buffer is added */
+ u_int32_t app_buflen; /*application supplied buffer length */
+ u_int8_t app_buf[];
+};
+
+/*
+ * The following definitions are used by an application to set filter
+ * for receiving management frames
+ */
+enum {
+ IEEE80211_FILTER_TYPE_BEACON = 0x1,
+ IEEE80211_FILTER_TYPE_PROBE_REQ = 0x2,
+ IEEE80211_FILTER_TYPE_PROBE_RESP = 0x4,
+ IEEE80211_FILTER_TYPE_ASSOC_REQ = 0x8,
+ IEEE80211_FILTER_TYPE_ASSOC_RESP = 0x10,
+ IEEE80211_FILTER_TYPE_AUTH = 0x20,
+ IEEE80211_FILTER_TYPE_DEAUTH = 0x40,
+ IEEE80211_FILTER_TYPE_DISASSOC = 0x80,
+ IEEE80211_FILTER_TYPE_ALL = 0xFF /* used to check the valid filter bits */
+};
+
+struct ieee80211req_set_filter {
+ u_int32_t app_filterype; /* management frame filter type */
+};
+
+enum {
+ IEEE80211_PARAM_AUTHMODE = 3, /* Authentication Mode */
+ IEEE80211_PARAM_MCASTCIPHER = 5,
+ IEEE80211_PARAM_MCASTKEYLEN = 6, /* multicast key length */
+ IEEE80211_PARAM_UCASTCIPHER = 8,
+ IEEE80211_PARAM_UCASTKEYLEN = 9, /* unicast key length */
+ IEEE80211_PARAM_WPA = 10, /* WPA mode (0,1,2) */
+ IEEE80211_PARAM_ROAMING = 12, /* roaming mode */
+ IEEE80211_PARAM_PRIVACY = 13, /* privacy invoked */
+ IEEE80211_PARAM_COUNTERMEASURES = 14, /* WPA/TKIP countermeasures */
+ IEEE80211_PARAM_DROPUNENCRYPTED = 15, /* discard unencrypted frames */
+ IEEE80211_PARAM_WAPI = 16, /* WAPI policy from wapid */
+};
+
+/*
+ * Values for IEEE80211_PARAM_WPA
+ */
+#define WPA_MODE_WPA1 1
+#define WPA_MODE_WPA2 2
+#define WPA_MODE_AUTO 3
+#define WPA_MODE_NONE 4
+
+struct ieee80211req_wpaie {
+ u_int8_t wpa_macaddr[IEEE80211_ADDR_LEN];
+ u_int8_t wpa_ie[IEEE80211_MAX_IE];
+ u_int8_t rsn_ie[IEEE80211_MAX_IE];
+};
+
+#ifndef IW_ENCODE_ALG_PMK
+#define IW_ENCODE_ALG_PMK 4
+#endif
+#ifndef IW_ENCODE_ALG_KRK
+#define IW_ENCODE_ALG_KRK 6
+#endif
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _IEEE80211_IOCTL_H_ */
diff --git a/ath6kl-wmiconfig/include/osapi_linux.h b/ath6kl-wmiconfig/include/osapi_linux.h
new file mode 100755
index 0000000..feb84d0
--- /dev/null
+++ b/ath6kl-wmiconfig/include/osapi_linux.h
@@ -0,0 +1,377 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+//------------------------------------------------------------------------------
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _OSAPI_LINUX_H_
+#define _OSAPI_LINUX_H_
+
+#ifdef __KERNEL__
+
+#include <linux/version.h>
+#include <linux/types.h>
+#include <linux/kernel.h>
+#include <linux/string.h>
+#include <linux/skbuff.h>
+#include <linux/netdevice.h>
+#include <linux/device.h>
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24)
+#include <linux/ethtool.h>
+#endif
+/*************************************/
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+#include <linux/jiffies.h>
+#endif
+#include <linux/timer.h>
+#include <linux/delay.h>
+#include <linux/wait.h>
+#ifdef KERNEL_2_4
+#include <asm/arch/irq.h>
+#include <asm/irq.h>
+#endif
+
+#include <linux/cache.h>
+
+#ifdef __GNUC__
+#define __ATTRIB_PACK __attribute__ ((packed))
+#define __ATTRIB_PRINTF __attribute__ ((format (printf, 1, 2)))
+#define __ATTRIB_NORETURN __attribute__ ((noreturn))
+#ifndef INLINE
+#define INLINE __inline__
+#endif
+#else /* Not GCC */
+#define __ATTRIB_PACK
+#define __ATTRIB_PRINTF
+#define __ATTRIB_NORETURN
+#ifndef INLINE
+#define INLINE __inline
+#endif
+#endif /* End __GNUC__ */
+
+#define PREPACK
+#define POSTPACK __ATTRIB_PACK
+
+/*
+ * Endianes macros
+ */
+#define A_BE2CPU8(x) ntohb(x)
+#define A_BE2CPU16(x) ntohs(x)
+#define A_BE2CPU32(x) ntohl(x)
+
+#define A_LE2CPU8(x) (x)
+#define A_LE2CPU16(x) (x)
+#define A_LE2CPU32(x) (x)
+
+#define A_CPU2BE8(x) htonb(x)
+#define A_CPU2BE16(x) htons(x)
+#define A_CPU2BE32(x) htonl(x)
+
+#define A_MEMCPY(dst, src, len) memcpy((A_UINT8 *)(dst), (src), (len))
+#define A_MEMZERO(addr, len) memset(addr, 0, len)
+#define A_MEMCMP(addr1, addr2, len) memcmp((addr1), (addr2), (len))
+
+#ifdef AR6K_ALLOC_DEBUG
+#define a_meminfo_add(p, s) __a_meminfo_add(p, s, __func__, __LINE)
+void __a_meminfo_add(void *ptr, size_t msize, const char *func, int lineno);
+void a_meminfo_del(void *ptr);
+void* a_mem_alloc(size_t msize, int type, const char *func, int lineno);
+void a_mem_free(void *ptr);
+void a_meminfo_report(int clear);
+A_BOOL a_meminfo_find(void *ptr);
+#define A_MALLOC(size) a_mem_alloc((size), GFP_KERNEL, __func__, __LINE__)
+#define A_MALLOC_NOWAIT(size) a_mem_alloc((size), GFP_ATOMIC, __func__, __LINE__)
+#define A_FREE(addr) a_mem_free(addr)
+#define A_NETIF_RX(skb) do { a_meminfo_del(skb); netif_rx(skb); } while (0)
+#define A_NETIF_RX_NI(skb) do { a_meminfo_del(skb); netif_rx_ni(skb); } while (0)
+#else
+#define a_meminfo_report(_c)
+#define A_MALLOC(size) kmalloc((size), GFP_KERNEL)
+#define A_MALLOC_NOWAIT(size) kmalloc((size), GFP_ATOMIC)
+#define A_FREE(addr) kfree(addr)
+#define A_NETIF_RX(skb) netif_rx(skb)
+#define A_NETIF_RX_NI(skb) netif_rx_ni(skb)
+#endif
+
+#if defined(ANDROID_ENV) && defined(CONFIG_ANDROID_LOGGER)
+extern unsigned int enablelogcat;
+extern int android_logger_lv(void* module, int mask);
+enum logidx { LOG_MAIN_IDX = 0 };
+extern int logger_write(const enum logidx idx,
+ const unsigned char prio,
+ const char __kernel * const tag,
+ const char __kernel * const fmt,
+ ...);
+#define A_ANDROID_PRINTF(mask, module, tags, args...) do { \
+ if (enablelogcat) \
+ logger_write(LOG_MAIN_IDX, android_logger_lv(module, mask), tags, args); \
+ else \
+ printk(KERN_ALERT args); \
+} while (0)
+#ifdef DEBUG
+#define A_LOGGER_MODULE_NAME(x) #x
+#define A_LOGGER(mask, mod, args...) \
+ A_ANDROID_PRINTF(mask, &GET_ATH_MODULE_DEBUG_VAR_NAME(mod), "ar6k_" A_LOGGER_MODULE_NAME(mod), args);
+#endif
+#define A_PRINTF(args...) A_ANDROID_PRINTF(ATH_DEBUG_INFO, NULL, "ar6k_driver", args)
+#else
+#define A_LOGGER(mask, mod, args...) printk(KERN_ALERT args)
+#define A_PRINTF(args...) printk(KERN_ALERT args)
+#endif /* ANDROID */
+#define A_PRINTF_LOG(args...) printk(args)
+#define A_SPRINTF(buf, args...) sprintf (buf, args)
+
+/* Mutual Exclusion */
+typedef spinlock_t A_MUTEX_T;
+#define A_MUTEX_INIT(mutex) spin_lock_init(mutex)
+#define A_MUTEX_LOCK(mutex) spin_lock_bh(mutex)
+#define A_MUTEX_UNLOCK(mutex) spin_unlock_bh(mutex)
+#define A_IS_MUTEX_VALID(mutex) TRUE /* okay to return true, since A_MUTEX_DELETE does nothing */
+#define A_MUTEX_DELETE(mutex) /* spin locks are not kernel resources so nothing to free.. */
+
+/* Get current time in ms adding a constant offset (in ms) */
+#define A_GET_MS(offset) \
+ (((jiffies / HZ) * 1000) + (offset))
+
+/*
+ * Timer Functions
+ */
+#define A_MDELAY(msecs) mdelay(msecs)
+typedef struct timer_list A_TIMER;
+
+#define A_INIT_TIMER(pTimer, pFunction, pArg) do { \
+ init_timer(pTimer); \
+ (pTimer)->function = (pFunction); \
+ (pTimer)->data = (unsigned long)(pArg); \
+} while (0)
+
+/*
+ * Start a Timer that elapses after 'periodMSec' milli-seconds
+ * Support is provided for a one-shot timer. The 'repeatFlag' is
+ * ignored.
+ */
+#define A_TIMEOUT_MS(pTimer, periodMSec, repeatFlag) do { \
+ if (repeatFlag) { \
+ printk("\n" __FILE__ ":%d: Timer Repeat requested\n",__LINE__); \
+ panic("Timer Repeat"); \
+ } \
+ mod_timer((pTimer), jiffies + HZ * (periodMSec) / 1000); \
+} while (0)
+
+/*
+ * Cancel the Timer.
+ */
+#define A_UNTIMEOUT(pTimer) do { \
+ del_timer((pTimer)); \
+} while (0)
+
+#define A_DELETE_TIMER(pTimer) do { \
+} while (0)
+
+define A_WAKE_UP(head) wake_up(head)
+
+#ifdef DEBUG
+extern unsigned int panic_on_assert;
+#define A_ASSERT(expr) \
+ if (!(expr)) { \
+ printk(KERN_ALERT"Debug Assert Caught, File %s, Line: %d, Test:%s \n",__FILE__, __LINE__,#expr); \
+ if (panic_on_assert) panic(#expr); \
+ }
+#else
+#define A_ASSERT(expr)
+#endif /* DEBUG */
+
+#ifdef ANDROID_ENV
+struct firmware;
+int android_request_firmware(const struct firmware **firmware_p, const char *filename,
+ struct device *device);
+void android_release_firmware(const struct firmware *firmware);
+#define A_REQUEST_FIRMWARE(_ppf, _pfile, _dev) android_request_firmware(_ppf, _pfile, _dev)
+#define A_RELEASE_FIRMWARE(_pf) android_release_firmware(_pf)
+#else
+#define A_REQUEST_FIRMWARE(_ppf, _pfile, _dev) request_firmware(_ppf, _pfile, _dev)
+#define A_RELEASE_FIRMWARE(_pf) release_firmware(_pf)
+#endif
+
+/*
+ * Initialization of the network buffer subsystem
+ */
+#define A_NETBUF_INIT()
+
+/*
+ * Network buffer queue support
+ */
+typedef struct sk_buff_head A_NETBUF_QUEUE_T;
+
+#define A_NETBUF_QUEUE_INIT(q) \
+ a_netbuf_queue_init(q)
+
+#define A_NETBUF_ENQUEUE(q, pkt) \
+ a_netbuf_enqueue((q), (pkt))
+#define A_NETBUF_PREQUEUE(q, pkt) \
+ a_netbuf_prequeue((q), (pkt))
+#define A_NETBUF_DEQUEUE(q) \
+ (a_netbuf_dequeue(q))
+#define A_NETBUF_QUEUE_SIZE(q) \
+ a_netbuf_queue_size(q)
+#define A_NETBUF_QUEUE_EMPTY(q) \
+ a_netbuf_queue_empty(q)
+
+/*
+ * Network buffer support
+ */
+#ifdef AR6K_ALLOC_DEBUG
+#define A_NETBUF_ALLOC(size) \
+ a_netbuf_alloc(size, __func__, __LINE__)
+#define A_NETBUF_ALLOC_RAW(size) \
+ a_netbuf_alloc_raw(size, __func__, __LINE__)
+#define A_NETBUF_CHECK(bufPtr) \
+ a_netbuf_check(bufPtr, __func__, __LINE__)
+#else
+#define A_NETBUF_ALLOC(size) \
+ a_netbuf_alloc(size)
+#define A_NETBUF_ALLOC_RAW(size) \
+ a_netbuf_alloc_raw(size)
+#endif /* AR6K_ALLOC_DEBUG */
+#define A_NETBUF_FREE(bufPtr) \
+ a_netbuf_free(bufPtr)
+#define A_NETBUF_DATA(bufPtr) \
+ a_netbuf_to_data(bufPtr)
+#define A_NETBUF_LEN(bufPtr) \
+ a_netbuf_to_len(bufPtr)
+#define A_NETBUF_PUSH(bufPtr, len) \
+ a_netbuf_push(bufPtr, len)
+#define A_NETBUF_PUT(bufPtr, len) \
+ a_netbuf_put(bufPtr, len)
+#define A_NETBUF_TRIM(bufPtr,len) \
+ a_netbuf_trim(bufPtr, len)
+#define A_NETBUF_PULL(bufPtr, len) \
+ a_netbuf_pull(bufPtr, len)
+#define A_NETBUF_HEADROOM(bufPtr)\
+ a_netbuf_headroom(bufPtr)
+#define A_NETBUF_SETLEN(bufPtr,len) \
+ a_netbuf_setlen(bufPtr, len)
+
+/* Add data to end of a buffer */
+#define A_NETBUF_PUT_DATA(bufPtr, srcPtr, len) \
+ a_netbuf_put_data(bufPtr, srcPtr, len)
+
+/* Add data to start of the buffer */
+#define A_NETBUF_PUSH_DATA(bufPtr, srcPtr, len) \
+ a_netbuf_push_data(bufPtr, srcPtr, len)
+
+/* Remove data at start of the buffer */
+#define A_NETBUF_PULL_DATA(bufPtr, dstPtr, len) \
+ a_netbuf_pull_data(bufPtr, dstPtr, len)
+
+/* Remove data from the end of the buffer */
+#define A_NETBUF_TRIM_DATA(bufPtr, dstPtr, len) \
+ a_netbuf_trim_data(bufPtr, dstPtr, len)
+
+/* View data as "size" contiguous bytes of type "t" */
+#define A_NETBUF_VIEW_DATA(bufPtr, t, size) \
+ (t )( ((struct skbuf *)(bufPtr))->data)
+
+/* return the beginning of the headroom for the buffer */
+#define A_NETBUF_HEAD(bufPtr) \
+ ((((struct sk_buff *)(bufPtr))->head))
+
+/*
+ * OS specific network buffer access routines
+ */
+#ifdef AR6K_ALLOC_DEBUG
+void *a_netbuf_alloc(int size, const char *func, int lineno);
+void *a_netbuf_alloc_raw(int size, const char *func, int lineno);
+void a_netbuf_check(void *bufPtr, const char *func, int lineno);
+#else
+void *a_netbuf_alloc(int size);
+void *a_netbuf_alloc_raw(int size);
+#endif
+void a_netbuf_free(void *bufPtr);
+void *a_netbuf_to_data(void *bufPtr);
+A_UINT32 a_netbuf_to_len(void *bufPtr);
+A_STATUS a_netbuf_push(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_push_data(void *bufPtr, char *srcPtr, A_INT32 len);
+A_STATUS a_netbuf_put(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_put_data(void *bufPtr, char *srcPtr, A_INT32 len);
+A_STATUS a_netbuf_pull(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_pull_data(void *bufPtr, char *dstPtr, A_INT32 len);
+A_STATUS a_netbuf_trim(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_trim_data(void *bufPtr, char *dstPtr, A_INT32 len);
+A_STATUS a_netbuf_setlen(void *bufPtr, A_INT32 len);
+A_INT32 a_netbuf_headroom(void *bufPtr);
+void a_netbuf_enqueue(A_NETBUF_QUEUE_T *q, void *pkt);
+void a_netbuf_prequeue(A_NETBUF_QUEUE_T *q, void *pkt);
+void *a_netbuf_dequeue(A_NETBUF_QUEUE_T *q);
+int a_netbuf_queue_size(A_NETBUF_QUEUE_T *q);
+int a_netbuf_queue_empty(A_NETBUF_QUEUE_T *q);
+int a_netbuf_queue_empty(A_NETBUF_QUEUE_T *q);
+void a_netbuf_queue_init(A_NETBUF_QUEUE_T *q);
+
+/*
+ * Kernel v.s User space functions
+ */
+A_UINT32 a_copy_to_user(void *to, const void *from, A_UINT32 n);
+A_UINT32 a_copy_from_user(void *to, const void *from, A_UINT32 n);
+
+/* In linux, WLAN Rx and Tx run in different contexts, so no need to check
+ * for any commands/data queued for WLAN */
+#define A_CHECK_DRV_TX()
+
+#define A_GET_CACHE_LINE_BYTES() L1_CACHE_BYTES
+
+#define A_CACHE_LINE_PAD 128
+
+static inline void *A_ALIGN_TO_CACHE_LINE(void *ptr) {
+ return (void *)L1_CACHE_ALIGN((unsigned long)ptr);
+}
+
+#else /* __KERNEL__ */
+
+#ifdef __GNUC__
+#define __ATTRIB_PACK __attribute__ ((packed))
+#define __ATTRIB_PRINTF __attribute__ ((format (printf, 1, 2)))
+#define __ATTRIB_NORETURN __attribute__ ((noreturn))
+#ifndef INLINE
+#define INLINE __inline__
+#endif
+#else /* Not GCC */
+#define __ATTRIB_PACK
+#define __ATTRIB_PRINTF
+#define __ATTRIB_NORETURN
+#ifndef INLINE
+#define INLINE __inline
+#endif
+#endif /* End __GNUC__ */
+
+#define PREPACK
+#define POSTPACK __ATTRIB_PACK
+
+#define A_MEMCPY(dst, src, len) memcpy((dst), (src), (len))
+#define A_MEMZERO(addr, len) memset((addr), 0, (len))
+#define A_MEMCMP(addr1, addr2, len) memcmp((addr1), (addr2), (len))
+#define A_MALLOC(size) malloc(size)
+#define A_FREE(addr) free(addr)
+
+#ifdef ANDROID
+#ifndef err
+#include <errno.h>
+#define err(_s, args...) do { \
+ fprintf(stderr, "%s: line %d ", __FILE__, __LINE__); \
+ fprintf(stderr, args); fprintf(stderr, ": %d\n", errno); \
+ exit(_s); } while (0)
+#endif
+#else
+#include <err.h>
+#endif
+
+#endif /* __KERNEL__ */
+
+#endif /* _OSAPI_LINUX_H_ */
diff --git a/ath6kl-wmiconfig/include/pkt_log.h b/ath6kl-wmiconfig/include/pkt_log.h
new file mode 100755
index 0000000..a542a91
--- /dev/null
+++ b/ath6kl-wmiconfig/include/pkt_log.h
@@ -0,0 +1,29 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+#ifndef __PKT_LOG_H__
+#define __PKT_LOG_H__
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+/* Pkt log info */
+typedef PREPACK struct pkt_log_t {
+ struct info_t {
+ A_UINT16 st;
+ A_UINT16 end;
+ A_UINT16 cur;
+ }info[4096];
+ A_UINT16 last_idx;
+}POSTPACK PACKET_LOG;
+
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* __PKT_LOG_H__ */
diff --git a/ath6kl-wmiconfig/include/testcmd.h b/ath6kl-wmiconfig/include/testcmd.h
new file mode 100755
index 0000000..20f58c9
--- /dev/null
+++ b/ath6kl-wmiconfig/include/testcmd.h
@@ -0,0 +1,263 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+#ifndef TESTCMD_H_
+#define TESTCMD_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#ifdef AR6002_REV2
+#define TCMD_MAX_RATES 12
+#else
+#define TCMD_MAX_RATES 28
+#endif
+
+#define WMI_CMD_ID_SIZE 4
+#define WMI_CMDS_SIZE_MAX 2048
+#define TC_CMDS_GAP 16
+// should add up to the same size as buf[WMI_CMDS_SIZE_MAX]
+//#define TC_CMDS_SIZE_MAX (WMI_CMDS_SIZE_MAX - sizeof(TC_CMDS_HDR) - WMI_CMD_ID_SIZE - TC_CMDS_GAP)
+#define TC_CMDS_SIZE_MAX 256
+
+typedef enum {
+ ZEROES_PATTERN = 0,
+ ONES_PATTERN,
+ REPEATING_10,
+ PN7_PATTERN,
+ PN9_PATTERN,
+ PN15_PATTERN
+}TX_DATA_PATTERN;
+
+/* Continous tx
+ mode : TCMD_CONT_TX_OFF - Disabling continous tx
+ TCMD_CONT_TX_SINE - Enable continuous unmodulated tx
+ TCMD_CONT_TX_FRAME- Enable continuous modulated tx
+ freq : Channel freq in Mhz. (e.g 2412 for channel 1 in 11 g)
+dataRate: 0 - 1 Mbps
+ 1 - 2 Mbps
+ 2 - 5.5 Mbps
+ 3 - 11 Mbps
+ 4 - 6 Mbps
+ 5 - 9 Mbps
+ 6 - 12 Mbps
+ 7 - 18 Mbps
+ 8 - 24 Mbps
+ 9 - 36 Mbps
+ 10 - 28 Mbps
+ 11 - 54 Mbps
+ txPwr: twice the Tx power in dBm, actual dBm values of [5 -11] for unmod Tx,
+ [5-14] for mod Tx
+antenna: 1 - one antenna
+ 2 - two antenna
+Note : Enable/disable continuous tx test cmd works only when target is awake.
+*/
+
+typedef enum {
+ TCMD_CONT_TX_OFF = 0,
+ TCMD_CONT_TX_SINE,
+ TCMD_CONT_TX_FRAME,
+ TCMD_CONT_TX_TX99,
+ TCMD_CONT_TX_TX100
+} TCMD_CONT_TX_MODE;
+
+typedef enum {
+ TCMD_WLAN_MODE_NOHT = 0,
+ TCMD_WLAN_MODE_HT20 = 1,
+ TCMD_WLAN_MODE_HT40PLUS = 2,
+ TCMD_WLAN_MODE_HT40MINUS = 3,
+ TCMD_WLAN_MODE_CCK = 4,
+
+ TCMD_WLAN_MODE_MAX,
+ TCMD_WLAN_MODE_INVALID = TCMD_WLAN_MODE_MAX,
+
+} TCMD_WLAN_MODE;
+
+typedef enum {
+ TPC_TX_PWR = 0,
+ TPC_FORCED_GAIN,
+ TPC_TGT_PWR
+} TPC_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 mode;
+ A_UINT32 freq;
+ A_UINT32 dataRate;
+ A_INT32 txPwr;
+ A_UINT32 antenna;
+ A_UINT32 enANI;
+ A_UINT32 scramblerOff;
+ A_UINT32 aifsn;
+ A_UINT16 pktSz;
+ A_UINT16 txPattern;
+ A_UINT32 shortGuard;
+ A_UINT32 numPackets;
+ A_UINT32 wlanMode;
+ A_UINT32 tpcm;
+} POSTPACK TCMD_CONT_TX;
+
+#define TCMD_TXPATTERN_ZERONE 0x1
+#define TCMD_TXPATTERN_ZERONE_DIS_SCRAMBLE 0x2
+
+/* Continuous Rx
+ act: TCMD_CONT_RX_PROMIS - promiscuous mode (accept all incoming frames)
+ TCMD_CONT_RX_FILTER - filter mode (accept only frames with dest
+ address equal specified
+ mac address (set via act =3)
+ TCMD_CONT_RX_REPORT off mode (disable cont rx mode and get the
+ report from the last cont
+ Rx test)
+
+ TCMD_CONT_RX_SETMAC - set MacAddr mode (sets the MAC address for the
+ target. This Overrides
+ the default MAC address.)
+
+*/
+typedef enum {
+ TCMD_CONT_RX_PROMIS =0,
+ TCMD_CONT_RX_FILTER,
+ TCMD_CONT_RX_REPORT,
+ TCMD_CONT_RX_SETMAC,
+ TCMD_CONT_RX_SET_ANT_SWITCH_TABLE,
+
+ TC_CMD_RESP,
+} TCMD_CONT_RX_ACT;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 act;
+ A_UINT32 enANI;
+ PREPACK union {
+ struct PREPACK TCMD_CONT_RX_PARA {
+ A_UINT32 freq;
+ A_UINT32 antenna;
+ A_UINT32 wlanMode;
+ } POSTPACK para;
+ struct PREPACK TCMD_CONT_RX_REPORT {
+ A_UINT32 totalPkt;
+ A_INT32 rssiInDBm;
+ A_UINT32 crcErrPkt;
+ A_UINT32 secErrPkt;
+ A_UINT16 rateCnt[TCMD_MAX_RATES];
+ A_UINT16 rateCntShortGuard[TCMD_MAX_RATES];
+ } POSTPACK report;
+ struct PREPACK TCMD_CONT_RX_MAC {
+ A_UCHAR addr[ATH_MAC_LEN];
+ A_UCHAR btaddr[ATH_MAC_LEN];
+ A_UINT16 regDmn[2];
+ A_UINT32 otpWriteFlag;
+ } POSTPACK mac;
+ struct PREPACK TCMD_CONT_RX_ANT_SWITCH_TABLE {
+ A_UINT32 antswitch1;
+ A_UINT32 antswitch2;
+ }POSTPACK antswitchtable;
+ } POSTPACK u;
+} POSTPACK TCMD_CONT_RX;
+
+/* Force sleep/wake test cmd
+ mode: TCMD_PM_WAKEUP - Wakeup the target
+ TCMD_PM_SLEEP - Force the target to sleep.
+ */
+typedef enum {
+ TCMD_PM_WAKEUP = 1, /* be consistent with target */
+ TCMD_PM_SLEEP,
+ TCMD_PM_DEEPSLEEP
+} TCMD_PM_MODE;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 mode;
+} POSTPACK TCMD_PM;
+
+typedef enum {
+ TC_CMDS_VERSION_RESERVED=0,
+ TC_CMDS_VERSION_MDK,
+ TC_CMDS_VERSION_TS,
+ TC_CMDS_VERSION_LAST,
+} TC_CMDS_VERSION;
+
+typedef enum {
+ TC_CMDS_TS =0,
+ TC_CMDS_CAL,
+ TC_CMDS_TPCCAL = TC_CMDS_CAL,
+ TC_CMDS_TPCCAL_WITH_OTPWRITE,
+ TC_CMDS_OTPDUMP,
+ TC_CMDS_OTPSTREAMWRITE,
+ TC_CMDS_EFUSEDUMP,
+ TC_CMDS_EFUSEWRITE,
+ TC_CMDS_READTHERMAL,
+} TC_CMDS_ACT;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 act;
+ PREPACK union {
+ A_UINT32 enANI; // to be identical to CONT_RX struct
+ struct PREPACK {
+ A_UINT16 length;
+ A_UINT8 version;
+ A_UINT8 bufLen;
+ } POSTPACK parm;
+ } POSTPACK u;
+} POSTPACK TC_CMDS_HDR;
+
+typedef PREPACK struct {
+ TC_CMDS_HDR hdr;
+ A_UINT8 buf[TC_CMDS_SIZE_MAX];
+} POSTPACK TC_CMDS;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 regAddr;
+ A_UINT32 val;
+ A_UINT16 flag;
+} POSTPACK TCMD_SET_REG;
+
+typedef enum {
+ TCMD_CONT_TX_ID,
+ TCMD_CONT_RX_ID,
+ TCMD_PM_ID,
+ TC_CMDS_ID,
+ TCMD_SET_REG_ID,
+
+ /*For synergy purpose we added the following tcmd id but these
+ tcmd's will not go to the firmware instead we will write values
+ to the NV area */
+
+ TCMD_NIC_MAC = 100,
+ TCMD_CAL_FILE_INDEX = 101,
+} TCMD_ID;
+
+typedef PREPACK struct
+{
+ A_UINT32 testCmdId;
+ A_UINT8 mac_address[ATH_MAC_LEN];
+} POSTPACK TCMD_NIC_MAC_S;
+
+typedef PREPACK struct
+{
+ A_UINT32 testCmdId;
+ A_UINT32 cal_file_index;
+} POSTPACK TCMD_CAL_FILE_INDEX_S;
+
+typedef PREPACK union {
+ TCMD_CONT_TX contTx;
+ TCMD_CONT_RX contRx;
+ TCMD_PM pm;
+ // New test cmds from ART/MDK ...
+ TC_CMDS tcCmds;
+ TCMD_SET_REG setReg;
+} POSTPACK TEST_CMD;
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* TESTCMD_H_ */
+
+
diff --git a/ath6kl-wmiconfig/include/wmi.h b/ath6kl-wmiconfig/include/wmi.h
new file mode 100755
index 0000000..8655a85
--- /dev/null
+++ b/ath6kl-wmiconfig/include/wmi.h
@@ -0,0 +1,4838 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+
+/*
+ * This file contains the definitions of the WMI protocol specified in the
+ * Wireless Module Interface (WMI). It includes definitions of all the
+ * commands and events. Commands are messages from the host to the WM.
+ * Events and Replies are messages from the WM to the host.
+ *
+ * Ownership of correctness in regards to commands
+ * belongs to the host driver and the WMI is not required to validate
+ * parameters for value, proper range, or any other checking.
+ *
+ */
+
+#ifndef _WMI_H_
+#define _WMI_H_
+
+#ifndef ATH_TARGET
+//#include "athstartpack.h"
+#endif
+
+//#include "wmix.h"
+//#include "wlan_defs.h"
+//#include "dfs_common.h"
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define HTC_PROTOCOL_VERSION 0x0002
+#define HTC_PROTOCOL_REVISION 0x0000
+
+#define WMI_PROTOCOL_VERSION 0x0002
+#define WMI_PROTOCOL_REVISION 0x0000
+
+#define ATH_MAC_LEN 6 /* length of mac in bytes */
+#define WMI_CMD_MAX_LEN 100
+#define WMI_CONTROL_MSG_MAX_LEN 256
+#define WMI_OPT_CONTROL_MSG_MAX_LEN 1536
+#define IS_ETHERTYPE(_typeOrLen) ((_typeOrLen) >= 0x0600)
+#define RFC1042OUI {0x00, 0x00, 0x00}
+
+#define IP_ETHERTYPE 0x0800
+
+#define WMI_IMPLICIT_PSTREAM 0xFF
+#define WMI_MAX_THINSTREAM 15
+
+#ifdef AR6002_REV2
+#define IBSS_MAX_NUM_STA 4
+#else
+#define IBSS_MAX_NUM_STA 8
+#endif
+
+#define WMI_MODE_MAX 8
+#define WMI_MAX_RATE_MASK 2
+#define WMI_NETWORK_TYPE(networkType) ((networkType) & 0x000F)
+#define WMI_CONNECTED_PHYMODE(networkType) (((networkType) & 0x0F00) >> 8)
+
+/* Max rates we'll handle */
+#define WMI_RATE_MAXSIZE 15
+/*
+ * These constants are used with A_WLAN_BAND_SET.
+ */
+#define A_BAND_24GHZ 0
+#define A_BAND_5GHZ 1
+#define A_NUM_BANDS 2
+
+PREPACK struct host_app_area_s {
+ A_UINT32 wmi_protocol_ver;
+} POSTPACK;
+
+/*
+ * Data Path
+ */
+typedef PREPACK struct {
+ A_UINT8 dstMac[ATH_MAC_LEN];
+ A_UINT8 srcMac[ATH_MAC_LEN];
+ A_UINT16 typeOrLen;
+} POSTPACK ATH_MAC_HDR;
+
+typedef PREPACK struct {
+ A_UINT8 dsap;
+ A_UINT8 ssap;
+ A_UINT8 cntl;
+ A_UINT8 orgCode[3];
+ A_UINT16 etherType;
+} POSTPACK ATH_LLC_SNAP_HDR;
+
+typedef enum {
+ DATA_MSGTYPE = 0x0,
+ CNTL_MSGTYPE,
+ SYNC_MSGTYPE,
+ OPT_MSGTYPE,
+} WMI_MSG_TYPE;
+
+
+/*
+ * Macros for operating on WMI_DATA_HDR (info) field
+ */
+
+#define WMI_DATA_HDR_MSG_TYPE_MASK 0x03
+#define WMI_DATA_HDR_MSG_TYPE_SHIFT 0
+#define WMI_DATA_HDR_UP_MASK 0x07
+#define WMI_DATA_HDR_UP_SHIFT 2
+/* In AP mode, the same bit (b5) is used to indicate Power save state in
+ * the Rx dir and More data bit state in the tx direction.
+ */
+#define WMI_DATA_HDR_PS_MASK 0x1
+#define WMI_DATA_HDR_PS_SHIFT 5
+
+#define WMI_DATA_HDR_MORE_MASK 0x1
+#define WMI_DATA_HDR_MORE_SHIFT 5
+
+typedef enum {
+ WMI_DATA_HDR_DATA_TYPE_802_3 = 0,
+ WMI_DATA_HDR_DATA_TYPE_802_11,
+ WMI_DATA_HDR_DATA_TYPE_ACL,
+} WMI_DATA_HDR_DATA_TYPE;
+
+/* Bitmap of data header flags */
+typedef enum {
+ WMI_DATA_HDR_FLAGS_MORE = 0x1,
+ WMI_DATA_HDR_FLAGS_EOSP = 0x2,
+} WMI_DATA_HDR_FLAGS;
+
+#define WMI_DATA_HDR_DATA_TYPE_MASK 0x3
+#define WMI_DATA_HDR_DATA_TYPE_SHIFT 6
+
+#define WMI_DATA_HDR_GET_RSSI(h) ((h)->rssi)
+
+#define WMI_DATA_HDR_SET_MORE_BIT(h) ((h)->info |= (WMI_DATA_HDR_MORE_MASK << WMI_DATA_HDR_MORE_SHIFT))
+#define WMI_DATA_HDR_HAS_MORE_BIT(h) ((h)->info & (WMI_DATA_HDR_MORE_MASK << WMI_DATA_HDR_MORE_SHIFT))
+
+#define WMI_DATA_HDR_IS_MSG_TYPE(h, t) (((h)->info & (WMI_DATA_HDR_MSG_TYPE_MASK)) == (t))
+#define WMI_DATA_HDR_SET_MSG_TYPE(h, t) (h)->info = (((h)->info & ~(WMI_DATA_HDR_MSG_TYPE_MASK << WMI_DATA_HDR_MSG_TYPE_SHIFT)) | (t << WMI_DATA_HDR_MSG_TYPE_SHIFT))
+#define WMI_DATA_HDR_GET_UP(h) (((h)->info >> WMI_DATA_HDR_UP_SHIFT) & WMI_DATA_HDR_UP_MASK)
+#define WMI_DATA_HDR_SET_UP(h, p) (h)->info = (((h)->info & ~(WMI_DATA_HDR_UP_MASK << WMI_DATA_HDR_UP_SHIFT)) | (p << WMI_DATA_HDR_UP_SHIFT))
+
+#define WMI_DATA_HDR_GET_DATA_TYPE(h) (((h)->info >> WMI_DATA_HDR_DATA_TYPE_SHIFT) & WMI_DATA_HDR_DATA_TYPE_MASK)
+#define WMI_DATA_HDR_SET_DATA_TYPE(h, p) (h)->info = (((h)->info & ~(WMI_DATA_HDR_DATA_TYPE_MASK << WMI_DATA_HDR_DATA_TYPE_SHIFT)) | ((p) << WMI_DATA_HDR_DATA_TYPE_SHIFT))
+
+#define WMI_DATA_HDR_GET_DOT11(h) (WMI_DATA_HDR_GET_DATA_TYPE((h)) == WMI_DATA_HDR_DATA_TYPE_802_11)
+#define WMI_DATA_HDR_SET_DOT11(h, p) WMI_DATA_HDR_SET_DATA_TYPE((h), (p))
+
+/* Macros for operating on WMI_DATA_HDR (info2) field */
+#define WMI_DATA_HDR_SEQNO_MASK 0xFFF
+#define WMI_DATA_HDR_SEQNO_SHIFT 0
+
+#define WMI_DATA_HDR_AMSDU_MASK 0x1
+#define WMI_DATA_HDR_AMSDU_SHIFT 12
+
+#define WMI_DATA_HDR_META_MASK 0x7
+#define WMI_DATA_HDR_META_SHIFT 13
+
+#define GET_SEQ_NO(_v) ((_v) & WMI_DATA_HDR_SEQNO_MASK)
+#define GET_ISMSDU(_v) ((_v) & WMI_DATA_HDR_AMSDU_MASK)
+
+#define WMI_DATA_HDR_GET_SEQNO(h) GET_SEQ_NO((h)->info2 >> WMI_DATA_HDR_SEQNO_SHIFT)
+#define WMI_DATA_HDR_SET_SEQNO(h, _v) ((h)->info2 = ((h)->info2 & ~(WMI_DATA_HDR_SEQNO_MASK << WMI_DATA_HDR_SEQNO_SHIFT)) | (GET_SEQ_NO(_v) << WMI_DATA_HDR_SEQNO_SHIFT))
+
+#define WMI_DATA_HDR_IS_AMSDU(h) GET_ISMSDU((h)->info2 >> WMI_DATA_HDR_AMSDU_SHIFT)
+#define WMI_DATA_HDR_SET_AMSDU(h, _v) ((h)->info2 = ((h)->info2 & ~(WMI_DATA_HDR_AMSDU_MASK << WMI_DATA_HDR_AMSDU_SHIFT)) | (GET_ISMSDU(_v) << WMI_DATA_HDR_AMSDU_SHIFT))
+
+#define WMI_DATA_HDR_GET_META(h) (((h)->info2 >> WMI_DATA_HDR_META_SHIFT) & WMI_DATA_HDR_META_MASK)
+#define WMI_DATA_HDR_SET_META(h, _v) ((h)->info2 = ((h)->info2 & ~(WMI_DATA_HDR_META_MASK << WMI_DATA_HDR_META_SHIFT)) | ((_v) << WMI_DATA_HDR_META_SHIFT))
+
+/* Macros for operating on WMI_DATA_HDR (info3) field */
+#define WMI_DATA_HDR_DEVID_MASK 0xF
+#define WMI_DATA_HDR_DEVID_SHIFT 0
+#define GET_DEVID(_v) ((_v) & WMI_DATA_HDR_DEVID_MASK)
+
+#define WMI_DATA_HDR_GET_DEVID(h) (((h)->info3 >> WMI_DATA_HDR_DEVID_SHIFT) & WMI_DATA_HDR_DEVID_MASK)
+#define WMI_DATA_HDR_SET_DEVID(h, _v) ((h)->info3 = ((h)->info3 & ~(WMI_DATA_HDR_DEVID_MASK << WMI_DATA_HDR_DEVID_SHIFT)) | (GET_DEVID(_v) << WMI_DATA_HDR_DEVID_SHIFT))
+
+#define WMI_DATA_HDR_RXFILT_SHIFT 4
+#define WMI_DATA_HDR_RXFILT_MASK (0x1 << WMI_DATA_HDR_RXFILT_SHIFT)
+
+#define WMI_DATA_HDR_IS_RXFILTERED(h) ((h)->info3 & WMI_DATA_HDR_RXFILT_MASK)
+#define SET_WMI_DATA_HDR_RXFILTERED(h) (h)->info3 |= WMI_DATA_HDR_RXFILT_MASK
+
+#define WMI_DATA_HDR_TRIGGER_MASK 0x1
+#define WMI_DATA_HDR_TRIGGER_SHIFT 4
+#define WMI_DATA_HDR_SET_TRIGGER(h, _v) ((h)->info3 = ((h)->info3 & ~(WMI_DATA_HDR_TRIGGER_MASK << WMI_DATA_HDR_TRIGGER_SHIFT)) | ((_v) << WMI_DATA_HDR_TRIGGER_SHIFT))
+#define WMI_DATA_HDR_IS_TRIGGER(h) ((((h)->info3 >> WMI_DATA_HDR_TRIGGER_SHIFT) & WMI_DATA_HDR_TRIGGER_MASK) == WMI_DATA_HDR_TRIGGER_MASK)
+
+#define WMI_DATA_HDR_EOSP_MASK WMI_DATA_HDR_TRIGGER_MASK
+#define WMI_DATA_HDR_EOSP_SHIFT WMI_DATA_HDR_TRIGGER_SHIFT
+
+#define WMI_DATA_HDR_SET_EOSP_BIT(h) ((h)->info3 |= (WMI_DATA_HDR_EOSP_MASK << WMI_DATA_HDR_EOSP_SHIFT))
+#define WMI_DATA_HDR_HAS_EOSP_BIT(h) ((h)->info3 & (WMI_DATA_HDR_EOSP_MASK << WMI_DATA_HDR_EOSP_SHIFT))
+
+
+#define WMI_DATA_HDR_CCX_LINKTEST_MASK 0x1
+#define WMI_DATA_HDR_CCX_LINKTEST_SHIFT 5
+#define WMI_DATA_HDR_SET_CCX_LINKTEST_BIT(h) ((h)->info3 |= (WMI_DATA_HDR_CCX_LINKTEST_MASK << WMI_DATA_HDR_CCX_LINKTEST_SHIFT))
+#define WMI_DATA_HDR_HAS_CCX_LINKTEST_BIT(h) ((h)->info3 & (WMI_DATA_HDR_CCX_LINKTEST_MASK << WMI_DATA_HDR_CCX_LINKTEST_SHIFT))
+
+#define WMI_DATA_HDR_PAD_BEFORE_DATA_MASK 0xFF
+#define WMI_DATA_HDR_PAD_BEFORE_DATA_SHIFT 0x8
+#define GET_PAD_BEFORE_DATA_START(_v) ((_v) & WMI_DATA_HDR_PAD_BEFORE_DATA_MASK)
+
+#define WMI_DATA_HDR_GET_PAD_BEFORE_DATA_START(h) (((h)->info3 >> WMI_DATA_HDR_PAD_BEFORE_DATA_SHIFT) & WMI_DATA_HDR_PAD_BEFORE_DATA_MASK)
+#define WMI_DATA_HDR_SET_PAD_BEFORE_DATA_START(h, _v) ((h)->info3 = ((h)->info3 & ~(WMI_DATA_HDR_PAD_BEFORE_DATA_MASK << WMI_DATA_HDR_PAD_BEFORE_DATA_SHIFT)) | (GET_PAD_BEFORE_DATA_START(_v) << WMI_DATA_HDR_PAD_BEFORE_DATA_SHIFT))
+
+typedef PREPACK struct {
+ A_INT8 rssi;
+ A_UINT8 info; /* usage of 'info' field(8-bit):
+ * b1:b0 - WMI_MSG_TYPE
+ * b4:b3:b2 - UP(tid)
+ * b5 - Used in AP mode. More-data in tx dir, PS in rx.
+ * b7:b6 - Dot3 header(0),
+ * Dot11 Header(1),
+ * ACL data(2)
+ */
+
+ A_UINT16 info2; /* usage of 'info2' field(16-bit):
+ * b11:b0 - seq_no
+ * b12 - A-MSDU?
+ * b15:b13 - META_DATA_VERSION 0 - 7
+ */
+ A_UINT16 info3; /* b3:b2:b1:b0 - device id
+ * b4 - Used in AP mode. uAPSD trigger in rx, EOSP in tx
+ * b7:b5 - unused?
+ * b15:b8 - pad before data start(irrespective of meta version)
+ */
+} POSTPACK WMI_DATA_HDR;
+
+/*
+ * TX META VERSION DEFINITIONS
+ */
+#define WMI_MAX_TX_META_SZ (12)
+#define WMI_MAX_TX_META_VERSION (7)
+#define WMI_META_VERSION_1 (0x01)
+#define WMI_META_VERSION_2 (0X02)
+#define WMI_META_VERSION_3 (0x03)
+#define WMI_META_VERSION_4 (0x04)
+
+#define WMI_ACL_TO_DOT11_HEADROOM 36
+
+#if 0 /* removed to prevent compile errors for WM.. */
+typedef PREPACK struct {
+/* intentionally empty. Default version is no meta data. */
+} POSTPACK WMI_TX_META_V0;
+#endif
+
+typedef PREPACK struct {
+ A_UINT8 pktID; /* The packet ID to identify the tx request */
+ A_UINT8 ratePolicyID; /* The rate policy to be used for the tx of this frame */
+} POSTPACK WMI_TX_META_V1;
+
+
+#define WMI_CSUM_DIR_TX (0x1)
+#define TX_CSUM_CALC_FILL (0x1)
+typedef PREPACK struct {
+ A_UINT8 csumStart; /*Offset from start of the Payload(SNAP header) for csum calculation to begin */
+ A_UINT8 csumDest; /*Offset from start of Payload(SNAP header) where final csum goes*/
+ A_UINT8 csumFlags; /*Flag for check sum engine to be offloaded to device*/
+} POSTPACK WMI_TX_META_V2;
+
+/* WMI_META_TX_FLAG... are used as TX qualifiers for frames containing WMI_TX_RATE_SCHEDULE in the
+ * meta data. 0 or more of these flags should be assigned to the flags member of the schedule. */
+#define WMI_META_TX_FLAG_ACK 0x01 // frame needs ACK response from receiver
+#define WMI_META_TX_FLAG_SET_RETRY_BIT 0x02 // device will set retry bit in MAC header for retried frames.
+#define WMI_META_TX_FLAG_SET_DURATION 0x04 // device will fill duration field in MAC header
+/* NOTE: If WMI_META_TX_FLAG_USE_PREFIX == 0 device will NOT use prefix frame.
+ * If WMI_META_TX_FLAG_USE_PREFIX == 1 && WMI_META_TX_FLAG_PREFIX_RTS == 0 device will use CTS prefix.
+ * If WMI_META_TX_FLAG_USE_PREFIX == 1 && WMI_META_TX_FLAG_PREFIX_RTS == 1 device will use RTS prefix.
+ */
+#define WMI_META_TX_FLAG_USE_PREFIX 0x08 // device will send either RTS or CTS frame prior to subject frame.
+#define WMI_META_TX_FLAG_PREFIX_RTS 0x10 // device will send RTS and wait for CTS prior to sending subject frame.
+#define WMI_META_TX_LOAD_TSF 0x20 // device will fill the TSF field during transmit procedure. <Beacons/probe responses>
+
+/* WMI_TX_RATE_SCHEDULE - Acts as a host-provided rate schedule to replace what would be normally determined
+ * by firmware. This allows the host to specify what rates and attempts should be used to transmit the
+ * frame. */
+typedef PREPACK struct {
+#define WMI_TX_MAX_RATE_SERIES (4)
+ A_UINT8 rateSeries[WMI_TX_MAX_RATE_SERIES]; //rate index for each series. first invalid rate terminates series.
+ A_UINT8 trySeries[WMI_TX_MAX_RATE_SERIES]; //number of tries for each series.
+ A_UINT8 flags; // combination of WMI_META_TX_FLAG...
+ A_UINT8 accessCategory; // should be WMM_AC_BE for managment frames and multicast frames.
+ //A_UINT8 keyIndex;
+ //
+}POSTPACK WMI_TX_RATE_SCHEDULE;
+
+#ifdef TIME_BASED_DISCARD
+typedef PREPACK struct {
+ A_UINT32 txdiscardTime;
+ A_UINT8 discardDispostion;
+} POSTPACK WMI_TX_META_V4;
+#endif
+
+typedef PREPACK struct {
+ WMI_TX_RATE_SCHEDULE rateSched;
+ A_UINT8 pktID; /* The packet ID to identify the tx request */
+} POSTPACK WMI_TX_META_V3;
+
+/*
+ * RX META VERSION DEFINITIONS
+ */
+/* if RX meta data is present at all then the meta data field
+ * will consume WMI_MAX_RX_META_SZ bytes of space between the
+ * WMI_DATA_HDR and the payload. How much of the available
+ * Meta data is actually used depends on which meta data
+ * version is active. */
+#define WMI_MAX_RX_META_SZ (12)
+#define WMI_MAX_RX_META_VERSION (7)
+
+#define WMI_RX_STATUS_OK 0 /* success */
+#define WMI_RX_STATUS_DECRYPT_ERR 1 /* decrypt error */
+#define WMI_RX_STATUS_MIC_ERR 2 /* tkip MIC error */
+#define WMI_RX_STATUS_ERR 3 /* undefined error */
+
+#define WMI_RX_FLAGS_AGGR 0x0001 /* part of AGGR */
+#define WMI_RX_FlAGS_STBC 0x0002 /* used STBC */
+#define WMI_RX_FLAGS_SGI 0x0004 /* used SGI */
+#define WMI_RX_FLAGS_HT 0x0008 /* is HT packet */
+/* the flags field is also used to store the CRYPTO_TYPE of the frame
+ * that value is shifted by WMI_RX_FLAGS_CRYPTO_SHIFT */
+#define WMI_RX_FLAGS_CRYPTO_SHIFT 4
+#define WMI_RX_FLAGS_CRYPTO_MASK 0x1f
+#define WMI_RX_META_GET_CRYPTO(flags) (((flags) >> WMI_RX_FLAGS_CRYPTO_SHIFT) & WMI_RX_FLAGS_CRYPTO_MASK)
+
+#if 0 /* removed to prevent compile errors for WM.. */
+typedef PREPACK struct {
+/* intentionally empty. Default version is no meta data. */
+} POSTPACK WMI_RX_META_VERSION_0;
+#endif
+
+typedef PREPACK struct {
+ A_UINT8 status; /* one of WMI_RX_STATUS_... */
+ A_UINT8 rix; /* rate index mapped to rate at which this packet was received. */
+ A_UINT8 rssi; /* rssi of packet */
+ A_UINT8 channel;/* rf channel during packet reception */
+ A_UINT16 flags; /* a combination of WMI_RX_FLAGS_... */
+} POSTPACK WMI_RX_META_V1;
+
+#define RX_CSUM_VALID_FLAG (0x1)
+typedef PREPACK struct {
+ A_UINT16 csum;
+ A_UINT8 csumFlags;/* bit 0 set -partial csum valid
+ bit 1 set -test mode */
+} POSTPACK WMI_RX_META_V2;
+
+#ifdef TIME_BASED_DISCARD
+typedef PREPACK struct {
+ A_UINT8 discardDispostion;
+ A_UINT32 txdiscardTime;
+} POSTPACK WMI_RX_META_V4;
+#endif
+
+
+#define WMI_GET_DEVICE_ID(info1) ((info1) & 0xF)
+/* Macros for operating on WMI_CMD_HDR (info1) field */
+#define WMI_CMD_HDR_DEVID_MASK 0xF
+#define WMI_CMD_HDR_DEVID_SHIFT 0
+#define GET_CMD_DEVID(_v) ((_v) & WMI_CMD_HDR_DEVID_MASK)
+
+#define WMI_CMD_HDR_GET_DEVID(h) (((h)->info1 >> WMI_CMD_HDR_DEVID_SHIFT) & WMI_CMD_HDR_DEVID_MASK)
+#define WMI_CMD_HDR_SET_DEVID(h, _v) ((h)->info1 = ((h)->info1 & ~(WMI_CMD_HDR_DEVID_MASK << WMI_CMD_HDR_DEVID_SHIFT)) | (GET_CMD_DEVID(_v) << WMI_CMD_HDR_DEVID_SHIFT))
+
+/*
+ * Control Path
+ */
+typedef PREPACK struct {
+ A_UINT16 commandId;
+/*
+ * info1 - 16 bits
+ * b03:b00 - id
+ * b15:b04 - unused
+ */
+ A_UINT16 info1;
+
+ A_UINT16 reserved; /* For alignment */
+} POSTPACK WMI_CMD_HDR; /* used for commands and events */
+
+/*
+ * List of Commnands
+ */
+typedef enum {
+ WMI_CONNECT_CMDID = 0x0001,
+ WMI_RECONNECT_CMDID,
+ WMI_DISCONNECT_CMDID,
+ WMI_SYNCHRONIZE_CMDID,
+ WMI_CREATE_PSTREAM_CMDID,
+ WMI_DELETE_PSTREAM_CMDID,
+ /* WMI_START_SCAN_CMDID is to be deprecated; WMI_BEGIN_SCAN is to
+ * be used instead. The new command supports P2P mgmt operations
+ * using station interface.
+ */
+ WMI_START_SCAN_CMDID,
+ WMI_SET_SCAN_PARAMS_CMDID,
+ WMI_SET_BSS_FILTER_CMDID,
+ WMI_SET_PROBED_SSID_CMDID, /* 10 */
+ WMI_SET_LISTEN_INT_CMDID,
+ WMI_SET_BMISS_TIME_CMDID,
+ WMI_SET_DISC_TIMEOUT_CMDID,
+ WMI_GET_CHANNEL_LIST_CMDID,
+ WMI_SET_BEACON_INT_CMDID,
+ WMI_GET_STATISTICS_CMDID,
+ WMI_SET_CHANNEL_PARAMS_CMDID,
+ WMI_SET_POWER_MODE_CMDID,
+ WMI_SET_IBSS_PM_CAPS_CMDID,
+ WMI_SET_POWER_PARAMS_CMDID, /* 20 */
+ WMI_SET_POWERSAVE_TIMERS_POLICY_CMDID,
+ WMI_ADD_CIPHER_KEY_CMDID,
+ WMI_DELETE_CIPHER_KEY_CMDID,
+ WMI_ADD_KRK_CMDID,
+ WMI_DELETE_KRK_CMDID,
+ WMI_SET_PMKID_CMDID,
+ WMI_SET_TX_PWR_CMDID,
+ WMI_GET_TX_PWR_CMDID,
+ WMI_SET_ASSOC_INFO_CMDID,
+ WMI_ADD_BAD_AP_CMDID, /* 30 */
+ WMI_DELETE_BAD_AP_CMDID,
+ WMI_SET_TKIP_COUNTERMEASURES_CMDID,
+ WMI_RSSI_THRESHOLD_PARAMS_CMDID,
+ WMI_TARGET_ERROR_REPORT_BITMASK_CMDID,
+ WMI_SET_ACCESS_PARAMS_CMDID,
+ WMI_SET_RETRY_LIMITS_CMDID,
+ WMI_SET_OPT_MODE_CMDID,
+ WMI_OPT_TX_FRAME_CMDID,
+ WMI_SET_VOICE_PKT_SIZE_CMDID,
+ WMI_SET_MAX_SP_LEN_CMDID, /* 40 */
+ WMI_SET_ROAM_CTRL_CMDID,
+ WMI_GET_ROAM_TBL_CMDID,
+ WMI_GET_ROAM_DATA_CMDID,
+ WMI_ENABLE_RM_CMDID,
+ WMI_SET_MAX_OFFHOME_DURATION_CMDID,
+ WMI_EXTENSION_CMDID, /* Non-wireless extensions */
+ WMI_SNR_THRESHOLD_PARAMS_CMDID,
+ WMI_LQ_THRESHOLD_PARAMS_CMDID,
+ WMI_SET_LPREAMBLE_CMDID,
+ WMI_SET_RTS_CMDID, /* 50 */
+ WMI_CLR_RSSI_SNR_CMDID,
+ WMI_SET_FIXRATES_CMDID,
+ WMI_GET_FIXRATES_CMDID,
+ WMI_SET_AUTH_MODE_CMDID,
+ WMI_SET_REASSOC_MODE_CMDID,
+ WMI_SET_WMM_CMDID,
+ WMI_SET_WMM_TXOP_CMDID,
+ WMI_TEST_CMDID,
+ /* COEX AR6002 only*/
+ WMI_SET_BT_STATUS_CMDID,
+ WMI_SET_BT_PARAMS_CMDID, /* 60 */
+
+ WMI_SET_KEEPALIVE_CMDID,
+ WMI_GET_KEEPALIVE_CMDID,
+ WMI_SET_APPIE_CMDID,
+ WMI_GET_APPIE_CMDID,
+ WMI_SET_WSC_STATUS_CMDID,
+
+ /* Wake on Wireless */
+ WMI_SET_HOST_SLEEP_MODE_CMDID,
+ WMI_SET_WOW_MODE_CMDID,
+ WMI_GET_WOW_LIST_CMDID,
+ WMI_ADD_WOW_PATTERN_CMDID,
+ WMI_DEL_WOW_PATTERN_CMDID, /* 70 */
+
+ WMI_SET_FRAMERATES_CMDID,
+ WMI_SET_AP_PS_CMDID,
+ WMI_SET_QOS_SUPP_CMDID,
+ /* WMI_THIN_RESERVED_... mark the start and end
+ * values for WMI_THIN_RESERVED command IDs. These
+ * command IDs can be found in wmi_thin.h */
+ WMI_THIN_RESERVED_START = 0x8000,
+ WMI_THIN_RESERVED_END = 0x8fff,
+ /*
+ * Developer commands starts at 0xF000
+ */
+ WMI_SET_BITRATE_CMDID = 0xF000,
+ WMI_GET_BITRATE_CMDID,
+ WMI_SET_WHALPARAM_CMDID,
+
+
+ /*Should add the new command to the tail for compatible with
+ * etna.
+ */
+ WMI_SET_MAC_ADDRESS_CMDID,
+ WMI_SET_AKMP_PARAMS_CMDID,
+ WMI_SET_PMKID_LIST_CMDID,
+ WMI_GET_PMKID_LIST_CMDID,
+ WMI_ABORT_SCAN_CMDID,
+ WMI_SET_TARGET_EVENT_REPORT_CMDID,
+
+ // Unused
+ WMI_UNUSED1,
+ WMI_UNUSED2,
+
+ /*
+ * AP mode commands
+ */
+ WMI_AP_HIDDEN_SSID_CMDID, /* F00B */
+ WMI_AP_SET_NUM_STA_CMDID,
+ WMI_AP_ACL_POLICY_CMDID,
+ WMI_AP_ACL_MAC_LIST_CMDID,
+ WMI_AP_CONFIG_COMMIT_CMDID,
+ WMI_AP_SET_MLME_CMDID, /* F010 */
+ WMI_AP_SET_PVB_CMDID,
+ WMI_AP_CONN_INACT_CMDID,
+ WMI_AP_PROT_SCAN_TIME_CMDID,
+ WMI_AP_SET_COUNTRY_CMDID,
+ WMI_AP_SET_DTIM_CMDID,
+ WMI_AP_MODE_STAT_CMDID,
+
+ WMI_SET_IP_CMDID, /* F017 */
+ WMI_SET_PARAMS_CMDID,
+ WMI_SET_MCAST_FILTER_CMDID,
+ WMI_DEL_MCAST_FILTER_CMDID,
+
+ WMI_ALLOW_AGGR_CMDID, /* F01B */
+ WMI_ADDBA_REQ_CMDID,
+ WMI_DELBA_REQ_CMDID,
+ WMI_SET_HT_CAP_CMDID,
+ WMI_SET_HT_OP_CMDID,
+ WMI_SET_TX_SELECT_RATES_CMDID,
+ WMI_SET_TX_SGI_PARAM_CMDID,
+ WMI_SET_RATE_POLICY_CMDID,
+
+ WMI_HCI_CMD_CMDID, /* F023 */
+ WMI_RX_FRAME_FORMAT_CMDID,
+ WMI_SET_THIN_MODE_CMDID,
+ WMI_SET_BT_WLAN_CONN_PRECEDENCE_CMDID,
+
+ WMI_AP_SET_11BG_RATESET_CMDID, /* F027 */
+ WMI_SET_PMK_CMDID,
+ WMI_MCAST_FILTER_CMDID,
+ /* COEX CMDID AR6003*/
+ WMI_SET_BTCOEX_FE_ANT_CMDID, /* F02A */
+ WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID,
+ WMI_SET_BTCOEX_SCO_CONFIG_CMDID,
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMDID,
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMDID,
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMDID,
+ WMI_SET_BTCOEX_DEBUG_CMDID,
+ WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID,
+ WMI_GET_BTCOEX_STATS_CMDID,
+ WMI_GET_BTCOEX_CONFIG_CMDID,
+#if !defined(AR6002_REV61) || !defined(ATH_TARGET) /* WAR for EV 89272 */
+ WMI_DFS_RESERVED, /* F034 */
+#endif
+ WMI_SET_DFS_MINRSSITHRESH_CMDID,
+ WMI_SET_DFS_MAXPULSEDUR_CMDID,
+ WMI_DFS_RADAR_DETECTED_CMDID,
+
+ /* P2P CMDS */
+ WMI_P2P_SET_CONFIG_CMDID, /* F037 */
+ WMI_WPS_SET_CONFIG_CMDID,
+ WMI_SET_REQ_DEV_ATTR_CMDID,
+ WMI_P2P_FIND_CMDID,
+ WMI_P2P_STOP_FIND_CMDID,
+ WMI_P2P_GO_NEG_START_CMDID,
+ WMI_P2P_LISTEN_CMDID,
+
+
+ WMI_CONFIG_TX_MAC_RULES_CMDID, /* F044 */
+ WMI_SET_PROMISCUOUS_MODE_CMDID,
+ WMI_RX_FRAME_FILTER_CMDID,
+ WMI_SET_CHANNEL_CMDID,
+
+ /* WAC commands */
+ WMI_ENABLE_WAC_CMDID,
+ WMI_WAC_SCAN_REPLY_CMDID,
+ WMI_WAC_CTRL_REQ_CMDID,
+
+ WMI_SET_DIV_PARAMS_CMDID,
+ WMI_GET_PMK_CMDID,
+ WMI_SET_PASSPHRASE_CMDID,
+ WMI_SEND_ASSOC_RES_CMDID,
+ WMI_SET_ASSOC_REQ_RELAY_CMDID,
+
+ /* ACS command, consists of sub-commands */
+ WMI_ACS_CTRL_CMDID,
+ WMI_SET_EXCESS_TX_RETRY_THRES_CMDID,
+ WMI_SET_TBD_TIME_CMDID, /*added for wmiconfig command for TBD */
+
+ /* Pktlog cmds */
+ WMI_PKTLOG_ENABLE_CMDID,
+ WMI_PKTLOG_DISABLE_CMDID,
+
+ /* More P2P Cmds */
+ WMI_P2P_GO_NEG_REQ_RSP_CMDID,
+ WMI_P2P_GRP_INIT_CMDID,
+ WMI_P2P_GRP_FORMATION_DONE_CMDID,
+ WMI_P2P_INVITE_CMDID,
+ WMI_P2P_INVITE_REQ_RSP_CMDID,
+ WMI_P2P_PROV_DISC_REQ_CMDID,
+ WMI_P2P_SET_CMDID,
+
+ WMI_GET_RFKILL_MODE_CMDID,
+ WMI_SET_RFKILL_MODE_CMDID,
+ WMI_AP_SET_APSD_CMDID,
+ WMI_AP_APSD_BUFFERED_TRAFFIC_CMDID,
+
+ WMI_P2P_SDPD_TX_CMDID, /* F05C */
+ WMI_P2P_STOP_SDPD_CMDID,
+ WMI_P2P_CANCEL_CMDID,
+ /* Ultra low power store / recall commands */
+ WMI_STORERECALL_CONFIGURE_CMDID,
+ WMI_STORERECALL_RECALL_CMDID,
+ WMI_STORERECALL_HOST_READY_CMDID,
+ WMI_FORCE_TARGET_ASSERT_CMDID,
+
+ WMI_SET_PROBED_SSID_EX_CMDID,
+ WMI_SET_NETWORK_LIST_OFFLOAD_CMDID,
+ WMI_SET_ARP_NS_OFFLOAD_CMDID,
+ WMI_ADD_WOW_EXT_PATTERN_CMDID,
+ WMI_GTK_OFFLOAD_OP_CMDID,
+
+ WMI_REMAIN_ON_CHNL_CMDID,
+ WMI_CANCEL_REMAIN_ON_CHNL_CMDID,
+ /* WMI_SEND_ACTION_CMDID is to be deprecated; WMI_SEND_MGMT_CMDID
+ * is to be used instead. The new command supports P2P mgmt
+ * operations using station interface
+ */
+ WMI_SEND_ACTION_CMDID,
+ WMI_PROBE_REQ_REPORT_CMDID,
+ WMI_DISABLE_11B_RATES_CMDID,
+ WMI_SEND_PROBE_RESPONSE_CMDID,
+ WMI_GET_P2P_INFO_CMDID,
+ WMI_AP_JOIN_BSS_CMDID,
+
+ WMI_SMPS_ENABLE_CMDID,
+ WMI_SMPS_CONFIG_CMDID,
+ WMI_SET_RATECTRL_PARM_CMDID,
+ /* LPL specific commands*/
+ WMI_LPL_FORCE_ENABLE_CMDID,
+ WMI_LPL_SET_POLICY_CMDID,
+ WMI_LPL_GET_POLICY_CMDID,
+ WMI_LPL_GET_HWSTATE_CMDID,
+ WMI_LPL_SET_PARAMS_CMDID,
+ WMI_LPL_GET_PARAMS_CMDID,
+
+ WMI_SET_BUNDLE_PARAM_CMDID,
+
+ /*GreenTx specific commands*/
+
+ WMI_GREENTX_PARAMS_CMDID,
+
+ WMI_RTT_MEASREQ_CMDID,
+ WMI_RTT_CAPREQ_CMDID,
+ WMI_RTT_STATUSREQ_CMDID,
+
+ /* WPS Commands */
+ WMI_WPS_START_CMDID,
+ WMI_GET_WPS_STATUS_CMDID,
+
+ /* More P2P commands */
+ WMI_SET_NOA_CMDID,
+ WMI_GET_NOA_CMDID,
+ WMI_SET_OPPPS_CMDID,
+ WMI_GET_OPPPS_CMDID,
+ WMI_ADD_PORT_CMDID,
+ WMI_DEL_PORT_CMDID,
+
+ /* 802.11w cmd */
+ WMI_SET_RSN_CAP_CMDID,
+ WMI_GET_RSN_CAP_CMDID,
+ WMI_SET_IGTK_CMDID,
+
+ WMI_RX_FILTER_COALESCE_FILTER_OP_CMDID,
+ WMI_RX_FILTER_SET_FRAME_TEST_LIST_CMDID,
+
+ /* Commands added to support P2P mgmt operations on top of station
+ * interface. WMI_SEND_ACTION_CMDID and WMI_START_SCAN_CMDID to be
+ * deprecated.
+ */
+ WMI_SEND_MGMT_CMDID,
+ WMI_BEGIN_SCAN_CMDID,
+ /* End of commands added to support P2P mgmt operations on station
+ * interface
+ */
+ WMI_SET_BLACK_LIST,
+ WMI_SET_MCASTRATE_CMDID,
+
+ WMI_STA_BMISS_ENHANCE_CMDID,
+
+ WMI_SET_REGDOMAIN_CMDID,
+
+ WMI_SET_RSSI_FILTER_CMDID,
+ WMI_SET_KEEPALIVE_CMDID_EXT,
+
+ WMI_VOICE_DETECTION_ENABLE_CMDID,
+
+ WMI_SET_TXE_NOTIFY_CMDID,
+
+ WMI_SET_RECOVERY_TEST_PARAMETER_CMDID,
+
+ WMI_ENABLE_SCHED_SCAN,
+
+WMI_DISABLE_BCAST_IN_PM_CMDID = 0xf200,
+
+} WMI_COMMAND_ID;
+
+/*
+ * Frame Types
+ */
+typedef enum {
+ WMI_FRAME_BEACON = 0,
+ WMI_FRAME_PROBE_REQ,
+ WMI_FRAME_PROBE_RESP,
+ WMI_FRAME_ASSOC_REQ,
+ WMI_FRAME_ASSOC_RESP,
+ WMI_NUM_MGMT_FRAME
+} WMI_MGMT_FRAME_TYPE;
+
+/*
+ * Connect Command
+ */
+typedef enum {
+ INFRA_NETWORK = 0x01,
+ ADHOC_NETWORK = 0x02,
+ ADHOC_CREATOR = 0x04,
+ AP_NETWORK = 0x10,
+ NETWORK_CONNECTED_USING_WPS = 0x20,
+} NETWORK_TYPE;
+
+typedef enum {
+ SUBTYPE_NONE,
+ SUBTYPE_BT,
+ SUBTYPE_P2PDEV,
+ SUBTYPE_P2PCLIENT,
+ SUBTYPE_P2PGO,
+} NETWORK_SUBTYPE;
+
+typedef enum {
+ OPEN_AUTH = 0x01,
+ SHARED_AUTH = 0x02,
+ LEAP_AUTH = 0x04, /* different from IEEE_AUTH_MODE definitions */
+} DOT11_AUTH_MODE;
+
+typedef enum {
+ WMI_NONE_AUTH = 0x01,
+ WMI_WPA_AUTH = 0x02,
+ WMI_WPA2_AUTH = 0x04,
+ WMI_WPA_PSK_AUTH = 0x08,
+ WMI_WPA2_PSK_AUTH = 0x10,
+ WMI_WPA_AUTH_CCKM = 0x20,
+ WMI_WPA2_AUTH_CCKM = 0x40,
+} AUTH_MODE;
+
+typedef enum {
+ NONE_CRYPT = 0x01,
+ WEP_CRYPT = 0x02,
+ TKIP_CRYPT = 0x04,
+ AES_CRYPT = 0x08,
+#ifdef WAPI_ENABLE
+ WAPI_CRYPT = 0x10,
+#endif /*WAPI_ENABLE*/
+} CRYPTO_TYPE;
+
+#define WMI_MIN_CRYPTO_TYPE NONE_CRYPT
+#define WMI_MAX_CRYPTO_TYPE (AES_CRYPT + 1)
+
+#ifdef WAPI_ENABLE
+#undef WMI_MAX_CRYPTO_TYPE
+#define WMI_MAX_CRYPTO_TYPE (WAPI_CRYPT + 1)
+#endif /* WAPI_ENABLE */
+
+#ifdef WAPI_ENABLE
+#define IW_ENCODE_ALG_SM4 0x20
+/*
+ * Defined this to be some very high bit because it is less likely to be
+ * clobbered by future changes to the kernel's wireless.h file
+*/
+#define IW_AUTH_CIPHER_SMS4 0x40000000
+#endif
+
+#define WMI_MIN_KEY_INDEX 0
+#define WMI_MAX_KEY_INDEX 3
+
+#ifdef IEEE80211W
+#undef WMI_MAX_KEY_INDEX
+#define WMI_MAX_KEY_INDEX 5
+#endif
+
+#ifdef WAPI_ENABLE
+#undef WMI_MAX_KEY_INDEX
+#define WMI_MAX_KEY_INDEX 7 /* wapi grpKey 0-3, prwKey 4-7 */
+#endif /* WAPI_ENABLE */
+
+#define WMI_MAX_KEY_LEN 32
+
+#define WMI_MAX_SSID_LEN 32
+
+typedef enum {
+ CONNECT_ASSOC_POLICY_USER = 0x0001,
+ CONNECT_SEND_REASSOC = 0x0002,
+ CONNECT_IGNORE_WPAx_GROUP_CIPHER = 0x0004,
+ CONNECT_PROFILE_MATCH_DONE = 0x0008,
+ CONNECT_IGNORE_AAC_BEACON = 0x0010,
+ CONNECT_CSA_FOLLOW_BSS = 0x0020,
+ CONNECT_DO_WPA_OFFLOAD = 0x0040,
+ CONNECT_DO_NOT_DEAUTH = 0x0080,
+ CONNECT_WPS_FLAG = 0x0100,
+ /* AP configuration flags */
+ AP_NO_DISASSOC_UPON_DEAUTH = 0x10000,
+ AP_HOSTPAL_SUPPORT = 0x20000
+} WMI_CONNECT_CTRL_FLAGS_BITS;
+
+#define DEFAULT_CONNECT_CTRL_FLAGS (CONNECT_CSA_FOLLOW_BSS)
+
+typedef PREPACK struct {
+ A_UINT8 networkType;
+ A_UINT8 dot11AuthMode;
+ A_UINT8 authMode;
+ A_UINT8 pairwiseCryptoType;
+ A_UINT8 pairwiseCryptoLen;
+ A_UINT8 groupCryptoType;
+ A_UINT8 groupCryptoLen;
+ A_UINT8 ssidLength;
+ A_UCHAR ssid[WMI_MAX_SSID_LEN];
+ A_UINT16 channel;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT32 ctrl_flags;
+ A_UINT8 networkSubtype;
+} POSTPACK WMI_CONNECT_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT32 divIdleTime;
+ A_UINT8 antRssiThresh;
+ A_UINT8 divEnable;
+ A_UINT16 active_treshold_rate;
+} POSTPACK WMI_DIV_PARAMS_CMD;
+
+/*
+ * WMI_RECONNECT_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT16 channel; /* hint */
+ A_UINT8 bssid[ATH_MAC_LEN]; /* mandatory if set */
+} POSTPACK WMI_RECONNECT_CMD;
+
+/*
+ * WMI_SET_PMK_CMDID
+ */
+#define WMI_PMK_LEN 32
+typedef PREPACK struct {
+ A_UINT8 pmk[WMI_PMK_LEN];
+ A_UINT8 pmk_len;
+} POSTPACK WMI_SET_PMK_CMD, WMI_GET_PMK_REPLY;
+
+/*
+ * WMI_SET_PASSPHRASE_CMDID
+ */
+#define WMI_PASSPHRASE_LEN 64
+typedef PREPACK struct {
+ A_UCHAR ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 passphrase[WMI_PASSPHRASE_LEN];
+ A_UINT8 ssid_len;
+ A_UINT8 passphrase_len;
+} POSTPACK WMI_SET_PASSPHRASE_CMD;
+
+/*
+ * WMI_SET_EXCESS_TX_RETRY_THRES_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT32 threshold;
+} POSTPACK WMI_SET_EXCESS_TX_RETRY_THRES_CMD;
+
+/*
+ * WMI_SET_MCASTRATE_CMD
+ */
+typedef PREPACK struct {
+ A_UINT16 bitrate; /* in units of 100 Kbps */
+ /* Valid values are 10, 20, 55, 110, 60, 90, 120, 180,
+ * 240, 360, 480, 540 */
+} POSTPACK WMI_SET_MCASTRATE_CMD;
+
+
+/*
+ * WMI_ADD_CIPHER_KEY_CMDID
+ */
+typedef enum {
+ PAIRWISE_USAGE = 0x00,
+ GROUP_USAGE = 0x01,
+ TX_USAGE = 0x02, /* default Tx Key - Static WEP only */
+} KEY_USAGE;
+
+/*
+ * Bit Flag
+ * Bit 0 - Initialise TSC - default is Initialize
+ */
+#define KEY_OP_INIT_TSC 0x01
+#define KEY_OP_INIT_RSC 0x02
+#ifdef WAPI_ENABLE
+#define KEY_OP_INIT_WAPIPN 0x10
+#endif /* WAPI_ENABLE */
+
+#define KEY_OP_INIT_VAL 0x03 /* Default Initialise the TSC & RSC */
+#define KEY_OP_VALID_MASK 0x03
+
+typedef PREPACK struct {
+ A_UINT8 keyIndex;
+ A_UINT8 keyType;
+ A_UINT8 keyUsage; /* KEY_USAGE */
+ A_UINT8 keyLength;
+ A_UINT8 keyRSC[8]; /* key replay sequence counter */
+ A_UINT8 key[WMI_MAX_KEY_LEN];
+ A_UINT8 key_op_ctrl; /* Additional Key Control information */
+ A_UINT8 key_macaddr[ATH_MAC_LEN];
+} POSTPACK WMI_ADD_CIPHER_KEY_CMD;
+
+/*
+ * WMI_DELETE_CIPHER_KEY_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 keyIndex;
+} POSTPACK WMI_DELETE_CIPHER_KEY_CMD;
+
+
+/*
+ *for Linux, it need KRK, length is 16
+ *for Win7, it need CCKM ie, length is 26
+ */
+#define WMI_KRK_LEN 16
+#define WMI_CCKM_IE_LEN 26
+/*
+ * WMI_ADD_KRK_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 krk[WMI_CCKM_IE_LEN];
+} POSTPACK WMI_ADD_KRK_CMD;
+
+/*
+ * WMI_SET_TKIP_COUNTERMEASURES_CMDID
+ */
+typedef enum {
+ WMI_TKIP_CM_DISABLE = 0x0,
+ WMI_TKIP_CM_ENABLE = 0x1,
+} WMI_TKIP_CM_CONTROL;
+
+typedef PREPACK struct {
+ A_UINT8 cm_en; /* WMI_TKIP_CM_CONTROL */
+} POSTPACK WMI_SET_TKIP_COUNTERMEASURES_CMD;
+
+/*
+ * WMI_SET_PMKID_CMDID
+ */
+
+#define WMI_PMKID_LEN 16
+
+typedef enum {
+ PMKID_DISABLE = 0,
+ PMKID_ENABLE = 1,
+} PMKID_ENABLE_FLG;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 enable; /* PMKID_ENABLE_FLG */
+ A_UINT8 pmkid[WMI_PMKID_LEN];
+} POSTPACK WMI_SET_PMKID_CMD;
+
+/*
+ * WMI_START_SCAN_CMD
+ */
+typedef enum {
+ WMI_LONG_SCAN = 0,
+ WMI_SHORT_SCAN = 1,
+} WMI_SCAN_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 nrates;
+ A_UINT8 rates[WMI_RATE_MAXSIZE];
+} POSTPACK WMI_SUPPORTED_RATES;
+
+typedef PREPACK struct {
+ A_BOOL forceFgScan;
+ A_BOOL isLegacy; /* For Legacy Cisco AP compatibility */
+ A_UINT32 homeDwellTime; /* Maximum duration in the home channel(milliseconds) */
+ A_UINT32 forceScanInterval; /* Time interval between scans (milliseconds)*/
+ A_BOOL no_cck; /* Flag to force no CCK rates to be used for
+ probe request frames */
+ A_UINT8 scanType; /* WMI_SCAN_TYPE */
+ WMI_SUPPORTED_RATES supp_rates[A_NUM_BANDS]; /* Supported rates to
+ advertise in probe request
+ frames */
+ A_UINT8 numChannels; /* how many channels follow */
+ A_UINT16 channelList[1]; /* channels in Mhz */
+} POSTPACK WMI_BEGIN_SCAN_CMD;
+
+/* WMI_START_SCAN_CMD is to be deprecated; WMI_BEGIN_SCAN_CMD is
+ * to be used instead. The new command supports P2P mgmt operations using
+ * station interface
+ */
+typedef PREPACK struct {
+ A_BOOL forceFgScan;
+ A_BOOL isLegacy; /* For Legacy Cisco AP compatibility */
+ A_UINT32 homeDwellTime; /* Maximum duration in the home channel(milliseconds) */
+ A_UINT32 forceScanInterval; /* Time interval between scans (milliseconds)*/
+ A_UINT8 scanType; /* WMI_SCAN_TYPE */
+ A_UINT8 numChannels; /* how many channels follow */
+ A_UINT16 channelList[1]; /* channels in Mhz */
+} POSTPACK WMI_START_SCAN_CMD;
+
+
+/*
+ * WMI_SET_SCAN_PARAMS_CMDID
+ */
+#define WMI_SHORTSCANRATIO_DEFAULT 3
+/*
+ * Warning: ScanCtrlFlag value of 0xFF is used to disable all flags in WMI_SCAN_PARAMS_CMD
+ * Do not add any more flags to WMI_SCAN_CTRL_FLAG_BITS
+ */
+typedef enum {
+ CONNECT_SCAN_CTRL_FLAGS = 0x01, /* set if can scan in the Connect cmd */
+ SCAN_CONNECTED_CTRL_FLAGS = 0x02, /* set if scan for the SSID it is */
+ /* already connected to */
+ ACTIVE_SCAN_CTRL_FLAGS = 0x04, /* set if enable active scan */
+ ROAM_SCAN_CTRL_FLAGS = 0x08, /* set if enable roam scan when bmiss and lowrssi */
+ REPORT_BSSINFO_CTRL_FLAGS = 0x10, /* set if follows customer BSSINFO reporting rule */
+ ENABLE_AUTO_CTRL_FLAGS = 0x20, /* if disabled, target doesn't
+ scan after a disconnect event */
+ ENABLE_SCAN_ABORT_EVENT = 0x40 /* Scan complete event with canceled status will be generated when a scan is prempted before it gets completed */
+} WMI_SCAN_CTRL_FLAGS_BITS;
+
+#define CAN_SCAN_IN_CONNECT(flags) (flags & CONNECT_SCAN_CTRL_FLAGS)
+#define CAN_SCAN_CONNECTED(flags) (flags & SCAN_CONNECTED_CTRL_FLAGS)
+#define ENABLE_ACTIVE_SCAN(flags) (flags & ACTIVE_SCAN_CTRL_FLAGS)
+#define ENABLE_ROAM_SCAN(flags) (flags & ROAM_SCAN_CTRL_FLAGS)
+#define CONFIG_REPORT_BSSINFO(flags) (flags & REPORT_BSSINFO_CTRL_FLAGS)
+#define IS_AUTO_SCAN_ENABLED(flags) (flags & ENABLE_AUTO_CTRL_FLAGS)
+#define SCAN_ABORT_EVENT_ENABLED(flags) (flags & ENABLE_SCAN_ABORT_EVENT)
+
+#define DEFAULT_SCAN_CTRL_FLAGS (CONNECT_SCAN_CTRL_FLAGS| SCAN_CONNECTED_CTRL_FLAGS| ACTIVE_SCAN_CTRL_FLAGS| ROAM_SCAN_CTRL_FLAGS | ENABLE_AUTO_CTRL_FLAGS)
+
+
+typedef PREPACK struct {
+ A_UINT16 fg_start_period; /* seconds */
+ A_UINT16 fg_end_period; /* seconds */
+ A_UINT16 bg_period; /* seconds */
+ A_UINT16 maxact_chdwell_time; /* msec */
+ A_UINT16 pas_chdwell_time; /* msec */
+ A_UINT8 shortScanRatio; /* how many shorts scan for one long */
+ A_UINT8 scanCtrlFlags;
+ A_UINT16 minact_chdwell_time; /* msec */
+ A_UINT16 maxact_scan_per_ssid; /* max active scans per ssid */
+ A_UINT32 max_dfsch_act_time; /* msecs */
+} POSTPACK WMI_SCAN_PARAMS_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 chan_index;
+ A_INT8 bang_radar;
+} POSTPACK WMI_RADAR_DETECTED_CMD;
+
+/*
+ * WMI_SET_BSS_FILTER_CMDID
+ */
+typedef enum {
+ NONE_BSS_FILTER = 0x0, /* no beacons forwarded */
+ ALL_BSS_FILTER, /* all beacons forwarded */
+ PROFILE_FILTER, /* only beacons matching profile */
+ ALL_BUT_PROFILE_FILTER, /* all but beacons matching profile */
+ CURRENT_BSS_FILTER, /* only beacons matching current BSS */
+ ALL_BUT_BSS_FILTER, /* all but beacons matching BSS */
+ PROBED_SSID_FILTER, /* beacons matching probed ssid */
+ LAST_BSS_FILTER, /* marker only */
+} WMI_BSS_FILTER;
+
+typedef PREPACK struct {
+ A_UINT8 bssFilter; /* see WMI_BSS_FILTER */
+ A_UINT8 reserved1; /* For alignment */
+ A_UINT16 reserved2; /* For alignment */
+ A_UINT32 ieMask;
+} POSTPACK WMI_BSS_FILTER_CMD;
+
+/*
+ * WMI_SET_PROBED_SSID_CMDID
+ */
+#define MAX_PROBED_SSID_INDEX 15
+
+typedef enum {
+ DISABLE_SSID_FLAG = 0, /* disables entry */
+ SPECIFIC_SSID_FLAG = 0x01, /* probes specified ssid */
+ ANY_SSID_FLAG = 0x02, /* probes for any ssid */
+ PASSIVE_LISTEN_SSID_FLAG = 0x04, /* Just Listen on the Channel without Probing for any SSIDs But we wanted to use the Probed SSID List*/ /* for Profile Matching */
+} WMI_SSID_FLAG;
+
+typedef PREPACK struct {
+ A_UINT8 entryIndex; /* 0 to MAX_PROBED_SSID_INDEX */
+ A_UINT8 flag; /* WMI_SSID_FLG */
+ A_UINT8 ssidLength;
+ A_UINT8 ssid[32];
+ A_UINT8 authentication;
+ A_UINT8 encryption;
+ A_UINT8 channelHint;
+ A_BOOL bmatchcompleteprofile; /* If this Flag is True, we do a complete profile match of SSID, AUTH, Encryption */
+} POSTPACK WMI_PROBED_SSID_CMD;
+
+/*
+ * WMI_SET_LISTEN_INT_CMDID
+ * The Listen interval is between 15 and 3000 TUs
+ */
+#define MIN_LISTEN_INTERVAL 15
+#define MAX_LISTEN_INTERVAL 5000
+#define MIN_LISTEN_BEACONS 1
+#define MAX_LISTEN_BEACONS 50
+
+typedef PREPACK struct {
+ A_UINT16 listenInterval;
+ A_UINT16 numBeacons;
+} POSTPACK WMI_LISTEN_INT_CMD;
+
+/*
+ * WMI_SET_BEACON_INT_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT16 beaconInterval;
+} POSTPACK WMI_BEACON_INT_CMD;
+
+/*
+ * WMI_SET_BMISS_TIME_CMDID
+ * valid values are between 1000 and 5000 TUs
+ */
+
+#define MIN_BMISS_TIME 1000
+#define MAX_BMISS_TIME 5000
+#define MIN_BMISS_BEACONS 1
+#define MAX_BMISS_BEACONS 50
+
+typedef PREPACK struct {
+ A_UINT16 bmissTime;
+ A_UINT16 numBeacons;
+} POSTPACK WMI_BMISS_TIME_CMD;
+
+/*
+ * WMI_SET_POWER_MODE_CMDID
+ */
+typedef enum {
+ REC_POWER = 0x01,
+ MAX_PERF_POWER,
+} WMI_POWER_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 powerMode; /* WMI_POWER_MODE */
+} POSTPACK WMI_POWER_MODE_CMD;
+
+typedef PREPACK struct {
+ A_INT8 status; /* WMI_SET_PARAMS_REPLY */
+} POSTPACK WMI_SET_PARAMS_REPLY;
+
+typedef PREPACK struct {
+ A_UINT32 opcode;
+ A_UINT32 length;
+ A_CHAR buffer[1]; /* WMI_SET_PARAMS */
+} POSTPACK WMI_SET_PARAMS_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 multicast_mac[ATH_MAC_LEN]; /* WMI_SET_MCAST_FILTER */
+} POSTPACK WMI_SET_MCAST_FILTER_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 enable; /* WMI_MCAST_FILTER */
+} POSTPACK WMI_MCAST_FILTER_CMD;
+
+/*
+ * WMI_SET_POWER_PARAMS_CMDID
+ */
+typedef enum {
+ IGNORE_DTIM = 0x01,
+ NORMAL_DTIM = 0x02,
+ STICK_DTIM = 0x03,
+ AUTO_DTIM = 0x04,
+} WMI_DTIM_POLICY;
+
+/* Policy to determnine whether TX should wakeup WLAN if sleeping */
+typedef enum {
+ TX_WAKEUP_UPON_SLEEP = 1,
+ TX_DONT_WAKEUP_UPON_SLEEP = 2
+} WMI_TX_WAKEUP_POLICY_UPON_SLEEP;
+
+/*
+ * Policy to determnine whether power save failure event should be sent to
+ * host during scanning
+ */
+typedef enum {
+ SEND_POWER_SAVE_FAIL_EVENT_ALWAYS = 1,
+ IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN = 2,
+} POWER_SAVE_FAIL_EVENT_POLICY;
+
+typedef PREPACK struct {
+ A_UINT16 idle_period; /* msec */
+ A_UINT16 pspoll_number;
+ A_UINT16 dtim_policy;
+ A_UINT16 tx_wakeup_policy;
+ A_UINT16 num_tx_to_wakeup;
+ A_UINT16 ps_fail_event_policy;
+} POSTPACK WMI_POWER_PARAMS_CMD;
+
+/* Adhoc power save types */
+typedef enum {
+ ADHOC_PS_DISABLE=1,
+ ADHOC_PS_ATH=2,
+ ADHOC_PS_IEEE=3,
+ ADHOC_PS_OTHER=4,
+} WMI_ADHOC_PS_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 power_saving;
+ A_UINT8 ttl; /* number of beacon periods */
+ A_UINT16 atim_windows; /* msec */
+ A_UINT16 timeout_value; /* msec */
+} POSTPACK WMI_IBSS_PM_CAPS_CMD;
+
+/* AP power save types */
+typedef enum {
+ AP_PS_DISABLE=1,
+ AP_PS_ATH=2,
+} WMI_AP_PS_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 idle_time; /* in msec */
+ A_UINT32 ps_period; /* in usec */
+ A_UINT8 sleep_period; /* in ps periods */
+ A_UINT8 psType;
+} POSTPACK WMI_AP_PS_CMD;
+
+/*
+ * WMI_SET_POWERSAVE_TIMERS_POLICY_CMDID
+ */
+typedef enum {
+ IGNORE_TIM_ALL_QUEUES_APSD = 0,
+ PROCESS_TIM_ALL_QUEUES_APSD = 1,
+ IGNORE_TIM_SIMULATED_APSD = 2,
+ PROCESS_TIM_SIMULATED_APSD = 3,
+} APSD_TIM_POLICY;
+
+typedef PREPACK struct {
+ A_UINT16 psPollTimeout; /* msec */
+ A_UINT16 triggerTimeout; /* msec */
+ A_UINT32 apsdTimPolicy; /* TIM behavior with ques APSD enabled. Default is IGNORE_TIM_ALL_QUEUES_APSD */
+ A_UINT32 simulatedAPSDTimPolicy; /* TIM behavior with simulated APSD enabled. Default is PROCESS_TIM_SIMULATED_APSD */
+} POSTPACK WMI_POWERSAVE_TIMERS_POLICY_CMD;
+
+/*
+ * WMI_SET_VOICE_PKT_SIZE_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT16 voicePktSize;
+} POSTPACK WMI_SET_VOICE_PKT_SIZE_CMD;
+
+/*
+ * WMI_SET_MAX_SP_LEN_CMDID
+ */
+typedef enum {
+ DELIVER_ALL_PKT = 0x0,
+ DELIVER_2_PKT = 0x1,
+ DELIVER_4_PKT = 0x2,
+ DELIVER_6_PKT = 0x3,
+} APSD_SP_LEN_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 maxSPLen;
+} POSTPACK WMI_SET_MAX_SP_LEN_CMD;
+
+/*
+ * WMI_SET_DISC_TIMEOUT_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 disconnectTimeout; /* seconds */
+} POSTPACK WMI_DISC_TIMEOUT_CMD;
+
+typedef enum {
+ UPLINK_TRAFFIC = 0,
+ DNLINK_TRAFFIC = 1,
+ BIDIR_TRAFFIC = 2,
+} DIR_TYPE;
+
+typedef enum {
+ DISABLE_FOR_THIS_AC = 0,
+ ENABLE_FOR_THIS_AC = 1,
+ ENABLE_FOR_ALL_AC = 2,
+} VOICEPS_CAP_TYPE;
+
+typedef enum {
+ TRAFFIC_TYPE_APERIODIC = 0,
+ TRAFFIC_TYPE_PERIODIC = 1,
+}TRAFFIC_TYPE;
+
+/*
+ * WMI_SYNCHRONIZE_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 dataSyncMap;
+} POSTPACK WMI_SYNC_CMD;
+
+/*
+ * WMI_CREATE_PSTREAM_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT32 minServiceInt; /* in milli-sec */
+ A_UINT32 maxServiceInt; /* in milli-sec */
+ A_UINT32 inactivityInt; /* in milli-sec */
+ A_UINT32 suspensionInt; /* in milli-sec */
+ A_UINT32 serviceStartTime;
+ A_UINT32 minDataRate; /* in bps */
+ A_UINT32 meanDataRate; /* in bps */
+ A_UINT32 peakDataRate; /* in bps */
+ A_UINT32 maxBurstSize;
+ A_UINT32 delayBound;
+ A_UINT32 minPhyRate; /* in bps */
+ A_UINT32 sba;
+ A_UINT32 mediumTime;
+ A_UINT16 nominalMSDU; /* in octects */
+ A_UINT16 maxMSDU; /* in octects */
+ A_UINT8 trafficClass;
+ A_UINT8 trafficDirection; /* DIR_TYPE */
+ A_UINT8 rxQueueNum;
+ A_UINT8 trafficType; /* TRAFFIC_TYPE */
+ A_UINT8 voicePSCapability; /* VOICEPS_CAP_TYPE */
+ A_UINT8 tsid;
+ A_UINT8 userPriority; /* 802.1D user priority */
+ A_UINT8 nominalPHY; /* nominal phy rate */
+} POSTPACK WMI_CREATE_PSTREAM_CMD;
+
+/*
+ * WMI_DELETE_PSTREAM_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficDirection;
+ A_UINT8 trafficClass;
+ A_UINT8 tsid;
+} POSTPACK WMI_DELETE_PSTREAM_CMD;
+
+/*
+ * WMI_SET_CHANNEL_PARAMS_CMDID
+ */
+typedef enum {
+ WMI_11A_MODE = 0x1,
+ WMI_11G_MODE = 0x2,
+ WMI_11AG_MODE = 0x3,
+ WMI_11B_MODE = 0x4,
+ WMI_11GONLY_MODE = 0x5,
+} WMI_PHY_MODE;
+
+#define WMI_MAX_CHANNELS 32
+
+typedef PREPACK struct {
+ A_UINT8 reserved1;
+ A_UINT8 scanParam; /* set if enable scan */
+ A_UINT8 phyMode; /* see WMI_PHY_MODE */
+ A_UINT8 numChannels; /* how many channels follow */
+ A_UINT16 channelList[1]; /* channels in Mhz */
+} POSTPACK WMI_CHANNEL_PARAMS_CMD;
+
+
+/*
+ * WMI_RSSI_THRESHOLD_PARAMS_CMDID
+ * Setting the polltime to 0 would disable polling.
+ * Threshold values are in the ascending order, and should agree to:
+ * (lowThreshold_lowerVal < lowThreshold_upperVal < highThreshold_lowerVal
+ * < highThreshold_upperVal)
+ */
+
+typedef PREPACK struct WMI_RSSI_THRESHOLD_PARAMS{
+ A_UINT32 pollTime; /* Polling time as a factor of LI */
+ A_INT16 thresholdAbove1_Val; /* lowest of upper */
+ A_INT16 thresholdAbove2_Val;
+ A_INT16 thresholdAbove3_Val;
+ A_INT16 thresholdAbove4_Val;
+ A_INT16 thresholdAbove5_Val;
+ A_INT16 thresholdAbove6_Val; /* highest of upper */
+ A_INT16 thresholdBelow1_Val; /* lowest of bellow */
+ A_INT16 thresholdBelow2_Val;
+ A_INT16 thresholdBelow3_Val;
+ A_INT16 thresholdBelow4_Val;
+ A_INT16 thresholdBelow5_Val;
+ A_INT16 thresholdBelow6_Val; /* highest of bellow */
+ A_UINT8 weight; /* "alpha" */
+ A_UINT8 reserved[3];
+} POSTPACK WMI_RSSI_THRESHOLD_PARAMS_CMD;
+
+/*
+ * WMI_SNR_THRESHOLD_PARAMS_CMDID
+ * Setting the polltime to 0 would disable polling.
+ */
+
+typedef PREPACK struct WMI_SNR_THRESHOLD_PARAMS{
+ A_UINT32 pollTime; /* Polling time as a factor of LI */
+ A_UINT8 weight; /* "alpha" */
+ A_UINT8 thresholdAbove1_Val; /* lowest of uppper*/
+ A_UINT8 thresholdAbove2_Val;
+ A_UINT8 thresholdAbove3_Val;
+ A_UINT8 thresholdAbove4_Val; /* highest of upper */
+ A_UINT8 thresholdBelow1_Val; /* lowest of bellow */
+ A_UINT8 thresholdBelow2_Val;
+ A_UINT8 thresholdBelow3_Val;
+ A_UINT8 thresholdBelow4_Val; /* highest of bellow */
+ A_UINT8 reserved[3];
+} POSTPACK WMI_SNR_THRESHOLD_PARAMS_CMD;
+
+/*
+ * WMI_LQ_THRESHOLD_PARAMS_CMDID
+ */
+typedef PREPACK struct WMI_LQ_THRESHOLD_PARAMS {
+ A_UINT8 enable;
+ A_UINT8 thresholdAbove1_Val;
+ A_UINT8 thresholdAbove2_Val;
+ A_UINT8 thresholdAbove3_Val;
+ A_UINT8 thresholdAbove4_Val;
+ A_UINT8 thresholdBelow1_Val;
+ A_UINT8 thresholdBelow2_Val;
+ A_UINT8 thresholdBelow3_Val;
+ A_UINT8 thresholdBelow4_Val;
+ A_UINT8 reserved[3];
+} POSTPACK WMI_LQ_THRESHOLD_PARAMS_CMD;
+
+typedef enum {
+ WMI_LPREAMBLE_DISABLED = 0,
+ WMI_LPREAMBLE_ENABLED
+} WMI_LPREAMBLE_STATUS;
+
+typedef enum {
+ WMI_IGNORE_BARKER_IN_ERP = 0,
+ WMI_DONOT_IGNORE_BARKER_IN_ERP
+} WMI_PREAMBLE_POLICY;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+ A_UINT8 preamblePolicy;
+}POSTPACK WMI_SET_LPREAMBLE_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 threshold;
+}POSTPACK WMI_SET_RTS_CMD;
+
+/*
+ * WMI_TARGET_ERROR_REPORT_BITMASK_CMDID
+ * Sets the error reporting event bitmask in target. Target clears it
+ * upon an error. Subsequent errors are counted, but not reported
+ * via event, unless the bitmask is set again.
+ */
+typedef PREPACK struct {
+ A_UINT32 bitmask;
+} POSTPACK WMI_TARGET_ERROR_REPORT_BITMASK;
+
+/*
+ * WMI_SET_TX_PWR_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 dbM; /* in dbM units */
+} POSTPACK WMI_SET_TX_PWR_CMD, WMI_TX_PWR_REPLY;
+
+/*
+ * WMI_SET_ASSOC_INFO_CMDID
+ *
+ * A maximum of 2 private IEs can be sent in the [Re]Assoc request.
+ * A 3rd one, the CCX version IE can also be set from the host.
+ */
+
+/*
+ * Bit 7: 1 CCX cckm ie upload to host, 0 default, don't upload
+ * Bit 6: 1 ccx radio measurement upload to host, 0 default, don't upload
+ * Bit 3~5: reserved
+ * Bit 0~2: ccx version
+ */
+
+#define WMI_CCX_VERSION_MASK 0x7
+#define WMI_CCX_CCKMIE_UPLOAD_MASK (0x1 << 7)
+#define WMI_CCX_RM_UPLOAD_MASK (0x1 << 6)
+
+#define WMI_MAX_ASSOC_INFO_TYPE 2
+#define WMI_CCX_VER_IE 2 /* ieType to set CCX Version IE */
+
+#define WMI_MAX_ASSOC_INFO_LEN 240
+
+typedef PREPACK struct {
+ A_UINT8 ieType;
+ A_UINT8 bufferSize;
+ A_UINT8 assocInfo[1]; /* up to WMI_MAX_ASSOC_INFO_LEN */
+} POSTPACK WMI_SET_ASSOC_INFO_CMD;
+
+
+/*
+ * WMI_GET_TX_PWR_CMDID does not take any parameters
+ */
+
+/*
+ * WMI_ADD_BAD_AP_CMDID
+ */
+#define WMI_MAX_BAD_AP_INDEX 1
+
+typedef PREPACK struct {
+ A_UINT8 badApIndex; /* 0 to WMI_MAX_BAD_AP_INDEX */
+ A_UINT8 bssid[ATH_MAC_LEN];
+} POSTPACK WMI_ADD_BAD_AP_CMD;
+
+/*
+ * WMI_DELETE_BAD_AP_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 badApIndex; /* 0 to WMI_MAX_BAD_AP_INDEX */
+} POSTPACK WMI_DELETE_BAD_AP_CMD;
+
+/*
+ * WMI_SET_ACCESS_PARAMS_CMDID
+ */
+#define WMI_DEFAULT_TXOP_ACPARAM 0 /* implies one MSDU */
+#define WMI_DEFAULT_ECWMIN_ACPARAM 4 /* corresponds to CWmin of 15 */
+#define WMI_DEFAULT_ECWMAX_ACPARAM 10 /* corresponds to CWmax of 1023 */
+#define WMI_MAX_CW_ACPARAM 15 /* maximum eCWmin or eCWmax */
+#define WMI_DEFAULT_AIFSN_ACPARAM 2
+#define WMI_MAX_AIFSN_ACPARAM 15
+typedef PREPACK struct {
+ A_UINT16 txop; /* in units of 32 usec */
+ A_UINT8 eCWmin;
+ A_UINT8 eCWmax;
+ A_UINT8 aifsn;
+ A_UINT8 ac;
+} POSTPACK WMI_SET_ACCESS_PARAMS_CMD;
+
+
+/*
+ * WMI_SET_RETRY_LIMITS_CMDID
+ *
+ * This command is used to customize the number of retries the
+ * wlan device will perform on a given frame.
+ */
+#define WMI_MIN_RETRIES 2
+#define WMI_MAX_RETRIES 13
+typedef enum {
+ MGMT_FRAMETYPE = 0,
+ CONTROL_FRAMETYPE = 1,
+ DATA_FRAMETYPE = 2
+} WMI_FRAMETYPE;
+
+typedef PREPACK struct {
+ A_UINT8 frameType; /* WMI_FRAMETYPE */
+ A_UINT8 trafficClass; /* applies only to DATA_FRAMETYPE */
+ A_UINT8 maxRetries;
+ A_UINT8 enableNotify;
+} POSTPACK WMI_SET_RETRY_LIMITS_CMD;
+
+/*
+ * WMI_SET_ROAM_CTRL_CMDID
+ *
+ * This command is used to influence the Roaming behaviour
+ * Set the host biases of the BSSs before setting the roam mode as bias
+ * based.
+ */
+
+/*
+ * Different types of Roam Control
+ */
+
+typedef enum {
+ WMI_FORCE_ROAM = 1, /* Roam to the specified BSSID */
+ WMI_SET_ROAM_MODE = 2, /* default ,progd bias, no roam */
+ WMI_SET_HOST_BIAS = 3, /* Set the Host Bias */
+ WMI_SET_LOWRSSI_SCAN_PARAMS = 4, /* Set lowrssi Scan parameters */
+} WMI_ROAM_CTRL_TYPE;
+
+#define WMI_MIN_ROAM_CTRL_TYPE WMI_FORCE_ROAM
+#define WMI_MAX_ROAM_CTRL_TYPE WMI_SET_LOWRSSI_SCAN_PARAMS
+
+/*
+ * ROAM MODES
+ */
+
+typedef enum {
+ WMI_DEFAULT_ROAM_MODE = 1, /* RSSI based ROAM */
+ WMI_HOST_BIAS_ROAM_MODE = 2, /* HOST BIAS based ROAM */
+ WMI_LOCK_BSS_MODE = 3 /* Lock to the Current BSS - no Roam */
+} WMI_ROAM_MODE;
+
+/*
+ * BSS HOST BIAS INFO
+ */
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_INT8 bias;
+} POSTPACK WMI_BSS_BIAS;
+
+typedef PREPACK struct {
+ A_UINT8 numBss;
+ WMI_BSS_BIAS bssBias[1];
+} POSTPACK WMI_BSS_BIAS_INFO;
+
+typedef PREPACK struct WMI_LOWRSSI_SCAN_PARAMS {
+ A_UINT16 lowrssi_scan_period;
+ A_INT16 lowrssi_scan_threshold;
+ A_INT16 lowrssi_roam_threshold;
+ A_UINT8 roam_rssi_floor;
+ A_UINT8 reserved[1]; /* For alignment */
+} POSTPACK WMI_LOWRSSI_SCAN_PARAMS;
+
+typedef PREPACK struct {
+ PREPACK union {
+ A_UINT8 bssid[ATH_MAC_LEN]; /* WMI_FORCE_ROAM */
+ A_UINT8 roamMode; /* WMI_SET_ROAM_MODE */
+ WMI_BSS_BIAS_INFO bssBiasInfo; /* WMI_SET_HOST_BIAS */
+ WMI_LOWRSSI_SCAN_PARAMS lrScanParams;
+ } POSTPACK info;
+ A_UINT8 roamCtrlType ;
+} POSTPACK WMI_SET_ROAM_CTRL_CMD;
+
+/*
+ * WMI_SET_BT_WLAN_CONN_PRECEDENCE_CMDID
+ */
+typedef enum {
+ BT_WLAN_CONN_PRECDENCE_WLAN=0, /* Default */
+ BT_WLAN_CONN_PRECDENCE_PAL,
+} BT_WLAN_CONN_PRECEDENCE;
+
+typedef PREPACK struct {
+ A_UINT8 precedence;
+} POSTPACK WMI_SET_BT_WLAN_CONN_PRECEDENCE;
+
+/*
+ * WMI_ENABLE_RM_CMDID
+ */
+typedef PREPACK struct {
+ A_BOOL enable_radio_measurements;
+} POSTPACK WMI_ENABLE_RM_CMD;
+
+/*
+ * WMI_SET_MAX_OFFHOME_DURATION_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 max_offhome_duration;
+} POSTPACK WMI_SET_MAX_OFFHOME_DURATION_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 frequency;
+ A_UINT8 threshold;
+} POSTPACK WMI_SET_HB_CHALLENGE_RESP_PARAMS_CMD;
+
+typedef enum {
+ WMI_PKTLOG_CMD_DISABLE,
+ WMI_PKTLOG_CMD_SETSIZE,
+} WMI_PKTLOG_CMD;
+
+#define PKTLOG_MAX_BYTES 4096
+
+typedef PREPACK struct {
+ A_UINT32 nbytes;
+ A_UINT8 buffer[PKTLOG_MAX_BYTES];
+} POSTPACK WMI_GET_PKTLOG_CMD;
+
+/* LPL commands */
+typedef PREPACK struct {
+ A_UINT8 lplPolicy; /*0 - force off, 1 force on, 2 dynamic*/
+ A_UINT8 noBlockerDetect; /*don't do blocker detection if lpl policy is set
+ to dynamic*/
+ A_UINT8 noRfbDetect; /*don't do rate fall back detection if lpl policy is set
+ to dynamic*/
+ A_UINT8 rsvd;
+} POSTPACK WMI_LPL_FORCE_ENABLE_CMD;
+
+/*command structure for all policy related commands*/
+typedef PREPACK struct {
+ A_UINT64 index;
+ A_BOOL value;
+} POSTPACK WMI_LPL_POLICY_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 rfbPeriod;
+ A_UINT32 rfbObsDuration;
+ A_UINT32 blockerBeaconRssi;
+ A_UINT8 chanOff;
+ A_UINT32 rfbDiffThold;
+ A_UINT32 bRssiThold;
+ A_UINT32 maxBlockerRssi;
+} POSTPACK WMI_LPL_PARAMS_CMD;
+
+typedef enum {
+ WMI_PKTLOG_OPTION_LOG_TCP_HEADERS = 0x1,
+ WMI_PKTLOG_OPTION_TRIGGER_THRUPUT = 0x2,
+ WMI_PKTLOG_OPTION_TRIGGER_SACK = 0x4,
+ WMI_PKTLOG_OPTION_TRIGGER_PER = 0x8
+} WMI_PKTLOG_OPTION;
+
+typedef enum {
+ WMI_PKTLOG_EVENT_RX = 0x1,
+ WMI_PKTLOG_EVENT_TX = 0x2,
+ WMI_PKTLOG_EVENT_RCF = 0x4, /* Rate Control Find */
+ WMI_PKTLOG_EVENT_RCU = 0x8, /* Rate Control Update */
+} WMI_PKTLOG_EVENT;
+
+typedef PREPACK struct {
+ WMI_PKTLOG_EVENT evlist;
+ WMI_PKTLOG_OPTION option;
+ A_UINT32 trigger_thresh;
+ A_UINT32 trigger_interval;
+ A_UINT32 trigger_tail_count;
+ A_UINT32 buffer_size;
+} POSTPACK WMI_ENABLE_PKTLOG_CMD;
+
+typedef enum {
+ WMI_SMPS_OPTION_MODE = 0x1,
+ WMI_SMPS_OPTION_AUTO = 0x2,
+ WMI_SMPS_OPTION_DATATHRESH = 0x4,
+ WMI_SMPS_OPTION_RSSITHRESH = 0x8,
+} WMI_SMPS_OPTION;
+
+typedef enum {
+ WMI_SMPS_MODE_STATIC = 0x1,
+ WMI_SMPS_MODE_DYNAMIC = 0x2,
+} WMI_SMPS_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 flags; /* To indicate which options have changed */
+ A_UINT8 rssiThresh;
+ A_UINT8 dataThresh;
+ A_UINT8 mode; /* static/dynamic */
+ A_UINT8 automatic;
+} POSTPACK WMI_CONFIG_SMPS_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 enable; /* Enable/disable */
+} POSTPACK WMI_ENABLE_SMPS_CMD;
+
+
+typedef enum {
+ WMI_CCX_RM_STATUS_UNKNOWN = 0,
+ WMI_CCX_RM_REPORT_SENT,
+ WMI_CCX_RM_REFUSE_REPORT_SENT,
+ WMI_CCX_RM_STATUS_MAX
+} WMI_CCX_RM_STATUS_TYPE;
+
+/*---------------------- BTCOEX RELATED -------------------------------------*/
+/*----------------------COMMON to AR6002 and AR6003 -------------------------*/
+typedef enum {
+ BT_STREAM_UNDEF = 0,
+ BT_STREAM_SCO, /* SCO stream */
+ BT_STREAM_A2DP, /* A2DP stream */
+ BT_STREAM_SCAN, /* BT Discovery or Page */
+ BT_STREAM_ESCO,
+ BT_STREAM_MAX
+} BT_STREAM_TYPE;
+
+typedef enum {
+ BT_PARAM_SCO_PSPOLL_LATENCY_ONE_FOURTH =1,
+ BT_PARAM_SCO_PSPOLL_LATENCY_HALF,
+ BT_PARAM_SCO_PSPOLL_LATENCY_THREE_FOURTH,
+} BT_PARAMS_SCO_PSPOLL_LATENCY;
+
+typedef enum {
+ BT_PARAMS_SCO_STOMP_SCO_NEVER =1,
+ BT_PARAMS_SCO_STOMP_SCO_ALWAYS,
+ BT_PARAMS_SCO_STOMP_SCO_IN_LOWRSSI,
+} BT_PARAMS_SCO_STOMP_RULES;
+
+typedef enum {
+ BT_STATUS_UNDEF = 0,
+ BT_STATUS_ON,
+ BT_STATUS_OFF,
+ BT_STATUS_MAX
+} BT_STREAM_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 streamType;
+ A_UINT8 status;
+} POSTPACK WMI_SET_BT_STATUS_CMD;
+
+typedef enum {
+ BT_ANT_TYPE_UNDEF=0,
+ BT_ANT_TYPE_DUAL,
+ BT_ANT_TYPE_SPLITTER,
+ BT_ANT_TYPE_SWITCH,
+ BT_ANT_TYPE_HIGH_ISO_DUAL
+} BT_ANT_FRONTEND_CONFIG;
+
+typedef enum {
+ BT_COLOCATED_DEV_BTS4020=0,
+ BT_COLCATED_DEV_CSR ,
+ BT_COLOCATED_DEV_VALKYRIE
+} BT_COLOCATED_DEV_TYPE;
+
+/*********************** Applicable to AR6002 ONLY ******************************/
+
+typedef enum {
+ BT_PARAM_SCO = 1, /* SCO stream parameters */
+ BT_PARAM_A2DP ,
+ BT_PARAM_ANTENNA_CONFIG,
+ BT_PARAM_COLOCATED_BT_DEVICE,
+ BT_PARAM_ACLCOEX,
+ BT_PARAM_11A_SEPARATE_ANT,
+ BT_PARAM_MAX
+} BT_PARAM_TYPE;
+
+
+#define BT_SCO_ALLOW_CLOSE_RANGE_OPT (1 << 0)
+#define BT_SCO_FORCE_AWAKE_OPT (1 << 1)
+#define BT_SCO_SET_RSSI_OVERRIDE(flags) ((flags) |= (1 << 2))
+#define BT_SCO_GET_RSSI_OVERRIDE(flags) (((flags) >> 2) & 0x1)
+#define BT_SCO_SET_RTS_OVERRIDE(flags) ((flags) |= (1 << 3))
+#define BT_SCO_GET_RTS_OVERRIDE(flags) (((flags) >> 3) & 0x1)
+#define BT_SCO_GET_MIN_LOW_RATE_CNT(flags) (((flags) >> 8) & 0xFF)
+#define BT_SCO_GET_MAX_LOW_RATE_CNT(flags) (((flags) >> 16) & 0xFF)
+#define BT_SCO_SET_MIN_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 8)
+#define BT_SCO_SET_MAX_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 16)
+
+typedef PREPACK struct {
+ A_UINT32 numScoCyclesForceTrigger; /* Number SCO cycles after which
+ force a pspoll. default = 10 */
+ A_UINT32 dataResponseTimeout; /* Timeout Waiting for Downlink pkt
+ in response for ps-poll,
+ default = 10 msecs */
+ A_UINT32 stompScoRules;
+ A_UINT32 scoOptFlags; /* SCO Options Flags :
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 Force awake during close range
+ 2 If set use host supplied RSSI for OPT
+ 3 If set use host supplied RTS COUNT for OPT
+ 4..7 Unused
+ 8..15 Low Data Rate Min Cnt
+ 16..23 Low Data Rate Max Cnt
+ */
+
+ A_UINT8 stompDutyCyleVal; /* Sco cycles to limit ps-poll queuing
+ if stomped */
+ A_UINT8 stompDutyCyleMaxVal; /*firm ware increases stomp duty cycle
+ gradually uptill this value on need basis*/
+ A_UINT8 psPollLatencyFraction; /* Fraction of idle
+ period, within which
+ additional ps-polls
+ can be queued */
+ A_UINT8 noSCOSlots; /* Number of SCO Tx/Rx slots.
+ HVx, EV3, 2EV3 = 2 */
+ A_UINT8 noIdleSlots; /* Number of Bluetooth idle slots between
+ consecutive SCO Tx/Rx slots
+ HVx, EV3 = 4
+ 2EV3 = 10 */
+ A_UINT8 scoOptOffRssi;/*RSSI value below which we go to ps poll*/
+ A_UINT8 scoOptOnRssi; /*RSSI value above which we reenter opt mode*/
+ A_UINT8 scoOptRtsCount;
+} POSTPACK BT_PARAMS_SCO;
+
+#define BT_A2DP_ALLOW_CLOSE_RANGE_OPT (1 << 0)
+#define BT_A2DP_FORCE_AWAKE_OPT (1 << 1)
+#define BT_A2DP_SET_RSSI_OVERRIDE(flags) ((flags) |= (1 << 2))
+#define BT_A2DP_GET_RSSI_OVERRIDE(flags) (((flags) >> 2) & 0x1)
+#define BT_A2DP_SET_RTS_OVERRIDE(flags) ((flags) |= (1 << 3))
+#define BT_A2DP_GET_RTS_OVERRIDE(flags) (((flags) >> 3) & 0x1)
+#define BT_A2DP_GET_MIN_LOW_RATE_CNT(flags) (((flags) >> 8) & 0xFF)
+#define BT_A2DP_GET_MAX_LOW_RATE_CNT(flags) (((flags) >> 16) & 0xFF)
+#define BT_A2DP_SET_MIN_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 8)
+#define BT_A2DP_SET_MAX_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 16)
+
+typedef PREPACK struct {
+ A_UINT32 a2dpWlanUsageLimit; /* MAX time firmware uses the medium for
+ wlan, after it identifies the idle time
+ default (30 msecs) */
+ A_UINT32 a2dpBurstCntMin; /* Minimum number of bluetooth data frames
+ to replenish Wlan Usage limit (default 3) */
+ A_UINT32 a2dpDataRespTimeout;
+ A_UINT32 a2dpOptFlags; /* A2DP Option flags:
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 Force awake during close range
+ 2 If set use host supplied RSSI for OPT
+ 3 If set use host supplied RTS COUNT for OPT
+ 4..7 Unused
+ 8..15 Low Data Rate Min Cnt
+ 16..23 Low Data Rate Max Cnt
+ */
+ A_UINT8 isCoLocatedBtRoleMaster;
+ A_UINT8 a2dpOptOffRssi;/*RSSI value below which we go to ps poll*/
+ A_UINT8 a2dpOptOnRssi; /*RSSI value above which we reenter opt mode*/
+ A_UINT8 a2dpOptRtsCount;
+}POSTPACK BT_PARAMS_A2DP;
+
+/* During BT ftp/ BT OPP or any another data based acl profile on bluetooth
+ (non a2dp).*/
+typedef PREPACK struct {
+ A_UINT32 aclWlanMediumUsageTime; /* Wlan usage time during Acl (non-a2dp)
+ coexistence (default 30 msecs) */
+ A_UINT32 aclBtMediumUsageTime; /* Bt usage time during acl coexistence
+ (default 30 msecs)*/
+ A_UINT32 aclDataRespTimeout;
+ A_UINT32 aclDetectTimeout; /* ACL coexistence enabled if we get
+ 10 Pkts in X msec(default 100 msecs) */
+ A_UINT32 aclmaxPktCnt; /* No of ACL pkts to receive before
+ enabling ACL coex */
+
+}POSTPACK BT_PARAMS_ACLCOEX;
+
+typedef PREPACK struct {
+ PREPACK union {
+ BT_PARAMS_SCO scoParams;
+ BT_PARAMS_A2DP a2dpParams;
+ BT_PARAMS_ACLCOEX aclCoexParams;
+ A_UINT8 antType; /* 0 -Disabled (default)
+ 1 - BT_ANT_TYPE_DUAL
+ 2 - BT_ANT_TYPE_SPLITTER
+ 3 - BT_ANT_TYPE_SWITCH */
+ A_UINT8 coLocatedBtDev; /* 0 - BT_COLOCATED_DEV_BTS4020 (default)
+ 1 - BT_COLCATED_DEV_CSR
+ 2 - BT_COLOCATED_DEV_VALKYRIe
+ */
+ } POSTPACK info;
+ A_UINT8 paramType ;
+} POSTPACK WMI_SET_BT_PARAMS_CMD;
+
+/************************ END AR6002 BTCOEX *******************************/
+/*-----------------------AR6003 BTCOEX -----------------------------------*/
+
+/* ---------------WMI_SET_BTCOEX_FE_ANT_CMDID --------------------------*/
+/* Indicates front end antenna configuration. This command needs to be issued
+ * right after initialization and after WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID.
+ * AR6003 enables coexistence and antenna switching based on the configuration.
+ */
+typedef enum {
+ WMI_BTCOEX_NOT_ENABLED = 0,
+ WMI_BTCOEX_FE_ANT_SINGLE =1,
+ WMI_BTCOEX_FE_ANT_DUAL=2,
+ WMI_BTCOEX_FE_ANT_DUAL_HIGH_ISO=3,
+ WMI_BTCOEX_FE_ANT_DUAL_SH_BT_LOW_ISO = 4,
+ WMI_BTCOEX_FE_ANT_DUAL_SH_BT_HIGH_ISO = 5,
+ WMI_BTCOEX_FE_ANT_TYPE_MAX
+}WMI_BTCOEX_FE_ANT_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 btcoexFeAntType; /* 1 - WMI_BTCOEX_FE_ANT_SINGLE for single antenna front end
+ 2 - WMI_BTCOEX_FE_ANT_DUAL for dual antenna front end
+ (for isolations less 35dB, for higher isolation there
+ is not need to pass this command).
+ (not implemented)
+ */
+}POSTPACK WMI_SET_BTCOEX_FE_ANT_CMD;
+
+/* -------------WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID ----------------*/
+/* Indicate the bluetooth chip to the firmware. Firmware can have different algorithm based
+ * bluetooth chip type.Based on bluetooth device, different coexistence protocol would be used.
+ */
+typedef PREPACK struct {
+ A_UINT8 btcoexCoLocatedBTdev; /*1 - Qcom BT (3 -wire PTA)
+ 2 - CSR BT (3 wire PTA)
+ 3 - Atheros 3001 BT (3 wire PTA)
+ 4 - STE bluetooth (4-wire ePTA)
+ 5 - Atheros 3002 BT (4-wire MCI)
+ defaults= 3 (Atheros 3001 BT )
+ */
+}POSTPACK WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD;
+
+/* -------------WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMDID ------------*/
+/* Configuration parameters during bluetooth inquiry and page. Page configuration
+ * is applicable only on interfaces which can distinguish page (applicable only for ePTA -
+ * STE bluetooth).
+ * Bluetooth inquiry start and end is indicated via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID.
+ * During this the station will be power-save mode.
+ */
+typedef PREPACK struct {
+ A_UINT32 btInquiryDataFetchFrequency;/* The frequency of querying the AP for data
+ (via pspoll) is configured by this parameter.
+ "default = 10 ms" */
+
+ A_UINT32 protectBmissDurPostBtInquiry;/* The firmware will continue to be in inquiry state
+ for configured duration, after inquiry completion
+ . This is to ensure other bluetooth transactions
+ (RDP, SDP profiles, link key exchange ...etc)
+ goes through smoothly without wifi stomping.
+ default = 10 secs*/
+
+ A_UINT32 maxpageStomp; /*Applicable only for STE-BT interface. Currently not
+ used */
+ A_UINT32 btInquiryPageFlag; /* Not used */
+}POSTPACK WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD;
+
+/*---------------------WMI_SET_BTCOEX_SCO_CONFIG_CMDID ---------------*/
+/* Configure SCO parameters. These parameters would be used whenever firmware is indicated
+ * of (e)SCO profile on bluetooth ( via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID).
+ * Configration of BTCOEX_SCO_CONFIG data structure are common configuration and applies
+ * ps-poll mode and opt mode.
+ * Ps-poll Mode - Station is in power-save and retrieves downlink data between sco gaps.
+ * Opt Mode - station is in awake state and access point can send data to station any time.
+ * BTCOEX_PSPOLLMODE_SCO_CONFIG - Configuration applied only during ps-poll mode.
+ * BTCOEX_OPTMODE_SCO_CONFIG - Configuration applied only during opt mode.
+ */
+#define WMI_SCO_CONFIG_FLAG_ALLOW_OPTIMIZATION (1 << 0)
+#define WMI_SCO_CONFIG_FLAG_IS_EDR_CAPABLE (1 << 1)
+#define WMI_SCO_CONFIG_FLAG_IS_BT_MASTER (1 << 2)
+#define WMI_SCO_CONFIG_FLAG_FW_DETECT_OF_PER (1 << 3)
+typedef PREPACK struct {
+ A_UINT32 scoSlots; /* Number of SCO Tx/Rx slots.
+ HVx, EV3, 2EV3 = 2 */
+ A_UINT32 scoIdleSlots; /* Number of Bluetooth idle slots between
+ consecutive SCO Tx/Rx slots
+ HVx, EV3 = 4
+ 2EV3 = 10
+ */
+ A_UINT32 scoFlags; /* SCO Options Flags :
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 Is EDR capable or Not
+ 2 IS Co-located Bt role Master
+ 3 Firmware determines the periodicity of SCO.
+ */
+
+ A_UINT32 linkId; /* applicable to STE-BT - not used */
+}POSTPACK BTCOEX_SCO_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 scoCyclesForceTrigger; /* Number SCO cycles after which
+ force a pspoll. default = 10 */
+ A_UINT32 scoDataResponseTimeout; /* Timeout Waiting for Downlink pkt
+ in response for ps-poll,
+ default = 20 msecs */
+
+ A_UINT32 scoStompDutyCyleVal; /* not implemented */
+
+ A_UINT32 scoStompDutyCyleMaxVal; /*Not implemented */
+
+ A_UINT32 scoPsPollLatencyFraction; /* Fraction of idle
+ period, within which
+ additional ps-polls can be queued
+ 1 - 1/4 of idle duration
+ 2 - 1/2 of idle duration
+ 3 - 3/4 of idle duration
+ default =2 (1/2)
+ */
+}POSTPACK BTCOEX_PSPOLLMODE_SCO_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 scoStompCntIn100ms;/*max number of SCO stomp in 100ms allowed in
+ opt mode. If exceeds the configured value,
+ switch to ps-poll mode
+ default = 3 */
+
+ A_UINT32 scoContStompMax; /* max number of continous stomp allowed in opt mode.
+ if excedded switch to pspoll mode
+ default = 3 */
+
+ A_UINT32 scoMinlowRateMbps; /* Low rate threshold */
+
+ A_UINT32 scoLowRateCnt; /* number of low rate pkts (< scoMinlowRateMbps) allowed in 100 ms.
+ If exceeded switch/stay to ps-poll mode, lower stay in opt mode.
+ default = 36
+ */
+
+ A_UINT32 scoHighPktRatio; /*(Total Rx pkts in 100 ms + 1)/
+ ((Total tx pkts in 100 ms - No of high rate pkts in 100 ms) + 1) in 100 ms,
+ if exceeded switch/stay in opt mode and if lower switch/stay in pspoll mode.
+ default = 5 (80% of high rates)
+ */
+
+ A_UINT32 scoMaxAggrSize; /* Max number of Rx subframes allowed in this mode. (Firmware re-negogiates
+ max number of aggregates if it was negogiated to higher value
+ default = 1
+ Recommended value Basic rate headsets = 1, EDR (2-EV3) =4.
+ */
+}POSTPACK BTCOEX_OPTMODE_SCO_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 scanInterval;
+ A_UINT32 maxScanStompCnt;
+}POSTPACK BTCOEX_WLANSCAN_SCO_CONFIG;
+
+typedef PREPACK struct {
+ BTCOEX_SCO_CONFIG scoConfig;
+ BTCOEX_PSPOLLMODE_SCO_CONFIG scoPspollConfig;
+ BTCOEX_OPTMODE_SCO_CONFIG scoOptModeConfig;
+ BTCOEX_WLANSCAN_SCO_CONFIG scoWlanScanConfig;
+}POSTPACK WMI_SET_BTCOEX_SCO_CONFIG_CMD;
+
+/* ------------------WMI_SET_BTCOEX_A2DP_CONFIG_CMDID -------------------*/
+/* Configure A2DP profile parameters. These parameters would be used whenver firmware is indicated
+ * of A2DP profile on bluetooth ( via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID).
+ * Configuration of BTCOEX_A2DP_CONFIG data structure are common configuration and applies to
+ * ps-poll mode and opt mode.
+ * Ps-poll Mode - Station is in power-save and retrieves downlink data between a2dp data bursts.
+ * Opt Mode - station is in power save during a2dp bursts and awake in the gaps.
+ * BTCOEX_PSPOLLMODE_A2DP_CONFIG - Configuration applied only during ps-poll mode.
+ * BTCOEX_OPTMODE_A2DP_CONFIG - Configuration applied only during opt mode.
+ */
+
+#define WMI_A2DP_CONFIG_FLAG_ALLOW_OPTIMIZATION (1 << 0)
+#define WMI_A2DP_CONFIG_FLAG_IS_EDR_CAPABLE (1 << 1)
+#define WMI_A2DP_CONFIG_FLAG_IS_BT_ROLE_MASTER (1 << 2)
+#define WMI_A2DP_CONFIG_FLAG_IS_A2DP_HIGH_PRI (1 << 3)
+#define WMI_A2DP_CONFIG_FLAG_FIND_BT_ROLE (1 << 4)
+
+typedef PREPACK struct {
+ A_UINT32 a2dpFlags; /* A2DP Option flags:
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 IS EDR capable
+ 2 IS Co-located Bt role Master
+ 3 a2dp traffic is high priority
+ 4 Fw detect the role of bluetooth.
+ */
+ A_UINT32 linkId; /* Applicable only to STE-BT - not used */
+
+}POSTPACK BTCOEX_A2DP_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 a2dpWlanMaxDur; /* MAX time firmware uses the medium for
+ wlan, after it identifies the idle time
+ default (30 msecs) */
+
+ A_UINT32 a2dpMinBurstCnt; /* Minimum number of bluetooth data frames
+ to replenish Wlan Usage limit (default 3) */
+
+ A_UINT32 a2dpDataRespTimeout; /* Max duration firmware waits for downlink
+ by stomping on bluetooth
+ after ps-poll is acknowledged.
+ default = 20 ms
+ */
+}POSTPACK BTCOEX_PSPOLLMODE_A2DP_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 a2dpMinlowRateMbps; /* Low rate threshold */
+
+ A_UINT32 a2dpLowRateCnt; /* number of low rate pkts (< a2dpMinlowRateMbps) allowed in 100 ms.
+ If exceeded switch/stay to ps-poll mode, lower stay in opt mode.
+ default = 36
+ */
+
+ A_UINT32 a2dpHighPktRatio; /*(Total Rx pkts in 100 ms + 1)/
+ ((Total tx pkts in 100 ms - No of high rate pkts in 100 ms) + 1) in 100 ms,
+ if exceeded switch/stay in opt mode and if lower switch/stay in pspoll mode.
+ default = 5 (80% of high rates)
+ */
+
+ A_UINT32 a2dpMaxAggrSize; /* Max number of Rx subframes allowed in this mode. (Firmware re-negogiates
+ max number of aggregates if it was negogiated to higher value
+ default = 1
+ Recommended value Basic rate headsets = 1, EDR (2-EV3) =8.
+ */
+ A_UINT32 a2dpPktStompCnt; /*number of a2dp pkts that can be stomped per burst.
+ default = 6*/
+
+}POSTPACK BTCOEX_OPTMODE_A2DP_CONFIG;
+
+typedef PREPACK struct {
+ BTCOEX_A2DP_CONFIG a2dpConfig;
+ BTCOEX_PSPOLLMODE_A2DP_CONFIG a2dppspollConfig;
+ BTCOEX_OPTMODE_A2DP_CONFIG a2dpOptConfig;
+}POSTPACK WMI_SET_BTCOEX_A2DP_CONFIG_CMD;
+
+/*------------ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMDID---------------------*/
+/* Configure non-A2dp ACL profile parameters.The starts of ACL profile can either be
+ * indicated via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID orenabled via firmware detection
+ * which is configured via "aclCoexFlags".
+ * Configration of BTCOEX_ACLCOEX_CONFIG data structure are common configuration and applies
+ * ps-poll mode and opt mode.
+ * Ps-poll Mode - Station is in power-save and retrieves downlink data during wlan medium.
+ * Opt Mode - station is in power save during bluetooth medium time and awake during wlan duration.
+ * (Not implemented yet)
+ *
+ * BTCOEX_PSPOLLMODE_ACLCOEX_CONFIG - Configuration applied only during ps-poll mode.
+ * BTCOEX_OPTMODE_ACLCOEX_CONFIG - Configuration applied only during opt mode.
+ */
+
+#define WMI_ACLCOEX_FLAGS_ALLOW_OPTIMIZATION (1 << 0)
+#define WMI_ACLCOEX_FLAGS_DISABLE_FW_DETECTION (1 << 1)
+
+typedef PREPACK struct {
+ A_UINT32 aclWlanMediumDur; /* Wlan usage time during Acl (non-a2dp)
+ coexistence (default 30 msecs)
+ */
+
+ A_UINT32 aclBtMediumDur; /* Bt usage time during acl coexistence
+ (default 30 msecs)
+ */
+
+ A_UINT32 aclDetectTimeout; /* BT activity observation time limit.
+ In this time duration, number of bt pkts are counted.
+ If the Cnt reaches "aclPktCntLowerLimit" value
+ for "aclIterToEnableCoex" iteration continuously,
+ firmware gets into ACL coexistence mode.
+ Similarly, if bt traffic count during ACL coexistence
+ has not reached "aclPktCntLowerLimit" continuously
+ for "aclIterToEnableCoex", then ACL coexistence is
+ disabled.
+ -default 100 msecs
+ */
+
+ A_UINT32 aclPktCntLowerLimit; /* Acl Pkt Cnt to be received in duration of
+ "aclDetectTimeout" for
+ "aclIterForEnDis" times to enabling ACL coex.
+ Similar logic is used to disable acl coexistence.
+ (If "aclPktCntLowerLimit" cnt of acl pkts
+ are not seen by the for "aclIterForEnDis"
+ then acl coexistence is disabled).
+ default = 10
+ */
+
+ A_UINT32 aclIterForEnDis; /* number of Iteration of "aclPktCntLowerLimit" for Enabling and
+ Disabling Acl Coexistence.
+ default = 3
+ */
+
+ A_UINT32 aclPktCntUpperLimit; /* This is upperBound limit, if there is more than
+ "aclPktCntUpperLimit" seen in "aclDetectTimeout",
+ ACL coexistence is enabled right away.
+ - default 15*/
+
+ A_UINT32 aclCoexFlags; /* A2DP Option flags:
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 disable Firmware detection
+ (Currently supported configuration is aclCoexFlags =0)
+ */
+
+ A_UINT32 linkId; /* Applicable only for STE-BT - not used */
+
+}POSTPACK BTCOEX_ACLCOEX_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 aclDataRespTimeout; /* Max duration firmware waits for downlink
+ by stomping on bluetooth
+ after ps-poll is acknowledged.
+ default = 20 ms */
+
+}POSTPACK BTCOEX_PSPOLLMODE_ACLCOEX_CONFIG;
+
+
+/* Not implemented yet*/
+typedef PREPACK struct {
+ A_UINT32 aclCoexMinlowRateMbps;
+ A_UINT32 aclCoexLowRateCnt;
+ A_UINT32 aclCoexHighPktRatio;
+ A_UINT32 aclCoexMaxAggrSize;
+ A_UINT32 aclPktStompCnt;
+}POSTPACK BTCOEX_OPTMODE_ACLCOEX_CONFIG;
+
+typedef PREPACK struct {
+ BTCOEX_ACLCOEX_CONFIG aclCoexConfig;
+ BTCOEX_PSPOLLMODE_ACLCOEX_CONFIG aclCoexPspollConfig;
+ BTCOEX_OPTMODE_ACLCOEX_CONFIG aclCoexOptConfig;
+}POSTPACK WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD;
+
+/* -----------WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID ------------------*/
+typedef enum {
+ WMI_BTCOEX_BT_PROFILE_SCO =1,
+ WMI_BTCOEX_BT_PROFILE_A2DP,
+ WMI_BTCOEX_BT_PROFILE_INQUIRY_PAGE,
+ WMI_BTCOEX_BT_PROFILE_ACLCOEX,
+}WMI_BTCOEX_BT_PROFILE;
+
+typedef PREPACK struct {
+ A_UINT32 btProfileType;
+ A_UINT32 btOperatingStatus;
+ A_UINT32 btLinkId;
+}WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD;
+
+/*--------------------- WMI_SET_BTCOEX_DEBUG_CMDID ---------------------*/
+/* Used for firmware development and debugging */
+typedef PREPACK struct {
+ A_UINT32 btcoexDbgParam1;
+ A_UINT32 btcoexDbgParam2;
+ A_UINT32 btcoexDbgParam3;
+ A_UINT32 btcoexDbgParam4;
+ A_UINT32 btcoexDbgParam5;
+}WMI_SET_BTCOEX_DEBUG_CMD;
+
+/*---------------------WMI_GET_BTCOEX_CONFIG_CMDID --------------------- */
+/* Command to firmware to get configuration parameters of the bt profile
+ * reported via WMI_BTCOEX_CONFIG_EVENTID */
+typedef PREPACK struct {
+ A_UINT32 btProfileType; /* 1 - SCO
+ 2 - A2DP
+ 3 - INQUIRY_PAGE
+ 4 - ACLCOEX
+ */
+ A_UINT32 linkId; /* not used */
+}WMI_GET_BTCOEX_CONFIG_CMD;
+
+/*------------------WMI_REPORT_BTCOEX_CONFIG_EVENTID------------------- */
+/* Event from firmware to host, sent in response to WMI_GET_BTCOEX_CONFIG_CMDID
+ * */
+typedef PREPACK struct {
+ A_UINT32 btProfileType;
+ A_UINT32 linkId; /* not used */
+ PREPACK union {
+ WMI_SET_BTCOEX_SCO_CONFIG_CMD scoConfigCmd;
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMD a2dpConfigCmd;
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD aclcoexConfig;
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD btinquiryPageConfigCmd;
+ } POSTPACK info;
+} POSTPACK WMI_BTCOEX_CONFIG_EVENT;
+
+/*------------- WMI_REPORT_BTCOEX_BTCOEX_STATS_EVENTID--------------------*/
+/* Used for firmware development and debugging*/
+typedef PREPACK struct {
+ A_UINT32 highRatePktCnt;
+ A_UINT32 firstBmissCnt;
+ A_UINT32 psPollFailureCnt;
+ A_UINT32 nullFrameFailureCnt;
+ A_UINT32 optModeTransitionCnt;
+}BTCOEX_GENERAL_STATS;
+
+typedef PREPACK struct {
+ A_UINT32 scoStompCntAvg;
+ A_UINT32 scoStompIn100ms;
+ A_UINT32 scoMaxContStomp;
+ A_UINT32 scoAvgNoRetries;
+ A_UINT32 scoMaxNoRetriesIn100ms;
+}BTCOEX_SCO_STATS;
+
+typedef PREPACK struct {
+ A_UINT32 a2dpBurstCnt;
+ A_UINT32 a2dpMaxBurstCnt;
+ A_UINT32 a2dpAvgIdletimeIn100ms;
+ A_UINT32 a2dpAvgStompCnt;
+}BTCOEX_A2DP_STATS;
+
+typedef PREPACK struct {
+ A_UINT32 aclPktCntInBtTime;
+ A_UINT32 aclStompCntInWlanTime;
+ A_UINT32 aclPktCntIn100ms;
+}BTCOEX_ACLCOEX_STATS;
+
+typedef PREPACK struct {
+ BTCOEX_GENERAL_STATS coexStats;
+ BTCOEX_SCO_STATS scoStats;
+ BTCOEX_A2DP_STATS a2dpStats;
+ BTCOEX_ACLCOEX_STATS aclCoexStats;
+}WMI_BTCOEX_STATS_EVENT;
+
+
+/*--------------------------END OF BTCOEX -------------------------------------*/
+
+/* WAC commands
+ */
+
+
+typedef PREPACK struct {
+ A_UINT32 period;
+ A_UINT32 threshold;
+ A_INT32 rssi;
+ A_BOOL enable;
+ A_CHAR wps_pin[8];
+}WMI_WAC_ENABLE_CMD;
+
+typedef enum {
+ WAC_MORE_SCAN = -1,
+ WAC_SEND_PROBE_IDX = 0,
+}WAC_SUBCMD;
+
+typedef PREPACK struct {
+ WAC_SUBCMD cmdid;
+}WMI_WAC_SCAN_REPLY_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 req;
+ A_UINT8 cmd;
+ A_UINT8 frame;
+ A_UINT8 ie[64];
+ A_INT32 status;
+}WMI_WAC_CTRL_REQ_CMD;
+
+/* END OF WAC */
+
+typedef PREPACK struct {
+ A_UINT32 sleepState;
+}WMI_REPORT_SLEEP_STATE_EVENT;
+
+typedef enum {
+ WMI_REPORT_SLEEP_STATUS_IS_DEEP_SLEEP =0,
+ WMI_REPORT_SLEEP_STATUS_IS_AWAKE
+} WMI_REPORT_SLEEP_STATUS;
+typedef enum {
+ DISCONN_EVT_IN_RECONN = 0, /* default */
+ NO_DISCONN_EVT_IN_RECONN
+} TARGET_EVENT_REPORT_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 evtConfig;
+} POSTPACK WMI_SET_TARGET_EVENT_REPORT_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT16 cmd_buf_sz; /* HCI cmd buffer size */
+ A_UINT8 buf[1]; /* Absolute HCI cmd */
+} POSTPACK WMI_HCI_CMD;
+
+/*
+ * Command Replies
+ */
+
+/*
+ * WMI_GET_CHANNEL_LIST_CMDID reply
+ */
+typedef PREPACK struct {
+ A_UINT8 reserved1;
+ A_UINT8 numChannels; /* number of channels in reply */
+ A_UINT16 channelList[1]; /* channel in Mhz */
+} POSTPACK WMI_CHANNEL_LIST_REPLY;
+
+typedef enum {
+ A_SUCCEEDED = A_OK,
+ A_FAILED_DELETE_STREAM_DOESNOT_EXIST=250,
+ A_SUCCEEDED_MODIFY_STREAM=251,
+ A_FAILED_INVALID_STREAM = 252,
+ A_FAILED_MAX_THINSTREAMS = 253,
+ A_FAILED_CREATE_REMOVE_PSTREAM_FIRST = 254,
+} PSTREAM_REPLY_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 status; /* PSTREAM_REPLY_STATUS */
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficClass;
+ A_UINT8 trafficDirection; /* DIR_TYPE */
+} POSTPACK WMI_CRE_PRIORITY_STREAM_REPLY;
+
+typedef PREPACK struct {
+ A_UINT8 status; /* PSTREAM_REPLY_STATUS */
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficDirection; /* DIR_TYPE */
+ A_UINT8 trafficClass;
+} POSTPACK WMI_DEL_PRIORITY_STREAM_REPLY;
+
+#ifdef TIME_BASED_DISCARD
+/*
+ * WMI_SET_TBD_TIME_CMDID
+ */
+typedef PREPACK struct{
+ A_UINT32 discardDispostion:1;
+ A_UINT32 txdiscardTime:31;
+} POSTPACK WMI_SET_TBD_TIME;
+extern WMI_SET_TBD_TIME *txDiscard ;
+#endif
+/*
+ * List of Events (target to host)
+ */
+typedef enum {
+ WMI_READY_EVENTID = 0x1001,
+ WMI_CONNECT_EVENTID,
+ WMI_DISCONNECT_EVENTID,
+ WMI_BSSINFO_EVENTID,
+ WMI_CMDERROR_EVENTID,
+ WMI_REGDOMAIN_EVENTID,
+ WMI_PSTREAM_TIMEOUT_EVENTID,
+ WMI_NEIGHBOR_REPORT_EVENTID,
+ WMI_TKIP_MICERR_EVENTID,
+ WMI_SCAN_COMPLETE_EVENTID, /* 0x100a */
+ WMI_REPORT_STATISTICS_EVENTID,
+ WMI_RSSI_THRESHOLD_EVENTID,
+ WMI_ERROR_REPORT_EVENTID,
+ WMI_OPT_RX_FRAME_EVENTID,
+ WMI_REPORT_ROAM_TBL_EVENTID,
+ WMI_EXTENSION_EVENTID,
+ WMI_CAC_EVENTID,
+ WMI_SNR_THRESHOLD_EVENTID,
+ WMI_LQ_THRESHOLD_EVENTID,
+ WMI_TX_RETRY_ERR_EVENTID, /* 0x1014 */
+ WMI_REPORT_ROAM_DATA_EVENTID,
+ WMI_TEST_EVENTID,
+ WMI_APLIST_EVENTID,
+ WMI_GET_WOW_LIST_EVENTID,
+ WMI_GET_PMKID_LIST_EVENTID,
+ WMI_CHANNEL_CHANGE_EVENTID,
+ WMI_PEER_NODE_EVENTID,
+ WMI_PSPOLL_EVENTID,
+ WMI_DTIMEXPIRY_EVENTID,
+ WMI_WLAN_VERSION_EVENTID,
+ WMI_SET_PARAMS_REPLY_EVENTID,
+ WMI_ADDBA_REQ_EVENTID, /*0x1020 */
+ WMI_ADDBA_RESP_EVENTID,
+ WMI_DELBA_REQ_EVENTID,
+ WMI_TX_COMPLETE_EVENTID,
+ WMI_HCI_EVENT_EVENTID,
+ WMI_ACL_DATA_EVENTID,
+ WMI_REPORT_SLEEP_STATE_EVENTID,
+ WMI_WAPI_REKEY_EVENTID,
+ WMI_REPORT_BTCOEX_STATS_EVENTID,
+ WMI_REPORT_BTCOEX_CONFIG_EVENTID,
+ WMI_GET_PMK_EVENTID,
+
+ /* DFS Events */
+ WMI_DFS_HOST_ATTACH_EVENTID, /* 102B */
+ WMI_DFS_HOST_INIT_EVENTID,
+ WMI_DFS_RESET_DELAYLINES_EVENTID,
+ WMI_DFS_RESET_RADARQ_EVENTID,
+ WMI_DFS_RESET_AR_EVENTID,
+ WMI_DFS_RESET_ARQ_EVENTID,
+ WMI_DFS_SET_DUR_MULTIPLIER_EVENTID,
+ WMI_DFS_SET_BANGRADAR_EVENTID,
+ WMI_DFS_SET_DEBUGLEVEL_EVENTID,
+ WMI_DFS_PHYERR_EVENTID,
+ /* CCX Evants */
+ WMI_CCX_RM_STATUS_EVENTID, /* 1035 */
+
+ /* P2P Events */
+ WMI_P2P_GO_NEG_RESULT_EVENTID, /* 1036 */
+
+ WMI_WAC_SCAN_DONE_EVENTID,
+ WMI_WAC_REPORT_BSS_EVENTID,
+ WMI_WAC_START_WPS_EVENTID,
+ WMI_WAC_CTRL_REQ_REPLY_EVENTID,
+ WMI_REPORT_WMM_PARAMS_EVENTID,
+ WMI_WAC_REJECT_WPS_EVENTID,
+
+ /* More P2P Events */
+ WMI_P2P_GO_NEG_REQ_EVENTID,
+ WMI_P2P_INVITE_REQ_EVENTID,
+ WMI_P2P_INVITE_RCVD_RESULT_EVENTID,
+ WMI_P2P_INVITE_SENT_RESULT_EVENTID,
+ WMI_P2P_PROV_DISC_RESP_EVENTID,
+ WMI_P2P_PROV_DISC_REQ_EVENTID,
+
+ /*RFKILL Events*/
+ WMI_RFKILL_STATE_CHANGE_EVENTID,
+ WMI_RFKILL_GET_MODE_CMD_EVENTID,
+
+ WMI_P2P_START_SDPD_EVENTID,
+ WMI_P2P_SDPD_RX_EVENTID,
+
+ /* Special event used to notify host that AR6003
+ * has processed sleep command (needed to prevent
+ * a late incoming credit report from crashing
+ * the system)
+ */
+ WMI_SET_HOST_SLEEP_MODE_CMD_PROCESSED_EVENTID,
+
+ WMI_THIN_RESERVED_START_EVENTID = 0x8000,
+ /* Events in this range are reserved for thinmode
+ * See wmi_thin.h for actual definitions */
+ WMI_THIN_RESERVED_END_EVENTID = 0x8fff,
+
+ WMI_SET_CHANNEL_EVENTID,
+ WMI_ASSOC_REQ_EVENTID,
+
+ /* generic ACS event */
+ WMI_ACS_EVENTID,
+ WMI_STORERECALL_STORE_EVENTID,
+ WMI_WOW_EXT_WAKE_EVENTID,
+ WMI_GTK_OFFLOAD_STATUS_EVENTID,
+ WMI_NETWORK_LIST_OFFLOAD_EVENTID,
+ WMI_REMAIN_ON_CHNL_EVENTID,
+ WMI_CANCEL_REMAIN_ON_CHNL_EVENTID,
+ WMI_TX_STATUS_EVENTID,
+ WMI_RX_PROBE_REQ_EVENTID,
+ WMI_P2P_CAPABILITIES_EVENTID,
+ WMI_RX_ACTION_EVENTID,
+ WMI_P2P_INFO_EVENTID,
+ /*WMI Location API Commands*/
+#ifdef WLAN_LOCATION_SUPPORT
+ WMI_RTT_MEASRESP_EVENTID,
+ WMI_RTT_CAPRESP_EVENTID,
+ WMI_RTT_STATUSRESP_EVENTID,
+#endif
+ /* WPS Events */
+ WMI_WPS_GET_STATUS_EVENTID,
+ WMI_WPS_PROFILE_EVENTID,
+
+ /* more P2P events */
+ WMI_NOA_INFO_EVENTID,
+ WMI_OPPPS_INFO_EVENTID,
+ WMI_PORT_STATUS_EVENTID,
+
+ /* 802.11w */
+ WMI_GET_RSN_CAP_EVENTID,
+} WMI_EVENT_ID;
+
+typedef enum {
+ WMI_11A_CAPABILITY = 1,
+ WMI_11G_CAPABILITY = 2,
+ WMI_11AG_CAPABILITY = 3,
+ WMI_11NA_CAPABILITY = 4,
+ WMI_11NG_CAPABILITY = 5,
+ WMI_11NAG_CAPABILITY = 6,
+ // END CAPABILITY
+ WMI_11N_CAPABILITY_OFFSET = (WMI_11NA_CAPABILITY - WMI_11A_CAPABILITY),
+} WMI_PHY_CAPABILITY;
+
+typedef PREPACK struct {
+ A_UINT8 macaddr[ATH_MAC_LEN];
+ A_UINT8 phyCapability; /* WMI_PHY_CAPABILITY */
+} POSTPACK WMI_READY_EVENT_1;
+
+typedef PREPACK struct {
+ A_UINT32 sw_version;
+ A_UINT32 abi_version;
+ A_UINT8 macaddr[ATH_MAC_LEN];
+ A_UINT8 phyCapability; /* WMI_PHY_CAPABILITY */
+} POSTPACK WMI_READY_EVENT_2;
+
+#if defined(ATH_TARGET)
+#ifdef AR6002_REV2
+#define WMI_READY_EVENT WMI_READY_EVENT_1 /* AR6002_REV2 target code */
+#else
+#define WMI_READY_EVENT WMI_READY_EVENT_2 /* AR6001, AR6002_REV4, AR6002_REV6 */
+#endif
+#else
+#define WMI_READY_EVENT WMI_READY_EVENT_2 /* host code */
+#endif
+
+
+/*
+ * Connect Event
+ *
+ * In STA mode networkType comes along with connected phy mode
+ * To get networkType, WMI_NETWORK_TYPE (networkType)
+ * To get connected phymode, WMI_CONNECTED_PHYMODE(networkType)
+ * will give the phymode value.
+ */
+typedef PREPACK struct {
+ PREPACK union {
+ struct {
+ A_UINT16 channel;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT16 listenInterval;
+ A_UINT16 beaconInterval;
+#if defined(EXTENDED_TX_COMPLETE)
+ A_UINT16 networkType;
+ A_UINT8 aid;
+ A_UINT8 unused;
+#else
+ A_UINT32 networkType;
+#endif /* EXTENDED_TX_COMPLETE */
+ } infra_ibss_bss;
+ struct {
+ A_UINT8 phymode;
+ A_UINT8 aid;
+ A_UINT8 mac_addr[ATH_MAC_LEN];
+ A_UINT8 auth;
+ A_UINT8 keymgmt;
+ A_UINT16 cipher;
+ A_UINT8 apsd_info;
+ A_UINT8 unused[3];
+ } ap_sta;
+ struct {
+ A_UINT16 channel;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 unused[8];
+ } ap_bss;
+ } POSTPACK u;
+ A_UINT8 beaconIeLen;
+ A_UINT8 assocReqLen;
+ A_UINT8 assocRespLen;
+ A_UINT8 assocInfo[1];
+} POSTPACK WMI_CONNECT_EVENT;
+
+
+typedef struct {
+ A_UINT8 status;
+ A_UINT8 rspType;
+} WMI_ASSOCREQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 host_accept;
+ A_UINT8 host_reasonCode;
+ A_UINT8 target_status;
+ A_UINT8 sta_mac_addr[ATH_MAC_LEN];
+ A_UINT8 rspType;
+} POSTPACK WMI_SEND_ASSOCRES_CMD;
+
+typedef struct {
+ A_UINT8 enable;
+} WMI_SET_ASSOCREQ_RELAY;
+
+/*
+ * Disconnect Event
+ */
+typedef enum {
+ NO_NETWORK_AVAIL = 0x01,
+ LOST_LINK = 0x02, /* bmiss */
+ DISCONNECT_CMD = 0x03,
+ BSS_DISCONNECTED = 0x04,
+ AUTH_FAILED = 0x05,
+ ASSOC_FAILED = 0x06,
+ NO_RESOURCES_AVAIL = 0x07,
+ CSERV_DISCONNECT = 0x08,
+ INVALID_PROFILE = 0x0a,
+ DOT11H_CHANNEL_SWITCH = 0x0b,
+ PROFILE_MISMATCH = 0x0c,
+ CONNECTION_EVICTED = 0x0d,
+ IBSS_MERGE = 0x0e,
+ EXCESS_TX_RETRY = 0x0f, /* TX frames failed after excessive retries */
+ SEC_HS_TO_RECV_M1 = 0x10, /* Security 4-way handshake timed out waiting for M1 */
+ SEC_HS_TO_RECV_M3 = 0x11, /* Security 4-way handshake timed out waiting for M3 */
+ TKIP_COUNTERMEASURES = 0x12,
+ MLME_TIMEOUT = 0x13,
+ CCX_TARGET_ROAMING_INDICATION = 0xfd, /* hack for CCX AP-Assisted roaming*/
+ CCKM_ROAMING_INDICATION = 0xfe, /* hack for CCKM fast roaming */
+} WMI_DISCONNECT_REASON;
+
+typedef PREPACK struct {
+ A_UINT16 protocolReasonStatus; /* reason code, see 802.11 spec. */
+ A_UINT8 bssid[ATH_MAC_LEN]; /* set if known */
+ A_UINT8 disconnectReason ; /* see WMI_DISCONNECT_REASON */
+ A_UINT8 assocRespLen;
+ A_UINT8 assocInfo[1];
+} POSTPACK WMI_DISCONNECT_EVENT;
+
+/*
+ * BSS Info Event.
+ * Mechanism used to inform host of the presence and characteristic of
+ * wireless networks present. Consists of bss info header followed by
+ * the beacon or probe-response frame body. The 802.11 header is not included.
+ */
+typedef enum {
+ BEACON_FTYPE = 0x1,
+ PROBERESP_FTYPE,
+ ACTION_MGMT_FTYPE,
+ PROBEREQ_FTYPE,
+} WMI_BI_FTYPE;
+
+enum {
+ BSS_ELEMID_CHANSWITCH = 0x01,
+ BSS_ELEMID_ATHEROS = 0x02,
+};
+
+typedef PREPACK struct {
+ A_UINT16 channel;
+ A_UINT8 frameType; /* see WMI_BI_FTYPE */
+ A_UINT8 snr;
+ A_INT16 rssi;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT32 ieMask;
+} POSTPACK WMI_BSS_INFO_HDR;
+
+/*
+ * BSS INFO HDR version 2.0
+ * With 6 bytes HTC header and 6 bytes of WMI header
+ * WMI_BSS_INFO_HDR cannot be accomodated in the removed 802.11 management
+ * header space.
+ * - Reduce the ieMask to 2 bytes as only two bit flags are used
+ * - Remove rssi and compute it on the host. rssi = snr - 95
+ */
+typedef PREPACK struct {
+ A_UINT16 channel;
+ A_UINT8 frameType; /* see WMI_BI_FTYPE */
+ A_UINT8 snr;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT16 ieMask;
+} POSTPACK WMI_BSS_INFO_HDR2;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 pin[8];
+} POSTPACK WMI_WPS_PIN_INFO;
+
+typedef PREPACK struct {
+ PREPACK union {
+ A_UINT8 ie[17];
+ A_INT32 wac_status;
+ } POSTPACK info;
+} POSTPACK WMI_GET_WAC_INFO;
+
+#define IEEE80211_NWID_LEN 32
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 ssid[IEEE80211_NWID_LEN];
+ A_UINT8 ssid_len;
+ A_UINT8 channel;
+ A_UINT8 snr;
+ A_UINT8 id;
+ A_UINT8 device_type;
+ A_UINT8 antenna_type;
+ A_INT8 threshold_offset1; /* offset for AP Tx power */
+ A_INT8 threshold_offset2; /* offset for antenna gain */
+} POSTPACK WMI_WAC_BSS_INFO_REPORT;
+
+/*
+ * Command Error Event
+ */
+typedef enum {
+ INVALID_PARAM = 0x01,
+ ILLEGAL_STATE = 0x02,
+ INTERNAL_ERROR = 0x03,
+ DFS_CHANNEL = 0x05,
+} WMI_ERROR_CODE;
+
+typedef PREPACK struct {
+ A_UINT16 commandId;
+ A_UINT8 errorCode;
+} POSTPACK WMI_CMD_ERROR_EVENT;
+
+/*
+ * New Regulatory Domain Event
+ */
+typedef PREPACK struct {
+ A_UINT32 regDomain;
+} POSTPACK WMI_REG_DOMAIN_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficDirection;
+ A_UINT8 trafficClass;
+} POSTPACK WMI_PSTREAM_TIMEOUT_EVENT;
+
+/*
+ * The WMI_NEIGHBOR_REPORT Event is generated by the target to inform
+ * the host of BSS's it has found that matches the current profile.
+ * It can be used by the host to cache PMKs and/to initiate pre-authentication
+ * if the BSS supports it. The first bssid is always the current associated
+ * BSS.
+ * The bssid and bssFlags information repeats according to the number
+ * or APs reported.
+ */
+typedef enum {
+ WMI_DEFAULT_BSS_FLAGS = 0x00,
+ WMI_PREAUTH_CAPABLE_BSS = 0x01,
+ WMI_PMKID_VALID_BSS = 0x02,
+} WMI_BSS_FLAGS;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 bssFlags; /* see WMI_BSS_FLAGS */
+} POSTPACK WMI_NEIGHBOR_INFO;
+
+typedef PREPACK struct {
+ A_INT8 numberOfAps;
+ WMI_NEIGHBOR_INFO neighbor[1];
+} POSTPACK WMI_NEIGHBOR_REPORT_EVENT;
+
+/*
+ * TKIP MIC Error Event
+ */
+typedef PREPACK struct {
+ A_UINT8 keyid;
+ A_UINT8 ismcast;
+} POSTPACK WMI_TKIP_MICERR_EVENT;
+
+/*
+ * WMI_SCAN_COMPLETE_EVENTID - no parameters (old), staus parameter (new)
+ */
+typedef PREPACK struct {
+ A_INT32 status;
+} POSTPACK WMI_SCAN_COMPLETE_EVENT;
+
+typedef PREPACK struct {
+ A_INT32 rm_type;
+ A_INT32 status;
+} POSTPACK WMI_CCX_RM_STATUS_EVENT;
+
+#define MAX_OPT_DATA_LEN 1400
+
+/*
+ * WMI_SET_ADHOC_BSSID_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+} POSTPACK WMI_SET_ADHOC_BSSID_CMD;
+
+/*
+ * Special frame receive Event.
+ * Mechanism used to inform host of the receiption of the special frames.
+ * Consists of special frame info header followed by special frame body.
+ * The 802.11 header is not included.
+ */
+typedef PREPACK struct {
+ A_UINT16 channel;
+ A_UINT8 frameType; /* see WMI_OPT_FTYPE */
+ A_INT8 snr;
+ A_UINT8 srcAddr[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+} POSTPACK WMI_OPT_RX_INFO_HDR;
+
+/*
+ * Reporting statistics.
+ */
+typedef PREPACK struct {
+ A_UINT32 tx_packets;
+ A_UINT32 tx_bytes;
+ A_UINT32 tx_unicast_pkts;
+ A_UINT32 tx_unicast_bytes;
+ A_UINT32 tx_multicast_pkts;
+ A_UINT32 tx_multicast_bytes;
+ A_UINT32 tx_broadcast_pkts;
+ A_UINT32 tx_broadcast_bytes;
+ A_UINT32 tx_rts_success_cnt;
+ A_UINT32 tx_packet_per_ac[4];
+ A_UINT32 tx_errors_per_ac[4];
+
+ A_UINT32 tx_errors;
+ A_UINT32 tx_failed_cnt;
+ A_UINT32 tx_retry_cnt;
+ A_UINT32 tx_mult_retry_cnt;
+ A_UINT32 tx_rts_fail_cnt;
+ A_INT32 tx_unicast_rate;
+}POSTPACK tx_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 rx_packets;
+ A_UINT32 rx_bytes;
+ A_UINT32 rx_unicast_pkts;
+ A_UINT32 rx_unicast_bytes;
+ A_UINT32 rx_multicast_pkts;
+ A_UINT32 rx_multicast_bytes;
+ A_UINT32 rx_broadcast_pkts;
+ A_UINT32 rx_broadcast_bytes;
+ A_UINT32 rx_fragment_pkt;
+
+ A_UINT32 rx_errors;
+ A_UINT32 rx_crcerr;
+ A_UINT32 rx_key_cache_miss;
+ A_UINT32 rx_decrypt_err;
+ A_UINT32 rx_duplicate_frames;
+ A_INT32 rx_unicast_rate;
+}POSTPACK rx_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 tkip_local_mic_failure;
+ A_UINT32 tkip_counter_measures_invoked;
+ A_UINT32 tkip_replays;
+ A_UINT32 tkip_format_errors;
+ A_UINT32 ccmp_format_errors;
+ A_UINT32 ccmp_replays;
+}POSTPACK tkip_ccmp_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 power_save_failure_cnt;
+ A_UINT16 stop_tx_failure_cnt;
+ A_UINT16 atim_tx_failure_cnt;
+ A_UINT16 atim_rx_failure_cnt;
+ A_UINT16 bcn_rx_failure_cnt;
+}POSTPACK pm_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 cs_bmiss_cnt;
+ A_UINT32 cs_lowRssi_cnt;
+ A_UINT16 cs_connect_cnt;
+ A_UINT16 cs_disconnect_cnt;
+ A_INT16 cs_aveBeacon_rssi;
+ A_UINT16 cs_roam_count;
+ A_INT16 cs_rssi;
+ A_UINT8 cs_snr;
+ A_UINT8 cs_aveBeacon_snr;
+ A_UINT8 cs_lastRoam_msec;
+} POSTPACK cserv_stats_t;
+
+typedef PREPACK struct {
+ tx_stats_t tx_stats;
+ rx_stats_t rx_stats;
+ tkip_ccmp_stats_t tkipCcmpStats;
+}POSTPACK wlan_net_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 arp_received;
+ A_UINT32 arp_matched;
+ A_UINT32 arp_replied;
+} POSTPACK arp_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 wow_num_pkts_dropped;
+ A_UINT16 wow_num_events_discarded;
+ A_UINT8 wow_num_host_pkt_wakeups;
+ A_UINT8 wow_num_host_event_wakeups;
+} POSTPACK wlan_wow_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 lqVal;
+ A_INT32 noise_floor_calibation;
+ pm_stats_t pmStats;
+ wlan_net_stats_t txrxStats;
+ wlan_wow_stats_t wowStats;
+ arp_stats_t arpStats;
+ cserv_stats_t cservStats;
+} POSTPACK WMI_TARGET_STATS;
+
+/*
+ * WMI_RSSI_THRESHOLD_EVENTID.
+ * Indicate the RSSI events to host. Events are indicated when we breach a
+ * thresold value.
+ */
+typedef enum{
+ WMI_RSSI_THRESHOLD1_ABOVE = 0,
+ WMI_RSSI_THRESHOLD2_ABOVE,
+ WMI_RSSI_THRESHOLD3_ABOVE,
+ WMI_RSSI_THRESHOLD4_ABOVE,
+ WMI_RSSI_THRESHOLD5_ABOVE,
+ WMI_RSSI_THRESHOLD6_ABOVE,
+ WMI_RSSI_THRESHOLD1_BELOW,
+ WMI_RSSI_THRESHOLD2_BELOW,
+ WMI_RSSI_THRESHOLD3_BELOW,
+ WMI_RSSI_THRESHOLD4_BELOW,
+ WMI_RSSI_THRESHOLD5_BELOW,
+ WMI_RSSI_THRESHOLD6_BELOW
+}WMI_RSSI_THRESHOLD_VAL;
+
+typedef PREPACK struct {
+ A_INT16 rssi;
+ A_UINT8 range;
+}POSTPACK WMI_RSSI_THRESHOLD_EVENT;
+
+/*
+ * WMI_ERROR_REPORT_EVENTID
+ */
+typedef enum{
+ WMI_TARGET_PM_ERR_FAIL = 0x00000001,
+ WMI_TARGET_KEY_NOT_FOUND = 0x00000002,
+ WMI_TARGET_DECRYPTION_ERR = 0x00000004,
+ WMI_TARGET_BMISS = 0x00000008,
+ WMI_PSDISABLE_NODE_JOIN = 0x00000010,
+ WMI_TARGET_COM_ERR = 0x00000020,
+ WMI_TARGET_FATAL_ERR = 0x00000040,
+ WMI_TARGET_BCN_FOUND = 0x00000080
+} WMI_TARGET_ERROR_VAL;
+
+typedef PREPACK struct {
+ A_UINT32 errorVal;
+}POSTPACK WMI_TARGET_ERROR_REPORT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 retrys;
+}POSTPACK WMI_TX_RETRY_ERR_EVENT;
+
+typedef enum{
+ WMI_SNR_THRESHOLD1_ABOVE = 1,
+ WMI_SNR_THRESHOLD1_BELOW,
+ WMI_SNR_THRESHOLD2_ABOVE,
+ WMI_SNR_THRESHOLD2_BELOW,
+ WMI_SNR_THRESHOLD3_ABOVE,
+ WMI_SNR_THRESHOLD3_BELOW,
+ WMI_SNR_THRESHOLD4_ABOVE,
+ WMI_SNR_THRESHOLD4_BELOW
+} WMI_SNR_THRESHOLD_VAL;
+
+typedef PREPACK struct {
+ A_UINT8 range; /* WMI_SNR_THRESHOLD_VAL */
+ A_UINT8 snr;
+}POSTPACK WMI_SNR_THRESHOLD_EVENT;
+
+typedef enum{
+ WMI_LQ_THRESHOLD1_ABOVE = 1,
+ WMI_LQ_THRESHOLD1_BELOW,
+ WMI_LQ_THRESHOLD2_ABOVE,
+ WMI_LQ_THRESHOLD2_BELOW,
+ WMI_LQ_THRESHOLD3_ABOVE,
+ WMI_LQ_THRESHOLD3_BELOW,
+ WMI_LQ_THRESHOLD4_ABOVE,
+ WMI_LQ_THRESHOLD4_BELOW
+} WMI_LQ_THRESHOLD_VAL;
+
+typedef PREPACK struct {
+ A_INT32 lq;
+ A_UINT8 range; /* WMI_LQ_THRESHOLD_VAL */
+}POSTPACK WMI_LQ_THRESHOLD_EVENT;
+/*
+ * WMI_REPORT_ROAM_TBL_EVENTID
+ */
+#define MAX_ROAM_TBL_CAND 5
+
+typedef PREPACK struct {
+ A_INT32 roam_util;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_INT8 rssi;
+ A_INT8 rssidt;
+ A_INT8 last_rssi;
+ A_INT8 util;
+ A_INT8 bias;
+ A_UINT8 reserved; /* For alignment */
+} POSTPACK WMI_BSS_ROAM_INFO;
+
+
+typedef PREPACK struct {
+ A_UINT16 roamMode;
+ A_UINT16 numEntries;
+ WMI_BSS_ROAM_INFO bssRoamInfo[1];
+} POSTPACK WMI_TARGET_ROAM_TBL;
+
+/*
+ * WMI_HCI_EVENT_EVENTID
+ */
+typedef PREPACK struct {
+ A_UINT16 evt_buf_sz; /* HCI event buffer size */
+ A_UINT8 buf[1]; /* HCI event */
+} POSTPACK WMI_HCI_EVENT;
+
+/*
+ * WMI_CAC_EVENTID
+ */
+typedef enum {
+ CAC_INDICATION_ADMISSION = 0x00,
+ CAC_INDICATION_ADMISSION_RESP = 0x01,
+ CAC_INDICATION_DELETE = 0x02,
+ CAC_INDICATION_NO_RESP = 0x03,
+}CAC_INDICATION;
+
+#define WMM_TSPEC_IE_LEN 63
+
+typedef PREPACK struct {
+ A_UINT8 ac;
+ A_UINT8 cac_indication;
+ A_UINT8 statusCode;
+ A_UINT8 tspecSuggestion[WMM_TSPEC_IE_LEN];
+}POSTPACK WMI_CAC_EVENT;
+
+/*
+ * WMI_APLIST_EVENTID
+ */
+
+typedef enum {
+ APLIST_VER1 = 1,
+} APLIST_VER;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT16 channel;
+} POSTPACK WMI_AP_INFO_V1;
+
+typedef PREPACK union {
+ WMI_AP_INFO_V1 apInfoV1;
+} POSTPACK WMI_AP_INFO;
+
+typedef PREPACK struct {
+ A_UINT8 apListVer;
+ A_UINT8 numAP;
+ WMI_AP_INFO apList[1];
+} POSTPACK WMI_APLIST_EVENT;
+
+/*
+ * developer commands
+ */
+
+/*
+ * WMI_SET_BITRATE_CMDID
+ *
+ * Get bit rate cmd uses same definition as set bit rate cmd
+ *
+ */
+typedef enum {
+ RATE_AUTO = -1,
+ AR6003_RATE_1Mb = 0,
+ AR6003_RATE_2Mb = 1,
+ AR6003_RATE_5_5Mb = 2,
+ AR6003_RATE_11Mb = 3,
+ AR6003_RATE_6Mb = 4,
+ AR6003_RATE_9Mb = 5,
+ AR6003_RATE_12Mb = 6,
+ AR6003_RATE_18Mb = 7,
+ AR6003_RATE_24Mb = 8,
+ AR6003_RATE_36Mb = 9,
+ AR6003_RATE_48Mb = 10,
+ AR6003_RATE_54Mb = 11,
+ AR6003_RATE_MCS_0_20 = 12,
+ AR6003_RATE_MCS_1_20 = 13,
+ AR6003_RATE_MCS_2_20 = 14,
+ AR6003_RATE_MCS_3_20 = 15,
+ AR6003_RATE_MCS_4_20 = 16,
+ AR6003_RATE_MCS_5_20 = 17,
+ AR6003_RATE_MCS_6_20 = 18,
+ AR6003_RATE_MCS_7_20 = 19,
+ AR6003_RATE_MCS_0_40 = 20,
+ AR6003_RATE_MCS_1_40 = 21,
+ AR6003_RATE_MCS_2_40 = 22,
+ AR6003_RATE_MCS_3_40 = 23,
+ AR6003_RATE_MCS_4_40 = 24,
+ AR6003_RATE_MCS_5_40 = 25,
+ AR6003_RATE_MCS_6_40 = 26,
+ AR6003_RATE_MCS_7_40 = 27,
+ AR6003_RATE_MAX,
+
+ AR6004_RATE_1Mb = 0,
+ AR6004_RATE_2Mb = 1,
+ AR6004_RATE_5_5Mb = 2,
+ AR6004_RATE_11Mb = 3,
+ AR6004_RATE_6Mb = 4,
+ AR6004_RATE_9Mb = 5,
+ AR6004_RATE_12Mb = 6,
+ AR6004_RATE_18Mb = 7,
+ AR6004_RATE_24Mb = 8,
+ AR6004_RATE_36Mb = 9,
+ AR6004_RATE_48Mb = 10,
+ AR6004_RATE_54Mb = 11,
+ AR6004_RATE_MCS_0_20 = 12,
+ AR6004_RATE_MCS_1_20 = 13,
+ AR6004_RATE_MCS_2_20 = 14,
+ AR6004_RATE_MCS_3_20 = 15,
+ AR6004_RATE_MCS_4_20 = 16,
+ AR6004_RATE_MCS_5_20 = 17,
+ AR6004_RATE_MCS_6_20 = 18,
+ AR6004_RATE_MCS_7_20 = 19,
+ AR6004_RATE_MCS_8_20 = 20,
+ AR6004_RATE_MCS_9_20 = 21,
+ AR6004_RATE_MCS_10_20 = 22,
+ AR6004_RATE_MCS_11_20 = 23,
+ AR6004_RATE_MCS_12_20 = 24,
+ AR6004_RATE_MCS_13_20 = 25,
+ AR6004_RATE_MCS_14_20 = 26,
+ AR6004_RATE_MCS_15_20 = 27,
+ AR6004_RATE_MCS_0_40 = 28,
+ AR6004_RATE_MCS_1_40 = 29,
+ AR6004_RATE_MCS_2_40 = 30,
+ AR6004_RATE_MCS_3_40 = 31,
+ AR6004_RATE_MCS_4_40 = 32,
+ AR6004_RATE_MCS_5_40 = 33,
+ AR6004_RATE_MCS_6_40 = 34,
+ AR6004_RATE_MCS_7_40 = 35,
+ AR6004_RATE_MCS_8_40 = 36,
+ AR6004_RATE_MCS_9_40 = 37,
+ AR6004_RATE_MCS_10_40 = 38,
+ AR6004_RATE_MCS_11_40 = 39,
+ AR6004_RATE_MCS_12_40 = 40,
+ AR6004_RATE_MCS_13_40 = 41,
+ AR6004_RATE_MCS_14_40 = 42,
+ AR6004_RATE_MCS_15_40 = 43,
+ AR6004_RATE_MAX,
+} WMI_BIT_RATE;
+
+typedef PREPACK struct {
+ A_INT8 rateIndex; /* see WMI_BIT_RATE */
+ A_INT8 mgmtRateIndex;
+ A_INT8 ctlRateIndex;
+} POSTPACK WMI_BIT_RATE_CMD;
+
+
+typedef PREPACK struct {
+ A_INT8 rateIndex; /* see WMI_BIT_RATE */
+} POSTPACK WMI_BIT_RATE_REPLY;
+
+
+/*
+ * WMI_SET_FIXRATES_CMDID
+ *
+ * Get fix rates cmd uses same definition as set fix rates cmd
+ * Fix rate mask is now 64 bit, which is split across two words.
+ * Refer WMI_BIT_RATE for bit position for each rate.
+ */
+#define FIX_RATE_1Mb ((A_UINT32)0x1)
+#define FIX_RATE_2Mb ((A_UINT32)0x2)
+#define FIX_RATE_5_5Mb ((A_UINT32)0x4)
+#define FIX_RATE_11Mb ((A_UINT32)0x8)
+#define FIX_RATE_6Mb ((A_UINT32)0x10)
+#define FIX_RATE_9Mb ((A_UINT32)0x20)
+#define FIX_RATE_12Mb ((A_UINT32)0x40)
+#define FIX_RATE_18Mb ((A_UINT32)0x80)
+#define FIX_RATE_24Mb ((A_UINT32)0x100)
+#define FIX_RATE_36Mb ((A_UINT32)0x200)
+#define FIX_RATE_48Mb ((A_UINT32)0x400)
+#define FIX_RATE_54Mb ((A_UINT32)0x800)
+
+typedef PREPACK struct {
+ A_UINT32 fixRateMask[WMI_MAX_RATE_MASK]; /* see WMI_BIT_RATE */
+} POSTPACK WMI_FIX_RATES_CMD, WMI_FIX_RATES_REPLY;
+
+typedef PREPACK struct {
+ A_UINT8 bEnableMask;
+ A_UINT8 frameType; /* type and subtype */
+ A_UINT8 reserved[2]; /* for alignment */
+ A_UINT32 frameRateMask[WMI_MAX_RATE_MASK]; /* see WMI_BIT_RATE */
+} POSTPACK WMI_FRAME_RATES_CMD, WMI_FRAME_RATES_REPLY;
+
+/*
+ * WMI_SET_RECONNECT_AUTH_MODE_CMDID
+ *
+ * Set authentication mode
+ */
+typedef enum {
+ RECONN_DO_AUTH = 0x00,
+ RECONN_NOT_AUTH = 0x01
+} WMI_AUTH_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 mode;
+} POSTPACK WMI_SET_AUTH_MODE_CMD;
+
+/*
+ * WMI_SET_REASSOC_MODE_CMDID
+ *
+ * Set authentication mode
+ */
+typedef enum {
+ REASSOC_DO_DISASSOC = 0x00,
+ REASSOC_DONOT_DISASSOC = 0x01
+} WMI_REASSOC_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 mode;
+}POSTPACK WMI_SET_REASSOC_MODE_CMD;
+
+typedef enum {
+ ROAM_DATA_TIME = 1, /* Get The Roam Time Data */
+} ROAM_DATA_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 disassoc_time;
+ A_UINT32 no_txrx_time;
+ A_UINT32 assoc_time;
+ A_UINT32 allow_txrx_time;
+ A_UINT8 disassoc_bssid[ATH_MAC_LEN];
+ A_INT8 disassoc_bss_rssi;
+ A_UINT8 assoc_bssid[ATH_MAC_LEN];
+ A_INT8 assoc_bss_rssi;
+} POSTPACK WMI_TARGET_ROAM_TIME;
+
+typedef PREPACK struct {
+ PREPACK union {
+ WMI_TARGET_ROAM_TIME roamTime;
+ } POSTPACK u;
+ A_UINT8 roamDataType ;
+} POSTPACK WMI_TARGET_ROAM_DATA;
+
+typedef enum {
+ WMI_WMM_DISABLED = 0,
+ WMI_WMM_ENABLED
+} WMI_WMM_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+}POSTPACK WMI_SET_WMM_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+}POSTPACK WMI_SET_QOS_SUPP_CMD;
+
+typedef enum {
+ WMI_TXOP_DISABLED = 0,
+ WMI_TXOP_ENABLED
+} WMI_TXOP_CFG;
+
+typedef PREPACK struct {
+ A_UINT8 txopEnable;
+}POSTPACK WMI_SET_WMM_TXOP_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 keepaliveInterval;
+} POSTPACK WMI_SET_KEEPALIVE_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 keepaliveInterval;
+ A_UINT8 keepaliveMode;
+ A_UINT8 reserved[2];
+ A_UINT32 keepalive_arp_srcip;
+ A_UINT32 keepalive_arp_tgtip;
+ A_UINT8 peer_mac_address[6];
+} POSTPACK WMI_SET_KEEPALIVE_CMD_EXT;
+
+
+typedef PREPACK struct {
+ A_BOOL configured;
+ A_UINT8 keepaliveInterval;
+} POSTPACK WMI_GET_KEEPALIVE_CMD;
+
+/*
+ * Add Application specified IE to a management frame
+ */
+#define WMI_MAX_IE_LEN 255
+
+typedef PREPACK struct {
+ A_UINT8 mgmtFrmType; /* one of WMI_MGMT_FRAME_TYPE */
+ A_UINT8 ieLen; /* Length of the IE that should be added to the MGMT frame */
+ A_UINT8 ieInfo[1];
+} POSTPACK WMI_SET_APPIE_CMD;
+
+/*
+ * Notify the WSC registration status to the target
+ */
+#define WSC_REG_ACTIVE 1
+#define WSC_REG_INACTIVE 0
+/* Generic Hal Interface for setting hal paramters. */
+/* Add new Set HAL Param cmdIds here for newer params */
+typedef enum {
+ WHAL_SETCABTO_CMDID = 1,
+}WHAL_CMDID;
+
+typedef PREPACK struct {
+ A_UINT8 cabTimeOut;
+} POSTPACK WHAL_SETCABTO_PARAM;
+
+typedef PREPACK struct {
+ A_UINT8 whalCmdId;
+ A_UINT8 data[1];
+} POSTPACK WHAL_PARAMCMD;
+
+
+#define WOW_MAX_FILTER_LISTS 1 /*4*/
+#define WOW_MAX_FILTERS_PER_LIST 4
+#define WOW_PATTERN_SIZE 64
+#define WOW_MASK_SIZE 64
+
+#define MAC_MAX_FILTERS_PER_LIST 7
+
+typedef PREPACK struct {
+ A_UINT8 wow_valid_filter;
+ A_UINT8 wow_filter_id;
+ A_UINT8 wow_filter_size;
+ A_UINT8 wow_filter_offset;
+ A_UINT8 wow_filter_mask[WOW_MASK_SIZE];
+ A_UINT8 wow_filter_pattern[WOW_PATTERN_SIZE];
+} POSTPACK WOW_FILTER;
+
+
+typedef PREPACK struct {
+ A_UINT8 wow_valid_list;
+ A_UINT8 wow_list_id;
+ A_UINT8 wow_num_filters;
+ A_UINT8 wow_total_list_size;
+ WOW_FILTER list[WOW_MAX_FILTERS_PER_LIST];
+} POSTPACK WOW_FILTER_LIST;
+
+typedef PREPACK struct {
+ A_UINT8 valid_filter;
+ A_UINT8 mac_addr[ATH_MAC_LEN];
+} POSTPACK MAC_FILTER;
+
+
+typedef PREPACK struct {
+ A_UINT8 total_list_size;
+ A_UINT8 enable;
+ MAC_FILTER list[MAC_MAX_FILTERS_PER_LIST];
+} POSTPACK MAC_FILTER_LIST;
+
+#define MAX_IP_ADDRS 2
+typedef PREPACK struct {
+ A_UINT32 ips[MAX_IP_ADDRS]; /* IP in Network Byte Order */
+} POSTPACK WMI_SET_IP_CMD;
+
+typedef PREPACK struct {
+ A_BOOL awake;
+ A_BOOL asleep;
+} POSTPACK WMI_SET_HOST_SLEEP_MODE_CMD;
+
+typedef A_UINT32 WMI_WOW_FILTER;
+
+ /* bit positions for filter options */
+#define WOW_FILTER_UNUSED 0
+#define WOW_FILTER_SSID 1 /* wake up on probed SSID (legacy definition) */
+ /* the following filter options are available if the WOW extensions are installed in the target
+ * otherwise the feature setting has no effect */
+
+#define WOW_FILTER_OPTION_MASK(option) (1 << (option))
+#define WOW_FILTER_OPTION_MAGIC_PACKET WOW_FILTER_OPTION_MASK(2)
+#define WOW_FILTER_OPTION_EAP_REQ WOW_FILTER_OPTION_MASK(3)
+#define WOW_FILTER_OPTION_PATTERNS WOW_FILTER_OPTION_MASK(4)
+#define WOW_FILTER_OPTION_OFFLOAD_ARP WOW_FILTER_OPTION_MASK(5)
+#define WOW_FILTER_OPTION_OFFLOAD_NS WOW_FILTER_OPTION_MASK(6)
+#define WOW_FILTER_OPTION_OFFLOAD_GTK WOW_FILTER_OPTION_MASK(7)
+#define WOW_FILTER_OPTION_8021X_4WAYHS WOW_FILTER_OPTION_MASK(8)
+#define WOW_FILTER_OPTION_NLO_DISCVRY WOW_FILTER_OPTION_MASK(9)
+#define WOW_FILTER_OPTION_NWK_DISASSOC WOW_FILTER_OPTION_MASK(10)
+#define WOW_FILTER_OPTION_GTK_ERROR WOW_FILTER_OPTION_MASK(11)
+
+#define WOW_FILTER_OPTION_TEST_MODE WOW_FILTER_OPTION_MASK(15)
+
+
+typedef PREPACK struct {
+ A_BOOL enable_wow;
+ WMI_WOW_FILTER filter;
+ A_UINT16 hostReqDelay;
+} POSTPACK WMI_SET_WOW_MODE_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 filter_list_id;
+} POSTPACK WMI_GET_WOW_LIST_CMD;
+
+/*
+ * WMI_GET_WOW_LIST_CMD reply
+ */
+typedef PREPACK struct {
+ A_UINT8 num_filters; /* number of patterns in reply */
+ A_UINT8 this_filter_num; /* this is filter # x of total num_filters */
+ A_UINT8 wow_mode;
+ A_UINT8 host_mode;
+ WOW_FILTER wow_filters[1];
+} POSTPACK WMI_GET_WOW_LIST_REPLY;
+
+typedef PREPACK struct {
+ A_UINT8 filter_list_id;
+ A_UINT8 filter_size;
+ A_UINT8 filter_offset;
+ A_UINT8 filter[1];
+} POSTPACK WMI_ADD_WOW_PATTERN_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 filter_list_id;
+ A_UINT16 filter_id;
+} POSTPACK WMI_DEL_WOW_PATTERN_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 macaddr[ATH_MAC_LEN];
+} POSTPACK WMI_SET_MAC_ADDRESS_CMD;
+
+/* WMI_SET_TXE_NOTIFY_CMDID */
+typedef PREPACK struct {
+ A_UINT32 rate;
+ A_UINT32 pkts;
+ A_UINT32 intvl;
+} POSTPACK WMI_SET_TXE_NOTIFY_CMD;
+
+
+/*
+ * WMI_SET_AKMP_PARAMS_CMD
+ */
+
+#define WMI_AKMP_MULTI_PMKID_EN 0x000001
+
+typedef PREPACK struct {
+ A_UINT32 akmpInfo;
+} POSTPACK WMI_SET_AKMP_PARAMS_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 pmkid[WMI_PMKID_LEN];
+} POSTPACK WMI_PMKID;
+
+/*
+ * WMI_SET_PMKID_LIST_CMD
+ */
+#define WMI_MAX_PMKID_CACHE 8
+
+typedef PREPACK struct {
+ A_UINT32 numPMKID;
+ WMI_PMKID pmkidList[WMI_MAX_PMKID_CACHE];
+} POSTPACK WMI_SET_PMKID_LIST_CMD;
+
+/*
+ * WMI_GET_PMKID_LIST_CMD Reply
+ * Following the Number of PMKIDs is the list of PMKIDs
+ */
+typedef PREPACK struct {
+ A_UINT32 numPMKID;
+ A_UINT8 bssidList[ATH_MAC_LEN][1];
+ WMI_PMKID pmkidList[1];
+} POSTPACK WMI_PMKID_LIST_REPLY;
+
+typedef PREPACK struct {
+ A_UINT16 oldChannel;
+ A_UINT32 newChannel;
+} POSTPACK WMI_CHANNEL_CHANGE_EVENT;
+
+typedef PREPACK struct {
+ A_UINT32 version;
+} POSTPACK WMI_WLAN_VERSION_EVENT;
+
+
+/* WMI_ADDBA_REQ_EVENTID */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 win_sz;
+ A_UINT16 st_seq_no;
+ A_UINT8 status; /* f/w response for ADDBA Req; OK(0) or failure(!=0) */
+} POSTPACK WMI_ADDBA_REQ_EVENT;
+
+/* WMI_ADDBA_RESP_EVENTID */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 status; /* OK(0), failure (!=0) */
+ A_UINT16 amsdu_sz; /* Three values: Not supported(0), 3839, 8k */
+} POSTPACK WMI_ADDBA_RESP_EVENT;
+
+/* WMI_DELBA_EVENTID
+ * f/w received a DELBA for peer and processed it.
+ * Host is notified of this
+ */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 is_peer_initiator;
+ A_UINT16 reason_code;
+} POSTPACK WMI_DELBA_EVENT;
+
+
+#ifdef WAPI_ENABLE
+#define WAPI_REKEY_UCAST 1
+#define WAPI_REKEY_MCAST 2
+typedef PREPACK struct {
+ A_UINT8 type;
+ A_UINT8 macAddr[ATH_MAC_LEN];
+} POSTPACK WMI_WAPIREKEY_EVENT;
+#endif
+
+
+/* WMI_ALLOW_AGGR_CMDID
+ * Configures tid's to allow ADDBA negotiations
+ * on each tid, in each direction
+ */
+typedef PREPACK struct {
+ A_UINT16 tx_allow_aggr; /* 16-bit mask to allow uplink ADDBA negotiation - bit position indicates tid*/
+ A_UINT16 rx_allow_aggr; /* 16-bit mask to allow donwlink ADDBA negotiation - bit position indicates tid*/
+} POSTPACK WMI_ALLOW_AGGR_CMD;
+
+/* WMI_ADDBA_REQ_CMDID
+ * f/w starts performing ADDBA negotiations with peer
+ * on the given tid
+ */
+typedef PREPACK struct {
+ A_UINT8 tid;
+} POSTPACK WMI_ADDBA_REQ_CMD;
+
+/* WMI_DELBA_REQ_CMDID
+ * f/w would teardown BA with peer.
+ * is_send_initiator indicates if it's or tx or rx side
+ */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 is_sender_initiator;
+
+} POSTPACK WMI_DELBA_REQ_CMD;
+
+#define PEER_NODE_JOIN_EVENT 0x00
+#define PEER_NODE_LEAVE_EVENT 0x01
+#define PEER_FIRST_NODE_JOIN_EVENT 0x10
+#define PEER_LAST_NODE_LEAVE_EVENT 0x11
+typedef PREPACK struct {
+ A_UINT8 eventCode;
+ A_UINT8 peerMacAddr[ATH_MAC_LEN];
+} POSTPACK WMI_PEER_NODE_EVENT;
+
+#define IEEE80211_FRAME_TYPE_MGT 0x00
+#define IEEE80211_FRAME_TYPE_CTL 0x04
+
+typedef PREPACK struct {
+ A_UINT32 rules; /* combination of WMI_WRT_... values */
+} POSTPACK WMI_CONFIG_TX_MAC_RULES_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 enable; /* 1 == device operates in promiscuous mode , 0 == normal mode <default> */
+} POSTPACK WMI_SET_PROMISCUOUS_MODE_CMD;
+
+
+/*RFKILL Related Data Structures*/
+typedef enum {
+ RADIO_STATE_OFF = 0x1,
+ RADIO_STATE_ON = 0x2,
+ RADIO_STATE_INVALID = 0xFF
+}RFKILL_RADIO_STATE;
+
+typedef PREPACK struct {
+ A_UINT8 GPIOPinNumber;
+ A_UINT8 IntrType;
+ A_UINT8 RadioState;
+} POSTPACK WMI_RFKILL_MODE_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 FastScanInterval;
+ A_UINT32 FastScanDuration;
+ A_UINT32 SlowScanInterval;
+ A_UINT8 ScanType; //ActiveUseSSID=0, ActiveUseWildCard=1, PassiveScan=2
+ A_UINT8 bStartNetworkListOffload; //TRUE - Use the Probed SSID
+}POSTPACK WMI_NETWORK_LIST_OFFLOAD_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 bProfileMatch;
+ A_UINT8 Index;
+ A_UINT32 nFastScansRemaining;
+}POSTPACK WMI_NETWORK_LIST_OFFLOAD_INFO;
+
+typedef PREPACK struct _WMI_IPV6_ADDR {
+ A_UINT8 address[16]; /* IPV6 in Network Byte Order */
+} POSTPACK WMI_IPV6_ADDR;
+
+#define WMI_MAX_NS_OFFLOADS 2
+#define WMI_MAX_ARP_OFFLOADS 2
+
+#define WMI_ARPOFF_FLAGS_VALID (1 << 0) /* the tuple entry is valid */
+#define WMI_ARPOFF_FLAGS_MAC_VALID (1 << 1) /* the target mac address is valid */
+#define WMI_ARPOFF_FLAGS_REMOTE_IP_VALID (1 << 2) /* remote IP field is valid */
+
+typedef PREPACK struct {
+ A_UINT8 flags; /* flags */
+ A_UINT8 target_ipaddr[4]; /* IPV4 addresses of the local node*/
+ A_UINT8 remote_ipaddr[4]; /* source address of the remote node requesting the ARP (qualifier) */
+ A_UINT8 target_mac[ATH_MAC_LEN]; /* mac address for this tuple, if not valid, the local MAC is used */
+} POSTPACK WMI_ARP_OFFLOAD_TUPLE;
+
+#define WMI_NSOFF_FLAGS_VALID (1 << 0) /* the tuple entry is valid */
+#define WMI_NSOFF_FLAGS_MAC_VALID (1 << 1) /* the target mac address is valid */
+#define WMI_NSOFF_FLAGS_REMOTE_IP_VALID (1 << 2) /* remote IP field is valid */
+
+#define WMI_NSOFF_MAX_TARGET_IPS 2
+
+typedef PREPACK struct {
+ A_UINT8 flags; /* flags */
+ WMI_IPV6_ADDR target_ipaddr[WMI_NSOFF_MAX_TARGET_IPS]; /* IPV6 target addresses of the local node */
+ WMI_IPV6_ADDR solicitation_ipaddr; /* multi-cast source IP addresses for receiving solicitations */
+ WMI_IPV6_ADDR remote_ipaddr; /* address of remote node requesting the solicitation (qualifier) */
+ A_UINT8 target_mac[ATH_MAC_LEN]; /* mac address for this tuple, if not valid, the local MAC is used */
+} POSTPACK WMI_NS_OFFLOAD_TUPLE;
+
+typedef PREPACK struct {
+ A_UINT32 flags;
+ WMI_NS_OFFLOAD_TUPLE ns_tuples[WMI_MAX_NS_OFFLOADS];
+ WMI_ARP_OFFLOAD_TUPLE arp_tuples[WMI_MAX_ARP_OFFLOADS];
+} POSTPACK WMI_SET_ARP_NS_OFFLOAD_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 filter_list_id;
+ A_UINT8 filter_id;
+ A_UINT16 filter_size;
+ A_UINT8 filter_offset;
+ A_UINT8 filter[1];
+} POSTPACK WMI_ADD_WOW_EXT_PATTERN_CMD;
+
+ /* WOW extension for larger filter patterns, note these settings are only
+ * valid if the WOW extension is installed in the target
+ * When using the WOW extensions, the use of WMI_GET_WOW_LIST_REPLY will return an empty
+ * WOW_FILTER structure. In WOW extended mode, the host is expected to track what filters
+ * are installed in the target. */
+#define WOW_EXT_DEF_FILTER_LISTS 1
+#define WOW_EXT_DEF_FILTERS_PER_LIST 16
+#define WOW_EXT_DEF_PATTERN_SIZE 136 /* typical pattern size (128 byte DIX + SNAPLLC) */
+#define WOW_EXT_FILTER_ID_CLEAR_ALL 0xFFFF /* use this ID in WMI_DEL_WOW_PATTERN, to clear all patterns */
+
+#define WOW_EXT_MAX_PATTERN_LEN_SIZE 2040 /* absolute max limit on pattern */
+
+ /* compute mask size based on pattern size */
+#define WOW_EXT_COMPUTE_MASK_SIZE(msize,psize) \
+{ \
+ *(msize) = ((A_UINT32)psize)/8; \
+ if (((A_UINT32)psize) % 8) {(*(msize))++;} \
+}
+
+ /* variable length event providing wake event information. Wake events can be
+ * the result of wake-packets, network events or other miscellaneous wake causes.
+ *
+ * NOTE: a WMI data header flag is not sufficient to use as WMI also forwards
+ * A-MSDU aggregates. The wake event indicates which frame caused the wake which could
+ * be embedded in an A-MSDU frame */
+typedef enum {
+ WOW_EXT_WAKE_TYPE_UNDEF = 0,
+ WOW_EXT_WAKE_TYPE_MAGIC = 1, /* magic, value = N/A, wake_data = copy of wake packet */
+ WOW_EXT_WAKE_TYPE_PATTERN = 2, /* bitmap pattern, value = filter index, wake_data = copy of wake packet */
+ WOW_EXT_WAKE_TYPE_EAPREQ = 3, /* eap request value = N/A, wake_data = copy of wake packet */
+ WOW_EXT_WAKE_TYPE_4WAYHS, /* 802.1X 4-wake handshake request caused wakeup, wake_data - copy of packet */
+ WOW_EXT_WAKE_TYPE_NETWORK_NLO, /* network list offload match */
+ WOW_EXT_WAKE_TYPE_NETWORK_DISASSOC, /* network association loss */
+ WOW_EXT_WAKE_TYPE_NETWORK_GTK_OFFL_ERROR, /* if GTK refresh is enabled, a failure generates a wake event */
+ WOW_EXT_WAKE_TYPE_MAX
+} WOW_EXT_WAKE_TYPE;
+
+typedef PREPACK struct {
+ A_UINT16 flags; /* flags, currently reserved */
+ A_UINT8 type; /* type of packet that caused the wake event */
+ A_UINT8 value; /* optional value depending on type (see above) */
+ A_UINT16 packet_length; /* if type is a wake packet, then this is the original length */
+ A_UINT16 wake_data_length; /* copy length of wake packet data to follow */
+ A_UINT8 wake_data[1]; /* start of wake data*/
+} POSTPACK WMI_WOW_EXT_WAKE_EVENT;
+
+#define WMI_WOW_EXT_WAKE_MAX_DATA_LENGTH 128
+
+#define GTK_OFFLOAD_REPLAY_COUNTER_BYTES 8
+
+#define WMI_GTK_OFFLOAD_STATUS_FLAGS_RUNNING (1 << 0) /* GTK offload is running*/
+
+
+#define GTK_OFFLOAD_KEK_BYTES 16
+#define GTK_OFFLOAD_KCK_BYTES 16
+#define GTK_REPLAY_COUNTER_BYTES 8
+
+typedef PREPACK struct {
+ A_UINT32 flags; /* status flags */
+ A_UINT32 refresh_cnt; /* number of successful GTK refresh exchanges since last SET operation */
+ A_UINT8 replay_counter[GTK_REPLAY_COUNTER_BYTES]; /* current replay counter */
+} POSTPACK WMI_GTK_OFFLOAD_STATUS_EVENT;
+
+#define WMI_GTK_OFFLOAD_OPCODE_SET 1 /* set offload parameters, KEK,KCK and replay counter values are valid */
+#define WMI_GTK_OFFLOAD_OPCODE_CLEAR 2 /* clear offload parameters */
+#define WMI_GTK_OFFLOAD_OPCODE_STATUS 3 /* get status, generates WMI_GTK_OFFLOAD_STATUS_EVENT */
+
+ /* structure to issue GTK offload opcode to set/clear or fetch status
+ * NOTE: offload is enabled when WOW options are enabled, see WOW_FILTER_OPTION_OFFLOAD_GTK */
+typedef PREPACK struct {
+ A_UINT32 flags; /* control flags */
+ A_UINT8 opcode; /* opcode */
+ A_UINT8 KEK[GTK_OFFLOAD_KEK_BYTES]; /* key encryption key */
+ A_UINT8 KCK[GTK_OFFLOAD_KCK_BYTES]; /* key confirmation key */
+ A_UINT8 replay_counter[GTK_REPLAY_COUNTER_BYTES]; /* replay counter for re-key */
+} POSTPACK WMI_GTK_OFFLOAD_OP;
+
+
+#define WMI_RX_FILTER_DEFAULT_MAX_TESTS_PER_FILTER 5
+#define WMI_RX_FILTER_DEFAULT_MAX_FILTERS 10
+
+ /* note the max pattern length was selected to balance size and usefulness. Header
+ * filtering is sized to support IPV6 addresses (16 octets using 2 entries)
+ * and MAC addresses (6 octets) */
+#define RX_FILTER_FRAME_TEST_MAX_PATTERN_LEN 8
+
+typedef enum {
+ WMI_RX_FILTER_PACKET_TYPE_NOT_SPEC = 0, /* not specified */
+ WMI_RX_FILTER_PACKET_TYPE_UNICAST = 1,
+ WMI_RX_FILTER_PACKET_TYPE_MULTICAST = 2,
+ WMI_RX_FILTER_PACKET_TYPE_BROADCAST = 3,
+ WMI_RX_FILTER_PACKET_TYPE_MAX
+} WMI_RX_FILTER_PACKET_TYPE;
+
+#define RX_FILTER_FRAME_TEST_FLAGS_EQUALITY (1 << 0) /* equality test, otherwise != */
+#define RX_FILTER_FRAME_TEST_FLAGS_MASK (1 << 1) /* mask test */
+#define RX_FILTER_FRAME_TEST_FLAGS_TYPE_CHECK (1 << 2) /* this entry is a packet type check place holder */
+
+/* testing a frame requires an offset, equality flag, an ANDing mask array and a check bytes array.
+ * This provides the flexibity to test a frame for a desired result using the following combinations:
+ *
+ * frame[offset] AND mask[] == check[]
+ * frame[offset] AND mask[] != check[]
+ * frame[offset] == check[]
+ * frame[offset] != check[]
+ *
+ */
+typedef PREPACK struct {
+ A_UINT8 flags; /* frame test flags */
+ union {
+ A_UINT8 offset; /* relative offset from this layer's header */
+ A_UINT8 type; /* if flags indicate a type-check, this value is WMI_RX_FILTER_PACKET_TYPE */
+ } option; /* additional test options depending on flags setting */
+ A_UINT8 length; /* number of bytes to test */
+ A_UINT8 rsvd0; /* reserved for target use */
+ A_UINT8 mask[RX_FILTER_FRAME_TEST_MAX_PATTERN_LEN]; /* AND mask to apply to each frame byte */
+ A_UINT8 check[RX_FILTER_FRAME_TEST_MAX_PATTERN_LEN]; /* check bytes */
+} POSTPACK WMI_RX_FILTER_FRAME_TEST;
+
+typedef PREPACK struct {
+ A_UINT8 index; /* index for this entry */
+ A_UINT8 reserved[3]; /* padding and future use */
+ WMI_RX_FILTER_FRAME_TEST frame_test; /* frame test information for this entry */
+} POSTPACK WMI_RX_FILTER_SET_FRAME_TEST;
+
+ /* structure for WMI_RX_FILTER_SET_FRAME_TEST_LIST_CMDID */
+typedef PREPACK struct {
+ A_UINT8 num_entries; /* number of entries to follow */
+ A_UINT8 reserved[3]; /* padding and future use */
+ WMI_RX_FILTER_SET_FRAME_TEST frame_test_entries[1]; /* start of frame test entries */
+} POSTPACK WMI_RX_FILTER_SET_FRAME_TEST_LIST;
+
+typedef enum {
+ WMI_RX_FILTER_FRAME_HDR_TEST_MAC = 0, /* testing MAC fields */
+ WMI_RX_FILTER_FRAME_HDR_TEST_SNAP = 1, /* testing SNAP fields */
+ WMI_RX_FILTER_FRAME_HDR_TEST_ARP = 2, /* testing ARP fields */
+ WMI_RX_FILTER_FRAME_HDR_TEST_GEN_ETHPROTO, /* testing a generic pattern in ether payload */
+ WMI_RX_FILTER_FRAME_HDR_TEST_IPV4, /* testing IPV4 fields */
+ WMI_RX_FILTER_FRAME_HDR_TEST_IPV6, /* testing IPV6 fields */
+ WMI_RX_FILTER_FRAME_HDR_TEST_GEN_IPPROTO, /* testing a generic pattern in IP payload */
+ WMI_RX_FILTER_FRAME_HDR_TEST_UDP, /* testing UDP fields */
+ WMI_RX_FILTER_FRAME_HDR_TEST_MAX
+} WMI_RX_FILTER_FRAME_HDR_TEST_TYPE;
+
+#define MAKE_RX_FILTER_FRAME_HDR_MASK(b) (1 << (b))
+
+#define WMI_RX_FILT_FRAME_HDR_TEST_MAC \
+ MAKE_RX_FILTER_FRAME_HDR_MASK(WMI_RX_FILTER_FRAME_HDR_TEST_MAC)
+#define WMI_RX_FILT_FRAME_HDR_TEST_SNAP \
+ MAKE_RX_FILTER_FRAME_HDR_MASK(WMI_RX_FILTER_FRAME_HDR_TEST_SNAP)
+#define WMI_RX_FILT_FRAME_HDR_TEST_ARP \
+ MAKE_RX_FILTER_FRAME_HDR_MASK(WMI_RX_FILTER_FRAME_HDR_TEST_ARP)
+#define WMI_RX_FILT_FRAME_HDR_TEST_IPV4 \
+ MAKE_RX_FILTER_FRAME_HDR_MASK(WMI_RX_FILTER_FRAME_HDR_TEST_IPV4)
+#define WMI_RX_FILT_FRAME_HDR_TEST_IPV6 \
+ MAKE_RX_FILTER_FRAME_HDR_MASK(WMI_RX_FILTER_FRAME_HDR_TEST_IPV6)
+#define WMI_RX_FILT_FRAME_HDR_TEST_UDP \
+ MAKE_RX_FILTER_FRAME_HDR_MASK(WMI_RX_FILTER_FRAME_HDR_TEST_UDP)
+
+typedef PREPACK struct {
+ A_UINT8 type; /* header test type (see WMI_RX_FILTER_FRAME_HDR_TEST_TYPE) */
+ A_UINT8 frame_test_index; /* corresponding frame test */
+ A_UINT8 reserved[2]; /* padding and future use */
+} POSTPACK WMI_RX_FILTER_SET_HDR_TEST;
+
+typedef enum {
+ WMI_RX_COALESCE_FILTER_OP_UNDEF = 0,
+ WMI_RX_COALESCE_FILTER_OP_SET = 1,
+ WMI_RX_COALESCE_FILTER_OP_CLEAR = 2,
+ WMI_RX_COALESCE_FILTER_OP_MAX,
+} WMI_RX_COALESCE_FILTER_OPCODE;
+
+typedef PREPACK struct {
+ A_UINT8 op_code; /* op code */
+ A_UINT8 index; /* filter index */
+ A_UINT8 reserved[2]; /* padding and future use */
+ union {
+ /* parameters for SET opcode */
+ struct {
+ A_UINT32 coalesc_delay_ms; /* coalesc delay in milliseconds */
+ A_UINT8 total_hdr_tests; /* number of hdr test elements to follow */
+ A_UINT8 reserved[3]; /* padding and future use */
+ } set_filter_params;
+ } params;
+ union {
+ /* data for SET opcode */
+ WMI_RX_FILTER_SET_HDR_TEST header_tests[1]; /* one or more entries */
+ } data;
+} POSTPACK WMI_RX_FILTER_COALESCE_FILTER_OP;
+
+
+/*
+ * Transmit complete event data structure(s)
+ */
+
+
+typedef PREPACK struct {
+#define TX_COMPLETE_STATUS_SUCCESS 0
+#define TX_COMPLETE_STATUS_RETRIES 1
+#define TX_COMPLETE_STATUS_NOLINK 2
+#define TX_COMPLETE_STATUS_TIMEOUT 3
+#define TX_COMPLETE_STATUS_OTHER 4
+
+ A_UINT8 status; /* one of TX_COMPLETE_STATUS_... */
+ A_UINT8 pktID; /* packet ID to identify parent packet */
+ A_UINT8 rateIdx; /* rate index on successful transmission */
+ A_UINT8 ackFailures; /* number of ACK failures in tx attempt */
+#if 0 /* optional params currently ommitted. */
+ A_UINT32 queueDelay; // usec delay measured Tx Start time - host delivery time
+ A_UINT32 mediaDelay; // usec delay measured ACK rx time - host delivery time
+#endif
+} POSTPACK TX_COMPLETE_MSG_V1; /* version 1 of tx complete msg */
+
+#if defined(EXTENDED_TX_COMPLETE)
+typedef PREPACK struct {
+#define TX_COMPLETE_TYPE_UCAST 0
+#define TX_COMPLETE_TYPE_MGMT 1
+#define TX_COMPLETE_TYPE_MCAST 2
+#define TX_COMPLETE_TYPE_PAL 3
+ A_UINT8 status : 4, /* one of TX_COMPLETE_STATUS_... */
+ dev_id : 4;
+ A_UINT8 peer_id;
+ A_UINT8 tid : 4,
+ pkt_type : 4; /* 0:unicast data, 1:mgmt&ctrl, 2:multicast data, 3:pal */
+ A_UINT8 packet_id;
+} POSTPACK TX_COMPLETE_MSG_V2; /* version 1 of tx complete msg */
+#endif /* EXTENDED_TX_COMPLETE */
+
+typedef PREPACK struct {
+ A_UINT8 numMessages; /* number of tx comp msgs following this struct */
+ A_UINT8 msgLen; /* length in bytes for each individual msg following this struct */
+ A_UINT8 msgType; /* version of tx complete msg data following this struct */
+ A_UINT8 reserved; /* individual messages follow this header */
+} POSTPACK WMI_TX_COMPLETE_EVENT;
+
+#define WMI_TXCOMPLETE_VERSION_1 (0x01)
+#if defined(EXTENDED_TX_COMPLETE)
+#define WMI_TXCOMPLETE_VERSION_2 (0x02)
+#endif /* EXTENDED_TX_COMPLETE */
+
+
+/*
+ * ------- AP Mode definitions --------------
+ */
+
+/*
+ * !!! Warning !!!
+ * -Changing the following values needs compilation of both driver and firmware
+ */
+#ifdef AR6002_REV2
+#define AP_MAX_NUM_STA 4
+#else
+#define AP_MAX_NUM_STA 10
+#endif
+
+/*Maximum no. of virtual interface supported*/
+#ifdef AR6002_REV64
+#define NUM_DEV 4
+#define NUM_CONN (AP_MAX_NUM_STA + NUM_DEV - 1) /* As P2P device port won't enter CONN state, so we omit 1 CONN buffer */
+#else
+#define NUM_DEV 3
+#define NUM_CONN (AP_MAX_NUM_STA + NUM_DEV)
+#endif
+
+#define AP_ACL_SIZE 10
+#define IEEE80211_MAX_IE 256
+#define MCAST_AID 0xFF /* Spl. AID used to set DTIM flag in the beacons */
+#define DEF_AP_COUNTRY_CODE "US "
+#define DEF_AP_WMODE_G WMI_11G_MODE
+#define DEF_AP_WMODE_AG WMI_11AG_MODE
+#define DEF_AP_DTIM 5
+#define DEF_BEACON_INTERVAL 100
+
+/* ACS scan policy */
+#define AP_ACS_NORMAL 0 /* 1, 6, 11 */
+#define AP_ACS_DISABLE_CH11 1 /* 1, 6 */
+#define AP_ACS_INCLUDE_CH13 2 /* 1, 5, 9, 13 */
+
+/* AP mode disconnect reasons */
+#define AP_DISCONNECT_STA_LEFT 101
+#define AP_DISCONNECT_FROM_HOST 102
+#define AP_DISCONNECT_COMM_TIMEOUT 103
+#define AP_DISCONNECT_MAX_STA 104
+#define AP_DISCONNECT_ACL 105
+#define AP_DISCONNECT_STA_ROAM 106
+#define AP_DISCONNECT_DFS_CHANNEL 107
+/*
+ * Used with WMI_AP_HIDDEN_SSID_CMDID
+ */
+#define HIDDEN_SSID_FALSE 0
+#define HIDDEN_SSID_TRUE 1
+typedef PREPACK struct {
+ A_UINT8 hidden_ssid;
+} POSTPACK WMI_AP_HIDDEN_SSID_CMD;
+
+/*
+ * Used with WMI_AP_ACL_POLICY_CMDID
+ */
+#define AP_ACL_DISABLE 0x00
+#define AP_ACL_ALLOW_MAC 0x01
+#define AP_ACL_DENY_MAC 0x02
+#define AP_ACL_BLWL_MAC 0x03
+#define AP_ACL_RETAIN_LIST_MASK 0x80
+typedef PREPACK struct {
+ A_UINT8 policy;
+} POSTPACK WMI_AP_ACL_POLICY_CMD;
+
+/*
+ * Used with WMI_AP_ACL_MAC_LIST_CMDID
+ */
+#define ADD_MAC_ADDR 1
+#define DEL_MAC_ADDR 2
+
+#define ADD_WHITE_MAC_ADDR 0x01
+#define ADD_BLACK_MAC_ADDR 0x02
+#define RESET_WHITE_LIST 0x03
+#define RESET_BLACK_LIST 0x04
+#define RESET_BWLIST 0x10
+
+typedef PREPACK struct {
+ A_UINT8 action;
+ A_UINT8 index;
+ A_UINT8 mac[ATH_MAC_LEN];
+ A_UINT8 wildcard;
+} POSTPACK WMI_AP_ACL_MAC_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 index;
+ A_UINT8 acl_mac[AP_ACL_SIZE][ATH_MAC_LEN];
+ A_UINT8 wildcard[AP_ACL_SIZE];
+ A_UINT8 policy;
+} POSTPACK WMI_AP_ACL;
+
+/*
+ * Used with WMI_AP_SET_NUM_STA_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 num_sta;
+} POSTPACK WMI_AP_NUM_STA_CMD;
+
+/*
+ * Used with WMI_AP_SET_MLME_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 mac[ATH_MAC_LEN];
+ A_UINT16 reason; /* 802.11 reason code */
+ A_UINT8 cmd; /* operation to perform */
+/* MLME Commands */
+#define WMI_AP_MLME_ASSOC 1 /* associate station */
+#define WMI_AP_DISASSOC 2 /* disassociate station */
+#define WMI_AP_DEAUTH 3 /* deauthenticate station */
+#define WMI_AP_MLME_AUTHORIZE 4 /* authorize station */
+#define WMI_AP_MLME_UNAUTHORIZE 5 /* unauthorize station */
+} POSTPACK WMI_AP_SET_MLME_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 period;
+ A_UINT8 num_null_func;
+} POSTPACK WMI_AP_CONN_INACT_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 period_min;
+ A_UINT32 dwell_ms;
+} POSTPACK WMI_AP_PROT_SCAN_TIME_CMD;
+
+typedef struct {
+ A_BOOL flag;
+ A_UINT16 rsvd;
+ A_UINT16 aid;
+} WMI_AP_SET_PVB_CMD;
+
+#define WMI_DISABLE_REGULATORY_CODE "FF"
+
+typedef PREPACK struct {
+ A_UCHAR countryCode[3];
+} POSTPACK WMI_AP_SET_COUNTRY_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 dtim;
+} POSTPACK WMI_AP_SET_DTIM_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 band; /* specifies which band to apply these values */
+ A_UINT8 enable; /* allows 11n to be disabled on a per band basis */
+ A_UINT8 chan_width_40M_supported;
+ A_UINT8 short_GI_20MHz;
+ A_UINT8 short_GI_40MHz;
+ A_UINT8 intolerance_40MHz;
+ A_UINT8 max_ampdu_len_exp;
+} POSTPACK WMI_SET_HT_CAP_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 sta_chan_width;
+} POSTPACK WMI_SET_HT_OP_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 rateMasks[WMI_MODE_MAX*WMI_MAX_RATE_MASK];
+} POSTPACK WMI_SET_TX_SELECT_RATES_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 sgiMask[WMI_MAX_RATE_MASK];
+ A_UINT8 sgiPERThreshold;
+} POSTPACK WMI_SET_TX_SGI_PARAM_CMD;
+/* Enable for MCS 7/MCS 15 */
+#define DEFAULT_SGI_MASK_L32 0x08080000
+#define DEFAULT_SGI_MASK_U32 0x00000808
+#define DEFAULT_SGI_PER 10
+
+typedef PREPACK struct {
+ A_UINT32 rateField[WMI_MAX_RATE_MASK]; /* 1 bit per rate corresponding to index */
+#define WMI_RATE_POLICY_ID_MAX 5
+ A_UINT8 id; /* valid values == 1->WMI_RATE_POLICY_ID_MAX */
+ A_UINT8 shortTrys;
+ A_UINT8 longTrys;
+ A_UINT8 reserved; /* padding */
+} POSTPACK WMI_SET_RATE_POLICY_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 metaVersion; /* version of meta data for rx packets <0 = default> (0-7 = valid) */
+ A_UINT8 dot11Hdr; /* 1 == leave .11 header intact , 0 == replace .11 header with .3 <default> */
+ A_UINT8 defragOnHost; /* 1 == defragmentation is performed by host, 0 == performed by target <default> */
+ A_UINT8 reserved[1]; /* alignment */
+} POSTPACK WMI_RX_FRAME_FORMAT_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT8 enable; /* 1 == device operates in thin mode , 0 == normal mode <default> */
+ A_UINT8 reserved[3];
+} POSTPACK WMI_SET_THIN_MODE_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT16 channel; /* frequency in Mhz */
+ //A_UINT8 mode; // HT20 or HT40
+ //A_UINT8 secondary; // if mode == HT40 secondary channel above | below
+} POSTPACK WMI_SET_CHANNEL_CMD;
+
+
+typedef enum {
+ WMI_SET_CHANNEL_RES_SUCCESS = 0, // device has joined the network
+ WMI_SET_CHANNEL_RES_FAIL, // device failed for unspecified reason
+}WMI_SET_CHANNEL_RESULT;
+
+typedef PREPACK struct {
+ A_UINT8 result; /* the result of the join cmd. one of WMI_THIN_JOIN_RESULT */
+ A_UINT8 reserved[3]; /* alignment */
+} POSTPACK WMI_SET_CHANNEL_EVENT;
+
+typedef enum {
+ WMI_FILTERMASK_MGMT=0,
+ WMI_FILTERMASK_CTRL,
+ WMI_FILTERMASK_DATA,
+ WMI_FILTERMASK_MAX
+}WMI_FILTERMASK_INDEX;
+
+typedef PREPACK struct {
+ A_UINT16 filtermask[WMI_FILTERMASK_MAX];
+ A_UINT16 reserved; /* alignment */
+} POSTPACK WMI_RX_FRAME_FILTER_CMD;
+
+/* AP mode events */
+/* WMI_PS_POLL_EVENT */
+typedef PREPACK struct {
+ A_UINT16 aid;
+} POSTPACK WMI_PSPOLL_EVENT;
+
+typedef PREPACK struct {
+ A_UINT32 tx_bytes;
+ A_UINT32 tx_pkts;
+ A_UINT32 tx_error;
+ A_UINT32 tx_discard;
+ A_UINT32 rx_bytes;
+ A_UINT32 rx_pkts;
+ A_UINT32 rx_error;
+ A_UINT32 rx_discard;
+ A_UINT32 aid;
+} POSTPACK WMI_PER_STA_STAT;
+
+#define AP_GET_STATS 0
+#define AP_CLEAR_STATS 1
+
+typedef PREPACK struct {
+ A_UINT32 action;
+ WMI_PER_STA_STAT sta[AP_MAX_NUM_STA];
+} POSTPACK WMI_AP_MODE_STAT;
+
+#define AP_11BG_RATESET1 1
+#define AP_11BG_RATESET2 2
+#define DEF_AP_11BG_RATESET AP_11BG_RATESET1
+typedef PREPACK struct {
+ A_UINT8 rateset;
+} POSTPACK WMI_AP_SET_11BG_RATESET_CMD;
+/*
+ * End of AP mode definitions
+ */
+
+struct _wmm_params {
+ A_UINT8 acm; /* ACM parameter */
+ A_UINT8 aifsn; /* AIFSN parameters */
+ A_UINT8 logcwmin; /* cwmin in exponential form */
+ A_UINT8 logcwmax; /* cwmax in exponential form */
+ A_UINT16 txopLimit; /* txopLimit */
+};
+
+/* WMI_REPORT_WMM_PARAMS_EVENT */
+typedef PREPACK struct {
+ struct _wmm_params wmm_params[4];
+} POSTPACK WMI_REPORT_WMM_PARAMS_EVENT;
+
+/* P2P module definitions */
+
+/* P2P module commands */
+typedef PREPACK struct {
+ A_UINT8 go_intent;
+ A_UINT8 country[3];
+ A_UINT8 reg_class;
+ A_UINT8 listen_channel;
+ A_UINT8 op_reg_class;
+ A_UINT8 op_channel;
+} POSTPACK WMI_P2P_SET_CONFIG_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 categ;
+ A_UINT16 sub_categ;
+} POSTPACK device_type_tuple;
+
+typedef PREPACK struct {
+ device_type_tuple pri_dev_type;
+ //A_UINT8 pri_device_type[8];
+#define MAX_P2P_SEC_DEVICE_TYPES 5
+ device_type_tuple sec_dev_type[MAX_P2P_SEC_DEVICE_TYPES];
+#define WPS_UUID_LEN 16
+ A_UINT8 uuid[WPS_UUID_LEN];
+#define WPS_MAX_DEVNAME_LEN 32
+ A_UINT8 device_name[WPS_MAX_DEVNAME_LEN];
+ A_UINT8 dev_name_len;
+} POSTPACK WMI_WPS_SET_CONFIG_CMD;
+
+typedef PREPACK struct {
+ device_type_tuple pri_dev_type;
+ device_type_tuple sec_dev_type[MAX_P2P_SEC_DEVICE_TYPES];
+ A_UINT8 device_addr[ATH_MAC_LEN];
+} POSTPACK WMI_SET_REQ_DEV_ATTR_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 ssidLength;
+ A_UINT8 ssid[WMI_MAX_SSID_LEN];
+} POSTPACK P2P_SSID;
+
+typedef enum wmi_p2p_discovery_type {
+ WMI_P2P_FIND_START_WITH_FULL,
+ WMI_P2P_FIND_ONLY_SOCIAL,
+ WMI_P2P_FIND_PROGRESSIVE
+} WMI_P2P_DISC_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 timeout;
+ WMI_P2P_DISC_TYPE type;
+} POSTPACK WMI_P2P_FIND_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 listen_freq;
+ A_UINT16 force_freq;
+ A_UINT16 go_oper_freq;
+ A_UINT8 dialog_token;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT8 own_interface_addr[ATH_MAC_LEN];
+ A_UINT8 member_in_go_dev[ATH_MAC_LEN];
+ A_UINT8 go_dev_dialog_token;
+ P2P_SSID peer_go_ssid;
+ A_UINT8 wps_method;
+ A_UINT8 dev_capab;
+ A_INT8 go_intent;
+ A_UINT8 persistent_grp;
+} POSTPACK WMI_P2P_GO_NEG_START_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 persistent_group;
+ A_UINT8 group_formation;
+} POSTPACK WMI_P2P_GRP_INIT_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT8 grp_formation_status;
+} POSTPACK WMI_P2P_GRP_FORMATION_DONE_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 timeout;
+}POSTPACK WMI_P2P_LISTEN_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 listen_freq;
+ A_UINT16 force_freq;
+ A_UINT8 status;
+ A_INT8 go_intent;
+ A_UINT8 wps_buf[512];
+ A_UINT16 wps_buflen;
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 dialog_token;
+ A_UINT8 wps_method;
+ A_UINT8 persistent_grp;
+}POSTPACK WMI_P2P_GO_NEG_REQ_RSP_CMD;
+
+typedef enum {
+ WMI_P2P_INVITE_ROLE_GO,
+ WMI_P2P_INVITE_ROLE_ACTIVE_GO,
+ WMI_P2P_INVITE_ROLE_CLIENT,
+} WMI_P2P_INVITE_ROLE;
+
+typedef PREPACK struct {
+ WMI_P2P_INVITE_ROLE role;
+ A_UINT16 listen_freq;
+ A_UINT16 force_freq;
+ A_UINT8 dialog_token;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID ssid;
+ A_UINT8 is_persistent;
+ A_UINT8 wps_method;
+}POSTPACK WMI_P2P_INVITE_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 force_freq;
+ A_UINT8 status;
+ A_UINT8 dialog_token;
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 is_go;
+ A_UINT8 group_bssid[ATH_MAC_LEN];
+}POSTPACK WMI_P2P_INVITE_REQ_RSP_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 wps_method;
+ A_UINT16 listen_freq;
+ A_UINT8 dialog_token;
+ A_UINT8 peer[ATH_MAC_LEN];
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID go_oper_ssid;
+}POSTPACK WMI_P2P_PROV_DISC_REQ_CMD;
+
+typedef enum {
+ WMI_P2P_CONFID_LISTEN_CHANNEL=1,
+ WMI_P2P_CONFID_CROSS_CONNECT=2,
+ WMI_P2P_CONFID_SSID_POSTFIX=3,
+ WMI_P2P_CONFID_INTRA_BSS=4,
+
+} WMI_P2P_CONF_ID;
+
+typedef PREPACK struct {
+ A_UINT8 reg_class;
+ A_UINT8 listen_channel;
+}POSTPACK WMI_P2P_LISTEN_CHANNEL;
+
+typedef PREPACK struct {
+ A_UINT8 flag;
+}POSTPACK WMI_P2P_SET_CROSS_CONNECT;
+
+typedef PREPACK struct {
+ A_UINT8 ssid_postfix[WMI_MAX_SSID_LEN-9];
+ A_UINT8 ssid_postfix_len;
+}POSTPACK WMI_P2P_SET_SSID_POSTFIX;
+
+typedef PREPACK struct {
+ A_UINT8 flag;
+}POSTPACK WMI_P2P_SET_INTRA_BSS;
+
+typedef PREPACK struct {
+ A_UINT8 config_id; /* set to one of WMI_P2P_CONF_ID */
+ PREPACK union {
+ WMI_P2P_LISTEN_CHANNEL listen_ch;
+ WMI_P2P_SET_CROSS_CONNECT cross_conn;
+ WMI_P2P_SET_SSID_POSTFIX ssid_postfix;
+ WMI_P2P_SET_INTRA_BSS intra_bss;
+ }POSTPACK val;
+}POSTPACK WMI_P2P_SET_CMD;
+
+#define RATECTRL_MODE_DEFAULT 0
+#define RATECTRL_MODE_PERONLY 1
+
+typedef PREPACK struct {
+ A_UINT32 mode;
+}POSTPACK WMI_SET_RATECTRL_PARM_CMD;
+
+#define WMI_P2P_MAX_TLV_LEN 1024
+typedef enum {
+ WMI_P2P_SD_TYPE_GAS_INITIAL_REQ = 0x1,
+ WMI_P2P_SD_TYPE_GAS_INITIAL_RESP = 0x2,
+ WMI_P2P_SD_TYPE_GAS_COMEBACK_REQ = 0x3,
+ WMI_P2P_SD_TYPE_GAS_COMEBACK_RESP = 0x4,
+ WMI_P2P_PD_TYPE_RESP = 0x5,
+ WMI_P2P_SD_TYPE_STATUS_IND = 0x6,
+} WMI_P2P_SDPD_TYPE;
+
+typedef enum {
+ WMI_P2P_SDPD_TRANSACTION_PENDING = 0x1,
+ WMI_P2P_SDPD_TRANSACTION_COMP = 0x2,
+} WMI_P2P_SDPD_TRANSACTION_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 type;
+ A_UINT8 dialog_token;
+ A_UINT8 frag_id;
+ A_UINT8 reserved1; /* alignment */
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT16 freq;
+ A_UINT16 status_code;
+ A_UINT16 comeback_delay;
+ A_UINT16 tlv_length;
+ A_UINT16 update_indic;
+ A_UINT16 total_length;
+ A_UINT16 reserved2; /* future */
+ A_UINT8 tlv[WMI_P2P_MAX_TLV_LEN];
+} POSTPACK WMI_P2P_SDPD_TX_CMD;
+
+/* P2P module events */
+
+typedef PREPACK struct {
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT8 wps_buf[512];
+ A_UINT16 wps_buflen;
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 dialog_token;
+}POSTPACK WMI_P2P_GO_NEG_REQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT16 freq;
+ A_INT8 status;
+ A_UINT8 role_go;
+ A_UINT8 ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 ssid_len;
+#define WMI_MAX_PASSPHRASE_LEN 9
+ A_CHAR pass_phrase[WMI_MAX_PASSPHRASE_LEN];
+ A_UINT8 peer_device_addr[ATH_MAC_LEN];
+ A_UINT8 peer_interface_addr[ATH_MAC_LEN];
+ A_UINT8 wps_method;
+ A_UINT8 persistent_grp;
+} POSTPACK WMI_P2P_GO_NEG_RESULT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID ssid;
+ A_UINT8 is_persistent;
+ A_UINT8 dialog_token;
+} POSTPACK WMI_P2P_INVITE_REQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT16 oper_freq;
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 is_bssid_valid;
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID ssid;
+ A_UINT8 status;
+} POSTPACK WMI_P2P_INVITE_RCVD_RESULT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 is_bssid_valid;
+} POSTPACK WMI_P2P_INVITE_SENT_RESULT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT16 wps_config_method;
+ A_UINT8 dev_addr[ATH_MAC_LEN];
+#define WPS_DEV_TYPE_LEN 8
+ A_UINT8 pri_dev_type[WPS_DEV_TYPE_LEN];
+ A_UINT8 device_name[WPS_MAX_DEVNAME_LEN];
+ A_UINT8 dev_name_len;
+ A_UINT16 dev_config_methods;
+ A_UINT8 device_capab;
+ A_UINT8 group_capab;
+} POSTPACK WMI_P2P_PROV_DISC_REQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 peer[ATH_MAC_LEN];
+ A_UINT16 config_methods;
+} POSTPACK WMI_P2P_PROV_DISC_RESP_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 type;
+ A_UINT8 transaction_status;
+ A_UINT8 dialog_token;
+ A_UINT8 frag_id;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT16 freq;
+ A_UINT16 status_code;
+ A_UINT16 comeback_delay;
+ A_UINT16 tlv_length;
+ A_UINT16 update_indic;
+// Variable length TLV will be placed after the event
+} POSTPACK WMI_P2P_SDPD_RX_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 event_id; /* event identifier */
+ A_UINT8 length; /* number of bytes of data that follows */
+ A_UINT8 data[1]; /* start of event data */
+} POSTPACK WMI_ACS_EVENT_MSG;
+
+#define WMI_ACS_EVENT_HDR_LEN (sizeof(WMI_ACS_EVENT_MSG) - sizeof(A_UINT8))
+
+typedef PREPACK struct {
+ A_UINT8 ctrl_id; /* control identifier */
+ A_UINT8 length; /* number of bytes of data to follow */
+ A_UINT8 data[1]; /* start of control data */
+} POSTPACK WMI_ACS_CTRL_MSG;
+
+#define WMI_ACS_CTRL_HDR_LEN (sizeof(WMI_ACS_CTRL_MSG) - sizeof(A_UINT8))
+
+/* STORE / RECALL Commands AND Events DEFINITION START */
+typedef PREPACK struct {
+ A_UINT8 enable;
+#define STRRCL_RECIPIENT_HOST 1
+#define STRRCL_RECIPIENT_POWERSAFE_MEM 2
+ A_UINT8 recipient;
+} POSTPACK WMI_STORERECALL_CONFIGURE_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 length; /* number of bytes of data to follow */
+ A_UINT8 data[1]; /* start of data */
+} POSTPACK WMI_STORERECALL_RECALL_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 sleep_msec;
+ A_UINT8 store_after_tx_empty;
+ A_UINT8 store_after_fresh_beacon_rx;
+} POSTPACK WMI_STORERECALL_HOST_READY_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 msec_sleep; /* time between power off/on */
+ A_UINT32 length; /* length of following data */
+ A_UINT8 data[1]; /* start of data */
+} POSTPACK WMI_STORERECALL_STORE_EVENT;
+
+/* STORE / RECALL Commands AND Events DEFINITION END */
+/* WPS Commands AND Events DEFINITION START */
+
+typedef PREPACK struct {
+ A_UINT8 ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 macaddress[ATH_MAC_LEN];
+ A_UINT16 channel;
+ A_UINT8 ssid_len;
+} POSTPACK WPS_SCAN_LIST_ENTRY;
+
+#define WPS_PIN_LEN (8)
+
+typedef PREPACK struct {
+ A_UINT8 pin[WPS_PIN_LEN+1];
+}POSTPACK WPS_PIN;
+
+typedef enum {
+ WPS_PIN_MODE = 0x1,
+ WPS_PBC_MODE = 0x2
+} WPS_MODE;
+
+typedef enum {
+ WPS_REGISTRAR_ROLE = 0x1,
+ WPS_ENROLLEE_ROLE = 0x2
+} WPS_OPER_MODE;
+
+typedef enum {
+ WPS_DO_CONNECT_AFTER_CRED_RECVD = 0x1
+} WPS_START_CTRL_FLAG;
+
+typedef PREPACK struct {
+ WPS_SCAN_LIST_ENTRY ssid_info;
+ A_UINT8 config_mode; /* WPS_MODE */
+ WPS_PIN wps_pin;
+ A_UINT8 timeout; /* in Seconds */
+ A_UINT8 role; /* WPS_OPER_MOD */
+ A_UINT8 ctl_flag; /* WPS_START_CTRL_FLAG */
+} POSTPACK WMI_WPS_START_CMD;
+
+typedef enum {
+ WPS_STATUS_SUCCESS = 0x0,
+ WPS_STATUS_FAILURE = 0x1,
+ WPS_STATUS_IDLE = 0x2,
+ WPS_STATUS_IN_PROGRESS = 0x3,
+} WPS_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 wps_status; /* WPS_STATUS */
+ A_UINT8 wps_state;
+} POSTPACK WMI_WPS_GET_STATUS_EVENT;
+
+typedef enum {
+ WPS_ERROR_INVALID_START_INFO = 0x1,
+ WPS_ERROR_MULTIPLE_PBC_SESSIONS,
+ WPS_ERROR_WALKTIMER_TIMEOUT,
+ WPS_ERROR_M2D_RCVD,
+ WPS_ERROR_PWD_AUTH_FAIL
+} WPS_ERROR_CODE;
+
+typedef enum {
+ WPS_AUTH_TYPE_OPEN = 0x0001,
+ WPS_AUTH_TYPE_WPAPSK = 0x0002,
+ WPS_AUTH_TYPE_SHARED = 0x0004,
+ WPS_AUTH_TYPE_WPA = 0x0008,
+ WPS_AUTH_TYPE_WPA2 = 0x0010,
+ WPS_AUTH_TYPE_WPA2PSK = 0x0020
+} WPS_AUTH_TYPE;
+
+typedef enum {
+ WPS_ENCR_TYPE_NONE = 0x0001,
+ WPS_ENCR_TYPE_WEP = 0x0002,
+ WPS_ENCR_TYPE_TKIP = 0x0004,
+ WPS_ENCR_TYPE_AES = 0x0008,
+} WPS_ENCR_TYPE;
+
+typedef PREPACK struct {
+ A_UINT16 ap_channel;
+ A_UINT8 ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 ssid_len;
+ A_UINT16 auth_type; /* WPS_AUTH_TYPE */
+ A_UINT16 encr_type; /* WPS_ENCR_TYPE */
+ A_UINT8 key_idx;
+ A_UINT8 key[64];
+ A_UINT8 key_len;
+ A_UINT8 mac_addr[ATH_MAC_LEN];
+} POSTPACK WPS_CREDENTIAL;
+
+typedef PREPACK struct {
+ A_UINT8 status; /* WPS_STATUS */
+ A_UINT8 error_code; /* WPS_ERROR_CODE */
+ WPS_CREDENTIAL credential;
+} POSTPACK WMI_WPS_PROFILE_EVENT;
+
+/* WPS Commands AND Events DEFINITION END */
+
+typedef enum {
+ WMI_AP_APSD_DISABLED = 0,
+ WMI_AP_APSD_ENABLED
+} WMI_AP_APSD_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 enable;
+} POSTPACK WMI_AP_SET_APSD_CMD;
+
+typedef enum {
+ WMI_AP_APSD_NO_DELIVERY_FRAMES_FOR_THIS_TRIGGER = 0x1,
+} WMI_AP_APSD_BUFFERED_TRAFFIC_FLAGS;
+
+typedef PREPACK struct {
+ A_UINT16 aid;
+ A_UINT16 bitmap;
+ A_UINT32 flags;
+} POSTPACK WMI_AP_APSD_BUFFERED_TRAFFIC_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 freq;
+ A_UINT32 duration;
+} POSTPACK WMI_REMAIN_ON_CHNL_CMD_STRUCT;
+
+/* WMI_SEND_ACTION_CMD_STRUCT is to be deprecated; WMI_SEND_MGMT_CMD_STRUCT is
+ * to be used instead. The new command supports P2P mgmt operations using
+ * station interface
+ */
+typedef PREPACK struct {
+ A_UINT32 ID;
+ A_UINT32 freq;
+ A_UINT32 wait;
+ A_UINT16 len;
+ A_UINT8 data[1];
+} POSTPACK WMI_SEND_ACTION_CMD_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 ID;
+ A_UINT32 freq;
+ A_UINT32 wait;
+ A_BOOL no_cck;
+ A_UINT16 len;
+ A_UINT8 data[1];
+} POSTPACK WMI_SEND_MGMT_CMD_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 ID;
+ A_UINT8 ACKStatus;
+} POSTPACK WMI_TX_STATUS_EVENT_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT8 enable;
+} POSTPACK WMI_PROBE_REQ_REPORT_CMD_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT8 disable;
+} POSTPACK WMI_DISABLE_11B_RATES_CMD_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT8 RoleID;
+ A_UINT8 mgmtFrmType;
+ A_UINT8 ieLen;
+ A_UINT8 ieInfo[1];
+} POSTPACK WMI_SET_APPIE_EXTENDED_CMD_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 freq;
+ A_UINT32 duration;
+} POSTPACK WMI_REMAIN_ON_CHNL_EVENT_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 freq;
+ A_UINT32 duration;
+ A_UINT8 status;
+} POSTPACK WMI_CANCEL_REMAIN_ON_CHNL_EVENT_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 freq;
+ A_UINT16 len;
+ A_UINT8 data[1];
+} POSTPACK WMI_RX_ACTION_EVENT_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT16 len;
+ A_UINT8 data[1];
+} POSTPACK WMI_P2P_CAPABILITIES_EVENT_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 freq;
+ A_UINT16 len;
+ A_UINT8 data[1];
+} POSTPACK WMI_P2P_RX_PROBE_REQ_EVENT_STRUCT;
+
+#define P2P_FLAG_CAPABILITIES_REQ (0x00000001)
+#define P2P_FLAG_MACADDR_REQ (0x00000002)
+#define P2P_FLAG_P2P_MODEL_REQ (0x00000004)
+
+typedef PREPACK struct {
+ A_UINT32 InfoReqFlags;
+} POSTPACK WMI_GET_P2P_INFO_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 InfoReqFlags;
+ A_UINT16 len;
+ A_UINT8 data[1];
+} POSTPACK WMI_P2P_INFO_EVENT_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT8 GOPowerSave;
+} POSTPACK WMI_P2P_CAPABILITIES_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT8 MACAddr[6];
+} POSTPACK WMI_P2P_MACADDR_STRUCT;
+
+#define P2P_HOST_MODEL 1
+#define P2P_FW_MODEL 0
+
+typedef PREPACK struct {
+ A_UINT8 P2PModel;
+} POSTPACK WMI_P2P_MODEL_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 freq;
+ A_UINT8 DestinationAddr[6];
+ A_UINT16 len;
+ A_UINT8 data[1];
+} POSTPACK WMI_P2P_PROBE_RESPONSE_CMD_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT32 duration;
+ A_UINT32 interval;
+ A_UINT32 start_or_offset;
+ A_UINT8 count_or_type;
+} POSTPACK P2P_NOA_DESCRIPTOR;
+
+typedef PREPACK struct {
+ A_UINT8 enable;
+ A_UINT8 count;
+ A_UINT8 noas[1];
+} POSTPACK WMI_NOA_INFO_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT8 enable;
+ A_UINT8 ctwin;
+} POSTPACK WMI_OPPPS_INFO_STRUCT;
+
+typedef PREPACK struct {
+ A_UINT8 port_id;
+ A_UINT8 port_opmode;
+ A_UINT8 port_subopmode;
+} POSTPACK WMI_ADD_PORT_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 port_id;
+} POSTPACK WMI_DEL_PORT_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+ A_UINT8 port_id;
+ A_UINT8 mac_addr[6];
+} POSTPACK WMI_PORT_STATUS_INFO;
+
+typedef PREPACK struct {
+ A_UINT16 rsn_cap;
+} POSTPACK WMI_RSN_CAP_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 keyIndex;
+ A_UINT8 keyLength;
+ A_UINT8 keyRSC[6];/* key replay sequence counter */
+ A_UINT8 key[WMI_MAX_KEY_LEN];
+} POSTPACK WMI_SET_IGTK_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 min_rx_bundle_frame;
+ A_UINT8 min_rx_bundle_timeout;
+} POSTPACK WMI_SET_BUNDLE_PARAM_CMD;
+
+typedef PREPACK struct {
+ A_BOOL enable;
+ A_UINT8 nextProbeCount;
+ A_UINT8 maxBackOff;
+ A_UINT8 forceBackOff;
+} POSTPACK WMI_GREENTX_PARAMS_CMD;
+
+/* voice detection enable/disable command structure */
+typedef PREPACK struct {
+ A_UINT8 enable;
+} POSTPACK WMI_VOICE_DETECTION_ENABLE_CMD;
+
+typedef enum {
+ RECOVERY_SIM_ASSERT = 0x01,
+ RECOVERY_SIM_NO_DETECT = 0x02,
+ RECOVERY_SIM_CTR_EP_FULL= 0x03,
+ RECOVERY_SIM_EMPTY_POINT= 0x04,
+ RECOVERY_SIM_STACK_OV = 0x05,
+} RECOVERY_SIM_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 type; /*0:unused 1: ASSERT, 2: not respond detect command,3: simulate ep-full(),4:empty point,5 stack overflow...*/
+ A_UINT8 reserved; /*unused now*/
+ A_UINT16 delay_time_ms; /*0xffff means the simulate will delay for random time (0 ~0xffff ms)*/
+}POSTPACK WMI_SET_RECOVERY_TEST_PARAMETER_CMD;
+
+typedef PREPACK struct {
+A_UINT8 disable; /*0: enable broadcast, 1: disable broadcast */
+} POSTPACK WMI_DISABLE_BCAST_IN_PM_CMD;
+
+typedef PREPACK struct {
+ A_INT8 rssi_value;
+} POSTPACK WMI_SET_RSSI_FILTER_CMD;
+
+
+#ifndef ATH_TARGET
+//#include "athendpack.h"
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WMI_H_ */
diff --git a/ath6kl-wmiconfig/include/wmiconfig.h b/ath6kl-wmiconfig/include/wmiconfig.h
new file mode 100755
index 0000000..d9ac071
--- /dev/null
+++ b/ath6kl-wmiconfig/include/wmiconfig.h
@@ -0,0 +1,555 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*
+ * This file contains the definitions for wmiconfig utility
+ */
+
+#ifndef _WMI_CONFIG_H_
+#define _WMI_CONFIG_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+enum ath6kl_tm_attr {
+ __ATH6KL_TM_ATTR_INVALID = 0,
+ ATH6KL_TM_ATTR_CMD = 1,
+ ATH6KL_TM_ATTR_DATA = 2,
+
+ /* keep last */
+ __ATH6KL_TM_ATTR_AFTER_LAST,
+ ATH6KL_TM_ATTR_MAX = __ATH6KL_TM_ATTR_AFTER_LAST - 1,
+};
+
+enum ath6kl_tm_cmd {
+ ATH6KL_TM_CMD_TCMD = 0,
+ ATH6KL_TM_CMD_RX_REPORT = 1, /* not used anymore */
+ ATH6KL_TM_CMD_WMI_CMD = 0xF000,
+};
+
+
+enum {
+ WMI_GET_VERSION=501, /* something that doesn't collide with ascii */
+ WMI_SET_POWER_MODE,
+ WMI_SET_IBSS_PM_CAPS,
+ WMI_SET_PM_PARAMS,
+ WMI_SET_SCAN_PARAMS,
+ WMI_SET_LISTEN_INTERVAL,
+ WMI_SET_BMISS_TIME,
+ WMI_SET_BSS_FILTER,
+ WMI_SET_RSSI_THRESHOLDS,
+ WMI_SET_CHANNEL,
+ WMI_SET_SSID,
+ WMI_SET_BADAP,
+ WMI_DELETE_BADAP,
+ WMI_CREATE_QOS,
+ WMI_DELETE_QOS,
+ WMI_GET_QOS_QUEUE,
+ WMI_GET_TARGET_STATS,
+ WMI_SET_TARGET_ERROR_REPORTING_BITMASK,
+ WMI_SET_AC_PARAMS,
+ WMI_SET_ASSOC_IE,
+ WMI_SET_DISC_TIMEOUT,
+ WMI_SET_ADHOC_BSSID,
+ WMI_SET_OPT_MODE,
+ WMI_OPT_SEND_FRAME,
+ WMI_SET_BEACON_INT,
+ WMI_SET_VOICE_PKT_SIZE,
+ WMI_SET_MAX_SP,
+ WMI_GET_ROAM_TBL,
+ WMI_SET_ROAM_CTRL,
+ WMI_SET_POWERSAVE_TIMERS,
+ WMI_SET_POWERSAVE_TIMERS_PSPOLLTIMEOUT,
+ WMI_SET_POWERSAVE_TIMERS_TRIGGERTIMEOUT,
+ WMI_GET_POWER_MODE,
+ WMI_SET_WLAN_STATE,
+ WMI_GET_WLAN_STATE,
+ WMI_GET_ROAM_DATA,
+ WMI_SET_BT_STATUS,
+ WMI_SET_BT_PARAMS,
+ WMI_SET_BTCOEX_FE_ANT,
+ WMI_SET_BTCOEX_COLOCATED_BT_DEV,
+ WMI_SET_BTCOEX_SCO_CONFIG,
+ WMI_SET_BTCOEX_A2DP_CONFIG,
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG,
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG,
+ WMI_SET_BTCOEX_DEBUG,
+ WMI_SET_BTCOEX_BT_OPERATING_STATUS,
+ WMI_GET_BTCOEX_CONFIG,
+ WMI_GET_BTCOEX_STATS,
+ WMI_SET_RETRYLIMITS,
+ WMI_START_SCAN,
+ WMI_SET_FIX_RATES,
+ WMI_GET_FIX_RATES,
+ WMI_SET_SNR_THRESHOLDS,
+ WMI_CLR_RSSISNR,
+ WMI_SET_LQ_THRESHOLDS,
+ WMI_SET_AUTH_MODE,
+ WMI_SET_REASSOC_MODE,
+ WMI_SET_LPREAMBLE,
+ WMI_SET_RTS,
+ WMI_SET_WMM,
+#ifdef USER_KEYS
+ USER_SETKEYS,
+#endif
+ WMI_APSD_TIM_POLICY,
+ WMI_SET_ERROR_DETECTION,
+ WMI_GET_HB_CHALLENGE_RESP,
+ WMI_SET_TXOP,
+ DIAG_ADDR,
+ DIAG_DATA,
+ DIAG_READ,
+ DIAG_WRITE,
+ WMI_GET_RD,
+ WMI_SET_KEEPALIVE,
+ WMI_GET_KEEPALIVE,
+ WMI_SET_APPIE,
+ WMI_SET_MGMT_FRM_RX_FILTER,
+ WMI_DBGLOG_CFG_MODULE,
+ WMI_DBGLOG_GET_DEBUG_LOGS,
+ WMI_SET_HOST_SLEEP_MODE,
+ WMI_SET_WOW_MODE,
+ WMI_GET_WOW_LIST,
+ WMI_ADD_WOW_PATTERN,
+ WMI_DEL_WOW_PATTERN,
+ DIAG_DUMP_CHIP_MEM,
+ WMI_SET_CONNECT_CTRL_FLAGS,
+ DUMP_HTC_CREDITS,
+ USER_SETKEYS_INITRSC,
+ WMI_SCAN_DFSCH_ACT_TIME,
+ WMI_SIMULATED_APSD_TIM_POLICY,
+ WMI_SET_AKMP_INFO,
+ WMI_AKMP_MULTI_PMKID,
+ WMI_NUM_PMKID,
+ WMI_PMKID_ENTRY,
+ WMI_SET_PMKID_LIST,
+ WMI_GET_PMKID_LIST,
+ WMI_SET_IEMASK,
+ WMI_SCAN_CHANNEL_LIST,
+ WMI_SET_BSS_PMKID_INFO,
+ WMI_BSS_PMKID_ENTRY,
+ WMI_BSSID,
+ WMI_ABORT_SCAN,
+ WMI_TARGET_EVENT_REPORT,
+ WMI_AP_GET_STA_LIST, /* AP mode */
+ WMI_AP_HIDDEN_SSID, /* AP mode */
+ WMI_AP_SET_NUM_STA, /* AP mode */
+ WMI_AP_ACL_POLICY, /* AP mode */
+ WMI_AP_ACL_MAC_LIST1, /* AP mode */
+ WMI_AP_ACL_MAC_LIST2, /* AP mode */
+ WMI_AP_GET_ACL_LIST, /* AP mode */
+ WMI_AP_COMMIT_CONFIG, /* AP mode */
+ WMI_AP_INACT_TIME, /* AP mode */
+ WMI_AP_PROT_TIME, /* AP mode */
+ WMI_AP_SET_MLME, /* AP mode */
+ WMI_AP_SET_COUNTRY, /* AP mode */
+ WMI_AP_GET_COUNTRY_LIST,/* AP mode */
+ WMI_AP_DISABLE_REGULATORY, /* AP mode */
+ WMI_AP_SET_DTIM, /* AP mode */
+ WMI_AP_INTRA_BSS, /* AP mode */
+ WMI_AP_INTER_BSS, /* AP mode */
+ WMI_GET_IP,
+ WMI_SET_MCAST_FILTER,
+ WMI_DEL_MCAST_FILTER,
+ WMI_MCAST_FILTER,
+ WMI_DUMP_RCV_AGGR_STATS,
+ WMI_SETUP_AGGR,
+ WMI_CFG_ALLOW_AGGR,
+ WMI_CFG_DELE_AGGR,
+ WMI_SET_HT_CAP,
+ WMI_SET_HT_OP,
+ WMI_AP_GET_STAT, /* AP mode */
+ WMI_AP_CLR_STAT, /* AP mode */
+ WMI_SET_TX_SELECT_RATES,
+ WMI_SCAN_MAXACT_PER_SSID,
+ WMI_AP_GET_HIDDEN_SSID, /* AP mode */
+ WMI_AP_GET_COUNTRY, /* AP mode */
+ WMI_AP_GET_WMODE, /* AP mode */
+ WMI_AP_GET_DTIM, /* AP mode */
+ WMI_AP_GET_BINTVL, /* AP mode */
+ WMI_GET_RTS,
+ DIAG_FETCH_TARGET_REGS,
+#ifdef ATH_INCLUDE_PAL
+ WMI_SEND_PAL_CMD,
+ WMI_SEND_PAL_DATA,
+#endif
+ WMI_SET_WLAN_CONN_PRECDNCE,
+ WMI_SET_AP_RATESET, /* AP mode */
+ WMI_SET_TX_WAKEUP_POLICY,
+ WMI_SET_TX_NUM_FRAMES_TO_WAKEUP,
+ WMI_SET_AP_PS,
+ WMI_SET_AP_PS_PSTYPE,
+ WMI_SET_AP_PS_IDLE_TIME,
+ WMI_SET_AP_PS_PS_PERIOD,
+ WMI_SET_AP_PS_SLEEP_PERIOD,
+ WMI_SEND_CONNECT_CMD,
+ WMI_SEND_CONNECT_CMD1,
+ WMI_SEND_CONNECT_CMD2,
+ WMI_SET_WOW_FILTER,
+ WMI_SET_WOW_HOST_REQ_DELAY,
+ WMI_SET_QOS_SUPP,
+ WMI_SET_AC_VAL,
+ WMI_AP_SET_DFS, /* AP mode */
+ BT_HW_POWER_STATE,
+ SET_BT_HW_POWER_STATE,
+ GET_BT_HW_POWER_STATE,
+ DIAG_DUMP_CHIP_MEM_VENUS,
+ WMI_SET_TX_SGI_PARAM,
+ WMI_SGI_MASK,
+ WMI_PER_SGI,
+ WMI_WAC_ENABLE,
+ WMI_SET_WPA_OFFLOAD_STATE,
+ WMI_AP_ACS_DISABLE_HI_CHANNELS,
+ WMI_SET_DIVERSITY_PARAM,
+ WMI_SET_EXCESS_TX_RETRY_THRES,
+ WMI_FORCE_ASSERT,
+ WMI_AP_SET_GNUM_STA,
+ WMI_AP_GET_GNUM_STA,
+ WMI_AP_GET_NUM_STA,
+ WMI_SUSPEND_DRIVER,
+ WMI_RESUME_DRIVER,
+ WMI_SCAN_PROBED_SSID,
+ WMI_AP_SET_APSD,
+ WMI_GET_HT_CAP,
+ WMI_SET_MCASTRATE,
+ WMI_VOICE_DETECTION_ENABLE, /* enable/disable voice detection */
+ WMI_SET_TXE_NOTIFY,
+ WMI_SET_RECOVERY_SIMULATE, /*set recovery simulate*/
+WMI_DISABLE_BCAST_IN_PM, /* enable/disable broadcast in power save */
+ WMI_AP_BLWL, /*set SAP blacklist/whitelist*/
+ WMI_AP_BLWL_POLICY, /*set SAP blacklist/whitelist policy*/
+ WMI_AP_BLWL_MAC_LIST, /*set SAP blacklist/whitelist mac*/
+ WMI_SET_RSSI_FILTER,
+};
+
+/*
+***************************************************************************
+** How to form a regcode from CountryCode, Regulatory domain or WWR code:
+**
+** WWR code is nothing but a special case of Regulatory domain.
+**
+** code is of type U_INT32
+**
+** Bit-31 Bit-30 Bit11-0
+** 0 0 xxxx -> Bit11-0 is a Regulatory Domain
+** 0 1 xxxx -> Bit11-0 is a WWR code
+** 1 X xxxx -> Bit11-0 is a Country code
+**
+***************************************************************************
+*/
+#define REGCODE_IS_CC_BITSET(x) ((x) & 0x80000000)
+#define REGCODE_GET_CODE(x) ((x) & 0xFFF)
+#define REGCODE_IS_WWR_BITSET(x) ((x) & 0x40000000)
+#ifdef ATH_INCLUDE_PAL
+#define MAX_BUFFER_SIZE 1512
+#endif
+
+typedef struct {
+ A_UINT32 numPMKIDUser; /* PMKIDs user wants to enter */
+ WMI_SET_PMKID_LIST_CMD *pmkidInfo;
+} pmkidUserInfo_t;
+
+#define KEYTYPE_PSK 1
+#define KEYTYPE_PHRASE 2
+
+typedef struct {
+ char ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 ssid_len;
+ A_UINT8 wpa;
+ A_UINT8 ucipher;
+ A_UINT8 mcipher;
+ char psk[64];
+ A_UINT8 psk_type;
+ A_UINT8 pmk[WMI_PMK_LEN];
+ A_UINT8 auth;
+ A_UINT8 wep_key[4][26];
+ A_UINT8 def_wep_key;
+} profile_t;
+
+/*
+ * Numbering from ISO 3166
+ */
+enum CountryCode {
+ CTRY_ALBANIA = 8, /* Albania */
+ CTRY_ALGERIA = 12, /* Algeria */
+ CTRY_ARGENTINA = 32, /* Argentina */
+ CTRY_ARMENIA = 51, /* Armenia */
+ CTRY_ARUBA = 533, /* Aruba */
+ CTRY_AUSTRALIA = 36, /* Australia (for STA) */
+ CTRY_AUSTRALIA_AP = 5000, /* Australia (for AP) */
+ CTRY_AUSTRIA = 40, /* Austria */
+ CTRY_AZERBAIJAN = 31, /* Azerbaijan */
+ CTRY_BAHRAIN = 48, /* Bahrain */
+ CTRY_BANGLADESH = 50, /* Bangladesh */
+ CTRY_BARBADOS = 52, /* Barbados */
+ CTRY_BELARUS = 112, /* Belarus */
+ CTRY_BELGIUM = 56, /* Belgium */
+ CTRY_BELIZE = 84, /* Belize */
+ CTRY_BOLIVIA = 68, /* Bolivia */
+ CTRY_BOSNIA_HERZEGOWANIA = 70, /* Bosnia & Herzegowania */
+ CTRY_BRAZIL = 76, /* Brazil */
+ CTRY_BRUNEI_DARUSSALAM = 96, /* Brunei Darussalam */
+ CTRY_BULGARIA = 100, /* Bulgaria */
+ CTRY_CAMBODIA = 116, /* Cambodia */
+ CTRY_CANADA = 124, /* Canada (for STA) */
+ CTRY_CANADA_AP = 5001, /* Canada (for AP) */
+ CTRY_CHILE = 152, /* Chile */
+ CTRY_CHINA = 156, /* People's Republic of China */
+ CTRY_COLOMBIA = 170, /* Colombia */
+ CTRY_COSTA_RICA = 188, /* Costa Rica */
+ CTRY_CROATIA = 191, /* Croatia */
+ CTRY_CYPRUS = 196,
+ CTRY_CZECH = 203, /* Czech Republic */
+ CTRY_DENMARK = 208, /* Denmark */
+ CTRY_DOMINICAN_REPUBLIC = 214, /* Dominican Republic */
+ CTRY_ECUADOR = 218, /* Ecuador */
+ CTRY_EGYPT = 818, /* Egypt */
+ CTRY_EL_SALVADOR = 222, /* El Salvador */
+ CTRY_ESTONIA = 233, /* Estonia */
+ CTRY_FAEROE_ISLANDS = 234, /* Faeroe Islands */
+ CTRY_FINLAND = 246, /* Finland */
+ CTRY_FRANCE = 250, /* France */
+ CTRY_FRANCE2 = 255, /* France2 */
+ CTRY_GEORGIA = 268, /* Georgia */
+ CTRY_GERMANY = 276, /* Germany */
+ CTRY_GREECE = 300, /* Greece */
+ CTRY_GREENLAND = 304, /* Greenland */
+ CTRY_GRENADA = 308, /* Grenada */
+ CTRY_GUAM = 316, /* Guam */
+ CTRY_GUATEMALA = 320, /* Guatemala */
+ CTRY_HAITI = 332, /* Haiti */
+ CTRY_HONDURAS = 340, /* Honduras */
+ CTRY_HONG_KONG = 344, /* Hong Kong S.A.R., P.R.C. */
+ CTRY_HUNGARY = 348, /* Hungary */
+ CTRY_ICELAND = 352, /* Iceland */
+ CTRY_INDIA = 356, /* India */
+ CTRY_INDONESIA = 360, /* Indonesia */
+ CTRY_IRAN = 364, /* Iran */
+ CTRY_IRAQ = 368, /* Iraq */
+ CTRY_IRELAND = 372, /* Ireland */
+ CTRY_ISRAEL = 376, /* Israel */
+ CTRY_ITALY = 380, /* Italy */
+ CTRY_JAMAICA = 388, /* Jamaica */
+ CTRY_JAPAN = 392, /* Japan */
+ CTRY_JAPAN1 = 393, /* Japan (JP1) */
+ CTRY_JAPAN2 = 394, /* Japan (JP0) */
+ CTRY_JAPAN3 = 395, /* Japan (JP1-1) */
+ CTRY_JAPAN4 = 396, /* Japan (JE1) */
+ CTRY_JAPAN5 = 397, /* Japan (JE2) */
+ CTRY_JAPAN6 = 399, /* Japan (JP6) */
+ CTRY_JORDAN = 400, /* Jordan */
+ CTRY_KAZAKHSTAN = 398, /* Kazakhstan */
+ CTRY_KENYA = 404, /* Kenya */
+ CTRY_KOREA_NORTH = 408, /* North Korea */
+ CTRY_KOREA_ROC = 410, /* South Korea (for STA) */
+ CTRY_KOREA_ROC2 = 411, /* South Korea */
+ CTRY_KOREA_ROC3 = 412, /* South Korea (for AP) */
+ CTRY_KUWAIT = 414, /* Kuwait */
+ CTRY_LATVIA = 428, /* Latvia */
+ CTRY_LEBANON = 422, /* Lebanon */
+ CTRY_LIBYA = 434, /* Libya */
+ CTRY_LIECHTENSTEIN = 438, /* Liechtenstein */
+ CTRY_LITHUANIA = 440, /* Lithuania */
+ CTRY_LUXEMBOURG = 442, /* Luxembourg */
+ CTRY_MACAU = 446, /* Macau */
+ CTRY_MACEDONIA = 807, /* the Former Yugoslav Republic of Macedonia */
+ CTRY_MALAYSIA = 458, /* Malaysia */
+ CTRY_MALTA = 470, /* Malta */
+ CTRY_MEXICO = 484, /* Mexico */
+ CTRY_MONACO = 492, /* Principality of Monaco */
+ CTRY_MOROCCO = 504, /* Morocco */
+ CTRY_NEPAL = 524, /* Nepal */
+ CTRY_NETHERLANDS = 528, /* Netherlands */
+ CTRY_NETHERLAND_ANTILLES = 530, /* Netherlands-Antilles */
+ CTRY_NEW_ZEALAND = 554, /* New Zealand */
+ CTRY_NICARAGUA = 558, /* Nicaragua */
+ CTRY_NORWAY = 578, /* Norway */
+ CTRY_OMAN = 512, /* Oman */
+ CTRY_PAKISTAN = 586, /* Islamic Republic of Pakistan */
+ CTRY_PANAMA = 591, /* Panama */
+ CTRY_PARAGUAY = 600, /* Paraguay */
+ CTRY_PERU = 604, /* Peru */
+ CTRY_PHILIPPINES = 608, /* Republic of the Philippines */
+ CTRY_POLAND = 616, /* Poland */
+ CTRY_PORTUGAL = 620, /* Portugal */
+ CTRY_PUERTO_RICO = 630, /* Puerto Rico */
+ CTRY_QATAR = 634, /* Qatar */
+ CTRY_ROMANIA = 642, /* Romania */
+ CTRY_RUSSIA = 643, /* Russia */
+ CTRY_RWANDA = 646, /* Rwanda */
+ CTRY_SAUDI_ARABIA = 682, /* Saudi Arabia */
+ CTRY_MONTENEGRO = 891, /* Montenegro */
+ CTRY_SINGAPORE = 702, /* Singapore */
+ CTRY_SLOVAKIA = 703, /* Slovak Republic */
+ CTRY_SLOVENIA = 705, /* Slovenia */
+ CTRY_SOUTH_AFRICA = 710, /* South Africa */
+ CTRY_SPAIN = 724, /* Spain */
+ CTRY_SRILANKA = 144, /* Sri Lanka */
+ CTRY_SWEDEN = 752, /* Sweden */
+ CTRY_SWITZERLAND = 756, /* Switzerland */
+ CTRY_SYRIA = 760, /* Syria */
+ CTRY_TAIWAN = 158, /* Taiwan */
+ CTRY_THAILAND = 764, /* Thailand */
+ CTRY_TRINIDAD_Y_TOBAGO = 780, /* Trinidad y Tobago */
+ CTRY_TUNISIA = 788, /* Tunisia */
+ CTRY_TURKEY = 792, /* Turkey */
+ CTRY_UAE = 784, /* U.A.E. */
+ CTRY_UKRAINE = 804, /* Ukraine */
+ CTRY_UNITED_KINGDOM = 826, /* United Kingdom */
+ CTRY_UNITED_STATES = 840, /* United States (for STA) */
+ CTRY_UNITED_STATES_AP = 841, /* United States (for AP) */
+ CTRY_UNITED_STATES_PS = 842, /* United States - public safety */
+ CTRY_URUGUAY = 858, /* Uruguay */
+ CTRY_UZBEKISTAN = 860, /* Uzbekistan */
+ CTRY_VENEZUELA = 862, /* Venezuela */
+ CTRY_VIET_NAM = 704, /* Viet Nam */
+ CTRY_YEMEN = 887, /* Yemen */
+ CTRY_ZIMBABWE = 716 /* Zimbabwe */
+};
+
+#define CTRY_DEBUG 0
+#define CTRY_DEFAULT 0x1ff
+#define REGCODE_COUNTRY_BIT 0x80000000
+
+typedef struct {
+ A_UINT16 countryCode;
+ A_CHAR isoName[3];
+} COUNTRY_CODE_MAP;
+#if 0
+static COUNTRY_CODE_MAP allCountries[] = {
+ {CTRY_DEBUG, "DB"},
+ {CTRY_DEFAULT, "NA"},
+ {CTRY_ALBANIA, "AL"},
+ {CTRY_ALGERIA, "DZ"},
+ {CTRY_ARGENTINA, "AR"},
+ {CTRY_ARMENIA, "AM"},
+ {CTRY_ARUBA, "AW"},
+ {CTRY_AUSTRALIA, "AU"},
+ {CTRY_AUSTRALIA_AP, "AU"},
+ {CTRY_AUSTRIA, "AT"},
+ {CTRY_AZERBAIJAN, "AZ"},
+ {CTRY_BAHRAIN, "BH"},
+ {CTRY_BANGLADESH, "BD"},
+ {CTRY_BARBADOS, "BB"},
+ {CTRY_BELARUS, "BY"},
+ {CTRY_BELGIUM, "BE"},
+ {CTRY_BELIZE, "BZ"},
+ {CTRY_BOLIVIA, "BO"},
+ {CTRY_BOSNIA_HERZEGOWANIA, "BA"},
+ {CTRY_BRAZIL, "BR"},
+ {CTRY_BRUNEI_DARUSSALAM, "BN"},
+ {CTRY_BULGARIA, "BG"},
+ {CTRY_CAMBODIA, "KH"},
+ {CTRY_CANADA, "CA"},
+ {CTRY_CANADA_AP, "CA"},
+ {CTRY_CHILE, "CL"},
+ {CTRY_CHINA, "CN"},
+ {CTRY_COLOMBIA, "CO"},
+ {CTRY_COSTA_RICA, "CR"},
+ {CTRY_CROATIA, "HR"},
+ {CTRY_CYPRUS, "CY"},
+ {CTRY_CZECH, "CZ"},
+ {CTRY_DENMARK, "DK"},
+ {CTRY_DOMINICAN_REPUBLIC, "DO"},
+ {CTRY_ECUADOR, "EC"},
+ {CTRY_EGYPT, "EG"},
+ {CTRY_EL_SALVADOR, "SV"},
+ {CTRY_ESTONIA, "EE"},
+ {CTRY_FINLAND, "FI"},
+ {CTRY_FRANCE, "FR"},
+ {CTRY_FRANCE2, "F2"},
+ {CTRY_GEORGIA, "GE"},
+ {CTRY_GERMANY, "DE"},
+ {CTRY_GREECE, "GR"},
+ {CTRY_GREENLAND, "GL"},
+ {CTRY_GRENADA, "GD"},
+ {CTRY_GUAM, "GU"},
+ {CTRY_GUATEMALA, "GT"},
+ {CTRY_HAITI, "HT"},
+ {CTRY_HONDURAS, "HN"},
+ {CTRY_HONG_KONG, "HK"},
+ {CTRY_HUNGARY, "HU"},
+ {CTRY_ICELAND, "IS"},
+ {CTRY_INDIA, "IN"},
+ {CTRY_INDONESIA, "ID"},
+ {CTRY_IRAN, "IR"},
+ {CTRY_IRELAND, "IE"},
+ {CTRY_ISRAEL, "IL"},
+ {CTRY_ITALY, "IT"},
+ {CTRY_JAMAICA, "JM"},
+ {CTRY_JAPAN, "JP"},
+ {CTRY_JORDAN, "JO"},
+ {CTRY_KAZAKHSTAN, "KZ"},
+ {CTRY_KENYA, "KE"},
+ {CTRY_KOREA_NORTH, "KP"},
+ {CTRY_KOREA_ROC, "KR"},
+ {CTRY_KOREA_ROC2, "K2"},
+ {CTRY_KOREA_ROC3, "K3"},
+ {CTRY_KUWAIT, "KW"},
+ {CTRY_LATVIA, "LV"},
+ {CTRY_LEBANON, "LB"},
+ {CTRY_LIECHTENSTEIN, "LI"},
+ {CTRY_LITHUANIA, "LT"},
+ {CTRY_LUXEMBOURG, "LU"},
+ {CTRY_MACAU, "MO"},
+ {CTRY_MACEDONIA, "MK"},
+ {CTRY_MALAYSIA, "MY"},
+ {CTRY_MALTA, "MT"},
+ {CTRY_MEXICO, "MX"},
+ {CTRY_MONACO, "MC"},
+ {CTRY_MOROCCO, "MA"},
+ {CTRY_NEPAL, "NP"},
+ {CTRY_NEW_ZEALAND, "NZ"},
+ {CTRY_NETHERLANDS, "NL"},
+ {CTRY_NETHERLAND_ANTILLES, "AN"},
+ {CTRY_NORWAY, "NO"},
+ {CTRY_OMAN, "OM"},
+ {CTRY_PAKISTAN, "PK"},
+ {CTRY_PANAMA, "PA"},
+ {CTRY_PERU, "PE"},
+ {CTRY_PHILIPPINES, "PH"},
+ {CTRY_POLAND, "PL"},
+ {CTRY_PORTUGAL, "PT"},
+ {CTRY_PUERTO_RICO, "PR"},
+ {CTRY_QATAR, "QA"},
+ {CTRY_ROMANIA, "RO"},
+ {CTRY_RUSSIA, "RU"},
+ {CTRY_RWANDA, "RW"},
+ {CTRY_SAUDI_ARABIA, "SA"},
+ {CTRY_MONTENEGRO, "CS"},
+ {CTRY_SINGAPORE, "SG"},
+ {CTRY_SLOVAKIA, "SK"},
+ {CTRY_SLOVENIA, "SI"},
+ {CTRY_SOUTH_AFRICA, "ZA"},
+ {CTRY_SPAIN, "ES"},
+ {CTRY_SRILANKA, "LK"},
+ {CTRY_SWEDEN, "SE"},
+ {CTRY_SWITZERLAND, "CH"},
+ {CTRY_SYRIA, "SY"},
+ {CTRY_TAIWAN, "TW"},
+ {CTRY_THAILAND, "TH"},
+ {CTRY_TRINIDAD_Y_TOBAGO, "TT"},
+ {CTRY_TUNISIA, "TN"},
+ {CTRY_TURKEY, "TR"},
+ {CTRY_UKRAINE, "UA"},
+ {CTRY_UAE, "AE"},
+ {CTRY_UNITED_KINGDOM, "GB"},
+ {CTRY_UNITED_STATES, "US"},
+ {CTRY_UNITED_STATES_AP, "US"},
+ {CTRY_UNITED_STATES_PS, "PS"},
+ {CTRY_URUGUAY, "UY"},
+ {CTRY_UZBEKISTAN, "UZ"},
+ {CTRY_VENEZUELA, "VE"},
+ {CTRY_VIET_NAM, "VN"},
+ {CTRY_YEMEN, "YE"},
+ {CTRY_ZIMBABWE, "ZW"}
+};
+#endif
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WMI_CONFIG_H_ */
diff --git a/ath6kl-wmiconfig/wmiconfig b/ath6kl-wmiconfig/wmiconfig
new file mode 100755
index 0000000..958ded7
--- /dev/null
+++ b/ath6kl-wmiconfig/wmiconfig
Binary files differ
diff --git a/ath6kl-wmiconfig/wmiconfig.c b/ath6kl-wmiconfig/wmiconfig.c
new file mode 100755
index 0000000..5e5c2c3
--- /dev/null
+++ b/ath6kl-wmiconfig/wmiconfig.c
@@ -0,0 +1,3530 @@
+/*
+* Copyright (c) 2012 Qualcomm Atheros, Inc..
+* All Rights Reserved.
+* Qualcomm Atheros Confidential and Proprietary.
+*/
+#define SUPPORT_11N
+#include "libtcmd.h"
+#include <sys/types.h>
+#include <sys/file.h>
+#include <sys/ioctl.h>
+#include <sys/socket.h>
+#include <linux/types.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <getopt.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <stdbool.h>
+#include <a_config.h>
+#include <a_osapi.h>
+#include <athdefs.h>
+#include <a_types.h>
+#include <wmi.h>
+
+#include "athdrv_linux.h"
+#include "ieee80211.h"
+#include "ieee80211_ioctl.h"
+#include "wmiconfig.h"
+#include "pkt_log.h"
+#include "wmi.h"
+#include "dbglog.h"
+#include "testcmd.h"
+
+#define TO_LOWER(c) ((((c) >= 'A') && ((c) <= 'Z')) ? ((c)+ 0x20) : (c))
+
+#define ISDIGIT(c) ( (((c) >= '0') && ((c) <= '9')) ? (1) : (0) )
+
+//static int send_connect_cmd();
+
+//static int send_scan_probedssid_cmd();
+
+static int _from_hex(char c);
+//static A_INT8 getPhyMode(char *pArg);
+
+static A_UINT16 wmic_ieee2freq(int chan);
+static A_STATUS wmic_ether_aton(const char *orig, A_UINT8 *eth);
+void printTargetStats(TARGET_STATS *pStats);
+static A_STATUS
+wmic_get_ip(const char *ipstr, A_UINT32 *ip);
+A_STATUS
+wmic_validate_setkeepalive(WMI_SET_KEEPALIVE_CMD_EXT *cmd, char **argv);
+A_STATUS
+wmic_validate_roam_ctrl(WMI_SET_ROAM_CTRL_CMD *pRoamCtrl, A_UINT8 numArgs,
+ char **argv);
+A_STATUS
+wmic_validate_appie(struct ieee80211req_getset_appiebuf *appIEInfo, char **argv);
+void rx_cb(void *buf, int len);
+A_STATUS
+wmic_validate_mgmtfilter(A_UINT32 *pMgmtFilter, char **argv);
+void convert_hexstring_bytearray(char *hexStr, A_UINT8 *byteArray,
+ A_UINT8 numBytes);
+//static int is_mac_null(A_UINT8 *mac);
+void print_wild_mac(unsigned char *mac, char wildcard);
+A_STATUS wmic_ether_aton_wild(const char *orig, A_UINT8 *eth, A_UINT8 *wild);
+void printBtcoexConfig(WMI_BTCOEX_CONFIG_EVENT * pConfig);
+void printBtcoexStats(WMI_BTCOEX_STATS_EVENT * pStats);
+#ifdef ATH_INCLUDE_PAL
+void *phy_attach(char *if_name);
+int pal_send_hci_cmd(void *dev, char *buf, short sz);
+int pal_send_acl_data_pkt(void *dev, char *buf, short sz);
+void cmdParser(A_UINT8 *cmd,A_UINT16 len);
+void palData(A_UINT8 *data,A_UINT32 len);
+extern int eventLogLevel; //To enable/disable Debug messages. defined in pal parser library
+
+const char palcommands[]=
+"--sendpalcmd <filename> <on/off> ; on - enable debug; off - disable debug \n\
+--sendpaldata <filename> <on/off>; on - enable debug; off - disable debug \n";
+#endif
+const char *progname;
+const char commands[] =
+"commands:\n\
+--version\n\
+--power <mode> where <mode> is rec or maxperf\n\
+--getpower is used to get the power mode(rec or maxperf)\n\
+--pmparams --it=<msec> --np=<number of PS POLL> --dp=<DTIM policy: ignore/normal/stick> --twp=<Tx wakeup policy: wakeup/sleep> --nt=<number of tx to wakeup>\n\
+--psparams --psPollTimer=<psPollTimeout> --triggerTimer=<triggerTimeout> --apsdTimPolicy=<ignore/adhere> --simulatedAPSDTimPolicy=<ignore/adhere>\n\
+--forceAssert \n\
+--ibsspmcaps --ps=<disable/atheros/ieee> --aw=<ATIM Windows in millisecond> --to=<TIMEOUT in millisecond> --ttl=<Time to live in number of beacon periods>\n\
+--appsparams --pstype=<disable/atheros> --psit=<millisecond> --psperiod=<in microsecond> --sleepperiod=<in psperiods>\n\
+--scan --fgstart=<sec> --fgend=<sec> --bg=<sec> --minact=<msec> maxact=<msec> --pas=<msec> --sr=<short scan ratio> --maxact2pas=<msec> --scanctrlflags <connScan> <scanConnected> <activeScan> <roamScan> <reportBSSINFO> <EnableAutoScan> --maxactscan_ssid=<Max no of active scan per probed ssid>\n\
+ where: \n\\n\
+ <connScan> is 0 to not scan when Connect and Reconnect command, \n\
+ 1 to scan when Connect and Reconnect command, \n\
+ <scanConnected> is 0 to skip the ssid it is already connected to, \n\
+ 1 to scan the ssid it is already connected to, \n\
+ <activeScan> is 0 to disable active scan, \n\
+ 1 to enable active scan, \n\
+ <roamScan> is 0 to disable roam scan when beacom miss and low rssi.(It's only valible when connScan is 0.\n\
+ 1 to enable roam scan.\n\
+ <reportBSSINFO> is 0 to disable specified BSSINFO reporting rule.\n\
+ 1 to enable specified BSSINFO reporting rule.\n\
+ <EnableAutoScan> is 0 to disable autonomous scan. No scan after a disconnect event\n\
+ 1 Enable autonomous scan.\n\
+--listen=<#of TUs, can range from 15 to 5000>\n\
+--listenbeacons=<#of beacons, can range from 1 to 50>\n\
+--setbmisstime <#of TUs, can range from 1000 to 5000>\n\
+--setbmissbeacons <#of beacons, can range from 5 to 50>\n\
+--filter=<filter> --ieMask 0x<mask> where <filter> is none, all, profile, not_profile, bss, not_bss, or ssid and <mask> is a combination of the following\n\
+{\n\
+ BSS_ELEMID_CHANSWITCH = 0x01 \n\
+ BSS_ELEMID_ATHEROS = 0x02\n\
+}\n\
+--wmode <mode> <list> sc <scan> where \n\
+ <mode> is a, g, b,ag, gonly (use mode alone in AP mode) \n\
+ <list> is a list of channels (frequencies in mhz or ieee channel numbers)\n\
+ <scan> is 0 to disable scan after setting channel list.\n\
+ 1 to enable scan after setting channel list.\n\
+--getwmode \n\
+--ssid <index> <ssid> \n\
+ where <ssid> is the wireless network string,'any' mean empty ssid, 'off' means disable \n\
+ <index> is 0 ~ 15 \n\
+--badAP=<macaddr> [--num=<index>] where macaddr is macaddr of AP to be avoided in xx:xx:xx:xx:xx:xx format, and num is index from 0-1.\n\
+--clrAP [--num=<index>] is used to clear a badAP entry. num is index from 0-1\n\
+--createqos <user priority> <direction> <traffic class> <trafficType> <voice PS capability> \n\
+ <min service interval> <max service interval> <inactivity interval> <suspension interval> \n\
+ <service start time> <tsid> <nominal MSDU> <max MSDU> <min data rate> <mean data rate> \n\
+ <peak data rate> <max burst size> <delay bound> <min phy rate> <sba> <medium time>where:\n\
+ <user priority> 802.1D user priority range : 0-7 \n\
+ <direction> is 0 for Tx(uplink) traffic, \n\
+ 1 for Rx(downlink) traffic, \n\
+ 2 for bi-directional traffic; \n\
+ <traffic class> is 0 for BE, \n\
+ 1 for BK, \n\
+ 2 for VI, \n\
+ 3 for VO; \n\
+ <trafficType> 1-periodic, 0-aperiodic \n\
+ <voice PS capability> specifies whether the voice power save mechanism \n\
+ (APSD if AP supports it or legacy/simulated APSD \n\
+ [using PS-Poll] ) should be used \n\
+ = 0 to disable voice power save for this traffic class,\n\
+ = 1 to enable APSD voice power save for this traffic class,\n\
+ = 2 to enable voice power save for ALL traffic classes,\n\
+ <min service interval> in milliseconds \n\
+ <max service interval> in milliseconds \n\
+ <inactivity interval> in milliseconds;=0 means infinite inactivity interval\n\
+ <suspension interval> in milliseconds \n\
+ <service start time> service start time \n\
+ <tsid> TSID range: 0-15 \n\
+ <nominal MSDU> nominal MAC SDU size \n\
+ <max MSDU> maximum MAC SDU size \n\
+ <min data rate> min data rate in bps \n\
+ <mean data rate> mean data rate in bps \n\
+ <peak data rate> peak data rate in bps \n\
+ <max burst size> max burst size in bps \n\
+ <delay bound> delay bound \n\
+ <min phy rate> min phy rate in bps \n\
+ <sba> surplus bandwidth allowance \n\
+ <medium time> medium time in TU of 32-us periods per sec \n\
+--deleteqos <trafficClass> <tsid> where:\n\
+ <traffic class> is 0 for BE, \n\
+ 1 for BK, \n\
+ 2 for VI, \n\
+ 3 for VO; \n\
+ <tsid> is the TspecID, use --qosqueue option to get the active tsids\n\
+--qosqueue <traffic class>, where:\n\
+ <traffic class> is 0 for BE, \n\
+ 1 for BK, \n\
+ 2 for VI, \n\
+ 3 for VO; \n\
+--getTargetStats --clearStats\n\
+ tx_unicast_rate, rx_unicast_rate values will be 0Kbps when no tx/rx \n\
+ unicast data frame is received.\n\
+--setErrorReportingBitmask\n\
+--acparams --acval <0-3> --txop <limit> --cwmin <0-15> --cwmax <0-15> --aifsn<0-15>\n\
+--disc=<timeout> to set the disconnect timeout in seconds\n\
+--mode <mode> set the optional mode, where mode is special or off \n\
+--sendframe <frmType> <dstaddr> <bssid> <optIEDatalen> <optIEData> where:\n\
+ <frmType> is 1 for probe request frame,\n\
+ 2 for probe response frame,\n\
+ 3 for CPPP start,\n\
+ 4 for CPPP stop, \n\
+ <dstaddr> is the destination mac address, in xx:xx:xx:xx:xx:xx format, \n\
+ <bssid> is the bssid, in xx:xx:xx:xx:xx:xx format, \n\
+ <optIEDatalen> optional IE data length,\n\
+ <optIEData> is the pointer to optional IE data arrary \n\
+--adhocbssid <macaddr> where macaddr is the BSSID for IBSS to be created in xx:xx:xx:xx:xx:xx format\n\
+--beaconintvl <beacon_interval in milliseonds> \n\
+--getbeaconintvl \n\
+--setretrylimits <frameType> <trafficClass> <maxRetries> <enableNotify>\n\
+ <frameType> is 0 for management frame, \n\
+ 1 for control frame,\n\
+ 2,for data frame;\n\
+ <trafficClass> is 0 for BE, 1 for BK, 2 for VI, 3 for VO, only applies to data frame type\n\
+ <maxRetries> is # in [2 - 13]; \n\
+ <enableNotify> is \"on\" to enable the notification of max retries exceed \n\
+ \"off\" to disable the notification of max retries excedd \n\
+--rssiThreshold <weight> <pollTimer> <above_threshold_tag_1> <above_threshold_val_1> ... \n\
+ <above_threshold_tag_6> <above_threshold_val_6> \n\
+ <below_threshold_tag_1> <below_threshold_val_1> ... \n\
+ <below_threshold_tag_6> <below_threshold_val_6> \n\
+ <weight> share with snrThreshold\n\
+ <threshold_x> will be converted to negatvie value automatically, \n\
+ i.e. input 90, actually -90 will be set into HW\n\
+ <pollTimer> is timer to poll rssi value(factor of LI), set to 0 will disable all thresholds\n\
+ \n\
+--snrThreshold <weight> <upper_threshold_1> ... <upper_threshold_4> \n\
+ <lower_threshold_1> ... <lower_threshold_4> <pollTimer>\n\
+ <weight> share with rssiThreshold\n\
+ <threshold_x> is positive value, in ascending order\n\
+ <pollTimer> is timer to poll snr value(factor of LI), set to 0 will disable all thresholds\n\
+ \n\
+--cleanRssiSnr \n\
+--lqThreshold <enable> <upper_threshold_1> ... <upper_threshold_4>\n\
+ <lower_threshold_1> ... <lower_threshold_4>\n\
+ <enable> is 0 for disable,\n\
+ 1 for enable lqThreshold\n\
+ <threshold_x> is in ascending order \n\
+--setlongpreamble <enable>\n\
+ <enable> is 0 for diable,\n\
+ 1 for enable.\n\
+--setRTS <pkt length threshold>\n\
+--getRTS \n\
+--startscan --homeDwellTime=<msec> --forceScanInt<ms> --forceScanFlags <scan type> <forcefgscan> <isLegacyCisco> --scanlist <list> where:\n\
+ <homeDwellTime> Maximum duration in the home channel(milliseconds),\n\
+ <forceScanInt> Time interval between scans (milliseconds),\n\
+ <scan type> is 0 for long scan,\n\
+ 1 for short scan,\n\
+ <forcefgscan> is 0 for disable force fgscan,\n\
+ 1 for enable force fgscan,\n\
+ <isLegacyCisco> is 0 for disable legacy Cisco AP compatible,\n\
+ 1 for enable legacy Cisco AP compatible,\n\
+ <list> is a list of channels (frequencies in mhz or ieee channel numbers)\n\
+--setfixrates <rate index> where: \n\
+ <rate index> is {0 1M},{1 2M},{2 5.5M},{3 11M},{4 6M},{5 9M},{6 12M},{7 18M},{8 24M},{9 36M},{10 48M},{11 54M},\n\
+ if want to config more rare index, can use blank to space out, such as: --setfixrates 0 1 2 \n\
+--getfixrates : Get the fix rate index from target\n\
+--setauthmode <mode> where:\n\
+ <mode> is 0 to do authentication when reconnect, \n\
+ 1 to not do authentication when reconnect.(not clean key). \n\
+--setreassocmode <mode> where:\n\
+ <mode> is 0 do send disassoc when reassociation, \n\
+ 1 do not send disassoc when reassociation. \n\
+--setVoicePktSize is maximum size of voice packet \n\
+--setMaxSPLength is the maximum service period in packets, as applicable in APSD \n\
+ 0 - deliver all packets \n\
+ 1 - deliver up to 2 packets \n\
+ 2 - deliver up to 4 packets \n\
+ 3 - deliver up to 6 packets \n\
+--setAssocIe <IE String>\n\
+--roam <roamctrl> <info>\n\
+ where <roamctrl> is 1 force a roam to specified bssid\n\
+ 2 set the roam mode \n\
+ 3 set the host bias of the specified BSSID\n\
+ 4 set the lowrssi scan parameters \n\
+ where <info> is BSSID<aa:bb:cc:dd:ee:ff> for roamctrl of 1\n\
+ DEFAULT ,BSSBIAS or LOCK for roamctrl of 2\n\
+ BSSID<aa:bb:cc:dd:ee:ff> <bias> for roamctrl of 3\n\
+ where <bias> is a value between -256 and 255\n\
+ <scan period> <scan threshold> <roam threshold> \n\
+ <roam rssi floor> for roamctrl of 4\n\
+--getroamtable\n\
+--getroamdata\n\
+--wlan <enable/disable/query>\n\
+--bt <on/off/query>\n\
+--setBTstatus <streamType> <status>\n\
+ where <streamType> is 1 - Bluetooth SCO stream\n\
+ 2 - Bluetooth A2DP stream\n\
+ 3 - Bluetooth Inquiry/low priority stream\n\
+ 4 - Bluetooth E-SCO stream\n\
+ \n\
+ where <status> is 1 - stream started\n\
+ 2 - stream stopped\n\
+ 3 - stream resumed\n\
+ 4 - stream suspended\n\
+--setBTparams <paramType> <params>\n\
+ where <paramType> is 1 - Bluetooth SCO stream parameters\n\
+ 2 - Bluetooth A2DP stream parameters \n\
+ 3 - Front end antenna configuration \n\
+ 4 - Co-located Bluetooth configuration\n\
+ 5 - Bluetooth ACL coex (non-a2dp) parameters\n\
+ 6 - 11a is using a separate antenna\n\
+ \n\
+ where <params> for Bluetooth SCO are:\n\
+ <numScoCyclesForceTrigger> - number of Sco cyles, to force a trigger\n\
+ <dataResponseTimeout> - timeout for receiving downlink packet per PS-poll\n\
+ <stompScoRules> - Applicable for dual/splitter front end\n\
+ 1, Never stomp BT to receive downlink pkt\n\
+ 2, Always stomp BT to receive downlink pkt\n\
+ 3, Stomp BT only during low rssi conditions\n\
+ <stompDutyCyleVal> If Sco is stomped while waiting for downlink pkt, number sco cyles to not queue ps-poll-(Applicable only for switch FE)\n\
+ <psPollLatencyFraction> Fraction of idle SCO idle time.\n\
+ 1, if more than 3/4 idle duration is left, retrieve downlink pkt\n\
+ 2, if more than 1/2 idle duration is left, retrieve downlink pkt\n\
+ 3, if more 1/4 idle duration is left, retrieve dwnlink pkt\n\
+ <SCO slots> - number of Tx+Rx SCO slots : 2 for single-slot SCO, 6 for 3-slot SCO\n\
+ <Idle SCO slots> - number of idle slots between two SCO Tx+Rx instances\n\
+ \n\
+ where <params> for A2DP configuration are\n\
+ <a2dpWlanUsageLimit> Max duration wlan can use the medium ,whenever firmware detects medium for wlan (in msecs) \n\
+ <a2dpBurstCntMin> Mininum number of bluetooth data frames to replenish wlan usage time\n\
+ <a2dpDataRespTimeout> Time to wait for downlink data, after queuing pspoll\n\
+ where <params> for front end antenna configuration are\n\
+ 1 - Dual antenna configuration (BT and wlan have seperate antenna) \n\
+ 2 - Single antenna splitter configuration \n\
+ 3 - Single antenna switch configuration \n\
+ \n\
+ where <params> for co-located Bluetooth configuration are\n\
+ 0 - Qualcomm BTS402x (default)\n\
+ 1 - CSR Bluetooth\n\
+ 2 - Atheros Bluetooth\n\
+ \n\
+ where <params> for Bluetooth ACL coex(bt ftp or bt OPP or other data based ACL profile (non a2dp) parameter are \n\
+ <aclWlanMediumUsageTime> Usage time for Wlan.(default 30 msecs)\n\
+ <aclBtMediumUsageTime> Usage time for bluetooth (default 30 msecs)\n\
+ <aclDataRespTimeout> - timeout for receiving downlink packet per PS-poll\n\
+--setbtcoexfeant <antType> \n\
+ <antType> - Front end antenna type\n\
+ 1 - Single antenna\n\
+ 2 - Dual antenna\n\
+ 3 - Dual antenna high isolation\n\
+ 4 - bypass mode\n\
+ 5 - combine mode\n\
+--setbtcoexcolocatedbt <btdevType >\n\
+ <btdevType> Co-located bluetooth device\n\
+ 1 - Qualcomm BTS402X \n\
+ 2 - CSR BC06 bluetooth \n\
+ 3 - Atheros 3001 bluetooth\n\
+ 4 - ST-ericssion CG2900 \n\
+ 5 - Atheros 3002/MCI \n\
+--setbtcoexscoconfig <noscoSlots> <noidleslots> <scoflags> <linkid> <scoCyclesForceTrigger> <scoDataResponseTimeout> <scoStompDutyCyleVal> <scoStompDutyCyleMaxVal> <scoPsPollLatencyFraction> <scoStompCntIn100ms> <scoContStompMax> <scoMinlowRateMbps> <scoLowRateCnt> <scoHighPktRatio> <scoMaxAggrSize>\n\
+--setbtcoexa2dpconfig <a2dpFlags> <linkid> <a2dpWlanMaxDur> <a2dpMinBurstCnt> <a2dpDataRespTimeout> <a2dpMinlowRateMbps> <a2dpLowRateCnt> <a2dpHighPktRatio> <a2dpMaxAggrSize> <a2dpPktStompCnt>\n\
+--setbtcoexaclcoexconfig <aclWlanMediumDur> <aclBtMediumDur> <aclDetectTimeout> <aclPktCntLowerLimit> <aclIterForEnDis> <aclPktCntUpperLimit> <aclCoexFlags> <linkId> <aclDataRespTimeout> <aclCoexMinlowRateMbps> <aclCoexLowRateCnt> <aclCoexHighPktRatio> <aclCoexMaxAggrSize> <aclPktStompCnt> \n\
+--setbtcoexbtinquirypageconfig <btInquiryDataFetchFrequency> <protectBmissDurPostBtInquiry> <btInquiryPageFlag>\n\
+--setbtcoexbtoperatingstatus <btprofiletype> <btoperatingstatus> <btlinkid>\n\
+ <btprofiletype> - Bluetooth profile\n\
+ 1 - Bluetooth SCO profile \n\
+ 2 - Bluetooth A2DP profile \n\
+ 3 - Bluetooth Inquiry Page profile \n\
+ 4 - Bluetooth ACL (non-a2dp) profile \n\
+ \n\
+ <btoperatingstatus> profile operating status \n\
+ 1 - start \n\
+ 2 - stop \n\
+ \n\
+ <btlinkid> bluetooth link id -Applicable only for STE Bluetooth\n\
+ \n\
+--setbtcoexdebug <params1> <params2> <params3> <params4> <params5> \n\
+--getbtcoexconfig <btprofile> <linkid>\n\
+ <btprofile> - bluetooth profile \n\
+ 1 - Bluetooth SCO profile \n\
+ 2 - Bluetooth A2DP profile \n\
+ 3 - Bluetooth Inquiry Page profile \n\
+ 4 - Bluetooth ACL (non-a2dp) profile \n\
+ \n\
+ <btlinkid> bluetooth link id -Applicable only for STE Bluetooth\n\
+ \n\
+\n\
+--getbtcoexstats\n\
+--detecterror --frequency=<sec> --threshold=<count> where:\n\
+ <frequency> is the periodicity of the challenge messages in seconds, \n\
+ <threshold> is the number of challenge misses after which the error detection module in the driver will report an error, \n\
+--getheartbeat --cookie=<cookie>\n\
+ <cookie> is used to identify the response corresponding to a challenge sent\n\
+--usersetkeys --initrsc=<on/off>\n\
+ initrsc=on(off> initialises(doesnot initialise) the RSC in the firmware\n\
+--getRD\n\
+--setcountry <countryCode> (Use --countrycodes for list of codes)\n\
+--countrycodes (Lists all the valid country codes)\n\
+--getcountry \n\
+--disableregulatory\n\
+--txopbursting <burstEnable>\n\
+ where <burstEnable> is 0 disallow TxOp bursting\n\
+ 1 allow TxOp bursting\n\
+--diagread\n\
+--diagwrite\n\
+--setkeepalive <keepalive interval> <keepalive mode> <peer mac address> <arp src ip> <arp tgt ip>\n\
+ <keepalive interval> is the time within which if there is no transmission/reception activity, the station sends a null packet to AP.\n\
+ <keepalive mode> 1: NULL data frame (default)\n\
+ 2: ARP response \n\
+ 3: both \n\
+ valid if <keepalive mode> is 2 or 3:\n\
+ <peer mac address>: target mac address for arp response\n\
+ <arp src ip>: host ip\n\
+ <arp tgt ip>: arp response target ip\n\
+--getkeepalive\n\
+--setappie <frame> <IE>\n\
+ where frame is one of beacon, probe, respon, assoc\n\
+ IE is a hex string starting with dd\n\
+ if IE is 0 then no IE is sent in the management frame\n\
+--setmgmtfilter <op> <frametype>\n\
+ op is one of set, clear\n\
+ frametype is one of beacon proberesp\n\
+--setdbglogconfig --mmask=<mask> --rep=<0/1> --tsr=<tsr codes> --size=<num>\n\
+ where <mask> is a 16 bit wide mask to selectively enable logging for different modules. Example: 0xFFFD enables logging for all modules except WMI. The mask is derived from the module ids defined in etna/include/dbglog.h header file.\n\
+ <rep> is whether the target should generate log events to the host whenever the log buffer is full.\n\
+ <tsr> resolution of the debug timestamp (less than 16)\n\
+ 0: 31.25 us\n\
+ 1: 62.50 us\n\
+ 2: 125.0 us\n\
+ 3: 250.0 us\n\
+ 4: 500.0 us\n\
+ 5: 1.0 ms and so on.\n\
+ <size> size of the report in number of debug logs.\n\
+--getdbglogs\n\
+--sethostmode <mode>\n\
+ where <mode> is awake\n\
+ asleep\n\
+--setwowmode <mode> --wowfilter <filter> --hostreqdelay <hostreqdelay> \n\
+ where <mode> is enable \n\
+ disable\n\
+ where <filter> is ssid -to enable ssid filtering when asleep\n\
+ none \n\
+--getwowlist <listid> \n\
+--addwowpattern <list-id> <pattern-size> <pattern-offset> <pattern> <pattern-mask \n\
+--delwowpattern <list-id> <pattern-id>\n\
+--dumpchipmem \n\
+--dumpchipmem_venus \n\
+--setconnectctrl <ctrl flags bitmask> \n\
+ where <flags> could take the following values:\n\
+ 0x0001(CONNECT_ASSOC_POLICY_USER): Assoc frames are sent using the policy specified by the flag below.\n\
+ 0x0002(CONNECT_SEND_REASSOC): Send Reassoc frame while connecting otherwise send assoc frames.\n\
+ 0x0004(CONNECT_IGNORE_WPAx_GROUP_CIPHER): Ignore WPAx group cipher for WPA/WPA2.\n\
+ 0x0008(CONNECT_PROFILE_MATCH_DONE): Ignore any profile check.\n\
+ 0x0010(CONNECT_IGNORE_AAC_BEACON): Ignore the admission control beacon.\n\
+ 0x0020(CONNECT_CSA_FOLLOW_BSS):Set to Follow BSS to the new channel and connect \n\
+ and reset to disconnect from BSS and change channel \n\
+--dumpcreditstates \n\
+ Triggers the HTC layer to dump credit state information to the debugger \n\
+--setakmp --multipmkid=<on/off>\n\
+ multipmkid=on(off> enables(doesnot enable) Multi PMKID Caching in firmware\n\
+--setpmkidlist --numpmkid=<n> --pmkid=<pmkid_1> ... --pmkid=<pmkid_n>\n\
+ where n is the number of pmkids (max 8)\n\
+ and pmkid_i is the ith pmkid (16 bytes in hex format)\n\
+--setbsspmkid --bssid=<aabbccddeeff> --bsspmkid=<pmkid>\n\
+ bssid is 6 bytes in hex format\n\
+ bsspmkid is 16 bytes in hex format\n\
+--getpmkidlist \n\
+--abortscan \n\
+--settgtevt <event value>\n\
+ where <event value> is 0 send WMI_DISCONNECT_EVENT with disconnectReason = BSS_DISCONNECTED\n\
+ after re-connection with AP\n\
+ 1 NOT send WMI_DISCONNECT_EVENT with disconnectReason = BSS_DISCONNECTED\n\
+ after re-connection with AP\n\
+--getsta \n\
+--hiddenssid <value> \n\
+ where value 1-Enable, 0-Disable. \n\
+--gethiddenssid \n\
+--numsta <num> \n\
+--gnumsta <num> \n\
+--getnumsta \n\
+--getgnumsta \n\
+--conninact <period> \n\
+ where period is time in min (default 5min). \n\
+ 0 will disable STA inactivity check. \n\
+--protectionscan <period> <dwell> \n\
+ where period is in min (default 5min). 0 will disable. \n\
+ dwell is in ms. (default 200ms). \n\
+--addacl <mac> \n\
+ where mac is of the format xx:xx:xx:xx:xx:xx \n\
+--delacl <index> \n\
+ use --getacl to get index \n\
+--getacl \n\
+--aclpolicy <policy> <retain list> \n\
+ where <policy> \n\
+ 0 - Disable ACL \n\
+ 1 - Allow MAC \n\
+ 2 - Deny MAC \n\
+ <retain list> \n\
+ 0 - Clear the current ACL list \n\
+ 1 - Retain the current ACL list \n\
+--removesta <action> <reason> <mac> \n\
+ where <action> \n\
+ 2 - Disassoc \n\
+ 3 - Deauth \n\
+ <reason> protocol reason code, use 1 when in doubt \n\
+ <mac> mac addr of a connected STA \n\
+--dtim <period> \n\
+--getdtim \n\
+--intrabss <ctrl> \n\
+ where <ctrl> 0 - Disable, 1 - Enable (default) \n\
+--interbss <ctrl> \n\
+ where <ctrl> 0 - Disable, 1 - Enable (default) \n\
+--apgetstats \n\
+--apclearstats \n\
+--acsdisablehichannels <0/1> \n\
+ where 0 - ACS will choose 1, 6 or 11 \n\
+ 1 - ACS will choose 1, 6 or 11 \n\
+--commit \n\
+--ip arg, arg may be \n\
+ none - resets ip \n\
+ x.x.x.x - ip addr is dotted form\n\
+--set_ht_cap <band> <enable> <supported channel width set> <short GI 20MHz> <short GI 40MHz> <40MHz intolerant> <max AMPDU len exponent> \n\
+ where <band> : 'g' for 2.4 GHZ or 'a' for 5GHZ \n\
+ <enable> : 0 to disable 11n in band, 1 to enable 11n in band \n\
+ <supported channel width set> : 0 if only 20MHz operation supported \n\
+ 1 if 20MHz and 40MHz operation supported \n\
+ <short GI 20MHz> : 0 if not supported, 1 if supported \n\
+ <short GI 40MHz> : 0 if not supported, 1 if supported \n\
+ <40MHz intolerant> : 1 if prohibit a receing AP from operating as a 20/40 MHz BSS \n\
+ 0 otherwise \n\
+ <max AMPDU len exponent> : valid values from 0 to 3 \n\
+--dump_recv_aggr_stats \n\
+--setup_aggr <tid> <aid> \n\
+ where <aid> = aid of a connected STA. Ignored in STA mode \n\
+--allow_aggr <tx_tid_mask> <rx_tid_mask> \n\
+--dele_aggr <tid> <direction> <aid> \n\
+ where <direction> =1 uplink; \n\
+ =0 dnlink \n\
+ <aid> = aid of a connected STA. Ignored in STA mode \n\
+--set_ht_op <STA channel width> : 0 if only allow 20MHz channel width\n\
+ 1 if allow any channel width in the supported channel width set \n\
+--wlan_conn_prec <prec_val> \n\
+ where 0: WLAN connection will have precedence;\n\
+ 1: PAL connection will have precedence;\n\
+--settxselrates <11A ratemask> <11G ratemask> <11B ratemask> <11GOnly ratemask> <11A_HT20 ratemask> <11G_HT20 ratemask> \
+<11A_HT40 ratemask> <11G_HT40 ratemask> where all rate masks are hex integers. \n\
+--aprateset <val> \n\
+ where 1: RateSet#1 - 1,2,5.5,11 basic rates (default)\n\
+ 2: RateSet#2 - 1,2,5.5,11,6,12,24 basic rates\n\
+--connect <ssid> \n\
+--connect <ssid> --wpa <ver> <ucipher> <mcipher> <psk> \n\
+--connect <ssid> --wep <mode> <def_keyix> <key1> <key2*> <key3*> <key4*> \n\
+ where <ssid> : SSID of network \n\
+ <ver> : 1 - WPA, 2 - RSN \n\
+ <ucipher> : TKIP or CCMP for unicast \n\
+ <mcipher> : TKIP or CCMP for multicast \n\
+ <psk> : passphrase for WPA \n\
+ <mode> : open or shared \n\
+ <def_keyix>: Default TX wep key index [1-4] \n\
+ <key> : wep key \n\
+ * : optional parameters \n\
+--set_tx_sgi --masksgi <mask> --persgi <value> \n\
+ where <mask> is a 32 bit hexadecimal value (eg: 0x0808000 or 08080000) to select desired MCS and ht20/ht40 SGI implementation (refer spec for bit location of each MCS)\n\
+ For disabling SGI enter 0x00000000 or 0.\n\
+ If mask is not entered, the default mask is 0x08080000 which enables MCS 7 to use SGI for both ht20 and ht40, when set_tx_sgi command is issued \n\
+ where <value> is the acceptable loss percentage for Packet Error Rate (PER) for SGI (default : 10)\n\
+--set_dfs <enable> \n\
+ where <enable> : 1 to allow DFS \n\
+ : 0 to disable DFS \n\
+--setdivparam <idleTime> <RSSIThresh> <Enable> <Threshold Rate> \n\
+ where <idleTime> : time in ms where the idle timer would start checking the other antenna (default: 10000) \n\
+ <RSSIThresh> : in db, where the firmware will check the other antenna if the RSSI drops below this delta (default: 10) \n\
+ <Enable> : 1 to enable diversity \n\
+ <Threshold Rate> : in Mbps, where the firmware will block the idleTimer if the throughput is above this rate (default 48) \n\
+--scanprobedssid <ssid> where <ssid> is the wireless network string to scan. Broadcast probe will not be sent . Set ssid to 'off' or 'any' to send broadcast probe requests \n\
+--ap_apsd <value> \n\
+ where value 1-Enable, 0-Disable \n\
+--get_ht_cap <band> \n\
+ where <band> : 'g' for 2.4 GHZ or 'a' for 5GHZ \n\
+--set_mcast_rate <value> \n\
+ where value is rate in units of 100 Kbps \n\
+ Valid values are 10, 20, 55, 110, 60, 90, 120, 180, 240, 360, 480, 540 \n\
+--enablevoicedetection <enable> \n\
+ where <enable> : 1 to enable voice detection \n\
+ : 0 to disable voice detection \n\
+--txe-notify <rate> <pkts> <intvl> \n\
+ send a TXE_NOTIFY_EVENT when <rate>% of <pkts> in given <intvl> fail to be transmitted to current AP.\n\
+--setrecoverysim <type> <delay_time_ms> \n\
+ where <type> : 1 assert \n\
+ : 2 not respond detect command \n\
+ : 3 simulate ep-full (disable wmi control ep), use 'echo 60>keepalive' trigger\n\
+ : 4 null access \n\
+ : 5: stack overflow\n\
+ <delay_time_ms> : 0~65534 ,delay time ms\n\
+ : 65535 ,delay random time( 0~65535) ms\n\
+--disablebcast <enable> \n\
+--blwl <control> <index> <mac> \n\
+ where <control>: 0 disable blwl \n\
+ : 1 enable blwl \n\
+ : 2 add white mac \n\
+ : 3 add black mac \n\
+ : 4 reset whitelist \n\
+ : 5 reset blacklist \n\
+ <index> : valid when control=2 3 4 5, mac address index [0,9] \n\
+ <mac> : valid when control=2 3 4 5, mac address xx:xx:xx:xx:xx:xx \n\
+--setrssifilter <snr_value> \n\
+ where <snr_value> : 0~127 the rssi value, (DBM: value-95dbm) \n\
+";
+
+A_UINT32 mercuryAdd[5][2] = {
+ {0x20000, 0x200fc},
+ {0x28000, 0x28800},
+ {0x20800, 0x20a40},
+ {0x21000, 0x212f0},
+ {0x500000, 0x500000+184*1024},
+ };
+
+typedef struct chip_internal_t{
+ A_UINT32 addr_st;
+ A_UINT32 addr_end;
+ A_UINT8 *info;
+}CHIP_INTERNAL;
+
+CHIP_INTERNAL venus_internal[8] = {
+ {0x20000, 0x200fc, (A_UINT8 *)"General DMA and recv related registers"},
+ {0x28000, 0x28900, (A_UINT8 *)"MAC PCU register & keycache"},
+ {0x20800, 0x20a40, (A_UINT8 *)"QCU"},
+ {0x21000, 0x212f0, (A_UINT8 *)"DCU"},
+ {0x4000, 0x42e4, (A_UINT8 *)"RTC"},
+ {0x540000, 0x540000+256*1024, (A_UINT8 *)"RAM"},
+ {0x29800, 0x2B210, (A_UINT8 *)"BB"},
+ {0x1C000, 0x1C748, (A_UINT8 *)"Analog"},
+ };
+
+
+
+static void
+usage(void)
+{
+ fprintf(stderr, "usage:\n%s [-i device] commands\n", progname);
+ fprintf(stderr, "%s\n", commands);
+#ifdef ATH_INCLUDE_PAL
+ fprintf(stderr, "%s\n", palcommands);
+#endif
+ fprintf(stderr, "The options can be given in any order\n");
+ exit(-1);
+}
+
+/* List of Country codes */
+char *my_ctr[] = {
+ "DB", "NA", "AL", "DZ", "AR", "AM", "AU", "AT", "AZ", "BH", "BY", "BE", "BZ", "BO", "BR", "BN",
+ "BG", "CA", "CL", "CN", "CO", "CR", "HR", "CY", "CZ", "DK", "DO", "EC", "EG", "SV", "EE", "FI",
+ "FR", "GE", "DE", "GR", "GT", "HN", "HK", "HU", "IS", "IN", "ID", "IR", "IE", "IL", "IT", "JP",
+ "JO", "KZ", "KP", "KR", "K2", "KW", "LV", "LB", "LI", "LT", "LU",
+ "MO", "MK", "MY", "MX", "MC", "MA", "NL", "NZ", "NO", "OM", "PK", "PA", "PE", "PH", "PL", "PT",
+ "PR", "QA", "RO", "RU", "SA", "SG", "SK", "SI", "ZA", "ES", "SE", "CH", "SY", "TW", "TH", "TT",
+ "TN", "TR", "UA", "AE", "GB", "US", "UY", "UZ", "VE", "VN", "YE", "ZW"
+ };
+
+const char *targ_reg_name[] = {
+"zero", "pc", "lbeg", "lend", "lcount", "sar", "litbaddr", "ps",
+"brtarg", "epc1", "epc2", "epc3", "epc4", "windowbase", "windowstart", "zero",
+"zero", "zero", "zero", "zero", "zero", "zero", "zero", "zero",
+"zero", "zero", "zero", "zero", "zero", "zero", "zero", "zero",
+"ar0", "ar1", "ar2", "ar3", "ar4", "ar5", "ar6", "ar7",
+"ar8", "ar9", "ar10", "ar11", "ar12", "ar13", "ar14", "ar15",
+"ar16", "ar17", "ar18", "ar19", "ar20", "ar21", "ar22", "ar23",
+"ar24", "ar25", "ar26", "ar27", "ar28", "ar29", "ar30", "ar31",
+};
+
+#ifdef ATH_INCLUDE_PAL
+
+A_INT32
+get_input_choice(char *fname,A_UINT8 *pdu, A_UINT16 *sz)
+{
+ int fhdl;
+ A_INT32 ret = -1;
+ fhdl = open(fname, O_RDONLY);
+ if(fhdl != -1)
+ {
+ *sz = read(fhdl, pdu,MAX_BUFFER_SIZE);
+ close(fhdl);
+ ret = 0;
+ }
+ return ret;
+}
+
+
+#endif
+int
+main (int argc, char **argv)
+{
+ int c, error;
+ char ifname[IFNAMSIZ];
+ unsigned int cmd = 0;
+ progname = argv[0];
+ char *buf = malloc(sizeof(PACKET_LOG));
+ int clearstat = 0;
+
+
+WMI_DISABLE_BCAST_IN_PM_CMD *disableBcastCmd = (WMI_DISABLE_BCAST_IN_PM_CMD *) (buf+4);
+ WMI_LISTEN_INT_CMD *listenCmd = (WMI_LISTEN_INT_CMD*)buf;
+ WMI_BMISS_TIME_CMD *bmissCmd = (WMI_BMISS_TIME_CMD*)buf;
+
+ WMI_POWER_MODE_CMD *pwrCmd = (WMI_POWER_MODE_CMD *)buf;
+ WMI_SET_MCAST_FILTER_CMD *sMcastFilterCmd = (WMI_SET_MCAST_FILTER_CMD *)(buf + 4);
+ WMI_MCAST_FILTER_CMD *mcastFilterCmd = (WMI_MCAST_FILTER_CMD *)(buf + 4);
+ WMI_IBSS_PM_CAPS_CMD *adhocPmCmd = (WMI_IBSS_PM_CAPS_CMD *)buf;
+ WMI_AP_PS_CMD *apPsCmd = (WMI_AP_PS_CMD *)(buf + 4);
+ WMI_SCAN_PARAMS_CMD *sParamCmd = (WMI_SCAN_PARAMS_CMD *)(buf + 4);
+ WMI_BSS_FILTER_CMD *filterCmd = (WMI_BSS_FILTER_CMD *)buf;
+ WMI_CHANNEL_PARAMS_CMD *chParamCmd = (WMI_CHANNEL_PARAMS_CMD *)buf;
+ WMI_POWER_PARAMS_CMD *pmParamCmd = (WMI_POWER_PARAMS_CMD *)buf;
+ WMI_ADD_BAD_AP_CMD *badApCmd = (WMI_ADD_BAD_AP_CMD *)buf;
+ WMI_CREATE_PSTREAM_CMD *crePStreamCmd = (WMI_CREATE_PSTREAM_CMD *)buf;
+ WMI_DELETE_PSTREAM_CMD *delPStreamCmd = (WMI_DELETE_PSTREAM_CMD *)buf;
+ USER_RSSI_PARAMS *rssiThresholdParam = (USER_RSSI_PARAMS *)(buf + 4);
+ WMI_SNR_THRESHOLD_PARAMS_CMD *snrThresholdParam = (WMI_SNR_THRESHOLD_PARAMS_CMD *)buf;
+ WMI_LQ_THRESHOLD_PARAMS_CMD *lqThresholdParam = (WMI_LQ_THRESHOLD_PARAMS_CMD *)(buf + 4);
+ WMI_TARGET_ERROR_REPORT_BITMASK *pBitMask =
+ (WMI_TARGET_ERROR_REPORT_BITMASK *)buf;
+ WMI_SET_ASSOC_INFO_CMD *ieInfo = (WMI_SET_ASSOC_INFO_CMD *)buf;
+ WMI_SET_ACCESS_PARAMS_CMD *acParamsCmd = (WMI_SET_ACCESS_PARAMS_CMD *)buf;
+ WMI_DISC_TIMEOUT_CMD *discCmd = (WMI_DISC_TIMEOUT_CMD *)(buf + 4);
+ WMI_SET_ADHOC_BSSID_CMD *adhocBssidCmd = (WMI_SET_ADHOC_BSSID_CMD *)(buf + 4);
+ WMI_BEACON_INT_CMD *bconIntvl = (WMI_BEACON_INT_CMD *)(buf + 4);
+ WMI_SET_RETRY_LIMITS_CMD *setRetryCmd = (WMI_SET_RETRY_LIMITS_CMD *)(buf + 4);
+ WMI_START_SCAN_CMD *startScanCmd = (WMI_START_SCAN_CMD *)(buf + 4);
+ WMI_SET_LPREAMBLE_CMD *setLpreambleCmd = (WMI_SET_LPREAMBLE_CMD *)(buf + 4);
+ WMI_SET_RTS_CMD *setRtsCmd = (WMI_SET_RTS_CMD *)(buf + 4);
+ struct ar6000_queuereq *getQosQueueCmd = (struct ar6000_queuereq *)buf;
+ WMI_SET_VOICE_PKT_SIZE_CMD *pSizeThresh = (WMI_SET_VOICE_PKT_SIZE_CMD *)(buf + sizeof(int));
+ WMI_SET_MAX_SP_LEN_CMD *pMaxSP = (WMI_SET_MAX_SP_LEN_CMD *)(buf + sizeof(int));
+ WMI_SET_ROAM_CTRL_CMD *pRoamCtrl = (WMI_SET_ROAM_CTRL_CMD *)(buf +
+ sizeof(int));
+ WMI_POWERSAVE_TIMERS_POLICY_CMD *pPowerSave = (WMI_POWERSAVE_TIMERS_POLICY_CMD *)(buf + sizeof(int));
+ WMI_SET_BT_STATUS_CMD *pBtStatCmd = (WMI_SET_BT_STATUS_CMD *) (buf + sizeof(int));
+ WMI_SET_BT_PARAMS_CMD *pBtParmCmd = (WMI_SET_BT_PARAMS_CMD *) (buf + sizeof(int));
+ WMI_SET_BTCOEX_FE_ANT_CMD *pBtcoexFeAntCmd = (WMI_SET_BTCOEX_FE_ANT_CMD *) (buf + sizeof(int));
+ WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD *pBtcoexCoLocatedBtCmd = (WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD *) (buf + sizeof(int));
+ WMI_SET_BTCOEX_SCO_CONFIG_CMD *pBtcoexScoConfigCmd = (WMI_SET_BTCOEX_SCO_CONFIG_CMD *) (buf + sizeof(int));
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD *pBtcoexbtinquiryPageConfigCmd = (WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD *) (buf + sizeof(int));
+ AR6000_BTCOEX_CONFIG *pBtcoexConfig = (AR6000_BTCOEX_CONFIG *) (buf + sizeof(int));
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMD *pBtcoexA2dpConfigCmd = (WMI_SET_BTCOEX_A2DP_CONFIG_CMD *) (buf + sizeof(int));
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD *pBtcoexAclCoexConfigCmd = (WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD *) (buf + sizeof(int));
+ WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD *pBtcoexBtOperatingStatusCmd = (WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD *) (buf + sizeof(int));
+ WMI_SET_WMM_CMD *setWmmCmd = (WMI_SET_WMM_CMD *)(buf + 4);
+ WMI_SET_QOS_SUPP_CMD *qosSupp = (WMI_SET_QOS_SUPP_CMD *)(buf +4);
+ WMI_SET_HB_CHALLENGE_RESP_PARAMS_CMD *hbparam = (WMI_SET_HB_CHALLENGE_RESP_PARAMS_CMD *)(buf + 4);
+ A_UINT32 *cookie = (A_UINT32 *)(buf + 4);
+ A_UINT32 *diagaddr = (A_UINT32 *)(buf + 4);
+ A_UINT32 *diagdata = (A_UINT32 *)(buf + 8);
+ WMI_SET_WMM_TXOP_CMD *pTxOp = (WMI_SET_WMM_TXOP_CMD *)(buf + sizeof(int));
+ WMI_AP_SET_COUNTRY_CMD *pCountry = (WMI_AP_SET_COUNTRY_CMD *)(buf + sizeof(int));
+ WMI_SET_KEEPALIVE_CMD_EXT *setKeepAlive = (WMI_SET_KEEPALIVE_CMD_EXT *)(buf + 4);
+ struct ieee80211req_getset_appiebuf *appIEInfo = (struct ieee80211req_getset_appiebuf *)(buf + 4);
+ A_UINT32 *pMgmtFilter = (A_UINT32 *)(buf + 4);
+ DBGLOG_MODULE_CONFIG *dbglogCfg = (DBGLOG_MODULE_CONFIG *)(buf + 4);
+
+ WMI_SET_HOST_SLEEP_MODE_CMD *hostSleepModeCmd = (WMI_SET_HOST_SLEEP_MODE_CMD*)(buf + sizeof(int));
+ WMI_SET_WOW_MODE_CMD *wowModeCmd = (WMI_SET_WOW_MODE_CMD*)(buf + sizeof(int));
+ WMI_ADD_WOW_PATTERN_CMD *addWowCmd = (WMI_ADD_WOW_PATTERN_CMD*)(buf + sizeof(int));
+ WMI_DEL_WOW_PATTERN_CMD *delWowCmd = (WMI_DEL_WOW_PATTERN_CMD*)(buf + sizeof(int));
+ WMI_GET_WOW_LIST_CMD *getWowListCmd = (WMI_GET_WOW_LIST_CMD*)(buf + sizeof(int));
+ AR6000_USER_SETKEYS_INFO *user_setkeys_info =
+ (AR6000_USER_SETKEYS_INFO *)(buf + sizeof(int));
+ WMI_SET_AKMP_PARAMS_CMD *akmpCtrlCmd =
+ (WMI_SET_AKMP_PARAMS_CMD *)(buf + sizeof(int));
+ WMI_SET_TARGET_EVENT_REPORT_CMD *evtCfgCmd = (WMI_SET_TARGET_EVENT_REPORT_CMD *) (buf + sizeof(int));
+ WMI_ENABLE_SMPS_CMD *setDfsCmd = (WMI_ENABLE_SMPS_CMD*)(buf + 4);
+ pmkidUserInfo_t pmkidUserInfo;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ struct ieee80211req_addpmkid *pi_cmd = (struct ieee80211req_addpmkid *)buf;
+
+ int i, index = 0, channel, chindex;//, cnt;
+ A_INT16 threshold[26]; /* user can set rssi tags */
+ A_UINT16 *clist;
+ A_UCHAR *ssid;
+ char *ethIf;
+
+ WMI_AP_HIDDEN_SSID_CMD *pHidden = (WMI_AP_HIDDEN_SSID_CMD *)(buf + 4);
+ WMI_AP_ACL_MAC_CMD *pACL = (WMI_AP_ACL_MAC_CMD *)(buf + 4);
+ WMI_AP_NUM_STA_CMD *pNumSta = (WMI_AP_NUM_STA_CMD *)(buf + 4);
+ WMI_AP_CONN_INACT_CMD *pInact = (WMI_AP_CONN_INACT_CMD *)(buf + 4);
+ WMI_AP_PROT_SCAN_TIME_CMD *pProt = (WMI_AP_PROT_SCAN_TIME_CMD *)(buf + 4);
+ struct ieee80211req_mlme *pMlme = (struct ieee80211req_mlme *)buf;
+ WMI_AP_SET_DTIM_CMD *pDtim = (WMI_AP_SET_DTIM_CMD *)(buf + 4);
+ WMI_AP_ACL_POLICY_CMD *pACLpolicy = (WMI_AP_ACL_POLICY_CMD *)(buf + 4);
+ A_UINT8 *intra = (A_UINT8 *)(buf + 4);
+ WMI_ADDBA_REQ_CMD *pAddbaReq = (WMI_ADDBA_REQ_CMD *)(buf + 4);
+ WMI_ALLOW_AGGR_CMD *pAllowAggr = (WMI_ALLOW_AGGR_CMD *)(buf + 4);
+ WMI_DELBA_REQ_CMD *pDeleteAggr = (WMI_DELBA_REQ_CMD *)(buf + 4);
+ WMI_SET_BT_WLAN_CONN_PRECEDENCE *prec = (WMI_SET_BT_WLAN_CONN_PRECEDENCE *) (buf + 4);
+ WMI_AP_SET_11BG_RATESET_CMD *pAPrs = (WMI_AP_SET_11BG_RATESET_CMD *) (buf + 4);
+ WMI_SET_TX_SGI_PARAM_CMD *set_txsgiparam = (WMI_SET_TX_SGI_PARAM_CMD *) (buf + 4);
+ WMI_DIV_PARAMS_CMD *pDiversity = (WMI_DIV_PARAMS_CMD *)(buf + 4);
+ WMI_AP_SET_APSD_CMD *pApApsd = (WMI_AP_SET_APSD_CMD *)(buf + 4);
+ WMI_SET_MCASTRATE_CMD *pMcast = (WMI_SET_MCASTRATE_CMD *)(buf + 4);
+ WMI_VOICE_DETECTION_ENABLE_CMD *pVoiceDetectionEnable = (WMI_VOICE_DETECTION_ENABLE_CMD *)(buf + 4);
+ WMI_SET_TXE_NOTIFY_CMD *pTXe = (WMI_SET_TXE_NOTIFY_CMD *)(buf + 4);
+ WMI_SET_RECOVERY_TEST_PARAMETER_CMD *pSetRecoveryParam = (WMI_SET_RECOVERY_TEST_PARAMETER_CMD*)(buf + 4);
+ WMI_SET_RSSI_FILTER_CMD *pSetRssiFilter = (WMI_SET_RSSI_FILTER_CMD*)(buf + 4);
+ WMI_PROBED_SSID_CMD *pSsidCmd = (WMI_PROBED_SSID_CMD*)(buf + 4);
+ profile_t cp;
+ A_UINT8 *pWpaOffloadState = (A_UINT8 *) (buf + 4);
+ A_UINT32 *pExcessTxRetryThres = (A_UINT32 *)(buf + 4);
+
+ if (argc == 1) {
+ usage();
+ }
+
+ memset(buf, 0, sizeof(buf));
+ memset(ifname, '\0', IFNAMSIZ);
+ if ((ethIf = getenv("NETIF")) == NULL) {
+ ethIf = "eth1";
+ }
+ while (1) {
+ int option_index = 0;
+ static struct option long_options[] = {
+ {"it", 1, NULL, 'a'},
+ {"bg", 1, NULL, 'b'},
+ {"np", 1, NULL, 'c'},
+ {"dp", 1, NULL, 'd'},
+ {"fgend", 1, NULL, 'e'},
+ {"filter", 1, NULL, 'f'},
+ {"fgstart", 1, NULL, 'g'},
+ {"maxact", 1, NULL, 'h'},
+ {"interface", 1, NULL, 'i'},
+ {"createqos", 1, NULL, 'j'},
+ {"deleteqos", 1, NULL, 'k'},
+ {"listen", 1, NULL, 'l'},
+ {"listenbeacons", 1, NULL, 'N'},
+ {"pmparams", 0, NULL, 'm'},
+ {"num", 1, NULL, 'n'},
+ {"qosqueue", 1, NULL, 'o'},
+ {"power", 1, NULL, 'p'},
+ {"pas", 1, NULL, 'q'},
+ {"scan", 0, NULL, 's'},
+ {"sr", 1, NULL, 'r'},
+ {"ssid", 1, NULL, 't'},
+ {"rssiThreshold", 1, NULL, 'u'},
+ {"snrThreshold", 1, NULL, WMI_SET_SNR_THRESHOLDS},
+ {"cleanRssiSnr", 0, NULL, WMI_CLR_RSSISNR},
+ {"lqThreshold", 1, NULL, WMI_SET_LQ_THRESHOLDS},
+ {"version", 0, NULL, 'v'}, //WMI_GET_VERSION
+ {"wmode", 1, NULL, 'w'},
+ {"badAP", 1, NULL, 'x'},
+ {"clrAP", 0, NULL, 'y'},
+ {"minact", 1, NULL, 'z'},
+ {"getTargetStats", 0, NULL, WMI_GET_TARGET_STATS},
+ {"setErrorReportingBitmask", 1, NULL,
+ WMI_SET_TARGET_ERROR_REPORTING_BITMASK},
+ {"acparams", 0, NULL, WMI_SET_AC_PARAMS},
+ {"acval", 1, NULL, WMI_SET_AC_VAL},
+ {"txop", 1, NULL, 'A'},
+ {"cwmin", 1, NULL, 'B'},
+ {"cwmax", 1, NULL, 'C'},
+ {"aifsn", 1, NULL, 'D'},
+ {"ps", 1, NULL, 'E'},
+ {"aw", 1, NULL, 'F'},
+ {"adhocbssid", 1, NULL, 'G'},
+ {"mode", 1, NULL, 'H'},
+ {"sendframe", 1, NULL, 'I'},
+ {"wlan", 1, NULL, 'J'},
+ {"to", 1, NULL, 'K'},
+ {"ttl", 1, NULL, 'L'},
+ {"scanctrlflags", 1, NULL, 'O'},
+ {"homeDwellTime", 1, NULL, 'P'},
+ {"forceScanInt", 1, NULL, 'Q'},
+ {"forceScanFlags",1, NULL, 'R'},
+ {"threshold", 1, NULL, 'S'},
+ {"frequency", 1, NULL, 'T'},
+ {"cookie", 1, NULL, 'U'},
+ {"mmask", 1, NULL, 'V'},
+ {"rep", 1, NULL, 'W'},
+ {"tsr", 1, NULL, 'X'},
+ {"size", 1, NULL, 'Y'},
+ {"bssid",1, NULL, WMI_BSSID},
+ {"initrsc", 1, NULL, USER_SETKEYS_INITRSC},
+ {"multipmkid", 1, NULL, WMI_AKMP_MULTI_PMKID},
+ {"numpmkid", 1, NULL, WMI_NUM_PMKID},
+ {"pmkid", 1, NULL, WMI_PMKID_ENTRY},
+ {"clearStats", 0, NULL, 'Z'},
+ {"maxact2pas", 1, NULL, WMI_SCAN_DFSCH_ACT_TIME},
+ {"maxactscan_ssid", 1, NULL, WMI_SCAN_MAXACT_PER_SSID},
+ {"ibsspmcaps", 0, NULL, WMI_SET_IBSS_PM_CAPS},
+ {"appsparams", 0, NULL, WMI_SET_AP_PS},
+ {"setAssocIe", 1, NULL, WMI_SET_ASSOC_IE},
+ {"setbmisstime", 1, NULL, WMI_SET_BMISS_TIME},
+ {"setbmissbeacons", 1, NULL, 'M'},
+ {"disc", 1, NULL, WMI_SET_DISC_TIMEOUT},
+ {"beaconintvl", 1, NULL, WMI_SET_BEACON_INT},
+ {"setVoicePktSize", 1, NULL, WMI_SET_VOICE_PKT_SIZE},
+ {"setMaxSPLength", 1, NULL, WMI_SET_MAX_SP},
+ {"getroamtable", 0, NULL, WMI_GET_ROAM_TBL},
+ {"roam", 1, NULL, WMI_SET_ROAM_CTRL},
+ {"psparams", 0, NULL, WMI_SET_POWERSAVE_TIMERS},
+ {"psPollTimer", 1, NULL, WMI_SET_POWERSAVE_TIMERS_PSPOLLTIMEOUT},
+ {"triggerTimer", 1, NULL, WMI_SET_POWERSAVE_TIMERS_TRIGGERTIMEOUT},
+ {"getpower", 0, NULL, WMI_GET_POWER_MODE},
+ {"getroamdata", 0, NULL, WMI_GET_ROAM_DATA},
+ {"setBTstatus", 1, NULL, WMI_SET_BT_STATUS},
+ {"setBTparams", 1, NULL, WMI_SET_BT_PARAMS},
+ {"setbtcoexfeant", 1, NULL, WMI_SET_BTCOEX_FE_ANT},
+ {"setbtcoexcolocatedbt", 1, NULL, WMI_SET_BTCOEX_COLOCATED_BT_DEV},
+ {"setbtcoexscoconfig", 1, NULL, WMI_SET_BTCOEX_SCO_CONFIG},
+ {"setbtcoexa2dpconfig", 1, NULL, WMI_SET_BTCOEX_A2DP_CONFIG},
+ {"setbtcoexaclcoexconfig", 1, NULL, WMI_SET_BTCOEX_ACLCOEX_CONFIG},
+ {"setbtcoexbtinquirypageconfig", 1, NULL, WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG},
+ {"setbtcoexbtoperatingstatus", 1, NULL, WMI_SET_BTCOEX_BT_OPERATING_STATUS},
+ {"getbtcoexconfig",1,NULL, WMI_GET_BTCOEX_CONFIG},
+ {"getbtcoexstats", 0, NULL, WMI_GET_BTCOEX_STATS},
+ {"setretrylimits", 1, NULL, WMI_SET_RETRYLIMITS},
+ {"startscan", 0, NULL, WMI_START_SCAN},
+ {"setfixrates", 1, NULL, WMI_SET_FIX_RATES},
+ {"getfixrates", 0, NULL, WMI_GET_FIX_RATES},
+ {"setauthmode", 1, NULL, WMI_SET_AUTH_MODE},
+ {"setreassocmode", 1, NULL, WMI_SET_REASSOC_MODE},
+ {"setlongpreamble", 1, NULL, WMI_SET_LPREAMBLE},
+ {"setRTS", 1, NULL, WMI_SET_RTS},
+ {"setwmm", 1, NULL, WMI_SET_WMM},
+ {"setqos", 1, NULL, WMI_SET_QOS_SUPP},
+ {"apsdTimPolicy", 1, NULL, WMI_APSD_TIM_POLICY},
+ {"simulatedAPSDTimPolicy", 1, NULL, WMI_SIMULATED_APSD_TIM_POLICY},
+ {"detecterror", 0, NULL, WMI_SET_ERROR_DETECTION},
+ {"getheartbeat", 0, NULL, WMI_GET_HB_CHALLENGE_RESP},
+#ifdef USER_KEYS
+ {"usersetkeys", 0, NULL, USER_SETKEYS},
+#endif
+ {"getRD", 0, NULL, WMI_GET_RD},
+ {"setcountry", 1, NULL, WMI_AP_SET_COUNTRY},
+ {"countrycodes", 0, NULL, WMI_AP_GET_COUNTRY_LIST},
+ {"disableregulatory", 0, NULL, WMI_AP_DISABLE_REGULATORY},
+ {"txopbursting", 1, NULL, WMI_SET_TXOP},
+ {"diagaddr", 1, NULL, DIAG_ADDR},
+ {"diagdata", 1, NULL, DIAG_DATA},
+ {"diagread", 0, NULL, DIAG_READ},
+ {"diagwrite", 0, NULL, DIAG_WRITE},
+ {"setkeepalive", 1, NULL, WMI_SET_KEEPALIVE},
+ {"getkeepalive", 0, NULL, WMI_GET_KEEPALIVE},
+ {"setappie", 1, NULL, WMI_SET_APPIE},
+ {"setmgmtfilter", 1, NULL, WMI_SET_MGMT_FRM_RX_FILTER},
+ {"setdbglogconfig", 0, NULL, WMI_DBGLOG_CFG_MODULE},
+ {"getdbglogs", 0, NULL, WMI_DBGLOG_GET_DEBUG_LOGS},
+ {"sethostmode", 1, NULL, WMI_SET_HOST_SLEEP_MODE},
+ {"setwowmode", 1, NULL, WMI_SET_WOW_MODE},
+ {"wowfilter",1,NULL,WMI_SET_WOW_FILTER},
+ {"hostreqdelay",1,NULL,WMI_SET_WOW_HOST_REQ_DELAY},
+ {"getwowlist", 1, NULL, WMI_GET_WOW_LIST},
+ {"addwowpattern", 1, NULL, WMI_ADD_WOW_PATTERN},
+ {"delwowpattern", 1, NULL, WMI_DEL_WOW_PATTERN},
+ {"dumpchipmem", 0, NULL, DIAG_DUMP_CHIP_MEM},
+ {"dumpchipmem_venus", 0, NULL, DIAG_DUMP_CHIP_MEM_VENUS},
+ {"setconnectctrl", 1, NULL, WMI_SET_CONNECT_CTRL_FLAGS},
+ {"dumpcreditstates",0, NULL, DUMP_HTC_CREDITS},
+ {"setakmp", 0, NULL, WMI_SET_AKMP_INFO},
+ {"setpmkidlist", 0, NULL, WMI_SET_PMKID_LIST},
+ {"getpmkidlist", 0, NULL, WMI_GET_PMKID_LIST},
+ {"ieMask", 1, NULL, WMI_SET_IEMASK},
+ {"scanlist", 1, NULL, WMI_SCAN_CHANNEL_LIST},
+ {"setbsspmkid", 0, NULL, WMI_SET_BSS_PMKID_INFO},
+ {"bsspmkid", 1, NULL, WMI_BSS_PMKID_ENTRY},
+ {"abortscan", 0, NULL, WMI_ABORT_SCAN},
+ {"settgtevt", 1, NULL, WMI_TARGET_EVENT_REPORT},
+ {"getsta", 0, NULL, WMI_AP_GET_STA_LIST}, /* AP mode */
+ {"hiddenssid", 0, NULL, WMI_AP_HIDDEN_SSID}, /* AP mode */
+ {"numsta", 0, NULL, WMI_AP_SET_NUM_STA}, /* AP mode */
+ {"aclpolicy", 0, NULL, WMI_AP_ACL_POLICY}, /* AP mode */
+ {"addacl", 0, NULL, WMI_AP_ACL_MAC_LIST1}, /* AP mode */
+ {"delacl", 0, NULL, WMI_AP_ACL_MAC_LIST2}, /* AP mode */
+ {"getacl", 0, NULL, WMI_AP_GET_ACL_LIST}, /* AP mode */
+ {"commit", 0, NULL, WMI_AP_COMMIT_CONFIG}, /* AP mode */
+ {"conninact", 0, NULL, WMI_AP_INACT_TIME}, /* AP mode */
+ {"protectionscan", 0, NULL, WMI_AP_PROT_TIME}, /* AP mode */
+ {"removesta", 0, NULL, WMI_AP_SET_MLME}, /* AP mode */
+ {"dtim", 0, NULL, WMI_AP_SET_DTIM}, /* AP mode */
+ {"intrabss", 0, NULL, WMI_AP_INTRA_BSS}, /* AP mode */
+ {"interbss", 0, NULL, WMI_AP_INTER_BSS}, /* AP mode */
+ {"ip", 1, NULL, WMI_GET_IP},
+ {"setMcastFilter", 1, NULL, WMI_SET_MCAST_FILTER},
+ {"delMcastFilter", 1, NULL, WMI_DEL_MCAST_FILTER},
+ {"mcastFilter", 1, NULL, WMI_MCAST_FILTER},
+ {"dump_recv_aggr_stats",0, NULL, WMI_DUMP_RCV_AGGR_STATS},
+ {"setup_aggr", 2, NULL, WMI_SETUP_AGGR},
+ {"allow_aggr", 2, NULL, WMI_CFG_ALLOW_AGGR},
+ {"dele_aggr", 2, NULL, WMI_CFG_DELE_AGGR},
+ {"set_ht_cap",1, NULL, WMI_SET_HT_CAP},
+ {"set_ht_op",1, NULL, WMI_SET_HT_OP},
+ {"apgetstats", 0, NULL, WMI_AP_GET_STAT}, /* AP mode */
+ {"apclearstats", 0, NULL, WMI_AP_CLR_STAT}, /* AP mode */
+ {"settxselrates", 1, NULL, WMI_SET_TX_SELECT_RATES},
+ {"gethiddenssid", 0, NULL, WMI_AP_GET_HIDDEN_SSID}, /* AP mode */
+ {"getcountry", 0, NULL, WMI_AP_GET_COUNTRY}, /* AP mode */
+ {"getwmode", 0, NULL, WMI_AP_GET_WMODE},
+ {"getdtim", 0, NULL, WMI_AP_GET_DTIM}, /* AP mode */
+ {"getbeaconintvl", 0, NULL, WMI_AP_GET_BINTVL}, /* AP mode */
+ {"getRTS", 0, NULL, WMI_GET_RTS},
+ {"targregs", 0, NULL, DIAG_FETCH_TARGET_REGS},
+#ifdef ATH_INCLUDE_PAL
+ {"sendpalcmd", 2, NULL, WMI_SEND_PAL_CMD},
+ {"sendpaldata", 2, NULL, WMI_SEND_PAL_DATA},
+ {"wlan_conn_prec", 1, NULL, WMI_SET_WLAN_CONN_PRECDNCE},
+#endif
+ {"aprateset", 0, NULL, WMI_SET_AP_RATESET},
+ {"twp", 1, NULL, WMI_SET_TX_WAKEUP_POLICY},
+ {"nt", 1, NULL, WMI_SET_TX_NUM_FRAMES_TO_WAKEUP},
+ {"pstype", 1, NULL, WMI_SET_AP_PS_PSTYPE},
+ {"psit", 1, NULL, WMI_SET_AP_PS_IDLE_TIME},
+ {"psperiod", 1, NULL, WMI_SET_AP_PS_PS_PERIOD},
+ {"sleepperiod", 1, NULL, WMI_SET_AP_PS_SLEEP_PERIOD},
+ {"connect", 1, NULL, WMI_SEND_CONNECT_CMD},
+ {"wpa", 1, NULL, WMI_SEND_CONNECT_CMD1},
+ {"wep", 1, NULL, WMI_SEND_CONNECT_CMD2},
+ {"set_dfs", 1, NULL, WMI_AP_SET_DFS},
+ {"bt",1,NULL,BT_HW_POWER_STATE},
+ {"set_tx_sgi", 0, NULL, WMI_SET_TX_SGI_PARAM},
+ {"masksgi", 1, NULL, WMI_SGI_MASK},
+ {"persgi", 1, NULL, WMI_PER_SGI},
+ {"wac", 1, NULL, WMI_WAC_ENABLE},
+ {"setwpaoffload", 1, NULL, WMI_SET_WPA_OFFLOAD_STATE},
+ {"acsdisablehichannels", 0, NULL, WMI_AP_ACS_DISABLE_HI_CHANNELS},
+ {"setdivparam", 1, NULL, WMI_SET_DIVERSITY_PARAM},
+ {"setexcesstxretrythres", 1, NULL, WMI_SET_EXCESS_TX_RETRY_THRES},
+ {"forceAssert", 0, NULL, WMI_FORCE_ASSERT},
+ {"gnumsta", 0, NULL, WMI_AP_SET_GNUM_STA}, /* AP mode */
+ {"getgnumsta", 0, NULL, WMI_AP_GET_GNUM_STA}, /* AP mode */
+ {"getnumsta", 0, NULL, WMI_AP_GET_NUM_STA}, /* AP mode */
+ {"suspend", 0, NULL, WMI_SUSPEND_DRIVER},
+ {"resume", 0, NULL, WMI_RESUME_DRIVER},
+ {"scanprobedssid", 1, NULL, WMI_SCAN_PROBED_SSID},
+ {"ap_apsd", 0, NULL, WMI_AP_SET_APSD}, /* AP mode */
+ {"get_ht_cap", 0, NULL, WMI_GET_HT_CAP},
+ {"set_mcast_rate", 1, NULL, WMI_SET_MCASTRATE},
+ {"enablevoicedetection", 1, NULL, WMI_VOICE_DETECTION_ENABLE}, /* enable/disable voice detection command */
+ {"txe-notify", 1, NULL, WMI_SET_TXE_NOTIFY},
+ {"setrecoverysim", 0, NULL, WMI_SET_RECOVERY_SIMULATE}, /* set recovery simulation */
+{"disablebcast", 1, NULL, WMI_DISABLE_BCAST_IN_PM}, /* disable broadcast in power save */
+ {"blwl", 0, NULL, WMI_AP_BLWL}, /* AP mode */
+ {"setrssifilter", 0, NULL, WMI_SET_RSSI_FILTER},
+ {0, 0, 0, 0}
+ };
+
+ c = getopt_long(argc, argv, "rsvda:b:c:e:h:f:g:h:i:l:p:q:r:w:n:t:u:x:y:z:A:B:C:D:E:F:G:H:I:J:K:L:M:N:O:P:Q:R:S:T:U:V:W:X:Y:Z:", long_options, &option_index);
+ if (c == -1)
+ break;
+ switch (c) {
+ case 'a':
+ pmParamCmd->idle_period = atoi(optarg);
+ break;
+ case 'b':
+ if (!strcasecmp(optarg,"default")) {
+ sParamCmd->bg_period = 0;
+ } else {
+ sParamCmd->bg_period = atoi(optarg);
+ /* Setting the background scan to 0 or 65535 has the same effect
+ - it disables background scanning */
+ if(!sParamCmd->bg_period)
+ sParamCmd->bg_period = 65535;
+ }
+ break;
+ case 'c':
+ pmParamCmd->pspoll_number = atoi(optarg);
+ break;
+ case 'd':
+ if (!strcmp(optarg, "ignore")) {
+ pmParamCmd->dtim_policy = IGNORE_DTIM;
+ } else if (!strcmp(optarg, "normal")) {
+ pmParamCmd->dtim_policy = NORMAL_DTIM;
+ } else if (!strcmp(optarg, "stick")) {
+ pmParamCmd->dtim_policy = STICK_DTIM;
+ } else {
+ cmd = 0;
+ }
+ break;
+ case 'f':
+ cmd = WMI_SET_BSS_FILTER;
+ if (!strcmp(optarg, "none")) {
+ filterCmd->bssFilter = NONE_BSS_FILTER;
+ } else if (!strcmp(optarg, "all")) {
+ filterCmd->bssFilter = ALL_BSS_FILTER;
+ } else if (!strcmp(optarg, "profile")) {
+ filterCmd->bssFilter = PROFILE_FILTER;
+ } else if (!strcmp(optarg, "not_profile")) {
+ filterCmd->bssFilter = ALL_BUT_PROFILE_FILTER;
+ } else if (!strcmp(optarg, "bss")) {
+ filterCmd->bssFilter = CURRENT_BSS_FILTER;
+ } else if (!strcmp(optarg, "not_bss")) {
+ filterCmd->bssFilter = ALL_BUT_BSS_FILTER;
+ } else if (!strcmp(optarg, "ssid")) {
+ filterCmd->bssFilter = PROBED_SSID_FILTER;
+ } else {
+ cmd = 0;
+ }
+ break;
+ case 'e':
+ sParamCmd->fg_end_period = atoi(optarg);
+ break;
+ case 'g':
+ sParamCmd->fg_start_period = atoi(optarg);
+ break;
+ case 'h':
+ sParamCmd->maxact_chdwell_time = atoi(optarg);
+ break;
+ case 'q':
+ sParamCmd->pas_chdwell_time = atoi(optarg);
+ break;
+ case 'j':
+ cmd = WMI_CREATE_QOS;
+ crePStreamCmd->userPriority = atoi(optarg);
+ break;
+ case 'k':
+ cmd = WMI_DELETE_QOS;
+ delPStreamCmd->trafficClass = atoi(optarg);
+ break;
+ case 'l':
+ cmd = WMI_SET_LISTEN_INTERVAL;
+ listenCmd->listenInterval = atoi(optarg);
+ if ((listenCmd->listenInterval < MIN_LISTEN_INTERVAL) ||
+ (listenCmd->listenInterval > MAX_LISTEN_INTERVAL))
+ {
+ printf("Listen Interval out of range\n");
+ cmd = 0;
+ }
+ break;
+ case 'N':
+ cmd = WMI_SET_LISTEN_INTERVAL;
+ listenCmd->numBeacons = atoi(optarg);
+ if ((listenCmd->numBeacons < MIN_LISTEN_BEACONS) ||
+ (listenCmd->numBeacons > MAX_LISTEN_BEACONS))
+ {
+ printf("Listen beacons out of range\n");
+ cmd = 0;
+ }
+ break;
+ case 'm':
+ cmd = WMI_SET_PM_PARAMS;
+ break;
+ case 'n':
+ index = atoi(optarg);
+ break;
+ case 'v':
+ cmd = WMI_GET_VERSION;
+ break;
+ case 'o':
+ cmd = WMI_GET_QOS_QUEUE;
+ getQosQueueCmd->trafficClass = atoi(optarg);
+ break;
+ case 'p':
+ cmd = WMI_SET_POWER_MODE;
+ if (!strcmp(optarg, "rec")) {
+ pwrCmd->powerMode = REC_POWER;
+ } else if (!strcmp(optarg, "maxperf")) {
+ pwrCmd->powerMode = MAX_PERF_POWER;
+ } else {
+ cmd = 0;
+ }
+ break;
+ case WMI_FORCE_ASSERT:
+ cmd = WMI_FORCE_ASSERT;
+ break;
+ case WMI_SET_MCAST_FILTER:
+ cmd = WMI_SET_MCAST_FILTER;
+ sMcastFilterCmd->multicast_mac[0] = (unsigned int) atoi(argv[2]);
+ sMcastFilterCmd->multicast_mac[1] = (unsigned int) atoi(argv[3]);
+ sMcastFilterCmd->multicast_mac[2] = (unsigned int) atoi(argv[4]);
+ sMcastFilterCmd->multicast_mac[3] = (unsigned int) atoi(argv[5]);
+ sMcastFilterCmd->multicast_mac[4] = (unsigned int) atoi(argv[6]);
+ sMcastFilterCmd->multicast_mac[5] = (unsigned int) atoi(argv[7]);
+
+ printf("sMcastFilterCmd->multicast_mac[0] %d\n",sMcastFilterCmd->multicast_mac[0] );
+ printf("sMcastFilterCmd->multicast_mac[1] %d\n",sMcastFilterCmd->multicast_mac[1] );
+ printf("sMcastFilterCmd->multicast_mac[2] %d\n",sMcastFilterCmd->multicast_mac[2] );
+ printf("sMcastFilterCmd->multicast_mac[3] %d\n",sMcastFilterCmd->multicast_mac[3] );
+ printf("sMcastFilterCmd->multicast_mac[4] %d\n",sMcastFilterCmd->multicast_mac[4] );
+ printf("sMcastFilterCmd->multicast_mac[5] %d\n",sMcastFilterCmd->multicast_mac[5] );
+ break;
+ case WMI_DEL_MCAST_FILTER:
+ cmd = WMI_DEL_MCAST_FILTER;
+ sMcastFilterCmd->multicast_mac[0] = (unsigned int) atoi(argv[2]);
+ sMcastFilterCmd->multicast_mac[1] = (unsigned int) atoi(argv[3]);
+ sMcastFilterCmd->multicast_mac[2] = (unsigned int) atoi(argv[4]);
+ sMcastFilterCmd->multicast_mac[3] = (unsigned int) atoi(argv[5]);
+ sMcastFilterCmd->multicast_mac[4] = (unsigned int) atoi(argv[6]);
+ sMcastFilterCmd->multicast_mac[5] = (unsigned int) atoi(argv[7]);
+
+ printf("sMcastFilterCmd->multicast_mac[0] %d\n",sMcastFilterCmd->multicast_mac[0] );
+ printf("sMcastFilterCmd->multicast_mac[1] %d\n",sMcastFilterCmd->multicast_mac[1] );
+ printf("sMcastFilterCmd->multicast_mac[2] %d\n",sMcastFilterCmd->multicast_mac[2] );
+ printf("sMcastFilterCmd->multicast_mac[3] %d\n",sMcastFilterCmd->multicast_mac[3] );
+ printf("sMcastFilterCmd->multicast_mac[4] %d\n",sMcastFilterCmd->multicast_mac[4] );
+ printf("sMcastFilterCmd->multicast_mac[5] %d\n",sMcastFilterCmd->multicast_mac[5] );
+ break;
+ case WMI_MCAST_FILTER:
+ cmd = WMI_MCAST_FILTER;
+
+ mcastFilterCmd->enable = (unsigned int) atoi(argv[2]);
+ printf("Multicast Filter State: %s\n", mcastFilterCmd->enable ? "enable" : "disable");
+ break;
+ case 'r':
+ sParamCmd->shortScanRatio = atoi(optarg);
+ break;
+ case 's':
+ cmd = WMI_SET_SCAN_PARAMS;
+ sParamCmd->scanCtrlFlags = DEFAULT_SCAN_CTRL_FLAGS;
+ sParamCmd->shortScanRatio = WMI_SHORTSCANRATIO_DEFAULT;
+ sParamCmd->max_dfsch_act_time = 0 ;
+ break;
+ case WMI_SCAN_DFSCH_ACT_TIME:
+ sParamCmd->max_dfsch_act_time = atoi(optarg);
+ break;
+ case WMI_SCAN_MAXACT_PER_SSID:
+ sParamCmd->maxact_scan_per_ssid = atoi(optarg);
+ break;
+ case 't':
+ cmd = WMI_SET_SSID;
+ index = optind-1;
+ pSsidCmd->entryIndex =(A_UINT8)atoi(argv[index++]);
+ ssid = (A_UCHAR *)argv[index++];
+ break;
+ case 'u':
+ cmd = WMI_SET_RSSI_THRESHOLDS;
+ memset(threshold, 0, sizeof(threshold));
+ for (index = optind; index <= argc; index++)
+ threshold[index-optind] = atoi(argv[index-1]);
+
+ rssiThresholdParam->weight = threshold[0];
+ rssiThresholdParam->pollTime = threshold[1];
+ rssiThresholdParam->tholds[0].tag = threshold[2];
+ rssiThresholdParam->tholds[0].rssi = 0 - threshold[3];
+ rssiThresholdParam->tholds[1].tag = threshold[4];
+ rssiThresholdParam->tholds[1].rssi = 0 - threshold[5];
+ rssiThresholdParam->tholds[2].tag = threshold[6];
+ rssiThresholdParam->tholds[2].rssi = 0 - threshold[7];
+ rssiThresholdParam->tholds[3].tag = threshold[8];
+ rssiThresholdParam->tholds[3].rssi = 0 - threshold[9];
+ rssiThresholdParam->tholds[4].tag = threshold[10];
+ rssiThresholdParam->tholds[4].rssi = 0 - threshold[11];
+ rssiThresholdParam->tholds[5].tag = threshold[12];
+ rssiThresholdParam->tholds[5].rssi = 0 - threshold[13];
+ rssiThresholdParam->tholds[6].tag = threshold[14];
+ rssiThresholdParam->tholds[6].rssi = 0 - threshold[15];
+ rssiThresholdParam->tholds[7].tag = threshold[16];
+ rssiThresholdParam->tholds[7].rssi = 0 - threshold[17];
+ rssiThresholdParam->tholds[8].tag = threshold[18];
+ rssiThresholdParam->tholds[8].rssi = 0 - threshold[19];
+ rssiThresholdParam->tholds[9].tag = threshold[20];
+ rssiThresholdParam->tholds[9].rssi = 0 - threshold[21];
+ rssiThresholdParam->tholds[10].tag = threshold[22];
+ rssiThresholdParam->tholds[10].rssi = 0 - threshold[23];
+ rssiThresholdParam->tholds[11].tag = threshold[24];
+ rssiThresholdParam->tholds[11].rssi = 0 - threshold[25];
+
+ break;
+ case WMI_SET_SNR_THRESHOLDS:
+ cmd = WMI_SET_SNR_THRESHOLDS;
+ memset(threshold, 0, sizeof(threshold));
+ for (index = optind; index <= argc; index++)
+ threshold[index-optind] = atoi(argv[index-1]);
+
+ snrThresholdParam->weight = threshold[0];
+ snrThresholdParam->thresholdAbove1_Val = threshold[1];
+ snrThresholdParam->thresholdAbove2_Val = threshold[2];
+ snrThresholdParam->thresholdAbove3_Val = threshold[3];
+ snrThresholdParam->thresholdAbove4_Val = threshold[4];
+ snrThresholdParam->thresholdBelow1_Val = threshold[5];
+ snrThresholdParam->thresholdBelow2_Val = threshold[6];
+ snrThresholdParam->thresholdBelow3_Val = threshold[7];
+ snrThresholdParam->thresholdBelow4_Val = threshold[8];
+ snrThresholdParam->pollTime = threshold[9];
+ break;
+ case WMI_CLR_RSSISNR:
+ cmd = WMI_CLR_RSSISNR;
+ break;
+ case WMI_SET_LQ_THRESHOLDS:
+ cmd = WMI_SET_LQ_THRESHOLDS;
+ memset(threshold, 0, sizeof(threshold));
+ for (index = optind; index <= argc; index++)
+ threshold[index-optind] = atoi(argv[index-1]);
+
+ lqThresholdParam->enable = threshold[0];
+ lqThresholdParam->thresholdAbove1_Val = threshold[1];
+ lqThresholdParam->thresholdAbove2_Val = threshold[2];
+ lqThresholdParam->thresholdAbove3_Val = threshold[3];
+ lqThresholdParam->thresholdAbove4_Val = threshold[4];
+ lqThresholdParam->thresholdBelow1_Val = threshold[5];
+ lqThresholdParam->thresholdBelow2_Val = threshold[6];
+ lqThresholdParam->thresholdBelow3_Val = threshold[7];
+ lqThresholdParam->thresholdBelow4_Val = threshold[8];
+
+ break;
+ case 'i':
+ memset(ifname, '\0', 8);
+ strncpy(ifname, optarg, sizeof(ifname));
+ break;
+ case 'w':
+ cmd = WMI_SET_CHANNEL;
+ chParamCmd->numChannels = 0;
+ chParamCmd->scanParam = 0;
+ break;
+ case 'x':
+ if (wmic_ether_aton(optarg, badApCmd->bssid) != A_OK) {
+ printf("bad mac address\n");
+ break;
+ }
+ cmd = WMI_SET_BADAP;
+ break;
+ case 'y':
+ /*
+ * we are clearing a bad AP. We pass a null mac address
+ */
+ cmd = WMI_DELETE_BADAP;
+ break;
+ case 'z':
+ sParamCmd->minact_chdwell_time = atoi(optarg);
+ break;
+ case WMI_GET_TARGET_STATS:
+ cmd = WMI_GET_TARGET_STATS;
+ break;
+ case WMI_SET_TARGET_ERROR_REPORTING_BITMASK:
+ cmd = WMI_SET_TARGET_ERROR_REPORTING_BITMASK;
+ pBitMask->bitmask = atoi(optarg);
+ printf("Setting the bitmask = 0x%x\n", pBitMask->bitmask);
+ break;
+ case WMI_SET_ASSOC_IE:
+ cmd = WMI_SET_ASSOC_INFO_CMDID;
+ ieInfo->ieType = 1;
+ if (strlen(optarg) > WMI_MAX_ASSOC_INFO_LEN) {
+ printf("IE Size cannot be greater than %d\n",
+ WMI_MAX_ASSOC_INFO_LEN);
+ cmd = 0;
+ } else {
+ ieInfo->bufferSize = strlen(optarg) + 2;
+ memcpy(&ieInfo->assocInfo[2], optarg,
+ ieInfo->bufferSize - 2);
+ ieInfo->assocInfo[0] = 0xdd;
+ ieInfo->assocInfo[1] = ieInfo->bufferSize - 2;
+ }
+ break;
+ case WMI_SET_BMISS_TIME:
+ cmd = WMI_SET_BMISS_TIME;
+ bmissCmd->bmissTime = atoi(optarg);
+ if ((bmissCmd->bmissTime < MIN_BMISS_TIME) ||
+ (bmissCmd->bmissTime > MAX_BMISS_TIME))
+ {
+ printf("BMISS time out of range\n");
+ cmd = 0;
+ }
+ break;
+ case 'M':
+ cmd = WMI_SET_BMISS_TIME;
+ bmissCmd->numBeacons = atoi(optarg);
+ if ((bmissCmd->numBeacons < MIN_BMISS_BEACONS) ||
+ (bmissCmd->numBeacons > MAX_BMISS_BEACONS))
+ {
+ printf("BMISS beacons out of range\n");
+ cmd = 0;
+ }
+ break;
+
+ case WMI_SET_AC_PARAMS:
+ cmd = WMI_SET_AC_PARAMS;
+ break;
+ case WMI_SET_AC_VAL:
+ acParamsCmd->ac = atoi(optarg);
+ break;
+ case 'A':
+ acParamsCmd->txop = atoi(optarg);
+ break;
+ case 'B':
+ acParamsCmd->eCWmin = atoi(optarg);
+ break;
+ case 'C':
+ acParamsCmd->eCWmax = atoi(optarg);
+ break;
+ case 'D':
+ acParamsCmd->aifsn = atoi(optarg);
+ break;
+ case 'E':
+ if (!strcmp(optarg, "disable")) {
+ adhocPmCmd->power_saving = ADHOC_PS_DISABLE;
+ } else if (!strcmp(optarg, "atheros")) {
+ adhocPmCmd->power_saving = ADHOC_PS_ATH;
+ } else if (!strcmp(optarg, "ieee")) {
+ adhocPmCmd->power_saving = ADHOC_PS_IEEE;
+ } else {
+ cmd = 0;
+ }
+
+ break;
+ case 'F':
+ adhocPmCmd->atim_windows = atoi(optarg);
+ break;
+ case 'G':
+ if (wmic_ether_aton(optarg, adhocBssidCmd->bssid) != A_OK) {
+ printf("bad mac address\n");
+ break;
+ }
+ printf("adhoc bssid address, %x\n", adhocBssidCmd->bssid[0]);
+ cmd = WMI_SET_ADHOC_BSSID;
+ break;
+
+ case 'J':
+ cmd = WMI_SET_WLAN_STATE;
+ if (!strcmp(optarg, "enable")) {
+ ((int *)buf)[1] = WLAN_ENABLED;
+ } else if (!strcmp(optarg, "disable")) {
+ ((int *)buf)[1] = WLAN_DISABLED;
+ } else if (!strcmp(optarg, "query")) {
+ cmd = WMI_GET_WLAN_STATE;
+ } else {
+ usage();
+ }
+ break;
+ case 'K':
+ adhocPmCmd->timeout_value = atoi(optarg);
+ break;
+ case 'O':
+ index = optind;
+ index--;
+ if((index + 6) > argc) { /*6 is the number of flags
+ scanctrlflags takes */
+ printf("Incorrect number of scanctrlflags\n");
+ cmd = 0;
+ break;
+ }
+ sParamCmd->scanCtrlFlags = 0;
+ if (atoi(argv[index]) == 1)
+ sParamCmd->scanCtrlFlags |= CONNECT_SCAN_CTRL_FLAGS;
+ index++;
+ if (atoi(argv[index]) == 1)
+ sParamCmd->scanCtrlFlags |= SCAN_CONNECTED_CTRL_FLAGS;
+ index++;
+ if (atoi(argv[index]) == 1)
+ sParamCmd->scanCtrlFlags |= ACTIVE_SCAN_CTRL_FLAGS;
+ index++;
+ if (atoi(argv[index]) == 1)
+ sParamCmd->scanCtrlFlags |= ROAM_SCAN_CTRL_FLAGS;
+ index++;
+ if (atoi(argv[index]) == 1)
+ sParamCmd->scanCtrlFlags |= REPORT_BSSINFO_CTRL_FLAGS;
+ index++;
+ if(atoi(argv[index]) == 1)
+ sParamCmd->scanCtrlFlags |= ENABLE_AUTO_CTRL_FLAGS;
+ index++;
+ if (argc - index) {
+ if(atoi(argv[index]) == 1)
+ sParamCmd->scanCtrlFlags |= ENABLE_SCAN_ABORT_EVENT;
+ index++;
+ }
+ if(!sParamCmd->scanCtrlFlags) {
+ sParamCmd->scanCtrlFlags = 255; /* all flags have being disabled by the user */
+ }
+ break;
+ case 'L':
+ adhocPmCmd->ttl = atoi(optarg);
+ break;
+ case 'P':
+ startScanCmd->homeDwellTime =atoi(optarg);
+ break;
+ case 'Q':
+ startScanCmd->forceScanInterval =atoi(optarg);
+ break;
+ case 'R':
+ index = optind;
+ index--;
+ if((index + 3) > argc) {
+ printf("Incorrect number of forceScanCtrlFlags\n");
+ cmd = 0;
+ break;
+ }
+ startScanCmd->scanType = atoi(argv[index]);
+ index++;
+ startScanCmd->forceFgScan = atoi(argv[index]);
+ index++;
+ startScanCmd->isLegacy = atoi(argv[index]);
+ index++;
+ break;
+ case WMI_SCAN_CHANNEL_LIST:
+ chindex = 0;
+ index = optind - 1;
+ clist = startScanCmd->channelList;
+
+ while (argv[index] != NULL) {
+ channel = atoi(argv[index]);
+ if (channel < 255) {
+ /*
+ * assume channel is a ieee channel #
+ */
+ clist[chindex] = wmic_ieee2freq(channel);
+ } else {
+ clist[chindex] = channel;
+ }
+ chindex++;
+ index++;
+ }
+ startScanCmd->numChannels = chindex;
+ break;
+ case WMI_SET_IBSS_PM_CAPS:
+ cmd = WMI_SET_IBSS_PM_CAPS;
+ break;
+ case WMI_SET_AP_PS:
+ cmd = WMI_SET_AP_PS;
+ break;
+ case WMI_SET_DISC_TIMEOUT:
+ cmd = WMI_SET_DISC_TIMEOUT;
+ discCmd->disconnectTimeout = atoi(optarg);
+ break;
+ case WMI_SET_BEACON_INT:
+ cmd = WMI_SET_BEACON_INT;
+ bconIntvl->beaconInterval = atoi(optarg);
+ break;
+ case WMI_SET_VOICE_PKT_SIZE:
+ cmd = WMI_SET_VOICE_PKT_SIZE;
+ pSizeThresh->voicePktSize = atoi(optarg);
+ break;
+ case WMI_SET_MAX_SP:
+ cmd = WMI_SET_MAX_SP;
+ pMaxSP->maxSPLen = atoi(optarg);
+ break;
+ case WMI_GET_ROAM_TBL:
+ cmd = WMI_GET_ROAM_TBL;
+ break;
+ case WMI_SET_ROAM_CTRL:
+ pRoamCtrl->roamCtrlType = atoi(optarg);
+ if (A_OK != wmic_validate_roam_ctrl(pRoamCtrl, argc-optind, argv)) {
+ break;
+ }
+ cmd = WMI_SET_ROAM_CTRL;
+ break;
+ case WMI_SET_POWERSAVE_TIMERS:
+ cmd = WMI_SET_POWERSAVE_TIMERS;
+ break;
+ case WMI_SET_POWERSAVE_TIMERS_PSPOLLTIMEOUT:
+ pPowerSave->psPollTimeout = atoi(optarg);
+ break;
+ case WMI_SET_POWERSAVE_TIMERS_TRIGGERTIMEOUT:
+ pPowerSave->triggerTimeout = atoi(optarg);
+ break;
+ case WMI_GET_POWER_MODE:
+ cmd = WMI_GET_POWER_MODE;
+ break;
+ case WMI_GET_ROAM_DATA:
+ cmd = WMI_GET_ROAM_DATA;
+ break;
+ case WMI_SET_BT_STATUS:
+ cmd = WMI_SET_BT_STATUS;
+ pBtStatCmd->streamType = atoi(optarg);
+ pBtStatCmd->status = atoi(argv[optind]);
+ if (pBtStatCmd->streamType >= BT_STREAM_MAX ||
+ pBtStatCmd->status >= BT_STATUS_MAX)
+ {
+ fprintf(stderr, "Invalid parameters.\n");
+ exit(0);
+ }
+ break;
+ case WMI_SET_BT_PARAMS:
+ cmd = WMI_SET_BT_PARAMS;
+ pBtParmCmd->paramType = atoi(optarg);
+ if (pBtParmCmd->paramType >= BT_PARAM_MAX)
+ {
+ fprintf(stderr, "Invalid parameters.\n");
+ exit(0);
+ }
+ if (BT_PARAM_SCO == pBtParmCmd->paramType) {
+ pBtParmCmd->info.scoParams.numScoCyclesForceTrigger =
+ strtoul(argv[optind], NULL, 0);
+ pBtParmCmd->info.scoParams.dataResponseTimeout =
+ strtoul(argv[optind+1], NULL, 0);
+ pBtParmCmd->info.scoParams.stompScoRules =
+ strtoul(argv[optind+2], NULL, 0);
+ pBtParmCmd->info.scoParams.scoOptFlags =
+ strtoul(argv[optind+3], NULL, 0);
+ pBtParmCmd->info.scoParams.stompDutyCyleVal =
+ strtoul(argv[optind+4], NULL, 0);
+ pBtParmCmd->info.scoParams.stompDutyCyleMaxVal =
+ strtoul(argv[optind+5], NULL, 0);
+ pBtParmCmd->info.scoParams. psPollLatencyFraction =
+ strtoul(argv[optind+6], NULL, 0);
+ pBtParmCmd->info.scoParams.noSCOSlots =
+ strtoul(argv[optind+7], NULL, 0);
+ pBtParmCmd->info.scoParams.noIdleSlots =
+ strtoul(argv[optind+8], NULL, 0);
+ pBtParmCmd->info.scoParams.scoOptOffRssi =
+ strtoul(argv[optind+9], NULL, 0);
+ pBtParmCmd->info.scoParams.scoOptOnRssi =
+ strtoul(argv[optind+10], NULL, 0);
+ pBtParmCmd->info.scoParams.scoOptRtsCount =
+ strtoul(argv[optind+11], NULL, 0);
+ }else if (BT_PARAM_A2DP == pBtParmCmd->paramType) {
+ pBtParmCmd->info.a2dpParams.a2dpWlanUsageLimit =
+ strtoul(argv[optind], NULL, 0);
+ pBtParmCmd->info.a2dpParams.a2dpBurstCntMin =
+ strtoul(argv[optind+1 ], NULL, 0);
+ pBtParmCmd->info.a2dpParams.a2dpDataRespTimeout =
+ strtoul(argv[optind+2 ], NULL, 0);
+ pBtParmCmd->info.a2dpParams.a2dpOptFlags =
+ strtoul(argv[optind+3 ], NULL, 0);
+ pBtParmCmd->info.a2dpParams.isCoLocatedBtRoleMaster =
+ strtoul(argv[optind+4 ], NULL, 0);
+ pBtParmCmd->info.a2dpParams.a2dpOptOffRssi =
+ strtoul(argv[optind+5], NULL, 0);
+ pBtParmCmd->info.a2dpParams.a2dpOptOnRssi =
+ strtoul(argv[optind+6], NULL, 0);
+ pBtParmCmd->info.a2dpParams.a2dpOptRtsCount =
+ strtoul(argv[optind+7 ], NULL, 0);
+
+ }else if (BT_PARAM_ANTENNA_CONFIG == pBtParmCmd->paramType) {
+ pBtParmCmd->info.antType = strtoul(argv[optind], NULL, 0);
+ } else if (BT_PARAM_COLOCATED_BT_DEVICE == pBtParmCmd->paramType) {
+ pBtParmCmd->info.coLocatedBtDev =
+ strtoul(argv[optind], NULL, 0);
+ }else if(BT_PARAM_ACLCOEX == pBtParmCmd->paramType) {
+ pBtParmCmd->info.aclCoexParams.aclWlanMediumUsageTime =
+ strtoul(argv[optind], NULL, 0);
+ pBtParmCmd->info.aclCoexParams.aclBtMediumUsageTime =
+ strtoul(argv[optind+1], NULL, 0);
+ pBtParmCmd->info.aclCoexParams.aclDataRespTimeout =
+ strtoul(argv[optind+2], NULL, 0);
+ pBtParmCmd->info.aclCoexParams.aclDetectTimeout =
+ strtoul(argv[optind+3], NULL, 0);
+ pBtParmCmd->info.aclCoexParams.aclmaxPktCnt =
+ strtoul(argv[optind + 4], NULL, 0);
+ } else if (BT_PARAM_11A_SEPARATE_ANT == pBtParmCmd->paramType) {
+ printf("BT_PARAM_11A_SEPARATE_ANT \n");
+ }
+ else
+ {
+ fprintf(stderr, "Invalid parameters.\n");
+ exit(0);
+ }
+ break;
+ case WMI_SET_BTCOEX_FE_ANT:
+ cmd = WMI_SET_BTCOEX_FE_ANT;
+ pBtcoexFeAntCmd->btcoexFeAntType = atoi(optarg);
+ if (pBtcoexFeAntCmd->btcoexFeAntType >= WMI_BTCOEX_FE_ANT_TYPE_MAX) {
+ printf("Invalid configuration [1-Single Antenna, 2- dual antenna low isolation, 3 - dual antenna high isolation\n");
+ printf("4 - bypass mode, 5 - combine mode]\n");
+ exit(-1);
+ }
+ break;
+ case WMI_SET_BTCOEX_COLOCATED_BT_DEV:
+ cmd = WMI_SET_BTCOEX_COLOCATED_BT_DEV;
+ pBtcoexCoLocatedBtCmd->btcoexCoLocatedBTdev = atoi(optarg);
+ if (pBtcoexCoLocatedBtCmd->btcoexCoLocatedBTdev > 4) {
+ printf("Invalid configuration %d\n",
+ pBtcoexCoLocatedBtCmd->btcoexCoLocatedBTdev);
+ exit(-1);
+ }
+ printf("btcoex colocated antType = %d\n",
+ pBtcoexCoLocatedBtCmd->btcoexCoLocatedBTdev);
+ break;
+ case WMI_SET_BTCOEX_SCO_CONFIG:
+ cmd = WMI_SET_BTCOEX_SCO_CONFIG;
+ index = optind - 1;
+ if((index + 17) > argc) {
+ printf("Incorrect number of sco Config\n");
+ exit(-1);
+ }
+ pBtcoexScoConfigCmd->scoConfig.scoSlots = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoConfig.scoIdleSlots = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoConfig.scoFlags = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoConfig.linkId = atoi(argv[index++]);
+
+ pBtcoexScoConfigCmd->scoPspollConfig.scoCyclesForceTrigger = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoPspollConfig.scoDataResponseTimeout = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoPspollConfig.scoStompDutyCyleVal = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoPspollConfig.scoStompDutyCyleMaxVal = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoPspollConfig.scoPsPollLatencyFraction = atoi(argv[index++]);
+
+
+ pBtcoexScoConfigCmd->scoOptModeConfig.scoStompCntIn100ms = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoOptModeConfig.scoContStompMax = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoOptModeConfig.scoMinlowRateMbps = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoOptModeConfig.scoLowRateCnt = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoOptModeConfig.scoHighPktRatio = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoOptModeConfig.scoMaxAggrSize = atoi(argv[index++]);
+
+ pBtcoexScoConfigCmd->scoWlanScanConfig.scanInterval = atoi(argv[index++]);
+ pBtcoexScoConfigCmd->scoWlanScanConfig.maxScanStompCnt = atoi(argv[index++]);
+ break;
+ case WMI_SET_BTCOEX_A2DP_CONFIG:
+ cmd = WMI_SET_BTCOEX_A2DP_CONFIG;
+ index = optind - 1;
+ if((index + 10) > argc ) {
+ printf("Incorrect number of A2DP Config\n");
+ exit(-1);
+ }
+ pBtcoexA2dpConfigCmd->a2dpConfig.a2dpFlags = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dpConfig.linkId = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dppspollConfig.a2dpWlanMaxDur = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dppspollConfig.a2dpMinBurstCnt = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dppspollConfig.a2dpDataRespTimeout = atoi(argv[index++]);
+
+ pBtcoexA2dpConfigCmd->a2dpOptConfig.a2dpMinlowRateMbps = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dpOptConfig.a2dpLowRateCnt = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dpOptConfig.a2dpHighPktRatio = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dpOptConfig.a2dpMaxAggrSize = atoi(argv[index++]);
+ pBtcoexA2dpConfigCmd->a2dpOptConfig.a2dpPktStompCnt = atoi(argv[index++]);
+
+ printf("a2dp Config, flags=%x\n", pBtcoexA2dpConfigCmd->a2dpConfig.a2dpFlags);
+ break;
+ case WMI_SET_BTCOEX_ACLCOEX_CONFIG:
+ cmd = WMI_SET_BTCOEX_ACLCOEX_CONFIG;
+ index = optind - 1;
+ if((index + 14) > argc ) {
+ printf("Incorrect number of ACL COEX Config\n");
+ exit(-1);
+ }
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.aclWlanMediumDur = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.aclBtMediumDur = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.aclDetectTimeout = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.aclPktCntLowerLimit = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.aclIterForEnDis = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.aclPktCntUpperLimit = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.aclCoexFlags = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexConfig.linkId = atoi(argv[index++]);
+
+ pBtcoexAclCoexConfigCmd->aclCoexPspollConfig.aclDataRespTimeout = atoi(argv[index++]);
+
+ pBtcoexAclCoexConfigCmd->aclCoexOptConfig.aclCoexMinlowRateMbps = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexOptConfig.aclCoexLowRateCnt = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexOptConfig.aclCoexHighPktRatio = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexOptConfig.aclCoexMaxAggrSize = atoi(argv[index++]);
+ pBtcoexAclCoexConfigCmd->aclCoexOptConfig.aclPktStompCnt = atoi(argv[index++]);
+ break;
+
+ case WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG:
+ cmd = WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG;
+ index = optind - 1;
+ if((index + 3) > argc) {
+ printf("Incorrect number of inquiry_page Config\n");
+ exit(-1);
+ }
+ pBtcoexbtinquiryPageConfigCmd->btInquiryDataFetchFrequency = atoi(argv[index++]);
+ pBtcoexbtinquiryPageConfigCmd->protectBmissDurPostBtInquiry = atoi(argv[index++]);
+ pBtcoexbtinquiryPageConfigCmd->btInquiryPageFlag = atoi(argv[index++]);
+ break;
+
+ case WMI_SET_BTCOEX_BT_OPERATING_STATUS:
+ cmd = WMI_SET_BTCOEX_BT_OPERATING_STATUS;
+ index = optind - 1;
+ if((index + 3) > argc) {
+ printf("Incorrect number of operating status cmdn");
+ exit(-1);
+ }
+
+ pBtcoexBtOperatingStatusCmd->btProfileType =atoi(argv[index++]);
+ pBtcoexBtOperatingStatusCmd->btOperatingStatus =atoi(argv[index++]);
+ pBtcoexBtOperatingStatusCmd->btLinkId =atoi(argv[index++]);
+ break;
+
+ case WMI_GET_BTCOEX_CONFIG:
+ cmd = WMI_GET_BTCOEX_CONFIG;
+ index = optind - 1;
+ if((index + 2) > argc) {
+ printf("Incorrect number of get Config\n");
+ exit(-1);
+ }
+ pBtcoexConfig->configCmd.btProfileType = atoi(argv[index++]);
+ pBtcoexConfig->configCmd.linkId = atoi(argv[index++]);
+ break;
+ case WMI_GET_BTCOEX_STATS:
+ cmd = WMI_GET_BTCOEX_STATS;
+ break;
+ case WMI_SET_RETRYLIMITS:
+ index = optind - 1;
+ setRetryCmd->frameType = atoi(argv[index++]);
+ if (setRetryCmd->frameType > 2) {
+ printf("Invalid frame type! [0 - 2]\n");
+ exit(-1);
+ }
+ setRetryCmd->trafficClass = atoi(argv[index++]);
+ if (setRetryCmd->trafficClass > 3) {
+ printf("Invalid traffic class! [0 - 3]\n");
+ exit(-1);
+ }
+ setRetryCmd->maxRetries = atoi(argv[index++]);
+ if (setRetryCmd->maxRetries > WMI_MAX_RETRIES) {
+ printf("Invalid max retries! [0 - 13] \n");
+ exit(-1);
+ }
+ if (!strcmp(argv[index], "on")) {
+ setRetryCmd->enableNotify = 1;
+ } else if (!strcmp(argv[index], "off")) {
+ setRetryCmd->enableNotify = 0;
+ } else {
+ usage();
+ }
+ cmd = WMI_SET_RETRYLIMITS;
+ break;
+ case WMI_START_SCAN:
+ cmd = WMI_START_SCAN;
+ startScanCmd->scanType= 0;
+ startScanCmd->forceFgScan= false;
+ startScanCmd->isLegacy= false;
+ startScanCmd->homeDwellTime = 0;
+ startScanCmd->forceScanInterval = 0;
+ startScanCmd->numChannels = 0;
+ break;
+ case WMI_SET_FIX_RATES:
+ cmd = WMI_SET_FIX_RATES;
+ break;
+ case WMI_GET_FIX_RATES:
+ cmd = WMI_GET_FIX_RATES;
+ break;
+ case WMI_SET_AUTH_MODE:
+ cmd = WMI_SET_AUTH_MODE;
+ break;
+ case WMI_SET_REASSOC_MODE:
+ cmd = WMI_SET_REASSOC_MODE;
+ break;
+ case WMI_SET_LPREAMBLE:
+ cmd = WMI_SET_LPREAMBLE;
+ setLpreambleCmd->status = atoi(optarg);
+ break;
+ case WMI_SET_RTS:
+ cmd = WMI_SET_RTS;
+ setRtsCmd->threshold = atoi(optarg);
+ break;
+ case WMI_SET_WMM:
+ cmd = WMI_SET_WMM;
+ setWmmCmd->status = atoi(optarg);
+ break;
+ case WMI_SET_QOS_SUPP:
+ cmd = WMI_SET_QOS_SUPP;
+ qosSupp->status = atoi(optarg);
+ break;
+ case WMI_APSD_TIM_POLICY:
+ if (!strcmp(optarg, "ignore")) {
+ pPowerSave->apsdTimPolicy = IGNORE_TIM_ALL_QUEUES_APSD;
+ } else {
+ pPowerSave->apsdTimPolicy = PROCESS_TIM_ALL_QUEUES_APSD;
+ }
+ break;
+ case WMI_SIMULATED_APSD_TIM_POLICY:
+ if (!strcmp(optarg, "ignore")) {
+ pPowerSave->simulatedAPSDTimPolicy = IGNORE_TIM_SIMULATED_APSD;
+ } else {
+ pPowerSave->simulatedAPSDTimPolicy = PROCESS_TIM_SIMULATED_APSD;
+ }
+ break;
+ case WMI_SET_ERROR_DETECTION:
+ cmd = WMI_SET_ERROR_DETECTION;
+ break;
+ case 'S':
+ hbparam->threshold = atoi(optarg);
+ break;
+ case 'T':
+ hbparam->frequency = atoi(optarg);
+ break;
+ case WMI_GET_HB_CHALLENGE_RESP:
+ cmd = WMI_GET_HB_CHALLENGE_RESP;
+ break;
+ case 'U':
+ *cookie = strtoul(optarg, (char **)NULL, 0);
+ break;
+ case USER_SETKEYS:
+ if (argc == 5) {
+ user_setkeys_info->keyOpCtrl = 0;
+ cmd = USER_SETKEYS;
+ } else {
+ printf("Invalid arg %s:Usage --usersetkeys --initrsc=<on/off>",
+ optarg);
+ }
+ break;
+ case WMI_GET_RD:
+ cmd = WMI_GET_RD;
+ break;
+ case WMI_SET_TXOP:
+ cmd = WMI_SET_TXOP;
+ pTxOp->txopEnable = atoi(optarg);
+ break;
+ case DIAG_ADDR:
+ *diagaddr = strtoul(optarg, (char **)NULL, 0);
+ printf("addr: 0x%x\n", *diagaddr);
+ break;
+ case DIAG_DATA:
+ *diagdata = strtoul(optarg, (char **)NULL, 0);
+ printf("data: 0x%x\n", *diagdata);
+ break;
+ case DIAG_READ:
+ cmd = DIAG_READ;
+ break;
+ case DIAG_WRITE:
+ cmd = DIAG_WRITE;
+ break;
+ case WMI_SET_KEEPALIVE:
+ cmd = WMI_SET_KEEPALIVE;
+ if (wmic_validate_setkeepalive(setKeepAlive, argv) != A_OK) {
+ printf("setkeepalive: invalid args\n");
+ cmd = 0;
+ break;
+ }
+ break;
+ case WMI_GET_KEEPALIVE:
+ cmd = WMI_GET_KEEPALIVE;
+ break;
+ case WMI_SET_APPIE:
+ cmd = WMI_SET_APPIE;
+
+ if (argc - optind != 1) {
+ printf("Usage is --setappie <beacon/probe/respon/assoc> <IE>\n");
+ cmd = 0;
+ break;
+ }
+
+ if (A_OK != wmic_validate_appie(appIEInfo, argv)) {
+ cmd = 0;
+ break;
+ }
+ break;
+ case WMI_SET_MGMT_FRM_RX_FILTER:
+ cmd = WMI_SET_MGMT_FRM_RX_FILTER;
+ if (argc - optind != 1) {
+ printf("Usage is --setmgmtfilter <set/clear> <frmtype> \n");
+ cmd = 0;
+ break;
+ }
+
+ if (A_OK != wmic_validate_mgmtfilter(pMgmtFilter, argv)) {
+ cmd = 0;
+ break;
+ }
+ break;
+ case 'V':
+ dbglogCfg->mmask = strtoul(optarg, (char **)NULL, 0);
+ dbglogCfg->valid |= DBGLOG_MODULE_LOG_ENABLE_MASK;
+ break;
+ case 'W':
+ dbglogCfg->rep = strtoul(optarg, (char **)NULL, 0);
+ dbglogCfg->valid |= DBGLOG_REPORTING_ENABLED_MASK;
+ break;
+ case 'X':
+ dbglogCfg->tsr = strtoul(optarg, (char **)NULL, 0);
+ dbglogCfg->valid |= DBGLOG_TIMESTAMP_RESOLUTION_MASK;
+ break;
+ case 'Y':
+ dbglogCfg->size = strtoul(optarg, (char **)NULL, 0);
+ dbglogCfg->valid |= DBGLOG_REPORT_SIZE_MASK;
+ break;
+ case 'Z':
+ clearstat = 1;
+ break;
+ case WMI_BSSID:
+ convert_hexstring_bytearray(optarg, bssid, sizeof(bssid));
+ break;
+ case USER_SETKEYS_INITRSC:
+ if (strcmp(optarg, "on") == 0) {
+ user_setkeys_info->keyOpCtrl &=
+ ~AR6000_USER_SETKEYS_RSC_UNCHANGED;
+ } else if (strcmp(optarg, "off") == 0) {
+ user_setkeys_info->keyOpCtrl |=
+ AR6000_USER_SETKEYS_RSC_UNCHANGED;
+ } else {
+ printf("Invalid arg %s:Usage --usersetkeys --initrsc=<on/off>",
+ optarg);
+ }
+ break;
+ case WMI_DBGLOG_CFG_MODULE:
+ dbglogCfg->valid = 0;
+ cmd = WMI_DBGLOG_CFG_MODULE;
+ break;
+ case WMI_DBGLOG_GET_DEBUG_LOGS:
+ cmd = WMI_DBGLOG_GET_DEBUG_LOGS;
+ break;
+ case WMI_SET_HOST_SLEEP_MODE:
+ cmd = WMI_SET_HOST_SLEEP_MODE;
+ if (!strcmp(optarg, "asleep")) {
+ hostSleepModeCmd->asleep = TRUE;
+ hostSleepModeCmd->awake = FALSE;
+ } else if (!strcmp(optarg, "awake")) {
+ hostSleepModeCmd->asleep = FALSE;
+ hostSleepModeCmd->awake = TRUE;
+ }
+ break;
+ case WMI_SET_WOW_MODE:
+ cmd = WMI_SET_WOW_MODE;
+ if (!strcmp(optarg, "enable")) {
+ wowModeCmd->enable_wow = TRUE;
+ } else if (!strcmp(optarg, "disable")) {
+ wowModeCmd->enable_wow = FALSE;
+ }
+ break;
+ case WMI_SET_WOW_FILTER:
+ if (!strcmp(optarg, "none")) {
+ wowModeCmd->filter = 0;
+ } else if (!strcmp(optarg, "ssid")) {
+ wowModeCmd->filter |= (1<<WOW_FILTER_SSID);
+ }
+ break;
+ case WMI_SET_WOW_HOST_REQ_DELAY:
+ wowModeCmd->hostReqDelay=atoi(optarg);
+ break;
+ case WMI_ADD_WOW_PATTERN:
+ cmd = WMI_ADD_WOW_PATTERN;
+ index = (optind - 1);
+ A_UINT8* filter_mask = NULL;
+ A_UINT8 temp1[64]={0};
+ A_UINT8 temp2[64]={0};
+
+ if((index + 4) > argc) {
+ printf("Incorrect number of add wow pattern parameters\n");
+ cmd = 0;
+ break;
+ }
+ memset((char*)addWowCmd, 0, sizeof(WMI_ADD_WOW_PATTERN_CMD));
+ i = addWowCmd->filter_list_id = 0;
+ addWowCmd->filter_list_id = atoi(argv[index++]);
+ addWowCmd->filter_size = atoi(argv[index++]);
+ addWowCmd->filter_offset = atoi(argv[index++]);
+ printf("optind=%d, size=%d offset=%d id=%d\n", optind,
+ addWowCmd->filter_size, addWowCmd->filter_offset,
+ addWowCmd->filter_list_id);
+ convert_hexstring_bytearray(argv[index], temp1,addWowCmd->filter_size );
+ memcpy(&addWowCmd->filter[0], temp1, addWowCmd->filter_size);
+ index++;
+ filter_mask = (A_UINT8*)(addWowCmd->filter + addWowCmd->filter_size);
+ convert_hexstring_bytearray(argv[index], temp2,addWowCmd->filter_size );
+ memcpy(filter_mask, temp2, addWowCmd->filter_size);
+
+ for (i=0; i< addWowCmd->filter_size; i++) {
+
+ printf ("mask[%d]=%x pattern[%d]=%x temp=%x\n", i, filter_mask[i], i, addWowCmd->filter[i], temp1[i]);
+ }
+ break;
+ case WMI_DEL_WOW_PATTERN:
+ cmd = WMI_DEL_WOW_PATTERN;
+ index = (optind - 1);
+ if ((index + 1) > argc) {
+ printf("Incorrect number of del wow pattern parameters\n");
+ cmd = 0;
+ break;
+ }
+ delWowCmd->filter_list_id = 0;
+ index++;
+ delWowCmd->filter_id = atoi(argv[index]);
+ break;
+ case WMI_GET_WOW_LIST:
+ cmd = WMI_GET_WOW_LIST;
+ index = (optind - 1);
+ if ((index + 1) > argc) {
+ printf("Incorrect number of get wow list parameters\n");
+ cmd = 0;
+ break;
+ }
+ getWowListCmd->filter_list_id = atoi(argv[index]);
+ printf("Get wow filters in list %d\n", getWowListCmd->filter_list_id);
+ break;
+ case DIAG_DUMP_CHIP_MEM:
+ cmd = DIAG_DUMP_CHIP_MEM;
+ break;
+ case DIAG_DUMP_CHIP_MEM_VENUS:
+ cmd = DIAG_DUMP_CHIP_MEM_VENUS;
+ break;
+ case WMI_SET_CONNECT_CTRL_FLAGS:
+ cmd = WMI_SET_CONNECT_CTRL_FLAGS;
+ break;
+ case DUMP_HTC_CREDITS:
+ cmd = DUMP_HTC_CREDITS;
+ break;
+ case WMI_AKMP_MULTI_PMKID:
+ if (strcmp(optarg, "on") == 0) {
+ akmpCtrlCmd->akmpInfo |= WMI_AKMP_MULTI_PMKID_EN;
+ } else if (strcmp(optarg, "off") == 0) {
+ akmpCtrlCmd->akmpInfo &= ~WMI_AKMP_MULTI_PMKID_EN;
+ } else {
+ printf("Invalid arg %s:Usage --setakmctrl --multipmkid=<on/off>",
+ optarg);
+ }
+ break;
+ case WMI_SET_AKMP_INFO:
+ cmd = WMI_SET_AKMP_INFO;
+ break;
+ case WMI_NUM_PMKID:
+ if ((pmkidUserInfo.numPMKIDUser = atoi(optarg))
+ > WMI_MAX_PMKID_CACHE)
+ {
+ printf("Number of PMKIDs %d is out of range [1-%d]\n",
+ pmkidUserInfo.numPMKIDUser,
+ WMI_MAX_PMKID_CACHE);
+ pmkidUserInfo.numPMKIDUser = 0;
+ }
+ break;
+ case WMI_PMKID_ENTRY:
+ if (pmkidUserInfo.pmkidInfo->numPMKID <
+ pmkidUserInfo.numPMKIDUser)
+ {
+ A_UINT8 nextEntry = pmkidUserInfo.pmkidInfo->numPMKID;
+
+ convert_hexstring_bytearray(optarg,
+ pmkidUserInfo.pmkidInfo->
+ pmkidList[nextEntry].pmkid,
+ WMI_PMKID_LEN);
+ pmkidUserInfo.pmkidInfo->numPMKID++;
+ }
+ break;
+ case WMI_SET_PMKID_LIST:
+ cmd = WMI_SET_PMKID_LIST;
+ pmkidUserInfo.pmkidInfo =
+ (WMI_SET_PMKID_LIST_CMD *)(buf + sizeof(int));
+ pmkidUserInfo.pmkidInfo->numPMKID = 0;
+ pmkidUserInfo.numPMKIDUser = 0;
+ break;
+ case WMI_GET_PMKID_LIST:
+ cmd = WMI_GET_PMKID_LIST;
+ break;
+ case WMI_SET_IEMASK:
+ filterCmd->ieMask = strtoul(argv[optind-1], NULL, 0);
+ break;
+ case WMI_SET_BSS_PMKID_INFO:
+ cmd = WMI_SET_BSS_PMKID_INFO;
+ memset(bssid, 0, sizeof(bssid));
+ pi_cmd->pi_enable = FALSE;
+ break;
+ case WMI_BSS_PMKID_ENTRY:
+ convert_hexstring_bytearray(optarg, pi_cmd->pi_pmkid,
+ sizeof(pi_cmd->pi_pmkid));
+ memcpy(pi_cmd->pi_bssid, bssid, sizeof(bssid));
+ pi_cmd->pi_enable = TRUE;
+ break;
+ case WMI_ABORT_SCAN:
+ cmd = WMI_ABORT_SCAN;
+ break;
+ case WMI_TARGET_EVENT_REPORT:
+ cmd = WMI_TARGET_EVENT_REPORT;
+ evtCfgCmd->evtConfig = atoi(optarg);
+ break;
+ /* AP mode commands */
+ case WMI_AP_GET_STA_LIST:
+ cmd = WMI_AP_GET_STA_LIST;
+ break;
+ case WMI_AP_HIDDEN_SSID:
+ cmd = WMI_AP_HIDDEN_SSID;
+ pHidden->hidden_ssid = atoi(argv[optind]);
+ break;
+ case WMI_AP_SET_NUM_STA:
+ cmd = WMI_AP_SET_NUM_STA;
+ pNumSta->num_sta = atoi(argv[optind]);
+ break;
+ case WMI_AP_SET_GNUM_STA:
+ cmd = WMI_AP_SET_GNUM_STA;
+ pNumSta->num_sta = atoi(argv[optind]);
+ pNumSta->num_sta |= 0x80;
+ break;
+ case WMI_AP_GET_NUM_STA:
+ cmd = WMI_AP_GET_NUM_STA;
+ pNumSta->num_sta = 0;
+ break;
+ case WMI_AP_GET_GNUM_STA:
+ cmd = WMI_AP_GET_GNUM_STA;
+ pNumSta->num_sta = 0x80;
+ break;
+ case WMI_AP_SET_DFS:
+ cmd = WMI_AP_SET_DFS;
+ setDfsCmd->enable = atoi(optarg);
+ break;
+ case WMI_AP_ACL_POLICY:
+ {
+ A_UINT8 policy, retain;
+ cmd = WMI_AP_ACL_POLICY;
+ index = optind;
+ policy = atoi(argv[index++]);
+ retain = atoi(argv[index++]);
+ pACLpolicy->policy = policy |
+ (retain?AP_ACL_RETAIN_LIST_MASK:0);
+ break;
+ }
+ case WMI_AP_ACL_MAC_LIST1:
+ cmd = WMI_AP_ACL_MAC_LIST1;
+ pACL->action = ADD_MAC_ADDR;
+ if(wmic_ether_aton_wild(argv[optind], pACL->mac, &pACL->wildcard) != A_OK) {
+ printf("bad mac address\n");
+ exit (0);
+ }
+ break;
+ case WMI_AP_ACL_MAC_LIST2:
+ cmd = WMI_AP_ACL_MAC_LIST2;
+ pACL->action = DEL_MAC_ADDR;
+ if( (strlen(argv[optind]) == 2) && ISDIGIT(argv[optind][0]) && ISDIGIT(argv[optind][1]) ) {
+ pACL->index = atoi(argv[optind]);
+ } else if( (strlen(argv[optind]) == 1) && ISDIGIT(argv[optind][0]) ) {
+ pACL->index = atoi(argv[optind]);
+ } else {
+ printf("bad ACL index\n");
+ exit(0);
+ }
+ break;
+ case WMI_AP_GET_ACL_LIST:
+ cmd = WMI_AP_GET_ACL_LIST;
+ break;
+ case WMI_AP_COMMIT_CONFIG:
+ cmd = WMI_AP_COMMIT_CONFIG;
+ break;
+ case WMI_AP_INACT_TIME:
+ cmd = WMI_AP_INACT_TIME;
+ pInact->period = atoi(argv[optind]);
+ break;
+ case WMI_AP_PROT_TIME:
+ cmd = WMI_AP_PROT_TIME;
+ index = optind;
+ pProt->period_min = atoi(argv[index++]);
+ pProt->dwell_ms = atoi(argv[index++]);
+ break;
+ case WMI_AP_SET_MLME:
+ cmd = WMI_AP_SET_MLME;
+ index = optind;
+ if((index + 3) > argc) {
+ printf("Incorrect number of arguments\n");
+ exit(0);
+ }
+ pMlme->im_op = atoi(argv[index++]);
+ pMlme->im_reason = atoi(argv[index++]);
+ if(wmic_ether_aton(argv[index++], pMlme->im_macaddr) != A_OK) {
+ printf("bad mac address\n");
+ exit (0);
+ }
+ break;
+ case WMI_AP_SET_DTIM:
+ cmd = WMI_AP_SET_DTIM;
+ pDtim->dtim = atoi(argv[optind]);
+ break;
+ case WMI_AP_SET_COUNTRY:
+ cmd = WMI_AP_SET_COUNTRY;
+ A_BOOL match=FALSE;
+
+ for(i = 0; i < sizeof(my_ctr)/sizeof(my_ctr[0]); i++) {
+ if(!strcasecmp(optarg, my_ctr[i])) {
+ match = 1;
+ break;
+ }
+ }
+
+ if (!match) {
+ cmd = 0;
+ } else {
+ memcpy(pCountry->countryCode,my_ctr[i], 2);
+ *(pCountry->countryCode + 2)=0x20;
+ }
+
+ break;
+ case WMI_AP_GET_COUNTRY_LIST:
+ cmd = WMI_AP_GET_COUNTRY_LIST;
+ break;
+ case WMI_AP_DISABLE_REGULATORY:
+ cmd = WMI_AP_DISABLE_REGULATORY;
+ break;
+ case WMI_AP_INTRA_BSS:
+ cmd = WMI_AP_INTRA_BSS;
+ *intra = atoi(argv[optind]);
+ *intra &= 0xF;
+ break;
+ case WMI_AP_INTER_BSS:
+ cmd = WMI_AP_INTER_BSS;
+ *intra = atoi(argv[optind]);
+ *intra |= 0x80;
+ break;
+ case WMI_DUMP_RCV_AGGR_STATS:
+ cmd = WMI_DUMP_RCV_AGGR_STATS;
+ break;
+ case WMI_SUSPEND_DRIVER:
+ cmd = WMI_SUSPEND_DRIVER;
+ break;
+ case WMI_RESUME_DRIVER:
+ cmd = WMI_RESUME_DRIVER;
+ break;
+ case WMI_SETUP_AGGR:
+ {
+ A_UINT8 aid;
+ cmd = WMI_SETUP_AGGR;
+ if(argc-optind < 2) {
+ printf("--setup_aggr <tid> <aid>\n");
+ return 0;
+ }
+ pAddbaReq->tid = strtoul(argv[optind++], NULL, 0);
+ if(argv[optind]) aid = strtoul(argv[optind], NULL, 0);
+ pAddbaReq->tid = (pAddbaReq->tid & 0xF) | (aid << 4);
+ break;
+ }
+ case WMI_CFG_ALLOW_AGGR:
+ cmd = WMI_CFG_ALLOW_AGGR;
+ pAllowAggr->tx_allow_aggr = strtoul(argv[argc-2], NULL, 0);
+ pAllowAggr->rx_allow_aggr = strtoul(argv[argc-1], NULL, 0);
+ break;
+ case WMI_CFG_DELE_AGGR:
+ {
+ A_UINT8 aid;
+ cmd = WMI_CFG_DELE_AGGR;
+ if(argc-optind < 2) {
+ printf("--dele_aggr <tid> <direction> <aid>\n");
+ return 0;
+ }
+ pDeleteAggr->tid = strtoul(argv[optind++], NULL, 0);
+ pDeleteAggr->is_sender_initiator = strtoul(argv[optind++], NULL, 0);
+ if(argv[optind]) aid = strtoul(argv[optind], NULL, 0);
+ pDeleteAggr->tid = (pDeleteAggr->tid & 0xF) | (aid << 4);
+ break;
+ }
+ case WMI_SET_HT_CAP:
+ cmd = WMI_SET_HT_CAP;
+ break;
+ case WMI_SET_HT_OP:
+ cmd = WMI_SET_HT_OP;
+ break;
+ case WMI_AP_GET_STAT:
+ cmd = WMI_AP_GET_STAT;
+ break;
+ case WMI_AP_CLR_STAT:
+ cmd = WMI_AP_CLR_STAT;
+ break;
+ case WMI_SET_TX_SELECT_RATES:
+ cmd = WMI_SET_TX_SELECT_RATES;
+ break;
+ case WMI_AP_GET_HIDDEN_SSID:
+ cmd = WMI_AP_GET_HIDDEN_SSID;
+ break;
+ case WMI_AP_GET_COUNTRY:
+ cmd = WMI_AP_GET_COUNTRY;
+ break;
+ case WMI_AP_GET_WMODE:
+ cmd = WMI_AP_GET_WMODE;
+ break;
+ case WMI_AP_GET_DTIM:
+ cmd = WMI_AP_GET_DTIM;
+ break;
+ case WMI_AP_GET_BINTVL:
+ cmd = WMI_AP_GET_BINTVL;
+ break;
+ case WMI_GET_RTS:
+ cmd = WMI_GET_RTS;
+ break;
+ case DIAG_FETCH_TARGET_REGS:
+ cmd = DIAG_FETCH_TARGET_REGS;
+ break;
+#ifdef ATH_INCLUDE_PAL
+ case WMI_SEND_PAL_CMD:
+ cmd = WMI_SEND_PAL_CMD;
+ break;
+ case WMI_SEND_PAL_DATA:
+ cmd = WMI_SEND_PAL_DATA;
+ break;
+#endif
+ case WMI_SET_WLAN_CONN_PRECDNCE:
+ cmd = WMI_SET_WLAN_CONN_PRECDNCE;
+ prec->precedence = atoi(argv[argc-1]);
+ break;
+ case WMI_SET_AP_RATESET:
+ cmd = WMI_SET_AP_RATESET;
+ pAPrs->rateset = atoi(argv[optind]);
+ break;
+ case WMI_SET_TX_WAKEUP_POLICY:
+ if (!strcmp(optarg, "sleep")) {
+ pmParamCmd->tx_wakeup_policy = TX_DONT_WAKEUP_UPON_SLEEP;
+ } else if (!strcmp(optarg, "wakeup")) {
+ pmParamCmd->tx_wakeup_policy = TX_WAKEUP_UPON_SLEEP;
+ } else {
+ cmd = 0;
+ }
+ break;
+ case WMI_SET_TX_NUM_FRAMES_TO_WAKEUP:
+ pmParamCmd->num_tx_to_wakeup = atoi(optarg);
+ break;
+ case WMI_SET_AP_PS_PSTYPE:
+ if (!strcmp(optarg, "disable")) {
+ apPsCmd->psType = AP_PS_DISABLE;
+ } else if (!strcmp(optarg, "atheros")) {
+ apPsCmd->psType = AP_PS_ATH;
+ } else {
+ cmd = 0;
+ }
+ break;
+ case WMI_SET_AP_PS_IDLE_TIME:
+ apPsCmd->idle_time = atoi(optarg);
+ break;
+ case WMI_SET_AP_PS_PS_PERIOD:
+ apPsCmd->ps_period = atoi(optarg);
+ break;
+ case WMI_SET_AP_PS_SLEEP_PERIOD:
+ apPsCmd->sleep_period = atoi(optarg);
+ break;
+ case WMI_SEND_CONNECT_CMD:
+ cmd = WMI_SEND_CONNECT_CMD;
+ memset(&cp,0,sizeof(cp));
+ if(strlen(optarg) > 32) {
+ printf("Error: Wrong SSID\n");
+ } else {
+ cp.ssid_len = strlen(optarg);
+ memcpy(cp.ssid, optarg, cp.ssid_len);
+ }
+ break;
+ case WMI_SEND_CONNECT_CMD1:
+#ifdef WPA_SUPPORT
+ {
+ unsigned long val;
+ index = optind-1;
+
+ if(argc-index != 4) {
+ printf("Error: wpa needs 4 args but only %d given\n", argc-index);
+ break;
+ }
+
+ val = strtol(argv[index++], NULL, 0);
+ if(val == 1) {
+ cp.wpa = IW_AUTH_WPA_VERSION_WPA;
+ } else if(val == 2) {
+ cp.wpa = IW_AUTH_WPA_VERSION_WPA2;
+ } else {
+ cp.wpa = 0;
+ printf("Error: Wrong WPA version\n");
+ }
+
+ if (!strcasecmp(argv[index], "tkip")) {
+ cp.ucipher = IW_AUTH_CIPHER_TKIP;
+ } else if (!strcasecmp(argv[index], "ccmp")) {
+ cp.ucipher = IW_AUTH_CIPHER_CCMP;
+ } else {
+ cp.ucipher = IW_AUTH_CIPHER_NONE;
+ printf("Error: Wrong unicast cipher\n");
+ }
+ index++;
+
+ if (!strcasecmp(argv[index], "tkip")) {
+ cp.mcipher = IW_AUTH_CIPHER_TKIP;
+ } else if (!strcasecmp(argv[index], "ccmp")) {
+ cp.mcipher = IW_AUTH_CIPHER_CCMP;
+ } else {
+ cp.mcipher = IW_AUTH_CIPHER_NONE;
+ printf("Error: Wrong multicast cipher\n");
+ }
+ index++;
+
+ val = strlen(argv[index]);
+ if(val >= 8 && val <= 63) {
+ memcpy(cp.psk, argv[index], val);
+ cp.psk_type = KEYTYPE_PHRASE;
+ } else if (val == 64) {
+ memcpy(cp.psk, argv[index], val);
+ cp.psk_type = KEYTYPE_PSK;
+ } else {
+ printf("Error: Wrong PSK\n");
+ }
+ break;
+ }
+#else
+ return -1;
+#endif
+ case WMI_SEND_CONNECT_CMD2:
+ printf("Error: WEP not yet implemented\n");
+ return 0;
+
+ case WMI_SET_WPA_OFFLOAD_STATE:
+ {
+ index = optind-1;
+
+ if(argc-index != 1) {
+ printf("Error: setwpaoffload needs 1 arg but only %d given\n", argc-index);
+ break;
+ }
+
+ *pWpaOffloadState = strtol(argv[index++], NULL, 0);
+
+ cmd = WMI_SET_WPA_OFFLOAD_STATE;
+
+ break;
+ }
+ case WMI_SET_EXCESS_TX_RETRY_THRES:
+ {
+ index = optind-1;
+
+ if(argc-index != 1) {
+ printf("Error: setexcesstxretrythres needs 1 arg but only %d given\n", argc-index);
+ break;
+ }
+
+ *pExcessTxRetryThres = strtol(argv[index++], NULL, 0);
+
+ cmd = WMI_SET_EXCESS_TX_RETRY_THRES;
+
+ break;
+ }
+ case BT_HW_POWER_STATE:
+ if (!strcmp(optarg, "on")) {
+ cmd = SET_BT_HW_POWER_STATE;
+ ((int *)buf)[0] = AR6000_XIOCTL_SET_BT_HW_POWER_STATE;
+ ((int *)buf)[1] = 1;
+ } else if (!strcmp(optarg, "off")) {
+ cmd = SET_BT_HW_POWER_STATE;
+ ((int *)buf)[0] = AR6000_XIOCTL_SET_BT_HW_POWER_STATE;
+ ((int *)buf)[1] = 0;
+ } else if (!strcmp(optarg, "query")) {
+ cmd = GET_BT_HW_POWER_STATE;
+ ((int *)buf)[0] = AR6000_XIOCTL_GET_BT_HW_POWER_STATE;
+ } else {
+ usage();
+ }
+ break;
+
+
+ case WMI_SET_TX_SGI_PARAM:
+ cmd = WMI_SET_TX_SGI_PARAM;
+ set_txsgiparam->sgiMask[0] = DEFAULT_SGI_MASK_L32;
+ set_txsgiparam->sgiMask[1] = DEFAULT_SGI_MASK_U32;
+ set_txsgiparam->sgiPERThreshold = DEFAULT_SGI_PER;
+ break;
+
+ case WMI_SGI_MASK:
+ {
+ unsigned long long val;
+
+ val = strtoll(optarg, NULL, 16);
+ set_txsgiparam->sgiMask[0] = (unsigned long) val;
+ set_txsgiparam->sgiMask[1] = (unsigned long) (val>>32);
+ }
+ break;
+
+
+ case WMI_PER_SGI:
+ {set_txsgiparam->sgiPERThreshold = atoi(optarg);
+ break;
+ }
+
+ case WMI_WAC_ENABLE:
+ cmd = WMI_WAC_ENABLE;
+ break;
+
+ case WMI_AP_ACS_DISABLE_HI_CHANNELS:
+ cmd = WMI_AP_ACS_DISABLE_HI_CHANNELS;
+ ((int *)buf)[1] = atoi(argv[optind]);
+ break;
+
+ case WMI_SET_DIVERSITY_PARAM:
+ cmd = WMI_SET_DIVERSITY_PARAM;
+ index = optind-1;
+
+ pDiversity->divIdleTime = atoi(argv[index++]);
+ pDiversity->antRssiThresh = atoi(argv[index++]);
+ pDiversity->divEnable = atoi(argv[index++]);
+ pDiversity->active_treshold_rate = atoi(argv[index++]);
+ break;
+
+ case WMI_SCAN_PROBED_SSID:
+ cmd = WMI_SCAN_PROBED_SSID;
+ ssid = (A_UCHAR *)optarg;
+ break;
+
+ case WMI_AP_SET_APSD:
+ cmd = WMI_AP_SET_APSD;
+ pApApsd->enable = atoi(argv[optind]);
+ break;
+
+ case WMI_GET_HT_CAP:
+ cmd = WMI_GET_HT_CAP;
+ break;
+
+ case WMI_SET_MCASTRATE:
+ cmd = WMI_SET_MCASTRATE;
+ break;
+
+ case WMI_VOICE_DETECTION_ENABLE:
+ cmd = WMI_VOICE_DETECTION_ENABLE;
+
+ if (argc - optind != 0) {
+ printf("Usage is --enablevoicedetection <enable>\n");
+ cmd = 0;
+ break;
+ }
+
+ pVoiceDetectionEnable->enable = atoi(optarg);
+ break;
+
+ case WMI_SET_TXE_NOTIFY:
+ cmd = WMI_SET_TXE_NOTIFY;
+ index = optind - 1;
+
+ pTXe->rate = atoi(argv[index++]);
+ pTXe->pkts = atoi(argv[index++]);
+ pTXe->intvl = atoi(argv[index++]);
+ break;
+ case WMI_SET_RECOVERY_SIMULATE:
+ /*wmiconfig -i wlan0 --setrecoverysim 0 100*/
+ if(argc - optind != 2){
+ printf("Error: WMI_SET_RECOVERY_SIMULATE optind:%x argc:%x\n", optind,argc);
+ cmd = 0;
+ break;
+ }
+ cmd = WMI_SET_RECOVERY_SIMULATE;
+ index = optind;
+ pSetRecoveryParam->type = atoi(argv[index++]);
+ pSetRecoveryParam->delay_time_ms = atoi(argv[index++]);
+ break;
+case WMI_DISABLE_BCAST_IN_PM:
+/* wmiconfig -i wlan0 --disablebcast <para0> */
+index = optind-1;
+if (argc - index != 1) {
+printf("Error: WMI_DISABLE_BCAST_IN_PM optind:%x argc:%x\n", optind, argc);
+cmd = 0;
+break;
+}
+cmd = WMI_DISABLE_BCAST_IN_PM;
+disableBcastCmd->disable = atoi(argv[index++]);
+break;
+ case WMI_AP_BLWL:
+ {
+ A_UINT8 control, macindex;
+
+ index = optind;
+ control = atoi(argv[index++]);
+
+ if (0 == control) //enable blwl
+ {
+ cmd = WMI_AP_BLWL_POLICY;
+ pACLpolicy->policy = AP_ACL_DISABLE;
+ }
+ else if (1 == control) //enable blwl
+ {
+ cmd = WMI_AP_BLWL_POLICY;
+ pACLpolicy->policy = AP_ACL_BLWL_MAC;
+ }
+ else if (2 == control) //add a mac into whitelist
+ {
+ cmd = WMI_AP_BLWL_MAC_LIST;
+ macindex = atoi(argv[index++]);
+ pACL->action = ADD_WHITE_MAC_ADDR;
+ pACL->index = macindex;
+ if (wmic_ether_aton_wild(argv[index], pACL->mac, &pACL->wildcard) != A_OK)
+ {
+ printf("bad mac address\n");
+ exit (0);
+ }
+ }
+ else if (3 == control) //add a mac into blacklist
+ {
+ cmd = WMI_AP_BLWL_MAC_LIST;
+ macindex = atoi(argv[index++]);
+ pACL->action = ADD_BLACK_MAC_ADDR;
+ pACL->index = macindex;
+ if (wmic_ether_aton_wild(argv[index], pACL->mac, &pACL->wildcard) != A_OK)
+ {
+ printf("bad mac address\n");
+ exit (0);
+ }
+ }
+ else if (4 == control) //reset whitelist
+ {
+ cmd = WMI_AP_BLWL_MAC_LIST;
+ pACL->action = RESET_WHITE_LIST;
+ }
+ else if (5 == control) //reset blacklist
+ {
+ cmd = WMI_AP_BLWL_MAC_LIST;
+ pACL->action = RESET_BLACK_LIST;
+ }
+ else
+ {
+ printf("cmd para error\n");
+ exit (0);
+ }
+
+ break;
+ }
+ case WMI_SET_RSSI_FILTER:
+ cmd = WMI_SET_RSSI_FILTER;
+ pSetRssiFilter->rssi_value = atoi(argv[optind]);
+ pSetRssiFilter->rssi_value -= 95; /*the configure value is the real dbm*/
+ break;
+ default:
+ usage();
+ break;
+ }
+ }
+
+ error = tcmd_init(ifname, rx_cb, TCMD_EP_WMI);
+
+ if (error) {
+ printf("Error\n");
+ return error;
+ }
+
+ switch (cmd) {
+ case WMI_SET_KEEPALIVE:
+ ((int *)buf)[0] = WMI_SET_KEEPALIVE_CMDID_EXT;
+ printf("Sending WMI_SET_KEEPALIVE\n");
+ tcmd_tx(buf, sizeof(*setKeepAlive) + 4, false);
+ break;
+ case WMI_SET_DISC_TIMEOUT:
+ ((int *)buf)[0] = WMI_SET_DISC_TIMEOUT_CMDID;
+ index = optind;
+ index--;
+ printf("Sending WMI_SET_DISC_TIMEOUT\n");
+ tcmd_tx(buf, 5, false);
+ break;
+ case WMI_GET_TARGET_STATS:
+ ((int *)buf)[0] = WMI_GET_STATISTICS_CMDID;
+ index = optind;
+ index--;
+ printf("case WMI_GET_TARGET_STATS=%d\n", WMI_GET_STATISTICS_CMDID);
+ tcmd_tx(buf, 4, true);
+ //printTargetStats(&(tgtStatsCmd.targetStats))
+ break;
+ case WMI_GET_VERSION:
+ ((int *)buf)[0] = WMI_GET_VERSION;
+ index = optind;
+ index--;
+ printf("case WMI_GET_VERSION\n");
+ tcmd_tx(buf, 4, true);
+ //printTargetStats(&(tgtStatsCmd.targetStats))
+ break;
+ case WMI_SET_SCAN_PARAMS:
+ ((int *)buf)[0] = WMI_SET_SCAN_PARAMS_CMDID;
+ index = optind;
+ index--;
+ printf("Sending WMI_SET_SCAN_PARAMS\n");
+ tcmd_tx(buf, 24, false);
+ break;
+ case WMI_SET_MCASTRATE:
+ ((int *)buf)[0] = WMI_SET_MCASTRATE_CMDID;
+ index = optind;
+ index--;
+ pMcast->bitrate = atoi(argv[index]);
+ printf("Sending WMI_SET_MCASTRATE %d\n", pMcast->bitrate);
+ tcmd_tx(buf, sizeof(WMI_SET_MCASTRATE_CMD) + 4, false);
+ break;
+ case WMI_VOICE_DETECTION_ENABLE:
+ ((int *)buf)[0] = WMI_VOICE_DETECTION_ENABLE_CMDID;
+ printf("Sending WMI_VOICE_DETECTION_ENABLE_CMDID(0x%x) to %s\n", WMI_VOICE_DETECTION_ENABLE_CMDID, pVoiceDetectionEnable->enable?"enable":"disable");
+ tcmd_tx(buf, sizeof(WMI_VOICE_DETECTION_ENABLE_CMD) + 4, false);
+ break;
+ case WMI_SET_TXE_NOTIFY:
+ ((int *)buf)[0] = WMI_SET_TXE_NOTIFY_CMDID;
+ printf("Sending WMI_SET_TXE_NOTIFY_CMDID, rate %d, pkts %d, intvl %d\n", pTXe->rate, pTXe->pkts, pTXe->intvl);
+ /* XXX: we do expect a TXE_NOTIFY_EVENT in response to this, but
+ * libtcmd currently does not support event listening. */
+ tcmd_tx(buf, sizeof(WMI_SET_TXE_NOTIFY_CMD) + 4, false);
+ break;
+ case WMI_SET_RECOVERY_SIMULATE:
+ ((int *)buf)[0] = WMI_SET_RECOVERY_TEST_PARAMETER_CMDID;
+ printf("Sending WMI_SET_RECOVERY_TEST_PARAMETER_CMDID(0x%x),type:%d, delay:%d\n", WMI_SET_RECOVERY_TEST_PARAMETER_CMDID,pSetRecoveryParam->type,pSetRecoveryParam->delay_time_ms);
+ tcmd_tx(buf, sizeof(WMI_SET_RECOVERY_TEST_PARAMETER_CMD) + 4, false);
+ break;
+case WMI_DISABLE_BCAST_IN_PM:
+((int *)buf)[0] = WMI_DISABLE_BCAST_IN_PM_CMDID;
+printf("Sending WMI_DISABLE_BCAST_IN_PM(0x%x),disable:%d\n", WMI_DISABLE_BCAST_IN_PM, disableBcastCmd->disable);
+tcmd_tx(buf, sizeof(WMI_DISABLE_BCAST_IN_PM_CMD)+4, false);
+break;
+ case WMI_AP_BLWL_POLICY:
+ ((int *)buf)[0] = WMI_AP_ACL_POLICY_CMDID;
+ printf("Sending WMI_AP_ACL_POLICY_CMDID(0x%x), policy = %d\n", WMI_AP_ACL_POLICY_CMDID, pACLpolicy->policy);
+ tcmd_tx(buf, sizeof(WMI_AP_ACL_POLICY_CMD) + 4, false);
+ break;
+ case WMI_AP_BLWL_MAC_LIST:
+ ((int *)buf)[0] = WMI_AP_ACL_MAC_LIST_CMDID;
+ printf("Sending WMI_AP_ACL_MAC_LIST_CMDID(0x%x), action = %d, index = %d, mac=%02X:%02X:%02X:%02X:%02X:%02X\n",
+ WMI_AP_ACL_MAC_LIST_CMDID, pACL->action, pACL->index,
+ pACL->mac[0], pACL->mac[1], pACL->mac[2], pACL->mac[3], pACL->mac[4], pACL->mac[5]);
+ tcmd_tx(buf, sizeof(WMI_AP_ACL_MAC_CMD) + 4, false);
+ break;
+ case WMI_AP_SET_NUM_STA:
+ ((int *)buf)[0] = WMI_AP_SET_NUM_STA_CMDID;
+ printf("Sending WMI_AP_SET_NUM_STA_CMDID(0x%x),NUMBER:%d\n", WMI_AP_SET_NUM_STA_CMDID, pNumSta->num_sta);
+ tcmd_tx(buf, sizeof(WMI_AP_NUM_STA_CMD)+4, false);
+ break;
+ case WMI_SET_RSSI_FILTER:
+ ((int *)buf)[0] = WMI_SET_RSSI_FILTER_CMDID;
+ printf("Sending WMI_SET_RSSI_FILTER_CMDID(0x%x),rssi:%d\n", WMI_SET_RSSI_FILTER_CMDID, pSetRssiFilter->rssi_value);
+ tcmd_tx(buf, sizeof(WMI_SET_RSSI_FILTER_CMD)+4, false);
+ break;
+ case WMI_SET_SSID:
+ ((int *)buf)[0] = WMI_SET_PROBED_SSID_CMDID;
+ printf("Sending WMI_SET_PROBED_SSID_CMDID(0x%x),ssid:%s index:%d\n", WMI_SET_PROBED_SSID_CMDID, ssid, pSsidCmd->entryIndex);
+ if (ssid && (strlen((const char *)ssid) > sizeof (pSsidCmd->ssid))) {
+ break;
+ }
+ if (strcmp((const char *)ssid, "off") == 0) {
+ pSsidCmd->ssidLength = 0;
+ pSsidCmd->flag = DISABLE_SSID_FLAG;
+ } else if (strcmp((const char *)ssid, "any") == 0) {
+ pSsidCmd->ssidLength = 0;
+ pSsidCmd->flag = ANY_SSID_FLAG;
+ } else {
+ pSsidCmd->flag = SPECIFIC_SSID_FLAG;
+ pSsidCmd->ssidLength = (A_UINT8)strlen((const char *)ssid);
+ memcpy(pSsidCmd->ssid, ssid, pSsidCmd->ssidLength);
+ }
+ tcmd_tx(buf, sizeof(WMI_PROBED_SSID_CMD)+4, false);
+ break;
+ case WMI_START_SCAN:
+ ((int *)buf)[0] = WMI_START_SCAN_CMDID;
+ printf("Sending WMI_START_SCAN_CMDID(0x%x),scanType:%d forceFgScan:%d,isLegacy:%d,homeDwellTime:%d,forceScanInterval:%d,numChannels:%d\n",
+ WMI_START_SCAN_CMDID, startScanCmd->scanType,startScanCmd->forceFgScan,startScanCmd->isLegacy,startScanCmd->homeDwellTime,startScanCmd->forceScanInterval,startScanCmd->numChannels);
+ tcmd_tx(buf, sizeof(WMI_START_SCAN_CMD)+4, false);
+ break;
+ case WMI_AP_SET_DTIM:
+ ((int *)buf)[0] = WMI_AP_SET_DTIM_CMDID;
+ printf("Sending WMI_AP_SET_DTIM_CMD(0x%x), dtim = %d\n", WMI_AP_SET_DTIM_CMDID, pDtim->dtim);
+ tcmd_tx(buf, sizeof(WMI_AP_SET_DTIM_CMD) + 4, false);
+ break;
+ case WMI_SET_DIVERSITY_PARAM:
+ ((int *)buf)[0] = WMI_SET_DIV_PARAMS_CMDID;
+ printf("Sending WMI_SET_DIVERSITY_PARAM IdleTime %d, antRssiThresh %d, divEnable %d, active_threshols_rate %d\n",
+ pDiversity->divIdleTime,
+ pDiversity->antRssiThresh,
+ pDiversity->divEnable,
+ pDiversity->active_treshold_rate);
+ tcmd_tx(buf, sizeof(WMI_DIV_PARAMS_CMD) + 4, false);
+ break;
+ default:
+ usage();
+ }
+
+ exit (0);
+}
+
+void rx_cb(void *buf, int len)
+{
+ TCMD_ID tcmd;
+ int i;
+ uint32_t * buff;
+ buff = (uint32_t *) buf;
+ char fw_version[32];
+
+ tcmd = * ((uint32_t *) buf + 1);
+ //printf("rx_cb: sizeof(TARGET_STATS)=%d, len=%d, user_cmd=%d\n",
+ // sizeof(TARGET_STATS), len, user_cmd);
+
+ for (i=0; i< len/4+1; i=i+4)
+ printf("rx_cb: 0x%08X 0x%08X 0x%08X 0x%08X\n",
+ buff[i], buff[i+1], buff[i+2], buff[i+3]);
+
+ //fprintf(stderr, "tcmd=%d\n", tcmd);
+ switch (buff[0]) {
+ case WMI_REPORT_STATISTICS_EVENTID:
+ printTargetStats((TARGET_STATS *)((uint32_t*)buf+1));
+ break;
+ case WMI_WLAN_VERSION_EVENTID:
+ memcpy(fw_version, (int *)buf+1, 32);
+ printf("FW Version: %s\n", fw_version);
+ break;
+ default:
+ break;
+ }
+
+}
+
+
+/*
+ * converts ieee channel number to frequency
+ */
+static A_UINT16
+wmic_ieee2freq(int chan)
+{
+ if (chan == 14) {
+ return 2484;
+ }
+ if (chan < 14) { /* 0-13 */
+ return (2407 + (chan*5));
+ }
+ if (chan < 27) { /* 15-26 */
+ return (2512 + ((chan-15)*20));
+ }
+ return (5000 + (chan*5));
+}
+
+
+#ifdef NOT_YET
+// Validate a hex character
+static A_BOOL
+_is_hex(char c)
+{
+ return (((c >= '0') && (c <= '9')) ||
+ ((c >= 'A') && (c <= 'F')) ||
+ ((c >= 'a') && (c <= 'f')));
+}
+
+// Validate alpha
+static A_BOOL
+isalpha(int c)
+{
+ return (((c >= 'a') && (c <= 'z')) ||
+ ((c >= 'A') && (c <= 'Z')));
+}
+
+// Validate alphanum
+static A_BOOL
+isalnum(int c)
+{
+ return (isalpha(c) || isdigit(c));
+}
+
+#endif
+
+// Convert a single hex nibble
+static int
+_from_hex(char c)
+{
+ int ret = 0;
+
+ if ((c >= '0') && (c <= '9')) {
+ ret = (c - '0');
+ } else if ((c >= 'a') && (c <= 'f')) {
+ ret = (c - 'a' + 0x0a);
+ } else if ((c >= 'A') && (c <= 'F')) {
+ ret = (c - 'A' + 0x0A);
+ }
+ return ret;
+}
+
+// Validate digit
+static A_BOOL
+isdigit(int c)
+{
+ return ((c >= '0') && (c <= '9'));
+}
+
+void
+convert_hexstring_bytearray(char *hexStr, A_UINT8 *byteArray, A_UINT8 numBytes)
+{
+ A_UINT8 i;
+
+ for (i = 0; i < numBytes; i++) {
+ byteArray[i] = 16*_from_hex(hexStr[2*i + 0]) + _from_hex(hexStr[2*i +1]);
+ }
+}
+
+/*------------------------------------------------------------------*/
+/*
+ * Input an Ethernet address and convert to binary.
+ */
+static A_STATUS
+wmic_ether_aton(const char *orig, A_UINT8 *eth)
+{
+ const char *bufp;
+ int i;
+
+ i = 0;
+ for(bufp = orig; *bufp != '\0'; ++bufp) {
+ unsigned int val;
+ unsigned char c = *bufp++;
+ if (isdigit(c)) val = c - '0';
+ else if (c >= 'a' && c <= 'f') val = c - 'a' + 10;
+ else if (c >= 'A' && c <= 'F') val = c - 'A' + 10;
+ else break;
+
+ val <<= 4;
+ c = *bufp++;
+ if (isdigit(c)) val |= c - '0';
+ else if (c >= 'a' && c <= 'f') val |= c - 'a' + 10;
+ else if (c >= 'A' && c <= 'F') val |= c - 'A' + 10;
+ else break;
+
+ eth[i] = (unsigned char) (val & 0377);
+ if(++i == ATH_MAC_LEN) {
+ /* That's it. Any trailing junk? */
+ if (*bufp != '\0') {
+#ifdef DEBUG
+ fprintf(stderr, "iw_ether_aton(%s): trailing junk!\n", orig);
+ return(A_EINVAL);
+#endif
+ }
+ return(A_OK);
+ }
+ if (*bufp != ':')
+ break;
+ }
+
+ return(A_EINVAL);
+}
+
+A_STATUS
+wmic_ether_aton_wild(const char *orig, A_UINT8 *eth, A_UINT8 *wild)
+{
+ const char *bufp;
+ unsigned char val, c;
+ int i=0;
+
+ *wild = 0;
+ for(bufp = orig; *bufp != '\0'; ++bufp) {
+ c = *bufp++;
+ if (isdigit(c)) val = c - '0';
+ else if (c >= 'a' && c <= 'f') val = c - 'a' + 10;
+ else if (c >= 'A' && c <= 'F') val = c - 'A' + 10;
+ else if (c == '*') { val = 0; *wild |= 1<<i; goto next; }
+ else break;
+
+ val <<= 4;
+ c = *bufp++;
+ if (isdigit(c)) val |= c - '0';
+ else if (c >= 'a' && c <= 'f') val |= c - 'a' + 10;
+ else if (c >= 'A' && c <= 'F') val |= c - 'A' + 10;
+ else break;
+
+next:
+ eth[i] = (unsigned char) (val & 0xFF);
+ if(++i == ATH_MAC_LEN) {
+ /* That's it. Any trailing junk? */
+ if (*bufp != '\0') {
+ }
+ return(A_OK);
+ }
+ if (*bufp != ':')
+ break;
+ }
+
+ return(A_EINVAL);
+}
+
+A_STATUS
+wmic_validate_roam_ctrl(WMI_SET_ROAM_CTRL_CMD *pRoamCtrl, A_UINT8 numArgs,
+ char **argv)
+{
+ A_STATUS status = A_OK;
+ WMI_BSS_BIAS *pBssBias;
+ A_INT32 bias;
+ A_UINT8 i = 0;
+
+ switch (pRoamCtrl->roamCtrlType) {
+ case WMI_FORCE_ROAM:
+ if (numArgs != 1) {
+ fprintf(stderr, "BSSID to roam not given\n");
+ status = A_EINVAL;
+ } else if (wmic_ether_aton(argv[optind], pRoamCtrl->info.bssid)
+ != A_OK)
+ {
+ fprintf(stderr,"BSSID %s not in correct format\n",
+ argv[optind]);
+ status = A_EINVAL;
+ }
+ break;
+ case WMI_SET_ROAM_MODE:
+ if (numArgs != 1) {
+ fprintf(stderr, "roam mode(default, bssbias, lock) not "
+ " given\n");
+ status = A_EINVAL;
+ } else {
+ if (strcasecmp(argv[optind], "default") == 0) {
+ pRoamCtrl->info.roamMode = WMI_DEFAULT_ROAM_MODE;
+ } else if (strcasecmp(argv[optind], "bssbias") == 0) {
+ pRoamCtrl->info.roamMode = WMI_HOST_BIAS_ROAM_MODE;
+ } else if (strcasecmp(argv[optind], "lock") == 0) {
+ pRoamCtrl->info.roamMode = WMI_LOCK_BSS_MODE;
+ } else {
+ fprintf(stderr, "roam mode(default, bssbias, lock) not "
+ " given\n");
+ status = A_EINVAL;
+ }
+ }
+ break;
+ case WMI_SET_HOST_BIAS:
+ if ((numArgs & 0x01) || (numArgs > 25) ) {
+ fprintf(stderr, "roam bias too many entries or bss bias"
+ "not input for every BSSID\n");
+ status = A_EINVAL;
+ } else {
+ pRoamCtrl->info.bssBiasInfo.numBss = numArgs >> 1;
+ pBssBias = pRoamCtrl->info.bssBiasInfo.bssBias;
+ while (i < pRoamCtrl->info.bssBiasInfo.numBss) {
+ if (wmic_ether_aton(argv[optind + 2 * i],
+ pBssBias[i].bssid)
+ != A_OK)
+ {
+ fprintf(stderr,"BSSID %s not in correct format\n",
+ argv[optind + 2 * i]);
+ status = A_EINVAL;
+ pRoamCtrl->info.bssBiasInfo.numBss = 0;
+ break;
+ }
+ bias = atoi(argv[optind + 2 * i + 1]);
+ if ((bias < -256) || (bias > 255)) {
+ fprintf(stderr,"bias value %d is not in range\n",
+ bias);
+ status = A_EINVAL;
+ pRoamCtrl->info.bssBiasInfo.numBss = 0;
+ break;
+ }
+ pBssBias[i].bias = bias;
+ i++;
+ }
+ }
+ break;
+ case WMI_SET_LOWRSSI_SCAN_PARAMS:
+ if (numArgs != 4) {
+ fprintf(stderr, "not enough arguments\n");
+ status = A_EINVAL;
+ } else {
+ pRoamCtrl->info.lrScanParams.lowrssi_scan_period = atoi(argv[optind]);
+ if (atoi(argv[optind+1]) >= atoi(argv[optind+2])) {
+ pRoamCtrl->info.lrScanParams.lowrssi_scan_threshold = atoi(argv[optind+1]);
+ pRoamCtrl->info.lrScanParams.lowrssi_roam_threshold = atoi(argv[optind+2]);
+ } else {
+ fprintf(stderr, "Scan threshold should be greater than \
+ equal to roam threshold\n");
+ status = A_EINVAL;
+ }
+ pRoamCtrl->info.lrScanParams.roam_rssi_floor = atoi(argv[optind+3]);
+ }
+
+ break;
+ default:
+ status = A_EINVAL;
+ fprintf(stderr,"roamctrl type %d out if range should be between"
+ " %d and %d\n", pRoamCtrl->roamCtrlType,
+ WMI_MIN_ROAM_CTRL_TYPE, WMI_MAX_ROAM_CTRL_TYPE);
+ break;
+ }
+ return status;
+}
+
+A_STATUS
+wmic_validate_appie(struct ieee80211req_getset_appiebuf *appIEInfo, char **argv)
+{
+ A_STATUS status = A_OK;
+ A_UINT8 index = optind - 1;
+ A_UINT16 ieLen;
+
+ if ((strlen(argv[index]) == strlen("probe")) &&
+ (strcmp(argv[index], "probe") == 0))
+ {
+ appIEInfo->app_frmtype = IEEE80211_APPIE_FRAME_PROBE_REQ;
+ } else if ((strlen(argv[index]) == strlen("assoc")) &&
+ (strcmp(argv[index], "assoc") == 0))
+ {
+ appIEInfo->app_frmtype = IEEE80211_APPIE_FRAME_ASSOC_REQ;
+ } else if((strlen(argv[index]) == strlen("beacon")) &&
+ (strcmp(argv[index], "beacon") == 0)) {
+ appIEInfo->app_frmtype = IEEE80211_APPIE_FRAME_BEACON;
+ } else if((strlen(argv[index]) == strlen("respon")) &&
+ (strcmp(argv[index], "respon") == 0)) {
+ appIEInfo->app_frmtype = IEEE80211_APPIE_FRAME_PROBE_RESP;
+ } else {
+ printf("specify one of beacon/probe/respon/assoc\n");
+ return A_EINVAL;
+ }
+ index++;
+
+ ieLen = strlen(argv[index]);
+ if ((ieLen == 1) && argv[index][0] == '0') {
+ appIEInfo->app_buflen = 0;
+ } else if ((ieLen > 4) && (ieLen <= 2*IEEE80211_APPIE_FRAME_MAX_LEN) &&
+ _from_hex(argv[index][2])*16 +
+ _from_hex(argv[index][3]) + 2 == ieLen/2)
+ {
+ if ((argv[index][0] != 'd') && (argv[index][1] != 'd')) {
+ status = A_EINVAL;
+ } else {
+ convert_hexstring_bytearray(argv[index], appIEInfo->app_buf, ieLen/2);
+ appIEInfo->app_buflen = ieLen/2;
+ }
+ } else {
+ status = A_EINVAL;
+ printf("Invalid IE format should be of format dd04aabbccdd\n");
+ }
+
+ return status;
+}
+
+static A_STATUS
+wmic_get_ip(const char *ipstr, A_UINT32 *ip)
+{
+ char tokstr[strlen(ipstr)];
+ char *tok;
+ int i = 4;
+ A_UINT32 addr = 0;
+ A_UINT32 sb;
+
+ strcpy(tokstr, ipstr);
+ tok = strtok(tokstr, ".");
+ if (!tok)
+ return A_EINVAL;
+
+ do {
+ if ((sb = strtoul(tok, NULL, 10)) < 0)
+ return A_EINVAL;
+ addr |= sb << (--i * 8);
+
+ if (i < 0)
+ return A_EINVAL;
+ } while ((tok = strtok(NULL, ".")) != NULL);
+
+ *ip = addr;
+ return A_OK;
+}
+
+A_STATUS
+wmic_validate_setkeepalive(WMI_SET_KEEPALIVE_CMD_EXT *cmd, char **argv)
+{
+ A_STATUS status = A_OK;
+ A_UINT8 index = optind - 1;
+ A_UINT8 intvl, mode;
+
+ if ((intvl = strtol(argv[index++], NULL, 10)) < 0) {
+ status = A_EINVAL;
+ printf("invalid keepalive interval\n");
+ goto out;
+ }
+ cmd->keepaliveInterval = intvl;
+
+ mode = strtol(argv[index++], NULL, 10);
+ if (mode < 0 || mode > 3) {
+ status = A_EINVAL;
+ printf("invalid keepalive mode\n");
+ goto out;
+ }
+ cmd->keepaliveMode = mode;
+
+ if (wmic_ether_aton(argv[index++], cmd->peer_mac_address) != A_OK) {
+ status = A_EINVAL;
+ printf("invalid target mac\n");
+ goto out;
+ }
+
+ if (wmic_get_ip(argv[index++], &cmd->keepalive_arp_srcip) != A_OK) {
+ status = A_EINVAL;
+ printf("invalid src ip\n");
+ goto out;
+ }
+
+ if (wmic_get_ip(argv[index++], &cmd->keepalive_arp_tgtip) != A_OK) {
+ status = A_EINVAL;
+ printf("invalid tgt ip\n");
+ goto out;
+ }
+
+out:
+ return status;
+}
+
+A_STATUS
+wmic_validate_mgmtfilter(A_UINT32 *pMgmtFilter, char **argv)
+{
+ A_UINT8 index = optind - 1;
+ A_BOOL setFilter = FALSE;
+ A_UINT32 filterType;
+
+ if ((strlen(argv[index]) == strlen("set")) &&
+ (strcmp(argv[index], "set") == 0))
+ {
+ setFilter = TRUE;
+ } else if ((strlen(argv[index]) == strlen("clear")) &&
+ (strcmp(argv[index], "clear") == 0))
+ {
+ setFilter = FALSE;
+ } else {
+ printf("specify one of set/clear\n");
+ return A_EINVAL;
+ }
+ index++;
+ if ((strlen(argv[index]) == strlen("beacon")) &&
+ (strcmp(argv[index], "beacon") == 0))
+ {
+ filterType = IEEE80211_FILTER_TYPE_BEACON;
+ } else if ((strlen(argv[index]) == strlen("proberesp")) &&
+ (strcmp(argv[index], "proberesp") == 0))
+ {
+ filterType = IEEE80211_FILTER_TYPE_PROBE_RESP;
+ } else {
+ printf("specify one of beacon/proberesp\n");
+ return A_EINVAL;
+ }
+ *pMgmtFilter = 0;
+
+ if (setFilter) {
+ *pMgmtFilter |= filterType;
+ } else {
+ *pMgmtFilter &= ~filterType;
+ }
+
+ return A_OK;
+}
+
+void
+printTargetStats(TARGET_STATS *pStats)
+{
+ printf("Target stats\n");
+ printf("------------\n");
+ printf("tx_packets = %d\n"
+ "tx_bytes = %d\n"
+ "tx_unicast_pkts = %d\n"
+ "tx_unicast_bytes = %d\n"
+ "tx_multicast_pkts = %d\n"
+ "tx_multicast_bytes = %d\n"
+ "tx_broadcast_pkts = %d\n"
+ "tx_broadcast_bytes = %d\n"
+ "tx_rts_success_cnt = %d\n"
+ "tx_packet_per_ac[%d] = %d\n"
+ "tx_packet_per_ac[%d] = %d\n"
+ "tx_packet_per_ac[%d] = %d\n"
+ "tx_packet_per_ac[%d] = %d\n"
+ "tx_errors = %d\n"
+ "tx_failed_cnt = %d\n"
+ "tx_retry_cnt = %d\n"
+ "tx_mult_retry_cnt = %d\n"
+ "tx_rts_fail_cnt = %d\n"
+ "tx_unicast_rate = %d Kbps\n"
+ "rx_packets = %d\n"
+ "rx_bytes = %d\\n"
+ "rx_unicast_pkts = %d\n"
+ "rx_unicast_bytes = %d\n"
+ "rx_multicast_pkts = %d\n"
+ "rx_multicast_bytes = %d\n"
+ "rx_broadcast_pkts = %d\n"
+ "rx_broadcast_bytes = %d\n"
+ "rx_fragment_pkt = %d\n"
+ "rx_errors = %d\n"
+ "rx_crcerr = %d\n"
+ "rx_key_cache_miss = %d\n"
+ "rx_decrypt_err = %d\n"
+ "rx_duplicate_frames = %d\n"
+ "rx_unicast_rate = %d Kbps\n"
+ "tkip_local_mic_failure = %d\n"
+ "tkip_counter_measures_invoked = %d\n"
+ "tkip_replays = %d\n"
+ "tkip_format_errors = %d\n"
+ "ccmp_format_errors = %d\n"
+ "ccmp_replays = %d\n"
+ "power_save_failure_cnt = %d\n"
+ "noise_floor_calibation = %d\n"
+ "cs_bmiss_cnt = %d\n"
+ "cs_lowRssi_cnt = %d\n"
+ "cs_connect_cnt = %d\n"
+ "cs_disconnect_cnt = %d\n"
+ "cs_aveBeacon_snr= %d\n"
+ "cs_aveBeacon_rssi = %d\n"
+ "cs_lastRoam_msec = %d\n"
+ "cs_rssi = %d\n"
+ "cs_snr = %d\n"
+ "lqVal = %d\n"
+ "wow_num_pkts_dropped = %d\n"
+ "wow_num_host_pkt_wakeups = %d\n"
+ "wow_num_host_event_wakeups = %d\n"
+ "wow_num_events_discarded = %d\n"
+ "arp_received = %d\n"
+ "arp_matched = %d\n"
+ "arp_replied = %d\n",
+ (int) pStats->tx_packets,
+ (int) pStats->tx_bytes,
+ (int) pStats->tx_unicast_pkts,
+ (int) pStats->tx_unicast_bytes,
+ (int) pStats->tx_multicast_pkts,
+ (int) pStats->tx_multicast_bytes,
+ (int) pStats->tx_broadcast_pkts,
+ (int) pStats->tx_broadcast_bytes,
+ (int) pStats->tx_rts_success_cnt,
+ 0, (int) pStats->tx_packet_per_ac[0],
+ 1, (int) pStats->tx_packet_per_ac[1],
+ 2, (int) pStats->tx_packet_per_ac[2],
+ 3, (int) pStats->tx_packet_per_ac[3],
+ (int) pStats->tx_errors,
+ (int) pStats->tx_failed_cnt,
+ (int) pStats->tx_retry_cnt,
+ (int) pStats->tx_mult_retry_cnt,
+ (int) pStats->tx_rts_fail_cnt,
+ (int) pStats->tx_unicast_rate,
+ (int) pStats->rx_packets,
+ (int) pStats->rx_bytes,
+ (int) pStats->rx_unicast_pkts,
+ (int) pStats->rx_unicast_bytes,
+ (int) pStats->rx_multicast_pkts,
+ (int) pStats->rx_multicast_bytes,
+ (int) pStats->rx_broadcast_pkts,
+ (int) pStats->rx_broadcast_bytes,
+ (int) pStats->rx_fragment_pkt,
+ (int) pStats->rx_errors,
+ (int) pStats->rx_crcerr,
+ (int) pStats->rx_key_cache_miss,
+ (int) pStats->rx_decrypt_err,
+ (int) pStats->rx_duplicate_frames,
+ (int) pStats->rx_unicast_rate,
+ (int) pStats->tkip_local_mic_failure,
+ (int) pStats->tkip_counter_measures_invoked,
+ (int) pStats->tkip_replays,
+ (int) pStats->tkip_format_errors,
+ (int) pStats->ccmp_format_errors,
+ (int) pStats->ccmp_replays,
+ (int) pStats->power_save_failure_cnt,
+ (int) pStats->noise_floor_calibation,
+ (int) pStats->cs_bmiss_cnt,
+ (int) pStats->cs_lowRssi_cnt,
+ (int) pStats->cs_connect_cnt,
+ (int) pStats->cs_disconnect_cnt,
+ (int) pStats->cs_aveBeacon_snr,
+ (int) pStats->cs_aveBeacon_rssi,
+ (int) pStats->cs_lastRoam_msec,
+ (int) pStats->cs_rssi,
+ (int) pStats->cs_snr,
+ (int) pStats->lq_val,
+ (int) pStats->wow_num_pkts_dropped,
+ (int) pStats->wow_num_host_pkt_wakeups,
+ (int) pStats->wow_num_host_event_wakeups,
+ (int) pStats->wow_num_events_discarded,
+ (int) pStats->arp_received,
+ (int) pStats->arp_matched,
+ (int) pStats->arp_replied
+);
+
+}
+
+void
+printBtcoexConfig(WMI_BTCOEX_CONFIG_EVENT *pConfig)
+{
+ switch(pConfig->btProfileType) {
+ case WMI_BTCOEX_BT_PROFILE_SCO:
+ {
+ WMI_SET_BTCOEX_SCO_CONFIG_CMD *scoConfigCmd = &pConfig->info.scoConfigCmd;
+ printf("BTCOEX SCO CONFIG\n");
+ printf("GENERIC SCO CONFIG\n");
+ printf("scoSlots =%d\n"
+ "scoIdleSlots =%d\n"
+ "scoFlags = %d\n"
+ "linkId = %d\n",
+ scoConfigCmd->scoConfig.scoSlots,
+ scoConfigCmd->scoConfig.scoIdleSlots,
+ scoConfigCmd->scoConfig.scoFlags,
+ scoConfigCmd->scoConfig.linkId
+ );
+ printf("PSPOLL SCO CONFIG \n");
+ printf( "scoCyclesForceTrigger = %d\n"
+ "scoDataResponseTimeout = %d\n"
+ "scoStompDutyCyleVal = %d\n"
+ "scoStompDutyCyleMaxVal = %d\n"
+ "scoPsPollLatencyFraction = %d\n",
+ scoConfigCmd->scoPspollConfig.scoCyclesForceTrigger,
+ scoConfigCmd->scoPspollConfig.scoDataResponseTimeout,
+ scoConfigCmd->scoPspollConfig.scoStompDutyCyleVal,
+ scoConfigCmd->scoPspollConfig.scoStompDutyCyleMaxVal,
+ scoConfigCmd->scoPspollConfig.scoPsPollLatencyFraction
+ );
+ printf("SCO optmode Config\n");
+ printf( "scoStompCntIn100ms = %d\n"
+ "scoContStompMax = %d\n"
+ "scoMinlowRateMbps = %d\n"
+ "scoLowRateCnt = %d\n"
+ "scoHighPktRatio = %d\n"
+ "scoMaxAggrSize = %d\n",
+ scoConfigCmd->scoOptModeConfig.scoStompCntIn100ms,
+ scoConfigCmd->scoOptModeConfig.scoContStompMax,
+ scoConfigCmd->scoOptModeConfig.scoMinlowRateMbps,
+ scoConfigCmd->scoOptModeConfig.scoLowRateCnt,
+ scoConfigCmd->scoOptModeConfig.scoHighPktRatio,
+ scoConfigCmd->scoOptModeConfig.scoMaxAggrSize
+ );
+ printf("SCO wlan scan config\n");
+ printf("scanInterval = %d\n"
+ "maxScanStompCnt = %d\n",
+ scoConfigCmd->scoWlanScanConfig.scanInterval,
+ scoConfigCmd->scoWlanScanConfig.maxScanStompCnt
+ );
+
+ }
+ break;
+
+ case WMI_BTCOEX_BT_PROFILE_A2DP:
+ {
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMD *a2dpConfigCmd = &pConfig->info.a2dpConfigCmd;
+ printf("BTCOEX A2DP CONFIG\n");
+ printf("a2dpFlags = %d\n"
+ "linkId = %d\n",
+ a2dpConfigCmd->a2dpConfig.a2dpFlags,
+ a2dpConfigCmd->a2dpConfig.linkId
+ );
+ printf("BTCOEX PSPOLLMODE A2DP CONFIG\n");
+ printf("a2dpWlanMaxDur = %d\n"
+ "a2dpMinBurstCnt = %d\n"
+ "a2dpDataRespTimeout = %d\n",
+ a2dpConfigCmd->a2dppspollConfig.a2dpWlanMaxDur,
+ a2dpConfigCmd->a2dppspollConfig.a2dpMinBurstCnt,
+ a2dpConfigCmd->a2dppspollConfig.a2dpDataRespTimeout
+ );
+ printf("BTCOEX OPTMODE A2DP CONFIG\n");
+ printf("a2dpMinlowRateMbps = %d\n"
+ "a2dpLowRateCnt = %d\n"
+ "a2dpHighPktRatio = %d\n"
+ "a2dpMaxAggrSize = %d\n"
+ "a2dpPktStompCnt = %d\n",
+ a2dpConfigCmd->a2dpOptConfig.a2dpMinlowRateMbps,
+ a2dpConfigCmd->a2dpOptConfig.a2dpLowRateCnt,
+ a2dpConfigCmd->a2dpOptConfig.a2dpHighPktRatio,
+ a2dpConfigCmd->a2dpOptConfig.a2dpMaxAggrSize,
+ a2dpConfigCmd->a2dpOptConfig.a2dpPktStompCnt
+ );
+ }
+ break;
+
+ case WMI_BTCOEX_BT_PROFILE_INQUIRY_PAGE:
+ {
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD *btinquiryPageConfigCmd = &pConfig->info.btinquiryPageConfigCmd;
+
+ printf("BTCOEX BTINQUIRY PAGE CONFIG\n");
+ printf("btInquiryDataFetchFrequency = %d\n"
+ "protectBmissDurPostBtInquiry = %d\n"
+ "maxpageStomp = %d\n"
+ "btInquiryPageFlag = %d\n",
+ btinquiryPageConfigCmd->btInquiryDataFetchFrequency,
+ btinquiryPageConfigCmd->protectBmissDurPostBtInquiry,
+ btinquiryPageConfigCmd->maxpageStomp,
+ btinquiryPageConfigCmd->btInquiryPageFlag
+ );
+ }
+ break;
+
+ case WMI_BTCOEX_BT_PROFILE_ACLCOEX:
+ {
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD *aclcoexConfig = &pConfig->info.aclcoexConfig;
+ printf("BTCOEX ACLCOEX CONFIG\n");
+ printf("aclWlanMediumDur = %d\n"
+ "aclBtMediumDur = %d\n"
+ "aclDetectTimeout = %d\n"
+ "aclPktCntLowerLimit = %d\n"
+ "aclIterForEnDis = %d\n"
+ "aclPktCntUpperLimit = %d\n"
+ "aclCoexFlags = %d\n"
+ "linkId = %d\n",
+ aclcoexConfig->aclCoexConfig.aclWlanMediumDur,
+ aclcoexConfig->aclCoexConfig.aclBtMediumDur,
+ aclcoexConfig->aclCoexConfig.aclDetectTimeout,
+ aclcoexConfig->aclCoexConfig.aclPktCntLowerLimit,
+ aclcoexConfig->aclCoexConfig.aclIterForEnDis,
+ aclcoexConfig->aclCoexConfig.aclPktCntUpperLimit,
+ aclcoexConfig->aclCoexConfig.aclCoexFlags,
+ aclcoexConfig->aclCoexConfig.linkId
+ );
+ printf("BTCOEX PSPOLLMODE ACLCOEX CONFIG\n");
+ printf("aclDataRespTimeout = %d\n",
+ aclcoexConfig->aclCoexPspollConfig.aclDataRespTimeout
+ );
+ printf("BTCOEX OPTMODE ACLCOEX CONFIG\n");
+ printf("aclCoexMinlowRateMbps = %d\n"
+ "aclCoexLowRateCnt = %d\n"
+ "aclCoexHighPktRatio = %d\n"
+ "aclCoexMaxAggrSize = %d\n"
+ "aclPktStompCnt = %d\n",
+ aclcoexConfig->aclCoexOptConfig.aclCoexMinlowRateMbps,
+ aclcoexConfig->aclCoexOptConfig.aclCoexLowRateCnt,
+ aclcoexConfig->aclCoexOptConfig.aclCoexHighPktRatio,
+ aclcoexConfig->aclCoexOptConfig.aclCoexMaxAggrSize,
+ aclcoexConfig->aclCoexOptConfig.aclPktStompCnt
+ );
+ }
+ break;
+
+ default:
+ break;
+ }
+ return;
+}
+
+
+void print_wild_mac(unsigned char *mac, char wildcard)
+{
+ int i;
+
+ printf(" ");
+ for(i=0;i<5;i++) {
+ if(wildcard & (1<<i)) printf("*:");
+ else printf("%02X:", mac[i]);
+ }
+
+ if(wildcard & (1<<i)) printf("*\n");
+ else printf("%02X\n", mac[5]);
+}
diff --git a/btconfig_1.05/Android.mk b/btconfig_1.05/Android.mk
new file mode 100755
index 0000000..d61ca11
--- /dev/null
+++ b/btconfig_1.05/Android.mk
@@ -0,0 +1,21 @@
+ifeq ($(BOARD_HAVE_BLUETOOTH),true)
+
+LOCAL_PATH:= $(call my-dir)
+include $(CLEAR_VARS)
+
+LOCAL_C_INCLUDES:= \
+ $(call include-path-for,bluez)/lib/ \
+
+LOCAL_SRC_FILES:= \
+ compat/getline.c \
+ btconfig.c
+
+LOCAL_SHARED_LIBRARIES := \
+ libbluetooth \
+
+LOCAL_MODULE_PATH := $(TARGET_OUT_OPTIONAL_EXECUTABLES)
+LOCAL_MODULE_TAGS := eng
+LOCAL_MODULE:=btconfig
+
+include $(BUILD_EXECUTABLE)
+endif
diff --git a/btconfig_1.05/COPYING b/btconfig_1.05/COPYING
new file mode 100644
index 0000000..e90dfed
--- /dev/null
+++ b/btconfig_1.05/COPYING
@@ -0,0 +1,340 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.
+ 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it. (Some other Free Software Foundation software is covered by
+the GNU Library General Public License instead.) You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must show them these terms so they know their
+rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ Finally, any free program is threatened constantly by software
+patents. We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary. To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License. The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+ 1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+ 2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) You must cause the modified files to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ b) You must cause any work that you distribute or publish, that in
+ whole or in part contains or is derived from the Program or any
+ part thereof, to be licensed as a whole at no charge to all third
+ parties under the terms of this License.
+
+ c) If the modified program normally reads commands interactively
+ when run, you must cause it, when started running for such
+ interactive use in the most ordinary way, to print or display an
+ announcement including an appropriate copyright notice and a
+ notice that there is no warranty (or else, saying that you provide
+ a warranty) and that users may redistribute the program under
+ these conditions, and telling the user how to view a copy of this
+ License. (Exception: if the Program itself is interactive but
+ does not normally print such an announcement, your work based on
+ the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+ a) Accompany it with the complete corresponding machine-readable
+ source code, which must be distributed under the terms of Sections
+ 1 and 2 above on a medium customarily used for software interchange; or,
+
+ b) Accompany it with a written offer, valid for at least three
+ years, to give any third party, for a charge no more than your
+ cost of physically performing source distribution, a complete
+ machine-readable copy of the corresponding source code, to be
+ distributed under the terms of Sections 1 and 2 above on a medium
+ customarily used for software interchange; or,
+
+ c) Accompany it with the information you received as to the offer
+ to distribute corresponding source code. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form with such
+ an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it. For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable. However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+ 5. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Program or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+ 7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all. For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded. In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+ 9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation. If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+ 10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission. For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this. Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+ NO WARRANTY
+
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) year name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU Library General
+Public License instead of this License.
diff --git a/btconfig_1.05/ChangeLog.txt b/btconfig_1.05/ChangeLog.txt
new file mode 100755
index 0000000..00581d5
--- /dev/null
+++ b/btconfig_1.05/ChangeLog.txt
@@ -0,0 +1,5 @@
+10/03/2012: define HI_MAGIC_NUMBER as unsigned short int, send sleep mode enabled command before do soft reset in master blaster mode since sleep mode is enabled from PS_ASIC.pst. version:1.05
+06/08/2012: Sync the structure tBtHost_Interest and PsSysCfgTransmitPowerControlEntry with BtTest version: 1.04
+04/26/2012: Support RX test and get BER at "Masterblaster" mode version: 1.03
+0
+03/14/2012: BtAgent is running at customer platform. It communicates with the host via USB. It looks like a router, which is forwarding packet between the host and AR3002. BtSoc.exe is running at the host. Like BtUART.exe, it can send command or receive event from AR3002 via BtAgent. version: 1.02
diff --git a/btconfig_1.05/Makefile b/btconfig_1.05/Makefile
new file mode 100755
index 0000000..520e903
--- /dev/null
+++ b/btconfig_1.05/Makefile
@@ -0,0 +1,23 @@
+ # Copyright (c) 2008-2009 Atheros Corporation. All rights reserved.
+ #
+ # This program is free software; you can redistribute it and/or modify
+ # it under the terms of the GNU General Public License version 2 as
+ # published by the Free Software Foundation;
+ #
+ # Software distributed under the License is distributed on an "AS
+ # IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
+ # implied. See the License for the specific language governing
+ # rights and limitations under the License.
+
+
+CC := arm-none-linux-gnueabi-gcc
+CFLAGS=-I../../../bluez/bluez/lib/ -mtune=arm1136j-s -march=armv6
+LDFLAGS=-lbluetooth -L../../../bluez/dist/usr/lib -L../../../../a5s_linux_sdk/ambarella/prebuild/third-party/ncurses/lib/
+
+all: btconfig
+
+btconfig: btconfig.c
+ $(CC) -Wall -g btconfig.c $(CFLAGS) $(LDFLAGS) -o btconfig
+
+clean:
+ rm btconfig
diff --git a/btconfig_1.05/README b/btconfig_1.05/README
new file mode 100755
index 0000000..21a93cf
--- /dev/null
+++ b/btconfig_1.05/README
@@ -0,0 +1,68 @@
+Compilation Instructions
+========================
+
+In order to compile Bluetooth utilities you need following software packages:
+ - Linux Bluetooth protocol stack (BlueZ)
+ - GCC compiler
+ - D-Bus library
+ - GLib library
+ - Lexical Analyzer (flex, lex)
+ - YACC (yacc, bison, byacc)
+
+To install these packages, switch to root previlege.
+
+Fedora Core:
+1] Linux Bluetooth protocol stack (BlueZ):
+ Download latest source code of BlueZ stack from:
+ http://www.bluez.org/download/
+2]GCC Compiler:
+ =>yum install gcc
+
+3]D-Bus library:
+ =>yum install dbus
+
+4]Lexical Analyzer (flex, lex)
+ =>yum install flex
+
+5]YACC (yacc, bison, byacc)
+ =>yum install byacc bison
+
+
+Ubuntu:
+1] Linux Bluetooth protocol stack (BlueZ):
+ Download latest source code of BlueZ stack from:
+ http://www.bluez.org/download/
+
+2]GCC Compiler:
+ =>sudo apt-get install gcc
+
+3]D-Bus library
+ =>sudo apt-get install libdbus-glib-1-dev
+
+4]Lexical Analyzer (flex, lex)
+ =>sudo apt-get install flex
+
+5]YACC (yacc, bison, byacc)
+ =>sudo apt-get install byacc
+
+After downloading these packages please follow README file from bluez source folder to install Bluez stack.
+
+Once BlueZ Stack is installed, go to btconfig folder and give make command to compile btconfig source code:
+ =>make
+
+ "btconfig" executable will be genearated and copied to /usr/bin folder, so that you can access it from any location.
+
+Application usage
+=================
+
+Use following command to get help about the features supported by btconfig:
+ => btconfig --help
+ => btconfig
+
+To get the help about syntax and additional parameters of the command:
+ E.g. To get help about Write BD Address (wba) command
+ => btconfig wba
+ Read PS tag operation
+ => btconfig rpst
+
+
diff --git a/btconfig_1.05/btconfig.c b/btconfig_1.05/btconfig.c
new file mode 100755
index 0000000..a3dc89b
--- /dev/null
+++ b/btconfig_1.05/btconfig.c
@@ -0,0 +1,5308 @@
+/*
+ * Copyright (c) 2008-2009 Atheros Corporation. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation;
+ *
+ * Software distributed under the License is distributed on an "AS
+ * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
+ * implied. See the License for the specific language governing
+ * rights and limitations under the License.
+ *
+ * <Configuration utility for AR3001>
+ *
+ * <btconfig.c>
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdio.h>
+#include <errno.h>
+#include <ctype.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <stdlib.h>
+#include <string.h>
+#include <getopt.h>
+#include <signal.h>
+#include <time.h>
+#include <sys/param.h>
+#include <sys/ioctl.h>
+#include <sys/socket.h>
+#include <linux/types.h>
+#include <netinet/in.h>
+#include <netinet/tcp.h>
+#include <bluetooth/bluetooth.h>
+#include <bluetooth/hci.h>
+#include <bluetooth/hci_lib.h>
+
+#include "compat/getline.h"
+#include "btconfig.h"
+#include "masterblaster.h"
+
+#define BT_PORT 2398
+/* Global Variables */
+static int sid, cid, aid;
+static int Tag_Count = 0;
+static int Patch_Count = 0;
+static unsigned short DynMem_Count = 0;
+static int Total_tag_lenght = 0;
+static BOOL CtrlCBreak = FALSE;
+bdaddr_t BdAddr;
+/* Function Declarations */
+static int LoadConfFile(const char *path, int basetag, int format);
+static int ParseFiles(FILE *fpt, int basetag, int format);
+static void LoadPSHeader(UCHAR *HCI_PS_Command,UCHAR opcode,int length,int index);
+static BOOL PSOperations(int dd, UCHAR Opcode, int Param1, UINT32 *out);
+static BOOL SU_LERxTest(int dev_id, UCHAR channel);
+static BOOL SU_LETxTest(int dev_id, UCHAR channel, UCHAR length, UCHAR payload);
+static int PSInit(int dd);
+static void usage(void);
+static int writeHciCommand(int dd, uint16_t ogf, uint16_t ocf, uint8_t plen, UCHAR *buf);
+static int MemBlkRead(int dd, UINT32 Address,UCHAR *pBuffer, UINT32 Length);
+static int MemBlkwrite(int dd, UINT32 Address,UCHAR *pBuffer, UINT32 Length);
+static int Dut(int dd);
+static int ReadAudioStats(int dd);
+static int ReadGlobalDMAStats(int dd);
+static int ResetGlobalDMAStats(int dd);
+static int ReadTpcTable(int dd);
+static int ReadHostInterest(int dd,tBtHostInterest *pHostInt);
+static int ReadMemoryBlock(int dd, int StartAddress,UCHAR *pBufToWrite, int Length );
+static int WriteMemoryBlock(int dd, int StartAddress,UCHAR *pBufToWrite, int Length );
+static int write_otpRaw(int dev_id, int address, int length, UCHAR *data);
+static int read_otpRaw(int dev_id, int address, int length, UCHAR *data);
+static void dumpHex(UCHAR *buf, int length, int col);
+static void sig_term(int sig);
+static UCHAR LEMode = 0;
+
+static struct option main_options[] = {
+ { "help", 0, 0, 'h' },
+ { "device", 1, 0, 'i' },
+ { 0, 0, 0, 0 }
+};
+//Read the configuration files, file paths are hardcoded in btconfig.h
+static int LoadConfFile(const char *path, int basetag, int format){
+
+ FILE *fp;
+ //printf("\nOpening file :%s\n",path);
+ fp = fopen(path,"r");
+ if(fp == NULL){
+ // perror("File open error");
+ return FALSE;
+ }
+ // Parse file
+ if(!ParseFiles(fp,basetag,format)){
+ printf("\nError :Invalid file format\n");
+ return FALSE;
+ }
+ // Load conf data to PS
+
+ fclose(fp);
+ return TRUE;
+}
+
+
+unsigned int uGetInputDataFormat(char **str, struct ST_PS_DATA_FORMAT *pstFormat)
+{
+ char *pCharLine = *str;
+ if(pCharLine[0] != '[') {
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ return TRUE;
+ }
+ switch(pCharLine[1]) {
+ case 'H':
+ case 'h':
+ if(pCharLine[2]==':') {
+ if((pCharLine[3]== 'a') || (pCharLine[3]== 'A')) {
+ if(pCharLine[4] == ']') {
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 5;
+ *str += 5;
+ return TRUE;
+ }
+ else {
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n"); //[H:A
+ return FALSE;
+ }
+ }
+ if((pCharLine[3]== 'S') || (pCharLine[3]== 's')) {
+ if(pCharLine[4] == ']') {
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = FALSE;
+ //pCharLine += 5;
+ *str += 5;
+ //printf("\nDEBUG H-1:%s\n",pCharLine);
+ return TRUE;
+ }
+ else {
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n"); //[H:A
+ return FALSE;
+ }
+ }
+ else if(pCharLine[3] == ']') { //[H:]
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 4;
+ *str += 4;
+ return TRUE;
+ }
+ else { //[H:
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");
+ return FALSE;
+ }
+ }
+ else if(pCharLine[2]==']') { //[H]
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 3;
+ *str += 5;
+ return TRUE;
+ }
+ else { //[H
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");
+ return FALSE;
+ }
+ break;
+
+ case 'A':
+ case 'a':
+ if(pCharLine[2]==':') {
+ if((pCharLine[3]== 'h') || (pCharLine[3]== 'H')) {
+ if(pCharLine[4] == ']') {
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 5;
+ *str += 5;
+ return TRUE;
+ }
+ else {
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n"); //[A:H
+ return FALSE;
+ }
+ }
+ else if(pCharLine[3]== ']') { //[A:]
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 4;
+ *str += 5;
+ return TRUE;
+ }
+ else { //[A:
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");
+ return FALSE;
+ }
+ }
+ else if(pCharLine[2]==']') { //[H]
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 3;
+ *str += 5;
+ return TRUE;
+ }
+ else { //[H
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");
+ return FALSE;
+ }
+ break;
+
+ case 'S':
+ case 's':
+ if(pCharLine[2]==':') {
+ if((pCharLine[3]== 'h') || (pCharLine[3]== 'H')) {
+ if(pCharLine[4] == ']') {
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 5;
+ *str += 5;
+ return TRUE;
+ }
+ else {
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");//[A:H
+ return FALSE;
+ }
+ }
+ else if(pCharLine[3]== ']') { //[A:]
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 4;
+ *str += 5;
+ return TRUE;
+ }
+ else { //[A:
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");
+ return FALSE;
+ }
+ }
+ else if(pCharLine[2]==']') { //[H]
+ pstFormat->eDataType = eHex;
+ pstFormat->bIsArray = TRUE;
+ //pCharLine += 3;
+ *str += 5;
+ return TRUE;
+ }
+ else { //[H
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");
+ return FALSE;
+ }
+ break;
+
+ default:
+ printf("\nuGetInputDataFormat - Invalid Data Format \r\n");
+ return FALSE;
+ }
+}
+
+unsigned int uReadDataInSection(char *pCharLine, struct ST_PS_DATA_FORMAT stPS_DataFormat)
+{
+ if(stPS_DataFormat.eDataType == eHex) {
+ if(stPS_DataFormat.bIsArray == TRUE) {
+ //Not implemented
+ printf("\nNO IMP\n");
+ return (0x0FFF);
+ }
+ else {
+ //printf("\nDEBUG H-2 %d\n",strtol(pCharLine, NULL, 16));
+ return (strtol(pCharLine, NULL, 16));
+ }
+ }
+ else {
+ //Not implemented
+ printf("\nNO IMP-1\n");
+ return (0x0FFF);
+ }
+}
+
+
+static int ParseFiles(FILE *fpt, int basetag, int format){
+ int i,j,k,linecnt,ByteCount=0,ByteCount_Org =0,data,Cnt;
+ char *str,line[LINE_SIZE_MAX],byte[3];
+ int ParseSelection=RAM_PS_SECTION;
+ struct ST_PS_DATA_FORMAT stPS_DataFormat;
+ struct ST_READ_STATUS stReadStatus = {0, 0, 0,0};
+ unsigned int uReadCount;
+
+ switch(format){
+ case MB_FILEFORMAT_PS:
+ linecnt = 0;
+ j=0;
+
+ while ((str = fgets(line, LINE_SIZE_MAX, fpt)) != NULL) {
+ SKIP_BLANKS(str);
+ //Comment line
+ if ((str[0]== '/') && (str[1]== '/'))
+ continue;
+
+ if (str[0]== '#'){
+ if (stReadStatus.uSection != 0){
+ printf("\nParseFiles - Invalid file format %d\r\n",ParseSelection);
+ return FALSE;
+ }
+ else {
+ stReadStatus.uSection = 1;
+ continue;
+ }
+
+ }
+ if ((str[0]== '/') && (str[1]== '*'))
+ {
+ str+=2;
+ SKIP_BLANKS(str);
+ if(!strncmp(str,"PA",2)||!strncmp(str,"Pa",2)||!strncmp(str,"pa",2)){
+
+ ParseSelection=RAM_PATCH_SECTION;
+ }
+ if(!strncmp(str,"DY",2)||!strncmp(str,"Dy",2)||!strncmp(str,"dy",2)){
+
+ ParseSelection=RAM_DYN_MEM_SECTION;
+ }
+ if(!strncmp(str,"PS",2)||!strncmp(str,"Ps",2)||!strncmp(str,"ps",2)){
+
+ ParseSelection=RAM_PS_SECTION;
+ }
+ linecnt = 0;
+ stReadStatus.uSection = 0;
+ continue;
+ }
+
+ switch(ParseSelection){
+
+ case RAM_PS_SECTION:
+ if (stReadStatus.uSection == 1){ //TagID
+ SKIP_BLANKS(str);
+ if(!uGetInputDataFormat(&str, &stPS_DataFormat)) {
+ return FALSE;
+ }
+ PsTagEntry[Tag_Count].TagId = uReadDataInSection(str, stPS_DataFormat);
+ stReadStatus.uSection = 2;
+ }
+ else if (stReadStatus.uSection == 2){ //TagLength
+ if(!uGetInputDataFormat(&str, &stPS_DataFormat)) {
+ return FALSE;
+ }
+ ByteCount = uReadDataInSection(str, stPS_DataFormat);
+
+ if (ByteCount > RAMPS_MAX_PS_DATA_PER_TAG){
+ printf("\nParseFiles - INVALID %d: One of the table exceeds maximum table size of %d\r\n",ParseSelection, MAX_RADIO_CFG_TABLE_SIZE);
+ return FALSE;
+ }
+ PsTagEntry[Tag_Count].TagLen = (ByteCount & 0xFF);
+ stReadStatus.uSection = 3;
+ stReadStatus.uLineCount = 0;
+ }
+ else if( stReadStatus.uSection == 3) { //Data
+ if(stReadStatus.uLineCount == 0) {
+ if(!uGetInputDataFormat(&str,&stPS_DataFormat)) {
+ return FALSE;
+ }
+ }
+ SKIP_BLANKS(str);
+ stReadStatus.uCharCount = 0;
+ uReadCount = (ByteCount > BYTES_OF_PS_DATA_PER_LINE)? BYTES_OF_PS_DATA_PER_LINE: ByteCount;
+ if((stPS_DataFormat.eDataType == eHex) && stPS_DataFormat.bIsArray == TRUE) {
+ while(uReadCount > 0) {
+ PsTagEntry[Tag_Count].TagData[stReadStatus.uByteCount] = (UCHAR)(CONV_HEX_DIGIT_TO_VALUE(str[stReadStatus.uCharCount]) << 4) | (UCHAR)(CONV_HEX_DIGIT_TO_VALUE(str[stReadStatus.uCharCount + 1]));
+ PsTagEntry[Tag_Count].TagData[stReadStatus.uByteCount+1] = (UCHAR)(CONV_HEX_DIGIT_TO_VALUE(str[stReadStatus.uCharCount + 3]) << 4) | (UCHAR)(CONV_HEX_DIGIT_TO_VALUE(str[stReadStatus.uCharCount + 4]));
+ stReadStatus.uCharCount += 6; // read two bytes, plus a space;
+ stReadStatus.uByteCount += 2;
+ uReadCount -= 2;
+ }
+
+ if(ByteCount > BYTES_OF_PS_DATA_PER_LINE) {
+ ByteCount -= BYTES_OF_PS_DATA_PER_LINE;
+ }
+ else {
+ ByteCount = 0;
+ }
+ }
+ else {
+ //to be implemented
+ printf("\nParseFiles - To be implemented");
+ }
+
+ stReadStatus.uLineCount++;
+
+ if(ByteCount == 0) {
+ stReadStatus.uSection = 0;
+ stReadStatus.uCharCount = 0;
+ stReadStatus.uLineCount = 0;
+ stReadStatus.uByteCount = 0;
+ }
+ else {
+ stReadStatus.uCharCount = 0;
+ }
+
+ if((stReadStatus.uSection == 0)&&(++Tag_Count == RAMPS_MAX_PS_TAGS_PER_FILE))
+ {
+ printf("\n ParseFiles - INVALID %d: Number of tables exceeds %d\r\n",ParseSelection, RAMPS_MAX_PS_TAGS_PER_FILE);
+ return FALSE;
+ }
+
+
+ }
+ break;
+ default:
+ {
+ printf("\nParseFiles - Invalid file format %d\r\n",ParseSelection);
+ return FALSE;
+ }
+ break;
+
+
+ }
+ linecnt++;
+ }
+ break;
+ case MB_FILEFORMAT_DY:
+ {
+ linecnt = 0;
+ while ((str = fgets(line, LINE_SIZE_MAX, fpt)) != NULL) {
+ SKIP_BLANKS(str);
+ //Comment line
+ if ((str[0]== '/') && (str[1]== '/'))
+ continue;
+
+ if ((str[0]== '/') && (str[1]== '*'))
+ {
+ continue;
+ }
+
+
+ if((linecnt % 2) == 0)
+ {
+ ByteCount = (UINT16)strtol(str, NULL, 16);
+ RamDynMemOverride.Len= (ByteCount & 0xFF);
+ }
+ else
+ {
+ for (i=0,k=0; k < ByteCount; i += 2,k++) {
+ memcpy(byte, &str[i], 2);
+ byte[2] = '\0';
+ data = strtoul(byte, NULL, 16);
+ RamDynMemOverride.Data[k] = (data & 0xFF);
+ }
+ DynMem_Count = TRUE;
+ }
+ linecnt++;
+ }
+ }
+ break;
+ case MB_FILEFORMAT_PATCH:
+ {
+ j=0;
+ Cnt=0;
+ linecnt = 0;
+ while ((str = fgets(line, LINE_SIZE_MAX, fpt)) != NULL) {
+ SKIP_BLANKS(str);
+ //Comment line
+ if ((str[0]== '/') && (str[1]== '/'))
+ continue;
+
+ if ((str[0]== '/') && (str[1]== '*'))
+ {
+ continue;
+ }
+
+ if(linecnt==0)
+ {
+ ByteCount = (UINT16)strtol(str, NULL, 16);
+ ByteCount_Org = ByteCount;
+ while(ByteCount > MAX_BYTE_LENGTH){
+ RamPatch[Patch_Count].Len= MAX_BYTE_LENGTH;
+ Patch_Count ++;
+ ByteCount= ByteCount - MAX_BYTE_LENGTH;
+ }
+ RamPatch[Patch_Count].Len= (ByteCount & 0xFF);
+ Patch_Count ++;
+
+ }
+ else
+ {
+ while(ByteCount_Org > MAX_BYTE_LENGTH){
+ for (i = 0, k=0; i < MAX_BYTE_LENGTH*2; i += 2,k++) {
+ memcpy(byte, &str[Cnt], 2);
+ byte[2] = '\0';
+ data = strtoul(byte, NULL, 16);
+ RamPatch[j].Data[k] = (data & 0xFF);
+ Cnt += 2;
+ }
+ j++;
+ ByteCount_Org = ByteCount_Org - MAX_BYTE_LENGTH;
+ }
+ if(j == 0){
+ j++;
+ }
+ for (k=0; k < ByteCount_Org;k++) {
+ memcpy(byte, &str[Cnt], 2);
+ byte[2] = '\0';
+ data = strtoul(byte, NULL, 16);
+ RamPatch[j].Data[k] = (data & 0xFF);
+ Cnt += 2;
+ }
+ }
+
+ linecnt++;
+ }
+
+ }
+ break;
+
+
+
+ }
+ return TRUE;
+}
+
+static void LoadPSHeader(UCHAR *HCI_PS_Command,UCHAR opcode,int length,int index) {
+
+ HCI_PS_Command[0]= opcode;
+ HCI_PS_Command[1]= (index & 0xFF);
+ HCI_PS_Command[2]= ((index>>8) & 0xFF);
+ HCI_PS_Command[3]= length;
+
+}
+
+
+static BOOL PSOperations(int dd, UCHAR Opcode, int Param1, UINT32 *out) {
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int Length,i,j,iRet;
+ memset(&buf,0,sizeof(buf));
+ switch(Opcode){
+ case WRITE_PATCH:
+ for(i=0;i< Param1;i++){
+ LoadPSHeader(buf,Opcode,RamPatch[i].Len,i);
+ for(j=0;j<RamPatch[i].Len;j++){
+ buf[4+j]=RamPatch[i].Data[j];
+ }
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_PS,RamPatch[i].Len + PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0){
+ return FALSE;
+ }
+ }
+ break;
+
+ case ENABLE_PATCH:
+ Length =0;
+ i=0;
+ LoadPSHeader(buf,Opcode,Length,i);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0){
+ return FALSE;
+ }
+ break;
+
+ case PS_RESET:
+ Length =0;
+ i=0;
+ LoadPSHeader(buf,Opcode,Length,i);
+ buf[8] = (Param1 & 0xFF);
+ buf[9] = ((Param1 >> 8) & 0xFF);
+ Length = 6;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,Length + PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0){
+ return FALSE;
+ }
+ break;
+
+ case PS_READ: {
+ UCHAR *len = (UCHAR *)out;
+ ssize_t plen = 0;
+ Length = len[0] | ( len[1] << 8);
+ LoadPSHeader(buf,Opcode,Length,Param1);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS, Length + PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0) {
+ return FALSE;
+ }
+ do {
+ plen = read(dd, buf, HCI_MAX_EVENT_SIZE);
+ if (plen < 0)
+ return FALSE;
+ } while (buf[HCI_EVENT_HEADER_SIZE] != DEBUG_EVENT_TYPE_PS);
+ memcpy((UCHAR *)out, buf + HCI_EVENT_HEADER_SIZE + 1, plen - HCI_EVENT_HEADER_SIZE - 1);
+ break;
+ }
+
+ case PS_WRITE:
+ for(i=0;i< Param1;i++){
+ LoadPSHeader(buf,Opcode,PsTagEntry[i].TagLen,PsTagEntry[i].TagId);
+ for(j=0;j<PsTagEntry[i].TagLen;j++){
+ buf[4+j]=PsTagEntry[i].TagData[j];
+ }
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PsTagEntry[i].TagLen + PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0){
+ return FALSE;
+ }
+ }
+ break;
+
+ case PS_DYNMEM_OVERRIDE:
+ LoadPSHeader(buf,Opcode,RamDynMemOverride.Len,RamDynMemOverride.Len);
+ for(j=0;j<RamDynMemOverride.Len;j++){
+ buf[4+j]=RamDynMemOverride.Data[j];
+ }
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_PS,RamDynMemOverride.Len + PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0){
+ return FALSE;
+ }
+ break;
+
+ case PS_VERIFY_CRC:
+ //printf("PSOperations - PS_VERIFY_CRC:VALUE of CRC:%d\r\n",Param1);
+ Length =0;
+ LoadPSHeader(buf,Opcode,Length,Param1);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS, PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0){
+ return FALSE;
+ }
+ break;
+
+ case PS_GET_LENGTH: {
+ ssize_t plen = 0;
+ LoadPSHeader(buf,Opcode,0,Param1);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS, PS_COMMAND_HEADER, buf);
+ if(buf[iRet-1] != 0){
+ return FALSE;
+ }
+ do {
+ plen = read(dd, buf, HCI_MAX_EVENT_SIZE);
+ if (plen < 0)
+ return FALSE;
+ } while (buf[HCI_EVENT_HEADER_SIZE] != DEBUG_EVENT_TYPE_PS);
+ *((UINT16 *)out) = (buf[HCI_EVENT_HEADER_SIZE + 2] << 8) | buf[HCI_EVENT_HEADER_SIZE + 1];
+ break;
+ }
+ }
+ return TRUE;
+}
+
+
+static int GetDeviceType(int dd){
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int iRet;
+ unsigned int Reg = 0;
+
+ memset(&buf,0,sizeof(buf));
+ buf[0] = (FPGA_REGISTER & 0xFF);
+ buf[1] = ((FPGA_REGISTER >> 8) & 0xFF);
+ buf[2] = ((FPGA_REGISTER >> 16) & 0xFF);
+ buf[3] = ((FPGA_REGISTER >> 24) & 0xFF);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_READ_MEMORY,4, buf);
+ if(buf[6] != 0){
+ return FALSE;
+ }
+
+ Reg = buf[10];
+ Reg = ((Reg << 8) | buf[9]);
+ Reg = ((Reg << 8) | buf[8]);
+ Reg = ((Reg << 8) | buf[7]);
+ return Reg;
+}
+/* PS Operations */
+static int PSInit(int dd){
+ int i,Crc=0,DevType =0;
+ BOOL BDADDR_Present = 0;
+ BOOL File_Present = 0;
+
+ //DevType = GetDeviceType(dd);
+ //printf("\nDevice Type:%x\n",DevType);
+ if(DevType){
+ if(DevType == 0xdeadc0de){
+
+ if(!LoadConfFile(PS_ASIC_FILENAME,0xFFFFFFFF,MB_FILEFORMAT_PS)){
+ printf("\nPlease copy PS file to :%s\n",PS_ASIC_FILENAME);
+ //return FALSE;
+ }
+ else
+ File_Present = 1;
+ }
+ else{
+ if(!LoadConfFile(PS_FPGA_FILENAME,0xFFFFFFFF,MB_FILEFORMAT_PS)){
+ printf("\nPlease copy PS file to :%s\n",PS_FPGA_FILENAME);
+ File_Present = 1;
+ //return FALSE;
+ }
+ else
+ File_Present = 1;
+ }
+ }
+ else{
+ if(!LoadConfFile(PS_ASIC_FILENAME,0xFFFFFFFF,MB_FILEFORMAT_PS)){
+ printf("\nPlease copy PS file to :%s\n",PS_ASIC_FILENAME);
+ File_Present = 1;
+ //return FALSE;
+ }
+ else
+ File_Present = 1;
+ }
+
+ if(!LoadConfFile(PATCH_FILENAME,0xFFFFFFFF,MB_FILEFORMAT_PATCH)){
+ printf("\nPlease copy Patch file to :%s\n",PATCH_FILENAME);
+ File_Present = 1;
+ }
+ else
+ File_Present = 1;
+
+ if(!File_Present){
+ printf("\nPS and Patch files are not present\n");
+ return FALSE;
+ }
+ if(Tag_Count == 0){
+ Total_tag_lenght = 10;
+
+ }
+ else{
+ for(i=0; i<Tag_Count; i++){
+ if(PsTagEntry[i].TagId == 1){
+ BDADDR_Present = TRUE;
+ //printf("ReadPSFiles - BD ADDR is present in Patch File \r\n");
+ }
+
+ if(PsTagEntry[i].TagLen % 2 == 1){
+ Total_tag_lenght = Total_tag_lenght + PsTagEntry[i].TagLen + 1;
+ }
+ else{
+ Total_tag_lenght = Total_tag_lenght + PsTagEntry[i].TagLen;
+ }
+
+ }
+ }
+
+ if(Tag_Count > 0 && !BDADDR_Present){
+ //printf("\nReadPSFiles - BD ADDR is not present adding 10 extra bytes \r\n");
+ Total_tag_lenght=Total_tag_lenght + 10;
+ }
+ Total_tag_lenght = Total_tag_lenght+ 10 + (Tag_Count*4);
+
+// printf("\nPSInitialize - PATCH:%d, DYN:%d, TAG:%d Total_tag_lenght:%d\n",Patch_Count,DynMem_Count,Tag_Count,Total_tag_lenght);
+
+ if(Patch_Count > 0)
+ Crc |= RAM_PATCH_REGION;
+ if(DynMem_Count)
+ Crc |= RAM_DYN_MEM_REGION;
+ if(Tag_Count > 0)
+ Crc |= RAM_PS_REGION;
+
+ if(Patch_Count || DynMem_Count || Tag_Count ){
+ if(Patch_Count > 0){
+ if(!PSOperations(dd,WRITE_PATCH,Patch_Count, NULL)){
+ printf("\nPSInitialize - *** WRITE_PATCH FAILED**** \r\n");
+ return FALSE;
+ }
+ if(!PSOperations(dd,ENABLE_PATCH,0, NULL)){
+ printf("\nPSInitialize - *** ENABLE_PATCH FAILED**** \r\n");
+ return FALSE;
+ }
+ }
+ if(DynMem_Count){
+ if(!PSOperations(dd,PS_DYNMEM_OVERRIDE,DynMem_Count, NULL)){
+ printf("\nPSInitialize - *** PS_DYNMEM_OVERRIDE FAILED**** \r\n");
+ return FALSE;
+ }
+ }
+ if(!PSOperations(dd,PS_RESET,Total_tag_lenght, NULL)){
+ printf("\nPSInitialize - *** PS RESET FAILED**** \r\n");
+ return FALSE;
+ }
+ if(Tag_Count > 0){
+ if(!PSOperations(dd,PS_WRITE,Tag_Count, NULL)){
+ printf("\nPSInitialize - *** PS_WRITE FAILED**** \r\n");
+ return FALSE;
+ }
+ }
+
+ }
+
+ if(!PSOperations(dd,PS_VERIFY_CRC,Crc, NULL)){
+ printf("\nVerify CRC failed\n");
+ return FALSE;
+ }
+ return TRUE;
+
+}
+
+static int writeHciCommand(int dd, uint16_t ogf, uint16_t ocf, uint8_t plen, UCHAR *buf){
+#ifdef DUMP_DEBUG
+#define cmd_opcode_pack(ogf, ocf) (uint16_t)((ocf & 0x03ff)|(ogf << 10))
+#if __BYTE_ORDER == __LITTLE_ENDIAN
+#define htobs(d) (d)
+#elif __BYTE_ORDER == __BIG_ENDIAN
+#define htobs(d) bswap_16(d);
+#else
+#error "Unknown byte order"
+#endif
+ int i = 0, j = 0;
+ uint16_t opcode = htobs(cmd_opcode_pack(ogf, ocf));
+
+ printf("\nDump:\n");
+ printf("0x%02X ", opcode & 0xff);
+ i++;
+ printf("0x%02X ", (opcode & 0xff00) >> 8);
+ i++;
+ printf("0x%02X ", plen);
+ i++;
+ for (j = 0; j < plen; i++, j++) {
+ printf("0x%02X ", buf[j]);
+ if (((i+1) % 8) == 0 && i != 0)
+ printf("\n");
+ }
+ if (((i+1) % 8) != 0) printf("\n");
+ buf[6] = 0;
+ return plen;
+#else
+ struct hci_filter flt;
+ uint16_t opcode, topcode;
+
+ /* Setup filter */
+ hci_filter_clear(&flt);
+ hci_filter_set_ptype(HCI_EVENT_PKT, &flt);
+ hci_filter_all_events(&flt);
+ if (setsockopt(dd, SOL_HCI, HCI_FILTER, &flt, sizeof(flt)) < 0) {
+ perror("HCI filter setup failed");
+ exit(EXIT_FAILURE);
+ }
+
+ //printf("< HCI Command: ogf 0x%02x, ocf 0x%04x, plen %d\n", ogf, ocf, plen);
+ if (hci_send_cmd(dd, ogf, ocf, plen, buf) < 0) {
+ perror("Send failed");
+ hci_close_dev(dd);
+ exit(EXIT_FAILURE);
+ }
+ sleep(0.4);
+ opcode = (ogf << 10 | ocf);
+ do {
+ plen = read(dd, buf,HCI_MAX_EVENT_SIZE);
+ if (plen < 0) {
+ perror("Read failed");
+ hci_close_dev(dd);
+ exit(EXIT_FAILURE);
+ }
+ topcode=(uint16_t)(buf[4] | (buf[5] << 8));
+ }while(topcode != opcode);
+ return plen;
+#endif
+}
+static int MemBlkRead(int dd,UINT32 Address,UCHAR *pBuffer, UINT32 Length){
+ UINT32 Size, ByteLeft,IntCnt;
+ UCHAR *pData,*pTemp=pBuffer;
+ int iRet;
+ int TempVal;
+
+ IntCnt =0;
+ TempVal = (Length % 4);
+ if (TempVal !=0)
+ {
+ Length = Length + (4- (Length%4));
+ }
+ ByteLeft = Length;
+ while (ByteLeft > 0)
+ {
+ Size = (ByteLeft > MEM_BLK_DATA_MAX) ? MEM_BLK_DATA_MAX : ByteLeft;
+ // printf("\nMemBlkwrite : Size :%x Address :%x\n",Size, Address);
+ pData = (UCHAR *) malloc(Size + 6);
+ pData[0]= 0x00;//depot/esw/projects/azure/AR3001_3_0/src/hci/Hci_Vsc_Proc.c
+ pData[1]= (Address & 0xFF);
+ pData[2]= ((Address >> 8) & 0xFF);
+ pData[3]= ((Address >> 16) & 0xFF);
+ pData[4]= ((Address >> 24) & 0xFF);
+ pData[5]= Size;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_MEMOP,6,pData);
+ if(pData[6]!= 0){
+ printf("\nwrite memory command failed due to reason 0x%X\n",pData[6]);
+ free(pData);
+ return FALSE;
+ }
+ if ((read(dd, pData,HCI_MAX_EVENT_SIZE)) < 0) {
+ perror("Read failed");
+ exit(EXIT_FAILURE);
+ }
+
+ if(pData[3]!=3) {
+ perror("Read failed");
+ exit(EXIT_FAILURE);
+ }
+ memcpy(pTemp,(pData+4),Size);
+ pTemp+=Size;
+ IntCnt = Size;
+ ByteLeft -= Size;
+ Address += Size;
+ free(pData);
+ }
+ return TRUE;
+}
+
+
+static int MemBlkwrite(int dd,UINT32 Address,UCHAR *pBuffer, UINT32 Length){
+ UINT32 Size, ByteLeft,IntCnt;
+ UCHAR *pData;
+ int iRet;
+ ByteLeft = Length;
+ IntCnt =0;
+ while (ByteLeft > 0)
+ {
+
+ Size = (ByteLeft > MEM_BLK_DATA_MAX) ? MEM_BLK_DATA_MAX : ByteLeft;
+ // printf("\nMemBlkwrite : Size :%x Address :%x\n",Size, Address);
+ pData = (UCHAR *) malloc(Size + 6);
+ pData[0]= 0x01;
+ pData[1]= (Address & 0xFF);
+ pData[2]= ((Address >> 8) & 0xFF);
+ pData[3]= ((Address >> 16) & 0xFF);
+ pData[4]= ((Address >> 24) & 0xFF);
+ pData[5]= Size;
+ memcpy(&pData[6],&pBuffer[IntCnt],Size);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_MEMOP,Size+6,pData);
+ if(pData[6]!= 0){
+ printf("\nwrite memory command faileddue to reason 0x%X\n",pData[6]);
+ free(pData);
+ return FALSE;
+ }
+ IntCnt = Size;
+ ByteLeft -= Size;
+ Address += Size;
+ free(pData);
+ }
+ return TRUE;
+}
+
+static int Dut(int dd){
+ int iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 3; //All scan enabled
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_WRITE_SCAN_ENABLE, 1, buf);
+ if(buf[6] != 0){
+ printf("\nWrite scan mode command failed due to reason 0x%X\n",buf[6]);
+ return FALSE;
+ }
+ sleep(1);
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = writeHciCommand(dd, OGF_TEST_CMD, OCF_ENABLE_DEVICE_UNDER_TEST_MODE, 0, buf);
+ if(buf[6] != 0){
+ printf("\nDUT mode command failed due to reason 0x%X\n",buf[6]);
+ return FALSE;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 0; //SEQN Track enable =0
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_TEST_MODE_SEQN_TRACKING , 1, buf);
+ if(buf[6] != 0){
+ printf("\nTest Mode seqn Tracking failed due to reason 0x%X\n",buf[6]);
+ return FALSE;
+ }
+ return TRUE;
+}
+
+
+void Audio_DumpStats(tAudioStat *AudioStats)
+{
+ printf("\n\n");
+ printf(" Audio Statistics\n");
+ printf(">RxCmplt: %d\n",AudioStats->RxCmplt);
+ printf(">TxCmplt: %d\n",AudioStats->TxCmplt);
+ printf(">RxSilenceInsert: %d\n",AudioStats->RxSilenceInsert);
+ printf(">RxAirPktDump: %d\n",AudioStats->RxAirPktDump);
+ printf(">MaxPLCGenInterval: %d\n",AudioStats->MaxPLCGenInterval);
+ printf(">RxAirPktStatusGood: %d\n",AudioStats->RxAirPktStatusGood);
+ printf(">RxAirPktStatusError: %d\n",AudioStats->RxAirPktStatusError);
+ printf(">RxAirPktStatusLost: %d\n",AudioStats->RxAirPktStatusLost);
+ printf(">RxAirPktStatusPartial: %d\n",AudioStats->RxAirPktStatusPartial);
+ printf(">SampleMin: %d\n",AudioStats->SampleMin);
+ printf(">SampleMax: %d\n",AudioStats->SampleMax);
+ printf(">SampleCounter: %d\n",AudioStats->SampleCounter);
+ printf("\n\n");
+
+ memset((UCHAR *)AudioStats, 0, sizeof(tAudioStat));
+ AudioStats->SampleMax =SHRT_MIN;
+ AudioStats->SampleMin =SHRT_MAX;
+}
+
+static int ReadAudioStats(int dd){
+
+ tBtHostInterest HostInt;
+ tAudioStat Stats;
+
+ ReadHostInterest(dd, &HostInt);
+ if(!HostInt.AudioStatAddr || (HostInt.Version < 0x0300)){
+ printf("\nAudio Stat not present\n");
+ return FALSE;
+ }
+ ReadMemoryBlock(dd,HostInt.AudioStatAddr,(UCHAR *)&Stats,sizeof(tAudioStat));
+ Audio_DumpStats(&Stats);
+ return TRUE;
+}
+
+void BRM_DumpStats(tBRM_Stats *Stats)
+{
+ printf("\n Link Controller Voice DMA Statistics\n");
+ printf(" %22s: %u\n", "VoiceTxDmaIntrs", Stats->VoiceTxDmaIntrs);
+ printf(" %22s: %u\n", "VoiceTxPktAvail", Stats->VoiceTxPktAvail);
+ printf(" %22s: %u\n", "VoiceTxPktDumped", Stats->VoiceTxPktDumped);
+ printf(" %22s: %u\n", "VoiceTxErrors", Stats->VoiceTxErrorIntrs);
+ printf(" %22s: %u\n", "VoiceTxDmaErrors", Stats->VoiceTxDmaErrorIntrs);
+ printf(" %22s: %u\n", "VoiceTxSilenceInserts", Stats->VoiceTxDmaSilenceInserts);
+ printf("\n");
+ printf(" %22s: %u\n", "VoiceRxDmaIntrs", Stats->VoiceRxDmaIntrs);
+ printf(" %22s: %u\n", "VoiceRxGoodPkts", Stats->VoiceRxGoodPkts);
+ printf(" %22s: %u\n", "VoiceRxPktDumped", Stats->VoiceRxPktDumped);
+ printf(" %22s: %u\n", "VoiceRxErrors", Stats->VoiceRxErrorIntrs);
+ printf(" %22s: %u\n", "VoiceRxCRC", Stats->VoiceRxErrCrc);
+ printf(" %22s: %u\n", "VoiceRxUnderOverFlow", Stats->VoiceRxErrUnderOverFlow);
+ printf("\n");
+ printf(" %22s: %u\n", "SchedOnVoiceError", Stats->SchedOnVoiceError);
+ printf(" %22s: %u\n", "VoiceTxReapOnError", Stats->VoiceTxReapOnError);
+ printf(" %22s: %u\n", "VoiceRxReapOnError", Stats->VoiceRxReapOnError);
+ printf(" %22s: %u\n", "VoiceSchedulingError", Stats->VoiceSchedulingError);
+
+ printf("\n Link Controller ACL DMA Statistics\n");
+ printf(" %22s: %u\n", "DmaIntrs", Stats->DmaIntrs);
+ printf(" %22s: %u\n", "ErrWrongLlid", Stats->ErrWrongLlid);
+ printf(" %22s: %u\n", "ErrL2CapLen", Stats->ErrL2CapLen);
+ printf(" %22s: %u\n", "ErrUnderOverFlow", Stats->ErrUnderOverFlow);
+ printf(" %22s: %u\n", "RxBufferDumped", Stats->RxBufferDumped);
+ printf(" %22s: %u\n", "ErrWrongLmpPktType", Stats->ErrWrongLmpPktType);
+ printf(" %22s: %u\n", "ErrWrongL2CapPktType", Stats->ErrWrongL2CapPktType);
+ printf(" %22s: %u\n", "IgnoredPkts", Stats->IgnoredPkts);
+ printf("\n");
+ printf(" %22s: %u\n", "Data TxBuffers", Stats->DataTxBuffers);
+ printf(" %22s: %u\n", "Data RxBuffers", Stats->DataRxBuffers);
+ printf(" %22s: %u\n", "LMP TxBuffers", Stats->LmpTxBuffers);
+ printf(" %22s: %u\n", "LMP RxBuffers", Stats->LmpRxBuffers);
+ printf(" %22s: %u\n", "HEC Errors", Stats->HecFailPkts);
+ printf(" %22s: %u\n", "CRC Errors", Stats->CrcFailPkts);
+
+ // Buffer Management
+ printf("\n Buffer Management Statistics\n");
+ printf(" %22s: %u\n", "CtrlErrNoLmpBufs", Stats->CtrlErrNoLmpBufs);
+
+ printf("\n Sniff Statistics\n");
+ printf(" %22s: %u\n", "SniffSchedulingError", Stats->SniffSchedulingError);
+ printf(" %22s: %u\n", "SniffIntervalNoCorr", Stats->SniffIntervalNoCorr);
+
+ // Other stats
+ printf("\n Other Statistics\n");
+ printf(" %22s: %u\n", "ForceOverQosJob", Stats->ForceOverQosJob);
+ //printf(" %22s: %u\n", "Temp 1", Stats->Temp1);
+ //printf(" %22s: %u\n", "Temp 2", Stats->Temp2);
+
+ // Test Mode Stats
+ printf("\n Test Mode Statistics\n");
+ printf(" %22s: %u\n", "TestModeDroppedTxPkts", Stats->TestModeDroppedTxPkts);
+ printf(" %22s: %u\n", "TestModeDroppedLmps", Stats->TestModeDroppedLmps);
+
+ // Error Stats
+ printf("\n General Error Statistics\n");
+ printf(" %22s: %u\n", "TimePassedIntrs", Stats->TimePassedIntrs);
+ printf(" %22s: %u\n", "NoCommandIntrs", Stats->NoCommandIntrs);
+}
+
+static int ReadGlobalDMAStats(int dd){
+ tBtHostInterest HostInt;
+ tBRM_Stats Stats;
+
+ ReadHostInterest(dd, &HostInt);
+ if(!HostInt.GlobalDmaStats || (HostInt.Version < 0x0100)){
+ printf("\nGlobal DMA stats not present\n");
+ return FALSE;
+ }
+ ReadMemoryBlock(dd,HostInt.GlobalDmaStats,(UCHAR *)&Stats,sizeof(tBRM_Stats));
+ BRM_DumpStats(&Stats);
+ return TRUE;
+}
+
+static int ResetGlobalDMAStats(int dd){
+ tBtHostInterest HostInt;
+ tBRM_Stats Stats;
+
+ ReadHostInterest(dd, &HostInt);
+ if(!HostInt.GlobalDmaStats || (HostInt.Version < 0x0100)){
+ printf("\nGlobal DMA stats not present\n");
+ return FALSE;
+ }
+ memset(&Stats,0,sizeof(Stats));
+ printf("\nHarry\n");
+ WriteMemoryBlock(dd,HostInt.GlobalDmaStats,(UCHAR *)&Stats,sizeof(tBRM_Stats));
+ printf("\nDMA stattestics has been reset\n");
+ return TRUE;
+}
+
+static int ReadTpcTable(int dd){
+ tBtHostInterest HostInt;
+ tPsSysCfgTransmitPowerControlTable TpcTable;
+ int i;
+
+ ReadHostInterest(dd, &HostInt);
+ if(!HostInt.TpcTableAddr || (HostInt.Version < 0x0100)){
+ printf("\nTPC table not present\n");
+ return FALSE;
+ }
+ ReadMemoryBlock(dd,HostInt.TpcTableAddr,(UCHAR *)&TpcTable,sizeof(TpcTable));
+ for(i=0;i< TpcTable.NumOfEntries; i++){
+ printf("Level [%d] represents %3d dBm\n",i,TpcTable.t[i].TxPowerLevel);
+ }
+ return TRUE;
+}
+
+/*
+static void dump_conf_data(){
+ printf("\nTAG_COUNT %d\n",Tag_Count);
+ int i=0,j=0;
+ for(i=0;i<Tag_Count;i++){
+ printf("\nTAG ID :%X LEN:%X\n",PsTagEntry[i].TagId,PsTagEntry[i].TagLen);
+ for(j=0;j<PsTagEntry[i].TagLen;j++)
+ printf("\t %x",PsTagEntry[i].TagData[j]);
+ }
+ printf("\n");
+ printf("\nPATCH_COUNT %d\n",Patch_Count);
+ for(i=0;i<Patch_Count;i++){
+ printf("\tPATCH LEN:%X\t",RamPatch[i].Len);
+ for(j=0;j<RamPatch[i].Len;j++)
+ printf("\t %x",RamPatch[i].Data[j]);
+ }
+ printf("\n");
+
+ printf("\tDYMA LEN:%X\t",RamDynMemOverride.Len);
+ for(j=0;j<RamDynMemOverride.Len;j++)
+ printf("\t %x",RamDynMemOverride.Data[j]);
+ printf("\n");
+
+}
+*/
+static const char *psreset_help =
+ "Usage:\n"
+ "\n psreset\n";
+
+static void cmd_psreset(int dev_id, int argc, char **argv){
+ int dd,Length =0,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if(argc > 1){
+ printf("\n%s\n",psreset_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ PSInit(dd);
+ memset(&buf,0,sizeof(buf));
+ iRet = writeHciCommand(dd, OGF_HOST_CTL,OCF_RESET,Length,buf);
+ if(buf[6] != 0){
+ printf("\nError: HCI RESET failed due to reason 0x%X\n",buf[6]);
+ return;
+ }
+
+ // Bttest work around for external 32k
+
+
+ int IsForeverRepeat=0;
+ int IsCmdIdle=0;
+ int address=0, width = 0, value=0;
+ int loop=0,Reg=0;
+ do
+ {
+
+ address = 0x00020024;
+ width = 4;
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = (UCHAR)width; //Memory width
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_READ_MEMORY, 5, buf);
+ if(buf[6] != 0){
+ printf("\nRead Memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ value = buf[10];
+ value = ((value << 8) | buf[9]);
+ value = ((value << 8) | buf[8]);
+ value = ((value << 8) | buf[7]);
+
+
+ if(value&0x40000000)
+ IsForeverRepeat=1;
+ else
+ IsForeverRepeat=0;
+
+
+ address = 0x00020020;
+ width = 4;
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = (UCHAR)width; //Memory width
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_READ_MEMORY, 5, buf);
+ if(buf[6] != 0){
+ printf("\nRead Memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ value = buf[10];
+ value = ((value << 8) | buf[9]);
+ value = ((value << 8) | buf[8]);
+ value = ((value << 8) | buf[7]);
+
+ if((value&0x0000000f)==0x8)
+ IsCmdIdle=1;
+ else
+ IsCmdIdle=0;
+
+ }
+ while(!(IsForeverRepeat&IsCmdIdle));//Wait til brm issues forever idle
+
+
+ address = 0x000200a8;
+ width = 4;
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = (UCHAR)width; //Memory width
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_READ_MEMORY, 5, buf);
+ if(buf[6] != 0){
+ printf("\nRead Memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ value = buf[10];
+ value = ((value << 8) | buf[9]);
+ value = ((value << 8) | buf[8]);
+ value = ((value << 8) | buf[7]);
+
+
+ value |= 0x1;
+
+ loop = 0;
+ while ( loop < 10 ) {
+
+ loop++;
+
+ address = 0x000200a8;
+ width = 4;
+
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = width; //Memory width
+ buf[5] = (value & 0xFF);
+ buf[6] = ((value >> 8) & 0xFF);
+ buf[7] = ((value >> 16) & 0xFF);
+ buf[8] = ((value >> 24) & 0xFF);
+ buf[9] = 0xFF;
+ buf[10] = 0xFF;
+ buf[11] = 0xFF;
+ buf[12] = 0xFF;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed\n");
+ hci_close_dev(dd);
+ return;
+ }
+
+ address = 0x00004064;
+ width = 4;
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = (UCHAR)width; //Memory width
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_READ_MEMORY, 5, buf);
+ if(buf[6] != 0){
+ printf("\nRead Memory address failed\n");
+ hci_close_dev(dd);
+ return;
+ }
+ Reg = buf[10];
+ Reg = ((Reg << 8) | buf[9]);
+ Reg = ((Reg << 8) | buf[8]);
+ Reg = ((Reg << 8) | buf[7]);
+
+ if(Reg & 0x04) {
+ break;
+ }
+ }
+
+//--------------------------------------------------------------
+
+
+ hci_close_dev(dd);
+ printf("\nReset Done\n");
+}
+static const char *reset_help =
+ "Usage:\n"
+ "\n reset\n";
+
+static void cmd_reset(int dev_id, int argc, char **argv){
+ int dd,Length =0,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if(argc > 1) {
+ printf("\n%s\n",reset_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,sizeof(buf));
+ iRet = writeHciCommand(dd, OGF_HOST_CTL,OCF_RESET,Length,buf);
+ if(buf[6] != 0){
+ printf("\nError: HCI RESET failed due to reason 0x%X\n",buf[6]);
+ return;
+ }
+
+ hci_close_dev(dd);
+ printf("\nReset Done\n");
+}
+static const char *rba_help =
+ "Usage:\n"
+ "\n rba\n";
+
+static void cmd_rba(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if(argc > 1){
+ printf("\n%s\n",rba_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = writeHciCommand(dd, OGF_INFO_PARAM, OCF_READ_BD_ADDR, 0, buf);
+ if(buf[6] != 0){
+ printf("\nread bdaddr command failed due to reason 0x%X\n",buf[6] );
+ return;
+ }
+ printf("\nBD ADDRESS: \n");
+ int i;
+ for(i=iRet-1;i > 7;i--){
+ printf("%02X:",buf[i]);
+ }
+ printf("%X \n\n",buf[7]);
+ hci_close_dev(dd);
+
+}
+
+static const char *dtx_help =
+ "Usage:\n"
+ "\n dtx\n";
+
+static void cmd_dtx(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if(argc > 1){
+ printf("\n%s\n",dtx_help);
+ return;
+ }
+
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_DISABLE_TX, 0, buf);
+ if(buf[6] != 0){
+ printf("\nDisable TX command failed due to reason 0x%X\n",buf[6]);
+ return;
+ }
+ else {
+ printf("\nDisable TX command passed\n");
+ }
+ hci_close_dev(dd);
+
+}
+
+static const char *ssm_help =
+ "Usage:\n"
+ "\n ssm [0|1]\n"
+ "\nExample:\n"
+ "\tssm 0\t(Sleep disabled)\n"
+ "\tssm 1\t(Sleep enabled)\n";
+
+static void cmd_ssm(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if(argc != 2){
+ printf("\n%s\n",ssm_help);
+ return;
+ }
+
+ if(atoi(argv[1]) > 1){
+ printf("\nInvalid sleep mode :%d\n",atoi(argv[1]));
+ return;
+ }
+
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = atoi(argv[1]);;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_SLEEP_MODE, 1, buf);
+ if(buf[6] != 0){
+ printf("\nSet sleep mode command failed due to reason 0x%X\n",buf[6]);
+ return;
+ }
+ else {
+ printf("\nSet sleep mode command passed\n");
+ }
+ hci_close_dev(dd);
+
+}
+
+static const char *wba_help =
+ "Usage:\n"
+ "\n wba <bdaddr>\n"
+ "\nExample:\n"
+ "\n wba 00:03:ff:56:23:89\n";
+
+static void cmd_wba(int dev_id, int argc, char **argv){
+ //printf("\nFeature not implemented\n");
+ int dd,iRet;
+ bdaddr_t bdaddr;
+
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ if(argc < 2){
+ printf("\n%s\n",wba_help);
+ return;
+ }
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ str2ba(argv[1],&bdaddr);
+ if((strlen(argv[1]) < 17)||(strlen(argv[1]) > 17)){
+ printf("\nInvalid BD address : %s\n",argv[1]);
+ printf("\n%s\n",wba_help);
+ hci_close_dev(dd);
+ return;
+ }
+ LoadPSHeader(buf,PS_WRITE,BD_ADDR_SIZE,BD_ADDR_PSTAG);
+ int i,j=0;
+ for(i= 0,j=4;i< BD_ADDR_SIZE;i++,j++){
+ buf[j] = bdaddr.b[i];
+ }
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,BD_ADDR_SIZE + PS_COMMAND_HEADER, buf);
+ if(buf[6] != 0){
+ printf("\n Write BD address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ memset(&buf,0,sizeof(buf));
+ iRet = writeHciCommand(dd, OGF_HOST_CTL,OCF_RESET,0,buf);
+ if(buf[iRet-1] != 0){
+ printf("\nError: HCI RESET failed\n");
+ hci_close_dev(dd);
+ return;
+ }
+ memset(&buf,0,sizeof(buf));
+ iRet = writeHciCommand(dd, OGF_INFO_PARAM, OCF_READ_BD_ADDR, 0, buf);
+ if(buf[6] != 0){
+ printf("\nread bdaddr command failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nBD address changed successfully\n");
+ hci_close_dev(dd);
+}
+
+static const char *edutm_help =
+ "Usage:\n"
+ "\n edutm\n";
+
+static void cmd_edutm(int dev_id, int argc, char **argv){
+ int Crc = 0;
+ int dd;
+ //UCHAR buf[HCI_MAX_EVENT_SIZE];
+ UCHAR ZeroBuf[MEM_BLK_DATA_MAX*2] = {0};
+ if(argc > 1){
+ printf("\n%s\n",edutm_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+/*
+ Patch_Count = 20;
+ for(i=0; i < Patch_Count; i++){
+ RamPatch[i].Len = MAX_BYTE_LENGTH;
+ memset(&RamPatch[i].Data,0,MAX_BYTE_LENGTH);
+ }
+ printf("\nCMD DUT MODE\n");
+*/
+//When Patch file is present write the patch, if not present just enter DUT mode
+ if(!LoadConfFile(TESTPATCH_FILENAME,0xFFFFFFFF,MB_FILEFORMAT_PATCH)){
+ if(!Dut(dd)){
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nDevice is in test mode ...\n");
+ hci_close_dev(dd);
+ return;
+ }
+ //dump_conf_data();
+ Crc |= RAM_PATCH_REGION;
+ if(!MemBlkwrite(dd,(UINT32)MC_BCAM_COMPARE_ADDRESS, ZeroBuf, HCI_3_PATCH_SPACE_LENGTH_1)){
+ printf("\nError in clearing the patch space 1\n");
+ return;
+ }
+
+ if(!MemBlkwrite(dd,(UINT32)MC_BCAM_VALID_ADDRESS, ZeroBuf, HCI_3_PATCH_SPACE_LENGTH_1)){
+ printf("\nError in clearing the patch space 2\n");
+ return;
+ }
+ printf("\nLoading Patch from file :%s\n",TESTPATCH_FILENAME);
+ if(!PSOperations(dd,WRITE_PATCH,Patch_Count, NULL)){
+ printf("EnterDUT_HCI_3 : patch write failed \r\n");
+ return;
+ }
+ if(!PSOperations(dd,ENABLE_PATCH,0, NULL)){
+ printf("EnterDUT_HCI_3 : patch enable failed \r\n");
+ return;
+ }
+ if(!PSOperations(dd,PS_VERIFY_CRC,Crc, NULL)){
+ printf("EnterDUT_HCI_3 : verify crc failed \r\n");
+ return;
+ }
+ if(!Dut(dd)){
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nDevice is in test mode ...\n");
+ hci_close_dev(dd);
+}
+
+
+static int ReadMemorySmallBlock(int dd, int StartAddress,UCHAR *pBufToWrite, int Length ){
+ int iRet;
+ UCHAR *pData;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ pData = (UCHAR *) malloc(Length + 6);
+ memset(pData,0,Length+6);
+ pData[0]= 0x00; //Memory Read Opcode
+ pData[1]= (StartAddress & 0xFF);
+ pData[2]= ((StartAddress >> 8) & 0xFF);
+ pData[3]= ((StartAddress >> 16) & 0xFF);
+ pData[4]= ((StartAddress >> 24) & 0xFF);
+ pData[5]= Length;
+
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_MEMOP,Length+6,pData);
+ if(pData[6]!= 0){
+ printf("\nwrite memory command failed due to reason 0x%X\n",pData[6]);
+ free(pData);
+ return FALSE;
+ }
+ int plen =0;
+ do{
+ plen = read(dd, buf,HCI_MAX_EVENT_SIZE);
+ if (plen < 0) {
+ free(pData);
+ perror("Read failed");
+ exit(EXIT_FAILURE);
+ }
+ }while (buf[HCI_EVENT_HEADER_SIZE] != DEBUG_EVENT_TYPE_MEMBLK);
+ memcpy(pBufToWrite,(buf+HCI_EVENT_HEADER_SIZE+1),Length);
+ free(pData);
+ return TRUE;
+}
+
+static int ReadMemoryBlock(int dd, int StartAddress,UCHAR *pBufToWrite, int Length ){
+
+ int ModResult,i;
+
+ if(Length > MEM_BLK_DATA_MAX){
+ ModResult = Length % MEM_BLK_DATA_MAX;
+ for(i=0;i < (Length - ModResult);i += MEM_BLK_DATA_MAX) {
+ ReadMemorySmallBlock(dd, (StartAddress + i),(pBufToWrite + i), MEM_BLK_DATA_MAX);
+ }
+ if(ModResult){
+ ReadMemorySmallBlock(dd, (StartAddress + i),(pBufToWrite + i), ModResult);
+ }
+ }
+ else{
+
+ ReadMemorySmallBlock(dd, StartAddress, pBufToWrite, Length);
+ }
+ return TRUE;
+}
+
+static int WriteMemorySmallBlock(int dd, int StartAddress,UCHAR *pBufToWrite, int Length ){
+ int iRet;
+ UCHAR *pData;
+
+ printf("\nStart Address:%x Length:%x %x\n",StartAddress,Length,MEM_BLK_DATA_MAX);
+ /*if(Length <= MEM_BLK_DATA_MAX)
+ return FALSE; */
+ pData = (UCHAR *) malloc(Length + 6);
+ memset(pData,0,Length+6);
+ pData[0]= 0x01; //Write Read Opcode
+ pData[1]= (StartAddress & 0xFF);
+ pData[2]= ((StartAddress >> 8) & 0xFF);
+ pData[3]= ((StartAddress >> 16) & 0xFF);
+ pData[4]= ((StartAddress >> 24) & 0xFF);
+ pData[5]= Length;
+
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_MEMOP,Length+6,pData);
+ if(pData[6]!= 0){
+ printf("\nwrite memory command failed due to reason 0x%X\n",pData[6]);
+ free(pData);
+ return FALSE;
+ }
+ free(pData);
+ return TRUE;
+}
+
+
+static int WriteMemoryBlock(int dd, int StartAddress,UCHAR *pBufToWrite, int Length ){
+
+ int ModResult,i;
+
+ if(Length > MEM_BLK_DATA_MAX){
+ ModResult = Length % MEM_BLK_DATA_MAX;
+ for(i=0;i < (Length - ModResult);i += MEM_BLK_DATA_MAX) {
+ WriteMemorySmallBlock(dd, (StartAddress + i),(pBufToWrite + i), MEM_BLK_DATA_MAX);
+ }
+ if(ModResult){
+ WriteMemorySmallBlock(dd, (StartAddress + i),(pBufToWrite + i), ModResult);
+ }
+ }
+ else{
+
+ WriteMemorySmallBlock(dd, StartAddress, pBufToWrite, Length);
+ }
+ return TRUE;
+}
+
+
+static int ReadHostInterest(int dd,tBtHostInterest *pHostInt){
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int iRet;
+ int HostInterestAddress;
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_HOST_INTEREST, 0, buf);
+ if(buf[6] != 0){
+ printf("\nhost interest command failed due to reason 0x%X\n",buf[6]);
+ return FALSE;
+ }
+ HostInterestAddress = buf[iRet-1];
+ HostInterestAddress = ((HostInterestAddress << 8)|buf[iRet-2]);
+ HostInterestAddress = ((HostInterestAddress << 8)|buf[iRet-3]);
+ HostInterestAddress = ((HostInterestAddress << 8)|buf[iRet-4]);
+ ReadMemoryBlock(dd, HostInterestAddress,(UCHAR*)pHostInt, sizeof(tBtHostInterest));
+
+ if(pHostInt->MagicNumber != HI_MAGIC_NUMBER){
+ if((pHostInt->MagicNumber != 0xFBAD)|| (pHostInt->Version != 0xDECA))
+ return 0;
+ }
+ return TRUE;
+
+}
+
+static int contRxAtGivenChannel(int dd, UCHAR *pString){
+ int Address, Mask, Reg, RxFreq,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ //1. Disable all scans and set intervals and scan windows eually
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 0; //All scan disabled
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_WRITE_SCAN_ENABLE, 1, buf);
+ if(buf[6] != 0){
+ printf("\nWrite scan mode command failed due to reason 0x%X\n",buf[6]);
+ return 0;
+ }
+ short int inq_scan = 0x1000;
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = (inq_scan&0xFF);
+ buf[1] = ((inq_scan >> 8)& 0xFF);
+ buf[2] = (inq_scan&0xFF);
+ buf[3] = ((inq_scan >> 8)& 0xFF);
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_WRITE_INQ_ACTIVITY, 4, buf);
+ if(buf[6] != 0){
+ printf("\nWrite inquiry scan activity command failed due to reason 0x%X\n",buf[6]);
+ return 0;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = (inq_scan&0xFF);
+ buf[1] = ((inq_scan >> 8)& 0xFF);
+ buf[2] = (inq_scan&0xFF);
+ buf[3] = ((inq_scan >> 8)& 0xFF);
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_WRITE_PAGE_ACTIVITY, 4, buf);
+ if(buf[6] != 0){
+ printf("\nWrite page scan activity command failed due to reason 0x%X\n",buf[6]);
+ return 0;
+ }
+ //2. Disbable AGC
+ Address = LC_JTAG_MODEM_REGS_ADDRESS + AGC_BYPASS_ADDRESS;
+ Mask = AGC_BYPASS_ENABLE_MASK;
+ Reg = AGC_BYPASS_ENABLE_SET(1);
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = (Address & 0xFF);
+ buf[1] = ((Address >>8) & 0xFF);
+ buf[2] = ((Address>>16) & 0xFF);
+ buf[3] = ((Address>>24) & 0xFF);
+ buf[4] = 0x04; //Memory width
+ buf[5] = (Reg & 0xFF);
+ buf[6] = ((Reg >> 8) & 0xFF);
+ buf[7] = ((Reg >> 16) & 0xFF);
+ buf[8] = ((Reg >> 24) & 0xFF);
+ buf[9] = (Mask & 0xFF);
+ buf[10] = ((Mask >>8) & 0xFF);
+ buf[11] = ((Mask>>16) & 0xFF);
+ buf[12] = ((Mask>>24) & 0xFF);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite to AGC bypass register failed due to reason 0x%X\n",buf[6]);
+ return 0;
+ }
+ // 3. Disable frequency hoping and set rx frequency
+
+ RxFreq = (int)pString;
+ Address = LC_DEV_PARAM_CTL_ADDRESS;
+ Mask = LC_DEV_PARAM_CTL_FREQ_HOP_EN_MASK |
+ LC_DEV_PARAM_CTL_RX_FREQ_MASK |
+ LC_DEV_PARAM_CTL_WHITEN_EN_MASK;
+ Reg = LC_DEV_PARAM_CTL_RX_FREQ_SET(RxFreq);
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = (Address & 0xFF);
+ buf[1] = ((Address >>8) & 0xFF);
+ buf[2] = ((Address>>16) & 0xFF);
+ buf[3] = ((Address>>24) & 0xFF);
+ buf[4] = 0x04; //Memory width
+ buf[5] = (Reg & 0xFF);
+ buf[6] = ((Reg >> 8) & 0xFF);
+ buf[7] = ((Reg >> 16) & 0xFF);
+ buf[8] = ((Reg >> 24) & 0xFF);
+ buf[9] = (Mask & 0xFF);
+ buf[10] = ((Mask >>8) & 0xFF);
+ buf[11] = ((Mask>>16) & 0xFF);
+ buf[12] = ((Mask>>24) & 0xFF);
+
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite to Rx Freq register failed due to reason 0x%X\n",buf[6]);
+ return 0;
+ }
+ // 4. Enable page scan only (Note: the old way puts device into inq scan mode only ???)
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 2; //Page scan enabled
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_WRITE_SCAN_ENABLE, 1, buf);
+ if(buf[6] != 0){
+ printf("\nPage scan enable command failed due to reason 0x%X\n",buf[6]);
+ return 0;
+ }
+ // 5. Increase correlator
+ Address = LC_JTAG_MODEM_REGS_ADDRESS + CORR_PARAM1_ADDRESS;
+ Mask = CORR_PARAM1_TIM_THR_MASK;
+ Reg = CORR_PARAM1_TIM_THR_SET(0x3f);
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = (Address & 0xFF);
+ buf[1] = ((Address >>8) & 0xFF);
+ buf[2] = ((Address>>16) & 0xFF);
+ buf[3] = ((Address>>24) & 0xFF);
+ buf[4] = 0x04; //Memory width
+ buf[5] = (Reg & 0xFF);
+ buf[6] = ((Reg >> 8) & 0xFF);
+ buf[7] = ((Reg >> 16) & 0xFF);
+ buf[8] = ((Reg >> 24) & 0xFF);
+ buf[9] = (Mask & 0xFF);
+ buf[10] = ((Mask >>8) & 0xFF);
+ buf[11] = ((Mask>>16) & 0xFF);
+ buf[12] = ((Mask>>24) & 0xFF);
+
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_WRITE_MEMORY, 12, buf);
+ if(buf[6] != 0){
+ printf("\nWrite to Correlator register failed due to reason 0x%X\n",buf[6]);
+ return 0;
+ }
+
+ return TRUE;
+}
+static const char *cwrx_help =
+ "Usage:\n"
+ "\n cwrx <Channel>\n";
+
+static void cmd_cwrx(int dev_id, int argc, char **argv){
+
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ UCHAR channel;
+ BOOL Ok = TRUE;
+ if(argc != 2){
+ printf("\n%s\n",cwrx_help);
+ return;
+ }
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ channel = atoi(argv[1]);
+ if(channel > 78 || channel < 0){
+ printf("\nPlease enter channel 0-78!\n");
+ return;
+ }
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ // Disable sleep mode
+ memset(&buf,0,sizeof(buf));
+ buf[0] = 0;
+ iRet = writeHciCommand(dd,OGF_VENDOR_CMD,OCF_SLEEP_MODE,1,buf);
+ if(buf[6] != 0){
+ printf("\nError: Sleep mode failed due to reason 0x%X\n",buf[6]);
+ Ok = 0;
+ }
+ printf (" Continuoux Rx at channel %d\n",channel);
+ Ok = contRxAtGivenChannel(dd, &channel);
+
+ // All modes come here
+ if (Ok)
+ {
+ printf (" Continuoux Rx at channel %d Done...\n",channel);
+ }
+ else
+ {
+ printf ("\nERROR ---> Could not enter continuous Rx mode\n");
+ }
+
+ hci_close_dev(dd);
+}
+static const char *mb_help =
+ "Usage:\n"
+ "\n mb\n";
+
+static void cmd_mb(int dev_id, int argc, char **argv){
+
+ int newfd, FieldNum,dd,iRet,need_raw, iDataSize, address,width,value,mask, fdmax, k, l;
+ bdaddr_t bdaddr;
+ tBRM_Control_packet MasterBlaster;
+ UCHAR SkipRxSlot;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ char FieldAlias;
+ BOOL TestEnabled = 0,Ok = TRUE;
+ UINT8 setContTxType;
+ tBtHostInterest HostInt;
+ fd_set master, read_fds;
+ uint32_t m_BerTotalBits, m_BerGoodBits;
+ uint8_t m_pattern[16];
+ uint16_t m_pPatternlength;
+ struct hci_filter flt;
+ struct hci_dev_info di;
+ struct timeval timeout;
+
+ if(argc > 1) {
+ printf("\n%s\n",mb_help);
+ return;
+ }
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = writeHciCommand(dd, OGF_INFO_PARAM, OCF_READ_BD_ADDR, 0, buf);
+ if (buf[6] != 0) {
+ printf("\nread bdaddr command failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ int i,j;
+ char bda[18];
+ for (i=iRet-1,j=0;i>7;i--,j+=3) {
+ sprintf(&bda[j],"%X",((buf[i]>>4)&0xFF));
+ sprintf(&bda[j+1],"%X",(buf[i]&0x0F));
+ sprintf(&bda[j+2],":");
+ }
+ sprintf(&bda[15],"%X",((buf[7]>>4)&0xFF));
+ sprintf(&bda[16],"%X",(buf[7]&0x0F));
+ bda[18] ='\0';
+ str2ba(bda,&bdaddr);
+
+ InitMasterBlaster(&MasterBlaster, &bdaddr, &SkipRxSlot);
+#ifndef DUMP_DEBUG
+ Ok = ReadHostInterest(dd,&HostInt);
+ if(Ok) {
+ if (HostInt.TpcTableAddr && (HostInt.Version >= 0x0100)) {
+ Ok = ReadMemoryBlock(dd, HostInt.TpcTableAddr, (UCHAR *)&TpcTable, sizeof(TpcTable));
+ MasterBlaster.testCtrl.Power = TpcTable.NumOfEntries - 1;
+ }
+ }
+ if(!Ok) {
+ printf ("\nCould not load TPC table.\n");
+ sleep (2);
+ Ok = TRUE;
+ }
+#endif
+
+ PrintMasterBlasterMenu (&MasterBlaster);
+ m_BerGoodBits = 0;
+ m_BerTotalBits = 0;
+ m_pattern[0] = 0x0f;
+ m_pPatternlength = 1;
+
+ FD_ZERO(&master);
+ FD_ZERO(&read_fds);
+ FD_SET(0, &master);
+ fdmax = 0;
+ newfd = -1;
+
+ while (1) {
+ read_fds = master;
+ timeout.tv_sec = 5;
+ timeout.tv_usec = 0;
+ iRet = select(fdmax+1, &read_fds, NULL, NULL, &timeout);
+ if (iRet == -1) {
+ perror("cmd_mb select() error!");
+ goto exits_mb;
+ }
+ if (iRet == 0) continue;
+
+ for(i = 0; i <= fdmax; i++) {
+ if(FD_ISSET(i, &read_fds)) {
+ if (i==0) { // input
+ scanf("%s",buf);
+ FieldAlias = (char)buf[0];
+ FieldNum = CheckField(MasterBlaster, &FieldAlias);
+ if (FieldNum == INVALID_MASTERBLASTER_FIELD) {
+ printf ("\nERROR ---> Invalid command. Try again.\n");
+ printf ("mb>");
+ continue;
+ }
+
+ if (!strncmp(&FieldAlias, MasterBlasterMenu[EXX].Alias, 1)) {
+ printf("\nExit the Master Blaster Mode without reset\n");
+ goto exits_mb;
+ }
+
+ // if the test is in rx and the key is neither 'd' nor 'g', then stop the test, renew the option, and procced
+ // if the test is in tx and the key is not 'e', then stop the test, renew the option, and procced
+ // if the test is in (LE) continuous rx/tx and the key is not 'j' , then stop the test, renew the option, and procced
+ if (((TestEnabled == MB_RX_TEST) && strncmp(&FieldAlias, MasterBlasterMenu[RX].Alias, 1) && strncmp(&FieldAlias, MasterBlasterMenu[GB].Alias, 1))
+ || ((TestEnabled == MB_TX_TEST) && strncmp(&FieldAlias, MasterBlasterMenu[TX].Alias, 1))
+ || ((TestEnabled == MB_CONT_RX_TEST || TestEnabled == MB_CONT_TX_TEST
+ || TestEnabled == MB_LE_RX_TEST || TestEnabled == MB_LE_TX_TEST) &&
+ (strncmp(&FieldAlias, MasterBlasterMenu[EN].Alias, 1)))) {
+ printf (" ... Please wait ...");
+ if (MasterBlaster.ContTxMode) {
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 255;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_CONT_TX_TESTER, 14, buf);
+ if(buf[6] != 0) {
+ printf("\nContinious Tx Tester command failed due to reason 0x%X\n",buf[6]);
+ Ok = 0;
+ } else
+ Ok = TRUE;
+ }
+ if (TestEnabled == MB_RX_TEST) {
+ if (need_raw) {
+ if (ioctl(dd, HCISETRAW, 0) < 0)
+ perror("Can't clear raw mode \n");
+ }
+ FD_CLR(newfd, &master);
+ newfd = -1;
+ fdmax = 0;
+ }
+ // Ok = Diag::Reset (Unit, "");
+ //PSInit(dd);
+ // The default setting is sleep mode enabled.
+ memset(&buf,0,sizeof(buf));
+ buf[0] = 1;
+ iRet = writeHciCommand(dd,OGF_VENDOR_CMD,OCF_SLEEP_MODE,1,buf);
+ if(buf[6] != 0) {
+ printf("\nError: Sleep mode failed due to reason 0x%X\n",buf[6]);
+ }
+
+ memset(&buf,0,sizeof(buf));
+ iRet = writeHciCommand(dd,OGF_HOST_CTL,OCF_RESET,0,buf);
+ if (buf[6] != 0) {
+ printf("\nError: HCI RESET failed due to reason 0x%X\n",buf[6]);
+ Ok = FALSE;
+ } else
+ Ok = TRUE;
+ if (!Ok) {
+ printf ("\nERROR ---> Could not stop test mode\n");
+ } else if (!strncmp(&FieldAlias, MasterBlasterMenu[RX].Alias, 1)
+ || !strncmp(&FieldAlias, MasterBlasterMenu[TX].Alias, 1)
+ || ((TestEnabled != MB_NO_TEST) &&
+ (!strncmp(&FieldAlias, MasterBlasterMenu[CR].Alias, 1) ||
+ !strncmp(&FieldAlias, MasterBlasterMenu[CT].Alias, 1) ||
+ !strncmp(&FieldAlias, MasterBlasterMenu[LR].Alias, 1) ||
+ !strncmp(&FieldAlias, MasterBlasterMenu[LT].Alias, 1))) ||
+ !strncmp(&FieldAlias, MasterBlasterMenu[EN].Alias, 1)) {
+ TestEnabled = MB_NO_TEST;
+ }
+ sleep(1);
+ }
+ if (!strncmp(&FieldAlias,MasterBlasterMenu[EX].Alias,1)) { // Exit
+ TestEnabled = MB_NO_TEST;
+ printf ("\n Exit ..\n");
+ goto exits_mb;
+ } else if (!strncmp(&FieldAlias,MasterBlasterMenu[ST].Alias,1)) { // Stop Test
+ TestEnabled = MB_NO_TEST;
+ PrintMasterBlasterMenu (&MasterBlaster);
+ continue;
+ } else if (!strncmp(&FieldAlias,MasterBlasterMenu[GB].Alias,1)) { // get BER
+ printf("\n\tGoodBits %d, total is %d\n", m_BerGoodBits, m_BerTotalBits);
+ printf("mb>\n");
+ continue;
+ } else if (!strncmp(&FieldAlias,MasterBlasterMenu[PO].Alias,1)) { // set Power
+ MasterBlasterMenu[FieldNum].pFunc (&MasterBlaster, &FieldAlias);
+ } else if (!MasterBlasterMenu[FieldNum].pFunc (&MasterBlaster, MasterBlasterMenu[FieldNum].Options)) {
+ printf ("\nERROR ---> Invalid option. Try again.\n");
+ printf ("mb>");
+ continue;
+ }
+ PrintMasterBlasterMenu(&MasterBlaster);
+
+ // Enable RX test mode
+ if ((!strncmp(&FieldAlias, MasterBlasterMenu[RX].Alias, 1) && (TestEnabled == MB_NO_TEST))
+ || (strncmp(&FieldAlias, MasterBlasterMenu[RX].Alias, 1) && (TestEnabled == MB_RX_TEST))) {
+ Ok = Dut(dd);
+ if (!Ok) {
+ printf("\nERROR ---> Could not enter DUT mode\n");
+ printf("mb>");
+ continue;
+ }
+
+ printf(".");
+ if (hci_devinfo(dev_id, &di) < 0) {
+ printf("Can't get device info\n");
+ printf("mb>");
+ continue;
+ }
+
+ need_raw = !hci_test_bit(HCI_RAW, &di.flags);
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = eBRM_TestMode_Rx;
+ buf[1] = MasterBlaster.testCtrl.Packet;
+ buf[2] = MasterBlaster.testCtrl.DataLen & 0xFF;
+ buf[3] = ((MasterBlaster.testCtrl.DataLen>>8) & 0xFF);
+ buf[4] = MasterBlaster.testCtrl.HopMode;
+ buf[5] = MasterBlaster.testCtrl.TxFreq;
+ buf[6] = MasterBlaster.testCtrl.Power;
+ buf[7] = MasterBlaster.testCtrl.RxFreq;
+ buf[8] = MasterBlaster.bdaddr[0];
+ buf[9] = MasterBlaster.bdaddr[1];
+ buf[10] = MasterBlaster.bdaddr[2];
+ buf[11] = MasterBlaster.bdaddr[3];
+ buf[12] = MasterBlaster.bdaddr[4];
+ buf[13] = MasterBlaster.bdaddr[5];
+ buf[14] = SkipRxSlot;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_RX_TESTER, 15, buf);
+ if (buf[6] != 0) {
+ printf("\nRx Tester command failed due to reason 0x%X\n",buf[6]);
+ printf("\nERROR --> Could not enable master blaster mode\n");
+ TestEnabled = MB_NO_TEST;
+ Ok = 0;
+ } else {
+ printf(" rx test is in progress. Press 's' to stop the test\n");
+ TestEnabled = MB_RX_TEST;
+ hci_filter_clear(&flt);
+ hci_filter_all_ptypes(&flt);
+ hci_filter_all_events(&flt);
+
+ if (setsockopt(dd, SOL_HCI, HCI_FILTER, &flt, sizeof(flt)) < 0) {
+ printf("Can't set filter for hci\n");
+ printf("mb>");
+ continue;
+ }
+
+ if (need_raw) {
+ if (ioctl(dd, HCISETRAW, 1) < 0) {
+ printf("Can't set raw mode on hci\n");
+ printf("mb>");
+ continue;
+ }
+ }
+ newfd = dd;
+ FD_SET(newfd, &master);
+ fdmax = dd;
+ }
+ printf("mb>");
+ continue;
+ } else if ((!strncmp(&FieldAlias, MasterBlasterMenu[RX].Alias, 1)) && (TestEnabled == MB_RX_TEST)) {
+ printf(" rx test is in progress. Press 's' to stop the test\n");
+ printf("mb>");
+ continue;
+ }
+
+ // Enable TX test mode
+ if ((!strncmp(&FieldAlias, MasterBlasterMenu[TX].Alias, 1) && (TestEnabled == MB_NO_TEST))
+ || (strncmp(&FieldAlias, MasterBlasterMenu[TX].Alias, 1) && (TestEnabled == MB_TX_TEST))) {
+ // Disable sleep mode
+ printf (".");
+ Ok = TRUE;
+ memset(&buf,0,sizeof(buf));
+ buf[0] = 0;
+ iRet = writeHciCommand(dd,OGF_VENDOR_CMD,OCF_SLEEP_MODE,1,buf);
+ if(buf[6] != 0) {
+ printf("\nError: Sleep mode failed due to reason 0x%X\n",buf[6]);
+ Ok = 0;
+ }
+
+ if (!Ok) {
+ printf ("\nERROR ---> Could not disable sleep mode\n");
+ printf ("mb>");
+ continue;
+ }
+
+ printf (".");
+ Ok = Dut(dd);
+ if (!Ok) {
+ printf("\nERROR ---> Could not enter DUT mode\n");
+ printf("mb>");
+ continue;
+ }
+
+ printf(".");
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = MasterBlaster.testCtrl.Mode ;
+ buf[1] = MasterBlaster.testCtrl.Packet;
+ buf[2] = MasterBlaster.testCtrl.DataLen & 0xFF;
+ buf[3] = ((MasterBlaster.testCtrl.DataLen>>8) & 0xFF);
+ buf[4] = MasterBlaster.testCtrl.HopMode;
+ buf[5] = MasterBlaster.testCtrl.TxFreq;
+ buf[6] = MasterBlaster.testCtrl.Power;
+ buf[7] = MasterBlaster.testCtrl.RxFreq;
+ buf[8] = MasterBlaster.bdaddr[0];
+ buf[9] = MasterBlaster.bdaddr[1];
+ buf[10] = MasterBlaster.bdaddr[2];
+ buf[11] = MasterBlaster.bdaddr[3];
+ buf[12] = MasterBlaster.bdaddr[4];
+ buf[13] = MasterBlaster.bdaddr[5];
+ buf[14] = SkipRxSlot;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_TX_TESTER, 15, buf);
+ if (buf[6] != 0) {
+ printf("\nTx Tester command failed due to reason 0x%X\n",buf[6]);
+ printf("\nERROR --> Could not enable master blaster mode\n");
+ TestEnabled = MB_NO_TEST;
+ Ok = 0;
+ } else {
+ printf(" tx test is in progress. Press 's' to stop the test\n");
+ TestEnabled = MB_TX_TEST;
+ }
+ printf("mb>");
+ continue;
+ } else if ((!strncmp(&FieldAlias, MasterBlasterMenu[TX].Alias, 1)) && TestEnabled == MB_TX_TEST) {
+ printf(" tx test is in progress. Press 's' to stop the test\n");
+ printf("mb>");
+ continue;
+ }
+
+ /* Enable (LE) continuous tx/rx test modes */
+ if (((!strncmp(&FieldAlias, MasterBlasterMenu[EN].Alias, 1)) && (TestEnabled == MB_NO_TEST))
+ || (strncmp(&FieldAlias, MasterBlasterMenu[EN].Alias, 1) && (TestEnabled == MB_CONT_RX_TEST
+ || TestEnabled == MB_CONT_TX_TEST || TestEnabled == MB_LE_RX_TEST || TestEnabled == MB_LE_TX_TEST))) {
+ // Disable sleep mode
+ printf (".");
+ Ok = TRUE;
+ memset(&buf,0,sizeof(buf));
+ buf[0] = 0;
+ iRet = writeHciCommand(dd,OGF_VENDOR_CMD,OCF_SLEEP_MODE,1,buf);
+ if (buf[6] != 0) {
+ printf("\nError: Sleep mode failed due to reason 0x%X\n",buf[6]);
+ Ok = 0;
+ }
+
+ if (!Ok) {
+ printf ("\nERROR ---> Could not disable sleep mode\n");
+ printf ("mb>");
+ continue;
+ }
+
+ /* LE Rx Mode */
+ if (MasterBlaster.LERxMode == ENABLE) {
+ Ok = SU_LERxTest(dd, MasterBlaster.testCtrl.RxFreq);
+ TestEnabled = MB_LE_RX_TEST;
+ } else if (MasterBlaster.LETxMode == ENABLE) {
+ Ok = SU_LETxTest(dd, MasterBlaster.testCtrl.TxFreq, MasterBlaster.testCtrl.DataLen,
+ MasterBlaster.LETxParms.PktPayload);
+ TestEnabled = MB_LE_TX_TEST;
+ } else if (MasterBlaster.ContRxMode == ENABLE) {
+ UCHAR RxFreq = MasterBlaster.testCtrl.RxFreq;
+ Ok = contRxAtGivenChannel(dd, &RxFreq);
+ TestEnabled = MB_CONT_RX_TEST;
+ } else /* Continous TX mode */ {
+ printf(".");
+ Ok = Dut(dd);
+ if (!Ok) {
+ printf("\nERROR ---> Could not enter DUT mode\n");
+ printf("mb>");
+ continue;
+ }
+ /* Enable master blaster mode */
+ printf(".");
+ if (CW_Single_Tone == MasterBlaster.ContTxType)
+ setContTxType = Cont_Tx_Raw_1MHz;
+ else
+ setContTxType = MasterBlaster.ContTxType;
+
+ memset(&buf, 0, HCI_MAX_EVENT_SIZE);
+ buf[0] = MasterBlaster.testCtrl.Mode ;
+ buf[1] = MasterBlaster.testCtrl.Packet;
+ buf[2] = MasterBlaster.testCtrl.DataLen & 0xFF;
+ buf[3] = ((MasterBlaster.testCtrl.DataLen>>8) & 0xFF);
+ buf[4] = MasterBlaster.ContTxType;
+ buf[5] = MasterBlaster.testCtrl.TxFreq;
+ buf[6] = MasterBlaster.testCtrl.Power;
+ buf[7] = MasterBlaster.testCtrl.RxFreq;
+ buf[8] = MasterBlaster.bdaddr[0];
+ buf[9] = MasterBlaster.bdaddr[1];
+ buf[10] = MasterBlaster.bdaddr[2];
+ buf[11] = MasterBlaster.bdaddr[3];
+ buf[12] = MasterBlaster.bdaddr[4];
+ buf[13] = MasterBlaster.bdaddr[5];
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_CONT_TX_TESTER, 14, buf);
+ if(buf[6] != 0){
+ printf("\nContinious Tx Tester command failed due to reason 0x%X\n",buf[6]);
+ Ok = FALSE;
+ } else
+ Ok = TRUE;
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ address = 0x00022914;
+ value = 0x00200000;
+ mask = 0x00200000;
+ width = 4;
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = width; //Memory width
+ buf[5] = (value & 0xFF);
+ buf[6] = ((value >> 8) & 0xFF);
+ buf[7] = ((value >> 16) & 0xFF);
+ buf[8] = ((value >> 24) & 0xFF);
+ buf[9] = (mask & 0xFF);
+ buf[10] = ((mask >>8) & 0xFF);
+ buf[11] = ((mask>>16) & 0xFF);
+ buf[12] = ((mask>>24) & 0xFF);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ Ok = FALSE;
+ } else
+ Ok = TRUE;
+
+ TestEnabled = MB_CONT_TX_TEST;
+ }
+ if (Ok) {
+ printf("Test is in progress. Press 's' to stop the test\n");
+ } else {
+ printf("\nERROR ---> Could not enable master blaster mode\n");
+ TestEnabled = MB_NO_TEST;
+ }
+ printf("mb>");
+ continue;
+ } else if ((!strncmp(&FieldAlias, MasterBlasterMenu[EN].Alias, 1)) && TestEnabled) {
+ printf (" Test mode is in progress. Press 's' to stop the test\n");
+ printf ("mb>");
+ continue;
+ }
+ }
+ else if (i == newfd) {
+ iRet = read(i, buf, sizeof(buf));
+ iDataSize = iRet - 5;
+// printf("first:%x,nbyte:%d, packet:%d, pattern:%x\n",buf[0], iRet, (uint16_t)(buf[3] | (buf[4] << 8)), buf[5]);
+ if (buf[0] == 0x2) { // ACL data
+ m_BerTotalBits = m_BerTotalBits + iDataSize * 8;
+ for(j=0,l=0;j<iDataSize;j++,l++) {
+ if (l == m_pPatternlength) l = 0;
+ for(k=0;k<8;k++){
+ if((m_pattern[l]&(1<<k)) == (buf[8+j]&(1<<k)))
+ m_BerGoodBits++;
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+exits_mb:
+ if (need_raw) {
+ if (ioctl(dd, HCISETRAW, 0) < 0)
+ perror("Can't clear raw mode \n");
+ }
+ hci_close_dev(dd);
+}
+/*
+static void cmd_gid(int dev_id, int argc, char **argv){
+ printf("\nFeature not implemented\n");
+}
+*/
+static const char *wsm_help =
+ "Usage:\n"
+ "\n wsm [0|1|2|3]\n"
+ "\nExample:\n"
+ "\twsm 0\t(Scan disabled)\n"
+ "\twsm 1\t(Inquiry scan enabled)\n"
+ "\twsm 2\t(Page scan enabled)\n"
+ "\twsm 3\t(Inquiry and Page scan enabled)\n";
+
+static void cmd_wsm(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ if(argc < 2){
+ printf("\n%s\n",wsm_help);
+ return;
+ }
+ if(atoi(argv[1]) > 3){
+ printf("\nInvalid scan mode :%d\n",atoi(argv[1]));
+ return;
+ }
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = atoi(argv[1]);
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_WRITE_SCAN_ENABLE, 1, buf);
+ if(buf[6] != 0){
+ printf("\nWrite scan mode command failed due to reason 0x%X\n",buf[6]);
+ return;
+ }
+ hci_close_dev(dd);
+ printf("\nScan Mode set to :%d\n",atoi(argv[1]));
+}
+
+static void dumpHex(UCHAR *buf, int length, int col)
+{
+ int i;
+ for (i = 0; i < length; i++) {
+ printf("0x%02x ", buf[i]);
+ if (((i+1) % col) == 0 && i != 0)
+ printf("\n");
+ }
+ if (((i+1) % col) != 0) printf("\n");
+}
+
+static void ReverseHexString(char *pStr)
+{
+ int i, j;
+ char temp;
+ int len = strlen(pStr);
+
+ for (i = 0; pStr[i] == ' ' || pStr[i] == '\t'; i++);
+
+ if (pStr[i] == '0' && pStr[i+1] == 'x')
+ i += 2;
+
+ for (j = len - 1; i < j - 2; i += 2, j -= 2) {
+ temp = pStr[i];
+ pStr[i] = pStr[j - 1];
+ pStr[j - 1] = temp;
+ temp = pStr[i + 1];
+ pStr[i + 1] = pStr[j];
+ pStr[j] = temp;
+ }
+}
+
+static void GetByteSeq(UCHAR *pDst, UCHAR *pSrc, int Size)
+{
+ UCHAR LowNibble, Nibble = 0;
+ UCHAR *pLastHex;
+ UCHAR *pStr = pSrc;
+
+ while (*pStr == ' ' || *pStr == '\t') pStr++;
+
+ if ((pStr[0] == '0') && (pStr[1] == 'x'))
+ pStr += 2;
+
+ pLastHex = pStr - 1;
+ while (IS_HEX(*(pLastHex + 1)))
+ pLastHex++;
+
+ LowNibble = 0;
+
+ while (Size > 0) {
+ if (pStr <= pLastHex) {
+ Nibble = CONV_HEX_DIGIT_TO_VALUE(*pStr);
+ pStr++;
+ } else {
+ Nibble = 0;
+ }
+
+ if (LowNibble) {
+ *pDst |= (UCHAR)(Nibble & 0x0F);
+ LowNibble = 0;
+ pDst++;
+ Size--;
+ } else {
+ *pDst = (UCHAR)((Nibble << 4) & 0xF0);
+ LowNibble = 1;
+ }
+ }
+}
+
+unsigned int GetUInt(char **ppLine, unsigned int DefaultValue)
+{
+ char *pStr = *ppLine;
+ unsigned int Value = 0;
+
+ // Is it a hex value?
+ if ((*pStr == '0') && (*(pStr+1) == 'x'))
+ {
+ // We have a hex value
+
+ pStr += 2;
+
+ while (IS_HEX(*pStr))
+ {
+ Value = CONV_HEX_DIGIT_TO_VALUE(*pStr) + (Value*16);
+ pStr++;
+ }
+
+ }
+ else if (IS_DIGIT(*pStr))
+ {
+ // We have a decimal value
+ while (IS_DIGIT(*pStr))
+ {
+ Value = CONV_DEC_DIGIT_TO_VALUE(*pStr) + (Value*10);
+ pStr++;
+ }
+ }
+ else
+ {
+ // We don't have a value at all - return default value
+ return DefaultValue;
+ }
+
+ // Update the BtString ptr
+ *ppLine = pStr;
+ return Value;
+}
+
+static const char *mbr_help =
+ "Usage:\n"
+ "\n mbr <address> <length> \n"
+ "\n Example \n"
+ "\n mbr 0x00004FFC 10 \n"
+ "\n mbr 0x00004FFC 0x10 \n";
+
+static void cmd_mbr(int dev_id, int argc, char **argv){
+ int dd;
+ UCHAR buf[HCI_MAX_EVENT_SIZE*20];
+
+ if(argc != 3){
+ printf("\n%s\n",mbr_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ int length = GetUInt(&(argv[2]),0);
+ int address = GetUInt(&(argv[1]),0);
+
+ if ((address == 0) || (length==0)){
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE*20);
+ if(!MemBlkRead(dd,address,buf, length)) {
+ printf("\nmemory bulk read command failed\n");
+ return;
+ }
+ printf("\ndata: \n");
+ int i;
+ for(i=0;i < length;i+=4){
+ printf("%08X: ",address+i);
+ printf("%08X",*((int*)(buf+i)));
+ printf("\n");
+ }
+ printf("\n");
+
+ hci_close_dev(dd);
+
+}
+
+static const char *psr_help =
+ "Usage:\n"
+ "\n psr \n";
+
+static void cmd_psr(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ if(argc > 1){
+ printf("\n%s\n",psr_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ LoadPSHeader(buf,PS_RESET,0,0);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER+2, buf);
+ if(buf[7] != 0){ /* Check for status */
+ printf("\n PS Reset failed\n");
+ hci_close_dev(dd);
+ return;
+ }
+ hci_close_dev(dd);
+ printf("PS reset done\n");
+}
+
+static const char *rpst_help =
+ "Usage:\n"
+ "\n rpst <tag id> <tag length> \n"
+ "\n Example:\n"
+ "\n rpst 1 6 \n";
+static void cmd_rpst(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int tag_id,tag_len,i,j;
+ if(argc != 3){
+ printf("\n%s\n",rpst_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ tag_id = GetUInt(&(argv[1]),0);
+ tag_len = GetUInt(&(argv[2]),0);
+ LoadPSHeader(buf,PS_READ,tag_len,tag_id);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER, buf);
+ if(buf[6] != 0){
+ printf("\n read PS tag failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = read(dd,&buf,HCI_MAX_EVENT_SIZE);
+ if(iRet < 0){
+ printf("\n read PS tag failed\n");
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nTag ID :%X\nTag Length:%X\nTag Data:\n",tag_id,tag_len);
+
+ for(i=4,j=1;i<iRet;i++,j++){
+ printf("%02X ",buf[i]);
+ if(j%16 == 0)
+ printf("\n");
+ }
+ printf("\n\n");
+ hci_close_dev(dd);
+}
+static const char *wpst_help =
+ "Usage:\n"
+ "\n wpst <tag id> <tag length> <tag data>\n"
+ "\n Example:\n"
+ "\n wpst 1 6 00 03 F4 55 AB 77 \n";
+
+static void cmd_wpst(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int tag_id,tag_len,i;
+ if(argc < 4){
+ printf("\n%s\n",wpst_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ tag_id = GetUInt(&(argv[1]),0);
+ tag_len = GetUInt(&(argv[2]),0);
+ if(argc < tag_len+3){
+ printf("\n Tag Data is less than Tag Length\n");
+ hci_close_dev(dd);
+ return;
+ }
+ LoadPSHeader(buf,PS_WRITE,tag_len,tag_id);
+ for(i=0;i<tag_len;i++){
+ buf[i+4] = strtol(argv[i+3], NULL, 16);
+ }
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER + tag_len, buf);
+ if(buf[6] != 0){
+ printf("\n Write PS tag failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ hci_close_dev(dd);
+}
+
+static const char *setam_help =
+ "Usage:\n"
+ "\nsetam <storage medium> <access mode>\n"
+ "\nstorage medium: 0-RAM 1-EEPROM\n"
+ "\naccess mode: 0-Read-only 1-Write-only 2-Read-Write 3- Disabled\n"
+ "\nExample:\n"
+ "\nsetam 0 3\n";
+static void cmd_setam(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int medium,mode;
+ if(argc !=3){
+ printf("\n%s\n",setam_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ medium = GetUInt(&(argv[1]),0);
+ mode = GetUInt(&(argv[2]),0);
+ LoadPSHeader(buf,PS_SET_ACCESS_MODE,mode,medium);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER, buf);
+ if(buf[6] != 0){
+ printf("\nSet Access mode failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ hci_close_dev(dd);
+ printf("\nAccess mode changed successfully!\n");
+}
+
+static const char *setap_help =
+ "Usage:\n"
+ "\nsetap <storage medium> <priority>\n"
+ "\nstorage medium: 0-RAM 1-EEPROM\n"
+ "\npriority: #Highest number corresponds to highest priority\n"
+ "\nExample:\n"
+ "\nsetap 0 1\n";
+
+static void cmd_setap(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int medium,priority;
+ if(argc !=3){
+ printf("\n%s\n",setap_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ medium = GetUInt(&(argv[1]),0);
+ priority = GetUInt(&(argv[2]),0);
+ LoadPSHeader(buf,PS_SET_ACCESS_MODE,priority,medium);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER, buf);
+ if(buf[6] != 0){
+ printf("\nSet Access priority failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ hci_close_dev(dd);
+ printf("\nPriority changed successfully!\n");
+}
+
+static const char *rpsraw_help =
+ "Usage:\n"
+ "\n rpsraw <offset> <length> \n"
+ "\n Example:\n"
+ "\n rpsraw 0x012c 10\n";
+static void cmd_rpsraw(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int offset,len,i,j;
+ if(argc != 3){
+ printf("\n%s\n",rpsraw_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ offset = GetUInt(&(argv[1]),0);
+ len = GetUInt(&(argv[2]),0);
+ LoadPSHeader(buf,PS_READ_RAW,len,offset);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER, buf);
+ if(buf[6] != 0){
+ printf("\n read PS raw failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = read(dd,&buf,HCI_MAX_EVENT_SIZE);
+ if(iRet < 0){
+ printf("\n read PS raw failed\n");
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nOffset :%X\nLength:%X\nData:\n",offset,len);
+
+ for(i=4,j=1;i<iRet;i++,j++){
+ printf("%02X ",buf[i]);
+ if(j%16 == 0)
+ printf("\n");
+ }
+ printf("\n\n");
+ hci_close_dev(dd);
+}
+static const char *wpsraw_help =
+ "Usage:\n"
+ "\n wpsraw <offset> <length> <data>\n"
+ "\n Example:\n"
+ "\n wpsraw 0x012C 6 00 03 F4 55 AB 77 \n";
+
+static void cmd_wpsraw(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int offset,len,i;
+ if(argc < 4){
+ printf("\n%s\n",wpsraw_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ offset = GetUInt(&(argv[1]),0);
+ len = GetUInt(&(argv[2]),0);
+ if(argc < len+3){
+ printf("\nData is less than Length\n");
+ hci_close_dev(dd);
+ return;
+ }
+ LoadPSHeader(buf,PS_WRITE_RAW,len,offset);
+ for(i=0;i<len;i++){
+ buf[i+4] = strtol(argv[i+3], NULL, 16);
+ }
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS,PS_COMMAND_HEADER + len, buf);
+ if(buf[6] != 0){
+ printf("\n Write PS tag failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ hci_close_dev(dd);
+}
+
+static const char *peek_help =
+ "\nUsage:"
+ "\npeek <address> <width>\n"
+ "\nExample:\n"
+ "\npeek 0x00004FFC 5\n";
+static void cmd_peek(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int address,width,value;
+ if(argc < 2){
+ printf("\n%s\n",peek_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ address = GetUInt(&(argv[1]),0);
+ if(argc == 3)
+ width = GetUInt(&(argv[2]),0x4);
+ else
+ width = 4;
+
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = (UCHAR)width; //Memory width
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_READ_MEMORY, 5, buf);
+ if(buf[6] != 0){
+ printf("\nRead Memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ value = buf[10];
+ value = ((value << 8) | buf[9]);
+ value = ((value << 8) | buf[8]);
+ value = ((value << 8) | buf[7]);
+
+ printf("\n0x%X : 0x%X \n",address,value);
+ //printf("\n0x%X : 0x%02X%02X%02X%02X \n",address,buf[7],buf[8],buf[9],buf[10]);
+ hci_close_dev(dd);
+}
+
+static const char *cwtx_help =
+ "\nUsage:"
+ "\ncwtx <channel number>\n"
+ "\nExample:\n"
+ "\ncwtx 40"
+ "\n\n";
+
+static void cmd_cwtx(int dev_id, int argc, char **argv){
+ int dd,iRet, Length = 0;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int channel;
+ if(argc != 2){
+ printf("\n%s\n",cwtx_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ channel = atoi(argv[1]);
+ if(channel > 78 || channel < 0){
+ printf("\nPlease enter channel 0-78!\n");
+ hci_close_dev(dd);
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ iRet = writeHciCommand(dd, OGF_HOST_CTL,OCF_RESET,Length,buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x80;
+ buf[1] = 0x20;
+ buf[2] = 0x02;
+ buf[3] = 0x00;
+ buf[4] = 0x04;
+ buf[5] = 0xFF;
+ buf[6] = 0x08;
+ buf[7] = 0xC0;
+ buf[8] = 0x00;
+ buf[9] = 0xFF;
+ buf[10] = 0xFF;
+ buf[11] = 0xFF;
+ buf[12] = 0xFF;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ /* hcitool cmd 0x3F 0x06 0x34 0x20 0x02 0x00 0x04 0x88 0xA0 0x00 0x02 0xFF 0xFF 0xFF 0xFF */
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x34;
+ buf[1] = 0x20;
+ buf[2] = 0x02;
+ buf[3] = 0x00;
+ buf[4] = 0x04;
+ buf[5] = 0x88;
+ buf[6] = 0xA0;
+ buf[7] = 0x00;
+ buf[8] = 0x02;
+ buf[9] = 0xFF;
+ buf[10] = 0xFF;
+ buf[11] = 0xFF;
+ buf[12] = 0xFF;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+
+ /* hcitool cmd 0x3F 0x06 0x28 0x20 0x02 0x00 0x04 0x00 0x90 0x05 0x20 0xFF 0xFF 0xFF 0xFF */
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x28;
+ buf[1] = 0x20;
+ buf[2] = 0x02;
+ buf[3] = 0x00;
+ buf[4] = 0x04;
+ buf[5] = 0x00;
+ buf[6] = 0x90;
+ buf[7] = 0x05;
+ buf[8] = 0x20;
+ buf[9] = 0xFF;
+ buf[10] = 0xFF;
+ buf[11] = 0xFF;
+ buf[12] = 0xFF;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+
+ /* hcitool cmd 0x3F 0x06 0x7C 0x08 0x02 0x00 0x04 0x01 0x00 0x00 0x4B 0xFF 0xFF 0xFF 0xFF */
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x7C;
+ buf[1] = 0x08;
+ buf[2] = 0x02;
+ buf[3] = 0x00;
+ buf[4] = 0x04;
+ buf[5] = 0x01;
+ buf[6] = 0x00;
+ buf[7] = 0x00;
+ buf[8] = 0x4B;
+ buf[9] = 0xFF;
+ buf[10] = 0xFF;
+ buf[11] = 0xFF;
+ buf[12] = 0xFF;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+
+
+ /* hcitool cmd 0x3F 0x06 0x00 0x08 0x02 0x00 0x04 $number 0x00 0x00 0x00 0xFF 0xFF 0xFF 0xFF */
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x00;
+ buf[1] = 0x08;
+ buf[2] = 0x02;
+ buf[3] = 0x00;
+ buf[4] = 0x04;
+ buf[5] = (UCHAR)channel; /* Num */
+ buf[6] = 0x00;
+ buf[7] = 0x00;
+ buf[8] = 0x00;
+ buf[9] = 0xFF;
+ buf[10] = 0xFF;
+ buf[11] = 0xFF;
+ buf[12] = 0xFF;
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD,OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nEntering continuous wave Tx on channel %d\n",channel);
+
+ hci_close_dev(dd);
+}
+
+
+static const char *poke_help =
+ "\nUsage:"
+ "\npoke <address> <value> <mask> <width>\n"
+ "\nExample:\n"
+ "\npoke 0x580000 0x22005FF 0xFFFFFFFF 4"
+ "\n\n";
+
+static void cmd_poke(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ int address,width,value,mask;
+ if(argc < 2){
+ printf("\n%s\n",poke_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ address = GetUInt(&(argv[1]),0);
+ value = GetUInt(&(argv[2]),0);
+ printf("\nARGC :%d\n",argc);
+ if(argc < 4)
+ mask = 0xffffffff;
+ else
+ mask = GetUInt(&(argv[3]),0xFFFFFFFF);
+ if(argc < 5)
+ width = 4;
+ else
+ width = GetUInt(&(argv[4]),0x4);
+ buf[0] = (address & 0xFF);
+ buf[1] = ((address >>8) & 0xFF);
+ buf[2] = ((address>>16) & 0xFF);
+ buf[3] = ((address>>24) & 0xFF);
+ buf[4] = width; //Memory width
+ buf[5] = (value & 0xFF);
+ buf[6] = ((value >> 8) & 0xFF);
+ buf[7] = ((value >> 16) & 0xFF);
+ buf[8] = ((value >> 24) & 0xFF);
+ buf[9] = (mask & 0xFF);
+ buf[10] = ((mask >>8) & 0xFF);
+ buf[11] = ((mask>>16) & 0xFF);
+ buf[12] = ((mask>>24) & 0xFF);
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_WRITE_MEMORY, 13, buf);
+ if(buf[6] != 0){
+ printf("\nWrite memory address failed due to reason 0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nPoke successful!\n");
+ hci_close_dev(dd);
+}
+
+
+
+static const char *dump_help =
+ "\nUsage:"
+ "\ndump audio - Display Audio statistics\n"
+ "\ndump dma- Display DMA statistics\n"
+ "\ndump dma r - Display and Reset DMA statistics\n"
+ "\ndump tpc - Dump TPC tables\n"
+ "\nExample:\n"
+ "\ndump audio"
+ "\ndump dma"
+ "\ndump dma r"
+ "\ndump tpc"
+ "\n";
+
+
+static void cmd_dump(int dev_id, int argc, char **argv){
+ int dd;
+ if(argc < 2){
+ printf("\n%s\n",dump_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ if(!strncmp(argv[1],"audio",5)){
+ ReadAudioStats(dd);
+ }
+ else if(!strncmp(argv[1],"dma",3)){
+ ReadGlobalDMAStats(dd);
+ if(argc == 3 && !strncmp(argv[2],"r",1)){
+ ResetGlobalDMAStats(dd);
+ }
+ }
+ else if(!strncmp(argv[1],"tpc",3)){
+ ReadTpcTable(dd);
+ }
+ else{
+ printf("\nInvalid option");
+ printf("\n%s\n",dump_help);
+ }
+
+ hci_close_dev(dd);
+ return;
+}
+
+static const char *rafh_help =
+ "\nUsage:"
+ "\nrafh <connection handle>\n"
+ "\nExample:\n"
+ "\nrafh 0x15"
+ "\n\n";
+
+static void cmd_rafh(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ short int handle;
+
+ if(argc < 2){
+ printf("\n%s\n",rafh_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ handle = GetUInt(&(argv[1]),0);
+ buf[0] = (handle & 0xFF);
+ buf[1] = ((handle >>8) & 0xFF);
+ iRet = writeHciCommand(dd, OGF_STATUS_PARAM,OCF_READ_AFH_MAP, 2, buf);
+ if(buf[6] != 0){
+ printf("\nRead AFH failed due to reason :0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+
+ if(buf[9] == 0)
+ printf(" AFH is disabled");
+ else
+ printf(" AFH is enabled");
+
+ handle = (buf[7] | (buf[8] << 8));
+ printf("\n AFH chaneel classification for handle: 0x%X",handle);
+ int i;
+ printf("\n Channel Classification Map :");
+ for(i=iRet-1; i>9 ; i--){
+ printf("%X",buf[i]);
+ }
+ printf("\n");
+ hci_close_dev(dd);
+}
+
+static const char *safh_help =
+ "\nUsage:"
+ "\nsafh <host channel classification>\n"
+ "\nExample:\n"
+ "\nsafh 0x7FFFFFFFFFFFFFFFFFFF"
+ "\n\n";
+
+static void cmd_safh(int dev_id, int argc, char **argv){
+ int dd,iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if(argc < 2){
+ printf("\n%s\n",safh_help);
+ return;
+ }
+ int i,j;
+ i = strlen(argv[1]);
+ if(i > 20 || i < 20){
+ printf("\n%s\n",safh_help);
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(&buf,0,HCI_MAX_EVENT_SIZE);
+ const char *map = argv[1];
+ char byte[3];
+ int data;
+ for (i = 0,j=9; i < 20 ; i+=2,j--) {
+ memcpy(byte,&map[i],2);
+ byte[2] = '\0';
+ data = strtol(byte, NULL, 16);
+ buf[j] = (data & 0xFF);
+ }
+ iRet = writeHciCommand(dd, OGF_HOST_CTL,OCF_SET_AFH_CLASSIFICATION,10, buf);
+ if(buf[6] != 0){
+ printf("\nSet AFH failed due to reason :0x%X\n",buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nSet AFH successful!\n");
+ hci_close_dev(dd);
+}
+
+static const char *wotp_help =
+ "\nUsage:"
+ "\nwotp <address> <data> [length=1]\n"
+ "\nExample:\n"
+ "\nwotp 0x15 0x2020 2"
+ "\n\n";
+
+static void cmd_wotp(int dev_id, int argc, char **argv)
+{
+ UINT32 address, length;
+
+ if (argc < 3) {
+ printf("\n%s\n", wotp_help);
+ return;
+ }
+ if (argc == 4)
+ length = GetUInt(&argv[3], 1);
+ else
+ length = 1;
+ address = GetUInt(&argv[1], 0xffffffff);
+ if (address == 0xffffffff) {
+ printf("\n%s\n", wotp_help);
+ return;
+ }
+ ReverseHexString(argv[2]);
+ if (!write_otpRaw(dev_id, address, length, (UCHAR *)argv[2]))
+ printf("Write to OTP sucessful!\n");
+}
+
+static int write_otpRaw(int dev_id, int address, int length, UCHAR *data)
+{
+ int dd, iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return dd;
+ }
+ memset(&buf, 0, HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x12; /* write RAW OTP */
+ buf[1] = address & 0xFF; /* PS tag */
+ buf[2] = (address >> 8) & 0xFF;
+ buf[3] = length; /* Entry Size */
+ GetByteSeq(buf + 4, data, 244); /* Entry Data */
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS, 244 + PS_COMMAND_HEADER, buf);
+ if (buf[6] != 0) {
+ printf("\nWrite to OTP failed due to reason :0x%X\n", buf[6]);
+ hci_close_dev(dd);
+ return buf[6];
+ }
+ hci_close_dev(dd);
+ return 0;
+}
+
+static const char *rotp_help =
+ "\nUsage:"
+ "\nrotp <address> [length=1]\n"
+ "\nExample:\n"
+ "\nrotp 0x15 2"
+ "\n\n";
+
+static void cmd_rotp(int dev_id, int argc, char **argv)
+{
+ UINT32 address, length;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if (argc < 2) {
+ printf("\n%s\n", rotp_help);
+ return;
+ }
+ if (argc == 3)
+ length = GetUInt(&argv[2], 1);
+ else
+ length = 1;
+ address = GetUInt(&argv[1], 0xffffffff);
+ if (address == 0xffffffff) {
+ printf("\n%s\n", rotp_help);
+ return;
+ }
+ if (!read_otpRaw(dev_id, address, length, buf))
+ dumpHex(buf, length, 8);
+}
+
+static int read_otpRaw(int dev_id, int address, int length, UCHAR *data)
+{
+ int dd, iRet, plen;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return dd;
+ }
+ memset(&buf, 0, HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x11; /* read OTP */
+ buf[1] = address & 0xFF; /* PS tag */
+ buf[2] = (address >> 8) & 0xFF;
+ buf[3] = length; /* Entry Size */
+ buf[4] = 0x00; /* Entry Data */
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_PS, 244 + PS_COMMAND_HEADER, buf);
+ if (buf[6] != 0) {
+ printf("\nRead from OTP failed due to reason :0x%X\n", buf[6]);
+ hci_close_dev(dd);
+ return buf[6];
+ }
+ do {
+ plen = read(dd, buf, HCI_MAX_EVENT_SIZE);
+ if (plen < 0) {
+ perror("Read OTP error\n");
+ exit(EXIT_FAILURE);
+ }
+ } while (buf[HCI_EVENT_HEADER_SIZE] != DEBUG_EVENT_TYPE_PS);
+ memcpy(data, buf + HCI_EVENT_HEADER_SIZE + 1, length);
+ hci_close_dev(dd);
+ return 0;
+}
+
+static int SU_GetId(int dev_id, char *pStr, tSU_RevInfo *pRetRevInfo)
+{
+ tSU_RevInfo RevInfo;
+ int dd, iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ RevInfo.RomVersion = 0x99999999;
+ RevInfo.BuildVersion = 0x99999999;
+ RevInfo.RadioFormat = 0xffff;
+ RevInfo.SysCfgFormat = 0xffff;
+
+ memset(buf, 0, HCI_MAX_EVENT_SIZE);
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return dd;
+ }
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_READ_VERSION, 0, buf);
+ if (buf[6] != 0) {
+ printf("\nRead version failed due to reason :0x%X\n", buf[6]);
+ return buf[6];
+ }
+ RevInfo.RomVersion = buf[7] + (buf[8]<<8) + (buf[9]<<16) + (buf[10]<<24);
+ RevInfo.BuildVersion = buf[11] + (buf[12]<<8) + (buf[13]<<16) + (buf[14]<<24);
+ return 0;
+}
+
+/*static const char *otp_help =
+ "\nUsage:"
+ "\notp [dump|imp|exp|test|rpid|wpid|rvid|wvid|rba|wba|hid|cpw|cpw|pwridx|ledo] [file]\n"
+ "\notp wba <BdAddr>:\n"
+ "\n\n";
+*/
+
+static void cmd_otp(int dev_id, int argc, char **argv)
+{
+ UCHAR buf[512], format[16];
+ FILE *pF = NULL;
+ UINT32 data;
+ int i;
+
+ if (argc == 1 || !strcmp(argv[1], "dump")) {
+ printf("dump:\n");
+ for (i = 0; i < 4; i++) {
+ if (read_otpRaw(dev_id, 128 * i, 128, &buf[128*i])) {
+ printf("read failed\n");
+ return;
+ }
+ }
+ dumpHex(buf, 512, 8);
+ } else if (!strcmp(argv[1], "test")) {
+ printf("test:\n");
+ printf("To be continue.\n");
+ } else if (!strcmp(argv[1], "imp")) {
+ if (argc < 3 || !*argv[2]) {
+ printf("Import file content into OTP. File name is required\n");
+ return;
+ }
+ printf("Import from %s into OTP:\n", argv[2]);
+ if (!(pF = fopen(argv[2], "rb"))) {
+ printf("Open file failed\n");
+ return;
+ }
+ fread(&buf[0], sizeof(buf), 1, pF);
+ fclose(pF);
+ for (i = 0; i < 512; i += 4) {
+ data = buf[i];
+ data <<= 8;
+ data += buf[i+1];
+ data <<= 8;
+ data += buf[i+2];
+ data <<= 8;
+ data += buf[i+3];
+ sprintf((char *)&format, "0x%08x", data);
+ if (write_otpRaw(dev_id, i, 4, (UCHAR *)format)) {
+ printf("Failed!(%d)\n", i);
+ return;
+ }
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "exp")) {
+ for (i = 0; i < 4; i++) {
+ if (read_otpRaw(dev_id, 128 * i, 128, &buf[128*i])) {
+ printf("Failed\n");
+ return;
+ }
+ }
+ if (argc < 3 || !*argv[2] || (!(pF = fopen(argv[2], "wb")))) {
+ /* export the content to the screen */
+ dumpHex(buf, 512, 8);
+ } else {
+ /* export the content to the file */
+ fwrite(&buf[0], sizeof(buf), 1, pF);
+ fclose(pF);
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "ledo")) {
+ int opendrain;
+ tSU_RevInfo RevInfo;
+
+ if (SU_GetId(dev_id, NULL, &RevInfo))
+ return;
+
+ printf("RomVer:%02X.%02X.%02X.%02X \n", (UINT8)((RevInfo.RomVersion >> (8*3)) & 0xff),
+ (UINT8)((RevInfo.RomVersion >> (8*2)) & 0xff),
+ (UINT8)((RevInfo.RomVersion >> 8) & 0xff),
+ (UINT8)(RevInfo.RomVersion & 0xff));
+ if (((UINT8)((RevInfo.RomVersion >> (8*3)) & 0xff) == 0x01) &&
+ ((UINT8)((RevInfo.RomVersion >> (8*2)) & 0xff) == 0x02) &&
+ ((UINT8)((RevInfo.RomVersion >> 8) & 0xff) == 0x02) &&
+ ((UINT8)(RevInfo.RomVersion & 0xff) == 0x00)) {
+ UINT8 LedValue[] = {0xCE, 0xDA, 0x04, 0x0C, 0x58,
+ 0x04, 0x05, 0x06, 0xff, 0x50,
+ 0x40, 0x01, 0x24, 0x08, 0x00,
+ 0x00};
+ for (opendrain = 112; opendrain < 128; opendrain++) {
+ if (write_otpRaw(dev_id, opendrain, 1, &LedValue[opendrain-112])) {
+ printf("Failed\n");
+ return;
+ }
+ }
+ printf("OTP led opendrain done\n");
+ } else {
+ printf("Wrong RomVer\n");
+ }
+ } else if (!strcmp(argv[1], "cpw")) {
+ UINT32 cin_value = 0, cout_value = 0;
+ char tempStr[8];
+
+ if (argc < 3) {
+ printf("\n Enter cin_value : ");
+ scanf("%d", &cin_value);
+ } else
+ cin_value = GetUInt(&argv[2], 0);
+ if (cin_value < 0 || cin_value > 128) {
+ printf("Invalid cin_value = %d\n", cin_value);
+ return;
+ }
+ if (argc < 4) {
+ printf("\n Enter cout_value : ");
+ scanf("%d", &cout_value);
+ } else
+ cout_value = GetUInt(&argv[3], 0);
+ if (cout_value < 0 || cout_value > 128) {
+ printf("Invalid cout_value = %d\n", cout_value);
+ return;
+ }
+ if (cout_value & 0x01) cin_value += 0x80;
+ sprintf(tempStr, "0x%02x", cin_value);
+ if (write_otpRaw(dev_id, 4, 1, (UCHAR *)tempStr)) {
+ printf("CapTune Error\n");
+ return;
+ }
+ sprintf(tempStr, "0x%02x", cout_value >> 1);
+ if (write_otpRaw(dev_id, 5, 1, (UCHAR *)tempStr)) {
+ printf("CapTune Error\n");
+ return;
+ }
+ sprintf(tempStr, "0x40");
+ if (write_otpRaw(dev_id, 5, 1, (UCHAR *)tempStr)) {
+ printf("CapTune Error\n");
+ return;
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "pwridx")) {
+ char tempStr[8];
+ sprintf(tempStr, "0x02");
+ if (write_otpRaw(dev_id, 21, 1, (UCHAR *)tempStr)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "hid")) {
+ char tempStr[8];
+ UINT32 value = 0;
+ if (argc < 3 || !*argv[2]) {
+ printf("\n Enter HID value(0|1) : ");
+ scanf("%d", &value);
+ } else
+ value = GetUInt(&argv[2], 0);
+ if (value != 0 && value != 1) {
+ printf("\n Error: Syntax \"otp hid 0x00|0x01\"\n");
+ return;
+ }
+ sprintf(tempStr, "0x%02x", value);
+ if (write_otpRaw(dev_id, 12, 1, (UCHAR *)tempStr)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "wpid")) {
+ UINT32 offset = 134;
+ size_t len = 0;
+ char pid[8] = {0};
+ char *ofs = NULL;
+ printf("\n Enter OTP_PID_OFFSET(default 134) : ");
+ getline(&ofs, &len, stdin);
+ sscanf(ofs, "%d", &offset);
+ if (ofs) free(ofs);
+ memset(pid, 0, sizeof(pid));
+ if (argc < 3 || !*argv[2]) {
+ printf("\n Enter PID : ");
+ fgets((char *)pid, 7, stdin);
+ } else
+ strncpy((char *)pid, argv[2], 7);
+ len = strlen(pid) - 1;
+ if (pid[len] == '\n' || pid[len] == '\r')
+ pid[len] = 0;
+ ReverseHexString(pid);
+ if (write_otpRaw(dev_id, offset, 4, (UCHAR *)pid)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "rpid")) {
+ UINT32 offset = 134;
+ size_t len = 0;
+ UCHAR Data[2];
+ char *ofs = NULL;
+ printf("\n Enter OTP_PID_OFFSET(default 134) : ");
+ getline(&ofs, &len, stdin);
+ sscanf(ofs, "%d", &offset);
+ if (ofs) free(ofs);
+ if (read_otpRaw(dev_id, offset, 2, Data)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("The OTP PID is 0x%02x%02x\n", Data[1], Data[0]);
+ } else if (!strcmp(argv[1], "wvid")) {
+ UINT32 offset = 136;
+ size_t len = 0;
+ char vid[8] = {0};
+ char *ofs = NULL;
+ printf("\n Enter OTP_VID_OFFSET(default 136) : ");
+ getline(&ofs, &len, stdin);
+ sscanf(ofs, "%d", &offset);
+ if (ofs) free(ofs);
+ memset(vid, 0, sizeof(vid));
+ if (argc < 3 || !*argv[2]) {
+ printf("\n Enter VID : ");
+ fgets(vid, 8, stdin);
+ } else
+ strncpy(vid, argv[2], 7);
+ len = strlen(vid) - 1;
+ if (vid[len] == '\n' || vid[len] == '\r')
+ vid[len] = 0;
+ ReverseHexString(vid);
+ if (write_otpRaw(dev_id, offset, 2, (UCHAR *)vid)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "rvid")) {
+ UINT32 offset = 136;
+ size_t len = 0;
+ char *ofs = NULL;
+ UCHAR Data[2];
+ printf("\n Enter OTP_VID_OFFSET(default 136) : ");
+ getline(&ofs, &len, stdin);
+ sscanf(ofs, "%d", &offset);
+ if (ofs) free(ofs);
+ if (read_otpRaw(dev_id, offset, 2, Data)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("The OTP VID is 0x%02x%02x\n", Data[1], Data[0]);
+ } else if (!strcmp(argv[1], "wba")) {
+ UINT32 offset = 128;
+ size_t len = 0;
+ char bdaddr[16] = {0};
+ char *ofs = NULL;
+ printf("\n Enter OTP_BDA_OFFSET(default 128) : ");
+ getline(&ofs, &len, stdin);
+ sscanf(ofs, "%d", &offset);
+ if (ofs) free(ofs);
+ memset(bdaddr, 0, sizeof(bdaddr));
+ if (argc < 3 || !*argv[2]) {
+ printf("\n Enter BDADDR : ");
+ fgets(bdaddr, 16, stdin);
+ } else
+ strncpy(bdaddr, argv[2], 15);
+ len = strlen(bdaddr) - 1;
+ if (bdaddr[len] == '\n' || bdaddr[len] == '\r')
+ bdaddr[len] = 0;
+ ReverseHexString(bdaddr);
+ if (write_otpRaw(dev_id, offset, 6, (UCHAR *)bdaddr)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("Done\n");
+ } else if (!strcmp(argv[1], "rba")) {
+ UINT32 offset = 128;
+ size_t len = 0;
+ char *ofs = NULL;
+ UCHAR Data[6];
+ printf("\n Enter OTP_BDA_OFFSET(default 128) : ");
+ getline(&ofs, &len, stdin);
+ sscanf(ofs, "%d", &offset);
+ if (ofs) free(ofs);
+ if (read_otpRaw(dev_id, offset, 6, Data)) {
+ printf("Failed\n");
+ return;
+ }
+ printf("The OTP BDADDR is 0x%02x%02x%02x%02x%02x%02x\n",
+ Data[5], Data[4], Data[3], Data[2], Data[1], Data[0]);
+ }
+}
+
+static const char *plb_help =
+ "\nUsage:"
+ "\nplb [1|0]\n"
+ "\nplb 1\n"
+ "\n\n";
+
+static void cmd_plb(int dev_id, int argc, char **argv)
+{
+ int dd, enable, iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ if (argc < 2)
+ enable = 1;
+ else
+ enable = GetUInt(&argv[1], 1);
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(buf, 0, HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x09; /* audio commmand opcode */
+ buf[4] = (enable == 0) ? 0x00 : 0x01; /* audio command param */
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_AUDIO_CMD, 8, buf);
+ if (buf[6] != 0) {
+ printf("\nError in setting PCM CODEC loopback :0x%X\n", buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ printf("\nPCM CODEC loopback is %s\n", (enable == 0) ? "OFF" : "ON");
+ hci_close_dev(dd);
+}
+
+static const char *psw_help =
+ "\nUsage:"
+ "\npsw [1|0] [Frequency]\n"
+ "\npsw 1 3000\n"
+ "\n\n";
+
+static void cmd_psw(int dev_id, int argc, char **argv)
+{
+ int dd, enable, freq, iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ if (argc < 2) {
+ enable = 1;
+ freq = 440;
+ }
+ else if (argc < 3) {
+ printf("aa\n");
+ enable = GetUInt(&argv[1], 1);
+ freq = 440;
+ } else {
+ enable = GetUInt(&argv[1], 1);
+ freq = GetUInt(&argv[2], 440);
+ }
+ if (freq > 3700) {
+ printf("Invalid frequency. It should be in the range of 0 to 3700\n");
+ return;
+ }
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ memset(buf, 0, HCI_MAX_EVENT_SIZE);
+ buf[0] = 0x0a; /* audio command opcode */
+ buf[4] = (enable == 0) ? 0x00 : 0x01; /* audio command param */
+ buf[5] = 0x00;
+ buf[6] = freq & 0xff;
+ buf[7] = (freq >> 8) & 0xff;
+
+ iRet = writeHciCommand(dd, OGF_VENDOR_CMD, OCF_AUDIO_CMD, 8, buf);
+ if (buf[6] != 0) {
+ printf("\nError in running PCM sine wave playback :0x%X\n", buf[6]);
+ hci_close_dev(dd);
+ return;
+ }
+ printf("PCM CODEC PCM sine wave playback is %s\n", (enable == 0) ? "OFF" : "ON");
+ hci_close_dev(dd);
+}
+
+static const char *lert_help=
+ "\nUsage:"
+ "\nlert <rx_channel>\n"
+ "\nlert 30 \n"
+ "\n\n";
+
+static void cmd_lert(int dev_id, int argc, char **argv)
+{
+ int dd;
+ UCHAR channel;
+ if (argc < 2) {
+ printf("\n%s\n", lert_help);
+ return;
+ }
+ channel = (UCHAR)GetUInt(&argv[1], 0);
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ SU_LERxTest(dd, channel);
+ hci_close_dev(dd);
+}
+
+static BOOL SU_LERxTest(int dd, UCHAR channel)
+{
+ int iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if (channel < MB_MIN_FREQUENCY_LE || channel > MB_MAX_FREQUENCY_LE) {
+ printf("Invalid rx channel. It should be in the range of %d to %d\n",
+ MB_MIN_FREQUENCY_LE, MB_MAX_FREQUENCY_LE);
+ return FALSE;
+ }
+
+ memset(buf, 0, HCI_MAX_EVENT_SIZE);
+ buf[0] = channel; /* rx_channel */
+ iRet = writeHciCommand(dd, OGF_LE_CTL, OCF_LE_RECEIVER_TEST, 1, buf);
+ if (buf[6] != 0) {
+ printf("\nError in putting the device into LE RX mode\n");
+ return FALSE;
+ }
+ return TRUE;
+}
+
+static const char *lett_help=
+ "\nUsage:"
+ "\nlett <rx_channel> <length> <packet_payload>\n"
+ "\nlett 30 30 5\n"
+ "\n\n";
+
+static void cmd_lett(int dev_id, int argc, char **argv)
+{
+ int dd;
+ UCHAR channel, length, payload;
+ if (argc < 4) {
+ printf("\n%s\n", lett_help);
+ return;
+ }
+ channel = (UCHAR)GetUInt(&argv[1], 0);
+ length = (UCHAR)GetUInt(&argv[2], 0);
+ payload = (UCHAR)GetUInt(&argv[3], 0);
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ SU_LETxTest(dd, channel, length, payload);
+ hci_close_dev(dd);
+}
+
+static BOOL SU_LETxTest(int dd, UCHAR channel, UCHAR length, UCHAR payload)
+{
+ int iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if (channel < MB_MIN_FREQUENCY_LE || channel > MB_MAX_FREQUENCY_LE) {
+ printf("Invalid tx channel. It should be in the range of %d to %d\n",
+ MB_MIN_FREQUENCY_LE, MB_MAX_FREQUENCY_LE);
+ return FALSE;
+ }
+ if (length < MB_MIN_DATALEN_LE || length > MB_MAX_DATALEN_LE) {
+ printf("Invalid data length. It should be in the range of %d to %d\n",
+ MB_MIN_DATALEN_LE, MB_MAX_DATALEN_LE);
+ return FALSE;
+ }
+ if (payload > 7) {
+ printf("Invalid packet payload. It should be in the range of 0 to 7\n");
+ return FALSE;
+ }
+
+ memset(buf, 0, HCI_MAX_EVENT_SIZE);
+ buf[0] = channel; /* tx_channel */
+ buf[1] = length; /* length of test data */
+ buf[2] = payload; /* packet payload */
+ iRet = writeHciCommand(dd, OGF_LE_CTL, OCF_LE_TRANSMITTER_TEST, 3, buf);
+ if (buf[6] != 0) {
+ printf("\nError in putting the device into LE TX mode\n");
+ return FALSE;
+ }
+ return TRUE;
+}
+
+static const char *lete_help =
+ "\nUsage:"
+ "\nlete\n"
+ "\n\n";
+
+static void cmd_lete(int dev_id, int argc, char **argv)
+{
+ int dd, iRet;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ memset(buf, 0, HCI_MAX_EVENT_SIZE);
+ iRet = writeHciCommand(dd, OGF_LE_CTL, OCF_LE_TEST_END, 0, buf);
+ if (buf[6] != 0) {
+ printf("\nError in ending LE test\n");
+ hci_close_dev(dd);
+ return;
+ }
+ printf("Number of packets = %d\n", buf[7] | (buf[8] << 8));
+ hci_close_dev(dd);
+}
+
+static const char *tputs_help =
+ "\nUsage:"
+ "\ntput-s [BD_Addr] [Judgment value] Logfile times"
+ "\ntput-s 11:22:33:44:55:66 150 log.txt 10"
+ "\n\n";
+
+static void CalculateTput(int dd, UINT16 hci_handle, char *filename, double threshold, int tx_size)
+{
+ time_t start, finish, checkbreak;
+ UCHAR buf[1009];
+ FILE *fp = NULL;
+ int aclnum = 8;
+ int retval;
+ unsigned long sentnum = 0;
+ double TimeResult = 0;
+ fd_set rfds;
+ struct hci_filter flt;
+ struct timeval tv1, tv2, timeout;
+ unsigned long long start_utime, end_utime, time_diff;
+ unsigned long long throughput;
+
+ hci_filter_clear(&flt);
+ hci_filter_set_ptype(HCI_EVENT_PKT, &flt);
+ hci_filter_set_event(EVT_NUM_COMP_PKTS, &flt);
+ if (setsockopt(dd, SOL_HCI, HCI_FILTER, &flt, sizeof(flt)) < 0) {
+ perror("HCI filter setup failed");
+ exit(EXIT_FAILURE);
+ }
+ start = time(NULL);
+ gettimeofday(&tv1, NULL);
+ start_utime = tv1.tv_sec*1000000 + tv1.tv_usec;
+ while (sentnum < 1024 * tx_size) {
+ while (aclnum > 0) {
+ aclnum--;
+ buf[0] = HCI_ACLDATA_PKT;
+ /* ACL packet header */
+ buf[1] = hci_handle & 0xFF;
+ buf[2] = ((hci_handle >> 8) & 0x0E);
+ buf[3] = 1004 & 0xff;
+ buf[4] = (1004 >> 8) & 0xff;
+ /* L2CAP packet header */
+ buf[5] = 1000 & 0xff;
+ buf[6] = (1000 >> 8) & 0xff;
+ buf[7] = 0x40 & 0xff;
+ buf[8] = 0;
+
+ memset(buf+9, sentnum++, 1000);
+ while (write(dd, (const void *)buf, 1009) < 0) {
+ if (errno == EAGAIN || errno == EINTR)
+ continue;
+ perror("HCI send packet failed");
+ exit(EXIT_FAILURE);
+ }
+ }
+ timeout.tv_sec = 5;
+ timeout.tv_usec = 0;
+
+ FD_ZERO(&rfds);
+ FD_SET(dd, &rfds);
+ retval = select(dd+1, &rfds, NULL, NULL, &timeout);
+ if (retval == -1) {
+ perror("select()");
+ exit(EXIT_FAILURE);
+ } else if (retval) {
+ /* Data is available now */
+ ssize_t plen;
+ UCHAR buffer[64];
+ int i;
+ plen = read(dd, buffer, 64);
+ if (plen < 0) {
+ perror("HCI read buffer failed");
+ exit(EXIT_FAILURE);
+ }
+ for (i = 0; i < buffer[HCI_EVENT_HEADER_SIZE]; i++)
+ aclnum += (buffer[HCI_EVENT_HEADER_SIZE+(i+1)*2+1] | (buffer[HCI_EVENT_HEADER_SIZE+(i+1)*2+2] << 8));
+ }
+ checkbreak = time(NULL);
+ if ((checkbreak - start) >= 300) break;
+ }
+ finish = time(NULL);
+ gettimeofday(&tv2, NULL);
+ end_utime = tv2.tv_sec*1000000 + tv2.tv_usec;
+ time_diff = end_utime - start_utime;
+ throughput = time_diff/1000;
+ throughput = (sentnum * 1000)/throughput;
+ printf("Transfer Completed! throughput [%0d KB/s]", (int)throughput);
+ printf(" result [%s]\n", threshold > throughput ? " Fail " : " Pass ");
+ if (filename && *filename)
+ fp = fopen(filename, "at+");
+ if (fp) {
+ fprintf(fp, "Transfer Completed! throughput [%.0f KB/s]", TimeResult);
+ fprintf(fp, " result [%s]\n", threshold > TimeResult ? " Fail " : " Pass ");
+ fclose(fp);
+ }
+}
+
+static void cmd_tputs(int dev_id, int argc, char **argv)
+{
+ int j, dd, iRet, loop = 1, tx_test_size = 1;
+ UINT16 Ps_EntrySize = 0;
+ UINT16 hci_handle = 0;
+ double threshold = 0.0;
+ char *filename = NULL;
+ struct sigaction sa;
+ FILE *fp = NULL;
+ bdaddr_t bdaddr;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ UCHAR Ps_Data[HCI_MAX_EVENT_SIZE];
+ UINT16 *pPs_Data;
+ BOOL Ok = FALSE;
+ char timeString[9] = {0};
+ char dateString[15] = {0};
+ time_t current_time;
+ struct tm *time_info;
+ tSU_RevInfo RevInfo;
+
+ if (argc < 3) {
+ printf("\n%s\n", tputs_help);
+ return;
+ }
+
+ if (str2ba(argv[1],&bdaddr)) {
+ printf("\nPlease input valid bdaddr.\n");
+ return;
+ }
+ threshold = atof(argv[2]);
+ if (!threshold) {
+ printf("\nPlease input valid throughput threshold.\n");
+ return;
+ }
+ if (argc > 3)
+ filename = strdup(argv[3]);
+ if (argc > 4)
+ loop = GetUInt(&argv[4], 1);
+ if (argc > 5)
+ tx_test_size = GetUInt(&argv[5],1);
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ CtrlCBreak = FALSE;
+ memset(&sa, 0, sizeof(sa));
+ sa.sa_handler = sig_term;
+ sigaction(SIGTERM, &sa, NULL);
+ sigaction(SIGINT, &sa, NULL);
+ PSInit(dd);
+ memset(buf, 0, sizeof(buf));
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_RESET, 0, buf);
+ if (buf[6] != 0) {
+ printf("Error: HCI RESET failed.\n");
+ hci_close_dev(dd);
+ return;
+ }
+ sleep(1);
+ for (j = 0; j < loop; j++) {
+ int i = 0;
+ if (!j) sleep(1);
+ printf("\n-----------------------------------");
+ printf("\nTimes %d/%d\n", j + 1, loop);
+
+ time(¤t_time);
+ time_info = localtime(¤t_time);
+ strftime(timeString, sizeof(timeString), "%H %M %S", time_info);
+ strftime(dateString, sizeof(dateString), "%b %d %Y", time_info);
+ if (j == 0) {
+ if (filename && *filename)
+ fp = fopen(filename, "at+");
+ if (fp != NULL)
+ fprintf(fp, "\n[%s %s] \nCMD : TPUT-S %s %f %s %d\n",
+ dateString, timeString, argv[1], threshold, filename, loop);
+ /* SFLAGS FW */
+ Ok = PSOperations(dd, PS_GET_LENGTH, PSTAG_RF_TEST_BLOCK_START, (UINT32 *)&Ps_EntrySize);
+ if (Ok) {
+ Ps_Data[0] = Ps_EntrySize & 0xff;
+ Ps_Data[1] = (Ps_EntrySize >> 8) & 0xff;
+ Ok = PSOperations(dd, PS_READ, PSTAG_RF_TEST_BLOCK_START, (UINT32 *)&Ps_Data);
+ if (Ok) {
+ pPs_Data = (UINT16 *)&Ps_Data[0];
+ if (*pPs_Data == BT_SOC_INIT_TOOL_START_MAGIC_WORD) {
+ RevInfo.RadioFormat = *(pPs_Data + 1);
+ RevInfo.RadioContent = *(pPs_Data + 2);
+ }
+ }
+ }
+
+ /* Get syscfg info */
+ Ok = PSOperations(dd, PS_GET_LENGTH, PSTAG_SYSCFG_PARAM_TABLE0, (UINT32 *)&Ps_EntrySize);
+ if (Ok) {
+ Ps_Data[0] = Ps_EntrySize & 0xff;
+ Ps_Data[1] = (Ps_EntrySize >> 8) & 0xff;
+ Ok = PSOperations(dd, PS_READ, PSTAG_SYSCFG_PARAM_TABLE0, (UINT32 *)&Ps_Data);
+ if (Ok) {
+ pPs_Data = (UINT16 *)&Ps_Data[0];
+ if (*pPs_Data == 0xC1C1) {
+ RevInfo.SysCfgFormat = *(pPs_Data + 1);
+ RevInfo.SysCfgContent = *(pPs_Data + 2);
+ }
+
+ }
+ }
+
+ if (RevInfo.SysCfgFormat != 0xff) {
+ printf("SysCfg - Format: %d.%d\n",((RevInfo.SysCfgFormat >> 4) & 0xfff), (RevInfo.SysCfgFormat & 0xf));
+ printf(" Content: %d\n", RevInfo.SysCfgContent);
+ if (fp) {
+ fprintf(fp, "SysCfg - Format: %d.%d\n",((RevInfo.SysCfgFormat >> 4) & 0xfff),
+ (RevInfo.SysCfgFormat & 0xf));
+ fprintf(fp, " Content: %d\n", RevInfo.SysCfgContent);
+ }
+ } else {
+ printf("SysCfg - N/A\n");
+ if(fp)
+ fprintf(fp, "SysCfg - N/A\n");
+ }
+
+ /* bd addr */
+ memset(&buf, 0, sizeof(buf));
+ iRet = writeHciCommand(dd, OGF_INFO_PARAM, OCF_READ_BD_ADDR, 0, buf);
+ if (buf[6] != 0) {
+ printf("\nCould not read the BD_ADDR (time out)\n");
+ } else {
+ char temp[16] = {0};
+ memset(temp, 0, sizeof(temp));
+ sprintf(temp, "%02X%02X%02X%02X%02X%02X", buf[iRet-1], buf[iRet-2],
+ buf[iRet-3], buf[iRet-4], buf[iRet-5], buf[iRet-6]);
+ printf("\nLocal BDAddress : 0x%s\n", temp);
+ if (fp)
+ fprintf(fp, "Local BDAddress : 0x%s\n", temp);
+ }
+
+ if (fp) {
+ fclose(fp);
+ fp = NULL;
+ }
+ }
+ printf("Sending packages to 0x%s\n", argv[1]);
+ while (i++ < 3) {
+ iRet = hci_create_connection(dd, &bdaddr, 0xCC18, 0, 0, &hci_handle, 0);
+ if (!iRet || CtrlCBreak) break;
+ }
+
+ if (iRet) {
+ if (filename && *filename) {
+ fp = fopen(filename, "at+");
+ if (fp) {
+ fprintf(fp, "Transfer Failed! \n");
+ fclose(fp);
+ fp = NULL;
+ }
+ }
+ printf("Transfer Failed! \n");
+ CtrlCBreak = TRUE;
+ hci_close_dev(dd);
+ return;
+ }
+ CalculateTput(dd, hci_handle, filename, threshold, tx_test_size);
+
+ hci_disconnect(dd, hci_handle, 0, 30);
+
+ if (CtrlCBreak) break;
+ }
+ CtrlCBreak = TRUE;
+ hci_close_dev(dd);
+}
+
+static void cmd_tputr(int dev_id, int argc, char **argv)
+{
+ int dd, iRet;
+ ssize_t plen;
+ UINT16 hci_handle = 0;
+ UCHAR buf[HCI_MAX_EVENT_SIZE];
+ struct hci_filter flt;
+ struct sigaction sa;
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+ CtrlCBreak = FALSE;
+ memset(&sa, 0, sizeof(sa));
+ sa.sa_handler = sig_term;
+ sigaction(SIGTERM, &sa, NULL);
+ sigaction(SIGINT, &sa, NULL);
+ memset(buf, 0, sizeof(buf));
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_RESET, 0, buf);
+ if (buf[6] != 0) {
+ printf("Error: HCI RESET failed.\n");
+ hci_close_dev(dd);
+ return;
+ }
+ sleep(1);
+ memset(buf, 0, sizeof(buf));
+ buf[0] = 0x02;
+ iRet = writeHciCommand(dd, OGF_HOST_CTL, OCF_WRITE_SCAN_ENABLE, 1, buf);
+ if (buf[6] != 0) {
+ printf("Error: Write scan failed\n");
+ return;
+ }
+ hci_filter_clear(&flt);
+ hci_filter_set_ptype(HCI_EVENT_PKT, &flt);
+ hci_filter_all_events(&flt);
+ if (setsockopt(dd, SOL_HCI, HCI_FILTER, &flt, sizeof(flt)) < 0) {
+ perror("HCI filter setup failed");
+ exit(EXIT_FAILURE);
+ }
+ printf("Start listening ...\n");
+ do {
+ plen = read(dd, buf, HCI_MAX_EVENT_SIZE);
+ if (plen < 0) {
+ printf("reading failed...\n");
+ if (errno == EAGAIN || errno == EINTR) continue;
+ else {
+ perror("HCI read failed");
+ exit(EXIT_FAILURE);
+ }
+ }
+ if (buf[1] == EVT_CONN_REQUEST) {
+ int i, j;
+ ssize_t plen = 0;
+ printf("Connection come in\n");
+ for (i = 0, j = 3; i < BD_ADDR_SIZE; i++, j++)
+ buf[i] = buf[j];
+ buf[BD_ADDR_SIZE] = 0x01;
+ if (hci_send_cmd(dd, OGF_LINK_CTL, OCF_ACCEPT_CONN_REQ, 7, buf)) {
+ printf("Accept connection error\n");
+ return;
+ }
+ do {
+ plen = read(dd, buf, HCI_MAX_EVENT_SIZE);
+ if (plen < 0) {
+ perror("Read failed");
+ exit(EXIT_FAILURE);
+ }
+ } while (buf[1] != EVT_CONN_COMPLETE);
+ if (buf[3] == 0) {
+ printf("Connection up\n");
+ } else {
+ printf("Connection failed\n");
+ }
+ hci_handle = (buf[4] | (buf[5] << 8)) & 0x0EFF;
+ } else if (buf[1] == EVT_DISCONN_COMPLETE) {
+ UINT16 hdl = buf[4] | (buf[5] << 8);
+ printf("Disconnect...\n");
+ if (hdl == hci_handle) {
+ break;
+ }
+ } else if (CtrlCBreak) {
+ printf("CtrlBreak...\n");
+ break;
+ }
+ } while (plen >= 0);
+ CtrlCBreak = TRUE;
+ hci_close_dev(dd);
+}
+
+static void cleanup()
+{
+ if (cid>=0) {
+ close(cid);
+ }
+ if (sid>=0) {
+ close(sid);
+ }
+}
+
+int sock_recv(int sockid, unsigned char *buf, int buflen)
+{
+ int recvbytes;
+ recvbytes = recv(sockid, buf, buflen, 0);
+ if (recvbytes == 0) {
+ printf("Connection close!? zero bytes received\n");
+ return -1;
+ } else if (recvbytes > 0) {
+ return recvbytes;
+ }
+ return -1;
+}
+
+int sock_send(int sockid, unsigned char *buf, int bytes)
+{
+ int cnt;
+ unsigned char* bufpos = buf;
+ while (bytes) {
+ cnt = write(sockid, bufpos, bytes);
+ if (cnt != bytes)
+ printf("cnt:%d,bytes:%d\n",cnt, bytes);
+
+ if (!cnt) {
+ break;
+ }
+ if (cnt == -1) {
+ if (errno == EINTR) {
+ continue;
+ } else {
+ return -1;
+ }
+ }
+
+ bytes -= cnt;
+ bufpos += cnt;
+ }
+ return (bufpos - buf);
+}
+
+static void cmd_btagent(int dev_id, int argc, char **argv)
+{
+ int dd, i, j, k, l, iRet, need_raw, rx_enable, iDataSize;
+ uint32_t m_BerTotalBits, m_BerGoodBits;
+ uint8_t m_pattern[16];
+ uint16_t m_pPatternlength;
+ int port = BT_PORT;
+ struct sigaction sa;
+ unsigned char buf[1024];
+ struct hci_filter flt;
+ struct hci_dev_info di;
+ struct timeval timeout;
+
+/* master file descriptor list */
+ fd_set master;
+ fd_set read_fds;
+
+/* server address */
+ struct sockaddr_in serveraddr;
+
+ int fdmax;
+
+/* listening socket descriptor */
+ int listener = -1;
+
+/* newly accept()ed socket descriptor */
+ int newfd = -1;
+
+ int nbytes;
+
+/* for setsockopt() SO_REUSEADDR, below */
+ int yes = 1;
+
+ int addrlen;
+
+ if (argc > 1)
+ port = atoi(argv[1]);
+ if (port == 0)
+ port = BT_PORT;
+ else if (port < 0 || port >65534) {
+ perror("\nERROR: Invalid port number\n");
+ return;
+ }
+
+ if (dev_id < 0)
+ dev_id = hci_get_route(NULL);
+ dd = hci_open_dev(dev_id);
+ if (dd < 0) {
+ perror("\nERROR: Can not open HCI device\n");
+ return;
+ }
+
+ if (hci_devinfo(dev_id, &di) < 0) {
+ perror("Can't get device info\n");
+ hci_close_dev(dd);
+ return;
+ }
+
+ need_raw = !hci_test_bit(HCI_RAW, &di.flags);
+
+ hci_filter_clear(&flt);
+ hci_filter_all_ptypes(&flt);
+ hci_filter_all_events(&flt);
+
+ if (setsockopt(dd, SOL_HCI, HCI_FILTER, &flt, sizeof(flt)) < 0) {
+ perror("Can't set filter for hci\n");
+ hci_close_dev(dd);
+ return;
+ }
+
+ if (need_raw) {
+ if (ioctl(dd, HCISETRAW, 1) < 0) {
+ perror("Can't set raw mode on hci\n");
+ hci_close_dev(dd);
+ return;
+ }
+ }
+
+ CtrlCBreak = FALSE;
+ memset(&sa, 0, sizeof(sa));
+ sa.sa_handler = sig_term;
+ sigaction(SIGTERM, &sa, NULL);
+ sigaction(SIGINT, &sa, NULL);
+
+ /* clear the master and temp sets */
+ FD_ZERO(&master);
+ FD_ZERO(&read_fds);
+
+ /* get the listener */
+ if((listener = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP)) == -1) {
+ perror("Server-socket() error lol!");
+ return;
+ }
+
+ if(setsockopt(listener, SOL_SOCKET, SO_REUSEADDR, (char *)&yes, sizeof(int)) == -1) {
+ perror("Server-setsockopt() error lol!");
+ close(listener);
+ return;
+ }
+
+ if(setsockopt(listener, IPPROTO_TCP, TCP_NODELAY, (char *)&yes, sizeof(int)) == -1) {
+ perror("Server-setsockopt() error TCP_NODELAY\n");
+ close(listener);
+ return;
+ }
+
+ /* bind */
+ serveraddr.sin_family = AF_INET;
+ serveraddr.sin_addr.s_addr = htonl(INADDR_ANY);
+ serveraddr.sin_port = htons(port);
+ memset(&(serveraddr.sin_zero), 0, 8);
+
+ if(bind(listener, (struct sockaddr *)&serveraddr, sizeof(serveraddr)) == -1) {
+ perror("Server-bind() error lol!");
+ close(listener);
+ return;
+ }
+
+ /* listen */
+ if(listen(listener, 10) == -1) {
+ perror("Server-listen() error lol!");
+ close(listener);
+ return;
+ }
+
+ /* add the listener to the master set */
+ FD_SET(listener, &master);
+
+ /* add hci handler to the master set */
+ FD_SET(dd, &master);
+
+ FD_SET(0, &master);
+ /* keep track of the biggest file descriptor */
+ fdmax = listener;
+ if (dd > listener) fdmax = dd;
+
+ printf("Start BtAgent, press 'q' to exit.\n");
+
+ rx_enable = 0;
+ m_BerGoodBits = 0;
+ m_BerTotalBits = 0;
+ m_pattern[0] = 0x0f;
+ m_pPatternlength = 1;
+
+ while (1) {
+ read_fds = master;
+ timeout.tv_sec = 5;
+ timeout.tv_usec = 0;
+ iRet = select(fdmax+1, &read_fds, NULL, NULL, &timeout);
+ if (iRet == -1) {
+ perror("Server-select() error lol!");
+ if (newfd > 0) close(newfd);
+ close(listener);
+ goto exits;
+ }
+ if (CtrlCBreak) break;
+ if (iRet == 0) continue;
+
+ /*run through the existing connections looking for data to be read*/
+ for(i = 0; i <= fdmax; i++) {
+ if(FD_ISSET(i, &read_fds)) {
+
+ if(i == 0) {
+ printf("Shutting down btagent\n");
+ iRet = getchar();
+ if (iRet == 'q') goto exits;
+ continue;
+ }
+
+ if(i == listener) {
+ /* handle new connections */
+ addrlen = sizeof(struct sockaddr_in);
+ if((newfd = accept(listener, (struct sockaddr *)&serveraddr, &addrlen)) == -1) {
+ perror("Server-accept() error lol!");
+ goto exits;
+ }
+ else {
+ printf("Server-accept() is OK...%d\n",newfd);
+ FD_SET(newfd, &master); /* add to master set */
+ if(newfd > fdmax)
+ fdmax = newfd;
+ }
+ }
+ else if (i == newfd) {
+ /* handle data from a client */
+ if((nbytes = sock_recv(i, buf, sizeof(buf))) < 0) {
+ /* got error or connection closed by client */
+ close(i);
+ /* remove from master set */
+ FD_CLR(i, &master);
+ }
+ else {
+
+ for (j=0; j<nbytes; j++)
+ printf("%x ",buf[j]);
+ printf("\n");
+ if (buf[0] == 0x7) { // BTAGENT_CMD_EVENT
+ if (buf[3] == 0x01) { // BTAGENT_CMD_EVENT_GETBER
+ buf[11] = (m_BerTotalBits & 0xff000000) >> 24;
+ buf[10] = (m_BerTotalBits & 0xff0000) >> 16;
+ buf[9] = (m_BerTotalBits & 0xff00) >> 8;
+ buf[8] = m_BerTotalBits & 0xff;
+ buf[7] = (m_BerGoodBits & 0xff000000) >> 24;
+ buf[6] = (m_BerGoodBits & 0xff0000) >> 16;
+ buf[5] = (m_BerGoodBits & 0xff00) >> 8;
+ buf[4] = m_BerGoodBits & 0xff;
+ buf[3] = 1; // BTAGENT_CMD_EVENT_GETBER
+ buf[2] = 0;
+ buf[1] = 9;
+ buf[0] = 7;
+ sock_send(newfd, buf, 9+3);
+ usleep(2000);
+ }
+ else if (buf[3] == 0x02) { // BTAGENT_CMD_EVENT_PATTERN
+ m_pPatternlength = (uint16_t)(buf[1] | (buf[2] << 8));
+ m_pPatternlength --;
+ if (m_pPatternlength > 16) m_pPatternlength = 16;
+ memcpy(m_pattern,&buf[4],m_pPatternlength);
+ printf("PatternLength:%d,%x\n",m_pPatternlength,buf[4]);
+ }
+ continue;
+ }
+
+ if (rx_enable == 1) {
+ if ((buf[4] == 0x03) && (buf[5] == 0x0c))
+ rx_enable = 0;
+ }
+ write(dd, &buf[3], nbytes - 3);
+ }
+ }
+ else if (i == dd) {
+ nbytes = read(dd, &buf[3], sizeof(buf) - 3);
+ iDataSize = nbytes - 5;
+// printf("nbyte:%d, packet:%d, pattern:%x\n",nbytes, (uint16_t)(buf[6] | (buf[7] << 8)), buf[8]);
+ if (buf[3] == 0x2) { // ACL data
+ if (rx_enable) {
+ m_BerTotalBits = m_BerTotalBits + iDataSize * 8;
+ for(j=0,l=0;j<iDataSize;j++,l++) {
+ if (l == m_pPatternlength) l = 0;
+ for(k=0;k<8;k++){
+ if((m_pattern[l]&(1<<k)) == (buf[8+j]&(1<<k)))
+ m_BerGoodBits++;
+ }
+ }
+ }
+ }
+ else {
+ if ((buf[7] == 0x5b) && (buf[8] == 0xfc)) { // Rx start CMD's event
+ rx_enable = 1;
+ m_BerTotalBits = 0;
+ m_BerGoodBits = 0;
+ }
+ buf[2] = 0;
+ buf[1] = (uint16_t)nbytes;
+ buf[0] = 3;
+ if (newfd > 0) {
+ sock_send(newfd, buf, nbytes+3);
+ usleep(2000);
+ }
+ }
+ }
+ }
+ }
+ }
+exits:
+ if (need_raw) {
+ if (ioctl(dd, HCISETRAW, 0) < 0)
+ perror("Can't clear raw mode \n");
+ }
+
+ hci_close_dev(dd);
+ if (listener > 0) close(listener);
+ if (newfd > 0) close(newfd);
+ printf("Total:%d,Good:%d\n",m_BerTotalBits, m_BerGoodBits);
+}
+
+static void sig_term(int sig)
+{
+ if (CtrlCBreak) return;
+ CtrlCBreak = TRUE;
+}
+
+static struct {
+ char *cmd;
+ char *cmd_option;
+ void (*func)(int dev_id, int argc, char **argv);
+ char *doc;
+} command[] = {
+ { "psreset"," ", cmd_psreset, "Download PS files and Reset Target" },
+ { "reset"," ", cmd_reset, "Reset Target" },
+ { "rba"," ", cmd_rba, "Read BD Address" },
+ { "wba","<bdaddr> ", cmd_wba, "Write BD Address" },
+ { "edutm"," ", cmd_edutm, "Enter DUT Mode" },
+ { "wsm","<mode> ", cmd_wsm, "Write Scan Mode" },
+ { "mb"," ", cmd_mb, "Enter Master Blaster Mode" },
+ { "mbr","<address> <length> ", cmd_mbr, "Block memory read" },
+ { "peek","<address> <width> ", cmd_peek, "Read Value of an Address" },
+ { "poke","<address> <value> <mask> <width> ", cmd_poke, "Write Value to an Address" },
+ { "cwtx","<channel number> ", cmd_cwtx, "Enter Continuous wave Tx" },
+ { "cwrx","<channel number> ", cmd_cwrx, "Enter Continuous wave Rx" },
+ { "rpst","<length> <id> ", cmd_rpst, "Read PS Tag" },
+ { "wpst","<length> <id> <data> ", cmd_wpst, "Write PS Tag" },
+ { "psr"," ", cmd_psr, "PS Reset" },
+ { "setap","<storage medium> <priority>", cmd_setap, "Set Access Priority" },
+ { "setam","<storage medium> <access mode>", cmd_setam, "Set Access Mode" },
+ { "rpsraw","<offset> <length> ", cmd_rpsraw, "Read Raw PS" },
+ { "wpsraw","<offset> <length> <data>", cmd_wpsraw, "Write Raw PS" },
+ { "ssm","<disable|enable> ", cmd_ssm, "Set Sleep Mode" },
+ { "dtx"," ", cmd_dtx, "Disable TX" },
+ { "dump","<option> ", cmd_dump, "Display Host Controller Information" },
+ { "rafh","<connection handle> ", cmd_rafh, "Read AFH channel Map" },
+ { "safh","<channel classification> ", cmd_safh, "Set AFH Host Channel Classification" },
+ { "wotp", "<address> <data> [length=1]", cmd_wotp, "Write Length (default 1) bytes of Data to OTP started at Address" },
+ { "rotp", "<address> [length=1]", cmd_rotp, "Read Length (default 1) bytes of Data to OTP started at Address" },
+ { "otp", "[dump|imp|exp|test|rpid|wpid|rvid|wvid|rba|wba|hid|cpw|pwridx|ledo] [file]; opt wba <BdAddr>",
+ cmd_otp, "Misc OTP operation: dump/import otp content; imp file content into otp; test otp; otp wba <BdAddr>" },
+ { "plb", "[1|0]", cmd_plb, "Enable/disable PCM CODEC loopback" },
+ { "psw", "[1|0] [Frequency]", cmd_psw, "Enable/disable PCM sine wave playback at frequency (0..3700)" },
+ { "lert", "<rx_channel>", cmd_lert, "Put unit in LE RX mode at rx_channel (0..39)" },
+ { "lett", "<tx_channel> <length> <packet_payload>", cmd_lett, "Put unit in LE TX mode at tx_channel (0..39) with packet of given length (0..37) and packet_payload" },
+ { "lete", " ", cmd_lete, "End LE test" },
+ { "tput-s", "[BD_Addr] [Judgment value] Logfile times data_size", cmd_tputs, "Throughput test - sender side" },
+ { "tput-r", " ", cmd_tputr, "Throughput test - receiver side" },
+ { "btagent","<port number>", cmd_btagent, "BT Agent for IQFact" },
+ { NULL, NULL, NULL, NULL }
+};
+/*
+ { "get_id", cmd_gid, "Get Chip Identification Number" },
+*/
+static void usage(void)
+{
+ int i;
+
+ printf("btconfig - BTCONFIG Tool ver %s\n", VERSION);
+ printf("Usage:\n"
+ "\tbtconfig [options] <command> [command parameters]\n");
+ printf("Options:\n"
+ "\t--help\tDisplay help\n"
+ "\t-i dev\tHCI device\n");
+ printf("Commands:\n");
+ for (i = 0; command[i].cmd; i++)
+ printf("\t%-8s %-40s\t%s\n", command[i].cmd,command[i].cmd_option,command[i].doc);
+ printf("\n"
+ "For more information on the usage of each command use:\n"
+ "\tbtconfig <command> --help\n" );
+}
+
+int main(int argc, char *argv[])
+{
+ int opt, i, dev_id = -1;
+ bdaddr_t ba;
+
+ while ((opt=getopt_long(argc, argv, "+i:h", main_options, NULL)) != -1) {
+ switch (opt) {
+ case 'i':
+ dev_id = hci_devid(optarg);
+ if (dev_id < 0) {
+ perror("Invalid device");
+ exit(1);
+ }
+ break;
+
+ case 'h':
+ default:
+ usage();
+ exit(0);
+ }
+ }
+
+ argc -= optind;
+ argv += optind;
+ optind = 0;
+
+ if (argc < 1) {
+ usage();
+ exit(0);
+ }
+
+ if (dev_id != -1 && hci_devba(dev_id, &ba) < 0) {
+ perror("Device is not available");
+ exit(1);
+ }
+
+ for (i = 0; command[i].cmd; i++) {
+ if (strcmp(command[i].cmd, argv[0]))
+ continue;
+ command[i].func(dev_id, argc, argv);
+ break;
+ }
+ return 0;
+}
+
+
+// MAster BLaster fucntions
+tMasterBlasterField MasterBlasterMenu[] =
+{
+ {"ContRxMode", "n", "toggle coNtinuous Rx", 0, ContRxModeOption, SetMasterBlasterContRxMode},
+ {"ContTxMode", "c", "toggle Continuous Tx", 0, ContTxModeOption, SetMasterBlasterContTxMode},
+ {"LERxMode", "q", "toggle LE Rx mode", 0, ContRxModeOption, SetMasterBlasterLERxMode},
+ {"LETxMode", "w", "toggle LE Tx mode", 0, ContTxModeOption, SetMasterBlasterLETxMode},
+ {"LETxPktPayload", "y", "set LE Tx packet payload", 0, LETxPktPayloadOption, SetMasterBlasterLETxPktPayload},
+ {"ContTxType", "u", "toggle continUous Tx Type", Cont_Tx_Raw_1MHz, ContTxTypeOption, SetMasterBlasterContTxType},
+ {"TestMode", "m", "toggle test Mode", eBRM_TestMode_TX_1010, TestModeOption, SetMasterBlasterTestMode},
+ {"HopMode", "h", "toggle Hop mode", 0, HopModeOption, SetMasterBlasterHopMode},
+ {"TxFreq", "t", "set Tx freq", 39, NULL, SetMasterBlasterTxFreq},
+ {"RxFreq", "r", "set Rx freq", 39, NULL, SetMasterBlasterRxFreq},
+ {"PacketType", "p", "toggle Packet type", TxTest_PktType_DH1, PacketTypeOption, SetMasterBlasterPacketType},
+ {"DataLen", "l", "set data Length", 15, NULL, SetMasterBlasterDataLen},
+ {"Power", "o", "toggle pOwer", 9, NULL, SetMasterBlasterPower},
+ {"BdAddr", "a", "set bdAddr", 0, NULL, SetMasterBlasterBdAddr},
+ {"SetBERType", "k", "set BER type", eBRM_BERMode_ALL_DATA, BERPacketTypeOption,SetMasterBlasterBERType},
+ {"GetBER", "g", "get BER type", 0, NULL, SetMasterBlasterNothing},
+ {"EnableRxTest", "d", "Enable rx test mode", 0, NULL, SetMasterBlasterNothing},
+ {"EnableTxTest", "e", "Enable tx test mode", 0, NULL, SetMasterBlasterNothing},
+ {"EnableTest", "j", "Start test mode", 0, NULL, SetMasterBlasterNothing},
+ {"StopTest", "s", "Stop test mode", 0, NULL, SetMasterBlasterNothing},
+ {"Exit", "x", "eXit", 0, NULL, SetMasterBlasterNothing},
+ {"ExitWithoutReset", "b", "Exit without reset", 0, NULL, SetMasterBlasterNothing},
+};
+
+tPsSysCfgTransmitPowerControlTable TpcTable;
+
+//----------------------------------------------------------------------------
+
+void InitMasterBlaster (tBRM_Control_packet *MasterBlaster, bdaddr_t *BdAddr, UCHAR *SkipRxSlot)
+{
+ *SkipRxSlot = 0x01;
+ MasterBlaster->testCtrl.Mode = MasterBlasterMenu[TM].Default;
+ MasterBlaster->testCtrl.HopMode = MasterBlasterMenu[HM].Default;
+ MasterBlaster->testCtrl.Packet = MasterBlasterMenu[PT].Default;
+ MasterBlaster->testCtrl.TxFreq = MasterBlasterMenu[TF].Default;
+ MasterBlaster->testCtrl.RxFreq = MasterBlasterMenu[RF].Default;
+ MasterBlaster->testCtrl.Power = MasterBlasterMenu[PO].Default;
+ MasterBlaster->testCtrl.DataLen = MasterBlasterMenu[DL].Default;
+ MasterBlaster->ContTxMode = MasterBlasterMenu[CT].Default;
+ MasterBlaster->ContTxType = MasterBlasterMenu[CX].Default;
+ MasterBlaster->ContRxMode = MasterBlasterMenu[CR].Default;
+ MasterBlaster->BERType = MasterBlasterMenu[SB].Default;
+ MasterBlaster->LERxMode = MasterBlasterMenu[LR].Default;
+ MasterBlaster->LETxMode = MasterBlasterMenu[LT].Default;
+ MasterBlaster->LETxParms.PktPayload = MasterBlasterMenu[LTM].Default;
+ memcpy(MasterBlaster->bdaddr,&BdAddr->b[0],6);
+
+ TpcTable.NumOfEntries = 0;
+}
+
+//----------------------------------------------------------------------------
+
+int CheckField (tBRM_Control_packet MasterBlaster, char *FieldAlias)
+{
+ if (((!strncmp(FieldAlias,MasterBlasterMenu[HM].Alias,1)) && MasterBlaster.ContTxMode) ||
+ (((!strncmp(FieldAlias,MasterBlasterMenu[TF].Alias,1)) || (!strncmp(FieldAlias,MasterBlasterMenu[RF].Alias,1))) && MasterBlaster.testCtrl.HopMode == 1) ||
+ ((!strncmp(FieldAlias,MasterBlasterMenu[CX].Alias,1)) && MasterBlaster.ContTxMode == 0))
+ {
+ return INVALID_MASTERBLASTER_FIELD;
+ }
+ unsigned int i;
+ for (i = 0; i < sizeof(MasterBlasterMenu)/sizeof(tMasterBlasterField); ++i)
+ {
+ if (!strncmp(FieldAlias,MasterBlasterMenu[i].Alias,1))
+ {
+ return i;
+ }
+ }
+
+ return INVALID_MASTERBLASTER_FIELD;
+}
+
+//----------------------------------------------------------------------------
+
+int GetTestModeOptionIndex (int Value)
+{
+ unsigned int i;
+ for (i = 0; i < sizeof(TestModeOption)/sizeof(tMasterBlasterOption); ++i)
+ {
+ if (Value == TestModeOption[i].Value)
+ {
+ return i;
+ }
+ }
+ // assert (0);
+ return -1;
+}
+
+//----------------------------------------------------------------------------
+
+int GetPacketTypeOptionIndex (int Value)
+{
+ unsigned int i;
+ for (i = 0; i < sizeof(PacketTypeOption)/sizeof(tMasterBlasterOption); ++i)
+ {
+ if (Value == PacketTypeOption[i].Value)
+ {
+ return i;
+ }
+ }
+ //assert (0);
+ return -1;
+}
+
+//----------------------------------------------------------------------------
+
+void PrintMasterBlasterMenu(tBRM_Control_packet *MasterBlaster)
+{
+ unsigned int i;
+ printf ("\n---------- Master Blaster Mode ----------\n\n");
+ for (i = 0; i < sizeof(MasterBlasterMenu)/sizeof(tMasterBlasterField); ++i)
+ {
+ if (((i == HM || i == RF) && (MasterBlaster->ContTxMode == ENABLE)) ||
+ ((i == TF || i == RF) && (MasterBlaster->testCtrl.HopMode == 1)) ||
+ ((i == CX) && (MasterBlaster->ContTxMode == DISABLE)) ||
+ ((i == CX || i == HM || i == TF || i == PT || i == DL || i == PO || i == BA) &&
+ (MasterBlaster->ContRxMode == ENABLE)))
+ {
+ continue;
+ }
+
+ printf ("\t%s - %s\n", MasterBlasterMenu[i].Alias, MasterBlasterMenu[i].Usage);
+ }
+ printf ("\n-----------------------------------------\n\n");
+
+ char BdAddr[18];
+ //strcpy(MasterBlaster.bdaddr,BdAddr);
+
+ printf ("ContRxMode: %s\n", ContRxModeOption[MasterBlaster->ContRxMode].Name);
+ printf ("ContTxMode: %s\n", ContTxModeOption[MasterBlaster->ContTxMode].Name);
+ printf ("LERxMode: %s\n", ContTxModeOption[MasterBlaster->LERxMode].Name);
+ printf ("LETxMode: %s\n", ContTxModeOption[MasterBlaster->LETxMode].Name);
+
+ // LE Rx mode
+ if (MasterBlaster->LERxMode == ENABLE)
+ {
+ if (MasterBlaster->testCtrl.RxFreq > MB_MAX_FREQUENCY_LE)
+ MasterBlaster->testCtrl.RxFreq = MB_MAX_FREQUENCY_LE;
+ printf("RxFreq: %d\n", MasterBlaster->testCtrl.RxFreq);
+ }
+ // LE Tx mode
+ if (MasterBlaster->LETxMode == ENABLE)
+ {
+ if (MasterBlaster->testCtrl.DataLen > MB_MAX_DATALEN_LE)
+ MasterBlaster->testCtrl.DataLen = MB_MAX_DATALEN_LE;
+ printf("TxFreq: %d\n", MasterBlaster->testCtrl.TxFreq);
+ printf("DataLen: %d\n", MasterBlaster->testCtrl.DataLen);
+ printf("PktPayload: %s\n", LETxPktPayloadOption[MasterBlaster->LETxParms.PktPayload].Name);
+ }
+ // Continous Rx mode
+ else if (MasterBlaster->ContRxMode == ENABLE)
+ {
+ printf ("BER Type: %s\n",BERPacketTypeOption[MasterBlaster->BERType].Name);
+ printf ("RxFreq: %d\n", MasterBlaster->testCtrl.RxFreq);
+ }
+ // Continous Tx mode and Tx test mode
+ else
+ {
+ printf ("BER Type: %s\n",BERPacketTypeOption[MasterBlaster->BERType].Name);
+ if (MasterBlaster->ContTxMode == ENABLE)
+ {
+ printf ("ContTxType: %s\n", ContTxTypeOption[MasterBlaster->ContTxType].Name);
+ if (ContTxTypeOption[MasterBlaster->ContTxType].Value != CW_Single_Tone)
+ printf ("TestMode: %s\n", TestModeOption[GetTestModeOptionIndex(MasterBlaster->testCtrl.Mode)].Name);
+ printf ("TxFreq: %d\n", MasterBlaster->testCtrl.TxFreq);
+ }
+ else
+ {
+ printf ("TestMode: %s\n", TestModeOption[GetTestModeOptionIndex(MasterBlaster->testCtrl.Mode)].Name);
+ printf ("HopMode: %s\n", HopModeOption[MasterBlaster->testCtrl.HopMode].Name);
+
+ if (MasterBlaster->testCtrl.HopMode == 0)
+ {
+ printf ("TxFreq: %d\n", MasterBlaster->testCtrl.TxFreq);
+ printf ("RxFreq: %d\n", MasterBlaster->testCtrl.RxFreq);
+ }
+ }
+ if (TpcTable.NumOfEntries > 0)
+ {
+ printf ("Power: Step = %d/%d; Level = %d dBm\n", MasterBlaster->testCtrl.Power+1,
+ TpcTable.NumOfEntries, TpcTable.t[MasterBlaster->testCtrl.Power].TxPowerLevel);
+ }
+ else
+ {
+ printf ("Power: Step = Max; Level = N/A\n");
+ }
+ if ((MasterBlaster->ContTxMode == ENABLE && ContTxTypeOption[MasterBlaster->ContTxType].Value == Cont_Tx_Regular) ||
+ (MasterBlaster->ContTxMode == DISABLE))
+ {
+ printf ("PacketType: %s\n", PacketTypeOption[GetPacketTypeOptionIndex(MasterBlaster->testCtrl.Packet)].Name);
+ printf ("DataLen: %d\n", MasterBlaster->testCtrl.DataLen);
+ }
+ if (ContTxTypeOption[MasterBlaster->ContTxType].Value != CW_Single_Tone) {//for single tone, no bdaddr
+ ba2str((const bdaddr_t *)MasterBlaster->bdaddr, BdAddr);
+ printf ("BdAddr: 0x%s\n\n",BdAddr);
+ }
+ }
+ printf ("\nmb>\n");
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterTestMode(tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = (int)MasterBlaster->testCtrl.Mode;
+
+ if (ToggleOption (&Value, Option, TestModeOption,
+ sizeof(TestModeOption)/sizeof(tMasterBlasterOption), TM,1))
+ {
+ MasterBlaster->testCtrl.Mode = (UCHAR)Value;
+ // Enable continous Tx should disable continous Rx
+ MasterBlaster->ContRxMode = DISABLE;
+ MasterBlaster->ContTxMode = DISABLE;
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterHopMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = (int)MasterBlaster->testCtrl.HopMode;
+
+ if (ToggleOption (&Value, Option, HopModeOption,
+ sizeof(HopModeOption)/sizeof(tMasterBlasterOption), HM,1))
+ {
+ MasterBlaster->testCtrl.HopMode = (UCHAR)Value;
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterTxFreq (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ //char Buffer[20];
+ tMasterBlasterOption NewValue;
+ int LoopCount = 4;
+ int Value = (int)MasterBlaster->testCtrl.TxFreq;
+ int MaxFreq = LEMode ? MB_MAX_FREQUENCY_LE : MB_MAX_FREQUENCY;
+ int MinFreq = LEMode ? MB_MIN_FREQUENCY_LE : MB_MIN_FREQUENCY;
+
+ while (--LoopCount > 0)
+ {
+ printf ("\n Enter Tx frequency (%d..%d): ", MinFreq, MaxFreq);
+ scanf("%d",&NewValue.Value);
+// fgets(NewValue,3,stdin);
+ if (MinMaxOption (&Value, &NewValue, MinFreq, MaxFreq))
+ {
+ MasterBlaster->testCtrl.TxFreq = (UCHAR)Value;
+ return TRUE;
+ }
+ else if (LoopCount > 1)
+ {
+ printf ("\n ERROR ---> Invalid Tx frequency.\n");
+ }
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterRxFreq (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ tMasterBlasterOption NewValue;
+ int LoopCount = 4;
+ int Value = (int)MasterBlaster->testCtrl.RxFreq;
+ int MaxFreq = LEMode ? MB_MAX_FREQUENCY_LE : MB_MAX_FREQUENCY;
+ int MinFreq = LEMode ? MB_MIN_FREQUENCY_LE : MB_MIN_FREQUENCY;
+
+ while (--LoopCount > 0)
+ {
+ printf ("\n Enter Rx frequency (%d..%d): ", MinFreq, MaxFreq);
+ scanf("%d",&NewValue.Value);
+ if (MinMaxOption (&Value, &NewValue, MinFreq, MaxFreq))
+ {
+ MasterBlaster->testCtrl.RxFreq = (UCHAR)Value;
+ return TRUE;
+ }
+ else if (LoopCount > 1)
+ {
+ printf ("\n ERROR ---> Invalid Rx frequency.\n");
+ }
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterPacketType (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = (int)MasterBlaster->testCtrl.Packet;
+
+ if (ToggleOption (&Value, Option, PacketTypeOption,
+ sizeof(PacketTypeOption)/sizeof(tMasterBlasterOption), PT,1))
+ {
+ MasterBlaster->testCtrl.Packet = (UCHAR)Value;
+ MasterBlaster->testCtrl.DataLen = MaxDataLenOption[GetPacketTypeOptionIndex(Value)];
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterDataLen (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ tMasterBlasterOption NewValue;
+ int LoopCount = 4;
+ int MaxLen = LEMode ? MB_MAX_DATALEN_LE : MB_MAX_DATALEN;
+ int MinLen = LEMode ? MB_MIN_DATALEN_LE : MB_MIN_DATALEN;
+
+ while (--LoopCount > 0)
+ {
+ printf ("\n Enter data length (%d..%d): ", MinLen, MaxLen);
+ scanf("%d",&NewValue.Value);
+ if (MinMaxOption (&MasterBlaster->testCtrl.DataLen, &NewValue, MinLen, MaxLen))
+ {
+ return TRUE;
+ }
+ else if (LoopCount > 1)
+ {
+ printf ("\n ERROR ---> Invalid data length.\n");
+ }
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterPower (tBRM_Control_packet *MasterBlaster, char *Option)
+{
+ if (TpcTable.NumOfEntries > MAX_TRANSMIT_POWER_CONTROL_ENTRIES)
+ {
+ printf ("\nNumber of entries in TPC table exceeds the limit.\n");
+ sleep(3);
+ return TRUE;
+ }
+
+ if (TpcTable.NumOfEntries == 0)
+ {
+ printf ("\nThere is no entry in TPC table.\n");
+ sleep(3);
+ return TRUE;
+ }
+
+ int Value = (int)MasterBlaster->testCtrl.Power;
+
+ if (ToggleMinMaxOption (&Value, Option, PO, 0, TpcTable.NumOfEntries-1,1))
+ {
+ MasterBlaster->testCtrl.Power = (UCHAR)Value;
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterBdAddr (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ char Buffer[20];
+ bdaddr_t bdaddr;
+
+ printf ("\n Enter BdAddr: ");
+// gets(Buffer);
+ scanf("%s",Buffer);
+ str2ba(Buffer,&bdaddr);
+ strncpy(MasterBlaster->bdaddr,bdaddr.b,6);
+ return TRUE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterContTxMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = (int)MasterBlaster->ContTxMode;
+
+ if (ToggleOption (&Value, Option, ContTxModeOption,
+ sizeof(ContTxModeOption)/sizeof(tMasterBlasterOption), CT,1))
+ {
+ MasterBlaster->ContTxMode = (UCHAR)Value;
+ if (MasterBlaster->ContTxMode == ENABLE)
+ {
+ // Enable continous Tx should disable continous Rx
+ MasterBlaster->ContRxMode = DISABLE;
+ MasterBlaster->LERxMode = DISABLE;
+ MasterBlaster->LETxMode = DISABLE;
+ LEMode = FALSE;
+ }
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterContTxType (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = (int)MasterBlaster->ContTxType;
+
+ if (ToggleOption (&Value, Option, ContTxTypeOption,
+ sizeof(ContTxTypeOption)/sizeof(tMasterBlasterOption), CX,1))
+ {
+ MasterBlaster->ContTxType = (UCHAR)Value;
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterLERxMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = MasterBlaster->LERxMode;
+
+ if (ToggleOption (&Value, Option, ContRxModeOption,
+ sizeof(ContRxModeOption)/sizeof(tMasterBlasterOption), LR, 1))
+ {
+ MasterBlaster->LERxMode = (UCHAR)Value;
+ if (MasterBlaster->LERxMode == ENABLE)
+ {
+ /* Enable continous Tx should disable other modes */
+ MasterBlaster->LETxMode = DISABLE;
+ MasterBlaster->ContTxMode = DISABLE;
+ MasterBlaster->ContRxMode = DISABLE;
+ if (MasterBlaster->testCtrl.RxFreq > 39)
+ {
+ MasterBlaster->testCtrl.RxFreq = 39;
+ }
+ LEMode = TRUE;
+ }
+ else
+ {
+ LEMode = FALSE;
+ }
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterLETxMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = MasterBlaster->LETxMode;
+
+ if (ToggleOption (&Value, Option, ContTxModeOption,
+ sizeof(ContTxModeOption)/sizeof(tMasterBlasterOption), LT, 1))
+ {
+ MasterBlaster->LETxMode = (UCHAR)Value;
+ if (MasterBlaster->LETxMode == ENABLE)
+ {
+ /* Enable continous Tx should disable other modes */
+ MasterBlaster->LERxMode = DISABLE;
+ MasterBlaster->ContTxMode = DISABLE;
+ MasterBlaster->ContRxMode = DISABLE;
+ if (MasterBlaster->testCtrl.TxFreq > MB_MAX_FREQUENCY_LE)
+ {
+ MasterBlaster->testCtrl.TxFreq = 39;
+ }
+ LEMode = TRUE;
+ }
+ else
+ {
+ LEMode = FALSE;
+ }
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterLETxPktPayload(tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = MasterBlaster->LETxParms.PktPayload;
+
+ if (ToggleOption(&Value, Option, LETxPktPayloadOption,
+ sizeof(LETxPktPayloadOption)/sizeof(tMasterBlasterOption), LTM, 1))
+ {
+ MasterBlaster->LETxParms.PktPayload = (UCHAR)Value;
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterContRxMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = (int)MasterBlaster->ContRxMode;
+ printf("\n N op\n");
+ if (ToggleOption (&Value, Option, ContRxModeOption,
+ sizeof(ContRxModeOption)/sizeof(tMasterBlasterOption), CR,1))
+ {
+ MasterBlaster->ContRxMode = (UCHAR)Value;
+ if (MasterBlaster->ContRxMode == ENABLE)
+ {
+ // Enable continous Tx should disable continous Rx
+ MasterBlaster->ContTxMode = DISABLE;
+ MasterBlaster->LERxMode = DISABLE;
+ MasterBlaster->LETxMode = DISABLE;
+ LEMode = FALSE;
+ }
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+int SetMasterBlasterBERType (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ int Value = (int)MasterBlaster->BERType;
+ if (ToggleOption (&Value, Option, BERPacketTypeOption,
+ sizeof(BERPacketTypeOption)/sizeof(tMasterBlasterOption), SB, 1))
+ {
+ MasterBlaster->BERType = (UCHAR)Value;
+ return TRUE;
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int SetMasterBlasterNothing (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option)
+{
+ UNUSED(MasterBlaster);
+ UNUSED(Option);
+
+ return TRUE;
+}
+
+//----------------------------------------------------------------------------
+
+int ToggleOption (int *Value, tMasterBlasterOption *Option, tMasterBlasterOption *OptionArray,
+ int Size, int FieldID, int Step)
+{
+ char Opt = Option->Name[0];
+
+ int Backward = ((Opt - 'A' + 'a') == MasterBlasterMenu[FieldID].Alias[0]);
+ int i;
+ for (i = 0; i < Size; ++i)
+ {
+ if (*Value == OptionArray[i].Value)
+ {
+ if (Backward)
+ {
+ i = ((i - Step) < 0) ? (Size - Step + i) : (i - Step);
+ }
+ else
+ {
+ i = (i + Step) % Size;
+ }
+ *Value = OptionArray[i].Value;
+ return TRUE;
+ }
+ }
+ return FALSE;
+}
+
+//----------------------------------------------------------------------------
+
+int MinMaxOption (int *Value, tMasterBlasterOption *Option, int Min, int Max)
+{
+ int NewValue = Option->Value;
+
+ if (NewValue < Min || NewValue > Max)
+ {
+ return FALSE;
+ }
+ *Value = NewValue;
+ return TRUE;
+}
+
+//----------------------------------------------------------------------------
+
+int ToggleMinMaxOption (int *Value, char *Option, int FieldID, int Min, int Max, int Step)
+{
+ char Opt = *Option;
+ int Backward = ((Opt - 'A' + 'a') == MasterBlasterMenu[FieldID].Alias[0]);
+
+ if (Backward)
+ {
+ *Value = ((*Value - Step) < Min) ? (Max + 1 - (Step - (*Value - Min))) : (*Value - Step);
+ }
+ else
+ {
+ *Value = ((*Value + Step) > Max) ? (Min + (Step - (Max + 1 - *Value))) : (*Value + Step);
+ }
+ return TRUE;
+
+}
+
+//----------------------------------------------------------------------------
diff --git a/btconfig_1.05/btconfig.h b/btconfig_1.05/btconfig.h
new file mode 100755
index 0000000..13de972
--- /dev/null
+++ b/btconfig_1.05/btconfig.h
@@ -0,0 +1,267 @@
+/*
+ * Copyright (c) 2008-2009 Atheros Corporation. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation;
+ *
+ * Software distributed under the License is distributed on an "AS
+ * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
+ * implied. See the License for the specific language governing
+ * rights and limitations under the License.
+ *
+ * <Header File>
+ *
+ * <btconfig.h>
+ */
+
+#ifndef _BTCONFIG_H_
+#define _BTCONFIG_H_
+
+#define VERSION "1.05"
+#define PS_ASIC_FILENAME "/etc/firmware/ar3k/1020200/PS_ASIC.pst"
+#define PS_FPGA_FILENAME "/etc/firmware/ar3k/1020200/PS_FPGA.pst"
+#define TESTPATCH_FILENAME "/etc/firmware/ar3k/1020200/Testpatch.txt"
+#define PATCH_FILENAME "/etc/firmware/ar3k/1020200/RamPatch.txt"
+
+#define TRUE 1
+#define FALSE 0
+#define LINE_SIZE_MAX 3000
+#define BD_ADDR_SIZE 6
+#define BD_ADDR_PSTAG 1
+#define WRITE_PATCH 8
+#define ENABLE_PATCH 11
+#define PS_RESET 2
+#define PS_READ 0
+#define PS_WRITE 1
+#define PS_READ_RAW 3
+#define PS_WRITE_RAW 4
+#define PS_GET_LENGTH 5
+#define PS_SET_ACCESS_MODE 6
+#define PS_SET_ACCESS_PRIORITY 7
+#define PS_WRITE 1
+#define PS_DYNMEM_OVERRIDE 10
+#define PS_VERIFY_CRC 9
+#define CHANGE_BDADDR 15
+#define PS_COMMAND_HEADER 4
+#define HCI_EVENT_SIZE 7
+#define PS_RETRY_COUNT 3
+#define RAM_PS_REGION (1<<0)
+#define RAM_PATCH_REGION (1<<1)
+#define RAM_DYN_MEM_REGION (1<<2)
+#define RAMPS_MAX_PS_DATA_PER_TAG 244
+#define RAMPS_MAX_PS_TAGS_PER_FILE 50
+#define PSTAG_RF_TEST_BLOCK_START (300)
+#define PSTAG_SYSTEM_BLOCK_START (1)
+#define BT_SOC_INIT_TOOL_START_MAGIC_WORD 0xB1B1
+#define PSTAG_RF_PARAM_TABLE0 (PSTAG_RF_TEST_BLOCK_START+0)
+#define PSTAG_SYSCFG_PARAM_TABLE0 (PSTAG_SYSTEM_BLOCK_START+18)
+#define PATCH_MAX_LEN 20000
+#define DYN_MEM_MAX_LEN 40
+#define SKIP_BLANKS(str) while (*str == ' ') str++
+#define MAX_RADIO_CFG_TABLE_SIZE 1000
+#define MAX_BYTE_LENGTH 244
+#define DEBUG_EVENT_TYPE_PS 0x02
+#define DEBUG_EVENT_TYPE_MEMBLK 0x03
+#define HCI_EVENT_HEADER_SIZE 0x03
+#define HI_MAGIC_NUMBER ((const unsigned short int) 0xFADE)
+#define HI_VERSION (0x0300) //Version 3.0
+#define EEPROM_CONFIG 0x00020C00
+#define FPGA_REGISTER 0x4FFC
+
+// Vendor specific command OCF
+#define OCF_PS 0x000B
+#define OCF_MEMOP 0x0014
+#define OGF_TEST_CMD 0x06
+#define OCF_HOST_INTEREST 0x000A
+#define OCF_CONT_TX_TESTER 0x0023
+#define OCF_TX_TESTER 0x001B
+#define OCF_SLEEP_MODE 0x0004
+#define OCF_READ_MEMORY 0x0005
+#define OCF_WRITE_MEMORY 0x0006
+#define OCF_DISABLE_TX 0x002D
+#define OCF_TEST_MODE_SEQN_TRACKING 0x0018
+#define OCF_READ_VERSION 0x001E
+#define OCF_AUDIO_CMD 0x0013
+#define OCF_GET_BERTYPE 0x005C
+#define OCF_RX_TESTER 0x005B
+
+#define UCHAR unsigned char
+#define BOOL unsigned short
+#define UINT16 unsigned short int
+#define UINT32 unsigned int
+#define SINT16 signed short int
+#define UINT8 unsigned char
+#define SINT8 signed char
+
+typedef struct tPsTagEntry
+{
+ int TagId;
+ UCHAR TagLen;
+ UCHAR TagData[RAMPS_MAX_PS_DATA_PER_TAG];
+} tPsTagEntry, *tpPsTagEntry;
+
+typedef struct tRamPatch
+{
+ int Len;
+ UCHAR Data[PATCH_MAX_LEN];
+} tRamPatch, *ptRamPatch;
+
+typedef struct tRamDynMemOverride
+{
+ int Len;
+ UCHAR Data[DYN_MEM_MAX_LEN];
+} tRamDynMemOverride, *ptRamDynMemOverride;
+
+tPsTagEntry PsTagEntry[RAMPS_MAX_PS_TAGS_PER_FILE];
+tRamPatch RamPatch[50];
+tRamDynMemOverride RamDynMemOverride;
+
+enum MB_FILEFORMAT {
+ MB_FILEFORMAT_PS,
+ MB_FILEFORMAT_PATCH,
+ MB_FILEFORMAT_DY,
+};
+enum RamPsSection
+{
+ RAM_PS_SECTION,
+ RAM_PATCH_SECTION,
+ RAM_DYN_MEM_SECTION
+};
+
+enum eType {
+ eHex,
+ edecimal,
+};
+
+struct ST_PS_DATA_FORMAT {
+ enum eType eDataType;
+ BOOL bIsArray;
+};
+#define CONV_DEC_DIGIT_TO_VALUE(c) ((c) - '0')
+#define IS_HEX(c) (IS_BETWEEN((c), '0', '9') || IS_BETWEEN((c), 'a', 'f') || IS_BETWEEN((c), 'A', 'F'))
+#define IS_BETWEEN(x, lower, upper) (((lower) <= (x)) && ((x) <= (upper)))
+#define IS_DIGIT(c) (IS_BETWEEN((c), '0', '9'))
+#define CONV_HEX_DIGIT_TO_VALUE(c) (IS_DIGIT(c) ? ((c) - '0') : (IS_BETWEEN((c), 'A', 'Z') ? ((c) - 'A' + 10) : ((c) - 'a' + 10)))
+#define BYTES_OF_PS_DATA_PER_LINE 16
+struct ST_READ_STATUS {
+ unsigned uTagID;
+ unsigned uSection;
+ unsigned uLineCount;
+ unsigned uCharCount;
+ unsigned uByteCount;
+};
+
+//DUT MODE related
+#define MC_BCAM_COMPARE_ADDRESS 0x00008080
+#define HCI_3_PATCH_SPACE_LENGTH_1 (0x80)
+#define HCI_3_PATCH_SPACE_LENGTH_2 (0x279C)
+#define MEM_BLK_DATA_MAX (244)
+#define MC_BCAM_VALID_ADDRESS 0x00008100
+
+//Audio stat
+
+typedef struct tAudio_Stat {
+ UINT16 RxSilenceInsert;
+ UINT16 RxAirPktDump;
+ UINT16 RxCmplt;
+ UINT16 TxCmplt;
+ UINT16 MaxPLCGenInterval;
+ UINT16 RxAirPktStatusGood;
+ UINT16 RxAirPktStatusError;
+ UINT16 RxAirPktStatusLost;
+ UINT16 RxAirPktStatusPartial;
+ SINT16 SampleMin;
+ SINT16 SampleMax;
+ UINT16 SampleCounter;
+ UINT16 SampleStatEnable;
+} tAudioStat;
+
+//DMA stats
+
+typedef struct tBRM_Stats {
+ // DMA Stats
+ UINT32 DmaIntrs;
+
+ // Voice Stats
+ UINT16 VoiceTxDmaIntrs;
+ UINT16 VoiceTxErrorIntrs;
+ UINT16 VoiceTxDmaErrorIntrs;
+ UINT16 VoiceTxPktAvail;
+ UINT16 VoiceTxPktDumped;
+ UINT16 VoiceTxDmaSilenceInserts;
+
+ UINT16 VoiceRxDmaIntrs;
+ UINT16 VoiceRxErrorIntrs;
+ UINT16 VoiceRxGoodPkts;
+ UINT16 VoiceRxErrCrc;
+ UINT16 VoiceRxErrUnderOverFlow;
+ UINT16 VoiceRxPktDumped;
+
+ UINT16 VoiceTxReapOnError;
+ UINT16 VoiceRxReapOnError;
+ UINT16 VoiceSchedulingError;
+ UINT16 SchedOnVoiceError;
+
+ UINT16 Temp1;
+ UINT16 Temp2;
+
+ // Control Stats
+ UINT16 ErrWrongLlid;
+ UINT16 ErrL2CapLen;
+ UINT16 ErrUnderOverFlow;
+ UINT16 RxBufferDumped;
+ UINT16 ErrWrongLmpPktType;
+ UINT16 ErrWrongL2CapPktType;
+ UINT16 HecFailPkts;
+ UINT16 IgnoredPkts;
+ UINT16 CrcFailPkts;
+ UINT16 HwErrRxOverflow;
+
+ UINT16 CtrlErrNoLmpBufs;
+
+ // ACL Stats
+ UINT16 DataTxBuffers;
+ UINT16 DataRxBuffers;
+ UINT16 DataRxErrCrc;
+ UINT16 DataRxPktDumped;
+ UINT16 LmpTxBuffers;
+ UINT16 LmpRxBuffers;
+ UINT16 ForceOverQosJob;
+
+ // Sniff Stats
+ UINT16 SniffSchedulingError;
+ UINT16 SniffIntervalNoCorr;
+
+ // Test Mode Stats
+ UINT16 TestModeDroppedTxPkts;
+ UINT16 TestModeDroppedLmps;
+
+ // Error Stats
+ UINT16 TimePassedIntrs;
+ UINT16 NoCommandIntrs;
+
+} tBRM_Stats;
+
+typedef struct tSYSUTIL_ChipId {
+ char *pName;
+ UINT32 HwRev;
+} tSYSUTIL_ChipId;
+
+typedef struct tSU_RevInfo {
+ tSYSUTIL_ChipId *pChipId;
+ tSYSUTIL_ChipId *pChipRadioId;
+ UINT32 ChipRadioId;
+ UINT32 SubRadioId;
+ UINT32 RomVersion;
+ UINT32 RomBuildNumber;
+ UINT32 BuildVersion;
+ UINT32 BuildNumber;
+ UINT16 RadioFormat;
+ UINT16 RadioContent;
+ UINT16 SysCfgFormat;
+ UINT16 SysCfgContent;
+ UINT8 ProductId;
+} tSU_RevInfo;
+
+#endif
diff --git a/btconfig_1.05/btconfig.tar.bz2 b/btconfig_1.05/btconfig.tar.bz2
new file mode 100644
index 0000000..129811c
--- /dev/null
+++ b/btconfig_1.05/btconfig.tar.bz2
Binary files differ
diff --git a/btconfig_1.05/build_btconfig.sh b/btconfig_1.05/build_btconfig.sh
new file mode 100755
index 0000000..2885118
--- /dev/null
+++ b/btconfig_1.05/build_btconfig.sh
@@ -0,0 +1,10 @@
+source ../../../../a5s_linux_sdk/ambarella/build/env/CodeSourcery.env
+PATH=$PATH:$ARM_LINUX_TOOLCHAIN_DIR/bin
+
+make -f Makefile
+
+rm -rf fakeroot
+mkdir -p fakeroot/usr/bin
+cp -d btconfig fakeroot/usr/bin
+
+tar cjfv btconfig.tar.bz2 fakeroot
diff --git a/btconfig_1.05/compat/arc4random.c b/btconfig_1.05/compat/arc4random.c
new file mode 100755
index 0000000..29528ce
--- /dev/null
+++ b/btconfig_1.05/compat/arc4random.c
@@ -0,0 +1,158 @@
+/*
+ * Arc4 random number generator for OpenBSD.
+ * Copyright 1996 David Mazieres <dm@lcs.mit.edu>.
+ *
+ * Modification and redistribution in source and binary forms is
+ * permitted provided that due credit is given to the author and the
+ * OpenBSD project by leaving this copyright notice intact.
+ */
+
+/*
+ * This code is derived from section 17.1 of Applied Cryptography,
+ * second edition, which describes a stream cipher allegedly
+ * compatible with RSA Labs "RC4" cipher (the actual description of
+ * which is a trade secret). The same algorithm is used as a stream
+ * cipher called "arcfour" in Tatu Ylonen's ssh package.
+ *
+ * Here the stream cipher has been modified always to include the time
+ * when initializing the state. That makes it impossible to
+ * regenerate the same random sequence twice, so this can't be used
+ * for encryption, but will generate good random numbers.
+ *
+ * RC4 is a registered trademark of RSA Laboratories.
+ */
+
+#include <sys/time.h>
+
+#include <fcntl.h>
+#include <stdint.h>
+#include <stdlib.h>
+#include <unistd.h>
+
+#include "arc4random.h"
+
+struct arc4_stream {
+ uint8_t i;
+ uint8_t j;
+ uint8_t s[256];
+};
+
+static int rs_initialized;
+static struct arc4_stream rs;
+static int arc4_count;
+
+static void
+arc4_init(struct arc4_stream *as)
+{
+ int n;
+
+ for (n = 0; n < 256; n++)
+ as->s[n] = n;
+ as->i = 0;
+ as->j = 0;
+}
+
+static void
+arc4_addrandom(struct arc4_stream *as, unsigned char *dat, int datlen)
+{
+ int n;
+ uint8_t si;
+
+ as->i--;
+ for (n = 0; n < 256; n++) {
+ as->i = (as->i + 1);
+ si = as->s[as->i];
+ as->j = (as->j + si + dat[n % datlen]);
+ as->s[as->i] = as->s[as->j];
+ as->s[as->j] = si;
+ }
+ as->j = as->i;
+}
+
+static uint8_t
+arc4_getbyte(struct arc4_stream *as)
+{
+ uint8_t si, sj;
+
+ as->i = (as->i + 1);
+ si = as->s[as->i];
+ as->j = (as->j + si);
+ sj = as->s[as->j];
+ as->s[as->i] = sj;
+ as->s[as->j] = si;
+ return (as->s[(si + sj) & 0xff]);
+}
+
+static uint32_t
+arc4_getword(struct arc4_stream *as)
+{
+ uint32_t val;
+
+ val = arc4_getbyte(as) << 24;
+ val |= arc4_getbyte(as) << 16;
+ val |= arc4_getbyte(as) << 8;
+ val |= arc4_getbyte(as);
+ return val;
+}
+
+static void
+arc4_stir(struct arc4_stream *as)
+{
+ int fd;
+ struct {
+ struct timeval tv;
+ unsigned int rnd[(128 - sizeof(struct timeval)) /
+ sizeof(unsigned int)];
+ } rdat;
+ int n;
+
+ gettimeofday(&rdat.tv, NULL);
+ fd = open("/dev/urandom", O_RDONLY);
+ if (fd != -1) {
+ n = read(fd, rdat.rnd, sizeof(rdat.rnd));
+ close(fd);
+ }
+
+ /* fd < 0? Ah, what the heck. We'll just take
+ * whatever was on the stack... */
+ arc4_addrandom(as, (void *) &rdat, sizeof(rdat));
+
+ /*
+ * Throw away the first N words of output, as suggested in the
+ * paper "Weaknesses in the Key Scheduling Algorithm of RC4"
+ * by Fluher, Mantin, and Shamir. (N = 256 in our case.)
+ */
+ for (n = 0; n < 256 * 4; n++)
+ arc4_getbyte(as);
+ arc4_count = 1600000;
+}
+
+void
+arc4random_stir()
+{
+
+ if (!rs_initialized) {
+ arc4_init(&rs);
+ rs_initialized = 1;
+ }
+ arc4_stir(&rs);
+}
+
+void
+arc4random_addrandom(unsigned char *dat, int datlen)
+{
+
+ if (!rs_initialized)
+ arc4random_stir();
+ arc4_addrandom(&rs, dat, datlen);
+}
+
+uint32_t
+arc4random()
+{
+
+ arc4_count -= 4;
+ if (!rs_initialized || arc4_count <= 0)
+ arc4random_stir();
+ return arc4_getword(&rs);
+}
diff --git a/btconfig_1.05/compat/arc4random.h b/btconfig_1.05/compat/arc4random.h
new file mode 100755
index 0000000..6724cef
--- /dev/null
+++ b/btconfig_1.05/compat/arc4random.h
@@ -0,0 +1,36 @@
+/*
+ * dhcpcd - DHCP client daemon
+ * Copyright (c) 2006-2010 Roy Marples <roy@marples.name>
+ * All rights reserved
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef ARC4RANDOM_H
+#define ARC4RANDOM_H
+
+#include <stdint.h>
+
+void arc4random_stir(void);
+void arc4random_addrandom(unsigned char *, int);
+uint32_t arc4random(void);
+#endif
diff --git a/btconfig_1.05/compat/closefrom.c b/btconfig_1.05/compat/closefrom.c
new file mode 100755
index 0000000..5c02005
--- /dev/null
+++ b/btconfig_1.05/compat/closefrom.c
@@ -0,0 +1,42 @@
+/*
+ * dhcpcd - DHCP client daemon
+ * Copyright (c) 2006-2009 Roy Marples <roy@marples.name>
+ * All rights reserved
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <unistd.h>
+
+#include "closefrom.h"
+
+int
+closefrom(int fd)
+{
+ int max = getdtablesize();
+ int i;
+ int r = 0;
+
+ for (i = fd; i < max; i++)
+ r += close(i);
+ return r;
+}
diff --git a/btconfig_1.05/compat/closefrom.h b/btconfig_1.05/compat/closefrom.h
new file mode 100755
index 0000000..6b8709b
--- /dev/null
+++ b/btconfig_1.05/compat/closefrom.h
@@ -0,0 +1,31 @@
+/*
+ * dhcpcd - DHCP client daemon
+ * Copyright (c) 2006-2009 Roy Marples <roy@marples.name>
+ * All rights reserved
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef CLOSEFROM_H
+#define CLOSEFROM_H
+int closefrom(int);
+#endif
diff --git a/btconfig_1.05/compat/getline.c b/btconfig_1.05/compat/getline.c
new file mode 100755
index 0000000..79fcf1e
--- /dev/null
+++ b/btconfig_1.05/compat/getline.c
@@ -0,0 +1,75 @@
+/*
+ * dhcpcd - DHCP client daemon
+ * Copyright (c) 2006-2009 Roy Marples <roy@marples.name>
+ * All rights reserved
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <errno.h>
+#include <stdint.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+
+#include "getline.h"
+
+/* Redefine a small buffer for our simple text config files */
+#undef BUFSIZ
+#define BUFSIZ 128
+
+ssize_t
+getline(char ** __restrict buf, size_t * __restrict buflen,
+ FILE * __restrict fp)
+{
+ size_t bytes, newlen;
+ char *newbuf, *p;
+
+ if (buf == NULL || buflen == NULL) {
+ errno = EINVAL;
+ return -1;
+ }
+ if (*buf == NULL)
+ *buflen = 0;
+
+ bytes = 0;
+ do {
+ if (feof(fp))
+ break;
+ if (*buf == NULL || bytes != 0) {
+ newlen = *buflen + BUFSIZ;
+ newbuf = realloc(*buf, newlen);
+ if (newbuf == NULL)
+ return -1;
+ *buf = newbuf;
+ *buflen = newlen;
+ }
+ p = *buf + bytes;
+ memset(p, 0, BUFSIZ);
+ if (fgets(p, BUFSIZ, fp) == NULL)
+ break;
+ bytes += strlen(p);
+ } while (bytes == 0 || *(*buf + (bytes - 1)) != '\n');
+ if (bytes == 0)
+ return -1;
+ return bytes;
+}
diff --git a/btconfig_1.05/compat/getline.h b/btconfig_1.05/compat/getline.h
new file mode 100755
index 0000000..be3b57c
--- /dev/null
+++ b/btconfig_1.05/compat/getline.h
@@ -0,0 +1,36 @@
+/*
+ * dhcpcd - DHCP client daemon
+ * Copyright (c) 2006-2009 Roy Marples <roy@marples.name>
+ * All rights reserved
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef GETLINE_H
+#define GETLINE_H
+
+#include <sys/types.h>
+#include <stdio.h>
+
+ssize_t getline(char ** __restrict buf, size_t * __restrict buflen,
+ FILE * __restrict fp);
+#endif
diff --git a/btconfig_1.05/compat/linkaddr.c b/btconfig_1.05/compat/linkaddr.c
new file mode 100755
index 0000000..8c7a6c8
--- /dev/null
+++ b/btconfig_1.05/compat/linkaddr.c
@@ -0,0 +1,120 @@
+/*-
+ * Copyright (c) 1990, 1993
+ * The Regents of the University of California. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the University nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+#if defined(LIBC_SCCS) && !defined(lint)
+static char sccsid[] = "@(#)linkaddr.c 8.1 (Berkeley) 6/4/93";
+#endif /* LIBC_SCCS and not lint */
+
+#include <sys/types.h>
+#include <sys/socket.h>
+#include <net/if_dl.h>
+
+#include <string.h>
+
+/* States*/
+#define NAMING 0
+#define GOTONE 1
+#define GOTTWO 2
+#define RESET 3
+/* Inputs */
+#define DIGIT (4*0)
+#define END (4*1)
+#define DELIM (4*2)
+#define LETTER (4*3)
+
+void
+link_addr(addr, sdl)
+ const char *addr;
+ struct sockaddr_dl *sdl;
+{
+ char *cp = sdl->sdl_data;
+ char *cplim = sdl->sdl_len + (char *)(void *)sdl;
+ int byte = 0, state = NAMING;
+ int newaddr = 0;
+
+ (void)memset(&sdl->sdl_family, 0, (size_t)sdl->sdl_len - 1);
+ sdl->sdl_family = AF_LINK;
+ do {
+ state &= ~LETTER;
+ if ((*addr >= '0') && (*addr <= '9')) {
+ newaddr = *addr - '0';
+ } else if ((*addr >= 'a') && (*addr <= 'f')) {
+ newaddr = *addr - 'a' + 10;
+ } else if ((*addr >= 'A') && (*addr <= 'F')) {
+ newaddr = *addr - 'A' + 10;
+ } else if (*addr == 0) {
+ state |= END;
+ } else if (state == NAMING &&
+ (((*addr >= 'A') && (*addr <= 'Z')) ||
+ ((*addr >= 'a') && (*addr <= 'z'))))
+ state |= LETTER;
+ else
+ state |= DELIM;
+ addr++;
+ switch (state /* | INPUT */) {
+ case NAMING | DIGIT:
+ case NAMING | LETTER:
+ *cp++ = addr[-1];
+ continue;
+ case NAMING | DELIM:
+ state = RESET;
+ sdl->sdl_nlen = cp - sdl->sdl_data;
+ continue;
+ case GOTTWO | DIGIT:
+ *cp++ = byte;
+ /* FALLTHROUGH */
+ case RESET | DIGIT:
+ state = GOTONE;
+ byte = newaddr;
+ continue;
+ case GOTONE | DIGIT:
+ state = GOTTWO;
+ byte = newaddr + (byte << 4);
+ continue;
+ default: /* | DELIM */
+ state = RESET;
+ *cp++ = byte;
+ byte = 0;
+ continue;
+ case GOTONE | END:
+ case GOTTWO | END:
+ *cp++ = byte;
+ /* FALLTHROUGH */
+ case RESET | END:
+ break;
+ }
+ break;
+ } while (cp < cplim);
+ sdl->sdl_alen = cp - LLADDR(sdl);
+ newaddr = cp - (char *)(void *)sdl;
+ if ((size_t) newaddr > sizeof(*sdl))
+ sdl->sdl_len = newaddr;
+ return;
+}
diff --git a/btconfig_1.05/compat/strlcpy.c b/btconfig_1.05/compat/strlcpy.c
new file mode 100755
index 0000000..2cdd6a5
--- /dev/null
+++ b/btconfig_1.05/compat/strlcpy.c
@@ -0,0 +1,51 @@
+/*
+ * dhcpcd - DHCP client daemon
+ * Copyright (c) 2006-2009 Roy Marples <roy@marples.name>
+ * All rights reserved
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/types.h>
+
+#include "strlcpy.h"
+
+size_t
+strlcpy(char *dst, const char *src, size_t size)
+{
+ const char *s = src;
+ size_t n = size;
+
+ if (n && --n)
+ do {
+ if (!(*dst++ = *src++))
+ break;
+ } while (--n);
+
+ if (!n) {
+ if (size)
+ *dst = '\0';
+ while (*src++);
+ }
+
+ return src - s - 1;
+}
diff --git a/btconfig_1.05/compat/strlcpy.h b/btconfig_1.05/compat/strlcpy.h
new file mode 100755
index 0000000..75eaec8
--- /dev/null
+++ b/btconfig_1.05/compat/strlcpy.h
@@ -0,0 +1,34 @@
+/*
+ * dhcpcd - DHCP client daemon
+ * Copyright (c) 2006-2009 Roy Marples <roy@marples.name>
+ * All rights reserved
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef STRLCPY_H
+#define STRLCPY_H
+
+#include <sys/types.h>
+
+size_t strlcpy(char *, const char *, size_t);
+#endif
diff --git a/btconfig_1.05/masterblaster.h b/btconfig_1.05/masterblaster.h
new file mode 100755
index 0000000..c5fd410
--- /dev/null
+++ b/btconfig_1.05/masterblaster.h
@@ -0,0 +1,413 @@
+/*
+ * Copyright (c) 2008-2009 Atheros Corporation. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation;
+ *
+ * Software distributed under the License is distributed on an "AS
+ * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
+ * implied. See the License for the specific language governing
+ * rights and limitations under the License.
+ *
+ * <Header file contains required data for master blaster mode>
+ *
+ * <masterblaster.h>
+ */
+
+#ifndef _MASTERBLASTER_H_
+#define _MASTERBLASTER_H_
+#include "btconfig.h"
+
+#define INVALID_MASTERBLASTER_FIELD (-1)
+#define UNUSED(x) (x=x)
+// Bluetooth Packet Type Identifiers
+#define MAX_TRANSMIT_POWER_CONTROL_ENTRIES 15
+
+#define LC_JTAG_MODEM_REGS_ADDRESS 0x00020800
+#define AGC_BYPASS_ADDRESS 0x0000040c
+#define AGC_BYPASS_ENABLE_MASK 0x00000001
+#define AGC_BYPASS_ENABLE_LSB 0
+#define AGC_BYPASS_ENABLE_SET(x) (((x) << AGC_BYPASS_ENABLE_LSB) & AGC_BYPASS_ENABLE_MASK)
+#define LC_DEV_PARAM_CTL_ADDRESS 0x00020010
+#define LC_DEV_PARAM_CTL_FREQ_HOP_EN_MASK 0x00000001
+#define LC_DEV_PARAM_CTL_RX_FREQ_MASK 0x00007f00
+#define LC_DEV_PARAM_CTL_WHITEN_EN_MASK 0x00008000
+#define LC_DEV_PARAM_CTL_RX_FREQ_SET(x) (((x) << LC_DEV_PARAM_CTL_RX_FREQ_LSB) & LC_DEV_PARAM_CTL_RX_FREQ_MASK)
+#define LC_DEV_PARAM_CTL_RX_FREQ_LSB 8
+
+#define CORR_PARAM1_ADDRESS 0x00000048
+#define CORR_PARAM1_TIM_THR_MASK 0xfc000000
+#define CORR_PARAM1_TIM_THR_LSB 26
+#define CORR_PARAM1_TIM_THR_SET(x) (((x) << CORR_PARAM1_TIM_THR_LSB) & CORR_PARAM1_TIM_THR_MASK)
+
+typedef struct tBtHost_Interest {
+ UINT16 MagicNumber;
+ UINT16 Version;
+ UINT32 TraceDataAddr;
+ UINT32 GlobalDmaStats; // BRM Global DMA Statistics
+ UINT32 TpcTableAddr; // SysCfg Transmit power table
+ UINT32 AudioStatAddr;
+ UINT32 AudioInternalAddr;
+ UINT32 SysCfgAddr;
+ UINT32 ReservedRamAddr;
+ UINT32 HostConfigAddr;
+ UINT32 RamVersionAddr;
+ // Version 1.01
+ UINT32 BrmGlobalDataAddr; // BRM Global Context pointer
+ UINT32 LeGlobalDataAddr; // LE Global Context pointer
+ // Version 1.02
+ UINT32 MmGlobalDataAddr;
+} tBtHostInterest;
+
+typedef struct PsSysCfgTransmitPowerControlEntry {
+ SINT8 TxPowerLevel;
+ UINT32 RadioConfig;
+ UINT32 EdrRadioConfig;
+ SINT16 Slope;
+ SINT16 EdrSlope;
+ UINT8 TxFreqCorr;
+ UINT8 EdrTxFreqCorr;
+} tPsSysCfgTransmitPowerControlEntry;
+
+typedef struct PsSysCfgTransmitPowerControlTable {
+ int NumOfEntries;
+ tPsSysCfgTransmitPowerControlEntry t[MAX_TRANSMIT_POWER_CONTROL_ENTRIES];
+} tPsSysCfgTransmitPowerControlTable;
+typedef UCHAR tBRM_PktType;
+
+enum {
+ TxTest_PktType_NULL = 0x00,
+ TxTest_PktType_POLL = 0x01,
+ TxTest_PktType_FHS = 0x02,
+ TxTest_PktType_DM1 = 0x03,
+ TxTest_PktType_DH1 = 0x04,
+ TxTest_PktType_HV1 = 0x05,
+ TxTest_PktType_HV2 = 0x06,
+ TxTest_PktType_HV3 = 0x07,
+ TxTest_PktType_DV = 0x08,
+ TxTest_PktType_AUX1 = 0x09,
+ TxTest_PktType_DM3 = 0x0A,
+ TxTest_PktType_DH3 = 0x0B,
+ TxTest_PktType_DM5 = 0x0E,
+ TxTest_PktType_DH5 = 0x0F,
+ TxTest_PktType_2DH1 = 0x24,
+ TxTest_PktType_2DH3 = 0x2A,
+ TxTest_PktType_2DH5 = 0x2E,
+ TxTest_PktType_3DH1 = 0x28,
+ TxTest_PktType_3DH3 = 0x2B,
+ TxTest_PktType_3DH5 = 0x2F,
+ TxTest_PktType_Invalid = 0xff,
+};
+
+typedef UCHAR tBRM_eSCO_PktType;
+
+enum {
+ TxTest_PktType_EV3 = 0x17,
+ TxTest_PktType_EV4 = 0x1C,
+ TxTest_PktType_EV5 = 0x1D,
+ TxTest_PktType_2EV3 = 0x36,
+ TxTest_PktType_2EV5 = 0x3C,
+ TxTest_PktType_3EV3 = 0x37,
+ TxTest_PktType_3EV5 = 0x3D,
+};
+
+typedef UCHAR tBRM_PktMode;
+
+enum {
+ eBRM_Mode_Basic = 0,
+ eBRM_Mode_2Mbps = 2,
+ eBRM_Mode_3Mbps = 3
+};
+
+// tBRM_TestMode
+enum {
+ eBRM_TestMode_Pause = 0,
+ eBRM_TestMode_TX_0,
+ eBRM_TestMode_TX_1,
+ eBRM_TestMode_TX_1010,
+ eBRM_TestMode_TX_PRBS,
+ eBRM_TestMode_Loop_ACL,
+ eBRM_TestMode_Loop_SCO,
+ eBRM_TestMode_Loop_ACL_No_Whitening,
+ eBRM_TestMode_Loop_SCO_No_Whitening,
+ eBRM_TestMode_TX_11110000,
+ eBRM_TestMode_Rx,
+ eBRM_TestMode_Exit = 255,
+};
+enum {
+ Cont_Tx_Raw_1MHz = 0,
+ Cont_Tx_Raw_2MHz,
+ Cont_Tx_Raw_3MHz,
+ Cont_Tx_Regular,
+ CW_Single_Tone,
+};
+typedef UCHAR tBRM_TestMode;
+
+typedef struct tBRM_TestControl {
+ tBRM_TestMode Mode;
+ UCHAR HopMode;
+ UCHAR TxFreq;
+ UCHAR RxFreq;
+ UCHAR Power;
+// UCHAR PollPeriod;
+ UCHAR Packet;
+ UCHAR SkipRxSlot;
+ int DataLen;
+} tBRM_TestControl;
+
+typedef struct tLE_TxParms {
+ UCHAR PktPayload;
+} tLE_TxParms;
+
+typedef struct tBRM_Control_packet {
+ tBRM_TestControl testCtrl;
+ UCHAR bdaddr[6];
+ UCHAR ContTxMode; // Continuous TX Mode
+ UCHAR ContTxType;
+ UCHAR ContRxMode; // Continuous RX Mode
+ UCHAR BERType;
+ UCHAR LERxMode;
+ UCHAR LETxMode;
+ tLE_TxParms LETxParms;
+} tBRM_Control_packet;
+
+
+#define DM1_MAX_PAYLOAD 17
+#define DH1_MAX_PAYLOAD 27
+#define DM3_MAX_PAYLOAD 121
+#define DH3_MAX_PAYLOAD 183
+#define DM5_MAX_PAYLOAD 224
+#define DH5_MAX_PAYLOAD 339
+#define AUX1_MAX_PAYLOAD 29
+#define E2_DH1_MAX_PAYLOAD 54
+#define E2_DH3_MAX_PAYLOAD 367
+#define E2_DH5_MAX_PAYLOAD 679
+#define E3_DH1_MAX_PAYLOAD 83
+#define E3_DH3_MAX_PAYLOAD 552
+#define E3_DH5_MAX_PAYLOAD 1021
+
+enum E_MasterBlasterFieldID
+{
+ CR = 0,
+ CT,
+ LR,
+ LT,
+ LTM,
+ CX,
+ TM,
+ HM,
+ TF,
+ RF,
+ PT,
+ DL,
+ PO,
+ BA,
+ SB,
+ GB,
+ RX,
+ TX,
+ EN,
+ ST,
+ EX,
+ EXX,
+};
+
+enum E_MasterBlasterTestFlag
+{
+ MB_NO_TEST = 0,
+ MB_RX_TEST,
+ MB_TX_TEST,
+ MB_CONT_RX_TEST,
+ MB_CONT_TX_TEST,
+ MB_LE_RX_TEST,
+ MB_LE_TX_TEST,
+};
+
+enum E_DisableEnable
+{
+ DISABLE = 0,
+ ENABLE = 1,
+};
+
+#define MB_MIN_DATALEN 0
+#define MB_MAX_DATALEN 1021
+#define MB_MIN_FREQUENCY 0
+#define MB_MAX_FREQUENCY 79
+#define MB_MIN_FREQUENCY_LE 0
+#define MB_MAX_FREQUENCY_LE 39
+#define MB_MIN_DATALEN_LE 0
+#define MB_MAX_DATALEN_LE 37
+typedef struct STR_MasterBlasterOption
+{
+ char *Name;
+ int Value;
+} tMasterBlasterOption;
+
+typedef struct STR_MasterBlasterField
+{
+ char *Name;
+ char *Alias;
+ char *Usage;
+ int Default;
+ tMasterBlasterOption *Options;
+ int (*pFunc)(tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+} tMasterBlasterField;
+
+static tMasterBlasterOption TestModeOption[] =
+{
+ {"TX_0", eBRM_TestMode_TX_0},
+ {"TX_1", eBRM_TestMode_TX_1},
+ {"TX_1010", eBRM_TestMode_TX_1010},
+ {"TX_PRBS", eBRM_TestMode_TX_PRBS},
+ {"TX_11110000", eBRM_TestMode_TX_11110000},
+ {"RX", eBRM_TestMode_Rx},
+};
+
+static tMasterBlasterOption HopModeOption[] =
+{
+ {"Disable", DISABLE},
+ {"Enable", ENABLE},
+};
+
+static tMasterBlasterOption PacketTypeOption[] =
+{
+ {"DM1", TxTest_PktType_DM1},
+ {"DM3", TxTest_PktType_DM3},
+ {"DM5", TxTest_PktType_DM5},
+ {"DH1", TxTest_PktType_DH1},
+ {"DH3", TxTest_PktType_DH3},
+ {"DH5", TxTest_PktType_DH5},
+ {"2-DH1", TxTest_PktType_2DH1},
+ {"2-DH3", TxTest_PktType_2DH3},
+ {"2-DH5", TxTest_PktType_2DH5},
+ {"3-DH1", TxTest_PktType_3DH1},
+ {"3-DH3", TxTest_PktType_3DH3},
+ {"3-DH5", TxTest_PktType_3DH5},
+};
+
+static int MaxDataLenOption[] =
+{
+ DM1_MAX_PAYLOAD,
+ DM3_MAX_PAYLOAD,
+ DM5_MAX_PAYLOAD,
+ DH1_MAX_PAYLOAD,
+ DH3_MAX_PAYLOAD,
+ DH5_MAX_PAYLOAD,
+ E2_DH1_MAX_PAYLOAD,
+ E2_DH3_MAX_PAYLOAD,
+ E2_DH5_MAX_PAYLOAD,
+ E3_DH1_MAX_PAYLOAD,
+ E3_DH3_MAX_PAYLOAD,
+ E3_DH5_MAX_PAYLOAD,
+};
+
+enum {
+ eBRM_BERMode_ALL = 0, // ALL type
+ eBRM_BERMode_ALL_DATA, // All type except dm1,dm3,dm5
+ eBRM_BERMode_DM1,
+ eBRM_BERMode_DM3,
+ eBRM_BERMode_DM5,
+ eBRM_BERMode_DH1,
+ eBRM_BERMode_DH3,
+ eBRM_BERMode_DH5,
+ eBRM_BERMode_2DH1,
+ eBRM_BERMode_2DH3,
+ eBRM_BERMode_2DH5,
+ eBRM_BERMode_3DH1,
+ eBRM_BERMode_3DH3,
+ eBRM_BERMode_3DH5,
+};
+
+static tMasterBlasterOption BERPacketTypeOption[] =
+{
+ {"ALL", eBRM_BERMode_ALL},
+ {"ALL_DATA", eBRM_BERMode_ALL_DATA},
+ {"DM1", eBRM_BERMode_DM1},
+ {"DM3", eBRM_BERMode_DM3},
+ {"DM5", eBRM_BERMode_DM5},
+ {"DH1", eBRM_BERMode_DH1},
+ {"DH3", eBRM_BERMode_DH3},
+ {"DH5", eBRM_BERMode_DH5},
+ {"2DH1", eBRM_BERMode_2DH1},
+ {"2DH3", eBRM_BERMode_2DH3},
+ {"2DH5", eBRM_BERMode_2DH5},
+ {"3DH1", eBRM_BERMode_3DH1},
+ {"3DH3", eBRM_BERMode_3DH3},
+ {"3DH5", eBRM_BERMode_3DH5},
+};
+
+static tMasterBlasterOption ContTxModeOption[] =
+{
+ {"Disable", DISABLE},
+ {"Enable", ENABLE},
+};
+
+static tMasterBlasterOption ContTxTypeOption[] =
+{
+ {"Raw_1MHz", Cont_Tx_Raw_1MHz},
+ {"Raw_2MHz", Cont_Tx_Raw_2MHz},
+ {"Raw_3MHz", Cont_Tx_Raw_3MHz},
+ {"Regular_BT_Packet_Format", Cont_Tx_Regular},
+ {"CW_Single_Tone", CW_Single_Tone},
+};
+
+static tMasterBlasterOption ContRxModeOption[] =
+{
+ {"Disable", DISABLE},
+ {"Enable", ENABLE},
+};
+
+static tMasterBlasterOption LETxPktPayloadOption[] =
+{
+ {"Random_9", 0},
+ {"11110000", 1},
+ {"10101010", 2},
+ {"Random_15", 3},
+ {"11111111", 4},
+ {"00000000", 5},
+ {"00001111", 6},
+ {"01010101", 7},
+};
+
+//----------------------------------------------------------------------------
+// Prototypes
+//----------------------------------------------------------------------------
+
+void InitMasterBlaster (tBRM_Control_packet *MasterBlaster, bdaddr_t *BdAddr, UCHAR *SkipRxSlot);
+
+int CheckField (tBRM_Control_packet MasterBlaster, char *FieldAlias);
+int GetTestModeOptionIndex (int Mode);
+int GetPacketTypeOptionIndex (int PacketType);
+
+void PrintMasterBlasterMenu (tBRM_Control_packet *MasterBlaster);
+int SetMasterBlasterTestMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterHopMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterPacketType (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterTxFreq (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterRxFreq (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterPower (tBRM_Control_packet *MasterBlaster, char *Option);
+int SetMasterBlasterDataLen (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterBdAddr (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterContTxMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterContTxType (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterNothing (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterContRxMode (tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterLERxMode(tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterLETxMode(tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterLETxPktPayload(tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+int SetMasterBlasterBERType(tBRM_Control_packet *MasterBlaster, tMasterBlasterOption *Option);
+
+int ToggleOption (int *Value, tMasterBlasterOption *Option, tMasterBlasterOption *OptionArray,
+ int Size, int FieldID, int Step);
+int MinMaxOption (int *Value, tMasterBlasterOption *Option, int Min, int Max);
+int ToggleMinMaxOption (int *Value, char *Option, int FieldID, int Min, int Max, int Step);
+
+//----------------------------------------------------------------------------
+// Variables
+//----------------------------------------------------------------------------
+
+extern tMasterBlasterField MasterBlasterMenu[];
+extern tPsSysCfgTransmitPowerControlTable TpcTable;
+
+#endif // _MASTERBLASTER_H_
diff --git a/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/bmiloader b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/bmiloader
new file mode 100755
index 0000000..55626f6
--- /dev/null
+++ b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/bmiloader
Binary files differ
diff --git a/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/dbgParser b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/dbgParser
new file mode 100755
index 0000000..c12e413
--- /dev/null
+++ b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/dbgParser
Binary files differ
diff --git a/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/drvdebugctrl b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/drvdebugctrl
new file mode 100755
index 0000000..8bb12ad
--- /dev/null
+++ b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/drvdebugctrl
Binary files differ
diff --git a/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/eeprom b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/eeprom
new file mode 100755
index 0000000..a428f57
--- /dev/null
+++ b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/eeprom
Binary files differ
diff --git a/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/recEvent b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/recEvent
new file mode 100755
index 0000000..3f7ab32
--- /dev/null
+++ b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/recEvent
Binary files differ
diff --git a/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/restore.sh b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/restore.sh
new file mode 100755
index 0000000..953ee6e
--- /dev/null
+++ b/host/.output/A5S_ARM_NATIVEMMC-SDIO/image/restore.sh
@@ -0,0 +1,31 @@
+#!/bin/sh
+
+if [ -z "$WORKAREA" ]
+then
+ echo "Please set your WORKAREA environment variable."
+ exit
+fi
+
+if [ -z "$ATH_PLATFORM" ]
+then
+ echo "Please set your ATH_PLATFORM environment variable."
+ exit 1
+fi
+
+if [ -z "$NETIF" ]
+then
+ NETIF=eth1
+fi
+
+export IMAGEPATH=${IMAGEPATH:-$WORKAREA/host/.output/$ATH_PLATFORM/image}
+
+/sbin/ifconfig $NETIF down
+rmmod ar6000
+sleep 2
+case $ATH_PLATFORM in
+ LOCAL_i686-SDIO|LOCAL_i686-CF|SANDGATEII_ARM-SDIO|SANDGATEII_ARM-CF)
+ /sbin/insmod $IMAGEPATH/ar6000.ko
+ ;;
+ *)
+ /sbin/insmod $IMAGEPATH/ar6000.o
+esac
diff --git a/host/include/a_config.h b/host/include/a_config.h
new file mode 100644
index 0000000..087ad4c
--- /dev/null
+++ b/host/include/a_config.h
@@ -0,0 +1,58 @@
+//------------------------------------------------------------------------------
+// <copyright file="a_config.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains software configuration options that enables
+// specific software "features"
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_CONFIG_H_
+#define _A_CONFIG_H_
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/config.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/config.h"
+#endif
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "../os/linux/include/config_linux.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/config_rexos.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include "../os/windows/include/config.h"
+#pragma warning( disable:4242)
+#pragma warning( disable:4100)
+#pragma warning( disable:4189)
+#pragma warning( disable:4244)
+#pragma warning( disable:4701)
+#pragma warning( disable:4389)
+#pragma warning( disable:4057)
+#pragma warning( disable:28193)
+#endif
+
+#endif
+
diff --git a/host/include/a_debug.h b/host/include/a_debug.h
new file mode 100644
index 0000000..a1b732e
--- /dev/null
+++ b/host/include/a_debug.h
@@ -0,0 +1,220 @@
+//------------------------------------------------------------------------------
+// <copyright file="a_debug.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_DEBUG_H_
+#define _A_DEBUG_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+#include <a_types.h>
+#include <a_osapi.h>
+
+ /* standard debug print masks bits 0..7 */
+#define ATH_DEBUG_ERR (1 << 0) /* errors */
+#define ATH_DEBUG_WARN (1 << 1) /* warnings */
+#define ATH_DEBUG_INFO (1 << 2) /* informational (module startup info) */
+#define ATH_DEBUG_TRC (1 << 3) /* generic function call tracing */
+#define ATH_DEBUG_RSVD1 (1 << 4)
+#define ATH_DEBUG_RSVD2 (1 << 5)
+#define ATH_DEBUG_RSVD3 (1 << 6)
+#define ATH_DEBUG_RSVD4 (1 << 7)
+
+#define ATH_DEBUG_MASK_DEFAULTS (ATH_DEBUG_ERR | ATH_DEBUG_WARN)
+#define ATH_DEBUG_ANY 0xFFFF
+
+ /* other aliases used throughout */
+#define ATH_DEBUG_ERROR ATH_DEBUG_ERR
+#define ATH_LOG_ERR ATH_DEBUG_ERR
+#define ATH_LOG_INF ATH_DEBUG_INFO
+#define ATH_LOG_TRC ATH_DEBUG_TRC
+#define ATH_DEBUG_TRACE ATH_DEBUG_TRC
+#define ATH_DEBUG_INIT ATH_DEBUG_INFO
+
+ /* bits 8..31 are module-specific masks */
+#define ATH_DEBUG_MODULE_MASK_SHIFT 8
+
+ /* macro to make a module-specific masks */
+#define ATH_DEBUG_MAKE_MODULE_MASK(index) (1 << (ATH_DEBUG_MODULE_MASK_SHIFT + (index)))
+
+void DebugDumpBytes(A_UCHAR *buffer, A_UINT16 length, char *pDescription);
+
+/* Debug support on a per-module basis
+ *
+ * Usage:
+ *
+ * Each module can utilize it's own debug mask variable. A set of commonly used
+ * masks are provided (ERRORS, WARNINGS, TRACE etc..). It is up to each module
+ * to define module-specific masks using the macros above.
+ *
+ * Each module defines a single debug mask variable debug_XXX where the "name" of the module is
+ * common to all C-files within that module. This requires every C-file that includes a_debug.h
+ * to define the module name in that file.
+ *
+ * Example:
+ *
+ * #define ATH_MODULE_NAME htc
+ * #include "a_debug.h"
+ *
+ * This will define a debug mask structure called debug_htc and all debug macros will reference this
+ * variable.
+ *
+ * A module can define module-specific bit masks using the ATH_DEBUG_MAKE_MODULE_MASK() macro:
+ *
+ * #define ATH_DEBUG_MY_MASK1 ATH_DEBUG_MAKE_MODULE_MASK(0)
+ * #define ATH_DEBUG_MY_MASK2 ATH_DEBUG_MAKE_MODULE_MASK(1)
+ *
+ * The instantiation of the debug structure should be made by the module. When a module is
+ * instantiated, the module can set a description string, a default mask and an array of description
+ * entries containing information on each module-defined debug mask.
+ * NOTE: The instantiation is statically allocated, only one instance can exist per module.
+ *
+ * Example:
+ *
+ *
+ * #define ATH_DEBUG_BMI ATH_DEBUG_MAKE_MODULE_MASK(0)
+ *
+ * #ifdef DEBUG
+ * static ATH_DEBUG_MASK_DESCRIPTION bmi_debug_desc[] = {
+ * { ATH_DEBUG_BMI , "BMI Tracing"}, <== description of the module specific mask
+ * };
+ *
+ * ATH_DEBUG_INSTANTIATE_MODULE_VAR(bmi,
+ * "bmi" <== module name
+ * "Boot Manager Interface", <== description of module
+ * ATH_DEBUG_MASK_DEFAULTS, <== defaults
+ * ATH_DEBUG_DESCRIPTION_COUNT(bmi_debug_desc),
+ * bmi_debug_desc);
+ *
+ * #endif
+ *
+ * A module can optionally register it's debug module information in order for other tools to change the
+ * bit mask at runtime. A module can call A_REGISTER_MODULE_DEBUG_INFO() in it's module
+ * init code. This macro can be called multiple times without consequence. The debug info maintains
+ * state to indicate whether the information was previously registered.
+ *
+ * */
+
+#define ATH_DEBUG_MAX_MASK_DESC_LENGTH 32
+#define ATH_DEBUG_MAX_MOD_DESC_LENGTH 64
+
+typedef struct {
+ A_UINT32 Mask;
+ A_CHAR Description[ATH_DEBUG_MAX_MASK_DESC_LENGTH];
+} ATH_DEBUG_MASK_DESCRIPTION;
+
+#define ATH_DEBUG_INFO_FLAGS_REGISTERED (1 << 0)
+
+typedef struct _ATH_DEBUG_MODULE_DBG_INFO{
+ struct _ATH_DEBUG_MODULE_DBG_INFO *pNext;
+ A_CHAR ModuleName[16];
+ A_CHAR ModuleDescription[ATH_DEBUG_MAX_MOD_DESC_LENGTH];
+ A_UINT32 Flags;
+ A_UINT32 CurrentMask;
+ int MaxDescriptions;
+ ATH_DEBUG_MASK_DESCRIPTION *pMaskDescriptions; /* pointer to array of descriptions */
+} ATH_DEBUG_MODULE_DBG_INFO;
+
+#define ATH_DEBUG_DESCRIPTION_COUNT(d) (int)((sizeof((d))) / (sizeof(ATH_DEBUG_MASK_DESCRIPTION)))
+
+#define GET_ATH_MODULE_DEBUG_VAR_NAME(s) _XGET_ATH_MODULE_NAME_DEBUG_(s)
+#define GET_ATH_MODULE_DEBUG_VAR_MASK(s) _XGET_ATH_MODULE_NAME_DEBUG_(s).CurrentMask
+#define _XGET_ATH_MODULE_NAME_DEBUG_(s) debug_ ## s
+
+#ifdef DEBUG
+
+ /* for source files that will instantiate the debug variables */
+#define ATH_DEBUG_INSTANTIATE_MODULE_VAR(s,name,moddesc,initmask,count,descriptions) \
+ATH_DEBUG_MODULE_DBG_INFO GET_ATH_MODULE_DEBUG_VAR_NAME(s) = \
+ {NULL,(name),(moddesc),0,(initmask),count,(descriptions)}
+
+#ifdef ATH_MODULE_NAME
+extern ATH_DEBUG_MODULE_DBG_INFO GET_ATH_MODULE_DEBUG_VAR_NAME(ATH_MODULE_NAME);
+#define AR_DEBUG_LVL_CHECK(lvl) (GET_ATH_MODULE_DEBUG_VAR_MASK(ATH_MODULE_NAME) & (lvl))
+#endif /* ATH_MODULE_NAME */
+
+#define ATH_DEBUG_SET_DEBUG_MASK(s,lvl) GET_ATH_MODULE_DEBUG_VAR_MASK(s) = (lvl)
+
+#define ATH_DEBUG_DECLARE_EXTERN(s) \
+ extern ATH_DEBUG_MODULE_DBG_INFO GET_ATH_MODULE_DEBUG_VAR_NAME(s)
+
+#define AR_DEBUG_PRINTBUF(buffer, length, desc) DebugDumpBytes(buffer,length,desc)
+
+
+#define AR_DEBUG_ASSERT A_ASSERT
+
+void a_dump_module_debug_info(ATH_DEBUG_MODULE_DBG_INFO *pInfo);
+void a_register_module_debug_info(ATH_DEBUG_MODULE_DBG_INFO *pInfo);
+#define A_DUMP_MODULE_DEBUG_INFO(s) a_dump_module_debug_info(&(GET_ATH_MODULE_DEBUG_VAR_NAME(s)))
+#define A_REGISTER_MODULE_DEBUG_INFO(s) a_register_module_debug_info(&(GET_ATH_MODULE_DEBUG_VAR_NAME(s)))
+
+#else /* !DEBUG */
+ /* NON DEBUG */
+#define ATH_DEBUG_INSTANTIATE_MODULE_VAR(s,name,moddesc,initmask,count,descriptions)
+#define AR_DEBUG_LVL_CHECK(lvl) 0
+#define AR_DEBUG_PRINTBUF(buffer, length, desc)
+#define AR_DEBUG_ASSERT(test)
+#define ATH_DEBUG_DECLARE_EXTERN(s)
+#define ATH_DEBUG_SET_DEBUG_MASK(s,lvl)
+#define A_DUMP_MODULE_DEBUG_INFO(s)
+#define A_REGISTER_MODULE_DEBUG_INFO(s)
+
+#endif
+
+A_STATUS a_get_module_mask(A_CHAR *module_name, A_UINT32 *pMask);
+A_STATUS a_set_module_mask(A_CHAR *module_name, A_UINT32 Mask);
+void a_dump_module_debug_info_by_name(A_CHAR *module_name);
+void a_module_debug_support_init(void);
+void a_module_debug_support_cleanup(void);
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/debug.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/debug.h"
+#endif
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "../os/linux/include/debug_linux.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/debug_rexos.h"
+#endif
+
+#if defined ART_WIN
+#include "../os/win_art/include/debug_win.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include "../os/windows/include/win/debug_win.h"
+#endif
+
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif
+
diff --git a/host/include/a_drv.h b/host/include/a_drv.h
new file mode 100644
index 0000000..e86f2e5
--- /dev/null
+++ b/host/include/a_drv.h
@@ -0,0 +1,50 @@
+//------------------------------------------------------------------------------
+// <copyright file="a_drv.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_DRV_H_
+#define _A_DRV_H_
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "../os/linux/include/athdrv_linux.h"
+#endif
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/athdrv.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/athdrv.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/athdrv_rexos.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include "../os/windows/include/athdrv.h"
+#endif
+
+#endif /* _ADRV_H_ */
diff --git a/host/include/a_drv_api.h b/host/include/a_drv_api.h
new file mode 100644
index 0000000..1da72dd
--- /dev/null
+++ b/host/include/a_drv_api.h
@@ -0,0 +1,341 @@
+//------------------------------------------------------------------------------
+// <copyright file="a_drv_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_DRV_API_H_
+#define _A_DRV_API_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/****************************************************************************/
+/****************************************************************************/
+/** **/
+/** WMI related hooks **/
+/** **/
+/****************************************************************************/
+/****************************************************************************/
+
+#include <ar6000_api.h>
+
+#define A_WMI_CHANNELLIST_RX(devt, numChan, chanList) \
+ ar6000_channelList_rx((devt), (numChan), (chanList))
+
+#define A_WMI_SET_NUMDATAENDPTS(devt, num) \
+ ar6000_set_numdataendpts((devt), (num))
+
+#define A_WMI_CONTROL_TX(devt, osbuf, streamID) \
+ ar6000_control_tx((devt), (osbuf), (streamID))
+
+#define A_WMI_TARGETSTATS_EVENT(devt, pStats, len) \
+ ar6000_targetStats_event((devt), (pStats), (len))
+
+#define A_WMI_SCANCOMPLETE_EVENT(devt, status) \
+ ar6000_scanComplete_event((devt), (status))
+
+#ifdef CONFIG_HOST_DSET_SUPPORT
+
+#define A_WMI_DSET_DATA_REQ(devt, access_cookie, offset, length, targ_buf, targ_reply_fn, targ_reply_arg) \
+ ar6000_dset_data_req((devt), (access_cookie), (offset), (length), (targ_buf), (targ_reply_fn), (targ_reply_arg))
+
+#define A_WMI_DSET_CLOSE(devt, access_cookie) \
+ ar6000_dset_close((devt), (access_cookie))
+
+#endif
+
+#define A_WMI_DSET_OPEN_REQ(devt, id, targ_handle, targ_reply_fn, targ_reply_arg) \
+ ar6000_dset_open_req((devt), (id), (targ_handle), (targ_reply_fn), (targ_reply_arg))
+
+#define A_WMI_CONNECT_EVENT(devt, pEvt) \
+ ar6000_connect_event((devt), (pEvt))
+
+#define A_WMI_PSPOLL_EVENT(devt, aid)\
+ ar6000_pspoll_event((devt),(aid))
+
+#define A_WMI_DTIMEXPIRY_EVENT(devt)\
+ ar6000_dtimexpiry_event((devt))
+
+#ifdef WAPI_ENABLE
+#define A_WMI_WAPI_REKEY_EVENT(devt, type, mac)\
+ ap_wapi_rekey_event((devt),(type),(mac))
+#endif
+
+#ifdef P2P
+#define A_WMI_P2PGONEG_EVENT(devt, res, len)\
+ p2p_go_neg_event((devt),(res), (len))
+
+#define A_WMI_P2PGONEG_REQ_EVENT(devt, sa, dev_passwd_id)\
+ p2p_go_neg_req_event((devt), (sa), (dev_passwd_id))
+
+#define A_WMI_P2P_INVITE_SENT_RESULT_EVENT(devt, res, len)\
+ p2p_invite_sent_result_event((devt), (res), (len))
+
+#define A_WMI_P2P_INVITE_RCVD_RESULT_EVENT(devt, res, len)\
+ p2p_invite_rcvd_result_event((devt), (res), (len))
+
+#define A_WMI_P2PDEV_EVENT(devt, addr, dev_addr, \
+ pri_dev_type, dev_name, dev_name_len, config_methods,\
+ dev_capab, grp_capab)\
+ ar6000_p2pdev_event((devt), (addr), (dev_addr),\
+ (pri_dev_type), (dev_name), (dev_name_len), (config_methods),\
+ (dev_capab), (grp_capab))
+#define A_WMI_P2PDEV_LOST_EVENT(devt, dev_addr) \
+ ar6000_p2pdev_lost_event((devt),(dev_addr))
+
+#define A_WMI_P2P_PROV_DISC_REQ_EVENT(devt, peer, config_methods, dev_addr, \
+ pri_dev_type, dev_name, dev_name_len, supp_config_methods,\
+ dev_capab, group_capab) \
+ ar6000_p2p_prov_disc_req_event((devt), (peer), (config_methods), \
+ (dev_addr), (pri_dev_type), (dev_name), (dev_name_len),\
+ (supp_config_methods), (dev_capab), (group_capab))
+
+#define A_WMI_P2P_PROV_DISC_RESP_EVENT(devt, peer, config_methods) \
+ ar6000_p2p_prov_disc_resp_event((devt), (peer), (config_methods))
+
+#define A_WMI_GET_P2P_CTX(devt) \
+ get_p2p_ctx((devt))
+
+#define A_WMI_GET_WMI_CTX(devt) \
+ get_wmi_ctx((devt))
+
+#define A_WMI_GET_DEV_NETWORK_SUBTYPE(devt) \
+ get_network_subtype((devt))
+
+#define A_WMI_P2P_SD_RX_EVENT(devt, ev) \
+ ar6000_p2p_sd_rx_event((devt), (ev))
+#endif /* P2P */
+
+#ifdef CONFIG_WLAN_RFKILL
+#define A_WMI_RFKILL_STATE_CHANGE_EVENT(devt,radiostate) \
+ ar6000_rfkill_state_change_event((devt),(radiostate))
+
+#define A_WMI_RFKILL_GET_MODE_CMD_EVENT(devt,datap,len) \
+ ar6000_rfkill_get_mode_cmd_event_rx((devt),(datap));
+
+#endif
+
+#define A_WMI_REGDOMAIN_EVENT(devt, regCode) \
+ ar6000_regDomain_event((devt), (regCode))
+
+#define A_WMI_NEIGHBORREPORT_EVENT(devt, numAps, info) \
+ ar6000_neighborReport_event((devt), (numAps), (info))
+
+#define A_WMI_DISCONNECT_EVENT(devt, reason, bssid, assocRespLen, assocInfo, protocolReasonStatus) \
+ ar6000_disconnect_event((devt), (reason), (bssid), (assocRespLen), (assocInfo), (protocolReasonStatus))
+
+#ifdef ATH_SUPPORT_DFS
+
+#define A_WMI_DFS_ATTACH_EVENT(devt, capinfo) \
+ ar6000_dfs_attach_event((devt),(capinfo))
+
+#define A_WMI_DFS_INIT_EVENT(devt, capinfo) \
+ ar6000_dfs_init_event((devt),(capinfo))
+
+#define A_WMI_DFS_PHYERR_EVENT(devt, info) \
+ ar6000_dfs_phyerr_event((devt),(info))
+
+#define A_WMI_DFS_RESET_DELAYLINES_EVENT(devt) \
+ ar6000_dfs_reset_delaylines_event((devt))
+
+#define A_WMI_DFS_RESET_RADARQ_EVENT(devt) \
+ ar6000_dfs_reset_radarq_event((devt))
+
+#define A_WMI_DFS_RESET_AR_EVENT(devt) \
+ ar6000_dfs_reset_ar_event((devt))
+
+#define A_WMI_DFS_RESET_ARQ_EVENT(devt) \
+ ar6000_dfs_reset_arq_event((devt))
+
+#define A_WMI_DFS_SET_DUR_MULTIPLIER_EVENT(devt, value) \
+ ar6000_dfs_set_dur_multiplier_event((devt), (value))
+
+#define A_WMI_DFS_SET_BANGRADAR_EVENT(devt, value) \
+ ar6000_dfs_set_bangradar_event((devt), (value))
+
+#define A_WMI_DFS_SET_DEBUGLEVEL_EVENT(devt, value) \
+ ar6000_dfs_set_debuglevel_event((devt), (value))
+
+#endif /* ATH_SUPPORT_DFS */
+
+#define A_WMI_TKIP_MICERR_EVENT(devt, keyid, ismcast) \
+ ar6000_tkip_micerr_event((devt), (keyid), (ismcast))
+
+#define A_WMI_BITRATE_RX(devt, rateKbps) \
+ ar6000_bitrate_rx((devt), (rateKbps))
+
+#define A_WMI_TXPWR_RX(devt, txPwr) \
+ ar6000_txPwr_rx((devt), (txPwr))
+
+#define A_WMI_READY_EVENT(devt, datap, phyCap, sw_ver, abi_ver) \
+ ar6000_ready_event((devt), (datap), (phyCap), (sw_ver), (abi_ver))
+
+#define A_WMI_DBGLOG_INIT_DONE(devt) \
+ ar6000_dbglog_init_done(devt);
+
+#define A_WMI_RSSI_THRESHOLD_EVENT(devt, newThreshold, rssi) \
+ ar6000_rssiThreshold_event((devt), (newThreshold), (rssi))
+
+#define A_WMI_REPORT_ERROR_EVENT(devt, errorVal) \
+ ar6000_reportError_event((devt), (errorVal))
+
+#define A_WMI_ROAM_TABLE_EVENT(devt, pTbl) \
+ ar6000_roam_tbl_event((devt), (pTbl))
+
+#define A_WMI_ROAM_DATA_EVENT(devt, p) \
+ ar6000_roam_data_event((devt), (p))
+
+#define A_WMI_WOW_LIST_EVENT(devt, num_filters, wow_filters) \
+ ar6000_wow_list_event((devt), (num_filters), (wow_filters))
+
+#define A_WMI_CAC_EVENT(devt, ac, cac_indication, statusCode, tspecSuggestion) \
+ ar6000_cac_event((devt), (ac), (cac_indication), (statusCode), (tspecSuggestion))
+
+#define A_WMI_CHANNEL_CHANGE_EVENT(devt, oldChannel, newChannel) \
+ ar6000_channel_change_event((devt), (oldChannel), (newChannel))
+
+#define A_WMI_PMKID_LIST_EVENT(devt, num_pmkid, pmkid_list, bssid_list) \
+ ar6000_pmkid_list_event((devt), (num_pmkid), (pmkid_list), (bssid_list))
+
+#define A_WMI_PEER_EVENT(devt, eventCode, bssid) \
+ ar6000_peer_event ((devt), (eventCode), (bssid))
+
+#define A_WMI_WACINFO_EVENT(devt, pStats, len) \
+ ar6000_wacinfo_event((devt), (pStats), (len))
+
+#ifdef CONFIG_HOST_GPIO_SUPPORT
+
+#define A_WMI_GPIO_INTR_RX(devt, intr_mask, input_values) \
+ ar6000_gpio_intr_rx((devt), (intr_mask), (input_values))
+
+#define A_WMI_GPIO_DATA_RX(devt, reg_id, value) \
+ ar6000_gpio_data_rx((devt), (reg_id), (value))
+
+#define A_WMI_GPIO_ACK_RX(devt) \
+ ar6000_gpio_ack_rx((devt))
+
+#endif
+
+#ifdef SEND_EVENT_TO_APP
+
+#define A_WMI_SEND_EVENT_TO_APP(ar, eventId, datap, len) \
+ ar6000_send_event_to_app((ar), (eventId), (datap), (len))
+
+#define A_WMI_SEND_GENERIC_EVENT_TO_APP(ar, eventId, datap, len) \
+ ar6000_send_generic_event_to_app((ar), (eventId), (datap), (len))
+
+#else
+
+#define A_WMI_SEND_EVENT_TO_APP(ar, eventId, datap, len)
+#define A_WMI_SEND_GENERIC_EVENT_TO_APP(ar, eventId, datap, len)
+
+#endif
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+#define A_WMI_TCMD_RX_REPORT_EVENT(devt, results, len) \
+ ar6000_tcmd_rx_report_event((devt), (results), (len))
+#endif
+
+#define A_WMI_HBCHALLENGERESP_EVENT(devt, cookie, source) \
+ ar6000_hbChallengeResp_event((devt), (cookie), (source))
+
+#define A_WMI_TX_RETRY_ERR_EVENT(devt) \
+ ar6000_tx_retry_err_event((devt))
+
+#define A_WMI_SNR_THRESHOLD_EVENT_RX(devt, newThreshold, snr) \
+ ar6000_snrThresholdEvent_rx((devt), (newThreshold), (snr))
+
+#define A_WMI_LQ_THRESHOLD_EVENT_RX(devt, range, lqVal) \
+ ar6000_lqThresholdEvent_rx((devt), (range), (lqVal))
+
+#define A_WMI_RATEMASK_RX(devt, ratemask) \
+ ar6000_ratemask_rx((devt), (ratemask))
+
+#define A_WMI_KEEPALIVE_RX(devt, configured) \
+ ar6000_keepalive_rx((devt), (configured))
+
+#define A_WMI_BSSINFO_EVENT_RX(ar, datp, len) \
+ ar6000_bssInfo_event_rx((ar), (datap), (len))
+
+#define A_WMI_AP_MODE_PROBE_RX(ar, datp, len) \
+ ar6000_ap_mode_probe_rx((ar), (datap), (len))
+
+#define A_WMI_DBGLOG_EVENT(ar, dropped, buffer, length) \
+ ar6000_dbglog_event((ar), (dropped), (buffer), (length));
+
+#define A_WMI_STREAM_TX_ACTIVE(devt,trafficClass) \
+ ar6000_indicate_tx_activity((devt),(trafficClass), TRUE)
+
+#define A_WMI_STREAM_TX_INACTIVE(devt,trafficClass) \
+ ar6000_indicate_tx_activity((devt),(trafficClass), FALSE)
+#define A_WMI_Ac2EndpointID(devht, ac)\
+ ar6000_ac2_endpoint_id((devht), (ac))
+
+#define A_WMI_AGGR_RECV_ADDBA_REQ_EVT(devt, cmd)\
+ ar6000_aggr_rcv_addba_req_evt((devt), (cmd))
+#define A_WMI_AGGR_RECV_ADDBA_RESP_EVT(devt, cmd)\
+ ar6000_aggr_rcv_addba_resp_evt((devt), (cmd))
+#define A_WMI_AGGR_RECV_DELBA_REQ_EVT(devt, cmd)\
+ ar6000_aggr_rcv_delba_req_evt((devt), (cmd))
+#define A_WMI_HCI_EVENT_EVT(devt, cmd)\
+ ar6000_hci_event_rcv_evt((devt), (cmd))
+
+#define A_WMI_Endpoint2Ac(devt, ep) \
+ ar6000_endpoint_id2_ac((devt), (ep))
+
+#define A_WMI_BTCOEX_CONFIG_EVENT(devt, evt, len)\
+ ar6000_btcoex_config_event((devt), (evt), (len))
+
+#define A_WMI_BTCOEX_STATS_EVENT(devt, datap, len)\
+ ar6000_btcoex_stats_event((devt), (datap), (len))
+
+#define A_WMI_PROBERESP_RECV_EVENT(devt, datap, len, bssid)\
+ ar6000_indicate_proberesp((devt), (datap), (len), (bssid))
+
+#define A_WMI_BEACON_RECV_EVENT(devt, datap, len, bssid)\
+ ar6000_indicate_beacon((devt), (datap), (len), (bssid))
+
+#define A_WMI_ASSOC_REQ_REPORT_EVENT(devt, status, rspType, datap, len)\
+ ar6000_assoc_req_report_event((devt),(status),(rspType),(datap),(len))
+
+#define A_WMI_GET_DEVICE_ADDR(devt, addr) \
+ ar6000_get_device_addr((devt), (addr))
+
+#define A_WMI_GET_NETWORK_TYPE(devt) \
+ ar6000_get_network_type((devt))
+
+/****************************************************************************/
+/****************************************************************************/
+/** **/
+/** HTC related hooks **/
+/** **/
+/****************************************************************************/
+/****************************************************************************/
+
+#if defined(CONFIG_TARGET_PROFILE_SUPPORT)
+#define A_WMI_PROF_COUNT_RX(addr, count) prof_count_rx((addr), (count))
+#endif /* CONFIG_TARGET_PROFILE_SUPPORT */
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff --git a/host/include/a_hci.h b/host/include/a_hci.h
new file mode 100644
index 0000000..803f75c
--- /dev/null
+++ b/host/include/a_hci.h
@@ -0,0 +1,679 @@
+//-
+// Copyright (c) 2009-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+//
+//
+//
+//
+
+
+#ifndef __A_HCI_H__
+#define __A_HCI_H__
+
+#define HCI_CMD_OGF_MASK 0x3F
+#define HCI_CMD_OGF_SHIFT 10
+#define HCI_CMD_GET_OGF(opcode) ((opcode >> HCI_CMD_OGF_SHIFT) & HCI_CMD_OGF_MASK)
+
+#define HCI_CMD_OCF_MASK 0x3FF
+#define HCI_CMD_OCF_SHIFT 0
+#define HCI_CMD_GET_OCF(opcode) (((opcode) >> HCI_CMD_OCF_SHIFT) & HCI_CMD_OCF_MASK)
+
+#define HCI_FORM_OPCODE(ocf, ogf) ((ocf & HCI_CMD_OCF_MASK) << HCI_CMD_OCF_SHIFT | \
+ (ogf & HCI_CMD_OGF_MASK) << HCI_CMD_OGF_SHIFT)
+
+
+/*======== HCI Opcode groups ===============*/
+#define OGF_NOP 0x00
+#define OGF_LINK_CONTROL 0x01
+#define OGF_LINK_POLICY 0x03
+#define OGF_INFO_PARAMS 0x04
+#define OGF_STATUS 0x05
+#define OGF_TESTING 0x06
+#define OGF_BLUETOOTH 0x3E
+#define OGF_VENDOR_DEBUG 0x3F
+
+
+
+#define OCF_NOP 0x00
+
+
+/*===== Link Control Commands Opcode===================*/
+#define OCF_HCI_Create_Physical_Link 0x35
+#define OCF_HCI_Accept_Physical_Link_Req 0x36
+#define OCF_HCI_Disconnect_Physical_Link 0x37
+#define OCF_HCI_Create_Logical_Link 0x38
+#define OCF_HCI_Accept_Logical_Link 0x39
+#define OCF_HCI_Disconnect_Logical_Link 0x3A
+#define OCF_HCI_Logical_Link_Cancel 0x3B
+#define OCF_HCI_Flow_Spec_Modify 0x3C
+
+
+
+/*===== Link Policy Commands Opcode====================*/
+#define OCF_HCI_Set_Event_Mask 0x01
+#define OCF_HCI_Reset 0x03
+#define OCF_HCI_Read_Conn_Accept_Timeout 0x15
+#define OCF_HCI_Write_Conn_Accept_Timeout 0x16
+#define OCF_HCI_Read_Link_Supervision_Timeout 0x36
+#define OCF_HCI_Write_Link_Supervision_Timeout 0x37
+#define OCF_HCI_Enhanced_Flush 0x5F
+#define OCF_HCI_Read_Logical_Link_Accept_Timeout 0x61
+#define OCF_HCI_Write_Logical_Link_Accept_Timeout 0x62
+#define OCF_HCI_Set_Event_Mask_Page_2 0x63
+#define OCF_HCI_Read_Location_Data 0x64
+#define OCF_HCI_Write_Location_Data 0x65
+#define OCF_HCI_Read_Flow_Control_Mode 0x66
+#define OCF_HCI_Write_Flow_Control_Mode 0x67
+#define OCF_HCI_Read_BE_Flush_Timeout 0x69
+#define OCF_HCI_Write_BE_Flush_Timeout 0x6A
+#define OCF_HCI_Short_Range_Mode 0x6B
+
+
+/*======== Info Commands Opcode========================*/
+#define OCF_HCI_Read_Local_Ver_Info 0x01
+#define OCF_HCI_Read_Local_Supported_Cmds 0x02
+#define OCF_HCI_Read_Data_Block_Size 0x0A
+/*======== Status Commands Opcode======================*/
+#define OCF_HCI_Read_Failed_Contact_Counter 0x01
+#define OCF_HCI_Reset_Failed_Contact_Counter 0x02
+#define OCF_HCI_Read_Link_Quality 0x03
+#define OCF_HCI_Read_RSSI 0x05
+#define OCF_HCI_Read_Local_AMP_Info 0x09
+#define OCF_HCI_Read_Local_AMP_ASSOC 0x0A
+#define OCF_HCI_Write_Remote_AMP_ASSOC 0x0B
+
+
+/*======= AMP_ASSOC Specific TLV tags =================*/
+#define AMP_ASSOC_MAC_ADDRESS_INFO_TYPE 0x1
+#define AMP_ASSOC_PREF_CHAN_LIST 0x2
+#define AMP_ASSOC_CONNECTED_CHAN 0x3
+#define AMP_ASSOC_PAL_CAPABILITIES 0x4
+#define AMP_ASSOC_PAL_VERSION 0x5
+
+
+/*========= PAL Events =================================*/
+#define PAL_COMMAND_COMPLETE_EVENT 0x0E
+#define PAL_COMMAND_STATUS_EVENT 0x0F
+#define PAL_HARDWARE_ERROR_EVENT 0x10
+#define PAL_FLUSH_OCCURRED_EVENT 0x11
+#define PAL_LOOPBACK_EVENT 0x19
+#define PAL_BUFFER_OVERFLOW_EVENT 0x1A
+#define PAL_QOS_VIOLATION_EVENT 0x1E
+#define PAL_ENHANCED_FLUSH_COMPLT_EVENT 0x39
+#define PAL_PHYSICAL_LINK_COMPL_EVENT 0x40
+#define PAL_CHANNEL_SELECT_EVENT 0x41
+#define PAL_DISCONNECT_PHYSICAL_LINK_EVENT 0x42
+#define PAL_PHY_LINK_EARLY_LOSS_WARNING_EVENT 0x43
+#define PAL_PHY_LINK_RECOVERY_EVENT 0x44
+#define PAL_LOGICAL_LINK_COMPL_EVENT 0x45
+#define PAL_DISCONNECT_LOGICAL_LINK_COMPL_EVENT 0x46
+#define PAL_FLOW_SPEC_MODIFY_COMPL_EVENT 0x47
+#define PAL_NUM_COMPL_DATA_BLOCK_EVENT 0x48
+#define PAL_SHORT_RANGE_MODE_CHANGE_COMPL_EVENT 0x4C
+#define PAL_AMP_STATUS_CHANGE_EVENT 0x4D
+/*======== End of PAL events definiton =================*/
+
+
+/*======== Timeouts (not part of HCI cmd, but input to PAL engine) =========*/
+#define Timer_Conn_Accept_TO 0x01
+#define Timer_Link_Supervision_TO 0x02
+
+#define NUM_HCI_COMMAND_PKTS 0x1
+
+
+/*====== NOP Cmd ============================*/
+#define HCI_CMD_NOP HCI_FORM_OPCODE(OCF_NOP, OGF_NOP)
+
+
+/*===== Link Control Commands================*/
+#define HCI_Create_Physical_Link HCI_FORM_OPCODE(OCF_HCI_Create_Physical_Link, OGF_LINK_CONTROL)
+#define HCI_Accept_Physical_Link_Req HCI_FORM_OPCODE(OCF_HCI_Accept_Physical_Link_Req, OGF_LINK_CONTROL)
+#define HCI_Disconnect_Physical_Link HCI_FORM_OPCODE(OCF_HCI_Disconnect_Physical_Link, OGF_LINK_CONTROL)
+#define HCI_Create_Logical_Link HCI_FORM_OPCODE(OCF_HCI_Create_Logical_Link, OGF_LINK_CONTROL)
+#define HCI_Accept_Logical_Link HCI_FORM_OPCODE(OCF_HCI_Accept_Logical_Link, OGF_LINK_CONTROL)
+#define HCI_Disconnect_Logical_Link HCI_FORM_OPCODE(OCF_HCI_Disconnect_Logical_Link, OGF_LINK_CONTROL)
+#define HCI_Logical_Link_Cancel HCI_FORM_OPCODE(OCF_HCI_Logical_Link_Cancel, OGF_LINK_CONTROL)
+#define HCI_Flow_Spec_Modify HCI_FORM_OPCODE(OCF_HCI_Flow_Spec_Modify, OGF_LINK_CONTROL)
+
+
+/*===== Link Policy Commands ================*/
+#define HCI_Set_Event_Mask HCI_FORM_OPCODE(OCF_HCI_Set_Event_Mask, OGF_LINK_POLICY)
+#define HCI_Reset HCI_FORM_OPCODE(OCF_HCI_Reset, OGF_LINK_POLICY)
+#define HCI_Enhanced_Flush HCI_FORM_OPCODE(OCF_HCI_Enhanced_Flush, OGF_LINK_POLICY)
+#define HCI_Read_Conn_Accept_Timeout HCI_FORM_OPCODE(OCF_HCI_Read_Conn_Accept_Timeout, OGF_LINK_POLICY)
+#define HCI_Write_Conn_Accept_Timeout HCI_FORM_OPCODE(OCF_HCI_Write_Conn_Accept_Timeout, OGF_LINK_POLICY)
+#define HCI_Read_Logical_Link_Accept_Timeout HCI_FORM_OPCODE(OCF_HCI_Read_Logical_Link_Accept_Timeout, OGF_LINK_POLICY)
+#define HCI_Write_Logical_Link_Accept_Timeout HCI_FORM_OPCODE(OCF_HCI_Write_Logical_Link_Accept_Timeout, OGF_LINK_POLICY)
+#define HCI_Read_Link_Supervision_Timeout HCI_FORM_OPCODE(OCF_HCI_Read_Link_Supervision_Timeout, OGF_LINK_POLICY)
+#define HCI_Write_Link_Supervision_Timeout HCI_FORM_OPCODE(OCF_HCI_Write_Link_Supervision_Timeout, OGF_LINK_POLICY)
+#define HCI_Read_Location_Data HCI_FORM_OPCODE(OCF_HCI_Read_Location_Data, OGF_LINK_POLICY)
+#define HCI_Write_Location_Data HCI_FORM_OPCODE(OCF_HCI_Write_Location_Data, OGF_LINK_POLICY)
+#define HCI_Set_Event_Mask_Page_2 HCI_FORM_OPCODE(OCF_HCI_Set_Event_Mask_Page_2, OGF_LINK_POLICY)
+#define HCI_Read_Flow_Control_Mode HCI_FORM_OPCODE(OCF_HCI_Read_Flow_Control_Mode, OGF_LINK_POLICY)
+#define HCI_Write_Flow_Control_Mode HCI_FORM_OPCODE(OCF_HCI_Write_Flow_Control_Mode, OGF_LINK_POLICY)
+#define HCI_Write_BE_Flush_Timeout HCI_FORM_OPCODE(OCF_HCI_Write_BE_Flush_Timeout, OGF_LINK_POLICY)
+#define HCI_Read_BE_Flush_Timeout HCI_FORM_OPCODE(OCF_HCI_Read_BE_Flush_Timeout, OGF_LINK_POLICY)
+#define HCI_Short_Range_Mode HCI_FORM_OPCODE(OCF_HCI_Short_Range_Mode, OGF_LINK_POLICY)
+
+
+/*===== Info Commands =====================*/
+#define HCI_Read_Local_Ver_Info HCI_FORM_OPCODE(OCF_HCI_Read_Local_Ver_Info, OGF_INFO_PARAMS)
+#define HCI_Read_Local_Supported_Cmds HCI_FORM_OPCODE(OCF_HCI_Read_Local_Supported_Cmds, OGF_INFO_PARAMS)
+#define HCI_Read_Data_Block_Size HCI_FORM_OPCODE(OCF_HCI_Read_Data_Block_Size, OGF_INFO_PARAMS)
+
+/*===== Status Commands =====================*/
+#define HCI_Read_Link_Quality HCI_FORM_OPCODE(OCF_HCI_Read_Link_Quality, OGF_STATUS)
+#define HCI_Read_RSSI HCI_FORM_OPCODE(OCF_HCI_Read_RSSI, OGF_STATUS)
+#define HCI_Read_Local_AMP_Info HCI_FORM_OPCODE(OCF_HCI_Read_Local_AMP_Info, OGF_STATUS)
+#define HCI_Read_Local_AMP_ASSOC HCI_FORM_OPCODE(OCF_HCI_Read_Local_AMP_ASSOC, OGF_STATUS)
+#define HCI_Write_Remote_AMP_ASSOC HCI_FORM_OPCODE(OCF_HCI_Write_Remote_AMP_ASSOC, OGF_STATUS)
+
+/*====== End of cmd definitions =============*/
+
+
+
+/*===== Timeouts(private - can't come from HCI)=================*/
+#define Conn_Accept_TO HCI_FORM_OPCODE(Timer_Conn_Accept_TO, OGF_VENDOR_DEBUG)
+#define Link_Supervision_TO HCI_FORM_OPCODE(Timer_Link_Supervision_TO, OGF_VENDOR_DEBUG)
+
+/*----- PAL Constants (Sec 6 of Doc)------------------------*/
+#define Max80211_PAL_PDU_Size 1492
+#define Max80211_AMP_ASSOC_Len 672
+#define MinGUserPrio 4
+#define MaxGUserPrio 7
+#define BEUserPrio0 0
+#define BEUserPrio1 3
+#define Max80211BeaconPeriod 2000 /* in millisec */
+#define ShortRangeModePowerMax 4 /* dBm */
+
+/*------ PAL Protocol Identifiers (Sec5.1) ------------------*/
+typedef enum {
+ ACL_DATA = 0x01,
+ ACTIVITY_REPORT,
+ SECURED_FRAMES,
+ LINK_SUPERVISION_REQ,
+ LINK_SUPERVISION_RESP,
+}PAL_PROTOCOL_IDENTIFIERS;
+
+#define HCI_CMD_HDR_SZ 3
+#define HCI_EVENT_HDR_SIZE 2
+#define MAX_EVT_PKT_SZ 255
+#define AMP_ASSOC_MAX_FRAG_SZ 248
+#define AMP_MAX_GUARANTEED_BW 20000
+
+#define DEFAULT_CONN_ACCPT_TO 5000
+#define DEFAULT_LL_ACCPT_TO 5000
+#define DEFAULT_LSTO 10000
+
+#define PACKET_BASED_FLOW_CONTROL_MODE 0x00
+#define DATA_BLK_BASED_FLOW_CONTROL_MODE 0x01
+
+#define SERVICE_TYPE_BEST_EFFORT 0x01
+#define SERVICE_TYPE_GUARANTEED 0x02
+
+#define MAC_ADDR_LEN 6
+#define LINK_KEY_LEN 32
+
+typedef enum {
+ ACL_DATA_PB_1ST_NON_AUTOMATICALLY_FLUSHABLE = 0x00,
+ ACL_DATA_PB_CONTINUING_FRAGMENT = 0x01,
+ ACL_DATA_PB_1ST_AUTOMATICALLY_FLUSHABLE = 0x02,
+ ACL_DATA_PB_COMPLETE_PDU = 0x03,
+} ACL_DATA_PB_FLAGS;
+#define ACL_DATA_PB_FLAGS_SHIFT 12
+
+typedef enum {
+ ACL_DATA_BC_POINT_TO_POINT = 0x00,
+} ACL_DATA_BC_FLAGS;
+#define ACL_DATA_BC_FLAGS_SHIFT 14
+
+/* Command pkt */
+typedef struct hci_cmd_pkt_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 params[255];
+} POSTPACK HCI_CMD_PKT;
+
+#define ACL_DATA_HDR_SIZE 4 /* hdl_and flags + data_len */
+/* Data pkt */
+typedef struct hci_acl_data_pkt_t {
+ A_UINT16 hdl_and_flags;
+ A_UINT16 data_len;
+ A_UINT8 data[Max80211_PAL_PDU_Size];
+} POSTPACK HCI_ACL_DATA_PKT;
+
+/* Event pkt */
+typedef struct hci_event_pkt_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 params[256];
+} POSTPACK HCI_EVENT_PKT;
+
+
+/*============== HCI Command definitions ======================= */
+typedef struct hci_cmd_phy_link_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 phy_link_hdl;
+ A_UINT8 link_key_len;
+ A_UINT8 link_key_type;
+ A_UINT8 link_key[LINK_KEY_LEN];
+} POSTPACK HCI_CMD_PHY_LINK;
+
+typedef struct hci_cmd_write_rem_amp_assoc_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 phy_link_hdl;
+ A_UINT16 len_so_far;
+ A_UINT16 amp_assoc_remaining_len;
+ A_UINT8 amp_assoc_frag[AMP_ASSOC_MAX_FRAG_SZ];
+} POSTPACK HCI_CMD_WRITE_REM_AMP_ASSOC;
+
+
+typedef struct hci_cmd_opcode_hdl_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT16 hdl;
+} POSTPACK HCI_CMD_READ_LINK_QUAL,
+ HCI_CMD_FLUSH,
+ HCI_CMD_READ_LINK_SUPERVISION_TIMEOUT;
+
+typedef struct hci_cmd_read_local_amp_assoc_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 phy_link_hdl;
+ A_UINT16 len_so_far;
+ A_UINT16 max_rem_amp_assoc_len;
+} POSTPACK HCI_CMD_READ_LOCAL_AMP_ASSOC;
+
+
+typedef struct hci_cmd_set_event_mask_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT64 mask;
+}POSTPACK HCI_CMD_SET_EVT_MASK, HCI_CMD_SET_EVT_MASK_PG_2;
+
+
+typedef struct hci_cmd_enhanced_flush_t{
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT16 hdl;
+ A_UINT8 type;
+} POSTPACK HCI_CMD_ENHANCED_FLUSH;
+
+
+typedef struct hci_cmd_write_timeout_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT16 timeout;
+} POSTPACK HCI_CMD_WRITE_TIMEOUT;
+
+typedef struct hci_cmd_write_link_supervision_timeout_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT16 hdl;
+ A_UINT16 timeout;
+} POSTPACK HCI_CMD_WRITE_LINK_SUPERVISION_TIMEOUT;
+
+typedef struct hci_cmd_write_flow_control_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 mode;
+} POSTPACK HCI_CMD_WRITE_FLOW_CONTROL;
+
+typedef struct location_data_cfg_t {
+ A_UINT8 reg_domain_aware;
+ A_UINT8 reg_domain[3];
+ A_UINT8 reg_options;
+} POSTPACK LOCATION_DATA_CFG;
+
+typedef struct hci_cmd_write_location_data_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ LOCATION_DATA_CFG cfg;
+} POSTPACK HCI_CMD_WRITE_LOCATION_DATA;
+
+
+typedef struct flow_spec_t {
+ A_UINT8 id;
+ A_UINT8 service_type;
+ A_UINT16 max_sdu;
+ A_UINT32 sdu_inter_arrival_time;
+ A_UINT32 access_latency;
+ A_UINT32 flush_timeout;
+} POSTPACK FLOW_SPEC;
+
+
+typedef struct hci_cmd_create_logical_link_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 phy_link_hdl;
+ FLOW_SPEC tx_flow_spec;
+ FLOW_SPEC rx_flow_spec;
+} POSTPACK HCI_CMD_CREATE_LOGICAL_LINK;
+
+typedef struct hci_cmd_flow_spec_modify_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT16 hdl;
+ FLOW_SPEC tx_flow_spec;
+ FLOW_SPEC rx_flow_spec;
+} POSTPACK HCI_CMD_FLOW_SPEC_MODIFY;
+
+typedef struct hci_cmd_logical_link_cancel_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 phy_link_hdl;
+ A_UINT8 tx_flow_spec_id;
+} POSTPACK HCI_CMD_LOGICAL_LINK_CANCEL;
+
+typedef struct hci_cmd_disconnect_logical_link_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT16 logical_link_hdl;
+} POSTPACK HCI_CMD_DISCONNECT_LOGICAL_LINK;
+
+typedef struct hci_cmd_disconnect_phy_link_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 phy_link_hdl;
+} POSTPACK HCI_CMD_DISCONNECT_PHY_LINK;
+
+typedef struct hci_cmd_srm_t {
+ A_UINT16 opcode;
+ A_UINT8 param_length;
+ A_UINT8 phy_link_hdl;
+ A_UINT8 mode;
+} POSTPACK HCI_CMD_SHORT_RANGE_MODE;
+/*============== HCI Command definitions end ======================= */
+
+
+
+/*============== HCI Event definitions ============================= */
+
+/* Command complete event */
+typedef struct hci_event_cmd_complete_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 num_hci_cmd_pkts;
+ A_UINT16 opcode;
+ A_UINT8 params[255];
+} POSTPACK HCI_EVENT_CMD_COMPLETE;
+
+
+/* Command status event */
+typedef struct hci_event_cmd_status_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT8 num_hci_cmd_pkts;
+ A_UINT16 opcode;
+} POSTPACK HCI_EVENT_CMD_STATUS;
+
+/* Hardware Error event */
+typedef struct hci_event_hw_err_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 hw_err_code;
+} POSTPACK HCI_EVENT_HW_ERR;
+
+/* Flush occured event */
+/* Qos Violation event */
+typedef struct hci_event_handle_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT16 handle;
+} POSTPACK HCI_EVENT_FLUSH_OCCRD,
+ HCI_EVENT_QOS_VIOLATION;
+
+/* Loopback command event */
+typedef struct hci_loopback_cmd_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 params[252];
+} POSTPACK HCI_EVENT_LOOPBACK_CMD;
+
+/* Data buffer overflow event */
+typedef struct hci_data_buf_overflow_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 link_type;
+} POSTPACK HCI_EVENT_DATA_BUF_OVERFLOW;
+
+/* Enhanced Flush complete event */
+typedef struct hci_enhanced_flush_complt_t{
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT16 hdl;
+} POSTPACK HCI_EVENT_ENHANCED_FLUSH_COMPLT;
+
+/* Channel select event */
+typedef struct hci_event_chan_select_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 phy_link_hdl;
+} POSTPACK HCI_EVENT_CHAN_SELECT;
+
+/* Physical Link Complete event */
+typedef struct hci_event_phy_link_complete_event_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT8 phy_link_hdl;
+} POSTPACK HCI_EVENT_PHY_LINK_COMPLETE;
+
+/* Logical Link complete event */
+typedef struct hci_event_logical_link_complete_event_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT16 logical_link_hdl;
+ A_UINT8 phy_hdl;
+ A_UINT8 tx_flow_id;
+} POSTPACK HCI_EVENT_LOGICAL_LINK_COMPLETE_EVENT;
+
+/* Disconnect Logical Link complete event */
+typedef struct hci_event_disconnect_logical_link_event_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT16 logical_link_hdl;
+ A_UINT8 reason;
+} POSTPACK HCI_EVENT_DISCONNECT_LOGICAL_LINK_EVENT;
+
+/* Disconnect Physical Link complete event */
+typedef struct hci_event_disconnect_phy_link_complete_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT8 phy_link_hdl;
+ A_UINT8 reason;
+} POSTPACK HCI_EVENT_DISCONNECT_PHY_LINK_COMPLETE;
+
+typedef struct hci_event_physical_link_loss_early_warning_t{
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 phy_hdl;
+ A_UINT8 reason;
+} POSTPACK HCI_EVENT_PHY_LINK_LOSS_EARLY_WARNING;
+
+typedef struct hci_event_physical_link_recovery_t{
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 phy_hdl;
+} POSTPACK HCI_EVENT_PHY_LINK_RECOVERY;
+
+
+/* Flow spec modify complete event */
+/* Flush event */
+typedef struct hci_event_status_handle_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT16 handle;
+} POSTPACK HCI_EVENT_FLOW_SPEC_MODIFY,
+ HCI_EVENT_FLUSH;
+
+
+/* Num of completed data blocks event */
+typedef struct hci_event_num_of_compl_data_blks_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT16 num_data_blks;
+ A_UINT8 num_handles;
+ A_UINT8 params[255];
+} POSTPACK HCI_EVENT_NUM_COMPL_DATA_BLKS;
+
+/* Short range mode change complete event */
+typedef struct hci_srm_cmpl_t {
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT8 phy_link;
+ A_UINT8 state;
+} POSTPACK HCI_EVENT_SRM_COMPL;
+
+typedef struct hci_event_amp_status_change_t{
+ A_UINT8 event_code;
+ A_UINT8 param_len;
+ A_UINT8 status;
+ A_UINT8 amp_status;
+} POSTPACK HCI_EVENT_AMP_STATUS_CHANGE;
+
+/*============== Event definitions end =========================== */
+
+
+typedef struct local_amp_info_resp_t {
+ A_UINT8 status;
+ A_UINT8 amp_status;
+ A_UINT32 total_bw; /* kbps */
+ A_UINT32 max_guranteed_bw; /* kbps */
+ A_UINT32 min_latency;
+ A_UINT32 max_pdu_size;
+ A_UINT8 amp_type;
+ A_UINT16 pal_capabilities;
+ A_UINT16 amp_assoc_len;
+ A_UINT32 max_flush_timeout; /* in ms */
+ A_UINT32 be_flush_timeout; /* in ms */
+} POSTPACK LOCAL_AMP_INFO;
+
+typedef struct amp_assoc_cmd_resp_t{
+ A_UINT8 status;
+ A_UINT8 phy_hdl;
+ A_UINT16 amp_assoc_len;
+ A_UINT8 amp_assoc_frag[AMP_ASSOC_MAX_FRAG_SZ];
+}POSTPACK AMP_ASSOC_CMD_RESP;
+
+
+enum PAL_HCI_CMD_STATUS {
+ PAL_HCI_CMD_PROCESSED,
+ PAL_HCI_CMD_IGNORED
+};
+
+
+/*============= HCI Error Codes =======================*/
+#define HCI_SUCCESS 0x00
+#define HCI_ERR_UNKNOW_CMD 0x01
+#define HCI_ERR_UNKNOWN_CONN_ID 0x02
+#define HCI_ERR_HW_FAILURE 0x03
+#define HCI_ERR_PAGE_TIMEOUT 0x04
+#define HCI_ERR_AUTH_FAILURE 0x05
+#define HCI_ERR_KEY_MISSING 0x06
+#define HCI_ERR_MEM_CAP_EXECED 0x07
+#define HCI_ERR_CON_TIMEOUT 0x08
+#define HCI_ERR_CON_LIMIT_EXECED 0x09
+#define HCI_ERR_ACL_CONN_ALRDY_EXISTS 0x0B
+#define HCI_ERR_COMMAND_DISALLOWED 0x0C
+#define HCI_ERR_CONN_REJ_BY_LIMIT_RES 0x0D
+#define HCI_ERR_CONN_REJ_BY_SEC 0x0E
+#define HCI_ERR_CONN_REJ_BY_BAD_ADDR 0x0F
+#define HCI_ERR_CONN_ACCPT_TIMEOUT 0x10
+#define HCI_ERR_UNSUPPORT_FEATURE 0x11
+#define HCI_ERR_INVALID_HCI_CMD_PARAMS 0x12
+#define HCI_ERR_REMOTE_USER_TERMINATE_CONN 0x13
+#define HCI_ERR_CON_TERM_BY_HOST 0x16
+#define HCI_ERR_UNSPECIFIED_ERROR 0x1F
+#define HCI_ERR_ENCRYPTION_MODE_NOT_SUPPORT 0x25
+#define HCI_ERR_REQUESTED_QOS_NOT_SUPPORT 0x27
+#define HCI_ERR_QOS_UNACCEPTABLE_PARM 0x2C
+#define HCI_ERR_QOS_REJECTED 0x2D
+#define HCI_ERR_CONN_REJ_NO_SUITABLE_CHAN 0x39
+
+/*============= HCI Error Codes End =======================*/
+
+
+/* Following are event return parameters.. part of HCI events
+ */
+typedef struct timeout_read_t {
+ A_UINT8 status;
+ A_UINT16 timeout;
+}POSTPACK TIMEOUT_INFO;
+
+typedef struct link_supervision_timeout_read_t {
+ A_UINT8 status;
+ A_UINT16 hdl;
+ A_UINT16 timeout;
+}POSTPACK LINK_SUPERVISION_TIMEOUT_INFO;
+
+typedef struct status_hdl_t {
+ A_UINT8 status;
+ A_UINT16 hdl;
+}POSTPACK INFO_STATUS_HDL;
+
+typedef struct write_remote_amp_assoc_t{
+ A_UINT8 status;
+ A_UINT8 hdl;
+}POSTPACK WRITE_REMOTE_AMP_ASSOC_INFO;
+
+typedef struct read_loc_info_t {
+ A_UINT8 status;
+ LOCATION_DATA_CFG loc;
+}POSTPACK READ_LOC_INFO;
+
+typedef struct read_flow_ctrl_mode_t {
+ A_UINT8 status;
+ A_UINT8 mode;
+}POSTPACK READ_FLWCTRL_INFO;
+
+typedef struct read_data_blk_size_t {
+ A_UINT8 status;
+ A_UINT16 max_acl_data_pkt_len;
+ A_UINT16 data_block_len;
+ A_UINT16 total_num_data_blks;
+}POSTPACK READ_DATA_BLK_SIZE_INFO;
+
+/* Read Link quality info */
+typedef struct link_qual_t {
+ A_UINT8 status;
+ A_UINT16 hdl;
+ A_UINT8 link_qual;
+} POSTPACK READ_LINK_QUAL_INFO,
+ READ_RSSI_INFO;
+
+typedef struct ll_cancel_resp_t {
+ A_UINT8 status;
+ A_UINT8 phy_link_hdl;
+ A_UINT8 tx_flow_spec_id;
+} POSTPACK LL_CANCEL_RESP;
+
+typedef struct read_local_ver_info_t {
+ A_UINT8 status;
+ A_UINT8 hci_version;
+ A_UINT16 hci_revision;
+ A_UINT8 pal_version;
+ A_UINT16 manf_name;
+ A_UINT16 pal_sub_ver;
+} POSTPACK READ_LOCAL_VER_INFO;
+
+
+#endif /* __A_HCI_H__ */
diff --git a/host/include/a_osapi.h b/host/include/a_osapi.h
new file mode 100644
index 0000000..aa9103d
--- /dev/null
+++ b/host/include/a_osapi.h
@@ -0,0 +1,59 @@
+//------------------------------------------------------------------------------
+// <copyright file="a_osapi.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_OSAPI_H_
+#define _A_OSAPI_H_
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "../os/linux/include/osapi_linux.h"
+#endif
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/osapi.h"
+#include "../os/windows/include/netbuf.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/osapi.h"
+#include "../os/windows/include/netbuf.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/osapi_rexos.h"
+#endif
+
+#if defined ART_WIN
+#include "../os/win_art/include/osapi_win.h"
+#include "../os/win_art/include/netbuf.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include "../os/windows/include/win/osapi_win.h"
+#include "../os/windows/include/netbuf.h"
+#endif
+
+#endif /* _OSAPI_H_ */
+
diff --git a/host/include/a_types.h b/host/include/a_types.h
new file mode 100644
index 0000000..6586ac2
--- /dev/null
+++ b/host/include/a_types.h
@@ -0,0 +1,55 @@
+//------------------------------------------------------------------------------
+// <copyright file="a_types.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _A_TYPES_H_
+#define _A_TYPES_H_
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "../os/linux/include/athtypes_linux.h"
+#endif
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/athtypes.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/athtypes.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/athtypes_rexos.h"
+#endif
+
+#if defined ART_WIN
+#include "../os/win_art/include/athtypes_win.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include <athtypes_win.h>
+#endif
+
+#endif /* _ATHTYPES_H_ */
+
diff --git a/host/include/aggr_recv_api.h b/host/include/aggr_recv_api.h
new file mode 100644
index 0000000..acec0f4
--- /dev/null
+++ b/host/include/aggr_recv_api.h
@@ -0,0 +1,165 @@
+/*
+ *
+ * Copyright (c) 2004-2010 Atheros Communications Inc.
+ * All rights reserved.
+ *
+ *
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+ *
+ */
+
+#ifndef __AGGR_RECV_API_H__
+#define __AGGR_RECV_API_H__
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+typedef void (* RX_CALLBACK)(void * dev, void *osbuf);
+
+typedef void (* ALLOC_NETBUFS)(A_NETBUF_QUEUE_T *q, A_UINT16 num);
+
+/*
+ * aggr_init:
+ * Initialises the data structures, allocates data queues and
+ * os buffers. Netbuf allocator is the input param, used by the
+ * aggr module for allocation of NETBUFs from driver context.
+ * These NETBUFs are used for AMSDU processing.
+ *
+ * Also registers OS call back function to deliver the
+ * frames to OS. This is generally the topmost layer of
+ * the driver context, after which the frames go to
+ * IP stack via the call back function.
+ * This dispatcher is active only when aggregation is ON.
+ * Returns A_OK if init success, else returns A_ERROR
+ */
+A_UINT8
+aggr_init(ALLOC_NETBUFS netbuf_allocator, RX_CALLBACK fn);
+
+/*
+ * aggr_init_conn:
+ * Initialises the data structures, allocates data queues and
+ * os buffers. Returns the context for a single conn aggr.
+ * For each supported conn, this API should be called.
+ */
+void *
+aggr_init_conn(void);
+
+/*
+ * aggr_process_bar:
+ * When target receives BAR, it communicates to host driver
+ * for modifying window parameters. Target indicates this via the
+ * event: WMI_ADDBA_REQ_EVENTID. Host will dequeue all frames
+ * up to the indicated sequence number.
+ */
+void
+aggr_process_bar(void *cntxt, A_UINT8 tid, A_UINT16 seq_no);
+
+
+/*
+ * aggr_recv_addba_req_evt:
+ * This event is to initiate/modify the receive side window.
+ * Target will send WMI_ADDBA_REQ_EVENTID event to host - to setup
+ * recv re-ordering queues. Target will negotiate ADDBA with peer,
+ * and indicate via this event after succesfully completing the
+ * negotiation. This happens in two situations:
+ * 1. Initial setup of aggregation
+ * 2. Renegotiation of current recv window.
+ * Window size for re-ordering is limited by target buffer
+ * space, which is reflected in win_sz.
+ * (Re)Start the periodic timer to deliver long standing frames,
+ * in hold_q to OS.
+ */
+void
+aggr_recv_addba_req_evt(void * cntxt, A_UINT8 tid, A_UINT16 seq_no, A_UINT8 win_sz);
+
+
+/*
+ * aggr_recv_delba_req_evt:
+ * Target indicates deletion of a BA window for a tid via the
+ * WMI_DELBA_EVENTID. Host would deliver all the frames in the
+ * hold_q, reset tid config and disable the periodic timer, if
+ * aggr is not enabled on any tid.
+ */
+void
+aggr_recv_delba_req_evt(void * cntxt, A_UINT8 tid);
+
+
+
+/*
+ * aggr_process_recv_frm:
+ * Called only for data frames. When aggr is ON for a tid, the buffer
+ * is always consumed, and osbuf would be NULL. For a non-aggr case,
+ * osbuf is not modified.
+ * AMSDU frames are consumed and are later freed. They are sliced and
+ * diced to individual frames and dispatched to stack.
+ * After consuming a osbuf(when aggr is ON), a previously registered
+ * callback may be called to deliver frames in order.
+ */
+void
+aggr_process_recv_frm(void *cntxt, A_UINT8 tid, A_UINT16 seq_no, A_BOOL is_amsdu, void **osbuf);
+
+
+/*
+ * aggr_module_destroy:
+ * Frees up all the queues and frames in them.
+ */
+void
+aggr_module_destroy(void);
+
+/*
+ * * aggr_module_destroy_timers:
+ * * Disarm the timers.
+ * */
+void
+aggr_module_destroy_timers(void *cntxt);
+
+/*
+ * aggr_module_destroy_conn:
+ * Frees up all the queues and frames in them. Releases the cntxt to OS.
+ */
+void
+aggr_module_destroy_conn(void *cntxt);
+
+/*
+ * Dumps the aggregation stats
+ */
+void
+aggr_dump_stats(void *cntxt, PACKET_LOG **log_buf);
+
+/*
+ * aggr_reset_state -- Called when it is deemed necessary to clear the aggregate
+ * hold Q state. Examples include when a Connect event or disconnect event is
+ * received.
+ */
+void
+aggr_reset_state(void *cntxt, void *dev);
+
+
+/*
+ * aggr_reset_state -- Called when it is deemed necessary to clear the aggregate
+ * hold Q state. Examples include when a Connect event or disconnect event is
+ * received.
+ */
+void
+aggr_delba_request (void *cntxt, void *wmicntxt, A_UINT16 aid, A_UINT8 reasonCode);
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /*__AGGR_RECV_API_H__ */
diff --git a/host/include/ar3kconfig.h b/host/include/ar3kconfig.h
new file mode 100644
index 0000000..3a5584e
--- /dev/null
+++ b/host/include/ar3kconfig.h
@@ -0,0 +1,65 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+/* AR3K module configuration APIs for HCI-bridge operation */
+
+#ifndef AR3KCONFIG_H_
+#define AR3KCONFIG_H_
+
+#include <net/bluetooth/bluetooth.h>
+#include <net/bluetooth/hci_core.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define AR3K_CONFIG_FLAG_FORCE_MINBOOT_EXIT (1 << 0)
+#define AR3K_CONFIG_FLAG_SET_AR3K_BAUD (1 << 1)
+#define AR3K_CONFIG_FLAG_AR3K_BAUD_CHANGE_DELAY (1 << 2)
+#define AR3K_CONFIG_FLAG_SET_AR6K_SCALE_STEP (1 << 3)
+
+
+typedef struct {
+ A_UINT32 Flags; /* config flags */
+ void *pHCIDev; /* HCI bridge device */
+ HCI_TRANSPORT_PROPERTIES *pHCIProps; /* HCI bridge props */
+ HIF_DEVICE *pHIFDevice; /* HIF layer device */
+
+ A_UINT32 AR3KBaudRate; /* AR3K operational baud rate */
+ A_UINT16 AR6KScale; /* AR6K UART scale value */
+ A_UINT16 AR6KStep; /* AR6K UART step value */
+ struct hci_dev *pBtStackHCIDev; /* BT Stack HCI dev */
+ A_UINT32 PwrMgmtEnabled; /* TLPM enabled? */
+ A_UINT32 IdleTimeout; /* TLPM idle timeout */
+ A_UINT16 WakeupTimeout; /* TLPM wakeup timeout */
+ A_UINT8 bdaddr[6]; /* Bluetooth device address */
+} AR3K_CONFIG_INFO;
+
+A_STATUS AR3KConfigure(AR3K_CONFIG_INFO *pConfigInfo);
+
+A_STATUS AR3KConfigureExit(void *config);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /*AR3KCONFIG_H_*/
diff --git a/host/include/ar6000_api.h b/host/include/ar6000_api.h
new file mode 100644
index 0000000..62f7766
--- /dev/null
+++ b/host/include/ar6000_api.h
@@ -0,0 +1,54 @@
+//------------------------------------------------------------------------------
+// <copyright file="ar6000_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains the API to access the OS dependent atheros host driver
+// by the WMI or WLAN generic modules.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _AR6000_API_H_
+#define _AR6000_API_H_
+
+#if defined(__linux__) && !defined(LINUX_EMULATION)
+#include "../os/linux/include/ar6xapi_linux.h"
+#endif
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/ar6xapi.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/ar6xapi.h"
+#endif
+
+#ifdef REXOS
+#include "../os/rexos/include/common/ar6xapi_rexos.h"
+#endif
+
+#if defined ART_WIN
+#include "../os/win_art/include/ar6xapi_win.h"
+#endif
+
+#ifdef ATHR_WIN_NWF
+#include "../os/windows/include/ar6xapi.h"
+#endif
+
+#endif /* _AR6000_API_H */
+
diff --git a/host/include/ar6000_diag.h b/host/include/ar6000_diag.h
new file mode 100644
index 0000000..b53512e
--- /dev/null
+++ b/host/include/ar6000_diag.h
@@ -0,0 +1,48 @@
+//------------------------------------------------------------------------------
+// <copyright file="ar6000_diag.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef AR6000_DIAG_H_
+#define AR6000_DIAG_H_
+
+
+A_STATUS
+ar6000_ReadRegDiag(HIF_DEVICE *hifDevice, A_UINT32 *address, A_UINT32 *data);
+
+A_STATUS
+ar6000_WriteRegDiag(HIF_DEVICE *hifDevice, A_UINT32 *address, A_UINT32 *data);
+
+A_STATUS
+ar6000_ReadDataDiag(HIF_DEVICE *hifDevice, A_UINT32 address,
+ A_UCHAR *data, A_UINT32 length);
+
+A_STATUS
+ar6000_WriteDataDiag(HIF_DEVICE *hifDevice, A_UINT32 address,
+ A_UCHAR *data, A_UINT32 length);
+
+A_STATUS
+ar6k_ReadTargetRegister(HIF_DEVICE *hifDevice, int regsel, A_UINT32 *regval);
+
+void
+ar6k_FetchTargetRegs(HIF_DEVICE *hifDevice, A_UINT32 *targregs);
+
+#endif /*AR6000_DIAG_H_*/
diff --git a/host/include/ar6kap_common.h b/host/include/ar6kap_common.h
new file mode 100644
index 0000000..9ab8531
--- /dev/null
+++ b/host/include/ar6kap_common.h
@@ -0,0 +1,46 @@
+//------------------------------------------------------------------------------
+
+// <copyright file="ar6kap_common.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+
+//==============================================================================
+
+// This file contains the definitions of common AP mode data structures.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _AR6KAP_COMMON_H_
+#define _AR6KAP_COMMON_H_
+/*
+ * Used with AR6000_XIOCTL_AP_GET_STA_LIST
+ */
+typedef struct {
+ A_UINT8 mac[ATH_MAC_LEN];
+ A_UINT8 aid;
+ A_UINT8 keymgmt;
+ A_UINT8 ucipher;
+ A_UINT8 auth;
+ A_UINT8 wmode;
+} station_t;
+
+typedef struct {
+ station_t sta[AP_MAX_NUM_STA];
+} ap_get_sta_t;
+#endif /* _AR6KAP_COMMON_H_ */
diff --git a/host/include/athbtfilter.h b/host/include/athbtfilter.h
new file mode 100644
index 0000000..b7ba661
--- /dev/null
+++ b/host/include/athbtfilter.h
@@ -0,0 +1,135 @@
+//------------------------------------------------------------------------------
+// <copyright file="athbtfilter.h" company="Atheros">
+// Copyright (c) 2007-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Public Bluetooth filter APIs
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef ATHBTFILTER_H_
+#define ATHBTFILTER_H_
+
+#define ATH_DEBUG_INFO (1 << 2)
+#define ATH_DEBUG_INF ATH_DEBUG_INFO
+
+typedef enum _ATHBT_HCI_CTRL_TYPE {
+ ATHBT_HCI_COMMAND = 0,
+ ATHBT_HCI_EVENT = 1,
+} ATHBT_HCI_CTRL_TYPE;
+
+typedef enum _ATHBT_STATE_INDICATION {
+ ATH_BT_NOOP = 0,
+ ATH_BT_INQUIRY = 1,
+ ATH_BT_CONNECT = 2,
+ ATH_BT_SCO = 3,
+ ATH_BT_ACL = 4,
+ ATH_BT_A2DP = 5,
+ ATH_BT_ESCO = 6,
+ /* new states go here.. */
+
+ ATH_BT_MAX_STATE_INDICATION
+} ATHBT_STATE_INDICATION;
+
+ /* filter function for OUTGOING commands and INCOMMING events */
+typedef void (*ATHBT_FILTER_CMD_EVENTS_FN)(void *pContext, ATHBT_HCI_CTRL_TYPE Type, unsigned char *pBuffer, int Length);
+
+ /* filter function for OUTGOING data HCI packets */
+typedef void (*ATHBT_FILTER_DATA_FN)(void *pContext, unsigned char *pBuffer, int Length);
+
+typedef enum _ATHBT_STATE {
+ STATE_OFF = 0,
+ STATE_ON = 1,
+ STATE_MAX
+} ATHBT_STATE;
+
+ /* BT state indication (when filter functions are not used) */
+
+typedef void (*ATHBT_INDICATE_STATE_FN)(void *pContext, ATHBT_STATE_INDICATION Indication, ATHBT_STATE State, unsigned char LMPVersion);
+
+typedef struct _ATHBT_FILTER_INSTANCE {
+#ifdef UNDER_CE
+ WCHAR *pWlanAdapterName; /* filled in by user */
+#else
+ A_CHAR *pWlanAdapterName; /* filled in by user */
+#endif /* UNDER_CE */
+ int FilterEnabled; /* filtering is enabled */
+ int Attached; /* filter library is attached */
+ void *pContext; /* private context for filter library */
+ ATHBT_FILTER_CMD_EVENTS_FN pFilterCmdEvents; /* function ptr to filter a command or event */
+ ATHBT_FILTER_DATA_FN pFilterAclDataOut; /* function ptr to filter ACL data out (to radio) */
+ ATHBT_FILTER_DATA_FN pFilterAclDataIn; /* function ptr to filter ACL data in (from radio) */
+ ATHBT_INDICATE_STATE_FN pIndicateState; /* function ptr to indicate a state */
+} ATH_BT_FILTER_INSTANCE;
+
+
+/* API MACROS */
+
+#define AthBtFilterHciCommand(instance,packet,length) \
+ if ((instance)->FilterEnabled) { \
+ (instance)->pFilterCmdEvents((instance)->pContext, \
+ ATHBT_HCI_COMMAND, \
+ (unsigned char *)(packet), \
+ (length)); \
+ }
+
+#define AthBtFilterHciEvent(instance,packet,length) \
+ if ((instance)->FilterEnabled) { \
+ (instance)->pFilterCmdEvents((instance)->pContext, \
+ ATHBT_HCI_EVENT, \
+ (unsigned char *)(packet), \
+ (length)); \
+ }
+
+#define AthBtFilterHciAclDataOut(instance,packet,length) \
+ if ((instance)->FilterEnabled) { \
+ (instance)->pFilterAclDataOut((instance)->pContext, \
+ (unsigned char *)(packet), \
+ (length)); \
+ }
+
+#define AthBtFilterHciAclDataIn(instance,packet,length) \
+ if ((instance)->FilterEnabled) { \
+ (instance)->pFilterAclDataIn((instance)->pContext, \
+ (unsigned char *)(packet), \
+ (length)); \
+ }
+
+/* if filtering is not desired, the application can indicate the state directly using this
+ * macro:
+ */
+#define AthBtIndicateState(instance,indication,state) \
+ if ((instance)->FilterEnabled) { \
+ (instance)->pIndicateState((instance)->pContext, \
+ (indication), \
+ (state), \
+ 0); \
+ }
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* API prototypes */
+int AthBtFilter_Attach(ATH_BT_FILTER_INSTANCE *pInstance, A_UINT32 flags);
+void AthBtFilter_Detach(ATH_BT_FILTER_INSTANCE *pInstance);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /*ATHBTFILTER_H_*/
diff --git a/host/include/athdefs.h b/host/include/athdefs.h
new file mode 100644
index 0000000..2d7dc9c
--- /dev/null
+++ b/host/include/athdefs.h
@@ -0,0 +1,85 @@
+//------------------------------------------------------------------------------
+// <copyright file="athdefs.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef __ATHDEFS_H__
+#define __ATHDEFS_H__
+
+/*
+ * This file contains definitions that may be used across both
+ * Host and Target software. Nothing here is module-dependent
+ * or platform-dependent.
+ */
+
+/*
+ * Generic error codes that can be used by hw, sta, ap, sim, dk
+ * and any other environments. Since these are enums, feel free to
+ * add any more codes that you need.
+ */
+
+typedef enum {
+ A_ERROR = -1, /* Generic error return */
+ A_OK = 0, /* success */
+ /* Following values start at 1 */
+ A_DEVICE_NOT_FOUND, /* not able to find PCI device */
+ A_NO_MEMORY, /* not able to allocate memory, not available */
+ A_MEMORY_NOT_AVAIL, /* memory region is not free for mapping */
+ A_NO_FREE_DESC, /* no free descriptors available */
+ A_BAD_ADDRESS, /* address does not match descriptor */
+ A_WIN_DRIVER_ERROR, /* used in NT_HW version, if problem at init */
+ A_REGS_NOT_MAPPED, /* registers not correctly mapped */
+ A_EPERM, /* Not superuser */
+ A_EACCES, /* Access denied */
+ A_ENOENT, /* No such entry, search failed, etc. */
+ A_EEXIST, /* The object already exists (can't create) */
+ A_EFAULT, /* Bad address fault */
+ A_EBUSY, /* Object is busy */
+ A_EINVAL, /* Invalid parameter */
+ A_EMSGSIZE, /* Inappropriate message buffer length */
+ A_ECANCELED, /* Operation canceled */
+ A_ENOTSUP, /* Operation not supported */
+ A_ECOMM, /* Communication error on send */
+ A_EPROTO, /* Protocol error */
+ A_ENODEV, /* No such device */
+ A_EDEVNOTUP, /* device is not UP */
+ A_NO_RESOURCE, /* No resources for requested operation */
+ A_HARDWARE, /* Hardware failure */
+ A_PENDING, /* Asynchronous routine; will send up results la
+ter (typically in callback) */
+ A_EBADCHANNEL, /* The channel cannot be used */
+ A_DECRYPT_ERROR, /* Decryption error */
+ A_PHY_ERROR, /* RX PHY error */
+ A_CONSUMED /* Object was consumed */
+} A_STATUS;
+
+#define A_SUCCESS(x) (x == A_OK)
+#define A_FAILED(x) (!A_SUCCESS(x))
+
+#ifndef TRUE
+#define TRUE 1
+#endif
+
+#ifndef FALSE
+#define FALSE 0
+#endif
+
+#endif /* __ATHDEFS_H__ */
+
diff --git a/host/include/athendpack.h b/host/include/athendpack.h
new file mode 100644
index 0000000..96445d7
--- /dev/null
+++ b/host/include/athendpack.h
@@ -0,0 +1,52 @@
+//------------------------------------------------------------------------------
+// <copyright file="athendpack.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// end compiler-specific structure packing
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifdef VXWORKS
+#endif /* VXWORKS */
+
+#if defined(LINUX) || defined(__linux__)
+#endif /* LINUX */
+
+#ifdef QNX
+#endif /* QNX */
+
+#ifdef INTEGRITY
+#include "integrity/athendpack_integrity.h"
+#endif /* INTEGRITY */
+
+#ifdef NUCLEUS
+#endif /* NUCLEUS */
+
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/athendpack.h"
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/athendpack.h"
+#endif /* WINCE */
+
+#ifdef ATHR_WIN_NWF
+#include <athendpack_win.h>
+#endif
diff --git a/host/include/athstartpack.h b/host/include/athstartpack.h
new file mode 100644
index 0000000..c81435b
--- /dev/null
+++ b/host/include/athstartpack.h
@@ -0,0 +1,69 @@
+//------------------------------------------------------------------------------
+// <copyright file="athstartpack.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// start compiler-specific structure packing
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifdef VXWORKS
+#endif /* VXWORKS */
+
+#if defined(LINUX) || defined(__linux__)
+#endif /* LINUX */
+
+#ifdef QNX
+#endif /* QNX */
+
+#ifdef INTEGRITY
+#include "integrity/athstartpack_integrity.h"
+#endif /* INTEGRITY */
+
+#ifdef NUCLEUS
+#endif /* NUCLEUS */
+
+#ifdef ATHR_WM_NWF
+#include "../os/windows/include/athstartpack.h"
+#define PREPACK
+#endif
+
+#ifdef ATHR_CE_LEGACY
+#include "../os/windows/include/athstartpack.h"
+#endif /* WINCE */
+
+#ifdef ATHR_WIN_NWF
+
+#ifndef PREPACK
+#define PREPACK __declspec(align(1))
+#endif
+
+#include <athstartpack_win.h>
+#define __ATTRIB_PACK POSTPACK
+
+#endif
+
+#if __LONG_MAX__ == __INT_MAX__
+/* 32-bit compilation */
+#define PREPACK64
+#define POSTPACK64
+#else
+/* 64-bit compilation */
+#define PREPACK64 PREPACK
+#define POSTPACK64 POSTPACK
+#endif
diff --git a/host/include/bmi.h b/host/include/bmi.h
new file mode 100644
index 0000000..960294e
--- /dev/null
+++ b/host/include/bmi.h
@@ -0,0 +1,140 @@
+//------------------------------------------------------------------------------
+// <copyright file="bmi.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// BMI declarations and prototypes
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _BMI_H_
+#define _BMI_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/* Header files */
+#include "a_config.h"
+#include "athdefs.h"
+#include "a_types.h"
+#include "hif.h"
+#include "a_osapi.h"
+#include "bmi_msg.h"
+
+void
+BMIInit(void);
+
+void
+BMICleanup(void);
+
+A_STATUS
+BMIDone(HIF_DEVICE *device);
+
+A_STATUS
+BMIGetTargetInfo(HIF_DEVICE *device, struct bmi_target_info *targ_info);
+
+A_STATUS
+BMIReadMemory(HIF_DEVICE *device,
+ A_UINT32 address,
+ A_UCHAR *buffer,
+ A_UINT32 length);
+
+A_STATUS
+BMIWriteMemory(HIF_DEVICE *device,
+ A_UINT32 address,
+ A_UCHAR *buffer,
+ A_UINT32 length);
+
+A_STATUS
+BMIExecute(HIF_DEVICE *device,
+ A_UINT32 address,
+ A_UINT32 *param);
+
+A_STATUS
+BMISetAppStart(HIF_DEVICE *device,
+ A_UINT32 address);
+
+A_STATUS
+BMIReadSOCRegister(HIF_DEVICE *device,
+ A_UINT32 address,
+ A_UINT32 *param);
+
+A_STATUS
+BMIWriteSOCRegister(HIF_DEVICE *device,
+ A_UINT32 address,
+ A_UINT32 param);
+
+A_STATUS
+BMIrompatchInstall(HIF_DEVICE *device,
+ A_UINT32 ROM_addr,
+ A_UINT32 RAM_addr,
+ A_UINT32 nbytes,
+ A_UINT32 do_activate,
+ A_UINT32 *patch_id);
+
+A_STATUS
+BMIrompatchUninstall(HIF_DEVICE *device,
+ A_UINT32 rompatch_id);
+
+A_STATUS
+BMIrompatchActivate(HIF_DEVICE *device,
+ A_UINT32 rompatch_count,
+ A_UINT32 *rompatch_list);
+
+A_STATUS
+BMIrompatchDeactivate(HIF_DEVICE *device,
+ A_UINT32 rompatch_count,
+ A_UINT32 *rompatch_list);
+
+A_STATUS
+BMILZStreamStart(HIF_DEVICE *device,
+ A_UINT32 address);
+
+A_STATUS
+BMILZData(HIF_DEVICE *device,
+ A_UCHAR *buffer,
+ A_UINT32 length);
+
+A_STATUS
+BMIFastDownload(HIF_DEVICE *device,
+ A_UINT32 address,
+ A_UCHAR *buffer,
+ A_UINT32 length);
+
+A_STATUS
+BMInvramProcess(HIF_DEVICE *device,
+ A_UCHAR *seg_name,
+ A_UINT32 *retval);
+
+A_STATUS
+BMIRawWrite(HIF_DEVICE *device,
+ A_UCHAR *buffer,
+ A_UINT32 length);
+
+A_STATUS
+BMIRawRead(HIF_DEVICE *device,
+ A_UCHAR *buffer,
+ A_UINT32 length,
+ A_BOOL want_timeout);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _BMI_H_ */
diff --git a/host/include/bmi_msg.h b/host/include/bmi_msg.h
new file mode 100644
index 0000000..e7032ab
--- /dev/null
+++ b/host/include/bmi_msg.h
@@ -0,0 +1,334 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __BMI_MSG_H__
+#define __BMI_MSG_H__
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+/*
+ * Bootloader Messaging Interface (BMI)
+ *
+ * BMI is a very simple messaging interface used during initialization
+ * to read memory, write memory, execute code, and to define an
+ * application entry PC.
+ *
+ * It is used to download an application to AR6K, to provide
+ * patches to code that is already resident on AR6K, and generally
+ * to examine and modify state. The Host has an opportunity to use
+ * BMI only once during bootup. Once the Host issues a BMI_DONE
+ * command, this opportunity ends.
+ *
+ * The Host writes BMI requests to mailbox0, and reads BMI responses
+ * from mailbox0. BMI requests all begin with a command
+ * (see below for specific commands), and are followed by
+ * command-specific data.
+ *
+ * Flow control:
+ * The Host can only issue a command once the Target gives it a
+ * "BMI Command Credit", using AR6K Counter #4. As soon as the
+ * Target has completed a command, it issues another BMI Command
+ * Credit (so the Host can issue the next command).
+ *
+ * BMI handles all required Target-side cache flushing.
+ */
+
+
+/* Maximum data size used for BMI transfers */
+#define BMI_DATASZ_MAX 256
+
+/* BMI Commands */
+
+#define BMI_NO_COMMAND 0
+
+#define BMI_DONE 1
+ /*
+ * Semantics: Host is done using BMI
+ * Request format:
+ * A_UINT32 command (BMI_DONE)
+ * Response format: none
+ */
+
+#define BMI_READ_MEMORY 2
+ /*
+ * Semantics: Host reads AR6K memory
+ * Request format:
+ * A_UINT32 command (BMI_READ_MEMORY)
+ * A_UINT32 address
+ * A_UINT32 length, at most BMI_DATASZ_MAX
+ * Response format:
+ * A_UINT8 data[length]
+ */
+
+#define BMI_WRITE_MEMORY 3
+ /*
+ * Semantics: Host writes AR6K memory
+ * Request format:
+ * A_UINT32 command (BMI_WRITE_MEMORY)
+ * A_UINT32 address
+ * A_UINT32 length, at most BMI_DATASZ_MAX
+ * A_UINT8 data[length]
+ * Response format: none
+ */
+/*
+ * Capbility to write "segmented files" is provided for two reasons
+ * 1) backwards compatibility for certain situations where Hosts
+ * have limited flexibility
+ * 2) because it's darn convenient.
+ *
+ * A segmented file consists of a file header followed by an arbitrary number
+ * of segments. Each segment contains segment metadata -- a Target address and
+ * a length -- followed by "length" bytes of data. A segmented file ends with
+ * a segment that specifies length=BMI_SGMTFILE_DONE. When a segmented file
+ * is sent to the Target, firmware writes each segment to the specified address.
+ *
+ * Special cases:
+ * 1) If a segment's metadata indicates length=BMI_SGMTFILE_EXEC, then the
+ * specified address is used as a function entry point for a brief function
+ * with prototype "(void *)(void)". That function is called immediately.
+ * After execution of the function completes, firmware continues with the
+ * next segment. No data is expected when length=BMI_SGMTFILE_EXEC.
+ *
+ * 2) If a segment's metadata indicates length=BMI_SGMTFILE_BEGINADDR, then
+ * the specified address is established as the application start address
+ * so that a subsequent BMI_DONE jumps there.
+ *
+ * 3) If a segment's metadata indicates length=BMI_SGMTFILE_BDDATA, then
+ * the specified address is used as the (possibly compressed) length of board
+ * data, which is loaded into the proper Target address as specified by
+ * hi_board_data. In addition, the hi_board_data_initialized flag is set.
+ *
+ * A segmented file is sent to the Target using a sequence of 1 or more
+ * BMI_WRITE_MEMORY commands. The first such command must have
+ * address=BMI_SEGMENTED_WRITE_ADDR. Subsequent BMI_WRITE_MEMORY commands
+ * can use an arbitrary address. In each BMI_WRITE_MEMORY command, the
+ * length specifies the number of data bytes transmitted (except for the
+ * special cases listed above).
+ *
+ * Alternatively, a segmented file may be sent to the Target using a
+ * BMI_LZ_STREAM_START command with address=BMI_SEGMENTED_WRITE_ADDR
+ * followed by a series of BMI_LZ_DATA commands that each send the next portion
+ * of the segmented file.
+ *
+ * The data segments may be lz77 compressed. In this case, the segmented file
+ * header flag, BMI_SGMTFILE_FLAG_COMPRESS, must be set. Note that segmented
+ * file METAdata is never compressed; only the data segments themselves are
+ * compressed. There is no way to mix compressed and uncompressed data segments
+ * in a single segmented file. Compressed (or uncompressed) segments are handled
+ * by both BMI_WRITE_MEMORY and by BMI_LZ_DATA commands. (Compression is an
+ * attribute of the segmented file rather than of the command used to transmit
+ * it.)
+ */
+#define BMI_SEGMENTED_WRITE_ADDR 0x1234
+
+/* File header for a segmented file */
+struct bmi_segmented_file_header {
+ A_UINT32 magic_num;
+ A_UINT32 file_flags;
+};
+#define BMI_SGMTFILE_MAGIC_NUM 0x544d4753 /* "SGMT" */
+#define BMI_SGMTFILE_FLAG_COMPRESS 1
+
+/* Metadata for a segmented file segment */
+struct bmi_segmented_metadata {
+ A_UINT32 addr;
+ A_UINT32 length;
+};
+/* Special values for bmi_segmented_metadata.length (all have high bit set) */
+#define BMI_SGMTFILE_DONE 0xffffffff /* end of segmented data */
+#define BMI_SGMTFILE_BDDATA 0xfffffffe /* Board Data segment */
+#define BMI_SGMTFILE_BEGINADDR 0xfffffffd /* set beginning address */
+#define BMI_SGMTFILE_EXEC 0xfffffffc /* immediate function execution */
+
+#define BMI_EXECUTE 4
+ /*
+ * Semantics: Causes AR6K to execute code
+ * Request format:
+ * A_UINT32 command (BMI_EXECUTE)
+ * A_UINT32 address
+ * A_UINT32 parameter
+ * Response format:
+ * A_UINT32 return value
+ */
+/*
+ * Note: In order to support the segmented file feature
+ * (see BMI_WRITE_MEMORY), when the address specified in a
+ * BMI_EXECUTE command matches (same physical address)
+ * BMI_SEGMENTED_WRITE_ADDR, it is ignored. Instead, execution
+ * begins at the address specified by hi_app_start.
+ */
+
+#define BMI_SET_APP_START 5
+ /*
+ * Semantics: Set Target application starting address
+ * Request format:
+ * A_UINT32 command (BMI_SET_APP_START)
+ * A_UINT32 address
+ * Response format: none
+ */
+
+#define BMI_READ_SOC_REGISTER 6
+ /*
+ * Semantics: Read a 32-bit Target SOC register.
+ * Request format:
+ * A_UINT32 command (BMI_READ_REGISTER)
+ * A_UINT32 address
+ * Response format:
+ * A_UINT32 value
+ */
+
+#define BMI_WRITE_SOC_REGISTER 7
+ /*
+ * Semantics: Write a 32-bit Target SOC register.
+ * Request format:
+ * A_UINT32 command (BMI_WRITE_REGISTER)
+ * A_UINT32 address
+ * A_UINT32 value
+ *
+ * Response format: none
+ */
+
+#define BMI_GET_TARGET_ID 8
+#define BMI_GET_TARGET_INFO 8
+ /*
+ * Semantics: Fetch the 4-byte Target information
+ * Request format:
+ * A_UINT32 command (BMI_GET_TARGET_ID/INFO)
+ * Response format1 (old firmware):
+ * A_UINT32 TargetVersionID
+ * Response format2 (newer firmware):
+ * A_UINT32 TARGET_VERSION_SENTINAL
+ * struct bmi_target_info;
+ */
+
+PREPACK struct bmi_target_info {
+ A_UINT32 target_info_byte_count; /* size of this structure */
+ A_UINT32 target_ver; /* Target Version ID */
+ A_UINT32 target_type; /* Target type */
+} POSTPACK;
+#define TARGET_VERSION_SENTINAL 0xffffffff
+#define TARGET_TYPE_AR6001 1
+#define TARGET_TYPE_AR6002 2
+#define TARGET_TYPE_AR6003 3
+#define TARGET_TYPE_MCKINLEY 5
+
+
+#define BMI_ROMPATCH_INSTALL 9
+ /*
+ * Semantics: Install a ROM Patch.
+ * Request format:
+ * A_UINT32 command (BMI_ROMPATCH_INSTALL)
+ * A_UINT32 Target ROM Address
+ * A_UINT32 Target RAM Address or Value (depending on Target Type)
+ * A_UINT32 Size, in bytes
+ * A_UINT32 Activate? 1-->activate;
+ * 0-->install but do not activate
+ * Response format:
+ * A_UINT32 PatchID
+ */
+
+#define BMI_ROMPATCH_UNINSTALL 10
+ /*
+ * Semantics: Uninstall a previously-installed ROM Patch,
+ * automatically deactivating, if necessary.
+ * Request format:
+ * A_UINT32 command (BMI_ROMPATCH_UNINSTALL)
+ * A_UINT32 PatchID
+ *
+ * Response format: none
+ */
+
+#define BMI_ROMPATCH_ACTIVATE 11
+ /*
+ * Semantics: Activate a list of previously-installed ROM Patches.
+ * Request format:
+ * A_UINT32 command (BMI_ROMPATCH_ACTIVATE)
+ * A_UINT32 rompatch_count
+ * A_UINT32 PatchID[rompatch_count]
+ *
+ * Response format: none
+ */
+
+#define BMI_ROMPATCH_DEACTIVATE 12
+ /*
+ * Semantics: Deactivate a list of active ROM Patches.
+ * Request format:
+ * A_UINT32 command (BMI_ROMPATCH_DEACTIVATE)
+ * A_UINT32 rompatch_count
+ * A_UINT32 PatchID[rompatch_count]
+ *
+ * Response format: none
+ */
+
+
+#define BMI_LZ_STREAM_START 13
+ /*
+ * Semantics: Begin an LZ-compressed stream of input
+ * which is to be uncompressed by the Target to an
+ * output buffer at address. The output buffer must
+ * be sufficiently large to hold the uncompressed
+ * output from the compressed input stream. This BMI
+ * command should be followed by a series of 1 or more
+ * BMI_LZ_DATA commands.
+ * A_UINT32 command (BMI_LZ_STREAM_START)
+ * A_UINT32 address
+ * Note: Not supported on all versions of ROM firmware.
+ */
+
+#define BMI_LZ_DATA 14
+ /*
+ * Semantics: Host writes AR6K memory with LZ-compressed
+ * data which is uncompressed by the Target. This command
+ * must be preceded by a BMI_LZ_STREAM_START command. A series
+ * of BMI_LZ_DATA commands are considered part of a single
+ * input stream until another BMI_LZ_STREAM_START is issued.
+ * Request format:
+ * A_UINT32 command (BMI_LZ_DATA)
+ * A_UINT32 length (of compressed data),
+ * at most BMI_DATASZ_MAX
+ * A_UINT8 CompressedData[length]
+ * Response format: none
+ * Note: Not supported on all versions of ROM firmware.
+ */
+
+#define BMI_NVRAM_PROCESS 15
+#define BMI_NVRAM_SEG_NAME_SZ 16
+ /*
+ * Semantics: Cause Target to search NVRAM (if any) for a
+ * segment with the specified name and process it according
+ * to NVRAM metadata.
+ * Request format:
+ * A_UINT32 command (BMI_NVRAM_PROCESS)
+ * A_UCHAR name[BMI_NVRAM_SEG_NAME_SZ] name (LE format)
+ * Response format:
+ * A_UINT32 0, if nothing was executed;
+ * otherwise the value returned from the
+ * last NVRAM segment that was executed
+ */
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#endif /* __BMI_MSG_H__ */
diff --git a/host/include/btcoexGpio.h b/host/include/btcoexGpio.h
new file mode 100644
index 0000000..15f3f01
--- /dev/null
+++ b/host/include/btcoexGpio.h
@@ -0,0 +1,86 @@
+// Copyright (c) 2010 Atheros Communications Inc.
+// All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+
+#ifndef BTCOEX_GPIO_H_
+#define BTCOEX_GPIO_H_
+
+
+
+#ifdef FPGA
+#define GPIO_A (15)
+#define GPIO_B (16)
+#define GPIO_C (17)
+#define GPIO_D (18)
+#define GPIO_E (19)
+#define GPIO_F (21)
+#define GPIO_G (21)
+#else
+#define GPIO_A (0)
+#define GPIO_B (5)
+#define GPIO_C (6)
+#define GPIO_D (7)
+#define GPIO_E (7)
+#define GPIO_F (7)
+#define GPIO_G (7)
+#endif
+
+
+
+
+
+#define GPIO_DEBUG_WORD_1 (1<<GPIO_A)
+#define GPIO_DEBUG_WORD_2 (1<<GPIO_B)
+#define GPIO_DEBUG_WORD_3 ((1<<GPIO_B) | (1<<GPIO_A))
+#define GPIO_DEBUG_WORD_4 (1<<GPIO_C)
+#define GPIO_DEBUG_WORD_5 ((1<<GPIO_C) | (1<<GPIO_A))
+#define GPIO_DEBUG_WORD_6 ((1<<GPIO_C) | (1<<GPIO_B))
+#define GPIO_DEBUG_WORD_7 ((1<<GPIO_C) | (1<<GPIO_B) | (1<<GPIO_A))
+
+#define GPIO_DEBUG_WORD_8 (1<<GPIO_D)
+#define GPIO_DEBUG_WORD_9 ((1<<GPIO_D) | GPIO_DEBUG_WORD_1)
+#define GPIO_DEBUG_WORD_10 ((1<<GPIO_D) | GPIO_DEBUG_WORD_2)
+#define GPIO_DEBUG_WORD_11 ((1<<GPIO_D) | GPIO_DEBUG_WORD_3)
+#define GPIO_DEBUG_WORD_12 ((1<<GPIO_D) | GPIO_DEBUG_WORD_4)
+#define GPIO_DEBUG_WORD_13 ((1<<GPIO_D) | GPIO_DEBUG_WORD_5)
+#define GPIO_DEBUG_WORD_14 ((1<<GPIO_D) | GPIO_DEBUG_WORD_6)
+#define GPIO_DEBUG_WORD_15 ((1<<GPIO_D) | GPIO_DEBUG_WORD_7)
+
+#define GPIO_DEBUG_WORD_16 (1<<GPIO_E)
+#define GPIO_DEBUG_WORD_17 ((1<<GPIO_E) | GPIO_DEBUG_WORD_1)
+#define GPIO_DEBUG_WORD_18 ((1<<GPIO_E) | GPIO_DEBUG_WORD_2)
+#define GPIO_DEBUG_WORD_19 ((1<<GPIO_E) | GPIO_DEBUG_WORD_3)
+#define GPIO_DEBUG_WORD_20 ((1<<GPIO_E) | GPIO_DEBUG_WORD_4)
+#define GPIO_DEBUG_WORD_21 ((1<<GPIO_E) | GPIO_DEBUG_WORD_5)
+#define GPIO_DEBUG_WORD_22 ((1<<GPIO_E) | GPIO_DEBUG_WORD_6)
+#define GPIO_DEBUG_WORD_23 ((1<<GPIO_E) | GPIO_DEBUG_WORD_7)
+
+
+
+extern void btcoexDbgPulseWord(A_UINT32 gpioPinMask);
+extern void btcoexDbgPulse(A_UINT32 pin);
+
+#ifdef CONFIG_BTCOEX_ENABLE_GPIO_DEBUG
+#define BTCOEX_DBG_PULSE_WORD(gpioPinMask) (btcoexDbgPulseWord(gpioPinMask))
+#define BTCOEX_DBG_PULSE(pin) (btcoexDbgPulse(pin))
+#else
+#define BTCOEX_DBG_PULSE_WORD(gpioPinMask)
+#define BTCOEX_DBG_PULSE(pin)
+
+#endif
+#endif
+
diff --git a/host/include/cnxmgmt.h b/host/include/cnxmgmt.h
new file mode 100644
index 0000000..3177957
--- /dev/null
+++ b/host/include/cnxmgmt.h
@@ -0,0 +1,38 @@
+//------------------------------------------------------------------------------
+// <copyright file="cnxmgmt.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _CNXMGMT_H_
+#define _CNXMGMT_H_
+
+typedef enum {
+ CM_CONNECT_WITHOUT_SCAN = 0x0001,
+ CM_CONNECT_ASSOC_POLICY_USER = 0x0002,
+ CM_CONNECT_SEND_REASSOC = 0x0004,
+ CM_CONNECT_WITHOUT_ROAMTABLE_UPDATE = 0x0008,
+ CM_CONNECT_DO_WPA_OFFLOAD = 0x0010,
+ CM_CONNECT_DO_NOT_DEAUTH = 0x0020,
+ CM_CONNECT_IGNORE_BSSID_HINT = 0x0040,
+ CM_CONNECT_STAY_AWAKE = 0x0080,
+} CM_CONNECT_TYPE;
+
+#endif /* _CNXMGMT_H_ */
diff --git a/host/include/common_drv.h b/host/include/common_drv.h
new file mode 100644
index 0000000..43dc199
--- /dev/null
+++ b/host/include/common_drv.h
@@ -0,0 +1,107 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef COMMON_DRV_H_
+#define COMMON_DRV_H_
+
+#include "hif.h"
+#include "htc_packet.h"
+#include "htc_api.h"
+
+/* structure that is the state information for the default credit distribution callback
+ * drivers should instantiate (zero-init as well) this structure in their driver instance
+ * and pass it as a context to the HTC credit distribution functions */
+typedef struct _COMMON_CREDIT_STATE_INFO {
+ int TotalAvailableCredits; /* total credits in the system at startup */
+ int CurrentFreeCredits; /* credits available in the pool that have not been
+ given out to endpoints */
+ HTC_ENDPOINT_CREDIT_DIST *pLowestPriEpDist; /* pointer to the lowest priority endpoint dist struct */
+} COMMON_CREDIT_STATE_INFO;
+
+typedef struct {
+ A_INT32 (*setupTransport)(void *ar);
+ void (*cleanupTransport)(void *ar);
+} HCI_TRANSPORT_CALLBACKS;
+
+typedef struct {
+ void *netDevice;
+ void *hifDevice;
+ void *htcHandle;
+} HCI_TRANSPORT_MISC_HANDLES;
+
+/* HTC TX packet tagging definitions */
+#define AR6K_CONTROL_PKT_TAG HTC_TX_PACKET_TAG_USER_DEFINED
+#define AR6K_DATA_PKT_TAG (AR6K_CONTROL_PKT_TAG + 1)
+
+#define AR6002_VERSION_REV2 0x20000188
+#define AR6003_VERSION_REV2 0x30000384
+
+#define AR6002_CUST_DATA_SIZE 112
+#define AR6003_CUST_DATA_SIZE 16
+#define MCKINLEY_CUST_DATA_SIZE 16
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* OS-independent APIs */
+A_STATUS ar6000_setup_credit_dist(HTC_HANDLE HTCHandle, COMMON_CREDIT_STATE_INFO *pCredInfo);
+
+A_STATUS ar6000_ReadRegDiag(HIF_DEVICE *hifDevice, A_UINT32 *address, A_UINT32 *data);
+
+A_STATUS ar6000_WriteRegDiag(HIF_DEVICE *hifDevice, A_UINT32 *address, A_UINT32 *data);
+
+A_STATUS ar6000_ReadDataDiag(HIF_DEVICE *hifDevice, A_UINT32 address, A_UCHAR *data, A_UINT32 length);
+
+A_STATUS ar6000_reset_device(HIF_DEVICE *hifDevice, A_UINT32 TargetType, A_BOOL waitForCompletion, A_BOOL coldReset);
+
+void ar6000_dump_target_assert_info(HIF_DEVICE *hifDevice, A_UINT32 TargetType);
+
+A_STATUS ar6000_set_htc_params(HIF_DEVICE *hifDevice,
+ A_UINT32 TargetType,
+ A_UINT32 MboxIsrYieldValue,
+ A_UINT8 HtcControlBuffers);
+
+A_STATUS ar6000_prepare_target(HIF_DEVICE *hifDevice,
+ A_UINT32 TargetType,
+ A_UINT32 TargetVersion);
+
+A_STATUS ar6000_set_hci_bridge_flags(HIF_DEVICE *hifDevice,
+ A_UINT32 TargetType,
+ A_UINT32 Flags);
+
+void ar6000_copy_cust_data_from_target(HIF_DEVICE *hifDevice, A_UINT32 TargetType);
+
+A_UINT8 *ar6000_get_cust_data_buffer(A_UINT32 TargetType);
+
+A_STATUS ar6000_setBTState(void *context, A_UINT8 *pInBuf, A_UINT32 InBufSize);
+
+A_STATUS ar6000_setDevicePowerState(void *context, A_UINT8 *pInBuf, A_UINT32 InBufSize);
+
+A_STATUS ar6000_setWowMode(void *context, A_UINT8 *pInBuf, A_UINT32 InBufSize);
+
+A_STATUS ar6000_setHostMode(void *context, A_UINT8 *pInBuf, A_UINT32 InBufSize);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /*COMMON_DRV_H_*/
diff --git a/host/include/dbglog.h b/host/include/dbglog.h
new file mode 100644
index 0000000..3061f94
--- /dev/null
+++ b/host/include/dbglog.h
@@ -0,0 +1,134 @@
+//------------------------------------------------------------------------------
+// <copyright file="dbglog.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _DBGLOG_H_
+#define _DBGLOG_H_
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define DBGLOG_TIMESTAMP_OFFSET 0
+#define DBGLOG_TIMESTAMP_MASK 0x0000FFFF /* Bit 0-15. Contains bit
+ 8-23 of the LF0 timer */
+#define DBGLOG_DBGID_OFFSET 16
+#define DBGLOG_DBGID_MASK 0x03FF0000 /* Bit 16-25 */
+#define DBGLOG_DBGID_NUM_MAX 256 /* Upper limit is width of mask */
+
+#define DBGLOG_MODULEID_OFFSET 26
+#define DBGLOG_MODULEID_MASK 0x3C000000 /* Bit 26-29 */
+#define DBGLOG_MODULEID_NUM_MAX 16 /* Upper limit is width of mask */
+
+/*
+ * Please ensure that the definition of any new module intrduced is captured
+ * between the DBGLOG_MODULEID_START and DBGLOG_MODULEID_END defines. The
+ * structure is required for the parser to correctly pick up the values for
+ * different modules.
+ */
+#define DBGLOG_MODULEID_START
+#define DBGLOG_MODULEID_INF 0
+#define DBGLOG_MODULEID_WMI 1
+#define DBGLOG_MODULEID_MISC 2
+#define DBGLOG_MODULEID_PM 3
+#define DBGLOG_MODULEID_TXRX_MGMTBUF 4
+#define DBGLOG_MODULEID_TXRX_TXBUF 5
+#define DBGLOG_MODULEID_TXRX_RXBUF 6
+#define DBGLOG_MODULEID_WOW 7
+#define DBGLOG_MODULEID_WHAL 8
+#define DBGLOG_MODULEID_DC 9
+#define DBGLOG_MODULEID_CO 10
+#define DBGLOG_MODULEID_RO 11
+#define DBGLOG_MODULEID_CM 12
+#define DBGLOG_MODULEID_MGMT 13
+#define DBGLOG_MODULEID_TMR 14
+#define DBGLOG_MODULEID_BTCOEX 15
+#define DBGLOG_MODULEID_END
+
+#define DBGLOG_NUM_ARGS_OFFSET 30
+#define DBGLOG_NUM_ARGS_MASK 0xC0000000 /* Bit 30-31 */
+#define DBGLOG_NUM_ARGS_MAX 2 /* Upper limit is width of mask */
+
+#define DBGLOG_MODULE_LOG_ENABLE_OFFSET 0
+#define DBGLOG_MODULE_LOG_ENABLE_MASK 0x0000FFFF
+
+#define DBGLOG_REPORTING_ENABLED_OFFSET 16
+#define DBGLOG_REPORTING_ENABLED_MASK 0x00010000
+
+#define DBGLOG_TIMESTAMP_RESOLUTION_OFFSET 17
+#define DBGLOG_TIMESTAMP_RESOLUTION_MASK 0x000E0000
+
+#define DBGLOG_REPORT_SIZE_OFFSET 20
+#define DBGLOG_REPORT_SIZE_MASK 0x3FF00000
+
+#define DBGLOG_LOG_BUFFER_SIZE 1500
+#define DBGLOG_DBGID_DEFINITION_LEN_MAX 90
+
+PREPACK struct dbglog_buf_s {
+ struct dbglog_buf_s *next;
+ A_UINT8 *buffer;
+ A_UINT32 bufsize;
+ A_UINT32 length;
+ A_UINT32 count;
+ A_UINT32 free;
+} POSTPACK;
+
+PREPACK struct dbglog_hdr_s {
+ struct dbglog_buf_s *dbuf;
+ A_UINT32 dropped;
+} POSTPACK;
+
+PREPACK struct dbglog_config_s {
+ A_UINT32 cfgvalid; /* Mask with valid config bits */
+ union {
+ /* TODO: Take care of endianness */
+ struct {
+ A_UINT32 mmask:16; /* Mask of modules with logging on */
+ A_UINT32 rep:1; /* Reporting enabled or not */
+ A_UINT32 tsr:3; /* Time stamp resolution. Def: 1 ms */
+ A_UINT32 size:10; /* Report size in number of messages */
+ A_UINT32 reserved:2;
+ } dbglog_config;
+
+ A_UINT32 value;
+ } u;
+} POSTPACK;
+
+#define cfgmmask u.dbglog_config.mmask
+#define cfgrep u.dbglog_config.rep
+#define cfgtsr u.dbglog_config.tsr
+#define cfgsize u.dbglog_config.size
+#define cfgvalue u.value
+
+#ifdef __cplusplus
+}
+#endif
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#endif /* _DBGLOG_H_ */
diff --git a/host/include/dbglog_api.h b/host/include/dbglog_api.h
new file mode 100644
index 0000000..7aba883
--- /dev/null
+++ b/host/include/dbglog_api.h
@@ -0,0 +1,58 @@
+//------------------------------------------------------------------------------
+// <copyright file="dbglog_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains host side debug primitives.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _DBGLOG_API_H_
+#define _DBGLOG_API_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include "dbglog.h"
+
+#define DBGLOG_HOST_LOG_BUFFER_SIZE DBGLOG_LOG_BUFFER_SIZE
+
+#define DBGLOG_GET_DBGID(arg) \
+ ((arg & DBGLOG_DBGID_MASK) >> DBGLOG_DBGID_OFFSET)
+
+#define DBGLOG_GET_MODULEID(arg) \
+ ((arg & DBGLOG_MODULEID_MASK) >> DBGLOG_MODULEID_OFFSET)
+
+#define DBGLOG_GET_NUMARGS(arg) \
+ ((arg & DBGLOG_NUM_ARGS_MASK) >> DBGLOG_NUM_ARGS_OFFSET)
+
+#define DBGLOG_GET_TIMESTAMP(arg) \
+ ((arg & DBGLOG_TIMESTAMP_MASK) >> DBGLOG_TIMESTAMP_OFFSET)
+
+/**
+ @param lv 0->RAW info, 1->Breif translated info, 2->Full info
+ @param logbuf dbglog buffer
+ */
+int dbg_formater(int lv, char *output, size_t len, A_UINT32 ts, A_INT32 *logbuf);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _DBGLOG_API_H_ */
diff --git a/host/include/dbglog_id.h b/host/include/dbglog_id.h
new file mode 100644
index 0000000..9bc48ff
--- /dev/null
+++ b/host/include/dbglog_id.h
@@ -0,0 +1,593 @@
+//------------------------------------------------------------------------------
+// <copyright file="dbglog_id.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _DBGLOG_ID_H_
+#define _DBGLOG_ID_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+ * The nomenclature for the debug identifiers is MODULE_DESCRIPTION.
+ * Please ensure that the definition of any new debugid introduced is captured
+ * between the <MODULE>_DBGID_DEFINITION_START and
+ * <MODULE>_DBGID_DEFINITION_END defines. The structure is required for the
+ * parser to correctly pick up the values for different debug identifiers.
+ */
+
+/* INF debug identifier definitions */
+#define INF_DBGID_DEFINITION_START
+#define INF_ASSERTION_FAILED 1
+#define INF_TARGET_ID 2
+#define INF_DBGID_DEFINITION_END
+
+/* WMI debug identifier definitions */
+#define WMI_DBGID_DEFINITION_START
+#define WMI_CMD_RX_XTND_PKT_TOO_SHORT 1
+#define WMI_EXTENDED_CMD_NOT_HANDLED 2
+#define WMI_CMD_RX_PKT_TOO_SHORT 3
+#define WMI_CALLING_WMI_EXTENSION_FN 4
+#define WMI_CMD_NOT_HANDLED 5
+#define WMI_IN_SYNC 6
+#define WMI_TARGET_WMI_SYNC_CMD 7
+#define WMI_SET_SNR_THRESHOLD_PARAMS 8
+#define WMI_SET_RSSI_THRESHOLD_PARAMS 9
+#define WMI_SET_LQ_TRESHOLD_PARAMS 10
+#define WMI_TARGET_CREATE_PSTREAM_CMD 11
+#define WMI_WI_DTM_INUSE 12
+#define WMI_TARGET_DELETE_PSTREAM_CMD 13
+#define WMI_TARGET_IMPLICIT_DELETE_PSTREAM_CMD 14
+#define WMI_TARGET_GET_BIT_RATE_CMD 15
+#define WMI_GET_RATE_MASK_CMD_FIX_RATE_MASK_IS 16
+#define WMI_TARGET_GET_AVAILABLE_CHANNELS_CMD 17
+#define WMI_TARGET_GET_TX_PWR_CMD 18
+#define WMI_FREE_EVBUF_WMIBUF 19
+#define WMI_FREE_EVBUF_DATABUF 20
+#define WMI_FREE_EVBUF_BADFLAG 21
+#define WMI_HTC_RX_ERROR_DATA_PACKET 22
+#define WMI_HTC_RX_SYNC_PAUSING_FOR_MBOX 23
+#define WMI_INCORRECT_WMI_DATA_HDR_DROPPING_PKT 24
+#define WMI_SENDING_READY_EVENT 25
+#define WMI_SETPOWER_MDOE_TO_MAXPERF 26
+#define WMI_SETPOWER_MDOE_TO_REC 27
+#define WMI_BSSINFO_EVENT_FROM 28
+#define WMI_TARGET_GET_STATS_CMD 29
+#define WMI_SENDING_SCAN_COMPLETE_EVENT 30
+#define WMI_SENDING_RSSI_INDB_THRESHOLD_EVENT 31
+#define WMI_SENDING_RSSI_INDBM_THRESHOLD_EVENT 32
+#define WMI_SENDING_LINK_QUALITY_THRESHOLD_EVENT 33
+#define WMI_SENDING_ERROR_REPORT_EVENT 34
+#define WMI_SENDING_CAC_EVENT 35
+#define WMI_TARGET_GET_ROAM_TABLE_CMD 36
+#define WMI_TARGET_GET_ROAM_DATA_CMD 37
+#define WMI_SENDING_GPIO_INTR_EVENT 38
+#define WMI_SENDING_GPIO_ACK_EVENT 39
+#define WMI_SENDING_GPIO_DATA_EVENT 40
+#define WMI_CMD_RX 41
+#define WMI_CMD_RX_XTND 42
+#define WMI_EVENT_SEND 43
+#define WMI_EVENT_SEND_XTND 44
+#define WMI_CMD_PARAMS_DUMP_START 45
+#define WMI_CMD_PARAMS_DUMP_END 46
+#define WMI_CMD_PARAMS 47
+#define WMI_DBGID_DEFINITION_END
+
+/* MISC debug identifier definitions */
+#define MISC_DBGID_DEFINITION_START
+#define MISC_WLAN_SCHEDULER_EVENT_REGISTER_ERROR 1
+#define TLPM_INIT 2
+#define TLPM_FILTER_POWER_STATE 3
+#define TLPM_NOTIFY_NOT_IDLE 4
+#define TLPM_TIMEOUT_IDLE_HANDLER 5
+#define TLPM_TIMEOUT_WAKEUP_HANDLER 6
+#define TLPM_WAKEUP_SIGNAL_HANDLER 7
+#define TLPM_UNEXPECTED_GPIO_INTR_ERROR 8
+#define TLPM_BREAK_ON_NOT_RECEIVED_ERROR 9
+#define TLPM_BREAK_OFF_NOT_RECIVED_ERROR 10
+#define TLPM_ACK_GPIO_INTR 11
+#define TLPM_ON 12
+#define TLPM_OFF 13
+#define TLPM_WAKEUP_FROM_HOST 14
+#define TLPM_WAKEUP_FROM_BT 15
+#define TLPM_TX_BREAK_RECIVED 16
+#define TLPM_IDLE_TIMER_NOT_RUNNING 17
+#define WAC_ENABLE 18
+#define WAC_SCAN_DONE 19
+#define WAC_REPORT_BSS 20
+#define WAC_START_WPS 21
+#define WAC_SCAN_REPLY 22
+#define WAC_UPDATE_BSS 23
+#define WAC_PIN_STATUS 24
+#define WAC_PIN_STATUS_REJECT 25
+#define WAC_RSSI_BELOW_THRESHOLD 26
+#define WAC_CTRL_REQ_CMD 27
+#define WAC_CTRL_REQ_REPLY 28
+#define DV_SET_ANTENNA 29
+#define MISC_DBGID_DEFINITION_END
+
+/* TXRX debug identifier definitions */
+#define TXRX_TXBUF_DBGID_DEFINITION_START
+#define TXRX_TXBUF_ALLOCATE_BUF 1
+#define TXRX_TXBUF_QUEUE_BUF_TO_MBOX 2
+#define TXRX_TXBUF_QUEUE_BUF_TO_TXQ 3
+#define TXRX_TXBUF_TXQ_DEPTH 4
+#define TXRX_TXBUF_IBSS_QUEUE_TO_SFQ 5
+#define TXRX_TXBUF_IBSS_QUEUE_TO_TXQ_FRM_SFQ 6
+#define TXRX_TXBUF_INITIALIZE_TIMER 7
+#define TXRX_TXBUF_ARM_TIMER 8
+#define TXRX_TXBUF_DISARM_TIMER 9
+#define TXRX_TXBUF_UNINITIALIZE_TIMER 10
+#define TXRX_TXBUF_DBGID_DEFINITION_END
+
+#define TXRX_RXBUF_DBGID_DEFINITION_START
+#define TXRX_RXBUF_ALLOCATE_BUF 1
+#define TXRX_RXBUF_QUEUE_TO_HOST 2
+#define TXRX_RXBUF_QUEUE_TO_WLAN 3
+#define TXRX_RXBUF_ZERO_LEN_BUF 4
+#define TXRX_RXBUF_QUEUE_TO_HOST_LASTBUF_IN_RXCHAIN 5
+#define TXRX_RXBUF_LASTBUF_IN_RXCHAIN_ZEROBUF 6
+#define TXRX_RXBUF_QUEUE_EMPTY_QUEUE_TO_WLAN 7
+#define TXRX_RXBUF_SEND_TO_RECV_MGMT 8
+#define TXRX_RXBUF_SEND_TO_IEEE_LAYER 9
+#define TXRX_RXBUF_REQUEUE_ERROR 10
+#define TXRX_RXBUF_DBGID_DEFINITION_END
+
+#define TXRX_MGMTBUF_DBGID_DEFINITION_START
+#define TXRX_MGMTBUF_ALLOCATE_BUF 1
+#define TXRX_MGMTBUF_ALLOCATE_SM_BUF 2
+#define TXRX_MGMTBUF_ALLOCATE_RMBUF 3
+#define TXRX_MGMTBUF_GET_BUF 4
+#define TXRX_MGMTBUF_GET_SM_BUF 5
+#define TXRX_MGMTBUF_QUEUE_BUF_TO_TXQ 6
+#define TXRX_MGMTBUF_REAPED_BUF 7
+#define TXRX_MGMTBUF_REAPED_SM_BUF 8
+#define TXRX_MGMTBUF_WAIT_FOR_TXQ_DRAIN 9
+#define TXRX_MGMTBUF_WAIT_FOR_TXQ_SFQ_DRAIN 10
+#define TXRX_MGMTBUF_ENQUEUE_INTO_DATA_SFQ 11
+#define TXRX_MGMTBUF_DEQUEUE_FROM_DATA_SFQ 12
+#define TXRX_MGMTBUF_PAUSE_DATA_TXQ 13
+#define TXRX_MGMTBUF_RESUME_DATA_TXQ 14
+#define TXRX_MGMTBUF_WAIT_FORTXQ_DRAIN_TIMEOUT 15
+#define TXRX_MGMTBUF_DRAINQ 16
+#define TXRX_MGMTBUF_INDICATE_Q_DRAINED 17
+#define TXRX_MGMTBUF_ENQUEUE_INTO_HW_SFQ 18
+#define TXRX_MGMTBUF_DEQUEUE_FROM_HW_SFQ 19
+#define TXRX_MGMTBUF_PAUSE_HW_TXQ 20
+#define TXRX_MGMTBUF_RESUME_HW_TXQ 21
+#define TXRX_MGMTBUF_TEAR_DOWN_BA 22
+#define TXRX_MGMTBUF_PROCESS_ADDBA_REQ 23
+#define TXRX_MGMTBUF_PROCESS_DELBA 24
+#define TXRX_MGMTBUF_PERFORM_BA 25
+#define TXRX_MGMTBUF_WLAN_RESET_ON_ERROR 26
+#define TXRX_MGMTBUF_DBGID_DEFINITION_END
+
+/* PM (Power Module) debug identifier definitions */
+#define PM_DBGID_DEFINITION_START
+#define PM_INIT 1
+#define PM_ENABLE 2
+#define PM_SET_STATE 3
+#define PM_SET_POWERMODE 4
+#define PM_CONN_NOTIFY 5
+#define PM_REF_COUNT_NEGATIVE 6
+#define PM_INFRA_STA_APSD_ENABLE 7
+#define PM_INFRA_STA_UPDATE_APSD_STATE 8
+#define PM_CHAN_OP_REQ 9
+#define PM_SET_MY_BEACON_POLICY 10
+#define PM_SET_ALL_BEACON_POLICY 11
+#define PM_INFRA_STA_SET_PM_PARAMS1 12
+#define PM_INFRA_STA_SET_PM_PARAMS2 13
+#define PM_ADHOC_SET_PM_CAPS_FAIL 14
+#define PM_ADHOC_UNKNOWN_IBSS_ATTRIB_ID 15
+#define PM_ADHOC_SET_PM_PARAMS 16
+#define PM_ADHOC_STATE1 18
+#define PM_ADHOC_STATE2 19
+#define PM_ADHOC_CONN_MAP 20
+#define PM_FAKE_SLEEP 21
+#define PM_AP_STATE1 22
+#define PM_AP_SET_PM_PARAMS 23
+#define PM_P2P_STATE1 24
+#define PM_DBGID_DEFINITION_END
+
+/* Wake on Wireless debug identifier definitions */
+#define WOW_DBGID_DEFINITION_START
+#define WOW_INIT 1
+#define WOW_GET_CONFIG_DSET 2
+#define WOW_NO_CONFIG_DSET 3
+#define WOW_INVALID_CONFIG_DSET 4
+#define WOW_USE_DEFAULT_CONFIG 5
+#define WOW_SETUP_GPIO 6
+#define WOW_INIT_DONE 7
+#define WOW_SET_GPIO_PIN 8
+#define WOW_CLEAR_GPIO_PIN 9
+#define WOW_SET_WOW_MODE_CMD 10
+#define WOW_SET_HOST_MODE_CMD 11
+#define WOW_ADD_WOW_PATTERN_CMD 12
+#define WOW_NEW_WOW_PATTERN_AT_INDEX 13
+#define WOW_DEL_WOW_PATTERN_CMD 14
+#define WOW_LIST_CONTAINS_PATTERNS 15
+#define WOW_GET_WOW_LIST_CMD 16
+#define WOW_INVALID_FILTER_ID 17
+#define WOW_INVALID_FILTER_LISTID 18
+#define WOW_NO_VALID_FILTER_AT_ID 19
+#define WOW_NO_VALID_LIST_AT_ID 20
+#define WOW_NUM_PATTERNS_EXCEEDED 21
+#define WOW_NUM_LISTS_EXCEEDED 22
+#define WOW_GET_WOW_STATS 23
+#define WOW_CLEAR_WOW_STATS 24
+#define WOW_WAKEUP_HOST 25
+#define WOW_EVENT_WAKEUP_HOST 26
+#define WOW_EVENT_DISCARD 27
+#define WOW_PATTERN_MATCH 28
+#define WOW_PATTERN_NOT_MATCH 29
+#define WOW_PATTERN_NOT_MATCH_OFFSET 30
+#define WOW_DISABLED_HOST_ASLEEP 31
+#define WOW_ENABLED_HOST_ASLEEP_NO_PATTERNS 32
+#define WOW_ENABLED_HOST_ASLEEP_NO_MATCH_FOUND 33
+#define WOW_DBGID_DEFINITION_END
+
+/* WHAL debug identifier definitions */
+#define WHAL_DBGID_DEFINITION_START
+#define WHAL_ERROR_ANI_CONTROL 1
+#define WHAL_ERROR_CHIP_TEST1 2
+#define WHAL_ERROR_CHIP_TEST2 3
+#define WHAL_ERROR_EEPROM_CHECKSUM 4
+#define WHAL_ERROR_EEPROM_MACADDR 5
+#define WHAL_ERROR_INTERRUPT_HIU 6
+#define WHAL_ERROR_KEYCACHE_RESET 7
+#define WHAL_ERROR_KEYCACHE_SET 8
+#define WHAL_ERROR_KEYCACHE_TYPE 9
+#define WHAL_ERROR_KEYCACHE_TKIPENTRY 10
+#define WHAL_ERROR_KEYCACHE_WEPLENGTH 11
+#define WHAL_ERROR_PHY_INVALID_CHANNEL 12
+#define WHAL_ERROR_POWER_AWAKE 13
+#define WHAL_ERROR_POWER_SET 14
+#define WHAL_ERROR_RECV_STOPDMA 15
+#define WHAL_ERROR_RECV_STOPPCU 16
+#define WHAL_ERROR_RESET_CHANNF1 17
+#define WHAL_ERROR_RESET_CHANNF2 18
+#define WHAL_ERROR_RESET_PM 19
+#define WHAL_ERROR_RESET_OFFSETCAL 20
+#define WHAL_ERROR_RESET_RFGRANT 21
+#define WHAL_ERROR_RESET_RXFRAME 22
+#define WHAL_ERROR_RESET_STOPDMA 23
+#define WHAL_ERROR_RESET_RECOVER 24
+#define WHAL_ERROR_XMIT_COMPUTE 25
+#define WHAL_ERROR_XMIT_NOQUEUE 26
+#define WHAL_ERROR_XMIT_ACTIVEQUEUE 27
+#define WHAL_ERROR_XMIT_BADTYPE 28
+#define WHAL_ERROR_XMIT_STOPDMA 29
+#define WHAL_ERROR_INTERRUPT_BB_PANIC 30
+#define WHAL_ERROR_RESET_TXIQCAL 31
+#define WHAL_ERROR_PAPRD_MAXGAIN_ABOVE_WINDOW 32
+#define WHAL_DBGID_DEFINITION_END
+
+/* DC debug identifier definitions */
+#define DC_DBGID_DEFINITION_START
+#define DC_SCAN_CHAN_START 1
+#define DC_SCAN_CHAN_FINISH 2
+#define DC_BEACON_RECEIVE7 3
+#define DC_SSID_PROBE_CB 4
+#define DC_SEND_NEXT_SSID_PROBE 5
+#define DC_START_SEARCH 6
+#define DC_CANCEL_SEARCH_CB 7
+#define DC_STOP_SEARCH 8
+#define DC_END_SEARCH 9
+#define DC_MIN_CHDWELL_TIMEOUT 10
+#define DC_START_SEARCH_CANCELED 11
+#define DC_SET_POWER_MODE 12
+#define DC_INIT 13
+#define DC_SEARCH_OPPORTUNITY 14
+#define DC_RECEIVED_ANY_BEACON 15
+#define DC_RECEIVED_MY_BEACON 16
+#define DC_PROFILE_IS_ADHOC_BUT_BSS_IS_INFRA 17
+#define DC_PS_ENABLED_BUT_ATHEROS_IE_ABSENT 18
+#define DC_BSS_ADHOC_CHANNEL_NOT_ALLOWED 19
+#define DC_SET_BEACON_UPDATE 20
+#define DC_BEACON_UPDATE_COMPLETE 21
+#define DC_END_SEARCH_BEACON_UPDATE_COMP_CB 22
+#define DC_BSSINFO_EVENT_DROPPED 23
+#define DC_IEEEPS_ENABLED_BUT_ATIM_ABSENT 24
+#define DC_DBGID_DEFINITION_END
+
+/* CO debug identifier definitions */
+#define CO_DBGID_DEFINITION_START
+#define CO_INIT 1
+#define CO_ACQUIRE_LOCK 2
+#define CO_START_OP1 3
+#define CO_START_OP2 4
+#define CO_DRAIN_TX_COMPLETE_CB 5
+#define CO_CHANGE_CHANNEL_CB 6
+#define CO_RETURN_TO_HOME_CHANNEL 7
+#define CO_FINISH_OP_TIMEOUT 8
+#define CO_OP_END 9
+#define CO_CANCEL_OP 10
+#define CO_CHANGE_CHANNEL 11
+#define CO_RELEASE_LOCK 12
+#define CO_CHANGE_STATE 13
+#define CO_DBGID_DEFINITION_END
+
+/* RO debug identifier definitions */
+#define RO_DBGID_DEFINITION_START
+#define RO_REFRESH_ROAM_TABLE 1
+#define RO_UPDATE_ROAM_CANDIDATE 2
+#define RO_UPDATE_ROAM_CANDIDATE_CB 3
+#define RO_UPDATE_ROAM_CANDIDATE_FINISH 4
+#define RO_REFRESH_ROAM_TABLE_DONE 5
+#define RO_PERIODIC_SEARCH_CB 6
+#define RO_PERIODIC_SEARCH_TIMEOUT 7
+#define RO_INIT 8
+#define RO_BMISS_STATE1 9
+#define RO_BMISS_STATE2 10
+#define RO_SET_PERIODIC_SEARCH_ENABLE 11
+#define RO_SET_PERIODIC_SEARCH_DISABLE 12
+#define RO_ENABLE_SQ_THRESHOLD 13
+#define RO_DISABLE_SQ_THRESHOLD 14
+#define RO_ADD_BSS_TO_ROAM_TABLE 15
+#define RO_SET_PERIODIC_SEARCH_MODE 16
+#define RO_CONFIGURE_SQ_THRESHOLD1 17
+#define RO_CONFIGURE_SQ_THRESHOLD2 18
+#define RO_CONFIGURE_SQ_PARAMS 19
+#define RO_LOW_SIGNAL_QUALITY_EVENT 20
+#define RO_HIGH_SIGNAL_QUALITY_EVENT 21
+#define RO_REMOVE_BSS_FROM_ROAM_TABLE 22
+#define RO_UPDATE_CONNECTION_STATE_METRIC 23
+#define RO_LOWRSSI_SCAN_PARAMS 24
+#define RO_LOWRSSI_SCAN_START 25
+#define RO_LOWRSSI_SCAN_END 26
+#define RO_LOWRSSI_SCAN_CANCEL 27
+#define RO_LOWRSSI_ROAM_CANCEL 28
+#define RO_REFRESH_ROAM_CANDIDATE 29
+#define RO_DBGID_DEFINITION_END
+
+/* CM debug identifier definitions */
+#define CM_DBGID_DEFINITION_START
+#define CM_INITIATE_HANDOFF 1
+#define CM_INITIATE_HANDOFF_CB 2
+#define CM_CONNECT_EVENT 3
+#define CM_DISCONNECT_EVENT 4
+#define CM_INIT 5
+#define CM_HANDOFF_SOURCE 6
+#define CM_SET_HANDOFF_TRIGGERS 7
+#define CM_CONNECT_REQUEST 8
+#define CM_CONNECT_REQUEST_CB 9
+#define CM_CONTINUE_SCAN_CB 10
+#define CM_DBGID_DEFINITION_END
+
+
+/* mgmt debug identifier definitions */
+#define MGMT_DBGID_DEFINITION_START
+#define KEYMGMT_CONNECTION_INIT 1
+#define KEYMGMT_CONNECTION_COMPLETE 2
+#define KEYMGMT_CONNECTION_CLOSE 3
+#define KEYMGMT_ADD_KEY 4
+#define MLME_NEW_STATE 5
+#define MLME_CONN_INIT 6
+#define MLME_CONN_COMPLETE 7
+#define MLME_CONN_CLOSE 8
+#define MLME_WLAN_OPMODE 9
+#define MLME_WLAN_SLOTTIME 10
+#define MGMT_DBGID_DEFINITION_END
+
+/* TMR debug identifier definitions */
+#define TMR_DBGID_DEFINITION_START
+#define TMR_HANG_DETECTED 1
+#define TMR_WDT_TRIGGERED 2
+#define TMR_WDT_RESET 3
+#define TMR_HANDLER_ENTRY 4
+#define TMR_HANDLER_EXIT 5
+#define TMR_SAVED_START 6
+#define TMR_SAVED_END 7
+#define TMR_DBGID_DEFINITION_END
+
+/* BTCOEX debug identifier definitions */
+#define BTCOEX_DBGID_DEFINITION_START
+#define BTCOEX_STATUS_CMD 1
+#define BTCOEX_PARAMS_CMD 2
+#define BTCOEX_ANT_CONFIG 3
+#define BTCOEX_COLOCATED_BT_DEVICE 4
+#define BTCOEX_CLOSE_RANGE_SCO_ON 5
+#define BTCOEX_CLOSE_RANGE_SCO_OFF 6
+#define BTCOEX_CLOSE_RANGE_A2DP_ON 7
+#define BTCOEX_CLOSE_RANGE_A2DP_OFF 8
+#define BTCOEX_A2DP_PROTECT_ON 9
+#define BTCOEX_A2DP_PROTECT_OFF 10
+#define BTCOEX_SCO_PROTECT_ON 11
+#define BTCOEX_SCO_PROTECT_OFF 12
+#define BTCOEX_CLOSE_RANGE_DETECTOR_START 13
+#define BTCOEX_CLOSE_RANGE_DETECTOR_STOP 14
+#define BTCOEX_CLOSE_RANGE_TOGGLE 15
+#define BTCOEX_CLOSE_RANGE_TOGGLE_RSSI_LRCNT 16
+#define BTCOEX_CLOSE_RANGE_RSSI_THRESH 17
+#define BTCOEX_CLOSE_RANGE_LOW_RATE_THRESH 18
+#define BTCOEX_PTA_PRI_INTR_HANDLER 19
+#define BTCOEX_PSPOLL_QUEUED 20
+#define BTCOEX_PSPOLL_COMPLETE 21
+#define BTCOEX_DBG_PM_AWAKE 22
+#define BTCOEX_DBG_PM_SLEEP 23
+#define BTCOEX_DBG_SCO_COEX_ON 24
+#define BTCOEX_SCO_DATARECEIVE 25
+#define BTCOEX_INTR_INIT 26
+#define BTCOEX_PTA_PRI_DIFF 27
+#define BTCOEX_TIM_NOTIFICATION 28
+#define BTCOEX_SCO_WAKEUP_ON_DATA 29
+#define BTCOEX_SCO_SLEEP 30
+#define BTCOEX_SET_WEIGHTS 31
+#define BTCOEX_SCO_DATARECEIVE_LATENCY_VAL 32
+#define BTCOEX_SCO_MEASURE_TIME_DIFF 33
+#define BTCOEX_SET_EOL_VAL 34
+#define BTCOEX_OPT_DETECT_HANDLER 35
+#define BTCOEX_SCO_TOGGLE_STATE 36
+#define BTCOEX_SCO_STOMP 37
+#define BTCOEX_NULL_COMP_CALLBACK 38
+#define BTCOEX_RX_INCOMING 39
+#define BTCOEX_RX_INCOMING_CTL 40
+#define BTCOEX_RX_INCOMING_MGMT 41
+#define BTCOEX_RX_INCOMING_DATA 42
+#define BTCOEX_RTS_RECEPTION 43
+#define BTCOEX_FRAME_PRI_LOW_RATE_THRES 44
+#define BTCOEX_PM_FAKE_SLEEP 45
+#define BTCOEX_ACL_COEX_STATUS 46
+#define BTCOEX_ACL_COEX_DETECTION 47
+#define BTCOEX_A2DP_COEX_STATUS 48
+#define BTCOEX_SCO_STATUS 49
+#define BTCOEX_WAKEUP_ON_DATA 50
+#define BTCOEX_DATARECEIVE 51
+#define BTCOEX_GET_MAX_AGGR_SIZE 53
+#define BTCOEX_MAX_AGGR_AVAIL_TIME 54
+#define BTCOEX_DBG_WBTIMER_INTR 55
+#define BTCOEX_DBG_SCO_SYNC 57
+#define BTCOEX_UPLINK_QUEUED_RATE 59
+#define BTCOEX_DBG_UPLINK_ENABLE_EOL 60
+#define BTCOEX_UPLINK_FRAME_DURATION 61
+#define BTCOEX_UPLINK_SET_EOL 62
+#define BTCOEX_DBG_EOL_EXPIRED 63
+#define BTCOEX_DBG_DATA_COMPLETE 64
+#define BTCOEX_UPLINK_QUEUED_TIMESTAMP 65
+#define BTCOEX_DBG_DATA_COMPLETE_TIME 66
+#define BTCOEX_DBG_A2DP_ROLE_IS_SLAVE 67
+#define BTCOEX_DBG_A2DP_ROLE_IS_MASTER 68
+#define BTCOEX_DBG_UPLINK_SEQ_NUM 69
+#define BTCOEX_UPLINK_AGGR_SEQ 70
+#define BTCOEX_DBG_TX_COMP_SEQ_NO 71
+#define BTCOEX_DBG_MAX_AGGR_PAUSE_STATE 72
+#define BTCOEX_DBG_ACL_TRAFFIC 73
+#define BTCOEX_CURR_AGGR_PROP 74
+#define BTCOEX_DBG_SCO_GET_PER_TIME_DIFF 75
+#define BTCOEX_PSPOLL_PROCESS 76
+#define BTCOEX_RETURN_FROM_MAC 77
+#define BTCOEX_FREED_REQUEUED_CNT 78
+#define BTCOEX_DBG_TOGGLE_LOW_RATES 79
+#define BTCOEX_MAC_GOES_TO_SLEEP 80
+#define BTCOEX_DBG_A2DP_NO_SYNC 81
+#define BTCOEX_RETURN_FROM_MAC_HOLD_Q_INFO 82
+#define BTCOEX_RETURN_FROM_MAC_AC 83
+#define BTCOEX_DBG_DTIM_RECV 84
+#define BTCOEX_IS_PRE_UPDATE 86
+#define BTCOEX_ENQUEUED_BIT_MAP 87
+#define BTCOEX_TX_COMPLETE_FIRST_DESC_STATS 88
+#define BTCOEX_UPLINK_DESC 89
+#define BTCOEX_SCO_GET_PER_FIRST_FRM_TIMESTAMP 90
+#define BTCOEX_DBG_RECV_ACK 94
+#define BTCOEX_DBG_ADDBA_INDICATION 95
+#define BTCOEX_TX_COMPLETE_EOL_FAILED 96
+#define BTCOEX_DBG_A2DP_USAGE_COMPLETE 97
+#define BTCOEX_DBG_A2DP_STOMP_FOR_BCN_HANDLER 98
+#define BTCOEX_DBG_A2DP_SYNC_INTR 99
+#define BTCOEX_DBG_A2DP_STOMP_FOR_BCN_RECEPTION 100
+#define BTCOEX_FORM_AGGR_CURR_AGGR 101
+#define BTCOEX_DBG_TOGGLE_A2DP_BURST_CNT 102
+#define BTCOEX_DBG_BT_TRAFFIC 103
+#define BTCOEX_DBG_STOMP_BT_TRAFFIC 104
+#define BTCOEX_RECV_NULL 105
+#define BTCOEX_DBG_A2DP_MASTER_BT_END 106
+#define BTCOEX_DBG_A2DP_BT_START 107
+#define BTCOEX_DBG_A2DP_SLAVE_BT_END 108
+#define BTCOEX_DBG_A2DP_STOMP_BT 109
+#define BTCOEX_DBG_GO_TO_SLEEP 110
+#define BTCOEX_DBG_A2DP_PKT 111
+#define BTCOEX_DBG_A2DP_PSPOLL_DATA_RECV 112
+#define BTCOEX_DBG_A2DP_NULL 113
+#define BTCOEX_DBG_UPLINK_DATA 114
+#define BTCOEX_DBG_A2DP_STOMP_LOW_PRIO_NULL 115
+#define BTCOEX_DBG_ADD_BA_RESP_TIMEOUT 116
+#define BTCOEX_DBG_TXQ_STATE 117
+#define BTCOEX_DBG_ALLOW_SCAN 118
+#define BTCOEX_DBG_SCAN_REQUEST 119
+#define BTCOEX_A2DP_SLEEP 127
+#define BTCOEX_DBG_DATA_ACTIV_TIMEOUT 128
+#define BTCOEX_DBG_SWITCH_TO_PSPOLL_ON_MODE 129
+#define BTCOEX_DBG_SWITCH_TO_PSPOLL_OFF_MODE 130
+#define BTCOEX_DATARECEIVE_AGGR 131
+#define BTCOEX_DBG_DATA_RECV_SLEEPING_PENDING 132
+#define BTCOEX_DBG_DATARESP_TIMEOUT 133
+#define BTCOEX_BDG_BMISS 134
+#define BTCOEX_DBG_DATA_RECV_WAKEUP_TIM 135
+#define BTCOEX_DBG_SECOND_BMISS 136
+#define BTCOEX_DBG_SET_WLAN_STATE 138
+#define BTCOEX_BDG_FIRST_BMISS 139
+#define BTCOEX_DBG_A2DP_CHAN_OP 140
+#define BTCOEX_DBG_A2DP_INTR 141
+#define BTCOEX_DBG_BT_INQUIRY 142
+#define BTCOEX_DBG_BT_INQUIRY_DATA_FETCH 143
+#define BTCOEX_DBG_POST_INQUIRY_FINISH 144
+#define BTCOEX_DBG_SCO_OPT_MODE_TIMER_HANDLER 145
+#define BTCOEX_DBG_NULL_FRAME_SLEEP 146
+#define BTCOEX_DBG_NULL_FRAME_AWAKE 147
+#define BTCOEX_DBG_SET_AGGR_SIZE 152
+#define BTCOEX_DBG_TEAR_BA_TIMEOUT 153
+#define BTCOEX_DBG_MGMT_FRAME_SEQ_NO 154
+#define BTCOEX_DBG_SCO_STOMP_HIGH_PRI 155
+#define BTCOEX_DBG_COLOCATED_BT_DEV 156
+#define BTCOEX_DBG_FE_ANT_TYPE 157
+#define BTCOEX_DBG_BT_INQUIRY_CMD 158
+#define BTCOEX_DBG_SCO_CONFIG 159
+#define BTCOEX_DBG_SCO_PSPOLL_CONFIG 160
+#define BTCOEX_DBG_SCO_OPTMODE_CONFIG 161
+#define BTCOEX_DBG_A2DP_CONFIG 162
+#define BTCOEX_DBG_A2DP_PSPOLL_CONFIG 163
+#define BTCOEX_DBG_A2DP_OPTMODE_CONFIG 164
+#define BTCOEX_DBG_ACLCOEX_CONFIG 165
+#define BTCOEX_DBG_ACLCOEX_PSPOLL_CONFIG 166
+#define BTCOEX_DBG_ACLCOEX_OPTMODE_CONFIG 167
+#define BTCOEX_DBG_DEBUG_CMD 168
+#define BTCOEX_DBG_SET_BT_OPERATING_STATUS 169
+#define BTCOEX_DBG_GET_CONFIG 170
+#define BTCOEX_DBG_GET_STATS 171
+#define BTCOEX_DBG_BT_OPERATING_STATUS 172
+#define BTCOEX_DBG_PERFORM_RECONNECT 173
+#define BTCOEX_DBG_ACL_WLAN_MED 175
+#define BTCOEX_DBG_ACL_BT_MED 176
+#define BTCOEX_DBG_WLAN_CONNECT 177
+#define BTCOEX_DBG_A2DP_DUAL_START 178
+#define BTCOEX_DBG_PMAWAKE_NOTIFY 179
+#define BTCOEX_DBG_BEACON_SCAN_ENABLE 180
+#define BTCOEX_DBG_BEACON_SCAN_DISABLE 181
+#define BTCOEX_DBG_RX_NOTIFY 182
+#define BTCOEX_SCO_GET_PER_SECOND_FRM_TIMESTAMP 183
+#define BTCOEX_DBG_TXQ_DETAILS 184
+#define BTCOEX_DBG_SCO_STOMP_LOW_PRI 185
+#define BTCOEX_DBG_A2DP_FORCE_SCAN 186
+#define BTCOEX_DBG_DTIM_STOMP_COMP 187
+#define BTCOEX_ACL_PRESENCE_TIMER 188
+#define BTCOEX_DBG_QUEUE_SELF_CTS 189
+#define BTCOEX_DBG_SELF_CTS_COMP 190
+#define BTCOEX_DBG_APMODE_WAIT_FOR_CTS_COMP_FAILED 191
+#define BTCOEX_DBG_APMODE_A2DP_MED_TO_BT 192
+#define BTCOEX_DBG_APMODE_SET_BTSTATE 193
+#define BTCOEX_DBG_APMODE_A2DP_STATUS 194
+#define BTCOEX_DBG_APMODE_SCO_CTS_HANDLER 195
+#define BTCOEX_DBG_APMODE_SCO_STATUS 196
+#define BTCOEX_DBG_APMODE_TXQ_DRAINED 197
+#define BTCOEX_DBG_APMODE_SCO_ARM_TIMER 198
+#define BTCOEX_DBG_APMODE_SWITCH_MED_TO_WLAN 199
+#define BTCOEX_APMODE_BCN_TX_HANDLER 200
+#define BTCOEX_APMODE_BCN_TX 201
+#define BTCOEX_APMODE_SCO_RTS_HANDLER 202
+#define BTCOEX_DBGID_DEFINITION_END
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _DBGLOG_ID_H_ */
diff --git a/host/include/dfs_common.h b/host/include/dfs_common.h
new file mode 100644
index 0000000..cf1844f
--- /dev/null
+++ b/host/include/dfs_common.h
@@ -0,0 +1,84 @@
+/*
+ * Copyright (c) 2005-2006 Atheros Communications, Inc.
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+
+#ifndef _DFS_COMMON_H_
+#define _DFS_COMMON_H_
+
+enum {
+ DFS_UNINIT_DOMAIN = 0, /* Uninitialized dfs domain */
+ DFS_FCC_DOMAIN = 1, /* FCC3 dfs domain */
+ DFS_ETSI_DOMAIN = 2, /* ETSI dfs domain */
+ DFS_MKK4_DOMAIN = 3 /* Japan dfs domain */
+};
+
+
+
+#define MAX_BIN5_DUR 131 /* 105 * 1.25*/
+
+PREPACK struct ath_dfs_capinfo {
+ A_UINT64 ext_chan_busy_ts;
+ A_UINT8 enable_ar;
+ A_UINT8 enable_radar;
+} POSTPACK;
+
+typedef struct ath_dfs_capinfo WMI_DFS_HOST_ATTACH_EVENT;
+
+PREPACK struct ath_dfs_info {
+ A_UINT32 dfs_domain;
+} POSTPACK;
+
+typedef struct ath_dfs_info WMI_DFS_HOST_INIT_EVENT;
+
+
+PREPACK struct dfs_event_info {
+ A_UINT64 full_ts; /* 64-bit full timestamp from interrupt time */
+ A_UINT32 ts; /* Original 15 bit recv timestamp */
+ A_UINT32 ext_chan_busy; /* Ext chan busy % */
+ A_UINT8 rssi; /* rssi of radar event */
+ A_UINT8 dur; /* duration of radar pulse */
+ A_UINT8 chanindex; /* Channel of event */
+ A_UINT8 flags;
+#define CH_TYPE_MASK 1
+#define PRIMARY_CH 0
+#define EXT_CH 1
+#define EVENT_TYPE_MASK 2
+#define AR_EVENT 0
+#define DFS_EVENT 2
+} POSTPACK;
+
+/* XXX: Replace 256 with WMI_SVC_MAX_BUFFERED_EVENT_SIZE */
+#define WMI_DFS_EVENT_MAX_BUFFER_SIZE ((256 - 1)/sizeof(struct dfs_event_info))
+/* Fill in event info */
+PREPACK struct dfs_ev_buffer {
+ A_UINT8 num_events;
+ struct dfs_event_info ev_info[WMI_DFS_EVENT_MAX_BUFFER_SIZE];
+} POSTPACK;
+
+typedef struct dfs_ev_buffer WMI_DFS_PHYERR_EVENT;
+
+
+ /* This should match the table from if_ath.c */
+enum {
+ ATH_DEBUG_DFS = 0x00000100, /* Minimal DFS debug */
+ ATH_DEBUG_DFS1 = 0x00000200, /* Normal DFS debug */
+ ATH_DEBUG_DFS2 = 0x00000400, /* Maximal DFS debug */
+ ATH_DEBUG_DFS3 = 0x00000800, /* matched filterID display */
+};
+
+#define TRAFFIC_DETECTED 1
+
+#endif /* _DFS_H_ */
diff --git a/host/include/dfs_host.h b/host/include/dfs_host.h
new file mode 100644
index 0000000..fc54ec5
--- /dev/null
+++ b/host/include/dfs_host.h
@@ -0,0 +1,387 @@
+/*
+ * Copyright (c) 2005-2006 Atheros Communications, Inc.
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+
+#ifndef _DFS_HOST_H_
+#define _DFS_HOST_H_
+
+#ifdef ATH_SUPPORT_DFS
+
+#include "dfs_host_project.h"
+
+#define DFS_MIN(a,b) ((a)<(b)?(a):(b))
+#define DFS_MAX(a,b) ((a)>(b)?(a):(b))
+#define DFS_DIFF(a,b) (DFS_MAX(a,b) - DFS_MIN(a,b))
+/*
+ * Maximum number of radar events to be processed in a single iteration.
+ * Allows soft watchdog to run.
+ */
+#define MAX_EVENTS 100
+
+
+#define DFS_MARGIN_EQUAL(a, b, margin) ((DFS_DIFF(a,b)) <= margin)
+#define DFS_MAX_STAGGERED_BURSTS 3
+
+/* All filter thresholds in the radar filter tables are effective at a 50% channel loading */
+#define DFS_CHAN_LOADING_THRESH 50
+#define DFS_EXT_CHAN_LOADING_THRESH 30
+#define DFS_DEFAULT_PRI_MARGIN 10
+#define DFS_DEFAULT_FIXEDPATTERN_PRI_MARGIN 6
+
+
+#define ATH_DFSQ_LOCK(_dfs) spin_lock(&(_dfs)->dfs_radarqlock)
+#define ATH_DFSQ_UNLOCK(_dfs) spin_unlock(&(_dfs)->dfs_radarqlock)
+#define ATH_DFSQ_LOCK_INIT(_dfs) spin_lock_init(&(_dfs)->dfs_radarqlock)
+
+#define ATH_ARQ_LOCK(_dfs) spin_lock(&(_dfs)->dfs_arqlock)
+#define ATH_ARQ_UNLOCK(_dfs) spin_unlock(&(_dfs)->dfs_arqlock)
+#define ATH_ARQ_LOCK_INIT(_dfs) spin_lock_init(&(_dfs)->dfs_arqlock)
+
+#define ATH_DFSEVENTQ_LOCK(_dfs) spin_lock(&(_dfs)->dfs_eventqlock)
+#define ATH_DFSEVENTQ_UNLOCK(_dfs) spin_unlock(&(_dfs)->dfs_eventqlock)
+#define ATH_DFSEVENTQ_LOCK_INIT(_dfs) spin_lock_init(&(_dfs)->dfs_eventqlock)
+
+
+#define DFS_TSMASK 0xFFFFFFFF /* Mask for time stamp from descriptor */
+#define DFS_TSSHIFT 32 /* Shift for time stamp from descriptor */
+#define DFS_TSF_WRAP 0xFFFFFFFFFFFFFFFFULL /* 64 bit TSF wrap value */
+#define DFS_64BIT_TSFMASK 0x0000000000007FFFULL /* TS mask for 64 bit value */
+
+
+#define DFS_AR_RADAR_RSSI_THR 5 /* in dB */
+#define DFS_AR_RADAR_RESET_INT 1 /* in secs */
+#define DFS_AR_RADAR_MAX_HISTORY 500
+#define DFS_AR_REGION_WIDTH 128
+#define DFS_AR_RSSI_THRESH_STRONG_PKTS 17 /* in dB */
+#define DFS_AR_RSSI_DOUBLE_THRESHOLD 15 /* in dB */
+#define DFS_AR_MAX_NUM_ACK_REGIONS 9
+#define DFS_AR_ACK_DETECT_PAR_THRESH 20
+#define DFS_AR_PKT_COUNT_THRESH 20
+
+#define DFS_MAX_DL_MASK 0x3F
+
+#define DFS_NOL_TIME 30*60*1000000 /* 30 minutes in usecs */
+
+#define DFS_WAIT_TIME 60*1000000 /* 1 minute in usecs */
+
+#define DFS_DISABLE_TIME 3*60*1000000 /* 3 minutes in usecs */
+
+#define DFS_MAX_B5_SIZE 128
+#define DFS_MAX_B5_MASK 0x0000007F /* 128 */
+
+#define DFS_MAX_RADAR_OVERLAP 16 /* Max number of overlapping filters */
+
+#define DFS_MAX_EVENTS 1024 /* Max number of dfs events which can be q'd */
+
+#define DFS_RADAR_EN 0x80000000 /* Radar detect is capable */
+#define DFS_AR_EN 0x40000000 /* AR detect is capable */
+#define DFS_MAX_RSSI_VALUE 0x7fffffff /* Max rssi value */
+
+#define DFS_BIN_MAX_PULSES 60 /* max num of pulses in a burst */
+#define DFS_BIN5_PRI_LOWER_LIMIT 990 /* us */
+#define DFS_BIN5_PRI_HIGHER_LIMIT 2010 /* us */
+#define DFS_BIN5_WIDTH_MARGIN 4 /* us */
+#define DFS_BIN5_RSSI_MARGIN 5 /* dBm */
+/*Following threshold is not specified but should be okay statistically*/
+#define DFS_BIN5_BRI_LOWER_LIMIT 300000 /* us */
+
+#define DFS_MAX_PULSE_BUFFER_SIZE 1024 /* Max number of pulses kept in buffer */
+#define DFS_MAX_PULSE_BUFFER_MASK 0x3ff
+
+#define DFS_FAST_CLOCK_MULTIPLIER (800/11)
+#define DFS_NO_FAST_CLOCK_MULTIPLIER (80)
+
+typedef spinlock_t dfsq_lock_t;
+
+struct dfs_pulse {
+ A_UINT32 rp_numpulses; /* Num of pulses in radar burst */
+ A_UINT32 rp_pulsedur; /* Duration of each pulse in usecs */
+ A_UINT32 rp_pulsefreq; /* Frequency of pulses in burst */
+ A_UINT32 rp_max_pulsefreq; /* Frequency of pulses in burst */
+ A_UINT32 rp_patterntype; /*fixed or variable pattern type*/
+ A_UINT32 rp_pulsevar; /* Time variation of pulse duration for
+ matched filter (single-sided) in usecs */
+ A_UINT32 rp_threshold; /* Thershold for MF output to indicate
+ radar match */
+ A_UINT32 rp_mindur; /* Min pulse duration to be considered for
+ this pulse type */
+ A_UINT32 rp_maxdur; /* Max pusle duration to be considered for
+ this pulse type */
+ A_UINT32 rp_rssithresh; /* Minimum rssi to be considered a radar pulse */
+ A_UINT32 rp_meanoffset; /* Offset for timing adjustment */
+ A_INT32 rp_rssimargin; /* rssi threshold margin. In Turbo Mode HW reports rssi 3dBm
+ * lower than in non TURBO mode. This will be used to offset
+ * that diff.*/
+ A_UINT32 rp_pulseid; /* Unique ID for identifying filter */
+
+};
+
+struct dfs_bin5pulse {
+ A_UINT32 b5_threshold; /* Number of bin5 pulses to indicate detection */
+ A_UINT32 b5_mindur; /* Min duration for a bin5 pulse */
+ A_UINT32 b5_maxdur; /* Max duration for a bin5 pulse */
+ A_UINT32 b5_timewindow; /* Window over which to count bin5 pulses */
+ A_UINT32 b5_rssithresh; /* Min rssi to be considered a pulse */
+ A_UINT32 b5_rssimargin; /* rssi threshold margin. In Turbo Mode HW reports rssi 3dB */
+};
+
+
+#define DFS_MAX_DL_SIZE 64
+#include "athstartpack.h"
+PREPACK struct dfs_delayelem {
+ u_int32_t de_time; /* Current "filter" time for start of pulse in usecs*/
+ u_int8_t de_dur; /* Duration of pulse in usecs*/
+ u_int8_t de_rssi; /* rssi of pulse in dB*/
+} POSTPACK adf_os_packed;
+
+/* NB: The first element in the circular buffer is the oldest element */
+
+PREPACK struct dfs_delayline {
+ struct dfs_delayelem dl_elems[DFS_MAX_DL_SIZE]; /* Array of pulses in delay line */
+ u_int64_t dl_last_ts; /* Last timestamp the delay line was used (in usecs) */
+ u_int32_t dl_firstelem; /* Index of the first element */
+ u_int32_t dl_lastelem; /* Index of the last element */
+ u_int32_t dl_numelems; /* Number of elements in the delay line */
+} POSTPACK adf_os_packed;
+
+
+PREPACK struct dfs_filter {
+ struct dfs_delayline rf_dl; /* Delay line of pulses for this filter */
+ u_int32_t rf_numpulses; /* Number of pulses in the filter */
+ u_int32_t rf_minpri; /* min pri to be considered for this filter*/
+ u_int32_t rf_maxpri; /* max pri to be considered for this filter*/
+ u_int32_t rf_threshold; /* match filter output threshold for radar detect */
+ u_int32_t rf_filterlen; /* Length (in usecs) of the filter */
+ u_int32_t rf_patterntype; /* fixed or variable pattern type */
+ u_int32_t rf_mindur; /* Min duration for this radar filter */
+ u_int32_t rf_maxdur; /* Max duration for this radar filter */
+ u_int32_t rf_pulseid; /* Unique ID corresponding to the original filter ID */
+} POSTPACK adf_os_packed;
+
+
+
+PREPACK struct dfs_pulseparams {
+ u_int64_t p_time; /* time for start of pulse in usecs*/
+ u_int8_t p_dur; /* Duration of pulse in usecs*/
+ u_int8_t p_rssi; /* Duration of pulse in usecs*/
+} POSTPACK adf_os_packed;
+
+PREPACK struct dfs_pulseline {
+ /* pl_elems - array of pulses in delay line */
+ struct dfs_pulseparams pl_elems[DFS_MAX_PULSE_BUFFER_SIZE];
+ u_int32_t pl_firstelem; /* Index of the first element */
+ u_int32_t pl_lastelem; /* Index of the last element */
+ u_int32_t pl_numelems; /* Number of elements in the delay line */
+} POSTPACK adf_os_packed;
+
+PREPACK struct dfs_event {
+ u_int64_t re_full_ts; /* 64-bit full timestamp from interrupt time */
+ u_int32_t re_ts; /* Original 15 bit recv timestamp */
+ u_int32_t re_ext_chan_busy; /* Ext channel busy % */
+ u_int8_t re_rssi; /* rssi of radar event */
+ u_int8_t re_dur; /* duration of radar pulse */
+ u_int8_t re_chanindex; /* Channel of event */
+ u_int8_t re_chanindextype; /* Primary channel or extension channel */
+ STAILQ_ENTRY(dfs_event) re_list; /* List of radar events */
+} POSTPACK adf_os_packed;
+#include "athendpack.h"
+
+#define DFS_AR_MAX_ACK_RADAR_DUR 511
+#define DFS_AR_MAX_NUM_PEAKS 3
+#define DFS_AR_ARQ_SIZE 2048 /* 8K AR events for buffer size */
+#define DFS_AR_ARQ_SEQSIZE 2049 /* Sequence counter wrap for AR */
+
+#define DFS_RADARQ_SIZE 512 /* 1K radar events for buffer size */
+#define DFS_RADARQ_SEQSIZE 513 /* Sequence counter wrap for radar */
+#define DFS_NUM_RADAR_STATES 64 /* Number of radar channels we keep state for */
+#define DFS_MAX_NUM_RADAR_FILTERS 10 /* Max number radar filters for each type */
+#define DFS_MAX_RADAR_TYPES 32 /* Number of different radar types */
+
+struct dfs_ar_state {
+ u_int32_t ar_prevwidth;
+ u_int32_t ar_phyerrcount[DFS_AR_MAX_ACK_RADAR_DUR];
+ u_int32_t ar_acksum;
+ u_int32_t ar_packetthreshold; /* Thresh to determine traffic load */
+ u_int32_t ar_parthreshold; /* Thresh to determine peak */
+ u_int32_t ar_radarrssi; /* Rssi threshold for AR event */
+ u_int16_t ar_prevtimestamp;
+ u_int16_t ar_peaklist[DFS_AR_MAX_NUM_PEAKS];
+};
+
+struct dfs_filtertype {
+ struct dfs_filter ft_filters[DFS_MAX_NUM_RADAR_FILTERS];
+ u_int32_t ft_filterdur; /* Duration of pulse which specifies filter type*/
+ u_int32_t ft_numfilters; /* Num filters of this type */
+ u_int64_t ft_last_ts; /* Last timestamp this filtertype was used
+ * (in usecs) */
+ u_int32_t ft_mindur; /* min pulse duration to be considered
+ * for this filter type */
+ u_int32_t ft_maxdur; /* max pulse duration to be considered
+ * for this filter type */
+ u_int32_t ft_rssithresh; /* min rssi to be considered
+ * for this filter type */
+ u_int32_t ft_numpulses; /* Num pulses in each filter of this type */
+ u_int32_t ft_patterntype; /* fixed or variable pattern type */
+ u_int32_t ft_minpri; /* min pri to be considered for this type */
+ u_int32_t ft_rssimargin; /* rssi threshold margin. In Turbo Mode HW
+ * reports rssi 3dB lower than in non TURBO
+ * mode. This will offset that diff. */
+};
+
+
+#define DFS_NOL_TIMEOUT_S (30*60) /* 30 minutes in seconds */
+#define DFS_NOL_TIMEOUT_MS (DFS_NOL_TIMEOUT_S * 1000)
+#define DFS_NOL_TIMEOUT_US (DFS_NOL_TIMEOUT_MS * 1000)
+
+#include "athstartpack.h"
+PREPACK struct dfs_info_host {
+ u_int32_t rn_numradars; /* Number of different types of radars */
+ u_int64_t rn_lastfull_ts; /* Last 64 bit timstamp from recv interrupt */
+ u_int16_t rn_last_ts; /* last 15 bit ts from recv descriptor */
+ u_int32_t rn_last_unique_ts; /* last unique 32 bit ts from recv descriptor */
+ u_int64_t rn_ts_prefix; /* Prefix to prepend to 15 bit recv ts */
+ u_int32_t rn_numbin5radars; /* Number of bin5 radar pulses to search for */
+ u_int64_t dfs_bin5_chirp_ts;
+ u_int8_t dfs_last_bin5_dur;
+} POSTPACK adf_os_packed;
+#include "athendpack.h"
+
+struct dfs_bin5elem {
+ u_int64_t be_ts; /* Timestamp for the bin5 element */
+ u_int32_t be_rssi; /* Rssi for the bin5 element */
+ u_int32_t be_dur; /* Duration of bin5 element */
+};
+
+struct dfs_bin5radars {
+ struct dfs_bin5elem br_elems[DFS_MAX_B5_SIZE]; /* List of bin5 elems that fall
+ * within the time window */
+ u_int32_t br_firstelem; /* Index of the first element */
+ u_int32_t br_lastelem; /* Index of the last element */
+ u_int32_t br_numelems; /* Number of elements in the delay line */
+ struct dfs_bin5pulse br_pulse; /* Original info about bin5 pulse */
+};
+
+
+#define ATH_DFS_RESET_TIME_S 7
+#define ATH_DFS_WAIT (60 + ATH_DFS_RESET_TIME_S) /* 60 seconds */
+#define ATH_DFS_WAIT_MS ((ATH_DFS_WAIT) * 1000) /*in MS*/
+
+#define ATH_DFS_WEATHER_CHANNEL_WAIT_MIN 10 /*10 minutes*/
+#define ATH_DFS_WEATHER_CHANNEL_WAIT_S (ATH_DFS_WEATHER_CHANNEL_WAIT_MIN * 60)
+#define ATH_DFS_WEATHER_CHANNEL_WAIT_MS ((ATH_DFS_WEATHER_CHANNEL_WAIT_S) * 1000) /*in MS*/
+
+#define ATH_DFS_WAIT_POLL_PERIOD 2 /* 2 seconds */
+#define ATH_DFS_WAIT_POLL_PERIOD_MS ((ATH_DFS_WAIT_POLL_PERIOD) * 1000) /*in MS*/
+#define ATH_DFS_TEST_RETURN_PERIOD 2 /* 2 seconds */
+#define ATH_DFS_TEST_RETURN_PERIOD_MS ((ATH_DFS_TEST_RETURN_PERIOD) * 1000)/* n MS*/
+
+#define IS_CHANNEL_WEATHER_RADAR(chan) ((chan->channel >= 5600) && (chan->channel <= 5650))
+
+#define DFS_DEBUG_TIMEOUT_S 30 // debug timeout is 30 seconds
+#define DFS_DEBUG_TIMEOUT_MS (DFS_DEBUG_TIMEOUT_S * 1000)
+struct ath_dfs_host {
+ DEV_HDL dev_hdl;
+ u_int32_t dfs_debug_level;
+ OS_HDL os_hdl;
+ STAILQ_HEAD(,dfs_event) dfs_eventq; /* Q of free dfs event objects */
+ dfsq_lock_t dfs_eventqlock; /* Lock for free dfs event list */
+ STAILQ_HEAD(,dfs_event) dfs_radarq; /* Q of radar events */
+ dfsq_lock_t dfs_radarqlock; /* Lock for dfs q */
+ STAILQ_HEAD(,dfs_event) dfs_arq; /* Q of AR events */
+ dfsq_lock_t dfs_arqlock; /* Lock for AR q */
+
+ struct dfs_pulseline *pulses; /* pulse history */
+ struct dfs_event *events; /* Events structure */
+ /* dfs_radarf - One filter for each radar pulse type */
+ struct dfs_filtertype *dfs_radarf[DFS_MAX_RADAR_TYPES];
+
+ int8_t **dfs_radartable; /* map of radar durs to filter types */
+ struct dfs_bin5radars *dfs_b5radars;/* array of bin5 radar events */
+ struct dfs_ar_state dfs_ar_state; /* AR state */
+ struct dfs_info_host dfs_rinfo; /* State vars for radar processing */
+ u_int8_t dfs_bangradar;
+ u_int32_t dur_multiplier;
+ A_TIMER dfs_radar_task_timer;
+};
+
+
+#define HAL_CAP_RADAR 0
+#define HAL_CAP_AR 1
+#define HAL_CAP_STRONG_DIV 2
+
+
+/* Attach, detach, handle ioctl prototypes */
+struct ath_dfs_host *dfs_attach_host(DEV_HDL dev, OS_HDL os, ATH_DFS_CAPINFO *cap_info);
+void dfs_detach_host(struct ath_dfs_host *sc);
+
+
+/* PHY error and radar event handling */
+void dfs_process_phyerr_host(struct ath_dfs_host *dfs, WMI_DFS_PHYERR_EVENT *ev);
+int dfs_process_radarevent_host(struct ath_dfs_host *dfs, int16_t *chan_index, u_int8_t *bangradar);
+
+
+/* FCC Bin5 detection prototypes */
+int dfs_bin5_addpulse(struct ath_dfs_host *sc, struct dfs_bin5radars *br,
+ struct dfs_event *re, u_int64_t thists);
+int dfs_bin5_check(struct ath_dfs_host *dfs);
+u_int8_t dfs_retain_bin5_burst_pattern(struct ath_dfs_host *dfs, u_int32_t diff_ts, u_int8_t old_dur);
+
+/* Debug prototypes */
+void dfs_print_delayline(struct ath_dfs_host *dfs, struct dfs_delayline *dl);
+void dfs_print_filters(struct ath_dfs_host *dfs);
+void dfs_print_filter(struct ath_dfs_host *dfs, struct dfs_filter *rf);
+
+/* Misc prototypes */
+u_int32_t dfs_round(int32_t val);
+
+/* Reset and init data structures */
+
+int dfs_init_radar_filters_host(struct ath_dfs_host *dfs, struct ath_dfs_info *dfs_info);
+void dfs_reset_alldelaylines(struct ath_dfs_host *dfs);
+void dfs_reset_delayline(struct dfs_delayline *dl);
+void dfs_reset_filter_delaylines(struct dfs_filtertype *dft);
+void dfs_reset_radarq(struct ath_dfs_host *dfs);
+
+/* Detection algorithm prototypes */
+void dfs_add_pulse(struct ath_dfs_host *dfs, struct dfs_filter *rf,
+ struct dfs_event *re, u_int32_t deltaT);
+
+int dfs_bin_fixedpattern_check(struct ath_dfs_host *dfs, struct dfs_filter *rf, u_int32_t dur, int ext_chan_flag, u_int32_t ext_chan_busy);
+int dfs_bin_check(struct ath_dfs_host *dfs, struct dfs_filter *rf,
+ u_int32_t deltaT, u_int32_t dur, int ext_chan_flag, u_int32_t ext_chan_busy);
+
+
+int dfs_bin_pri_check(struct ath_dfs_host *dfs, struct dfs_filter *rf,
+ struct dfs_delayline *dl, u_int32_t score,
+ u_int32_t refpri, u_int32_t refdur, int ext_chan_flag, u_int32_t ext_chan_busy);
+int dfs_staggered_check(struct ath_dfs_host *dfs, struct dfs_filter *rf,
+ u_int32_t deltaT, u_int32_t width, u_int32_t ext_chan_busy);
+
+/* AR related prototypes */
+u_int32_t dfs_process_ar_event(struct ath_dfs_host *dfs);
+void dfs_reset_ar(struct ath_dfs_host *dfs);
+void dfs_reset_arq(struct ath_dfs_host *dfs);
+
+void dfs_bangradar_enable(struct ath_dfs_host *dfs, u_int8_t enable);
+void dfs_set_dur_multiplier(struct ath_dfs_host *dfs, u_int32_t dur_multiplier);
+void dfs_set_debug_level_host(struct ath_dfs_host *dfs, u_int32_t level);
+
+/* False detection reduction */
+int dfs_get_pri_margin(int is_extchan_detect, int is_fixed_pattern, u_int64_t lastfull_ts, u_int32_t ext_chan_busy);
+int dfs_get_filter_threshold(struct dfs_filter *rf, int is_extchan_detect, u_int64_t lastfull_ts, u_int32_t ext_chan_busy);
+
+#endif /* ATH_SUPPORT_DFS */
+#endif /* _DFS_H_ */
diff --git a/host/include/dfs_host_project.h b/host/include/dfs_host_project.h
new file mode 100644
index 0000000..9f1ce2f
--- /dev/null
+++ b/host/include/dfs_host_project.h
@@ -0,0 +1,57 @@
+/*
+ * Copyright (c) 2005-2006 Atheros Communications, Inc.
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+
+#ifndef _DFS_PROJECT_H_
+#define _DFS_PROJECT_H_
+
+#ifdef ATH_SUPPORT_DFS
+
+#include <a_config.h>
+#include <athdefs.h>
+#include <a_types.h>
+#include <a_osapi.h>
+#include <a_debug.h>
+#include <queue.h> /* XXX: This is in target dir */
+#include "dfs_common.h"
+#include "ar6000_drv.h"
+#include "project.h"
+
+#define ATH_DFS_CAPINFO WMI_DFS_HOST_ATTACH_EVENT
+
+#define OS_HDL void *
+#define DEV_HDL void *
+
+#define DFS_MALLOC(os_hdl, nbytes) A_MALLOC(nbytes)
+
+#define DFS_DPRINTK(pDfs, _m, _fmt, ...) do { \
+ if ((_m) <= pDfs->dfs_debug_level) { \
+ A_PRINTF(_fmt, __VA_ARGS__); \
+ } \
+} while (0)
+
+
+void dfs_radar_task (unsigned long arg);
+
+#define adf_os_packed
+
+typedef enum {
+ AH_FALSE = 0, /* NB: lots of code assumes false is zero */
+ AH_TRUE = 1,
+} HAL_BOOL;
+#endif /* ATH_SUPPORT_DFS */
+
+#endif /* _DFS_PROJECT_H_ */
diff --git a/host/include/discovery.h b/host/include/discovery.h
new file mode 100644
index 0000000..12e3a58
--- /dev/null
+++ b/host/include/discovery.h
@@ -0,0 +1,77 @@
+//------------------------------------------------------------------------------
+// <copyright file="discovery.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _DISCOVERY_H_
+#define _DISCOVERY_H_
+
+/*
+ * DC_SCAN_PRIORITY is an 8-bit bitmap of the scan priority of a channel
+ */
+typedef enum {
+ DEFAULT_SCPRI = 0x01,
+ POPULAR_SCPRI = 0x02,
+ SSIDS_SCPRI = 0x04,
+ PROF_SCPRI = 0x08,
+ DISABLE_SCPRI = 0x10,
+} DC_SCAN_PRIORITY;
+
+/* The following search type construct can be used to manipulate the behavior of the search module based on different bits set */
+typedef enum {
+ SCAN_RESET = 0,
+ SCAN_ALL = (DEFAULT_SCPRI | POPULAR_SCPRI | \
+ SSIDS_SCPRI | PROF_SCPRI),
+
+ SCAN_POPULAR = (POPULAR_SCPRI | SSIDS_SCPRI | PROF_SCPRI),
+ SCAN_SSIDS = (SSIDS_SCPRI | PROF_SCPRI),
+ SCAN_PROF_MASK = (PROF_SCPRI),
+ SCAN_MULTI_CHANNEL = 0x000100,
+ SCAN_DETERMINISTIC = 0x000200,
+ SCAN_PROFILE_MATCH_TERMINATED = 0x000400,
+ SCAN_HOME_CHANNEL_SKIP = 0x000800,
+ SCAN_CHANNEL_LIST_CONTINUE = 0x001000,
+ SCAN_CURRENT_SSID_SKIP = 0x002000,
+ SCAN_ACTIVE_PROBE_DISABLE = 0x004000,
+ SCAN_CHANNEL_HINT_ONLY = 0x008000,
+ SCAN_ACTIVE_CHANNELS_ONLY = 0x010000,
+ SCAN_UNUSED1 = 0x020000, /* unused */
+ SCAN_PERIODIC = 0x040000,
+ SCAN_FIXED_DURATION = 0x080000,
+ SCAN_AP_ASSISTED = 0x100000,
+ SCAN_DONOT_RETURN_TO_HOME_AFTERSCAN = 0x200000,
+} DC_SCAN_TYPE;
+
+typedef enum {
+ BSS_REPORTING_DEFAULT = 0x0,
+ EXCLUDE_NON_SCAN_RESULTS = 0x1, /* Exclude results outside of scan */
+} DC_BSS_REPORTING_POLICY;
+
+typedef enum {
+ DC_IGNORE_WPAx_GROUP_CIPHER = 0x01,
+ DC_PROFILE_MATCH_DONE = 0x02,
+ DC_IGNORE_AAC_BEACON = 0x04,
+ DC_CSA_FOLLOW_BSS = 0x08,
+} DC_PROFILE_FILTER;
+
+#define DEFAULT_DC_PROFILE_FILTER (DC_CSA_FOLLOW_BSS)
+
+#endif /* _DISCOVERY_H_ */
diff --git a/host/include/dl_list.h b/host/include/dl_list.h
new file mode 100644
index 0000000..cc0e544
--- /dev/null
+++ b/host/include/dl_list.h
@@ -0,0 +1,154 @@
+//------------------------------------------------------------------------------
+// <copyright file="dl_list.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Double-link list definitions (adapted from Atheros SDIO stack)
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef __DL_LIST_H___
+#define __DL_LIST_H___
+
+#include "a_osapi.h"
+
+#define A_CONTAINING_STRUCT(address, struct_type, field_name)\
+ ((struct_type *)((unsigned long)(address) - (unsigned long)(&((struct_type *)0)->field_name)))
+
+/* list functions */
+/* pointers for the list */
+typedef struct _DL_LIST {
+ struct _DL_LIST *pPrev;
+ struct _DL_LIST *pNext;
+}DL_LIST, *PDL_LIST;
+/*
+ * DL_LIST_INIT , initialize doubly linked list
+*/
+#define DL_LIST_INIT(pList)\
+ {(pList)->pPrev = pList; (pList)->pNext = pList;}
+
+/* faster macro to init list and add a single item */
+#define DL_LIST_INIT_AND_ADD(pList,pItem) \
+{ (pList)->pPrev = (pItem); \
+ (pList)->pNext = (pItem); \
+ (pItem)->pNext = (pList); \
+ (pItem)->pPrev = (pList); \
+}
+
+#define DL_LIST_IS_EMPTY(pList) (((pList)->pPrev == (pList)) && ((pList)->pNext == (pList)))
+#define DL_LIST_GET_ITEM_AT_HEAD(pList) (pList)->pNext
+#define DL_LIST_GET_ITEM_AT_TAIL(pList) (pList)->pPrev
+/*
+ * ITERATE_OVER_LIST pStart is the list, pTemp is a temp list member
+ * NOT: do not use this function if the items in the list are deleted inside the
+ * iteration loop
+*/
+#define ITERATE_OVER_LIST(pStart, pTemp) \
+ for((pTemp) =(pStart)->pNext; pTemp != (pStart); (pTemp) = (pTemp)->pNext)
+
+
+/* safe iterate macro that allows the item to be removed from the list
+ * the iteration continues to the next item in the list
+ */
+#define ITERATE_OVER_LIST_ALLOW_REMOVE(pStart,pItem,st,offset) \
+{ \
+ PDL_LIST pTemp; \
+ pTemp = (pStart)->pNext; \
+ while (pTemp != (pStart)) { \
+ (pItem) = A_CONTAINING_STRUCT(pTemp,st,offset); \
+ pTemp = pTemp->pNext; \
+
+#define ITERATE_END }}
+
+/*
+ * DL_ListInsertTail - insert pAdd to the end of the list
+*/
+static INLINE PDL_LIST DL_ListInsertTail(PDL_LIST pList, PDL_LIST pAdd) {
+ /* insert at tail */
+ pAdd->pPrev = pList->pPrev;
+ pAdd->pNext = pList;
+ pList->pPrev->pNext = pAdd;
+ pList->pPrev = pAdd;
+ return pAdd;
+}
+
+/*
+ * DL_ListInsertHead - insert pAdd into the head of the list
+*/
+static INLINE PDL_LIST DL_ListInsertHead(PDL_LIST pList, PDL_LIST pAdd) {
+ /* insert at head */
+ pAdd->pPrev = pList;
+ pAdd->pNext = pList->pNext;
+ pList->pNext->pPrev = pAdd;
+ pList->pNext = pAdd;
+ return pAdd;
+}
+
+#define DL_ListAdd(pList,pItem) DL_ListInsertHead((pList),(pItem))
+/*
+ * DL_ListRemove - remove pDel from list
+*/
+static INLINE PDL_LIST DL_ListRemove(PDL_LIST pDel) {
+ pDel->pNext->pPrev = pDel->pPrev;
+ pDel->pPrev->pNext = pDel->pNext;
+ /* point back to itself just to be safe, incase remove is called again */
+ pDel->pNext = pDel;
+ pDel->pPrev = pDel;
+ return pDel;
+}
+
+/*
+ * DL_ListRemoveItemFromHead - get a list item from the head
+*/
+static INLINE PDL_LIST DL_ListRemoveItemFromHead(PDL_LIST pList) {
+ PDL_LIST pItem = NULL;
+ if (pList->pNext != pList) {
+ pItem = pList->pNext;
+ /* remove the first item from head */
+ DL_ListRemove(pItem);
+ }
+ return pItem;
+}
+
+static INLINE PDL_LIST DL_ListRemoveItemFromTail(PDL_LIST pList) {
+ PDL_LIST pItem = NULL;
+ if (pList->pPrev != pList) {
+ pItem = pList->pPrev;
+ /* remove the item from tail */
+ DL_ListRemove(pItem);
+ }
+ return pItem;
+}
+
+/* transfer src list items to the tail of the destination list */
+static INLINE void DL_ListTransferItemsToTail(PDL_LIST pDest, PDL_LIST pSrc) {
+ /* only concatenate if src is not empty */
+ if (!DL_LIST_IS_EMPTY(pSrc)) {
+ /* cut out circular list in src and re-attach to end of dest */
+ pSrc->pPrev->pNext = pDest;
+ pSrc->pNext->pPrev = pDest->pPrev;
+ pDest->pPrev->pNext = pSrc->pNext;
+ pDest->pPrev = pSrc->pPrev;
+ /* terminate src list, it is now empty */
+ pSrc->pPrev = pSrc;
+ pSrc->pNext = pSrc;
+ }
+}
+
+#endif /* __DL_LIST_H___ */
+
diff --git a/host/include/dset_api.h b/host/include/dset_api.h
new file mode 100644
index 0000000..0cc121f
--- /dev/null
+++ b/host/include/dset_api.h
@@ -0,0 +1,65 @@
+//------------------------------------------------------------------------------
+// <copyright file="dset_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Host-side DataSet API.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _DSET_API_H_
+#define _DSET_API_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/*
+ * Host-side DataSet support is optional, and is not
+ * currently required for correct operation. To disable
+ * Host-side DataSet support, set this to 0.
+ */
+#ifndef CONFIG_HOST_DSET_SUPPORT
+#define CONFIG_HOST_DSET_SUPPORT 1
+#endif
+
+/* Called to send a DataSet Open Reply back to the Target. */
+A_STATUS wmi_dset_open_reply(struct wmi_t *wmip,
+ A_UINT32 status,
+ A_UINT32 access_cookie,
+ A_UINT32 size,
+ A_UINT32 version,
+ A_UINT32 targ_handle,
+ A_UINT32 targ_reply_fn,
+ A_UINT32 targ_reply_arg);
+
+/* Called to send a DataSet Data Reply back to the Target. */
+A_STATUS wmi_dset_data_reply(struct wmi_t *wmip,
+ A_UINT32 status,
+ A_UINT8 *host_buf,
+ A_UINT32 length,
+ A_UINT32 targ_buf,
+ A_UINT32 targ_reply_fn,
+ A_UINT32 targ_reply_arg);
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+
+#endif /* _DSET_API_H_ */
diff --git a/host/include/dset_internal.h b/host/include/dset_internal.h
new file mode 100644
index 0000000..2330a57
--- /dev/null
+++ b/host/include/dset_internal.h
@@ -0,0 +1,63 @@
+//------------------------------------------------------------------------------
+// <copyright file="dset_internal.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+
+#ifndef __DSET_INTERNAL_H__
+#define __DSET_INTERNAL_H__
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+/*
+ * Internal dset definitions, common for DataSet layer.
+ */
+
+#define DSET_TYPE_STANDARD 0
+#define DSET_TYPE_BPATCHED 1
+#define DSET_TYPE_COMPRESSED 2
+
+/* Dataset descriptor */
+
+typedef PREPACK struct dset_descriptor_s {
+ struct dset_descriptor_s *next; /* List link. NULL only at the last
+ descriptor */
+ A_UINT16 id; /* Dset ID */
+ A_UINT16 size; /* Dset size. */
+ void *DataPtr; /* Pointer to raw data for standard
+ DataSet or pointer to original
+ dset_descriptor for patched
+ DataSet */
+ A_UINT32 data_type; /* DSET_TYPE_*, above */
+
+ void *AuxPtr; /* Additional data that might
+ needed for data_type. For
+ example, pointer to patch
+ Dataset descriptor for BPatch. */
+} POSTPACK dset_descriptor_t;
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#endif /* __DSET_INTERNAL_H__ */
diff --git a/host/include/dsetid.h b/host/include/dsetid.h
new file mode 100644
index 0000000..f17fc67
--- /dev/null
+++ b/host/include/dsetid.h
@@ -0,0 +1,134 @@
+//------------------------------------------------------------------------------
+// <copyright file="dsetid.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+
+#ifndef __DSETID_H__
+#define __DSETID_H__
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+/* Well-known DataSet IDs */
+#define DSETID_UNUSED 0x00000000
+#define DSETID_BOARD_DATA 0x00000001 /* Cal and board data */
+#define DSETID_REGDB 0x00000002 /* Regulatory Database */
+#define DSETID_POWER_CONTROL 0x00000003 /* TX Pwr Lim & Ant Gain */
+#define DSETID_USER_CONFIG 0x00000004 /* User Configuration */
+
+#define DSETID_ANALOG_CONTROL_DATA_START 0x00000005
+#define DSETID_ANALOG_CONTROL_DATA_END 0x00000025
+/*
+ * Get DSETID for various reference clock speeds.
+ * For each speed there are three DataSets that correspond
+ * to the three columns of bank6 data (addr, 11a, 11b/g).
+ * This macro returns the dsetid of the first of those
+ * three DataSets.
+ */
+#define ANALOG_CONTROL_DATA_DSETID(refclk) \
+ (DSETID_ANALOG_CONTROL_DATA_START + 3*refclk)
+
+/*
+ * There are TWO STARTUP_PATCH DataSets.
+ * DSETID_STARTUP_PATCH is historical, and was applied before BMI on
+ * earlier systems. On AR6002, it is applied after BMI, just like
+ * DSETID_STARTUP_PATCH2.
+ */
+#define DSETID_STARTUP_PATCH 0x00000026
+#define DSETID_GPIO_CONFIG_PATCH 0x00000027
+#define DSETID_WLANREGS 0x00000028 /* override wlan regs */
+#define DSETID_STARTUP_PATCH2 0x00000029
+
+#define DSETID_WOW_CONFIG 0x00000090 /* WoW Configuration */
+
+/* Add WHAL_INI_DATA_ID to DSETID_INI_DATA for a specific WHAL INI table. */
+#define DSETID_INI_DATA 0x00000100
+/* Reserved for WHAL INI Tables: 0x100..0x11f */
+#define DSETID_INI_DATA_END 0x0000011f
+
+#define DSETID_VENDOR_START 0x00010000 /* Vendor-defined DataSets */
+
+#define DSETID_INDEX_END 0xfffffffe /* Reserved to indicate the
+ end of a memory-based
+ DataSet Index */
+#define DSETID_INDEX_FREE 0xffffffff /* An unused index entry */
+
+/*
+ * PATCH DataSet format:
+ * A list of patches, terminated by a patch with
+ * address=PATCH_END.
+ *
+ * This allows for patches to be stored in flash.
+ */
+PREPACK struct patch_s {
+ A_UINT32 *address;
+ A_UINT32 data;
+} POSTPACK ;
+
+/*
+ * Skip some patches. Can be used to erase a single patch in a
+ * patch DataSet without having to re-write the DataSet. May
+ * also be used to embed information for use by subsequent
+ * patch code. The "data" in a PATCH_SKIP tells how many
+ * bytes of length "patch_s" to skip.
+ */
+#define PATCH_SKIP ((A_UINT32 *)0x00000000)
+
+/*
+ * Execute code at the address specified by "data".
+ * The address of the patch structure is passed as
+ * the one parameter.
+ */
+#define PATCH_CODE_ABS ((A_UINT32 *)0x00000001)
+
+/*
+ * Same as PATCH_CODE_ABS, but treat "data" as an
+ * offset from the start of the patch word.
+ */
+#define PATCH_CODE_REL ((A_UINT32 *)0x00000002)
+
+/* Mark the end of this patch DataSet. */
+#define PATCH_END ((A_UINT32 *)0xffffffff)
+
+/*
+ * A DataSet which contains a Binary Patch to some other DataSet
+ * uses the original dsetid with the DSETID_BPATCH_FLAG bit set.
+ * Such a BPatch DataSet consists of BPatch metadata followed by
+ * the bdiff bytes. BPatch metadata consists of a single 32-bit
+ * word that contains the size of the BPatched final image.
+ *
+ * To create a suitable bdiff DataSet, use bdiff in host/tools/bdiff
+ * to create "diffs":
+ * bdiff -q -O -nooldmd5 -nonewmd5 -d ORIGfile NEWfile diffs
+ * Then add BPatch metadata to the start of "diffs".
+ *
+ * NB: There are some implementation-induced restrictions
+ * on which DataSets can be BPatched.
+ */
+#define DSETID_BPATCH_FLAG 0x80000000
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#endif /* __DSETID_H__ */
diff --git a/host/include/epping_test.h b/host/include/epping_test.h
new file mode 100644
index 0000000..62f609f
--- /dev/null
+++ b/host/include/epping_test.h
@@ -0,0 +1,120 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//
+
+/* This file contains shared definitions for the host/target endpoint ping test */
+
+#ifndef EPPING_TEST_H_
+#define EPPING_TEST_H_
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+ /* alignment to 4-bytes */
+#define EPPING_ALIGNMENT_PAD (((sizeof(HTC_FRAME_HDR) + 3) & (~0x3)) - sizeof(HTC_FRAME_HDR))
+
+#ifndef A_OFFSETOF
+#define A_OFFSETOF(type,field) (int)(&(((type *)NULL)->field))
+#endif
+
+#define EPPING_RSVD_FILL 0xCC
+
+#define HCI_RSVD_EXPECTED_PKT_TYPE_RECV_OFFSET 7
+
+typedef PREPACK struct {
+ A_UINT8 _HCIRsvd[8]; /* reserved for HCI packet header (GMBOX) testing */
+ A_UINT8 StreamEcho_h; /* stream no. to echo this packet on (filled by host) */
+ A_UINT8 StreamEchoSent_t; /* stream no. packet was echoed to (filled by target)
+ When echoed: StreamEchoSent_t == StreamEcho_h */
+ A_UINT8 StreamRecv_t; /* stream no. that target received this packet on (filled by target) */
+ A_UINT8 StreamNo_h; /* stream number to send on (filled by host) */
+ A_UINT8 Magic_h[4]; /* magic number to filter for this packet on the host*/
+ A_UINT8 _rsvd[6]; /* reserved fields that must be set to a "reserved" value
+ since this packet maps to a 14-byte ethernet frame we want
+ to make sure ethertype field is set to something unknown */
+
+ A_UINT8 _pad[2]; /* padding for alignment */
+ A_UINT8 TimeStamp[8]; /* timestamp of packet (host or target) */
+ A_UINT32 HostContext_h; /* 4 byte host context, target echos this back */
+ A_UINT32 SeqNo; /* sequence number (set by host or target) */
+ A_UINT16 Cmd_h; /* ping command (filled by host) */
+ A_UINT16 CmdFlags_h; /* optional flags */
+ A_UINT8 CmdBuffer_h[8]; /* buffer for command (host -> target) */
+ A_UINT8 CmdBuffer_t[8]; /* buffer for command (target -> host) */
+ A_UINT16 DataLength; /* length of data */
+ A_UINT16 DataCRC; /* 16 bit CRC of data */
+ A_UINT16 HeaderCRC; /* header CRC (fields : StreamNo_h to end, minus HeaderCRC) */
+} POSTPACK EPPING_HEADER;
+
+#define EPPING_PING_MAGIC_0 0xAA
+#define EPPING_PING_MAGIC_1 0x55
+#define EPPING_PING_MAGIC_2 0xCE
+#define EPPING_PING_MAGIC_3 0xEC
+
+
+
+#define IS_EPPING_PACKET(pPkt) (((pPkt)->Magic_h[0] == EPPING_PING_MAGIC_0) && \
+ ((pPkt)->Magic_h[1] == EPPING_PING_MAGIC_1) && \
+ ((pPkt)->Magic_h[2] == EPPING_PING_MAGIC_2) && \
+ ((pPkt)->Magic_h[3] == EPPING_PING_MAGIC_3))
+
+#define SET_EPPING_PACKET_MAGIC(pPkt) { (pPkt)->Magic_h[0] = EPPING_PING_MAGIC_0; \
+ (pPkt)->Magic_h[1] = EPPING_PING_MAGIC_1; \
+ (pPkt)->Magic_h[2] = EPPING_PING_MAGIC_2; \
+ (pPkt)->Magic_h[3] = EPPING_PING_MAGIC_3;}
+
+#define CMD_FLAGS_DATA_CRC (1 << 0) /* DataCRC field is valid */
+#define CMD_FLAGS_DELAY_ECHO (1 << 1) /* delay the echo of the packet */
+#define CMD_FLAGS_NO_DROP (1 << 2) /* do not drop at HTC layer no matter what the stream is */
+
+#define IS_EPING_PACKET_NO_DROP(pPkt) ((pPkt)->CmdFlags_h & CMD_FLAGS_NO_DROP)
+
+#define EPPING_CMD_ECHO_PACKET 1 /* echo packet test */
+#define EPPING_CMD_RESET_RECV_CNT 2 /* reset recv count */
+#define EPPING_CMD_CAPTURE_RECV_CNT 3 /* fetch recv count, 4-byte count returned in CmdBuffer_t */
+#define EPPING_CMD_NO_ECHO 4 /* non-echo packet test (tx-only) */
+#define EPPING_CMD_CONT_RX_START 5 /* continous RX packets, parameters are in CmdBuffer_h */
+#define EPPING_CMD_CONT_RX_STOP 6 /* stop continuous RX packet transmission */
+
+ /* test command parameters may be no more than 8 bytes */
+typedef PREPACK struct {
+ A_UINT16 BurstCnt; /* number of packets to burst together (for HTC 2.1 testing) */
+ A_UINT16 PacketLength; /* length of packet to generate including header */
+ A_UINT16 Flags; /* flags */
+
+#define EPPING_CONT_RX_DATA_CRC (1 << 0) /* Add CRC to all data */
+#define EPPING_CONT_RX_RANDOM_DATA (1 << 1) /* randomize the data pattern */
+#define EPPING_CONT_RX_RANDOM_LEN (1 << 2) /* randomize the packet lengths */
+} POSTPACK EPPING_CONT_RX_PARAMS;
+
+#define EPPING_HDR_CRC_OFFSET A_OFFSETOF(EPPING_HEADER,StreamNo_h)
+#define EPPING_HDR_BYTES_CRC (sizeof(EPPING_HEADER) - EPPING_HDR_CRC_OFFSET - (sizeof(A_UINT16)))
+
+#define HCI_TRANSPORT_STREAM_NUM 16 /* this number is higher than the define WMM AC classes so we
+ can use this to distinguish packets */
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+
+#endif /*EPPING_TEST_H_*/
diff --git a/host/include/gmboxif.h b/host/include/gmboxif.h
new file mode 100644
index 0000000..8fb751c
--- /dev/null
+++ b/host/include/gmboxif.h
@@ -0,0 +1,83 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __GMBOXIF_H__
+#define __GMBOXIF_H__
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+/* GMBOX interface definitions */
+
+#define AR6K_GMBOX_CREDIT_COUNTER 1 /* we use credit counter 1 to track credits */
+#define AR6K_GMBOX_CREDIT_SIZE_COUNTER 2 /* credit counter 2 is used to pass the size of each credit */
+
+
+ /* HCI UART transport definitions when used over GMBOX interface */
+#define HCI_UART_COMMAND_PKT 0x01
+#define HCI_UART_ACL_PKT 0x02
+#define HCI_UART_SCO_PKT 0x03
+#define HCI_UART_EVENT_PKT 0x04
+
+ /* definitions for BT HCI packets */
+typedef PREPACK struct {
+ A_UINT16 Flags_ConnHandle;
+ A_UINT16 Length;
+} POSTPACK BT_HCI_ACL_HEADER;
+
+typedef PREPACK struct {
+ A_UINT16 Flags_ConnHandle;
+ A_UINT8 Length;
+} POSTPACK BT_HCI_SCO_HEADER;
+
+typedef PREPACK struct {
+ A_UINT16 OpCode;
+ A_UINT8 ParamLength;
+} POSTPACK BT_HCI_COMMAND_HEADER;
+
+typedef PREPACK struct {
+ A_UINT8 EventCode;
+ A_UINT8 ParamLength;
+} POSTPACK BT_HCI_EVENT_HEADER;
+
+/* MBOX host interrupt signal assignments */
+
+#define MBOX_SIG_HCI_BRIDGE_MAX 8
+#define MBOX_SIG_HCI_BRIDGE_BT_ON 0
+#define MBOX_SIG_HCI_BRIDGE_BT_OFF 1
+#define MBOX_SIG_HCI_BRIDGE_BAUD_SET 2
+#define MBOX_SIG_HCI_BRIDGE_PWR_SAV_ON 3
+#define MBOX_SIG_HCI_BRIDGE_PWR_SAV_OFF 4
+
+/* Host interrupts target to change baud rate and
+ * baud rate info is stored in scratch registers 4 and 5
+ */
+#define LSB_SCRATCH_IDX 4
+#define MSB_SCRATCH_IDX 5
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#endif /* __GMBOXIF_H__ */
+
diff --git a/host/include/gpio.h b/host/include/gpio.h
new file mode 100644
index 0000000..f69dcbe
--- /dev/null
+++ b/host/include/gpio.h
@@ -0,0 +1,51 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2005-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#define AR6001_GPIO_PIN_COUNT 18
+#define AR6002_GPIO_PIN_COUNT 18
+#define AR6003_GPIO_PIN_COUNT 28
+#define MCKINLEY_GPIO_PIN_COUNT 57
+
+/*
+ * Values of gpioreg_id in the WMIX_GPIO_REGISTER_SET_CMDID and WMIX_GPIO_REGISTER_GET_CMDID
+ * commands come in two flavors. If the upper bit of gpioreg_id is CLEAR, then the
+ * remainder is interpreted as one of these values. This provides platform-independent
+ * access to GPIO registers. If the upper bit (GPIO_ID_OFFSET_FLAG) of gpioreg_id is SET,
+ * then the remainder is interpreted as a platform-specific GPIO register offset.
+ */
+#define GPIO_ID_OUT 0x00000000
+#define GPIO_ID_OUT_W1TS 0x00000001
+#define GPIO_ID_OUT_W1TC 0x00000002
+#define GPIO_ID_ENABLE 0x00000003
+#define GPIO_ID_ENABLE_W1TS 0x00000004
+#define GPIO_ID_ENABLE_W1TC 0x00000005
+#define GPIO_ID_IN 0x00000006
+#define GPIO_ID_STATUS 0x00000007
+#define GPIO_ID_STATUS_W1TS 0x00000008
+#define GPIO_ID_STATUS_W1TC 0x00000009
+#define GPIO_ID_PIN0 0x0000000a
+#define GPIO_ID_PIN(n) (GPIO_ID_PIN0+(n))
+#define GPIO_ID_NONE 0xffffffff
+
+#define GPIO_ID_OFFSET_FLAG 0x80000000
+#define GPIO_ID_REG_MASK 0x7fffffff
+#define GPIO_ID_IS_OFFSET(reg_id) (((reg_id) & GPIO_ID_OFFSET_FLAG) != 0)
diff --git a/host/include/gpio_api.h b/host/include/gpio_api.h
new file mode 100644
index 0000000..96a1503
--- /dev/null
+++ b/host/include/gpio_api.h
@@ -0,0 +1,59 @@
+//------------------------------------------------------------------------------
+// <copyright file="gpio_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Host-side General Purpose I/O API.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _GPIO_API_H_
+#define _GPIO_API_H_
+
+/*
+ * Send a command to the Target in order to change output on GPIO pins.
+ */
+A_STATUS wmi_gpio_output_set(struct wmi_t *wmip,
+ A_UINT32 set_mask,
+ A_UINT32 clear_mask,
+ A_UINT32 enable_mask,
+ A_UINT32 disable_mask);
+
+/*
+ * Send a command to the Target requesting input state of GPIO pins.
+ */
+A_STATUS wmi_gpio_input_get(struct wmi_t *wmip);
+
+/*
+ * Send a command to the Target to change the value of a GPIO register.
+ */
+A_STATUS wmi_gpio_register_set(struct wmi_t *wmip,
+ A_UINT32 gpioreg_id,
+ A_UINT32 value);
+
+/*
+ * Send a command to the Target to fetch the value of a GPIO register.
+ */
+A_STATUS wmi_gpio_register_get(struct wmi_t *wmip, A_UINT32 gpioreg_id);
+
+/*
+ * Send a command to the Target, acknowledging some GPIO interrupts.
+ */
+A_STATUS wmi_gpio_intr_ack(struct wmi_t *wmip, A_UINT32 ack_mask);
+
+#endif /* _GPIO_API_H_ */
diff --git a/host/include/hci_transport_api.h b/host/include/hci_transport_api.h
new file mode 100644
index 0000000..b5157ea
--- /dev/null
+++ b/host/include/hci_transport_api.h
@@ -0,0 +1,259 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HCI_TRANSPORT_API_H_
+#define _HCI_TRANSPORT_API_H_
+
+ /* Bluetooth HCI packets are stored in HTC packet containers */
+#include "htc_packet.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+typedef void *HCI_TRANSPORT_HANDLE;
+
+typedef HTC_ENDPOINT_ID HCI_TRANSPORT_PACKET_TYPE;
+
+ /* we map each HCI packet class to a static Endpoint ID */
+#define HCI_COMMAND_TYPE ENDPOINT_1
+#define HCI_EVENT_TYPE ENDPOINT_2
+#define HCI_ACL_TYPE ENDPOINT_3
+#define HCI_PACKET_INVALID ENDPOINT_MAX
+
+#define HCI_GET_PACKET_TYPE(pP) (pP)->Endpoint
+#define HCI_SET_PACKET_TYPE(pP,s) (pP)->Endpoint = (s)
+
+/* callback when an HCI packet was completely sent */
+typedef void (*HCI_TRANSPORT_SEND_PKT_COMPLETE)(void *, HTC_PACKET *);
+/* callback when an HCI packet is received */
+typedef void (*HCI_TRANSPORT_RECV_PKT)(void *, HTC_PACKET *);
+/* Optional receive buffer re-fill callback,
+ * On some OSes (like Linux) packets are allocated from a global pool and indicated up
+ * to the network stack. The driver never gets the packets back from the OS. For these OSes
+ * a refill callback can be used to allocate and re-queue buffers into HTC.
+ * A refill callback is used for the reception of ACL and EVENT packets. The caller must
+ * set the watermark trigger point to cause a refill.
+ */
+typedef void (*HCI_TRANSPORT_RECV_REFILL)(void *, HCI_TRANSPORT_PACKET_TYPE Type, int BuffersAvailable);
+/* Optional receive packet refill
+ * On some systems packet buffers are an extremely limited resource. Rather than
+ * queue largest-possible-sized buffers to the HCI bridge, some systems would rather
+ * allocate a specific size as the packet is received. The trade off is
+ * slightly more processing (callback invoked for each RX packet)
+ * for the benefit of committing fewer buffer resources into the bridge.
+ *
+ * The callback is provided the length of the pending packet to fetch. This includes the
+ * full transport header, HCI header, plus the length of payload. The callback can return a pointer to
+ * the allocated HTC packet for immediate use.
+ *
+ * NOTE*** This callback is mutually exclusive with the the refill callback above.
+ *
+ * */
+typedef HTC_PACKET *(*HCI_TRANSPORT_RECV_ALLOC)(void *, HCI_TRANSPORT_PACKET_TYPE Type, int Length);
+
+typedef enum _HCI_SEND_FULL_ACTION {
+ HCI_SEND_FULL_KEEP = 0, /* packet that overflowed should be kept in the queue */
+ HCI_SEND_FULL_DROP = 1, /* packet that overflowed should be dropped */
+} HCI_SEND_FULL_ACTION;
+
+/* callback when an HCI send queue exceeds the caller's MaxSendQueueDepth threshold,
+ * the callback must return the send full action to take (either DROP or KEEP) */
+typedef HCI_SEND_FULL_ACTION (*HCI_TRANSPORT_SEND_FULL)(void *, HTC_PACKET *);
+
+typedef struct {
+ int HeadRoom; /* number of bytes in front of HCI packet for header space */
+ int TailRoom; /* number of bytes at the end of the HCI packet for tail space */
+ int IOBlockPad; /* I/O block padding required (always a power of 2) */
+} HCI_TRANSPORT_PROPERTIES;
+
+typedef struct _HCI_TRANSPORT_CONFIG_INFO {
+ int ACLRecvBufferWaterMark; /* low watermark to trigger recv refill */
+ int EventRecvBufferWaterMark; /* low watermark to trigger recv refill */
+ int MaxSendQueueDepth; /* max number of packets in the single send queue */
+ void *pContext; /* context for all callbacks */
+ void (*TransportFailure)(void *pContext, A_STATUS Status); /* transport failure callback */
+ A_STATUS (*TransportReady)(HCI_TRANSPORT_HANDLE, HCI_TRANSPORT_PROPERTIES *,void *pContext); /* transport is ready */
+ void (*TransportRemoved)(void *pContext); /* transport was removed */
+ /* packet processing callbacks */
+ HCI_TRANSPORT_SEND_PKT_COMPLETE pHCISendComplete;
+ HCI_TRANSPORT_RECV_PKT pHCIPktRecv;
+ HCI_TRANSPORT_RECV_REFILL pHCIPktRecvRefill;
+ HCI_TRANSPORT_RECV_ALLOC pHCIPktRecvAlloc;
+ HCI_TRANSPORT_SEND_FULL pHCISendFull;
+} HCI_TRANSPORT_CONFIG_INFO;
+
+/* ------ Function Prototypes ------ */
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Attach to the HCI transport module
+ @function name: HCI_TransportAttach
+ @input: HTCHandle - HTC handle (see HTC apis)
+ pInfo - initialization information
+ @output:
+ @return: HCI_TRANSPORT_HANDLE on success, NULL on failure
+ @notes: The HTC module provides HCI transport services.
+ @example:
+ @see also: HCI_TransportDetach
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+HCI_TRANSPORT_HANDLE HCI_TransportAttach(void *HTCHandle, HCI_TRANSPORT_CONFIG_INFO *pInfo);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Detach from the HCI transport module
+ @function name: HCI_TransportDetach
+ @input: HciTrans - HCI transport handle
+ pInfo - initialization information
+ @output:
+ @return:
+ @notes:
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HCI_TransportDetach(HCI_TRANSPORT_HANDLE HciTrans);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Add receive packets to the HCI transport
+ @function name: HCI_TransportAddReceivePkts
+ @input: HciTrans - HCI transport handle
+ pQueue - a queue holding one or more packets
+ @output:
+ @return: A_OK on success
+ @notes: user must supply HTC packets for capturing incomming HCI packets. The caller
+ must initialize each HTC packet using the SET_HTC_PACKET_INFO_RX_REFILL()
+ macro. Each packet in the queue must be of the same type and length
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HCI_TransportAddReceivePkts(HCI_TRANSPORT_HANDLE HciTrans, HTC_PACKET_QUEUE *pQueue);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Send an HCI packet packet
+ @function name: HCI_TransportSendPkt
+ @input: HciTrans - HCI transport handle
+ pPacket - packet to send
+ Synchronous - send the packet synchronously (blocking)
+ @output:
+ @return: A_OK
+ @notes: Caller must initialize packet using SET_HTC_PACKET_INFO_TX() and
+ HCI_SET_PACKET_TYPE() macros to prepare the packet.
+ If Synchronous is set to FALSE the call is fully asynchronous. On error or completion,
+ the registered send complete callback will be called.
+ If Synchronous is set to TRUE, the call will block until the packet is sent, if the
+ interface cannot send the packet within a 2 second timeout, the function will return
+ the failure code : A_EBUSY.
+
+ Synchronous Mode should only be used at start-up to initialize the HCI device using
+ custom HCI commands. It should NOT be mixed with Asynchronous operations. Mixed synchronous
+ and asynchronous operation behavior is undefined.
+
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HCI_TransportSendPkt(HCI_TRANSPORT_HANDLE HciTrans, HTC_PACKET *pPacket, A_BOOL Synchronous);
+
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Stop HCI transport
+ @function name: HCI_TransportStop
+ @input: HciTrans - hci transport handle
+ @output:
+ @return:
+ @notes: HCI transport communication will be halted. All receive and pending TX packets will
+ be flushed.
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HCI_TransportStop(HCI_TRANSPORT_HANDLE HciTrans);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Start the HCI transport
+ @function name: HCI_TransportStart
+ @input: HciTrans - hci transport handle
+ @output:
+ @return: A_OK on success
+ @notes: HCI transport communication will begin, the caller can expect the arrival
+ of HCI recv packets as soon as this call returns.
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HCI_TransportStart(HCI_TRANSPORT_HANDLE HciTrans);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Enable or Disable Asynchronous Recv
+ @function name: HCI_TransportEnableDisableAsyncRecv
+ @input: HciTrans - hci transport handle
+ Enable - enable or disable asynchronous recv
+ @output:
+ @return: A_OK on success
+ @notes: This API must be called when HCI recv is handled synchronously
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HCI_TransportEnableDisableAsyncRecv(HCI_TRANSPORT_HANDLE HciTrans, A_BOOL Enable);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Receive an event packet from the HCI transport synchronously using polling
+ @function name: HCI_TransportRecvHCIEventSync
+ @input: HciTrans - hci transport handle
+ pPacket - HTC packet to hold the recv data
+ MaxPollMS - maximum polling duration in Milliseconds;
+ @output:
+ @return: A_OK on success
+ @notes: This API should be used only during HCI device initialization, the caller must call
+ HCI_TransportEnableDisableAsyncRecv with Enable=FALSE prior to using this API.
+ This API will only capture HCI Event packets.
+ @example:
+ @see also: HCI_TransportEnableDisableAsyncRecv
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HCI_TransportRecvHCIEventSync(HCI_TRANSPORT_HANDLE HciTrans,
+ HTC_PACKET *pPacket,
+ int MaxPollMS);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Set the desired baud rate for the underlying transport layer
+ @function name: HCI_TransportSetBaudRate
+ @input: HciTrans - hci transport handle
+ Baud - baud rate in bps
+ @output:
+ @return: A_OK on success
+ @notes: This API should be used only after HCI device initialization
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HCI_TransportSetBaudRate(HCI_TRANSPORT_HANDLE HciTrans, A_UINT32 Baud);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Enable/Disable HCI Transport Power Management
+ @function name: HCI_TransportEnablePowerMgmt
+ @input: HciTrans - hci transport handle
+ Enable - 1 = Enable, 0 = Disable
+ @output:
+ @return: A_OK on success
+ @notes:
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HCI_TransportEnablePowerMgmt(HCI_TRANSPORT_HANDLE HciTrans, A_BOOL Enable);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _HCI_TRANSPORT_API_H_ */
diff --git a/host/include/hif.h b/host/include/hif.h
new file mode 100644
index 0000000..71b4a80
--- /dev/null
+++ b/host/include/hif.h
@@ -0,0 +1,529 @@
+//------------------------------------------------------------------------------
+// <copyright file="hif.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// HIF specific declarations and prototypes
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HIF_H_
+#define _HIF_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/* Header files */
+#include "a_config.h"
+#include "athdefs.h"
+#include "a_types.h"
+#include "a_osapi.h"
+#include "dl_list.h"
+
+
+typedef struct htc_callbacks HTC_CALLBACKS;
+typedef struct hif_device HIF_DEVICE;
+
+#define HIF_TYPE_AR6002 2
+#define HIF_TYPE_AR6003 3
+#define HIF_TYPE_MCKINLEY 5
+
+/*
+ * Thread Priority - AR6K Driver Thread Priority
+ * Priority must be > 154, since critical modules like SMD holds the thread priorities
+ * upto 154
+ */
+#define HIF_THREAD_PRIORITY 155
+#define AP_THREAD_PRIORITY 200
+
+
+
+
+/*
+ * direction - Direction of transfer (HIF_READ/HIF_WRITE).
+ */
+#define HIF_READ 0x00000001
+#define HIF_WRITE 0x00000002
+#define HIF_DIR_MASK (HIF_READ | HIF_WRITE)
+
+/*
+ * type - An interface may support different kind of read/write commands.
+ * For example: SDIO supports CMD52/CMD53s. In case of MSIO it
+ * translates to using different kinds of TPCs. The command type
+ * is thus divided into a basic and an extended command and can
+ * be specified using HIF_BASIC_IO/HIF_EXTENDED_IO.
+ */
+#define HIF_BASIC_IO 0x00000004
+#define HIF_EXTENDED_IO 0x00000008
+#define HIF_TYPE_MASK (HIF_BASIC_IO | HIF_EXTENDED_IO)
+
+/*
+ * emode - This indicates the whether the command is to be executed in a
+ * blocking or non-blocking fashion (HIF_SYNCHRONOUS/
+ * HIF_ASYNCHRONOUS). The read/write data paths in HTC have been
+ * implemented using the asynchronous mode allowing the the bus
+ * driver to indicate the completion of operation through the
+ * registered callback routine. The requirement primarily comes
+ * from the contexts these operations get called from (a driver's
+ * transmit context or the ISR context in case of receive).
+ * Support for both of these modes is essential.
+ */
+#define HIF_SYNCHRONOUS 0x00000010
+#define HIF_ASYNCHRONOUS 0x00000020
+#define HIF_EMODE_MASK (HIF_SYNCHRONOUS | HIF_ASYNCHRONOUS)
+
+/*
+ * dmode - An interface may support different kinds of commands based on
+ * the tradeoff between the amount of data it can carry and the
+ * setup time. Byte and Block modes are supported (HIF_BYTE_BASIS/
+ * HIF_BLOCK_BASIS). In case of latter, the data is rounded off
+ * to the nearest block size by padding. The size of the block is
+ * configurable at compile time using the HIF_BLOCK_SIZE and is
+ * negotiated with the target during initialization after the
+ * AR6000 interrupts are enabled.
+ */
+#define HIF_BYTE_BASIS 0x00000040
+#define HIF_BLOCK_BASIS 0x00000080
+#define HIF_DMODE_MASK (HIF_BYTE_BASIS | HIF_BLOCK_BASIS)
+
+/*
+ * amode - This indicates if the address has to be incremented on AR6000
+ * after every read/write operation (HIF?FIXED_ADDRESS/
+ * HIF_INCREMENTAL_ADDRESS).
+ */
+#define HIF_FIXED_ADDRESS 0x00000100
+#define HIF_INCREMENTAL_ADDRESS 0x00000200
+#define HIF_AMODE_MASK (HIF_FIXED_ADDRESS | HIF_INCREMENTAL_ADDRESS)
+
+#define HIF_WR_ASYNC_BYTE_FIX \
+ (HIF_WRITE | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_FIXED_ADDRESS)
+#define HIF_WR_ASYNC_BYTE_INC \
+ (HIF_WRITE | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_WR_ASYNC_BLOCK_INC \
+ (HIF_WRITE | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_WR_SYNC_BYTE_FIX \
+ (HIF_WRITE | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_FIXED_ADDRESS)
+#define HIF_WR_SYNC_BYTE_INC \
+ (HIF_WRITE | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_WR_SYNC_BLOCK_INC \
+ (HIF_WRITE | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_WR_ASYNC_BLOCK_FIX \
+ (HIF_WRITE | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_FIXED_ADDRESS)
+#define HIF_WR_SYNC_BLOCK_FIX \
+ (HIF_WRITE | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_FIXED_ADDRESS)
+#define HIF_RD_SYNC_BYTE_INC \
+ (HIF_READ | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_RD_SYNC_BYTE_FIX \
+ (HIF_READ | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_FIXED_ADDRESS)
+#define HIF_RD_ASYNC_BYTE_FIX \
+ (HIF_READ | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_FIXED_ADDRESS)
+#define HIF_RD_ASYNC_BLOCK_FIX \
+ (HIF_READ | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_FIXED_ADDRESS)
+#define HIF_RD_ASYNC_BYTE_INC \
+ (HIF_READ | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BYTE_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_RD_ASYNC_BLOCK_INC \
+ (HIF_READ | HIF_ASYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_RD_SYNC_BLOCK_INC \
+ (HIF_READ | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_INCREMENTAL_ADDRESS)
+#define HIF_RD_SYNC_BLOCK_FIX \
+ (HIF_READ | HIF_SYNCHRONOUS | HIF_EXTENDED_IO | HIF_BLOCK_BASIS | HIF_FIXED_ADDRESS)
+
+typedef enum {
+ HIF_DEVICE_POWER_STATE = 0,
+ HIF_DEVICE_GET_MBOX_BLOCK_SIZE,
+ HIF_DEVICE_GET_MBOX_ADDR,
+ HIF_DEVICE_GET_PENDING_EVENTS_FUNC,
+ HIF_DEVICE_GET_IRQ_PROC_MODE,
+ HIF_DEVICE_GET_RECV_EVENT_MASK_UNMASK_FUNC,
+ HIF_DEVICE_POWER_STATE_CHANGE,
+ HIF_DEVICE_GET_IRQ_YIELD_PARAMS,
+ HIF_CONFIGURE_QUERY_SCATTER_REQUEST_SUPPORT,
+ HIF_DEVICE_GET_OS_DEVICE,
+ HIF_DEVICE_DEBUG_BUS_STATE,
+} HIF_DEVICE_CONFIG_OPCODE;
+
+/*
+ * HIF CONFIGURE definitions:
+ *
+ * HIF_DEVICE_GET_MBOX_BLOCK_SIZE
+ * input : none
+ * output : array of 4 A_UINT32s
+ * notes: block size is returned for each mailbox (4)
+ *
+ * HIF_DEVICE_GET_MBOX_ADDR
+ * input : none
+ * output : HIF_DEVICE_MBOX_INFO
+ * notes:
+ *
+ * HIF_DEVICE_GET_PENDING_EVENTS_FUNC
+ * input : none
+ * output: HIF_PENDING_EVENTS_FUNC function pointer
+ * notes: this is optional for the HIF layer, if the request is
+ * not handled then it indicates that the upper layer can use
+ * the standard device methods to get pending events (IRQs, mailbox messages etc..)
+ * otherwise it can call the function pointer to check pending events.
+ *
+ * HIF_DEVICE_GET_IRQ_PROC_MODE
+ * input : none
+ * output : HIF_DEVICE_IRQ_PROCESSING_MODE (interrupt processing mode)
+ * note: the hif layer interfaces with the underlying OS-specific bus driver. The HIF
+ * layer can report whether IRQ processing is requires synchronous behavior or
+ * can be processed using asynchronous bus requests (typically faster).
+ *
+ * HIF_DEVICE_GET_RECV_EVENT_MASK_UNMASK_FUNC
+ * input :
+ * output : HIF_MASK_UNMASK_RECV_EVENT function pointer
+ * notes: this is optional for the HIF layer. The HIF layer may require a special mechanism
+ * to mask receive message events. The upper layer can call this pointer when it needs
+ * to mask/unmask receive events (in case it runs out of buffers).
+ *
+ * HIF_DEVICE_POWER_STATE_CHANGE
+ *
+ * input : HIF_DEVICE_POWER_CHANGE_TYPE
+ * output : none
+ * note: this is optional for the HIF layer. The HIF layer can handle power on/off state change
+ * requests in an interconnect specific way. This is highly OS and bus driver dependent.
+ * The caller must guarantee that no HIF read/write requests will be made after the device
+ * is powered down.
+ *
+ * HIF_DEVICE_GET_IRQ_YIELD_PARAMS
+ *
+ * input : none
+ * output : HIF_DEVICE_IRQ_YIELD_PARAMS
+ * note: This query checks if the HIF layer wishes to impose a processing yield count for the DSR handler.
+ * The DSR callback handler will exit after a fixed number of RX packets or events are processed.
+ * This query is only made if the device reports an IRQ processing mode of HIF_DEVICE_IRQ_SYNC_ONLY.
+ * The HIF implementation can ignore this command if it does not desire the DSR callback to yield.
+ * The HIF layer can indicate the maximum number of IRQ processing units (RX packets) before the
+ * DSR handler callback must yield and return control back to the HIF layer. When a yield limit is
+ * used the DSR callback will not call HIFAckInterrupts() as it would normally do before returning.
+ * The HIF implementation that requires a yield count must call HIFAckInterrupt() when it is prepared
+ * to process interrupts again.
+ *
+ * HIF_CONFIGURE_QUERY_SCATTER_REQUEST_SUPPORT
+ * input : none
+ * output : HIF_DEVICE_SCATTER_SUPPORT_INFO
+ * note: This query checks if the HIF layer implements the SCATTER request interface. Scatter requests
+ * allows upper layers to submit mailbox I/O operations using a list of buffers. This is useful for
+ * multi-message transfers that can better utilize the bus interconnect.
+ *
+ *
+ * HIF_DEVICE_GET_OS_DEVICE
+ * intput : none
+ * output : HIF_DEVICE_OS_DEVICE_INFO;
+ * note: On some operating systems, the HIF layer has a parent device object for the bus. This object
+ * may be required to register certain types of logical devices.
+ *
+ * HIF_DEVICE_DEBUG_BUS_STATE
+ * input : none
+ * output : none
+ * note: This configure option triggers the HIF interface to dump as much bus interface state. This
+ * configuration request is optional (No-OP on some HIF implementations)
+ *
+ */
+
+typedef struct {
+ A_UINT32 ExtendedAddress; /* extended address for larger writes */
+ A_UINT32 ExtendedSize;
+} HIF_MBOX_PROPERTIES;
+
+#define HIF_MBOX_FLAG_NO_BUNDLING (1 << 0) /* do not allow bundling over the mailbox */
+
+typedef struct {
+ A_UINT32 MboxAddresses[4]; /* must be first element for legacy HIFs that return the address in
+ and ARRAY of 32-bit words */
+
+ /* the following describe extended mailbox properties */
+ HIF_MBOX_PROPERTIES MboxProp[4];
+ /* if the HIF supports the GMbox extended address region it can report it
+ * here, some interfaces cannot support the GMBOX address range and not set this */
+ A_UINT32 GMboxAddress;
+ A_UINT32 GMboxSize;
+ A_UINT32 Flags; /* flags to describe mbox behavior or usage */
+} HIF_DEVICE_MBOX_INFO;
+
+typedef enum {
+ HIF_DEVICE_IRQ_SYNC_ONLY, /* for HIF implementations that require the DSR to process all
+ interrupts before returning */
+ HIF_DEVICE_IRQ_ASYNC_SYNC, /* for HIF implementations that allow DSR to process interrupts
+ using ASYNC I/O (that is HIFAckInterrupt can be called at a
+ later time */
+} HIF_DEVICE_IRQ_PROCESSING_MODE;
+
+typedef enum {
+ HIF_DEVICE_POWER_UP, /* HIF layer should power up interface and/or module */
+ HIF_DEVICE_POWER_DOWN, /* HIF layer should initiate bus-specific measures to minimize power */
+ HIF_DEVICE_POWER_CUT /* HIF layer should initiate bus-specific AND/OR platform-specific measures
+ to completely power-off the module and associated hardware (i.e. cut power supplies)
+ */
+} HIF_DEVICE_POWER_CHANGE_TYPE;
+
+typedef struct {
+ int RecvPacketYieldCount; /* max number of packets to force DSR to return */
+} HIF_DEVICE_IRQ_YIELD_PARAMS;
+
+
+typedef struct _HIF_SCATTER_ITEM {
+ A_UINT8 *pBuffer; /* CPU accessible address of buffer */
+ int Length; /* length of transfer to/from this buffer */
+ void *pCallerContexts[2]; /* space for caller to insert a context associated with this item */
+} HIF_SCATTER_ITEM;
+
+struct _HIF_SCATTER_REQ;
+
+typedef void ( *HIF_SCATTER_COMP_CB)(struct _HIF_SCATTER_REQ *);
+
+typedef enum _HIF_SCATTER_METHOD {
+ HIF_SCATTER_NONE = 0,
+ HIF_SCATTER_DMA_REAL, /* Real SG support no restrictions */
+ HIF_SCATTER_DMA_BOUNCE, /* Uses SG DMA but HIF layer uses an internal bounce buffer */
+} HIF_SCATTER_METHOD;
+
+typedef struct _HIF_SCATTER_REQ {
+ DL_LIST ListLink; /* link management */
+ A_UINT32 Address; /* address for the read/write operation */
+ A_UINT32 Request; /* request flags */
+ A_UINT32 TotalLength; /* total length of entire transfer */
+ A_UINT32 CallerFlags; /* caller specific flags can be stored here */
+ HIF_SCATTER_COMP_CB CompletionRoutine; /* completion routine set by caller */
+ A_STATUS CompletionStatus; /* status of completion */
+ void *Context; /* caller context for this request */
+ int ValidScatterEntries; /* number of valid entries set by caller */
+ HIF_SCATTER_METHOD ScatterMethod; /* scatter method handled by HIF */
+ void *HIFPrivate[4]; /* HIF private area */
+ A_UINT8 *pScatterBounceBuffer; /* bounce buffer for upper layers to copy to/from */
+ HIF_SCATTER_ITEM ScatterList[1]; /* start of scatter list */
+} HIF_SCATTER_REQ;
+
+typedef HIF_SCATTER_REQ * ( *HIF_ALLOCATE_SCATTER_REQUEST)(HIF_DEVICE *device);
+typedef void ( *HIF_FREE_SCATTER_REQUEST)(HIF_DEVICE *device, HIF_SCATTER_REQ *request);
+typedef A_STATUS ( *HIF_READWRITE_SCATTER)(HIF_DEVICE *device, HIF_SCATTER_REQ *request);
+
+typedef struct _HIF_DEVICE_SCATTER_SUPPORT_INFO {
+ /* information returned from HIF layer */
+ HIF_ALLOCATE_SCATTER_REQUEST pAllocateReqFunc;
+ HIF_FREE_SCATTER_REQUEST pFreeReqFunc;
+ HIF_READWRITE_SCATTER pReadWriteScatterFunc;
+ int MaxScatterEntries;
+ int MaxTransferSizePerScatterReq;
+} HIF_DEVICE_SCATTER_SUPPORT_INFO;
+
+typedef struct {
+ void *pOSDevice;
+} HIF_DEVICE_OS_DEVICE_INFO;
+
+#define HIF_MAX_DEVICES 1
+
+struct htc_callbacks {
+ void *context; /* context to pass to the dsrhandler
+ note : rwCompletionHandler is provided the context passed to HIFReadWrite */
+ A_STATUS (* rwCompletionHandler)(void *rwContext, A_STATUS status);
+ A_STATUS (* dsrHandler)(void *context);
+};
+
+typedef struct osdrv_callbacks {
+ void *context; /* context to pass for all callbacks except deviceRemovedHandler
+ the deviceRemovedHandler is only called if the device is claimed */
+ A_STATUS (* deviceInsertedHandler)(void *context, void *hif_handle);
+ A_STATUS (* deviceRemovedHandler)(void *claimedContext, void *hif_handle);
+ A_STATUS (* deviceSuspendHandler)(void *context);
+ A_STATUS (* deviceResumeHandler)(void *context);
+ A_STATUS (* deviceWakeupHandler)(void *context);
+ A_STATUS (* devicePowerChangeHandler)(void *context, HIF_DEVICE_POWER_CHANGE_TYPE config);
+} OSDRV_CALLBACKS;
+
+#define HIF_OTHER_EVENTS (1 << 0) /* other interrupts (non-Recv) are pending, host
+ needs to read the register table to figure out what */
+#define HIF_RECV_MSG_AVAIL (1 << 1) /* pending recv packet */
+
+typedef struct _HIF_PENDING_EVENTS_INFO {
+ A_UINT32 Events;
+ A_UINT32 LookAhead;
+ A_UINT32 AvailableRecvBytes;
+} HIF_PENDING_EVENTS_INFO;
+
+ /* function to get pending events , some HIF modules use special mechanisms
+ * to detect packet available and other interrupts */
+typedef A_STATUS ( *HIF_PENDING_EVENTS_FUNC)(HIF_DEVICE *device,
+ HIF_PENDING_EVENTS_INFO *pEvents,
+ void *AsyncContext);
+
+#define HIF_MASK_RECV TRUE
+#define HIF_UNMASK_RECV FALSE
+ /* function to mask recv events */
+typedef A_STATUS ( *HIF_MASK_UNMASK_RECV_EVENT)(HIF_DEVICE *device,
+ A_BOOL Mask,
+ void *AsyncContext);
+
+
+/*
+ * This API is used to perform any global initialization of the HIF layer
+ * and to set OS driver callbacks (i.e. insertion/removal) to the HIF layer
+ *
+ */
+A_STATUS HIFInit(OSDRV_CALLBACKS *callbacks);
+
+/* This API claims the HIF device and provides a context for handling removal.
+ * The device removal callback is only called when the OSDRV layer claims
+ * a device. The claimed context must be non-NULL */
+void HIFClaimDevice(HIF_DEVICE *device, void *claimedContext);
+/* release the claimed device */
+void HIFReleaseDevice(HIF_DEVICE *device);
+
+/* This API allows the HTC layer to attach to the HIF device */
+A_STATUS HIFAttachHTC(HIF_DEVICE *device, HTC_CALLBACKS *callbacks);
+/* This API detaches the HTC layer from the HIF device */
+void HIFDetachHTC(HIF_DEVICE *device);
+
+/*
+ * This API is used to provide the read/write interface over the specific bus
+ * interface.
+ * address - Starting address in the AR6000's address space. For mailbox
+ * writes, it refers to the start of the mbox boundary. It should
+ * be ensured that the last byte falls on the mailbox's EOM. For
+ * mailbox reads, it refers to the end of the mbox boundary.
+ * buffer - Pointer to the buffer containg the data to be transmitted or
+ * received.
+ * length - Amount of data to be transmitted or received.
+ * request - Characterizes the attributes of the command.
+ */
+A_STATUS
+HIFReadWrite(HIF_DEVICE *device,
+ A_UINT32 address,
+ A_UCHAR *buffer,
+ A_UINT32 length,
+ A_UINT32 request,
+ void *context);
+
+/*
+ * This can be initiated from the unload driver context when the OSDRV layer has no more use for
+ * the device.
+ */
+void HIFShutDownDevice(HIF_DEVICE *device);
+
+/*
+ * This should translate to an acknowledgment to the bus driver indicating that
+ * the previous interrupt request has been serviced and the all the relevant
+ * sources have been cleared. HTC is ready to process more interrupts.
+ * This should prevent the bus driver from raising an interrupt unless the
+ * previous one has been serviced and acknowledged using the previous API.
+ */
+void HIFAckInterrupt(HIF_DEVICE *device);
+
+void HIFMaskInterrupt(HIF_DEVICE *device);
+
+void HIFUnMaskInterrupt(HIF_DEVICE *device);
+
+A_STATUS
+HIFConfigureDevice(HIF_DEVICE *device, HIF_DEVICE_CONFIG_OPCODE opcode,
+ void *config, A_UINT32 configLen);
+
+/*
+ * This API wait for the remaining MBOX messages to be drained
+ * This should be moved to HTC AR6K layer
+ */
+A_STATUS hifWaitForPendingRecv(HIF_DEVICE *device);
+
+/****************************************************************/
+/* message based HIF interfaces */
+/****************************************************************/
+
+#define HIF_BMI_EXCHANGE_NO_TIMEOUT ((A_UINT32)(0))
+
+struct _HIF_MSG_OBJ;
+
+typedef void (* HIF_MSG_RECV_CALLBACK)(void *, struct _HIF_MSG_OBJ *);
+typedef void (* HIF_MSG_REQ_COMPLETION)(void *,struct _HIF_MSG_OBJ *);
+
+typedef enum {
+ HIF_MSG_SIMPLE_BUFFER = 0, /* a simple buffer ptr and length */
+ HIF_MSG_NET_BUFFER = 1 /* advanced OS-specific network buffer */
+} HIF_MSG_BUFFER_TYPE;
+
+ /* object to pass HIF message requests from upper layers */
+typedef struct _HIF_MSG_OBJ {
+ DL_LIST ListLink; /* for list management */
+ A_INT32 PipeId; /* pipe number to send on or recv'd from*/
+ HIF_MSG_BUFFER_TYPE BufferType;
+ union {
+ struct HIF_MSG_NET_BUFFER {
+ void *pAppNetBuf; /* OS-specific net buf */
+ } AsNetBuffer;
+ struct HIF_MSG_SIMPLE_BUFFER {
+ void *pBuffer; /* for future use.... */
+ A_UINT32 Length;
+ } AsSimpleBuffer;
+ } BufferInfo;
+ void *pContext; /* caller context of message */
+ HIF_MSG_REQ_COMPLETION CompletionRoutine; /* completion routine */
+ A_STATUS Status; /* completion status */
+ A_UINT32 Flags; /* request flags */
+ void *HIFPriv[4]; /* private contexts for HIF layer to use */
+
+} HIF_MSG_OBJ;
+
+ /* API to handle HIF-specific BMI message exchanges, this API is synchronous
+ * and only allowed to be called from a context that can block (sleep) */
+A_STATUS HIFExchangeBMIMsg(HIF_DEVICE *device,
+ A_UINT8 *pSendMessage,
+ A_UINT32 Length,
+ A_UINT8 *pResponseMessage,
+ A_UINT32 *pResponseLength,
+ A_UINT32 TimeoutMS);
+
+ /* API to handle HIF specific diagnostic window read accesses, this API is synchronous
+ * and only allowed to be called from a context that can block (sleep) */
+A_STATUS HIFDiagReadAccess(HIF_DEVICE *hifDevice, A_UINT32 address, A_UINT32 *data);
+
+ /* API to handle HIF specific diagnostic window write accesses, this API is synchronous
+ * and only allowed to be called from a context that can block (sleep) */
+A_STATUS HIFDiagWriteAccess(HIF_DEVICE *hifDevice, A_UINT32 address, A_UINT32 data);
+
+ /* get the Pipe ID associated with the service ID */
+A_STATUS HIFGetPipeId(HIF_DEVICE *hifDevice, A_UINT16 ServiceId, A_INT32 *pId);
+
+ /* API to let HIF layer know that pipe communications should be enabled
+ * caller will start to exchange messages on service pipes */
+A_STATUS HIFEnablePipes(HIF_DEVICE *hifDevice);
+
+ /* set the message recv handler for all incomming messages */
+void HIFSetMsgRecvHandler(HIF_DEVICE *hifDevice,
+ HIF_MSG_RECV_CALLBACK Callback,
+ void *pContext);
+
+ /* upper layers should return the HIF_MSG_OBJ back to HIF as it may be associated
+ * with some recv resource. The objects could be returned in a chain (batch mode)
+ * Note, upper layers can take ownership of the buffer (free it) if it is of the type
+ * HIF_MSG_NET_BUFFER, in this case upper layers will set
+ * BufferInfo.AsNetBuffer.pAppNetBuf to NULL */
+void HIFReturnRecvMsgObjects(HIF_DEVICE *hifDevice, HIF_MSG_OBJ *pMessageObj);
+
+ /* API for upper layers to send one or more messages. Note, HIF may
+ * take ownership of the buffer (it will free it) if it is of the type
+ * HIF_MSG_NET_BUFFER, in this case the HIF layer will set
+ * BufferInfo.AsNetBuffer.pAppNetBuf to NULL */
+A_STATUS HIFSendMessages(HIF_DEVICE *hifDevice, HIF_MSG_OBJ *pMessages);
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _HIF_H_ */
+
diff --git a/host/include/host_proxy_iface.h b/host/include/host_proxy_iface.h
new file mode 100644
index 0000000..a4b94ab
--- /dev/null
+++ b/host/include/host_proxy_iface.h
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2011 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+/*
+ * This file contains the definitions of the host_proxy interface.
+ */
+
+#ifndef _HOST_PROXY_IFACE_H_
+#define _HOST_PROXY_IFACE_H_
+
+/* Host proxy initializes shared memory with HOST_PROXY_INIT to
+ * indicate that it is ready to receive instruction */
+#define HOST_PROXY_INIT (1)
+/* Host writes HOST_PROXY_NORMAL_BOOT to shared memory to
+ * indicate to host proxy that it should proceed to boot
+ * normally (bypassing BMI).
+ */
+#define HOST_PROXY_NORMAL_BOOT (2)
+/* Host writes HOST_PROXY_BMI_BOOT to shared memory to
+ * indicate to host proxy that is should enable BMI and
+ * exit. This allows a host to reprogram the on board
+ * flash.
+ */
+#define HOST_PROXY_BMI_BOOT (3)
+
+#endif /* _HOST_PROXY_IFACE_H_ */
diff --git a/host/include/host_reg_table.h b/host/include/host_reg_table.h
new file mode 100644
index 0000000..a664cd8
--- /dev/null
+++ b/host/include/host_reg_table.h
@@ -0,0 +1,226 @@
+//------------------------------------------------------------------------------
+// <copyright file="target_reg_table.h" company="Atheros">
+// Copyright (c) 2004-2008 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Target register table macros and structure definitions
+//
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef HOST_REG_TABLE_H_
+#define HOST_REG_TABLE_H_
+
+#include "targaddrs.h"
+/*** WARNING : Add to the end of the TABLE! do not change the order ****/
+typedef struct hostdef_s {
+ A_UINT32 d_INT_STATUS_ENABLE_ERROR_LSB;
+ A_UINT32 d_INT_STATUS_ENABLE_ERROR_MASK;
+ A_UINT32 d_INT_STATUS_ENABLE_CPU_LSB;
+ A_UINT32 d_INT_STATUS_ENABLE_CPU_MASK;
+ A_UINT32 d_INT_STATUS_ENABLE_COUNTER_LSB;
+ A_UINT32 d_INT_STATUS_ENABLE_COUNTER_MASK;
+ A_UINT32 d_INT_STATUS_ENABLE_MBOX_DATA_LSB;
+ A_UINT32 d_INT_STATUS_ENABLE_MBOX_DATA_MASK;
+ A_UINT32 d_ERROR_STATUS_ENABLE_RX_UNDERFLOW_LSB;
+ A_UINT32 d_ERROR_STATUS_ENABLE_RX_UNDERFLOW_MASK;
+ A_UINT32 d_ERROR_STATUS_ENABLE_TX_OVERFLOW_LSB;
+ A_UINT32 d_ERROR_STATUS_ENABLE_TX_OVERFLOW_MASK;
+ A_UINT32 d_COUNTER_INT_STATUS_ENABLE_BIT_LSB;
+ A_UINT32 d_COUNTER_INT_STATUS_ENABLE_BIT_MASK;
+ A_UINT32 d_INT_STATUS_ENABLE_ADDRESS;
+ A_UINT32 d_CPU_INT_STATUS_ENABLE_BIT_LSB;
+ A_UINT32 d_CPU_INT_STATUS_ENABLE_BIT_MASK;
+ A_UINT32 d_HOST_INT_STATUS_ADDRESS;
+ A_UINT32 d_CPU_INT_STATUS_ADDRESS;
+ A_UINT32 d_ERROR_INT_STATUS_ADDRESS;
+ A_UINT32 d_ERROR_INT_STATUS_WAKEUP_MASK;
+ A_UINT32 d_ERROR_INT_STATUS_WAKEUP_LSB;
+ A_UINT32 d_ERROR_INT_STATUS_RX_UNDERFLOW_MASK;
+ A_UINT32 d_ERROR_INT_STATUS_RX_UNDERFLOW_LSB;
+ A_UINT32 d_ERROR_INT_STATUS_TX_OVERFLOW_MASK;
+ A_UINT32 d_ERROR_INT_STATUS_TX_OVERFLOW_LSB;
+ A_UINT32 d_COUNT_DEC_ADDRESS;
+ A_UINT32 d_HOST_INT_STATUS_CPU_MASK;
+ A_UINT32 d_HOST_INT_STATUS_CPU_LSB;
+ A_UINT32 d_HOST_INT_STATUS_ERROR_MASK;
+ A_UINT32 d_HOST_INT_STATUS_ERROR_LSB;
+ A_UINT32 d_HOST_INT_STATUS_COUNTER_MASK;
+ A_UINT32 d_HOST_INT_STATUS_COUNTER_LSB;
+ A_UINT32 d_RX_LOOKAHEAD_VALID_ADDRESS;
+ A_UINT32 d_WINDOW_DATA_ADDRESS;
+ A_UINT32 d_WINDOW_READ_ADDR_ADDRESS;
+ A_UINT32 d_WINDOW_WRITE_ADDR_ADDRESS;
+} HOST_REGISTER_TABLE;
+
+#if defined(MY_HOST_DEF) /* { */
+#if defined(ATHR_WIN_DEF)
+#define ATH_REG_TABLE_DIRECT_ASSIGN
+#endif
+#ifdef ATH_REG_TABLE_DIRECT_ASSIGN
+
+static struct hostdef_s my_host_def = {
+ INT_STATUS_ENABLE_ERROR_LSB,
+ INT_STATUS_ENABLE_ERROR_MASK,
+ INT_STATUS_ENABLE_CPU_LSB,
+ INT_STATUS_ENABLE_CPU_MASK,
+ INT_STATUS_ENABLE_COUNTER_LSB,
+ INT_STATUS_ENABLE_COUNTER_MASK,
+ INT_STATUS_ENABLE_MBOX_DATA_LSB,
+ INT_STATUS_ENABLE_MBOX_DATA_MASK,
+ ERROR_STATUS_ENABLE_RX_UNDERFLOW_LSB,
+ ERROR_STATUS_ENABLE_RX_UNDERFLOW_MASK,
+ ERROR_STATUS_ENABLE_TX_OVERFLOW_LSB,
+ ERROR_STATUS_ENABLE_TX_OVERFLOW_MASK,
+ COUNTER_INT_STATUS_ENABLE_BIT_LSB,
+ COUNTER_INT_STATUS_ENABLE_BIT_MASK,
+ INT_STATUS_ENABLE_ADDRESS,
+ CPU_INT_STATUS_ENABLE_BIT_LSB,
+ CPU_INT_STATUS_ENABLE_BIT_MASK,
+ HOST_INT_STATUS_ADDRESS,
+ CPU_INT_STATUS_ADDRESS,
+ ERROR_INT_STATUS_ADDRESS,
+ ERROR_INT_STATUS_WAKEUP_MASK,
+ ERROR_INT_STATUS_WAKEUP_LSB,
+ ERROR_INT_STATUS_RX_UNDERFLOW_MASK,
+ ERROR_INT_STATUS_RX_UNDERFLOW_LSB,
+ ERROR_INT_STATUS_TX_OVERFLOW_MASK,
+ ERROR_INT_STATUS_TX_OVERFLOW_LSB,
+ COUNT_DEC_ADDRESS,
+ HOST_INT_STATUS_CPU_MASK,
+ HOST_INT_STATUS_CPU_LSB,
+ HOST_INT_STATUS_ERROR_MASK,
+ HOST_INT_STATUS_ERROR_LSB,
+ HOST_INT_STATUS_COUNTER_MASK,
+ HOST_INT_STATUS_COUNTER_LSB,
+ RX_LOOKAHEAD_VALID_ADDRESS,
+ WINDOW_DATA_ADDRESS,
+ WINDOW_READ_ADDR_ADDRESS,
+ WINDOW_WRITE_ADDR_ADDRESS,
+};
+
+#else
+
+static struct hostdef_s my_host_def = {
+ .d_INT_STATUS_ENABLE_ERROR_LSB = INT_STATUS_ENABLE_ERROR_LSB,
+ .d_INT_STATUS_ENABLE_ERROR_MASK = INT_STATUS_ENABLE_ERROR_MASK,
+ .d_INT_STATUS_ENABLE_CPU_LSB = INT_STATUS_ENABLE_CPU_LSB,
+ .d_INT_STATUS_ENABLE_CPU_MASK = INT_STATUS_ENABLE_CPU_MASK,
+ .d_INT_STATUS_ENABLE_COUNTER_LSB = INT_STATUS_ENABLE_COUNTER_LSB,
+ .d_INT_STATUS_ENABLE_COUNTER_MASK = INT_STATUS_ENABLE_COUNTER_MASK,
+ .d_INT_STATUS_ENABLE_MBOX_DATA_LSB = INT_STATUS_ENABLE_MBOX_DATA_LSB,
+ .d_INT_STATUS_ENABLE_MBOX_DATA_MASK = INT_STATUS_ENABLE_MBOX_DATA_MASK,
+ .d_ERROR_STATUS_ENABLE_RX_UNDERFLOW_LSB = ERROR_STATUS_ENABLE_RX_UNDERFLOW_LSB,
+ .d_ERROR_STATUS_ENABLE_RX_UNDERFLOW_MASK = ERROR_STATUS_ENABLE_RX_UNDERFLOW_MASK,
+ .d_ERROR_STATUS_ENABLE_TX_OVERFLOW_LSB = ERROR_STATUS_ENABLE_TX_OVERFLOW_LSB,
+ .d_ERROR_STATUS_ENABLE_TX_OVERFLOW_MASK = ERROR_STATUS_ENABLE_TX_OVERFLOW_MASK,
+ .d_COUNTER_INT_STATUS_ENABLE_BIT_LSB = COUNTER_INT_STATUS_ENABLE_BIT_LSB,
+ .d_COUNTER_INT_STATUS_ENABLE_BIT_MASK = COUNTER_INT_STATUS_ENABLE_BIT_MASK,
+ .d_INT_STATUS_ENABLE_ADDRESS = INT_STATUS_ENABLE_ADDRESS,
+ .d_CPU_INT_STATUS_ENABLE_BIT_LSB = CPU_INT_STATUS_ENABLE_BIT_LSB,
+ .d_CPU_INT_STATUS_ENABLE_BIT_MASK = CPU_INT_STATUS_ENABLE_BIT_MASK,
+ .d_HOST_INT_STATUS_ADDRESS = HOST_INT_STATUS_ADDRESS,
+ .d_CPU_INT_STATUS_ADDRESS = CPU_INT_STATUS_ADDRESS,
+ .d_ERROR_INT_STATUS_ADDRESS = ERROR_INT_STATUS_ADDRESS,
+ .d_ERROR_INT_STATUS_WAKEUP_MASK = ERROR_INT_STATUS_WAKEUP_MASK,
+ .d_ERROR_INT_STATUS_WAKEUP_LSB = ERROR_INT_STATUS_WAKEUP_LSB,
+ .d_ERROR_INT_STATUS_RX_UNDERFLOW_MASK = ERROR_INT_STATUS_RX_UNDERFLOW_MASK,
+ .d_ERROR_INT_STATUS_RX_UNDERFLOW_LSB = ERROR_INT_STATUS_RX_UNDERFLOW_LSB,
+ .d_ERROR_INT_STATUS_TX_OVERFLOW_MASK = ERROR_INT_STATUS_TX_OVERFLOW_MASK,
+ .d_ERROR_INT_STATUS_TX_OVERFLOW_LSB = ERROR_INT_STATUS_TX_OVERFLOW_LSB,
+ .d_COUNT_DEC_ADDRESS = COUNT_DEC_ADDRESS,
+ .d_HOST_INT_STATUS_CPU_MASK = HOST_INT_STATUS_CPU_MASK,
+ .d_HOST_INT_STATUS_CPU_LSB = HOST_INT_STATUS_CPU_LSB,
+ .d_HOST_INT_STATUS_ERROR_MASK = HOST_INT_STATUS_ERROR_MASK,
+ .d_HOST_INT_STATUS_ERROR_LSB = HOST_INT_STATUS_ERROR_LSB,
+ .d_HOST_INT_STATUS_COUNTER_MASK = HOST_INT_STATUS_COUNTER_MASK,
+ .d_HOST_INT_STATUS_COUNTER_LSB = HOST_INT_STATUS_COUNTER_LSB,
+ .d_RX_LOOKAHEAD_VALID_ADDRESS = RX_LOOKAHEAD_VALID_ADDRESS,
+ .d_WINDOW_DATA_ADDRESS = WINDOW_DATA_ADDRESS,
+ .d_WINDOW_READ_ADDR_ADDRESS = WINDOW_READ_ADDR_ADDRESS,
+ .d_WINDOW_WRITE_ADDR_ADDRESS = WINDOW_WRITE_ADDR_ADDRESS,
+};
+
+#endif
+
+struct hostdef_s *MY_HOST_DEF = &my_host_def;
+
+#else /* } { */
+
+#define INT_STATUS_ENABLE_ERROR_LSB (hostdef->d_INT_STATUS_ENABLE_ERROR_LSB)
+#define INT_STATUS_ENABLE_ERROR_MASK (hostdef->d_INT_STATUS_ENABLE_ERROR_MASK)
+#define INT_STATUS_ENABLE_CPU_LSB (hostdef->d_INT_STATUS_ENABLE_CPU_LSB)
+#define INT_STATUS_ENABLE_CPU_MASK (hostdef->d_INT_STATUS_ENABLE_CPU_MASK)
+#define INT_STATUS_ENABLE_COUNTER_LSB (hostdef->d_INT_STATUS_ENABLE_COUNTER_LSB)
+#define INT_STATUS_ENABLE_COUNTER_MASK (hostdef->d_INT_STATUS_ENABLE_COUNTER_MASK)
+#define INT_STATUS_ENABLE_MBOX_DATA_LSB (hostdef->d_INT_STATUS_ENABLE_MBOX_DATA_LSB)
+#define INT_STATUS_ENABLE_MBOX_DATA_MASK (hostdef->d_INT_STATUS_ENABLE_MBOX_DATA_MASK)
+#define ERROR_STATUS_ENABLE_RX_UNDERFLOW_LSB (hostdef->d_ERROR_STATUS_ENABLE_RX_UNDERFLOW_LSB)
+#define ERROR_STATUS_ENABLE_RX_UNDERFLOW_MASK (hostdef->d_ERROR_STATUS_ENABLE_RX_UNDERFLOW_MASK)
+#define ERROR_STATUS_ENABLE_TX_OVERFLOW_LSB (hostdef->d_ERROR_STATUS_ENABLE_TX_OVERFLOW_LSB)
+#define ERROR_STATUS_ENABLE_TX_OVERFLOW_MASK (hostdef->d_ERROR_STATUS_ENABLE_TX_OVERFLOW_MASK)
+#define COUNTER_INT_STATUS_ENABLE_BIT_LSB (hostdef->d_COUNTER_INT_STATUS_ENABLE_BIT_LSB)
+#define COUNTER_INT_STATUS_ENABLE_BIT_MASK (hostdef->d_COUNTER_INT_STATUS_ENABLE_BIT_MASK)
+#define INT_STATUS_ENABLE_ADDRESS (hostdef->d_INT_STATUS_ENABLE_ADDRESS)
+#define CPU_INT_STATUS_ENABLE_BIT_LSB (hostdef->d_CPU_INT_STATUS_ENABLE_BIT_LSB)
+#define CPU_INT_STATUS_ENABLE_BIT_MASK (hostdef->d_CPU_INT_STATUS_ENABLE_BIT_MASK)
+#define HOST_INT_STATUS_ADDRESS (hostdef->d_HOST_INT_STATUS_ADDRESS)
+#define CPU_INT_STATUS_ADDRESS (hostdef->d_CPU_INT_STATUS_ADDRESS)
+#define ERROR_INT_STATUS_ADDRESS (hostdef->d_ERROR_INT_STATUS_ADDRESS)
+#define ERROR_INT_STATUS_WAKEUP_MASK (hostdef->d_ERROR_INT_STATUS_WAKEUP_MASK)
+#define ERROR_INT_STATUS_WAKEUP_LSB (hostdef->d_ERROR_INT_STATUS_WAKEUP_LSB)
+#define ERROR_INT_STATUS_RX_UNDERFLOW_MASK (hostdef->d_ERROR_INT_STATUS_RX_UNDERFLOW_MASK)
+#define ERROR_INT_STATUS_RX_UNDERFLOW_LSB (hostdef->d_ERROR_INT_STATUS_RX_UNDERFLOW_LSB)
+#define ERROR_INT_STATUS_TX_OVERFLOW_MASK (hostdef->d_ERROR_INT_STATUS_TX_OVERFLOW_MASK)
+#define ERROR_INT_STATUS_TX_OVERFLOW_LSB (hostdef->d_ERROR_INT_STATUS_TX_OVERFLOW_LSB)
+#define COUNT_DEC_ADDRESS (hostdef->d_COUNT_DEC_ADDRESS)
+#define HOST_INT_STATUS_CPU_MASK (hostdef->d_HOST_INT_STATUS_CPU_MASK)
+#define HOST_INT_STATUS_CPU_LSB (hostdef->d_HOST_INT_STATUS_CPU_LSB)
+#define HOST_INT_STATUS_ERROR_MASK (hostdef->d_HOST_INT_STATUS_ERROR_MASK)
+#define HOST_INT_STATUS_ERROR_LSB (hostdef->d_HOST_INT_STATUS_ERROR_LSB)
+#define HOST_INT_STATUS_COUNTER_MASK (hostdef->d_HOST_INT_STATUS_COUNTER_MASK)
+#define HOST_INT_STATUS_COUNTER_LSB (hostdef->d_HOST_INT_STATUS_COUNTER_LSB)
+#define RX_LOOKAHEAD_VALID_ADDRESS (hostdef->d_RX_LOOKAHEAD_VALID_ADDRESS)
+#define WINDOW_DATA_ADDRESS (hostdef->d_WINDOW_DATA_ADDRESS)
+#define WINDOW_READ_ADDR_ADDRESS (hostdef->d_WINDOW_READ_ADDR_ADDRESS)
+#define WINDOW_WRITE_ADDR_ADDRESS (hostdef->d_WINDOW_WRITE_ADDR_ADDRESS)
+
+/* SET macros */
+#define INT_STATUS_ENABLE_ERROR_SET(x) (((x) << INT_STATUS_ENABLE_ERROR_LSB) & INT_STATUS_ENABLE_ERROR_MASK)
+#define INT_STATUS_ENABLE_CPU_SET(x) (((x) << INT_STATUS_ENABLE_CPU_LSB) & INT_STATUS_ENABLE_CPU_MASK)
+#define INT_STATUS_ENABLE_COUNTER_SET(x) (((x) << INT_STATUS_ENABLE_COUNTER_LSB) & INT_STATUS_ENABLE_COUNTER_MASK)
+#define INT_STATUS_ENABLE_MBOX_DATA_SET(x) (((x) << INT_STATUS_ENABLE_MBOX_DATA_LSB) & INT_STATUS_ENABLE_MBOX_DATA_MASK)
+#define CPU_INT_STATUS_ENABLE_BIT_SET(x) (((x) << CPU_INT_STATUS_ENABLE_BIT_LSB) & CPU_INT_STATUS_ENABLE_BIT_MASK)
+#define ERROR_STATUS_ENABLE_RX_UNDERFLOW_SET(x) (((x) << ERROR_STATUS_ENABLE_RX_UNDERFLOW_LSB) & ERROR_STATUS_ENABLE_RX_UNDERFLOW_MASK)
+#define ERROR_STATUS_ENABLE_TX_OVERFLOW_SET(x) (((x) << ERROR_STATUS_ENABLE_TX_OVERFLOW_LSB) & ERROR_STATUS_ENABLE_TX_OVERFLOW_MASK)
+#define COUNTER_INT_STATUS_ENABLE_BIT_SET(x) (((x) << COUNTER_INT_STATUS_ENABLE_BIT_LSB) & COUNTER_INT_STATUS_ENABLE_BIT_MASK)
+#define ERROR_INT_STATUS_WAKEUP_GET(x) (((x) & ERROR_INT_STATUS_WAKEUP_MASK) >> ERROR_INT_STATUS_WAKEUP_LSB)
+#define ERROR_INT_STATUS_RX_UNDERFLOW_GET(x) (((x) & ERROR_INT_STATUS_RX_UNDERFLOW_MASK) >> ERROR_INT_STATUS_RX_UNDERFLOW_LSB)
+#define ERROR_INT_STATUS_TX_OVERFLOW_GET(x) (((x) & ERROR_INT_STATUS_TX_OVERFLOW_MASK) >> ERROR_INT_STATUS_TX_OVERFLOW_LSB)
+#define HOST_INT_STATUS_CPU_GET(x) (((x) & HOST_INT_STATUS_CPU_MASK) >> HOST_INT_STATUS_CPU_LSB)
+#define HOST_INT_STATUS_ERROR_GET(x) (((x) & HOST_INT_STATUS_ERROR_MASK) >> HOST_INT_STATUS_ERROR_LSB)
+#define HOST_INT_STATUS_COUNTER_GET(x) (((x) & HOST_INT_STATUS_COUNTER_MASK) >> HOST_INT_STATUS_COUNTER_LSB)
+
+
+extern struct hostdef_s *hostdef;
+
+#endif /* } */
+
+#endif /*HOST_REG_TABLE_H_*/
+
+
diff --git a/host/include/host_version.h b/host/include/host_version.h
new file mode 100644
index 0000000..74f1982
--- /dev/null
+++ b/host/include/host_version.h
@@ -0,0 +1,52 @@
+//------------------------------------------------------------------------------
+// <copyright file="host_version.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains version information for the sample host driver for the
+// AR6000 chip
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HOST_VERSION_H_
+#define _HOST_VERSION_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include <AR6002/AR6K_version.h>
+
+/*
+ * The version number is made up of major, minor, patch and build
+ * numbers. These are 16 bit numbers. The build and release script will
+ * set the build number using a Perforce counter. Here the build number is
+ * set to 9999 so that builds done without the build-release script are easily
+ * identifiable.
+ */
+
+#define ATH_SW_VER_MAJOR __VER_MAJOR_
+#define ATH_SW_VER_MINOR __VER_MINOR_
+#define ATH_SW_VER_PATCH __VER_PATCH_
+#define ATH_SW_VER_BUILD __BUILD_NUMBER_
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _HOST_VERSION_H_ */
diff --git a/host/include/htc.h b/host/include/htc.h
new file mode 100644
index 0000000..8462a35
--- /dev/null
+++ b/host/include/htc.h
@@ -0,0 +1,238 @@
+//------------------------------------------------------------------------------
+// <copyright file="htc.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __HTC_H__
+#define __HTC_H__
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+#ifndef A_OFFSETOF
+#define A_OFFSETOF(type,field) (unsigned long)(&(((type *)NULL)->field))
+#endif
+
+#define ASSEMBLE_UNALIGNED_UINT16(p,highbyte,lowbyte) \
+ (((A_UINT16)(((A_UINT8 *)(p))[(highbyte)])) << 8 | (A_UINT16)(((A_UINT8 *)(p))[(lowbyte)]))
+
+/* alignment independent macros (little-endian) to fetch UINT16s or UINT8s from a
+ * structure using only the type and field name.
+ * Use these macros if there is the potential for unaligned buffer accesses. */
+#define A_GET_UINT16_FIELD(p,type,field) \
+ ASSEMBLE_UNALIGNED_UINT16(p,\
+ A_OFFSETOF(type,field) + 1, \
+ A_OFFSETOF(type,field))
+
+#define A_SET_UINT16_FIELD(p,type,field,value) \
+{ \
+ ((A_UINT8 *)(p))[A_OFFSETOF(type,field)] = (A_UINT8)(value); \
+ ((A_UINT8 *)(p))[A_OFFSETOF(type,field) + 1] = (A_UINT8)((value) >> 8); \
+}
+
+#define A_GET_UINT8_FIELD(p,type,field) \
+ ((A_UINT8 *)(p))[A_OFFSETOF(type,field)]
+
+#define A_SET_UINT8_FIELD(p,type,field,value) \
+ ((A_UINT8 *)(p))[A_OFFSETOF(type,field)] = (value)
+
+/****** DANGER DANGER ***************
+ *
+ * The frame header length and message formats defined herein were
+ * selected to accommodate optimal alignment for target processing. This reduces code
+ * size and improves performance.
+ *
+ * Any changes to the header length may alter the alignment and cause exceptions
+ * on the target. When adding to the message structures insure that fields are
+ * properly aligned.
+ *
+ */
+
+/* HTC frame header */
+typedef PREPACK struct _HTC_FRAME_HDR{
+ /* do not remove or re-arrange these fields, these are minimally required
+ * to take advantage of 4-byte lookaheads in some hardware implementations */
+ A_UINT8 EndpointID;
+ A_UINT8 Flags;
+ A_UINT16 PayloadLen; /* length of data (including trailer) that follows the header */
+
+ /***** end of 4-byte lookahead ****/
+
+ A_UINT8 ControlBytes[2];
+
+ /* message payload starts after the header */
+
+} POSTPACK HTC_FRAME_HDR;
+
+/* frame header flags */
+
+ /* send direction */
+#define HTC_FLAGS_NEED_CREDIT_UPDATE (1 << 0)
+#define HTC_FLAGS_SEND_BUNDLE (1 << 1) /* start or part of bundle */
+ /* receive direction */
+#define HTC_FLAGS_RECV_UNUSED_0 (1 << 0) /* bit 0 unused */
+#define HTC_FLAGS_RECV_TRAILER (1 << 1) /* bit 1 trailer data present */
+#define HTC_FLAGS_RECV_UNUSED_2 (1 << 0) /* bit 2 unused */
+#define HTC_FLAGS_RECV_UNUSED_3 (1 << 0) /* bit 3 unused */
+#define HTC_FLAGS_RECV_BUNDLE_CNT_MASK (0xF0) /* bits 7..4 */
+#define HTC_FLAGS_RECV_BUNDLE_CNT_SHIFT 4
+
+#define HTC_HDR_LENGTH (sizeof(HTC_FRAME_HDR))
+#define HTC_MAX_TRAILER_LENGTH 255
+#define HTC_MAX_PAYLOAD_LENGTH (4096 - sizeof(HTC_FRAME_HDR))
+
+/* HTC control message IDs */
+
+#define HTC_MSG_READY_ID 1
+#define HTC_MSG_CONNECT_SERVICE_ID 2
+#define HTC_MSG_CONNECT_SERVICE_RESPONSE_ID 3
+#define HTC_MSG_SETUP_COMPLETE_ID 4
+#define HTC_MSG_SETUP_COMPLETE_EX_ID 5
+
+#define HTC_MAX_CONTROL_MESSAGE_LENGTH 256
+
+/* base message ID header */
+typedef PREPACK struct {
+ A_UINT16 MessageID;
+} POSTPACK HTC_UNKNOWN_MSG;
+
+/* HTC ready message
+ * direction : target-to-host */
+typedef PREPACK struct {
+ A_UINT16 MessageID; /* ID */
+ A_UINT16 CreditCount; /* number of credits the target can offer */
+ A_UINT16 CreditSize; /* size of each credit */
+ A_UINT8 MaxEndpoints; /* maximum number of endpoints the target has resources for */
+ A_UINT8 _Pad1;
+} POSTPACK HTC_READY_MSG;
+
+ /* extended HTC ready message */
+typedef PREPACK struct {
+ HTC_READY_MSG Version2_0_Info; /* legacy version 2.0 information at the front... */
+ /* extended information */
+ A_UINT8 HTCVersion;
+ A_UINT8 MaxMsgsPerHTCBundle;
+} POSTPACK HTC_READY_EX_MSG;
+
+#define HTC_VERSION_2P0 0x00
+#define HTC_VERSION_2P1 0x01 /* HTC 2.1 */
+
+#define HTC_SERVICE_META_DATA_MAX_LENGTH 128
+
+/* connect service
+ * direction : host-to-target */
+typedef PREPACK struct {
+ A_UINT16 MessageID;
+ A_UINT16 ServiceID; /* service ID of the service to connect to */
+ A_UINT16 ConnectionFlags; /* connection flags */
+
+#define HTC_CONNECT_FLAGS_REDUCE_CREDIT_DRIBBLE (1 << 2) /* reduce credit dribbling when
+ the host needs credits */
+#define HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_MASK (0x3)
+#define HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_ONE_FOURTH 0x0
+#define HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_ONE_HALF 0x1
+#define HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_THREE_FOURTHS 0x2
+#define HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_UNITY 0x3
+
+ A_UINT8 ServiceMetaLength; /* length of meta data that follows */
+ A_UINT8 _Pad1;
+
+ /* service-specific meta data starts after the header */
+
+} POSTPACK HTC_CONNECT_SERVICE_MSG;
+
+/* connect response
+ * direction : target-to-host */
+typedef PREPACK struct {
+ A_UINT16 MessageID;
+ A_UINT16 ServiceID; /* service ID that the connection request was made */
+ A_UINT8 Status; /* service connection status */
+ A_UINT8 EndpointID; /* assigned endpoint ID */
+ A_UINT16 MaxMsgSize; /* maximum expected message size on this endpoint */
+ A_UINT8 ServiceMetaLength; /* length of meta data that follows */
+ A_UINT8 _Pad1;
+
+ /* service-specific meta data starts after the header */
+
+} POSTPACK HTC_CONNECT_SERVICE_RESPONSE_MSG;
+
+typedef PREPACK struct {
+ A_UINT16 MessageID;
+ /* currently, no other fields */
+} POSTPACK HTC_SETUP_COMPLETE_MSG;
+
+ /* extended setup completion message */
+typedef PREPACK struct {
+ A_UINT16 MessageID;
+ A_UINT32 SetupFlags;
+ A_UINT8 MaxMsgsPerBundledRecv;
+ A_UINT8 Rsvd[3];
+} POSTPACK HTC_SETUP_COMPLETE_EX_MSG;
+
+#define HTC_SETUP_COMPLETE_FLAGS_ENABLE_BUNDLE_RECV (1 << 0)
+
+/* connect response status codes */
+#define HTC_SERVICE_SUCCESS 0 /* success */
+#define HTC_SERVICE_NOT_FOUND 1 /* service could not be found */
+#define HTC_SERVICE_FAILED 2 /* specific service failed the connect */
+#define HTC_SERVICE_NO_RESOURCES 3 /* no resources (i.e. no more endpoints) */
+#define HTC_SERVICE_NO_MORE_EP 4 /* specific service is not allowing any more
+ endpoints */
+
+/* report record IDs */
+
+#define HTC_RECORD_NULL 0
+#define HTC_RECORD_CREDITS 1
+#define HTC_RECORD_LOOKAHEAD 2
+#define HTC_RECORD_LOOKAHEAD_BUNDLE 3
+
+typedef PREPACK struct {
+ A_UINT8 RecordID; /* Record ID */
+ A_UINT8 Length; /* Length of record */
+} POSTPACK HTC_RECORD_HDR;
+
+typedef PREPACK struct {
+ A_UINT8 EndpointID; /* Endpoint that owns these credits */
+ A_UINT8 Credits; /* credits to report since last report */
+} POSTPACK HTC_CREDIT_REPORT;
+
+typedef PREPACK struct {
+ A_UINT8 PreValid; /* pre valid guard */
+ A_UINT8 LookAhead[4]; /* 4 byte lookahead */
+ A_UINT8 PostValid; /* post valid guard */
+
+ /* NOTE: the LookAhead array is guarded by a PreValid and Post Valid guard bytes.
+ * The PreValid bytes must equal the inverse of the PostValid byte */
+
+} POSTPACK HTC_LOOKAHEAD_REPORT;
+
+typedef PREPACK struct {
+ A_UINT8 LookAhead[4]; /* 4 byte lookahead */
+} POSTPACK HTC_BUNDLED_LOOKAHEAD_REPORT;
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+
+#endif /* __HTC_H__ */
+
diff --git a/host/include/htc_api.h b/host/include/htc_api.h
new file mode 100644
index 0000000..b007051
--- /dev/null
+++ b/host/include/htc_api.h
@@ -0,0 +1,575 @@
+//------------------------------------------------------------------------------
+// <copyright file="htc_api.h" company="Atheros">
+// Copyright (c) 2007-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HTC_API_H_
+#define _HTC_API_H_
+
+#include "htc_packet.h"
+#include <htc.h>
+#include <htc_services.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/* TODO.. for BMI */
+#define ENDPOINT1 0
+// TODO -remove me, but we have to fix BMI first
+#define HTC_MAILBOX_NUM_MAX 4
+
+/* this is the amount of header room required by users of HTC */
+#define HTC_HEADER_LEN HTC_HDR_LENGTH
+
+typedef void *HTC_HANDLE;
+
+typedef A_UINT16 HTC_SERVICE_ID;
+
+typedef struct _HTC_INIT_INFO {
+ void *pContext; /* context for target failure notification */
+ void (*TargetFailure)(void *Instance, A_STATUS Status);
+} HTC_INIT_INFO;
+
+/* per service connection send completion */
+typedef void (*HTC_EP_SEND_PKT_COMPLETE)(void *,HTC_PACKET *);
+/* per service connection callback when a plurality of packets have been sent
+ * The HTC_PACKET_QUEUE is a temporary queue object (e.g. freed on return from the callback)
+ * to hold a list of completed send packets.
+ * If the handler cannot fully traverse the packet queue before returning, it should
+ * transfer the items of the queue into the caller's private queue using:
+ * HTC_PACKET_ENQUEUE() */
+typedef void (*HTC_EP_SEND_PKT_COMP_MULTIPLE)(void *,HTC_PACKET_QUEUE *);
+/* per service connection pkt received */
+typedef void (*HTC_EP_RECV_PKT)(void *,HTC_PACKET *);
+/* per service connection callback when a plurality of packets are received
+ * The HTC_PACKET_QUEUE is a temporary queue object (e.g. freed on return from the callback)
+ * to hold a list of recv packets.
+ * If the handler cannot fully traverse the packet queue before returning, it should
+ * transfer the items of the queue into the caller's private queue using:
+ * HTC_PACKET_ENQUEUE() */
+typedef void (*HTC_EP_RECV_PKT_MULTIPLE)(void *,HTC_PACKET_QUEUE *);
+
+/* Optional per service connection receive buffer re-fill callback,
+ * On some OSes (like Linux) packets are allocated from a global pool and indicated up
+ * to the network stack. The driver never gets the packets back from the OS. For these OSes
+ * a refill callback can be used to allocate and re-queue buffers into HTC.
+ *
+ * On other OSes, the network stack can call into the driver's OS-specifc "return_packet" handler and
+ * the driver can re-queue these buffers into HTC. In this regard a refill callback is
+ * unnecessary */
+typedef void (*HTC_EP_RECV_REFILL)(void *, HTC_ENDPOINT_ID Endpoint);
+
+/* Optional per service connection receive buffer allocation callback.
+ * On some systems packet buffers are an extremely limited resource. Rather than
+ * queue largest-possible-sized buffers to HTC, some systems would rather
+ * allocate a specific size as the packet is received. The trade off is
+ * slightly more processing (callback invoked for each RX packet)
+ * for the benefit of committing fewer buffer resources into HTC.
+ *
+ * The callback is provided the length of the pending packet to fetch. This includes the
+ * HTC header length plus the length of payload. The callback can return a pointer to
+ * the allocated HTC packet for immediate use.
+ *
+ * Alternatively a variant of this handler can be used to allocate large receive packets as needed.
+ * For example an application can use the refill mechanism for normal packets and the recv-alloc mechanism to
+ * handle the case where a large packet buffer is required. This can significantly reduce the
+ * amount of "committed" memory used to receive packets.
+ *
+ * */
+typedef HTC_PACKET *(*HTC_EP_RECV_ALLOC)(void *, HTC_ENDPOINT_ID Endpoint, int Length);
+
+typedef enum _HTC_SEND_FULL_ACTION {
+ HTC_SEND_FULL_KEEP = 0, /* packet that overflowed should be kept in the queue */
+ HTC_SEND_FULL_DROP = 1, /* packet that overflowed should be dropped */
+} HTC_SEND_FULL_ACTION;
+
+/* Optional per service connection callback when a send queue is full. This can occur if the
+ * host continues queueing up TX packets faster than credits can arrive
+ * To prevent the host (on some Oses like Linux) from continuously queueing packets
+ * and consuming resources, this callback is provided so that that the host
+ * can disable TX in the subsystem (i.e. network stack).
+ * This callback is invoked for each packet that "overflows" the HTC queue. The callback can
+ * determine whether the new packet that overflowed the queue can be kept (HTC_SEND_FULL_KEEP) or
+ * dropped (HTC_SEND_FULL_DROP). If a packet is dropped, the EpTxComplete handler will be called
+ * and the packet's status field will be set to A_NO_RESOURCE.
+ * Other OSes require a "per-packet" indication for each completed TX packet, this
+ * closed loop mechanism will prevent the network stack from overunning the NIC
+ * The packet to keep or drop is passed for inspection to the registered handler the handler
+ * must ONLY inspect the packet, it may not free or reclaim the packet. */
+typedef HTC_SEND_FULL_ACTION (*HTC_EP_SEND_QUEUE_FULL)(void *, HTC_PACKET *pPacket);
+
+typedef struct _HTC_EP_CALLBACKS {
+ void *pContext; /* context for each callback */
+ HTC_EP_SEND_PKT_COMPLETE EpTxComplete; /* tx completion callback for connected endpoint */
+ HTC_EP_RECV_PKT EpRecv; /* receive callback for connected endpoint */
+ HTC_EP_RECV_REFILL EpRecvRefill; /* OPTIONAL receive re-fill callback for connected endpoint */
+ HTC_EP_SEND_QUEUE_FULL EpSendFull; /* OPTIONAL send full callback */
+ HTC_EP_RECV_ALLOC EpRecvAlloc; /* OPTIONAL recv allocation callback */
+ HTC_EP_RECV_ALLOC EpRecvAllocThresh; /* OPTIONAL recv allocation callback based on a threshold */
+ HTC_EP_SEND_PKT_COMP_MULTIPLE EpTxCompleteMultiple; /* OPTIONAL completion handler for multiple complete
+ indications (EpTxComplete must be NULL) */
+ HTC_EP_RECV_PKT_MULTIPLE EpRecvPktMultiple; /* OPTIONAL completion handler for multiple
+ recv packet indications (EpRecv must be NULL) */
+ int RecvAllocThreshold; /* if EpRecvAllocThresh is non-NULL, HTC will compare the
+ threshold value to the current recv packet length and invoke
+ the EpRecvAllocThresh callback to acquire a packet buffer */
+ int RecvRefillWaterMark; /* if a EpRecvRefill handler is provided, this value
+ can be used to set a trigger refill callback
+ when the recv queue drops below this value
+ if set to 0, the refill is only called when packets
+ are empty */
+} HTC_EP_CALLBACKS;
+
+/* service connection information */
+typedef struct _HTC_SERVICE_CONNECT_REQ {
+ HTC_SERVICE_ID ServiceID; /* service ID to connect to */
+ A_UINT16 ConnectionFlags; /* connection flags, see htc protocol definition */
+ A_UINT8 *pMetaData; /* ptr to optional service-specific meta-data */
+ A_UINT8 MetaDataLength; /* optional meta data length */
+ HTC_EP_CALLBACKS EpCallbacks; /* endpoint callbacks */
+ int MaxSendQueueDepth; /* maximum depth of any send queue */
+ A_UINT32 LocalConnectionFlags; /* HTC flags for the host-side (local) connection */
+ unsigned int MaxSendMsgSize; /* override max message size in send direction */
+} HTC_SERVICE_CONNECT_REQ;
+
+#define HTC_LOCAL_CONN_FLAGS_ENABLE_SEND_BUNDLE_PADDING (1 << 0) /* enable send bundle padding for this endpoint */
+
+/* service connection response information */
+typedef struct _HTC_SERVICE_CONNECT_RESP {
+ A_UINT8 *pMetaData; /* caller supplied buffer to optional meta-data */
+ A_UINT8 BufferLength; /* length of caller supplied buffer */
+ A_UINT8 ActualLength; /* actual length of meta data */
+ HTC_ENDPOINT_ID Endpoint; /* endpoint to communicate over */
+ unsigned int MaxMsgLength; /* max length of all messages over this endpoint */
+ A_UINT8 ConnectRespCode; /* connect response code from target */
+} HTC_SERVICE_CONNECT_RESP;
+
+/* endpoint distribution structure */
+typedef struct _HTC_ENDPOINT_CREDIT_DIST {
+ struct _HTC_ENDPOINT_CREDIT_DIST *pNext;
+ struct _HTC_ENDPOINT_CREDIT_DIST *pPrev;
+ HTC_SERVICE_ID ServiceID; /* Service ID (set by HTC) */
+ HTC_ENDPOINT_ID Endpoint; /* endpoint for this distribution struct (set by HTC) */
+ A_UINT32 DistFlags; /* distribution flags, distribution function can
+ set default activity using SET_EP_ACTIVE() macro */
+ int TxCreditsNorm; /* credits for normal operation, anything above this
+ indicates the endpoint is over-subscribed, this field
+ is only relevant to the credit distribution function */
+ int TxCreditsMin; /* floor for credit distribution, this field is
+ only relevant to the credit distribution function */
+ int TxCreditsAssigned; /* number of credits assigned to this EP, this field
+ is only relevant to the credit dist function */
+ int TxCredits; /* current credits available, this field is used by
+ HTC to determine whether a message can be sent or
+ must be queued */
+ int TxCreditsToDist; /* pending credits to distribute on this endpoint, this
+ is set by HTC when credit reports arrive.
+ The credit distribution functions sets this to zero
+ when it distributes the credits */
+ int TxCreditsSeek; /* this is the number of credits that the current pending TX
+ packet needs to transmit. This is set by HTC when
+ and endpoint needs credits in order to transmit */
+ int TxCreditSize; /* size in bytes of each credit (set by HTC) */
+ int TxCreditsPerMaxMsg; /* credits required for a maximum sized messages (set by HTC) */
+ void *pHTCReserved; /* reserved for HTC use */
+ int TxQueueDepth; /* current depth of TX queue , i.e. messages waiting for credits
+ This field is valid only when HTC_CREDIT_DIST_ACTIVITY_CHANGE
+ or HTC_CREDIT_DIST_SEND_COMPLETE is indicated on an endpoint
+ that has non-zero credits to recover
+ */
+} HTC_ENDPOINT_CREDIT_DIST;
+
+#define HTC_EP_ACTIVE ((A_UINT32) (1u << 31))
+
+/* macro to check if an endpoint has gone active, useful for credit
+ * distributions */
+#define IS_EP_ACTIVE(epDist) ((epDist)->DistFlags & HTC_EP_ACTIVE)
+#define SET_EP_ACTIVE(epDist) (epDist)->DistFlags |= HTC_EP_ACTIVE
+
+ /* credit distibution code that is passed into the distrbution function,
+ * there are mandatory and optional codes that must be handled */
+typedef enum _HTC_CREDIT_DIST_REASON {
+ HTC_CREDIT_DIST_SEND_COMPLETE = 0, /* credits available as a result of completed
+ send operations (MANDATORY) resulting in credit reports */
+ HTC_CREDIT_DIST_ACTIVITY_CHANGE = 1, /* a change in endpoint activity occured (OPTIONAL) */
+ HTC_CREDIT_DIST_SEEK_CREDITS, /* an endpoint needs to "seek" credits (OPTIONAL) */
+ HTC_DUMP_CREDIT_STATE /* for debugging, dump any state information that is kept by
+ the distribution function */
+} HTC_CREDIT_DIST_REASON;
+
+typedef void (*HTC_CREDIT_DIST_CALLBACK)(void *Context,
+ HTC_ENDPOINT_CREDIT_DIST *pEPList,
+ HTC_CREDIT_DIST_REASON Reason);
+
+typedef void (*HTC_CREDIT_INIT_CALLBACK)(void *Context,
+ HTC_ENDPOINT_CREDIT_DIST *pEPList,
+ int TotalCredits);
+
+ /* endpoint statistics action */
+typedef enum _HTC_ENDPOINT_STAT_ACTION {
+ HTC_EP_STAT_SAMPLE = 0, /* only read statistics */
+ HTC_EP_STAT_SAMPLE_AND_CLEAR = 1, /* sample and immediately clear statistics */
+ HTC_EP_STAT_CLEAR /* clear only */
+} HTC_ENDPOINT_STAT_ACTION;
+
+ /* endpoint statistics */
+typedef struct _HTC_ENDPOINT_STATS {
+ A_UINT32 TxCreditLowIndications; /* number of times the host set the credit-low flag in a send message on
+ this endpoint */
+ A_UINT32 TxIssued; /* running count of total TX packets issued */
+ A_UINT32 TxPacketsBundled; /* running count of TX packets that were issued in bundles */
+ A_UINT32 TxBundles; /* running count of TX bundles that were issued */
+ A_UINT32 TxDropped; /* tx packets that were dropped */
+ A_UINT32 TxCreditRpts; /* running count of total credit reports received for this endpoint */
+ A_UINT32 TxCreditRptsFromRx; /* credit reports received from this endpoint's RX packets */
+ A_UINT32 TxCreditRptsFromOther; /* credit reports received from RX packets of other endpoints */
+ A_UINT32 TxCreditRptsFromEp0; /* credit reports received from endpoint 0 RX packets */
+ A_UINT32 TxCreditsFromRx; /* count of credits received via Rx packets on this endpoint */
+ A_UINT32 TxCreditsFromOther; /* count of credits received via another endpoint */
+ A_UINT32 TxCreditsFromEp0; /* count of credits received via another endpoint */
+ A_UINT32 TxCreditsConsummed; /* count of consummed credits */
+ A_UINT32 TxCreditsReturned; /* count of credits returned */
+ A_UINT32 RxReceived; /* count of RX packets received */
+ A_UINT32 RxLookAheads; /* count of lookahead records
+ found in messages received on this endpoint */
+ A_UINT32 RxPacketsBundled; /* count of recv packets received in a bundle */
+ A_UINT32 RxBundleLookAheads; /* count of number of bundled lookaheads */
+ A_UINT32 RxBundleIndFromHdr; /* count of the number of bundle indications from the HTC header */
+ A_UINT32 RxAllocThreshHit; /* count of the number of times the recv allocation threshhold was hit */
+ A_UINT32 RxAllocThreshBytes; /* total number of bytes */
+} HTC_ENDPOINT_STATS;
+
+/* ------ Function Prototypes ------ */
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Create an instance of HTC over the underlying HIF device
+ @function name: HTCCreate
+ @input: HifDevice - hif device handle,
+ pInfo - initialization information
+ @output:
+ @return: HTC_HANDLE on success, NULL on failure
+ @notes:
+ @example:
+ @see also: HTCDestroy
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+HTC_HANDLE HTCCreate(void *HifDevice, HTC_INIT_INFO *pInfo);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Get the underlying HIF device handle
+ @function name: HTCGetHifDevice
+ @input: HTCHandle - handle passed into the AddInstance callback
+ @output:
+ @return: opaque HIF device handle usable in HIF API calls.
+ @notes:
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void *HTCGetHifDevice(HTC_HANDLE HTCHandle);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Set credit distribution parameters
+ @function name: HTCSetCreditDistribution
+ @input: HTCHandle - HTC handle
+ pCreditDistCont - caller supplied context to pass into distribution functions
+ CreditDistFunc - Distribution function callback
+ CreditDistInit - Credit Distribution initialization callback
+ ServicePriorityOrder - Array containing list of service IDs, lowest index is highest
+ priority
+ ListLength - number of elements in ServicePriorityOrder
+ @output:
+ @return:
+ @notes: The user can set a custom credit distribution function to handle special requirements
+ for each endpoint. A default credit distribution routine can be used by setting
+ CreditInitFunc to NULL. The default credit distribution is only provided for simple
+ "fair" credit distribution without regard to any prioritization.
+
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HTCSetCreditDistribution(HTC_HANDLE HTCHandle,
+ void *pCreditDistContext,
+ HTC_CREDIT_DIST_CALLBACK CreditDistFunc,
+ HTC_CREDIT_INIT_CALLBACK CreditInitFunc,
+ HTC_SERVICE_ID ServicePriorityOrder[],
+ int ListLength);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Wait for the target to indicate the HTC layer is ready
+ @function name: HTCWaitTarget
+ @input: HTCHandle - HTC handle
+ @output:
+ @return:
+ @notes: This API blocks until the target responds with an HTC ready message.
+ The caller should not connect services until the target has indicated it is
+ ready.
+ @example:
+ @see also: HTCConnectService
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HTCWaitTarget(HTC_HANDLE HTCHandle);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Start target service communications
+ @function name: HTCStart
+ @input: HTCHandle - HTC handle
+ @output:
+ @return:
+ @notes: This API indicates to the target that the service connection phase is complete
+ and the target can freely start all connected services. This API should only be
+ called AFTER all service connections have been made. TCStart will issue a
+ SETUP_COMPLETE message to the target to indicate that all service connections
+ have been made and the target can start communicating over the endpoints.
+ @example:
+ @see also: HTCConnectService
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HTCStart(HTC_HANDLE HTCHandle);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Add receive packet to HTC
+ @function name: HTCAddReceivePkt
+ @input: HTCHandle - HTC handle
+ pPacket - HTC receive packet to add
+ @output:
+ @return: A_OK on success
+ @notes: user must supply HTC packets for capturing incomming HTC frames. The caller
+ must initialize each HTC packet using the SET_HTC_PACKET_INFO_RX_REFILL()
+ macro.
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HTCAddReceivePkt(HTC_HANDLE HTCHandle, HTC_PACKET *pPacket);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Connect to an HTC service
+ @function name: HTCConnectService
+ @input: HTCHandle - HTC handle
+ pReq - connection details
+ @output: pResp - connection response
+ @return:
+ @notes: Service connections must be performed before HTCStart. User provides callback handlers
+ for various endpoint events.
+ @example:
+ @see also: HTCStart
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HTCConnectService(HTC_HANDLE HTCHandle,
+ HTC_SERVICE_CONNECT_REQ *pReq,
+ HTC_SERVICE_CONNECT_RESP *pResp);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Send an HTC packet
+ @function name: HTCSendPkt
+ @input: HTCHandle - HTC handle
+ pPacket - packet to send
+ @output:
+ @return: A_OK
+ @notes: Caller must initialize packet using SET_HTC_PACKET_INFO_TX() macro.
+ This interface is fully asynchronous. On error, HTC SendPkt will
+ call the registered Endpoint callback to cleanup the packet.
+ @example:
+ @see also: HTCFlushEndpoint
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HTCSendPkt(HTC_HANDLE HTCHandle, HTC_PACKET *pPacket);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Stop HTC service communications
+ @function name: HTCStop
+ @input: HTCHandle - HTC handle
+ @output:
+ @return:
+ @notes: HTC communications is halted. All receive and pending TX packets will
+ be flushed.
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HTCStop(HTC_HANDLE HTCHandle);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Destory HTC service
+ @function name: HTCDestroy
+ @input: HTCHandle
+ @output:
+ @return:
+ @notes: This cleans up all resources allocated by HTCCreate().
+ @example:
+ @see also: HTCCreate
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HTCDestroy(HTC_HANDLE HTCHandle);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Flush pending TX packets
+ @function name: HTCFlushEndpoint
+ @input: HTCHandle - HTC handle
+ Endpoint - Endpoint to flush
+ Tag - flush tag
+ @output:
+ @return:
+ @notes: The Tag parameter is used to selectively flush packets with matching tags.
+ The value of 0 forces all packets to be flush regardless of tag.
+ @example:
+ @see also: HTCSendPkt
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HTCFlushEndpoint(HTC_HANDLE HTCHandle, HTC_ENDPOINT_ID Endpoint, HTC_TX_TAG Tag);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Dump credit distribution state
+ @function name: HTCDumpCreditStates
+ @input: HTCHandle - HTC handle
+ @output:
+ @return:
+ @notes: This dumps all credit distribution information to the debugger
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HTCDumpCreditStates(HTC_HANDLE HTCHandle);
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Indicate a traffic activity change on an endpoint
+ @function name: HTCIndicateActivityChange
+ @input: HTCHandle - HTC handle
+ Endpoint - endpoint in which activity has changed
+ Active - TRUE if active, FALSE if it has become inactive
+ @output:
+ @return:
+ @notes: This triggers the registered credit distribution function to
+ re-adjust credits for active/inactive endpoints.
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HTCIndicateActivityChange(HTC_HANDLE HTCHandle,
+ HTC_ENDPOINT_ID Endpoint,
+ A_BOOL Active);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Get endpoint statistics
+ @function name: HTCGetEndpointStatistics
+ @input: HTCHandle - HTC handle
+ Endpoint - Endpoint identifier
+ Action - action to take with statistics
+ @output:
+ pStats - statistics that were sampled (can be NULL if Action is HTC_EP_STAT_CLEAR)
+
+ @return: TRUE if statistics profiling is enabled, otherwise FALSE.
+
+ @notes: Statistics is a compile-time option and this function may return FALSE
+ if HTC is not compiled with profiling.
+
+ The caller can specify the statistic "action" to take when sampling
+ the statistics. This includes:
+
+ HTC_EP_STAT_SAMPLE: The pStats structure is filled with the current values.
+ HTC_EP_STAT_SAMPLE_AND_CLEAR: The structure is filled and the current statistics
+ are cleared.
+ HTC_EP_STAT_CLEA : the statistics are cleared, the called can pass a NULL value for
+ pStats
+
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_BOOL HTCGetEndpointStatistics(HTC_HANDLE HTCHandle,
+ HTC_ENDPOINT_ID Endpoint,
+ HTC_ENDPOINT_STAT_ACTION Action,
+ HTC_ENDPOINT_STATS *pStats);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Unblock HTC message reception
+ @function name: HTCUnblockRecv
+ @input: HTCHandle - HTC handle
+ @output:
+ @return:
+ @notes:
+ HTC will block the receiver if the EpRecvAlloc callback fails to provide a packet.
+ The caller can use this API to indicate to HTC when resources (buffers) are available
+ such that the receiver can be unblocked and HTC may re-attempt fetching the pending message.
+
+ This API is not required if the user uses the EpRecvRefill callback or uses the HTCAddReceivePacket()
+ API to recycle or provide receive packets to HTC.
+
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+void HTCUnblockRecv(HTC_HANDLE HTCHandle);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: send a series of HTC packets
+ @function name: HTCSendPktsMultiple
+ @input: HTCHandle - HTC handle
+ pPktQueue - local queue holding packets to send
+ @output:
+ @return: A_OK
+ @notes: Caller must initialize each packet using SET_HTC_PACKET_INFO_TX() macro.
+ The queue must only contain packets directed at the same endpoint.
+ Caller supplies a pointer to an HTC_PACKET_QUEUE structure holding the TX packets in FIFO order.
+ This API will remove the packets from the pkt queue and place them into the HTC Tx Queue
+ and bundle messages where possible.
+ The caller may allocate the pkt queue on the stack to hold the packets.
+ This interface is fully asynchronous. On error, HTCSendPkts will
+ call the registered Endpoint callback to cleanup the packet.
+ @example:
+ @see also: HTCFlushEndpoint
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HTCSendPktsMultiple(HTC_HANDLE HTCHandle, HTC_PACKET_QUEUE *pPktQueue);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Add multiple receive packets to HTC
+ @function name: HTCAddReceivePktMultiple
+ @input: HTCHandle - HTC handle
+ pPktQueue - HTC receive packet queue holding packets to add
+ @output:
+ @return: A_OK on success
+ @notes: user must supply HTC packets for capturing incomming HTC frames. The caller
+ must initialize each HTC packet using the SET_HTC_PACKET_INFO_RX_REFILL()
+ macro. The queue must only contain recv packets for the same endpoint.
+ Caller supplies a pointer to an HTC_PACKET_QUEUE structure holding the recv packet.
+ This API will remove the packets from the pkt queue and place them into internal
+ recv packet list.
+ The caller may allocate the pkt queue on the stack to hold the packets.
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_STATUS HTCAddReceivePktMultiple(HTC_HANDLE HTCHandle, HTC_PACKET_QUEUE *pPktQueue);
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Check if an endpoint is marked active
+ @function name: HTCIsEndpointActive
+ @input: HTCHandle - HTC handle
+ Endpoint - endpoint to check for active state
+ @output:
+ @return: returns TRUE if Endpoint is Active
+ @notes:
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+A_BOOL HTCIsEndpointActive(HTC_HANDLE HTCHandle,
+ HTC_ENDPOINT_ID Endpoint);
+
+
+/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ @desc: Get the number of recv buffers currently queued into an HTC endpoint
+ @function name: HTCGetNumRecvBuffers
+ @input: HTCHandle - HTC handle
+ Endpoint - endpoint to check
+ @output:
+ @return: returns number of buffers in queue
+ @notes:
+ @example:
+ @see also:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
+int HTCGetNumRecvBuffers(HTC_HANDLE HTCHandle,
+ HTC_ENDPOINT_ID Endpoint);
+
+/* internally used functions for testing... */
+void HTCEnableRecv(HTC_HANDLE HTCHandle);
+void HTCDisableRecv(HTC_HANDLE HTCHandle);
+A_STATUS HTCWaitForPendingRecv(HTC_HANDLE HTCHandle,
+ A_UINT32 TimeoutInMs,
+ A_BOOL *pbIsRecvPending);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _HTC_API_H_ */
diff --git a/host/include/htc_packet.h b/host/include/htc_packet.h
new file mode 100644
index 0000000..15175cf
--- /dev/null
+++ b/host/include/htc_packet.h
@@ -0,0 +1,227 @@
+//------------------------------------------------------------------------------
+// <copyright file="htc_packet.h" company="Atheros">
+// Copyright (c) 2007-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef HTC_PACKET_H_
+#define HTC_PACKET_H_
+
+
+#include "dl_list.h"
+
+/* ------ Endpoint IDS ------ */
+typedef enum
+{
+ ENDPOINT_UNUSED = -1,
+ ENDPOINT_0 = 0,
+ ENDPOINT_1 = 1,
+ ENDPOINT_2 = 2,
+ ENDPOINT_3,
+ ENDPOINT_4,
+ ENDPOINT_5,
+ ENDPOINT_6,
+ ENDPOINT_7,
+ ENDPOINT_8,
+ ENDPOINT_MAX,
+} HTC_ENDPOINT_ID;
+
+struct _HTC_PACKET;
+
+typedef void (* HTC_PACKET_COMPLETION)(void *,struct _HTC_PACKET *);
+
+typedef A_UINT16 HTC_TX_TAG;
+
+typedef struct _HTC_TX_PACKET_INFO {
+ HTC_TX_TAG Tag; /* tag used to selective flush packets */
+ int CreditsUsed; /* number of credits used for this TX packet (HTC internal) */
+ A_UINT8 SendFlags; /* send flags (HTC internal) */
+ int SeqNo; /* internal seq no for debugging (HTC internal) */
+} HTC_TX_PACKET_INFO;
+
+#define HTC_TX_PACKET_TAG_ALL 0 /* a tag of zero is reserved and used to flush ALL packets */
+#define HTC_TX_PACKET_TAG_INTERNAL 1 /* internal tags start here */
+#define HTC_TX_PACKET_TAG_USER_DEFINED (HTC_TX_PACKET_TAG_INTERNAL + 9) /* user-defined tags start here */
+
+typedef struct _HTC_RX_PACKET_INFO {
+ A_UINT32 ExpectedHdr; /* HTC internal use */
+ A_UINT32 HTCRxFlags; /* HTC internal use */
+ A_UINT32 IndicationFlags; /* indication flags set on each RX packet indication */
+} HTC_RX_PACKET_INFO;
+
+#define HTC_RX_FLAGS_INDICATE_MORE_PKTS (1 << 0) /* more packets on this endpoint are being fetched */
+
+/* wrapper around endpoint-specific packets */
+typedef struct _HTC_PACKET {
+ DL_LIST ListLink; /* double link */
+ void *pPktContext; /* caller's per packet specific context */
+
+ A_UINT8 *pBufferStart; /* the true buffer start , the caller can
+ store the real buffer start here. In
+ receive callbacks, the HTC layer sets pBuffer
+ to the start of the payload past the header. This
+ field allows the caller to reset pBuffer when it
+ recycles receive packets back to HTC */
+ /*
+ * Pointer to the start of the buffer. In the transmit
+ * direction this points to the start of the payload. In the
+ * receive direction, however, the buffer when queued up
+ * points to the start of the HTC header but when returned
+ * to the caller points to the start of the payload
+ */
+ A_UINT8 *pBuffer; /* payload start (RX/TX) */
+ A_UINT32 BufferLength; /* length of buffer */
+ A_UINT32 ActualLength; /* actual length of payload */
+ HTC_ENDPOINT_ID Endpoint; /* endpoint that this packet was sent/recv'd from */
+ A_STATUS Status; /* completion status */
+ union {
+ HTC_TX_PACKET_INFO AsTx; /* Tx Packet specific info */
+ HTC_RX_PACKET_INFO AsRx; /* Rx Packet specific info */
+ } PktInfo;
+
+ /* the following fields are for internal HTC use */
+ HTC_PACKET_COMPLETION Completion; /* completion */
+ void *pContext; /* HTC private completion context */
+} HTC_PACKET;
+
+
+
+#define COMPLETE_HTC_PACKET(p,status) \
+{ \
+ (p)->Status = (status); \
+ (p)->Completion((p)->pContext,(p)); \
+}
+
+#define INIT_HTC_PACKET_INFO(p,b,len) \
+{ \
+ (p)->pBufferStart = (b); \
+ (p)->BufferLength = (len); \
+}
+
+/* macro to set an initial RX packet for refilling HTC */
+#define SET_HTC_PACKET_INFO_RX_REFILL(p,c,b,len,ep) \
+{ \
+ (p)->pPktContext = (c); \
+ (p)->pBuffer = (b); \
+ (p)->pBufferStart = (b); \
+ (p)->BufferLength = (len); \
+ (p)->Endpoint = (ep); \
+}
+
+/* fast macro to recycle an RX packet that will be re-queued to HTC */
+#define HTC_PACKET_RESET_RX(p) \
+ { (p)->pBuffer = (p)->pBufferStart; (p)->ActualLength = 0; }
+
+/* macro to set packet parameters for TX */
+#define SET_HTC_PACKET_INFO_TX(p,c,b,len,ep,tag) \
+{ \
+ (p)->pPktContext = (c); \
+ (p)->pBuffer = (b); \
+ (p)->ActualLength = (len); \
+ (p)->Endpoint = (ep); \
+ (p)->PktInfo.AsTx.Tag = (tag); \
+}
+
+/* HTC Packet Queueing Macros */
+typedef struct _HTC_PACKET_QUEUE {
+ DL_LIST QueueHead;
+ int Depth;
+} HTC_PACKET_QUEUE;
+
+/* initialize queue */
+#define INIT_HTC_PACKET_QUEUE(pQ) \
+{ \
+ DL_LIST_INIT(&(pQ)->QueueHead); \
+ (pQ)->Depth = 0; \
+}
+
+/* enqueue HTC packet to the tail of the queue */
+#define HTC_PACKET_ENQUEUE(pQ,p) \
+{ DL_ListInsertTail(&(pQ)->QueueHead,&(p)->ListLink); \
+ (pQ)->Depth++; \
+}
+
+/* enqueue HTC packet to the tail of the queue */
+#define HTC_PACKET_ENQUEUE_TO_HEAD(pQ,p) \
+{ DL_ListInsertHead(&(pQ)->QueueHead,&(p)->ListLink); \
+ (pQ)->Depth++; \
+}
+/* test if a queue is empty */
+#define HTC_QUEUE_EMPTY(pQ) ((pQ)->Depth == 0)
+/* get packet at head without removing it */
+static INLINE HTC_PACKET *HTC_GET_PKT_AT_HEAD(HTC_PACKET_QUEUE *queue) {
+ if (queue->Depth == 0) {
+ return NULL;
+ }
+ return A_CONTAINING_STRUCT((DL_LIST_GET_ITEM_AT_HEAD(&queue->QueueHead)),HTC_PACKET,ListLink);
+}
+/* remove a packet from a queue, where-ever it is in the queue */
+#define HTC_PACKET_REMOVE(pQ,p) \
+{ \
+ DL_ListRemove(&(p)->ListLink); \
+ (pQ)->Depth--; \
+}
+
+/* dequeue an HTC packet from the head of the queue */
+static INLINE HTC_PACKET *HTC_PACKET_DEQUEUE(HTC_PACKET_QUEUE *queue) {
+ DL_LIST *pItem = DL_ListRemoveItemFromHead(&queue->QueueHead);
+ if (pItem != NULL) {
+ queue->Depth--;
+ return A_CONTAINING_STRUCT(pItem, HTC_PACKET, ListLink);
+ }
+ return NULL;
+}
+
+/* dequeue an HTC packet from the tail of the queue */
+static INLINE HTC_PACKET *HTC_PACKET_DEQUEUE_TAIL(HTC_PACKET_QUEUE *queue) {
+ DL_LIST *pItem = DL_ListRemoveItemFromTail(&queue->QueueHead);
+ if (pItem != NULL) {
+ queue->Depth--;
+ return A_CONTAINING_STRUCT(pItem, HTC_PACKET, ListLink);
+ }
+ return NULL;
+}
+
+#define HTC_PACKET_QUEUE_DEPTH(pQ) (pQ)->Depth
+
+
+#define HTC_GET_ENDPOINT_FROM_PKT(p) (p)->Endpoint
+#define HTC_GET_TAG_FROM_PKT(p) (p)->PktInfo.AsTx.Tag
+
+ /* transfer the packets from one queue to the tail of another queue */
+#define HTC_PACKET_QUEUE_TRANSFER_TO_TAIL(pQDest,pQSrc) \
+{ \
+ DL_ListTransferItemsToTail(&(pQDest)->QueueHead,&(pQSrc)->QueueHead); \
+ (pQDest)->Depth += (pQSrc)->Depth; \
+ (pQSrc)->Depth = 0; \
+}
+
+ /* fast version to init and add a single packet to a queue */
+#define INIT_HTC_PACKET_QUEUE_AND_ADD(pQ,pP) \
+{ \
+ DL_LIST_INIT_AND_ADD(&(pQ)->QueueHead,&(pP)->ListLink) \
+ (pQ)->Depth = 1; \
+}
+
+#define HTC_PACKET_QUEUE_ITERATE_ALLOW_REMOVE(pQ, pPTemp) \
+ ITERATE_OVER_LIST_ALLOW_REMOVE(&(pQ)->QueueHead,(pPTemp), HTC_PACKET, ListLink)
+
+#define HTC_PACKET_QUEUE_ITERATE_END ITERATE_END
+
+#endif /*HTC_PACKET_H_*/
diff --git a/host/include/htc_services.h b/host/include/htc_services.h
new file mode 100644
index 0000000..bba022f
--- /dev/null
+++ b/host/include/htc_services.h
@@ -0,0 +1,52 @@
+//------------------------------------------------------------------------------
+// <copyright file="htc_services.h" company="Atheros">
+// Copyright (c) 2007 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __HTC_SERVICES_H__
+#define __HTC_SERVICES_H__
+
+/* Current service IDs */
+
+typedef enum {
+ RSVD_SERVICE_GROUP = 0,
+ WMI_SERVICE_GROUP = 1,
+
+ HTC_TEST_GROUP = 254,
+ HTC_SERVICE_GROUP_LAST = 255
+}HTC_SERVICE_GROUP_IDS;
+
+#define MAKE_SERVICE_ID(group,index) \
+ (int)(((int)group << 8) | (int)(index))
+
+/* NOTE: service ID of 0x0000 is reserved and should never be used */
+#define HTC_CTRL_RSVD_SVC MAKE_SERVICE_ID(RSVD_SERVICE_GROUP,1)
+#define WMI_CONTROL_SVC MAKE_SERVICE_ID(WMI_SERVICE_GROUP,0)
+#define WMI_DATA_BE_SVC MAKE_SERVICE_ID(WMI_SERVICE_GROUP,1)
+#define WMI_DATA_BK_SVC MAKE_SERVICE_ID(WMI_SERVICE_GROUP,2)
+#define WMI_DATA_VI_SVC MAKE_SERVICE_ID(WMI_SERVICE_GROUP,3)
+#define WMI_DATA_VO_SVC MAKE_SERVICE_ID(WMI_SERVICE_GROUP,4)
+#define WMI_MAX_SERVICES 5
+
+/* raw stream service (i.e. flash, tcmd, calibration apps) */
+#define HTC_RAW_STREAMS_SVC MAKE_SERVICE_ID(HTC_TEST_GROUP,0)
+
+#endif /*HTC_SERVICES_H_*/
diff --git a/host/include/ieee80211.h b/host/include/ieee80211.h
new file mode 100644
index 0000000..c4fd13f
--- /dev/null
+++ b/host/include/ieee80211.h
@@ -0,0 +1,401 @@
+//------------------------------------------------------------------------------
+// <copyright file="ieee80211.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _NET80211_IEEE80211_H_
+#define _NET80211_IEEE80211_H_
+
+#include "athstartpack.h"
+
+/*
+ * 802.11 protocol definitions.
+ */
+#define IEEE80211_WEP_KEYLEN 5 /* 40bit */
+#define IEEE80211_WEP_IVLEN 3 /* 24bit */
+#define IEEE80211_WEP_KIDLEN 1 /* 1 octet */
+#define IEEE80211_WEP_CRCLEN 4 /* CRC-32 */
+#define IEEE80211_WEP_NKID 4 /* number of key ids */
+
+/*
+ * 802.11i defines an extended IV for use with non-WEP ciphers.
+ * When the EXTIV bit is set in the key id byte an additional
+ * 4 bytes immediately follow the IV for TKIP. For CCMP the
+ * EXTIV bit is likewise set but the 8 bytes represent the
+ * CCMP header rather than IV+extended-IV.
+ */
+#define IEEE80211_WEP_EXTIV 0x20
+#define IEEE80211_WEP_EXTIVLEN 4 /* extended IV length */
+#define IEEE80211_WEP_MICLEN 8 /* trailing MIC */
+
+#define IEEE80211_CRC_LEN 4
+
+#ifdef WAPI_ENABLE
+#define IEEE80211_WAPI_EXTIVLEN 10 /* extended IV length */
+#endif /* WAPI ENABLE */
+
+
+#define IEEE80211_ADDR_LEN 6 /* size of 802.11 address */
+/* is 802.11 address multicast/broadcast? */
+#define IEEE80211_IS_MULTICAST(_a) (*(_a) & 0x01)
+#define IEEE80211_IS_BROADCAST(_a) (*(_a) == 0xFF)
+#define WEP_HEADER (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN)
+#define WEP_TRAILER IEEE80211_WEP_CRCLEN
+#define CCMP_HEADER (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN + \
+ IEEE80211_WEP_EXTIVLEN)
+#define CCMP_TRAILER IEEE80211_WEP_MICLEN
+#define TKIP_HEADER (IEEE80211_WEP_IVLEN + IEEE80211_WEP_KIDLEN + \
+ IEEE80211_WEP_EXTIVLEN)
+#define TKIP_TRAILER IEEE80211_WEP_CRCLEN
+#define TKIP_MICLEN IEEE80211_WEP_MICLEN
+
+
+#define IEEE80211_ADDR_EQ(addr1, addr2) \
+ (A_MEMCMP(addr1, addr2, IEEE80211_ADDR_LEN) == 0)
+
+#define IEEE80211_ADDR_COPY(dst,src) A_MEMCPY(dst,src,IEEE80211_ADDR_LEN)
+
+#define IEEE80211_KEYBUF_SIZE 16
+#define IEEE80211_MICBUF_SIZE (8+8) /* space for both tx and rx */
+
+/*
+ * NB: these values are ordered carefully; there are lots of
+ * of implications in any reordering. In particular beware
+ * that 4 is not used to avoid conflicting with IEEE80211_F_PRIVACY.
+ */
+#define IEEE80211_CIPHER_WEP 0
+#define IEEE80211_CIPHER_TKIP 1
+#define IEEE80211_CIPHER_AES_OCB 2
+#define IEEE80211_CIPHER_AES_CCM 3
+#define IEEE80211_CIPHER_CKIP 5
+#define IEEE80211_CIPHER_CCKM_KRK 6
+#define IEEE80211_CIPHER_NONE 7 /* pseudo value */
+
+#define IEEE80211_CIPHER_MAX (IEEE80211_CIPHER_NONE+1)
+
+#define IEEE80211_IS_VALID_WEP_CIPHER_LEN(len) \
+ (((len) == 5) || ((len) == 13) || ((len) == 16))
+
+
+
+/*
+ * generic definitions for IEEE 802.11 frames
+ */
+PREPACK struct ieee80211_frame {
+ A_UINT8 i_fc[2];
+ A_UINT8 i_dur[2];
+ A_UINT8 i_addr1[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr2[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr3[IEEE80211_ADDR_LEN];
+ A_UINT8 i_seq[2];
+ /* possibly followed by addr4[IEEE80211_ADDR_LEN]; */
+ /* see below */
+} POSTPACK;
+
+PREPACK struct ieee80211_qosframe {
+ A_UINT8 i_fc[2];
+ A_UINT8 i_dur[2];
+ A_UINT8 i_addr1[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr2[IEEE80211_ADDR_LEN];
+ A_UINT8 i_addr3[IEEE80211_ADDR_LEN];
+ A_UINT8 i_seq[2];
+ A_UINT8 i_qos[2];
+} POSTPACK;
+
+#define IEEE80211_FC0_VERSION_MASK 0x03
+#define IEEE80211_FC0_VERSION_SHIFT 0
+#define IEEE80211_FC0_VERSION_0 0x00
+#define IEEE80211_FC0_TYPE_MASK 0x0c
+#define IEEE80211_FC0_TYPE_SHIFT 2
+#define IEEE80211_FC0_TYPE_MGT 0x00
+#define IEEE80211_FC0_TYPE_CTL 0x04
+#define IEEE80211_FC0_TYPE_DATA 0x08
+
+#define IEEE80211_FC0_SUBTYPE_MASK 0xf0
+#define IEEE80211_FC0_SUBTYPE_SHIFT 4
+/* for TYPE_MGT */
+#define IEEE80211_FC0_SUBTYPE_ASSOC_REQ 0x00
+#define IEEE80211_FC0_SUBTYPE_ASSOC_RESP 0x10
+#define IEEE80211_FC0_SUBTYPE_REASSOC_REQ 0x20
+#define IEEE80211_FC0_SUBTYPE_REASSOC_RESP 0x30
+#define IEEE80211_FC0_SUBTYPE_PROBE_REQ 0x40
+#define IEEE80211_FC0_SUBTYPE_PROBE_RESP 0x50
+#define IEEE80211_FC0_SUBTYPE_BEACON 0x80
+#define IEEE80211_FC0_SUBTYPE_ATIM 0x90
+#define IEEE80211_FC0_SUBTYPE_DISASSOC 0xa0
+#define IEEE80211_FC0_SUBTYPE_AUTH 0xb0
+#define IEEE80211_FC0_SUBTYPE_DEAUTH 0xc0
+/* for TYPE_CTL */
+#define IEEE80211_FC0_SUBTYPE_PS_POLL 0xa0
+#define IEEE80211_FC0_SUBTYPE_RTS 0xb0
+#define IEEE80211_FC0_SUBTYPE_CTS 0xc0
+#define IEEE80211_FC0_SUBTYPE_ACK 0xd0
+#define IEEE80211_FC0_SUBTYPE_CF_END 0xe0
+#define IEEE80211_FC0_SUBTYPE_CF_END_ACK 0xf0
+/* for TYPE_DATA (bit combination) */
+#define IEEE80211_FC0_SUBTYPE_DATA 0x00
+#define IEEE80211_FC0_SUBTYPE_CF_ACK 0x10
+#define IEEE80211_FC0_SUBTYPE_CF_POLL 0x20
+#define IEEE80211_FC0_SUBTYPE_CF_ACPL 0x30
+#define IEEE80211_FC0_SUBTYPE_NODATA 0x40
+#define IEEE80211_FC0_SUBTYPE_CFACK 0x50
+#define IEEE80211_FC0_SUBTYPE_CFPOLL 0x60
+#define IEEE80211_FC0_SUBTYPE_CF_ACK_CF_ACK 0x70
+#define IEEE80211_FC0_SUBTYPE_QOS 0x80
+#define IEEE80211_FC0_SUBTYPE_QOS_NULL 0xc0
+
+#define IEEE80211_FC1_DIR_MASK 0x03
+#define IEEE80211_FC1_DIR_NODS 0x00 /* STA->STA */
+#define IEEE80211_FC1_DIR_TODS 0x01 /* STA->AP */
+#define IEEE80211_FC1_DIR_FROMDS 0x02 /* AP ->STA */
+#define IEEE80211_FC1_DIR_DSTODS 0x03 /* AP ->AP */
+
+#define IEEE80211_FC1_MORE_FRAG 0x04
+#define IEEE80211_FC1_RETRY 0x08
+#define IEEE80211_FC1_PWR_MGT 0x10
+#define IEEE80211_FC1_MORE_DATA 0x20
+#define IEEE80211_FC1_WEP 0x40
+#define IEEE80211_FC1_ORDER 0x80
+
+#define IEEE80211_SEQ_FRAG_MASK 0x000f
+#define IEEE80211_SEQ_FRAG_SHIFT 0
+#define IEEE80211_SEQ_SEQ_MASK 0xfff0
+#define IEEE80211_SEQ_SEQ_SHIFT 4
+
+#define IEEE80211_NWID_LEN 32
+
+/*
+ * 802.11 rate set.
+ */
+#define IEEE80211_RATE_SIZE 8 /* 802.11 standard */
+#define IEEE80211_RATE_MAXSIZE 15 /* max rates we'll handle */
+
+#define WMM_NUM_AC 4 /* 4 AC categories */
+
+#define WMM_PARAM_ACI_M 0x60 /* Mask for ACI field */
+#define WMM_PARAM_ACI_S 5 /* Shift for ACI field */
+#define WMM_PARAM_ACM_M 0x10 /* Mask for ACM bit */
+#define WMM_PARAM_ACM_S 4 /* Shift for ACM bit */
+#define WMM_PARAM_AIFSN_M 0x0f /* Mask for aifsn field */
+#define WMM_PARAM_LOGCWMIN_M 0x0f /* Mask for CwMin field (in log) */
+#define WMM_PARAM_LOGCWMAX_M 0xf0 /* Mask for CwMax field (in log) */
+#define WMM_PARAM_LOGCWMAX_S 4 /* Shift for CwMax field */
+
+#define WMM_AC_TO_TID(_ac) ( \
+ ((_ac) == WMM_AC_VO) ? 6 : \
+ ((_ac) == WMM_AC_VI) ? 5 : \
+ ((_ac) == WMM_AC_BK) ? 1 : \
+ 0)
+
+#define TID_TO_WMM_AC(_tid) ( \
+ ((_tid) < 1) ? WMM_AC_BE : \
+ ((_tid) < 3) ? WMM_AC_BK : \
+ ((_tid) < 6) ? WMM_AC_VI : \
+ WMM_AC_VO)
+/*
+ * Management information element payloads.
+ */
+
+enum {
+ IEEE80211_ELEMID_SSID = 0,
+ IEEE80211_ELEMID_RATES = 1,
+ IEEE80211_ELEMID_FHPARMS = 2,
+ IEEE80211_ELEMID_DSPARMS = 3,
+ IEEE80211_ELEMID_CFPARMS = 4,
+ IEEE80211_ELEMID_TIM = 5,
+ IEEE80211_ELEMID_IBSSPARMS = 6,
+ IEEE80211_ELEMID_COUNTRY = 7,
+ IEEE80211_ELEMID_CHALLENGE = 16,
+ /* 17-31 reserved for challenge text extension */
+ IEEE80211_ELEMID_PWRCNSTR = 32,
+ IEEE80211_ELEMID_PWRCAP = 33,
+ IEEE80211_ELEMID_TPCREQ = 34,
+ IEEE80211_ELEMID_TPCREP = 35,
+ IEEE80211_ELEMID_SUPPCHAN = 36,
+ IEEE80211_ELEMID_CHANSWITCH = 37,
+ IEEE80211_ELEMID_MEASREQ = 38,
+ IEEE80211_ELEMID_MEASREP = 39,
+ IEEE80211_ELEMID_QUIET = 40,
+ IEEE80211_ELEMID_IBSSDFS = 41,
+ IEEE80211_ELEMID_ERP = 42,
+ IEEE80211_ELEMID_HTCAP_ANA = 45, /* Address ANA, and non-ANA story, for interop. CL#171733 */
+ IEEE80211_ELEMID_RSN = 48,
+ IEEE80211_ELEMID_XRATES = 50,
+ IEEE80211_ELEMID_HTINFO_ANA = 61,
+#ifdef WAPI_ENABLE
+ IEEE80211_ELEMID_WAPI = 68,
+#endif
+ IEEE80211_ELEMID_TPC = 150,
+ IEEE80211_ELEMID_CCKM = 156,
+ IEEE80211_ELEMID_VENDOR = 221, /* vendor private */
+};
+
+#define ATH_OUI 0x7f0300 /* Atheros OUI */
+#define ATH_OUI_TYPE 0x01
+#define ATH_OUI_SUBTYPE 0x01
+#define ATH_OUI_VERSION 0x00
+
+#define WPA_OUI 0xf25000
+#define WPA_OUI_TYPE 0x01
+#define WPA_VERSION 1 /* current supported version */
+
+#define WPA_CSE_NULL 0x00
+#define WPA_CSE_WEP40 0x01
+#define WPA_CSE_TKIP 0x02
+#define WPA_CSE_CCMP 0x04
+#define WPA_CSE_WEP104 0x05
+
+#define WPA_ASE_NONE 0x00
+#define WPA_ASE_8021X_UNSPEC 0x01
+#define WPA_ASE_8021X_PSK 0x02
+
+#define RSN_OUI 0xac0f00
+#define RSN_VERSION 1 /* current supported version */
+
+#define RSN_CSE_NULL 0x00
+#define RSN_CSE_WEP40 0x01
+#define RSN_CSE_TKIP 0x02
+#define RSN_CSE_WRAP 0x03
+#define RSN_CSE_CCMP 0x04
+#define RSN_CSE_WEP104 0x05
+
+#define RSN_ASE_NONE 0x00
+#define RSN_ASE_8021X_UNSPEC 0x01
+#define RSN_ASE_8021X_PSK 0x02
+
+#define RSN_CAP_PREAUTH 0x01
+
+#define WMM_OUI 0xf25000
+#define WMM_OUI_TYPE 0x02
+#define WMM_INFO_OUI_SUBTYPE 0x00
+#define WMM_PARAM_OUI_SUBTYPE 0x01
+#define WMM_VERSION 1
+
+/* WMM stream classes */
+#define WMM_NUM_AC 4
+#define WMM_AC_BE 0 /* best effort */
+#define WMM_AC_BK 1 /* background */
+#define WMM_AC_VI 2 /* video */
+#define WMM_AC_VO 3 /* voice */
+
+/* TSPEC related */
+#define ACTION_CATEGORY_CODE_TSPEC 17
+#define ACTION_CODE_TSPEC_ADDTS 0
+#define ACTION_CODE_TSPEC_ADDTS_RESP 1
+#define ACTION_CODE_TSPEC_DELTS 2
+
+typedef enum {
+ TSPEC_STATUS_CODE_ADMISSION_ACCEPTED = 0,
+ TSPEC_STATUS_CODE_ADDTS_INVALID_PARAMS = 0x1,
+ TSPEC_STATUS_CODE_ADDTS_REQUEST_REFUSED = 0x3,
+ TSPEC_STATUS_CODE_UNSPECIFIED_QOS_RELATED_FAILURE = 0xC8,
+ TSPEC_STATUS_CODE_REQUESTED_REFUSED_POLICY_CONFIGURATION = 0xC9,
+ TSPEC_STATUS_CODE_INSUFFCIENT_BANDWIDTH = 0xCA,
+ TSPEC_STATUS_CODE_INVALID_PARAMS = 0xCB,
+ TSPEC_STATUS_CODE_DELTS_SENT = 0x30,
+ TSPEC_STATUS_CODE_DELTS_RECV = 0x31,
+} TSPEC_STATUS_CODE;
+
+#define TSPEC_TSID_MASK 0xF
+#define TSPEC_TSID_S 1
+
+/*
+ * WMM/802.11e Tspec Element
+ */
+typedef PREPACK struct wmm_tspec_ie_t {
+ A_UINT8 elementId;
+ A_UINT8 len;
+ A_UINT8 oui[3];
+ A_UINT8 ouiType;
+ A_UINT8 ouiSubType;
+ A_UINT8 version;
+ A_UINT16 tsInfo_info;
+ A_UINT8 tsInfo_reserved;
+ A_UINT16 nominalMSDU;
+ A_UINT16 maxMSDU;
+ A_UINT32 minServiceInt;
+ A_UINT32 maxServiceInt;
+ A_UINT32 inactivityInt;
+ A_UINT32 suspensionInt;
+ A_UINT32 serviceStartTime;
+ A_UINT32 minDataRate;
+ A_UINT32 meanDataRate;
+ A_UINT32 peakDataRate;
+ A_UINT32 maxBurstSize;
+ A_UINT32 delayBound;
+ A_UINT32 minPhyRate;
+ A_UINT16 sba;
+ A_UINT16 mediumTime;
+} POSTPACK WMM_TSPEC_IE;
+
+
+/*
+ * BEACON management packets
+ *
+ * octet timestamp[8]
+ * octet beacon interval[2]
+ * octet capability information[2]
+ * information element
+ * octet elemid
+ * octet length
+ * octet information[length]
+ */
+
+#define IEEE80211_BEACON_INTERVAL(beacon) \
+ ((beacon)[8] | ((beacon)[9] << 8))
+#define IEEE80211_BEACON_CAPABILITY(beacon) \
+ ((beacon)[10] | ((beacon)[11] << 8))
+
+#define IEEE80211_CAPINFO_ESS 0x0001
+#define IEEE80211_CAPINFO_IBSS 0x0002
+#define IEEE80211_CAPINFO_CF_POLLABLE 0x0004
+#define IEEE80211_CAPINFO_CF_POLLREQ 0x0008
+#define IEEE80211_CAPINFO_PRIVACY 0x0010
+#define IEEE80211_CAPINFO_SHORT_PREAMBLE 0x0020
+#define IEEE80211_CAPINFO_PBCC 0x0040
+#define IEEE80211_CAPINFO_CHNL_AGILITY 0x0080
+/* bits 8-9 are reserved */
+#define IEEE80211_CAPINFO_SHORT_SLOTTIME 0x0400
+#define IEEE80211_CAPINFO_APSD 0x0800
+/* bit 12 is reserved */
+#define IEEE80211_CAPINFO_DSSSOFDM 0x2000
+/* bits 14-15 are reserved */
+
+/*
+ * Authentication Modes
+ */
+
+enum ieee80211_authmode {
+ IEEE80211_AUTH_NONE = 0,
+ IEEE80211_AUTH_OPEN = 1,
+ IEEE80211_AUTH_SHARED = 2,
+ IEEE80211_AUTH_8021X = 3,
+ IEEE80211_AUTH_AUTO = 4, /* auto-select/accept */
+ /* NB: these are used only for ioctls */
+ IEEE80211_AUTH_WPA = 5, /* WPA/RSN w/ 802.1x */
+ IEEE80211_AUTH_WPA_PSK = 6, /* WPA/RSN w/ PSK */
+ IEEE80211_AUTH_WPA_CCKM = 7, /* WPA/RSN IE w/ CCKM */
+};
+
+#define IEEE80211_PS_MAX_QUEUE 50 /*Maximum no of buffers that can be queues for PS*/
+
+#include "athendpack.h"
+
+#endif /* _NET80211_IEEE80211_H_ */
diff --git a/host/include/ieee80211_node.h b/host/include/ieee80211_node.h
new file mode 100644
index 0000000..b3808c2
--- /dev/null
+++ b/host/include/ieee80211_node.h
@@ -0,0 +1,92 @@
+//------------------------------------------------------------------------------
+// <copyright file="ieee80211_node.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _IEEE80211_NODE_H_
+#define _IEEE80211_NODE_H_
+
+/*
+ * Node locking definitions.
+ */
+#define IEEE80211_NODE_LOCK_INIT(_nt) A_MUTEX_INIT(&(_nt)->nt_nodelock)
+#define IEEE80211_SCAN_REPORT_LOCK_INIT(_nt) A_MUTEX_INIT(&(_nt)->nt_scanReportLock)
+
+#define IEEE80211_NODE_LOCK_DESTROY(_nt) if (A_IS_MUTEX_VALID(&(_nt)->nt_nodelock)) { \
+ A_MUTEX_DELETE(&(_nt)->nt_nodelock); }
+#define IEEE80211_SCAN_REPORT_LOCK_DESTROY(_nt) if (A_IS_MUTEX_VALID(&(_nt)->nt_scanReportLock)) { \
+ A_MUTEX_DELETE(&(_nt)->nt_scanReportLock); }
+
+#define IEEE80211_NODE_LOCK(_nt) A_MUTEX_LOCK(&(_nt)->nt_nodelock)
+#define IEEE80211_NODE_UNLOCK(_nt) A_MUTEX_UNLOCK(&(_nt)->nt_nodelock)
+#define IEEE80211_SCAN_REPORT_LOCK(_nt) A_MUTEX_LOCK(&(_nt)->nt_scanReportLock)
+#define IEEE80211_SCAN_REPORT_UNLOCK(_nt) A_MUTEX_UNLOCK(&(_nt)->nt_scanReportLock)
+
+#define IEEE80211_NODE_LOCK_BH(_nt) A_MUTEX_LOCK(&(_nt)->nt_nodelock)
+#define IEEE80211_NODE_UNLOCK_BH(_nt) A_MUTEX_UNLOCK(&(_nt)->nt_nodelock)
+#define IEEE80211_NODE_LOCK_ASSERT(_nt)
+
+/*
+ * Node reference counting definitions.
+ *
+ * ieee80211_node_initref initialize the reference count to 1
+ * ieee80211_node_incref add a reference
+ * ieee80211_node_decref remove a reference
+ * ieee80211_node_dectestref remove a reference and return 1 if this
+ * is the last reference, otherwise 0
+ * ieee80211_node_refcnt reference count for printing (only)
+ */
+#define ieee80211_node_initref(_ni) ((_ni)->ni_refcnt = 1)
+#define ieee80211_node_incref(_ni) ((_ni)->ni_refcnt++)
+#define ieee80211_node_decref(_ni) ((_ni)->ni_refcnt--)
+#define ieee80211_node_dectestref(_ni) (((_ni)->ni_refcnt--) == 1)
+#define ieee80211_node_refcnt(_ni) ((_ni)->ni_refcnt)
+
+#define IEEE80211_NODE_HASHSIZE 32
+/* simple hash is enough for variation of macaddr */
+#define IEEE80211_NODE_HASH(addr) \
+ (((const A_UINT8 *)(addr))[IEEE80211_ADDR_LEN - 1] % \
+ IEEE80211_NODE_HASHSIZE)
+
+/*
+ * Table of ieee80211_node instances. Each ieee80211com
+ * has at least one for holding the scan candidates.
+ * When operating as an access point or in ibss mode there
+ * is a second table for associated stations or neighbors.
+ */
+struct ieee80211_node_table {
+ void *nt_wmip; /* back reference */
+ A_MUTEX_T nt_nodelock; /* on node table */
+ struct bss *nt_node_first; /* information of all nodes */
+ struct bss *nt_node_last; /* information of all nodes */
+ struct bss *nt_hash[IEEE80211_NODE_HASHSIZE];
+ const char *nt_name; /* for debugging */
+ A_UINT32 nt_scangen; /* gen# for timeout scan */
+ A_UINT32 nt_nodeAge; /* node aging time */
+#ifdef OS_ROAM_MANAGEMENT
+ A_UINT32 nt_si_gen; /* gen# for scan indication*/
+#endif
+ A_MUTEX_T nt_scanReportLock; /* to synchronize between scan ioctl and bssinfo event */
+};
+
+#define WLAN_NODE_INACT_TIMEOUT_MSEC 120000
+#define WLAN_NODE_INACT_CNT 4
+
+#endif /* _IEEE80211_NODE_H_ */
diff --git a/host/include/ini_dset.h b/host/include/ini_dset.h
new file mode 100644
index 0000000..3d80da7
--- /dev/null
+++ b/host/include/ini_dset.h
@@ -0,0 +1,83 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _INI_DSET_H_
+#define _INI_DSET_H_
+
+/*
+ * Each of these represents a WHAL INI table, which consists
+ * of an "address column" followed by 1 or more "value columns".
+ *
+ * Software uses the base WHAL_INI_DATA_ID+column to access a
+ * DataSet that holds a particular column of data.
+ */
+typedef enum {
+#if defined(AR6002_REV4) || defined(AR6003) || defined(AR6002_REV6)
+/* Add these definitions for compatability */
+#define WHAL_INI_DATA_ID_BB_RFGAIN_LNA1 WHAL_INI_DATA_ID_BB_RFGAIN
+#define WHAL_INI_DATA_ID_BB_RFGAIN_LNA2 WHAL_INI_DATA_ID_BB_RFGAIN
+ WHAL_INI_DATA_ID_NULL =0,
+ WHAL_INI_DATA_ID_MODE_SPECIFIC =1, /* 2,3,4,5 */
+ WHAL_INI_DATA_ID_COMMON =6, /* 7 */
+ WHAL_INI_DATA_ID_BB_RFGAIN =8, /* 9,10 */
+#ifdef FPGA
+ WHAL_INI_DATA_ID_ANALOG_BANK0 =11, /* 12 */
+ WHAL_INI_DATA_ID_ANALOG_BANK1 =13, /* 14 */
+ WHAL_INI_DATA_ID_ANALOG_BANK2 =15, /* 16 */
+ WHAL_INI_DATA_ID_ANALOG_BANK3 =17, /* 18, 19 */
+ WHAL_INI_DATA_ID_ANALOG_BANK6 =20, /* 21,22 */
+ WHAL_INI_DATA_ID_ANALOG_BANK7 =23, /* 24 */
+ WHAL_INI_DATA_ID_ADDAC =25, /* 26 */
+#else
+ WHAL_INI_DATA_ID_ANALOG_COMMON =11, /* 12 */
+ WHAL_INI_DATA_ID_ANALOG_MODE_SPECIFIC=13, /* 14,15 */
+ WHAL_INI_DATA_ID_ANALOG_BANK6 =16, /* 17,18 */
+ WHAL_INI_DATA_ID_MODE_OVERRIDES =19, /* 20,21,22,23 */
+ WHAL_INI_DATA_ID_COMMON_OVERRIDES =24, /* 25 */
+ WHAL_INI_DATA_ID_ANALOG_OVERRIDES =26, /* 27,28 */
+#endif /* FPGA */
+#else
+ WHAL_INI_DATA_ID_NULL =0,
+ WHAL_INI_DATA_ID_MODE_SPECIFIC =1, /* 2,3 */
+ WHAL_INI_DATA_ID_COMMON =4, /* 5 */
+ WHAL_INI_DATA_ID_BB_RFGAIN =6, /* 7,8 */
+#define WHAL_INI_DATA_ID_BB_RFGAIN_LNA1 WHAL_INI_DATA_ID_BB_RFGAIN
+ WHAL_INI_DATA_ID_ANALOG_BANK1 =9, /* 10 */
+ WHAL_INI_DATA_ID_ANALOG_BANK2 =11, /* 12 */
+ WHAL_INI_DATA_ID_ANALOG_BANK3 =13, /* 14, 15 */
+ WHAL_INI_DATA_ID_ANALOG_BANK6 =16, /* 17, 18 */
+ WHAL_INI_DATA_ID_ANALOG_BANK7 =19, /* 20 */
+ WHAL_INI_DATA_ID_MODE_OVERRIDES =21, /* 22,23 */
+ WHAL_INI_DATA_ID_COMMON_OVERRIDES =24, /* 25 */
+ WHAL_INI_DATA_ID_ANALOG_OVERRIDES =26, /* 27,28 */
+ WHAL_INI_DATA_ID_BB_RFGAIN_LNA2 =29, /* 30,31 */
+#endif
+ WHAL_INI_DATA_ID_MAX =31
+} WHAL_INI_DATA_ID;
+
+typedef PREPACK struct {
+ A_UINT16 freqIndex; // 1 - A mode 2 - B or G mode 0 - common
+ A_UINT16 offset;
+ A_UINT32 newValue;
+} POSTPACK INI_DSET_REG_OVERRIDE;
+
+#endif
diff --git a/host/include/iot_flashotp.h b/host/include/iot_flashotp.h
new file mode 100644
index 0000000..67c24fc
--- /dev/null
+++ b/host/include/iot_flashotp.h
@@ -0,0 +1,55 @@
+#ifndef _IOT_FLASHOTP_H_
+#define _IOT_FLASHOTP_H_
+/******************************************/
+/* firmware input param value definitions */
+/******************************************/
+/* IOTFLASHOTP_PARAM_SKIP_OTP - instructs firmware to skip OTP operations */
+#define IOTFLASHOTP_PARAM_SKIP_OTP (0x00000001)
+/* IOTFLASHOTP_PARAM_SKIP_FLASH - instructs firmware to skip Flash operations */
+#define IOTFLASHOTP_PARAM_SKIP_FLASH (0x00000002)
+/* IOTFLASHOTP_PARAM_USE_NVRAM_CONFIG_FROM_OTP - instructs firmware to use NVRAM config found in OTP
+ * to access flash. */
+#define IOTFLASHOTP_PARAM_USE_NVRAM_CONFIG_FROM_OTP (0x00000004)
+/*************************************/
+/* firmware return value definitions */
+/*************************************/
+#define IOTFLASHOTP_RESULT_OTP_SUCCESS (0x00000001)
+#define IOTFLASHOTP_RESULT_OTP_FAILED (0x00000002)
+#define IOTFLASHOTP_RESULT_OTP_NOT_WRITTEN (0x00000004)
+#define IOTFLASHOTP_RESULT_OTP_SKIPPED (0x00000008)
+#define IOTFLASHOTP_RESULT_OTP_POS_MASK (0x0000000f)
+#define IOTFLASHOTP_RESULT_OTP_POS_SHIFT (8)
+#define IOTFLASHOTP_RESULT_OTP_MASK (0x0000ffff)
+
+#define IOTFLASHOTP_RESULT_FLASH_SUCCESS (0x00010000)
+#define IOTFLASHOTP_RESULT_FLASH_FAILED (0x00020000)
+#define IOTFLASHOTP_RESULT_FLASH_VALIDATE_FAILED (0x00040000)
+#define IOTFLASHOTP_RESULT_FLASH_SKIPPED (0x00080000)
+#define IOTFLASHOTP_RESULT_FLASH_MASK (0xffff0000)
+
+
+#if !defined(AR6002_REV4)
+typedef unsigned long A_UINT32;
+#endif
+
+typedef struct{
+ A_UINT32 length; // length of binary in bytes
+ A_UINT32 loadAddr; // address to which the image should be loaded
+ A_UINT32 execAddr; // address from which execution should start
+ A_UINT32 MACOffset; // offset in image of MAC address location.
+ A_UINT32 ChksumOffset; // offset of checksum location <0 implies no checksum>
+ A_UINT32 ChksumStart; // offset in image for start of checksum calculation
+ A_UINT32 ChksumEnd; // offset in image for end of checksum calculation
+ A_UINT32 partitionTableOffset; // offset in image for start of 3 word partition table
+ A_UINT32 flashDescOffset; // offset in image for the start of the flash descriptor file
+}CONFIG_HEADER;
+
+typedef struct{
+ A_UINT32 capacity; // size of flash chip in bytes
+ A_UINT32 blocksize; // size of a block needed for nvram block erase command
+ A_UINT32 sectorsize; // size of sector needed for nvram sector erase command
+ A_UINT32 pagesize; // size of page needed for nvram write command
+}FLASH_DESCRIPTOR;
+
+
+#endif /* _IOT_FLASHOTP_H_ */
diff --git a/host/include/p2p.h b/host/include/p2p.h
new file mode 100644
index 0000000..48764d6
--- /dev/null
+++ b/host/include/p2p.h
@@ -0,0 +1,430 @@
+//------------------------------------------------------------------------------
+// <copyright file="p2p.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file has the shared declarations between the host & target P2P modules.
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _P2P_H_
+#define _P2P_H_
+
+#define WPS_NONCE_LEN 16
+#define WPS_DEV_TYPE_LEN 8
+#define WPS_AUTHENTICATOR_LEN 8
+#define WPS_HASH_LEN 32
+#define WPS_SECRET_NONCE_LEN 16
+#define WPS_KWA_LEN 8
+#define WPS_MAX_PIN_LEN 8
+#define P2P_MAX_SSID_LEN 32
+
+#define WPS_DEV_OUI_WFA 0x0050f204
+#define P2P_IE_VENDOR_TYPE 0x506f9a09
+
+#define WLAN_EID_VENDOR_SPECIFIC 221
+
+#define P2P_DEV_CAPAB_SERVICE_DISCOVERY BIT(0)
+
+/* Config Methods */
+#define WPS_CONFIG_USBA 0x0001
+#define WPS_CONFIG_ETHERNET 0x0002
+#define WPS_CONFIG_LABEL 0x0004
+#define WPS_CONFIG_DISPLAY 0x0008
+#define WPS_CONFIG_EXT_NFC_TOKEN 0x0010
+#define WPS_CONFIG_INT_NFC_TOKEN 0x0020
+#define WPS_CONFIG_NFC_INTERFACE 0x0040
+#define WPS_CONFIG_PUSHBUTTON 0x0080
+#define WPS_CONFIG_KEYPAD 0x0100
+
+/* Attribute Types */
+enum wps_attribute {
+ ATTR_AP_CHANNEL = 0x1001,
+ ATTR_ASSOC_STATE = 0x1002,
+ ATTR_AUTH_TYPE = 0x1003,
+ ATTR_AUTH_TYPE_FLAGS = 0x1004,
+ ATTR_AUTHENTICATOR = 0x1005,
+ ATTR_CONFIG_METHODS = 0x1008,
+ ATTR_CONFIG_ERROR = 0x1009,
+ ATTR_CONFIRM_URL4 = 0x100a,
+ ATTR_CONFIRM_URL6 = 0x100b,
+ ATTR_CONN_TYPE = 0x100c,
+ ATTR_CONN_TYPE_FLAGS = 0x100d,
+ ATTR_CRED = 0x100e,
+ ATTR_ENCR_TYPE = 0x100f,
+ ATTR_ENCR_TYPE_FLAGS = 0x1010,
+ ATTR_DEV_NAME = 0x1011,
+ ATTR_DEV_PASSWORD_ID = 0x1012,
+ ATTR_E_HASH1 = 0x1014,
+ ATTR_E_HASH2 = 0x1015,
+ ATTR_E_SNONCE1 = 0x1016,
+ ATTR_E_SNONCE2 = 0x1017,
+ ATTR_ENCR_SETTINGS = 0x1018,
+ ATTR_ENROLLEE_NONCE = 0x101a,
+ ATTR_FEATURE_ID = 0x101b,
+ ATTR_IDENTITY = 0x101c,
+ ATTR_IDENTITY_PROOF = 0x101d,
+ ATTR_KEY_WRAP_AUTH = 0x101e,
+ ATTR_KEY_ID = 0x101f,
+ ATTR_MAC_ADDR = 0x1020,
+ ATTR_MANUFACTURER = 0x1021,
+ ATTR_MSG_TYPE = 0x1022,
+ ATTR_MODEL_NAME = 0x1023,
+ ATTR_MODEL_NUMBER = 0x1024,
+ ATTR_NETWORK_INDEX = 0x1026,
+ ATTR_NETWORK_KEY = 0x1027,
+ ATTR_NETWORK_KEY_INDEX = 0x1028,
+ ATTR_NEW_DEVICE_NAME = 0x1029,
+ ATTR_NEW_PASSWORD = 0x102a,
+ ATTR_OOB_DEVICE_PASSWORD = 0x102c,
+ ATTR_OS_VERSION = 0x102d,
+ ATTR_POWER_LEVEL = 0x102f,
+ ATTR_PSK_CURRENT = 0x1030,
+ ATTR_PSK_MAX = 0x1031,
+ ATTR_PUBLIC_KEY = 0x1032,
+ ATTR_RADIO_ENABLE = 0x1033,
+ ATTR_REBOOT = 0x1034,
+ ATTR_REGISTRAR_CURRENT = 0x1035,
+ ATTR_REGISTRAR_ESTABLISHED = 0x1036,
+ ATTR_REGISTRAR_LIST = 0x1037,
+ ATTR_REGISTRAR_MAX = 0x1038,
+ ATTR_REGISTRAR_NONCE = 0x1039,
+ ATTR_REQUEST_TYPE = 0x103a,
+ ATTR_RESPONSE_TYPE = 0x103b,
+ ATTR_RF_BANDS = 0x103c,
+ ATTR_R_HASH1 = 0x103d,
+ ATTR_R_HASH2 = 0x103e,
+ ATTR_R_SNONCE1 = 0x103f,
+ ATTR_R_SNONCE2 = 0x1040,
+ ATTR_SELECTED_REGISTRAR = 0x1041,
+ ATTR_SERIAL_NUMBER = 0x1042,
+ ATTR_WPS_STATE = 0x1044,
+ ATTR_SSID = 0x1045,
+ ATTR_TOTAL_NETWORKS = 0x1046,
+ ATTR_UUID_E = 0x1047,
+ ATTR_UUID_R = 0x1048,
+ ATTR_VENDOR_EXT = 0x1049,
+ ATTR_VERSION = 0x104a,
+ ATTR_X509_CERT_REQ = 0x104b,
+ ATTR_X509_CERT = 0x104c,
+ ATTR_EAP_IDENTITY = 0x104d,
+ ATTR_MSG_COUNTER = 0x104e,
+ ATTR_PUBKEY_HASH = 0x104f,
+ ATTR_REKEY_KEY = 0x1050,
+ ATTR_KEY_LIFETIME = 0x1051,
+ ATTR_PERMITTED_CFG_METHODS = 0x1052,
+ ATTR_SELECTED_REGISTRAR_CONFIG_METHODS = 0x1053,
+ ATTR_PRIMARY_DEV_TYPE = 0x1054,
+ ATTR_SECONDARY_DEV_TYP_ELIST = 0x1055,
+ ATTR_PORTABLE_DEV = 0x1056,
+ ATTR_AP_SETUP_LOCKED = 0x1057,
+ ATTR_APPLICATION_EXT = 0x1058,
+ ATTR_EAP_TYPE = 0x1059,
+ ATTR_IV = 0x1060,
+ ATTR_KEY_PROVIDED_AUTO = 0x1061,
+ ATTR_802_1X_ENABLED = 0x1062,
+ ATTR_APPSESSIONKEY = 0x1063,
+ ATTR_WEPTRANSMITKEY = 0x1064,
+ ATTR_REQUESTED_DEV_TYPE = 0x106a
+};
+
+enum p2p_wps_method {
+ WPS_NOT_READY, WPS_PIN_LABEL, WPS_PIN_DISPLAY, WPS_PIN_KEYPAD, WPS_PBC
+};
+
+enum p2p_status_code {
+ P2P_SC_SUCCESS = 0,
+ P2P_SC_FAIL_INFO_CURRENTLY_UNAVAILABLE = 1,
+ P2P_SC_FAIL_INCOMPATIBLE_PARAMS = 2,
+ P2P_SC_FAIL_LIMIT_REACHED = 3,
+ P2P_SC_FAIL_INVALID_PARAMS = 4,
+ P2P_SC_FAIL_UNABLE_TO_ACCOMMODATE = 5,
+ P2P_SC_FAIL_PREV_PROTOCOL_ERROR = 6,
+ P2P_SC_FAIL_NO_COMMON_CHANNELS = 7,
+ P2P_SC_FAIL_UNKNOWN_GROUP = 8,
+ P2P_SC_FAIL_BOTH_GO_INTENT_15 = 9,
+ P2P_SC_FAIL_INCOMPATIBLE_PROV_METHOD = 10,
+ P2P_SC_FAIL_REJECTED_BY_USER = 11,
+};
+
+struct wps_parse_attr {
+ /* fixed length fields */
+ const A_UINT8 *version; /* 1 octet */
+ const A_UINT8 *msg_type; /* 1 octet */
+ const A_UINT8 *enrollee_nonce; /* WPS_NONCE_LEN (16) octets */
+ const A_UINT8 *registrar_nonce; /* WPS_NONCE_LEN (16) octets */
+ const A_UINT8 *uuid_r; /* WPS_UUID_LEN (16) octets */
+ const A_UINT8 *uuid_e; /* WPS_UUID_LEN (16) octets */
+ const A_UINT8 *auth_type_flags; /* 2 octets */
+ const A_UINT8 *encr_type_flags; /* 2 octets */
+ const A_UINT8 *conn_type_flags; /* 1 octet */
+ const A_UINT8 *config_methods; /* 2 octets */
+ const A_UINT8 *sel_reg_config_methods; /* 2 octets */
+ const A_UINT8 *primary_dev_type; /* 8 octets */
+ const A_UINT8 *rf_bands; /* 1 octet */
+ const A_UINT8 *assoc_state; /* 2 octets */
+ const A_UINT8 *config_error; /* 2 octets */
+ const A_UINT8 *dev_password_id; /* 2 octets */
+ const A_UINT8 *oob_dev_password; /* WPS_OOB_DEVICE_PASSWORD_ATTR_LEN (54)
+ * octets */
+ const A_UINT8 *os_version; /* 4 octets */
+ const A_UINT8 *wps_state; /* 1 octet */
+ const A_UINT8 *authenticator; /* WPS_AUTHENTICATOR_LEN (8) octets */
+ const A_UINT8 *r_hash1; /* WPS_HASH_LEN (32) octets */
+ const A_UINT8 *r_hash2; /* WPS_HASH_LEN (32) octets */
+ const A_UINT8 *e_hash1; /* WPS_HASH_LEN (32) octets */
+ const A_UINT8 *e_hash2; /* WPS_HASH_LEN (32) octets */
+ const A_UINT8 *r_snonce1; /* WPS_SECRET_NONCE_LEN (16) octets */
+ const A_UINT8 *r_snonce2; /* WPS_SECRET_NONCE_LEN (16) octets */
+ const A_UINT8 *e_snonce1; /* WPS_SECRET_NONCE_LEN (16) octets */
+ const A_UINT8 *e_snonce2; /* WPS_SECRET_NONCE_LEN (16) octets */
+ const A_UINT8 *key_wrap_auth; /* WPS_KWA_LEN (8) octets */
+ const A_UINT8 *auth_type; /* 2 octets */
+ const A_UINT8 *encr_type; /* 2 octets */
+ const A_UINT8 *network_idx; /* 1 octet */
+ const A_UINT8 *network_key_idx; /* 1 octet */
+ const A_UINT8 *mac_addr; /* ETH_ALEN (6) octets */
+ const A_UINT8 *key_prov_auto; /* 1 octet (Bool) */
+ const A_UINT8 *dot1x_enabled; /* 1 octet (Bool) */
+ const A_UINT8 *selected_registrar; /* 1 octet (Bool) */
+ const A_UINT8 *request_type; /* 1 octet */
+ const A_UINT8 *response_type; /* 1 octet */
+ const A_UINT8 *ap_setup_locked; /* 1 octet */
+
+ /* variable length fields */
+ const A_UINT8 *manufacturer;
+ A_UINT32 manufacturer_len;
+ const A_UINT8 *model_name;
+ A_UINT32 model_name_len;
+ const A_UINT8 *model_number;
+ A_UINT32 model_number_len;
+ const A_UINT8 *serial_number;
+ A_UINT32 serial_number_len;
+ const A_UINT8 *dev_name;
+ A_UINT32 dev_name_len;
+ const A_UINT8 *public_key;
+ A_UINT32 public_key_len;
+ const A_UINT8 *encr_settings;
+ A_UINT32 encr_settings_len;
+ const A_UINT8 *ssid; /* <= 32 octets */
+ A_UINT32 ssid_len;
+ const A_UINT8 *network_key; /* <= 64 octets */
+ A_UINT32 network_key_len;
+ const A_UINT8 *eap_type; /* <= 8 octets */
+ A_UINT32 eap_type_len;
+ const A_UINT8 *eap_identity; /* <= 64 octets */
+ A_UINT32 eap_identity_len;
+
+ /* attributes that can occur multiple times */
+#define MAX_CRED_COUNT 10
+ const A_UINT8 *cred[MAX_CRED_COUNT];
+ A_UINT32 cred_len[MAX_CRED_COUNT];
+ A_UINT32 num_cred;
+
+#define MAX_REQ_DEV_TYPE_COUNT 10
+ const A_UINT8 *req_dev_type[MAX_REQ_DEV_TYPE_COUNT];
+ A_UINT32 num_req_dev_type;
+};
+
+
+enum p2p_sublem_id {
+ P2P_ATTR_STATUS = 0,
+ P2P_ATTR_MINOR_REASON_CODE = 1,
+ P2P_ATTR_CAPABILITY = 2,
+ P2P_ATTR_DEVICE_ID = 3,
+ P2P_ATTR_GROUP_OWNER_INTENT = 4,
+ P2P_ATTR_CONFIGURATION_TIMEOUT = 5,
+ P2P_ATTR_LISTEN_CHANNEL = 6,
+ P2P_ATTR_GROUP_BSSID = 7,
+ P2P_ATTR_EXT_LISTEN_TIMING = 8,
+ P2P_ATTR_INTENDED_INTERFACE_ADDR = 9,
+ P2P_ATTR_MANAGEABILITY = 10,
+ P2P_ATTR_CHANNEL_LIST = 11,
+ P2P_ATTR_NOTICE_OF_ABSENCE = 12,
+ P2P_ATTR_DEVICE_INFO = 13,
+ P2P_ATTR_GROUP_INFO = 14,
+ P2P_ATTR_GROUP_ID = 15,
+ P2P_ATTR_INTERFACE = 16,
+ P2P_ATTR_OPERATING_CHANNEL = 17,
+ P2P_ATTR_INVITATION_FLAGS = 18,
+ P2P_ATTR_VENDOR_SPECIFIC = 221
+};
+
+#define P2P_MAX_REG_CLASSES 10
+#define P2P_MAX_REG_CLASS_CHANNELS 20
+
+#define P2P_WILDCARD_SSID "DIRECT-"
+#define P2P_WILDCARD_SSID_LEN 7
+
+struct p2p_channels {
+ struct p2p_reg_class {
+ A_UINT8 reg_class;
+ A_UINT8 channel[P2P_MAX_REG_CLASS_CHANNELS];
+ A_UINT8 channels;
+ } reg_class[P2P_MAX_REG_CLASSES];
+ A_UINT8 reg_classes;
+};
+
+#define P2P_NOA_DESCRIPTOR_LEN 13
+struct p2p_noa_descriptor {
+ A_UINT8 type_count; /* 255: continuous schedule, 0: reserved */
+ A_UINT32 duration ; /* Absent period duration in micro seconds */
+ A_UINT32 interval; /* Absent period interval in micro seconds */
+ A_UINT32 start_time; /* 32 bit tsf time when in starts */
+};
+
+#define P2P_MAX_NOA_DESCRIPTORS 4
+/*
+ * Length = (2 octets for Index and CTWin/Opp PS) and
+ * (13 octets for each NOA Descriptors)
+ */
+#define P2P_NOA_IE_SIZE(num_desc) (2 + (13 * (num_desc)))
+
+#define P2P_NOE_IE_OPP_PS_SET (0x80)
+#define P2P_NOE_IE_CTWIN_MASK (0x7F)
+
+struct p2p_sub_element_noa {
+ A_UINT8 p2p_sub_id;
+ A_UINT8 p2p_sub_len;
+ A_UINT8 index; /* identifies instance of NOA su element */
+ A_UINT8 oppPS:1, /* oppPS state of the AP */
+ ctwindow:7; /* ctwindow in TUs */
+ A_UINT8 num_descriptors; /* number of NOA descriptors */
+ struct p2p_noa_descriptor noa_descriptors[P2P_MAX_NOA_DESCRIPTORS];
+};
+
+#define ETH_ALEN 6
+
+struct p2p_ie {
+ A_UINT8 dialog_token;
+ const A_UINT8 *capability;
+ const A_UINT8 *go_intent;
+ const A_UINT8 *status;
+ const A_UINT8 *listen_channel;
+ const A_UINT8 *operating_channel;
+ const A_UINT8 *channel_list;
+ A_UINT8 channel_list_len;
+ const A_UINT8 *config_timeout;
+ const A_UINT8 *intended_addr;
+ const A_UINT8 *group_bssid;
+ const A_UINT8 *invitation_flags;
+
+ const A_UINT8 *group_info;
+ A_UINT32 group_info_len;
+ const A_UINT8 *group_id;
+ A_UINT32 group_id_len;
+
+ const A_UINT8 *device_id;
+ const A_UINT8 *manageability;
+
+ const A_UINT8 *noa;
+ A_UINT32 noa_len;
+ const A_UINT8 *ext_listen_timing;
+
+ const A_UINT8 *minor_reason_code;
+
+ /* P2P Device Info */
+ const A_UINT8 *p2p_device_info;
+ A_UINT32 p2p_device_info_len;
+ const A_UINT8 *p2p_device_addr;
+ const A_UINT8 *pri_dev_type;
+ A_UINT8 num_sec_dev_types;
+ A_CHAR device_name[33];
+ A_UINT8 dev_name_len;
+ A_UINT16 config_methods;
+
+ /* WPS IE */
+ A_UINT16 dev_password_id;
+ A_UINT16 wps_config_methods;
+ const A_UINT8 *wps_pri_dev_type;
+ A_CHAR wps_device_name[33];
+ A_UINT8 wps_dev_name_len;
+
+
+ /* SSID IE */
+ const A_UINT8 *ssid;
+};
+
+struct p2p_device {
+ A_UINT16 listen_freq;
+ A_UINT32 wps_pbc;
+ A_CHAR wps_pin[WPS_MAX_PIN_LEN];
+ A_UINT8 pin_len;
+ enum p2p_wps_method wps_method;
+
+ A_UINT8 p2p_device_addr[ETH_ALEN];
+ A_UINT8 pri_dev_type[8];
+ A_CHAR device_name[33];
+ A_UINT16 config_methods;
+ A_UINT8 dev_capab;
+ A_UINT8 group_capab;
+
+ A_UINT8 interface_addr[ETH_ALEN];
+
+ /* Dev. Discoverability data */
+ A_UINT8 dev_disc_dialog_token;
+ A_UINT8 member_in_go_dev[ETH_ALEN];
+ A_UINT8 member_in_go_iface[ETH_ALEN];
+ A_UINT8 dev_disc_go_oper_ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 dev_disc_go_oper_ssid_len;
+ A_UINT16 dev_disc_go_oper_freq;
+
+ A_UINT32 go_neg_req_sent;
+ enum p2p_go_state { UNKNOWN_GO, LOCAL_GO, REMOTE_GO } go_state;
+ A_UINT8 dialog_token;
+ A_UINT8 intended_addr[ETH_ALEN];
+
+ A_CHAR country[3];
+ struct p2p_channels channels;
+ A_UINT16 oper_freq;
+ A_UINT8 oper_ssid[P2P_MAX_SSID_LEN];
+ A_UINT8 oper_ssid_len;
+
+ A_UINT16 req_config_methods;
+
+#define P2P_DEV_PROBE_REQ_ONLY BIT(0)
+#define P2P_DEV_REPORTED BIT(1)
+#define P2P_DEV_NOT_YET_READY BIT(2)
+#define P2P_DEV_SD_INFO BIT(3)
+#define P2P_DEV_SD_SCHEDULE BIT(4)
+#define P2P_DEV_PD_PEER_DISPLAY BIT(5)
+#define P2P_DEV_PD_PEER_KEYPAD BIT(6)
+#define P2P_DEV_USER_REJECTED BIT(7)
+#define P2P_DEV_PEER_WAITING_RESPONSE BIT(8)
+#define P2P_DEV_PREFER_PERSISTENT_GROUP BIT(9)
+#define P2P_DEV_WAIT_GO_NEG_RESPONSE BIT(10)
+#define P2P_DEV_WAIT_GO_NEG_CONFIRM BIT(11)
+#define P2P_DEV_GROUP_CLIENT_ONLY BIT(12)
+#define P2P_DEV_FORCE_FREQ BIT(13)
+#define P2P_DEV_PD_FOR_JOIN BIT(14)
+#define P2P_DEV_INVITATION_AUTHORIZED BIT(15)
+
+ A_UINT32 flags;
+
+ A_UINT32 status;
+ A_UINT8 wait_count;
+ A_UINT32 invitation_reqs;
+
+ A_UINT16 ext_listen_period;
+ A_UINT16 ext_listen_interval;
+
+ A_UINT8 go_timeout;
+ A_UINT8 client_timeout;
+ A_UINT8 persistent_grp;
+
+};
+#endif /* _P2P_H_ */
diff --git a/host/include/p2p_api.h b/host/include/p2p_api.h
new file mode 100644
index 0000000..87191f7
--- /dev/null
+++ b/host/include/p2p_api.h
@@ -0,0 +1,144 @@
+//------------------------------------------------------------------------------
+// <copyright file="p2p_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains definitions exported by the P2P host module.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _HOST_P2P_API_H_
+#define _HOST_P2P_API_H_
+
+#include "utils_api.h"
+#include "wmi.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define P2P_OUI 0x99a6f50
+
+static int __inline
+isp2poui(const A_UINT8 *frm)
+{
+ return frm[1] > 3 && LE_READ_4(frm+2) == (P2P_OUI);
+}
+
+/* P2P Capability - Device Capability bitmap */
+#define P2P_DEV_CAPAB_SERVICE_DISCOVERY BIT(0)
+#define P2P_DEV_CAPAB_CLIENT_DISCOVERABILITY BIT(1)
+#define P2P_DEV_CAPAB_CONCURRENT_OPER BIT(2)
+#define P2P_DEV_CAPAB_INFRA_MANAGED BIT(3)
+#define P2P_DEV_CAPAB_DEVICE_LIMIT BIT(4)
+#define P2P_DEV_CAPAB_INVITATION_PROCEDURE BIT(5)
+
+/* P2P Capability - Group Capability bitmap */
+#define P2P_GROUP_CAPAB_GROUP_OWNER BIT(0)
+#define P2P_GROUP_CAPAB_PERSISTENT_GROUP BIT(1)
+#define P2P_GROUP_CAPAB_GROUP_LIMIT BIT(2)
+#define P2P_GROUP_CAPAB_INTRA_BSS_DIST BIT(3)
+#define P2P_GROUP_CAPAB_CROSS_CONN BIT(4)
+#define P2P_GROUP_CAPAB_PERSISTENT_RECONN BIT(5)
+#define P2P_GROUP_CAPAB_GROUP_FORMATION BIT(6)
+
+/* API function declarations */
+
+void *p2p_init(void *dev);
+void p2p_deinit(void);
+
+struct host_p2p_dev *p2p_get_device(void *p2p_dev_ctx, const A_UINT8 *addr);
+
+void *p2p_bssinfo_rx(void *p2p_dev_ctx, WMI_BI_FTYPE fType, A_UINT8 *addr, A_UINT16 channel, const A_UINT8 *data, A_UINT32 len);
+
+void p2p_go_neg_req_rx(void *p2p_dev_ctx, const A_UINT8 *datap, A_UINT8 len);
+
+void p2p_invite_req_rx(void *p2p_dev_ctx, const A_UINT8 *datap, A_UINT8 len);
+
+void p2p_prov_disc_req_rx(void *p2p_dev_ctx, const A_UINT8 *datap, A_UINT8 len);
+void p2p_prov_disc_resp_rx(void *p2p_dev_ctx,
+ const A_UINT8 *datap, A_UINT8 len);
+void p2p_start_sdpd_event_rx(void *p2p_dev_ctx);
+void p2p_sdpd_rx_event_rx(void *p2p_dev_ctx,
+ const A_UINT8 *datap, A_UINT8 len);
+void p2p_free_all_devices(void *ctx);
+void p2p_device_free(void *peer_dev);
+
+A_STATUS p2p_auth_go_neg(void *ctx,
+ WMI_P2P_GO_NEG_START_CMD *auth_go_neg_param);
+
+A_STATUS p2p_auth_invite(void *ctx, A_UINT32 auth, A_UINT8 *auth_peer);
+
+A_STATUS p2p_peer_reject(void *ctx, A_UINT8 *peer_addr);
+
+A_STATUS p2p_go_neg_start(void *ctx, WMI_P2P_GO_NEG_START_CMD *go_neg_param);
+
+A_STATUS p2p_invite_cmd(void *ctx, WMI_P2P_INVITE_CMD *invite_param);
+
+A_STATUS p2p_prov_disc_req(void *ctx, A_UINT8 *peer, A_UINT16 wps_method);
+
+A_STATUS p2p_peer(void *ctx, A_UINT8 *peer, A_UINT8 next);
+
+A_STATUS p2p_get_device_p2p_buf(void *ctx, A_UINT8 *peer, A_UINT8 **p2p_buf, A_UINT8 *p2p_buf_len);
+
+A_STATUS wmi_p2p_get_go_params(void *ctx, A_UINT8 *go_dev_addr,
+ A_UINT16 *oper_freq, A_UINT8 *ssid, A_UINT8 *ssid_len);
+
+A_STATUS p2p_get_devaddr (void *ctx, A_UINT8 *intf_addr);
+
+A_STATUS p2p_get_ifaddr (void *ctx, A_UINT8 *dev_addr);
+
+struct host_p2p_dev *p2p_get_device_intf_addrs(void *ctx, const A_UINT8 *intfaddr);
+
+void p2p_increment_dev_ref_count(struct host_p2p_dev *dev);
+
+void p2p_free_all_sd_queries(void *ctx);
+
+A_STATUS p2p_sd_request(void *ctx, A_UINT8 *peer_addr, A_UINT8 *tlvbuf,
+ A_UINT8 tlv_buflen, A_UINT32 *qid);
+
+A_STATUS p2p_sdpd_tx_cmd(void *ctx, WMI_P2P_SDPD_TX_CMD *sdpd_tx_cmd, A_UINT32 *qid);
+
+A_STATUS p2p_sd_cancel_request(void *ctx, A_UINT32 qid);
+
+void p2p_go_neg_complete_rx(void *ctx, const A_UINT8 *datap, A_UINT8 len);
+
+int p2p_get_peer_info(void *ctx, A_UINT8 *peer_addr, A_UINT8 *buf, A_UINT32 buflen);
+
+int p2p_get_next_addr(void *ctx, A_UINT8 *addr, A_UINT8 *buf, A_UINT32 buflen, int first_element);
+
+void p2p_clear_peers_reported_flag(void *ctx);
+
+void p2p_clear_peers_authorized_flag(void *ctx, const A_UINT8 *addr);
+
+A_STATUS p2p_get_own_info(void *ctx, A_UINT8 *p2p_buf, A_UINT8 p2p_buf_len);
+
+void p2p_update_capability(void *ctx, A_UINT8 arNetworkType, A_UINT8 numDev);
+
+void p2p_set_group_capability(void *ctx, A_UINT8 flag, A_UINT8 set);
+
+void p2p_clear_group_peer(void *ctx);
+
+void p2p_set_device_capability(void *ctx, A_UINT8 flag, A_UINT8 set);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _HOST_P2P_API_H_ */
diff --git a/host/include/pkt_log.h b/host/include/pkt_log.h
new file mode 100644
index 0000000..55ae2a3
--- /dev/null
+++ b/host/include/pkt_log.h
@@ -0,0 +1,45 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2005-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __PKT_LOG_H__
+#define __PKT_LOG_H__
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+/* Pkt log info */
+typedef PREPACK struct pkt_log_t {
+ struct info_t {
+ A_UINT16 st;
+ A_UINT16 end;
+ A_UINT16 cur;
+ }info[4096];
+ A_UINT16 last_idx;
+}POSTPACK PACKET_LOG;
+
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* __PKT_LOG_H__ */
diff --git a/host/include/project.h b/host/include/project.h
new file mode 100644
index 0000000..43378de
--- /dev/null
+++ b/host/include/project.h
@@ -0,0 +1,36 @@
+/*
+ * Copyright (c) 2008 Atheros Communications Inc.
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+#ifndef _PROJECT_H_
+#define _PROJECT_H_
+#include "queue.h"
+
+#define OS_TIMER_FUNC(fn) void fn(A_HANDLE hdl, void *context)
+#define OS_TIMER_FUNC_PTR(fn) void (* fn)(A_HANDLE hdl, void *context)
+#define OS_CANCEL_TIMER(timer_hdl) A_UNTIMEOUT(timer_hdl)
+#define OS_SET_TIMER(timer_hdl, period, repeat) A_TIMEOUT_MS(timer_hdl, period, repeat)
+#define OS_INIT_TIMER(timer_hdl, fn, arg) A_INIT_TIMER(timer_hdl, fn, arg)
+
+typedef A_TIMER os_timer_t;
+
+/* Memory related */
+#define OS_MEMZERO(ptr, size) A_MEMZERO(ptr, size)
+#define OS_MEMCPY(dst, src, len) A_MEMCPY(dst, src, len)
+#define OS_MALLOC(nbytes) A_MALLOC(nbytes)
+#define OS_FREE(ptr) A_FREE(ptr)
+
+#endif
+
+
diff --git a/host/include/queue.h b/host/include/queue.h
new file mode 100644
index 0000000..62caf5e
--- /dev/null
+++ b/host/include/queue.h
@@ -0,0 +1,565 @@
+//
+// Copyright (c) 1991, 1993
+// The Regents of the University of California. All rights reserved.
+//
+//
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+// 1. Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// 2. Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in the
+// documentation and/or other materials provided with the distribution.
+// 3. All advertising materials mentioning features or use of this software
+// must display the following acknowledgement:
+// This product includes software developed by the University of
+// California, Berkeley and its contributors.
+// 4. Neither the name of the University nor the names of its contributors
+// may be used to endorse or promote products derived from this software
+// without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+// ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+// FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+// DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+// OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+// HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+// OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+// SUCH DAMAGE.
+//
+// @(#)queue.h 8.5 (Berkeley) 8/20/94
+// $FreeBSD: src/sys/sys/queue.h,v 1.58 2004/04/07 04:19:49 imp Exp $
+// $Id: //depot/sw/releases/olca3.1-RC/include/queue.h#3 $
+//
+
+#ifndef _SYS_QUEUE_H_
+#define _SYS_QUEUE_H_
+
+/*
+ * This file defines four types of data structures: singly-linked lists,
+ * singly-linked tail queues, lists and tail queues.
+ *
+ * A singly-linked list is headed by a single forward pointer. The elements
+ * are singly linked for minimum space and pointer manipulation overhead at
+ * the expense of O(n) removal for arbitrary elements. New elements can be
+ * added to the list after an existing element or at the head of the list.
+ * Elements being removed from the head of the list should use the explicit
+ * macro for this purpose for optimum efficiency. A singly-linked list may
+ * only be traversed in the forward direction. Singly-linked lists are ideal
+ * for applications with large datasets and few or no removals or for
+ * implementing a LIFO queue.
+ *
+ * A singly-linked tail queue is headed by a pair of pointers, one to the
+ * head of the list and the other to the tail of the list. The elements are
+ * singly linked for minimum space and pointer manipulation overhead at the
+ * expense of O(n) removal for arbitrary elements. New elements can be added
+ * to the list after an existing element, at the head of the list, or at the
+ * end of the list. Elements being removed from the head of the tail queue
+ * should use the explicit macro for this purpose for optimum efficiency.
+ * A singly-linked tail queue may only be traversed in the forward direction.
+ * Singly-linked tail queues are ideal for applications with large datasets
+ * and few or no removals or for implementing a FIFO queue.
+ *
+ * A list is headed by a single forward pointer (or an array of forward
+ * pointers for a hash table header). The elements are doubly linked
+ * so that an arbitrary element can be removed without a need to
+ * traverse the list. New elements can be added to the list before
+ * or after an existing element or at the head of the list. A list
+ * may only be traversed in the forward direction.
+ *
+ * A tail queue is headed by a pair of pointers, one to the head of the
+ * list and the other to the tail of the list. The elements are doubly
+ * linked so that an arbitrary element can be removed without a need to
+ * traverse the list. New elements can be added to the list before or
+ * after an existing element, at the head of the list, or at the end of
+ * the list. A tail queue may be traversed in either direction.
+ *
+ * For details on the use of these macros, see the queue(3) manual page.
+ *
+ *
+ * SLIST LIST STAILQ TAILQ
+ * _HEAD + + + +
+ * _HEAD_INITIALIZER + + + +
+ * _ENTRY + + + +
+ * _INIT + + + +
+ * _EMPTY + + + +
+ * _FIRST + + + +
+ * _NEXT + + + +
+ * _PREV - - - +
+ * _LAST - - + +
+ * _FOREACH + + + +
+ * _FOREACH_SAFE + + + +
+ * _FOREACH_REVERSE - - - +
+ * _FOREACH_REVERSE_SAFE - - - +
+ * _INSERT_HEAD + + + +
+ * _INSERT_BEFORE - + - +
+ * _INSERT_AFTER + + + +
+ * _INSERT_TAIL - - + +
+ * _CONCAT - - + +
+ * _REMOVE_HEAD + - + -
+ * _REMOVE + + + +
+ *
+ */
+#define QUEUE_MACRO_DEBUG 0
+#if QUEUE_MACRO_DEBUG
+/* Store the last 2 places the queue element or head was altered */
+struct qm_trace {
+ char * lastfile;
+ int lastline;
+ char * prevfile;
+ int prevline;
+};
+
+#define TRACEBUF struct qm_trace trace;
+#define TRASHIT(x) do {(x) = (void *)-1;} while (0)
+
+#define QMD_TRACE_HEAD(head) do { \
+ (head)->trace.prevline = (head)->trace.lastline; \
+ (head)->trace.prevfile = (head)->trace.lastfile; \
+ (head)->trace.lastline = __LINE__; \
+ (head)->trace.lastfile = __FILE__; \
+} while (0)
+
+#define QMD_TRACE_ELEM(elem) do { \
+ (elem)->trace.prevline = (elem)->trace.lastline; \
+ (elem)->trace.prevfile = (elem)->trace.lastfile; \
+ (elem)->trace.lastline = __LINE__; \
+ (elem)->trace.lastfile = __FILE__; \
+} while (0)
+
+#else
+#define QMD_TRACE_ELEM(elem)
+#define QMD_TRACE_HEAD(head)
+#define TRACEBUF
+#define TRASHIT(x)
+#endif /* QUEUE_MACRO_DEBUG */
+
+/*
+ * Singly-linked List declarations.
+ */
+#define SLIST_HEAD(name, type) \
+struct name { \
+ struct type *slh_first; /* first element */ \
+}
+
+#define SLIST_HEAD_INITIALIZER(head) \
+ { NULL }
+
+#define SLIST_ENTRY(type) \
+struct { \
+ struct type *sle_next; /* next element */ \
+}
+
+/*
+ * Singly-linked List functions.
+ */
+#define SLIST_EMPTY(head) ((head)->slh_first == NULL)
+
+#define SLIST_FIRST(head) ((head)->slh_first)
+
+#define SLIST_FOREACH(var, head, field) \
+ for ((var) = SLIST_FIRST((head)); \
+ (var); \
+ (var) = SLIST_NEXT((var), field))
+
+#define SLIST_FOREACH_SAFE(var, head, field, tvar) \
+ for ((var) = SLIST_FIRST((head)); \
+ (var) && ((tvar) = SLIST_NEXT((var), field), 1); \
+ (var) = (tvar))
+
+#define SLIST_FOREACH_PREVPTR(var, varp, head, field) \
+ for ((varp) = &SLIST_FIRST((head)); \
+ ((var) = *(varp)) != NULL; \
+ (varp) = &SLIST_NEXT((var), field))
+
+#define SLIST_INIT(head) do { \
+ SLIST_FIRST((head)) = NULL; \
+} while (0)
+
+#define SLIST_INSERT_AFTER(slistelm, elm, field) do { \
+ SLIST_NEXT((elm), field) = SLIST_NEXT((slistelm), field); \
+ SLIST_NEXT((slistelm), field) = (elm); \
+} while (0)
+
+#define SLIST_INSERT_HEAD(head, elm, field) do { \
+ SLIST_NEXT((elm), field) = SLIST_FIRST((head)); \
+ SLIST_FIRST((head)) = (elm); \
+} while (0)
+
+#define SLIST_NEXT(elm, field) ((elm)->field.sle_next)
+
+#define SLIST_REMOVE(head, elm, type, field) do { \
+ if (SLIST_FIRST((head)) == (elm)) { \
+ SLIST_REMOVE_HEAD((head), field); \
+ } \
+ else { \
+ struct type *curelm = SLIST_FIRST((head)); \
+ while (SLIST_NEXT(curelm, field) != (elm)) \
+ curelm = SLIST_NEXT(curelm, field); \
+ SLIST_NEXT(curelm, field) = \
+ SLIST_NEXT(SLIST_NEXT(curelm, field), field); \
+ } \
+} while (0)
+
+#define SLIST_REMOVE_HEAD(head, field) do { \
+ SLIST_FIRST((head)) = SLIST_NEXT(SLIST_FIRST((head)), field); \
+} while (0)
+
+/*
+ * Singly-linked Tail queue declarations.
+ */
+#define STAILQ_HEAD(name, type) \
+struct name { \
+ struct type *stqh_first;/* first element */ \
+ struct type **stqh_last;/* addr of last next element */ \
+}
+
+#define STAILQ_HEAD_INITIALIZER(head) \
+ { NULL, &(head).stqh_first }
+
+#define STAILQ_ENTRY(type) \
+struct { \
+ struct type *stqe_next; /* next element */ \
+}
+
+/*
+ * Singly-linked Tail queue functions.
+ */
+#define STAILQ_CONCAT(head1, head2) do { \
+ if (!STAILQ_EMPTY((head2))) { \
+ *(head1)->stqh_last = (head2)->stqh_first; \
+ (head1)->stqh_last = (head2)->stqh_last; \
+ STAILQ_INIT((head2)); \
+ } \
+} while (0)
+
+#define STAILQ_EMPTY(head) ((head)->stqh_first == NULL)
+
+#define STAILQ_FIRST(head) ((head)->stqh_first)
+
+#define STAILQ_FOREACH(var, head, field) \
+ for((var) = STAILQ_FIRST((head)); \
+ (var); \
+ (var) = STAILQ_NEXT((var), field))
+
+
+#define STAILQ_FOREACH_SAFE(var, head, field, tvar) \
+ for ((var) = STAILQ_FIRST((head)); \
+ (var) && ((tvar) = STAILQ_NEXT((var), field), 1); \
+ (var) = (tvar))
+
+#define STAILQ_INIT(head) do { \
+ STAILQ_FIRST((head)) = NULL; \
+ (head)->stqh_last = &STAILQ_FIRST((head)); \
+} while (0)
+
+#define STAILQ_INSERT_AFTER(head, tqelm, elm, field) do { \
+ if ((STAILQ_NEXT((elm), field) = STAILQ_NEXT((tqelm), field)) == NULL)\
+ (head)->stqh_last = &STAILQ_NEXT((elm), field); \
+ STAILQ_NEXT((tqelm), field) = (elm); \
+} while (0)
+
+#define STAILQ_INSERT_HEAD(head, elm, field) do { \
+ if ((STAILQ_NEXT((elm), field) = STAILQ_FIRST((head))) == NULL) \
+ (head)->stqh_last = &STAILQ_NEXT((elm), field); \
+ STAILQ_FIRST((head)) = (elm); \
+} while (0)
+
+#define STAILQ_INSERT_TAIL(head, elm, field) do { \
+ STAILQ_NEXT((elm), field) = NULL; \
+ *(head)->stqh_last = (elm); \
+ (head)->stqh_last = &STAILQ_NEXT((elm), field); \
+} while (0)
+
+#define FIELD_OFFSET(type, field) ((int)(int *)&(((struct type *)0)->field))
+
+#define STAILQ_LAST(head, type, field) \
+ (STAILQ_EMPTY((head)) ? \
+ NULL : \
+ ((struct type *) \
+ ((char *)((head)->stqh_last) - FIELD_OFFSET(type, field))))
+
+#define STAILQ_NEXT(elm, field) ((elm)->field.stqe_next)
+
+#define STAILQ_CONCAT_ELEM(prevelm, elm, field) do { \
+ prevelm->field.stqe_next = elm; \
+} while (0)
+
+#define STAILQ_REMOVE(head, elm, type, field) do { \
+ if (STAILQ_FIRST((head)) == (elm)) { \
+ STAILQ_REMOVE_HEAD((head), field); \
+ } \
+ else { \
+ struct type *curelm = STAILQ_FIRST((head)); \
+ while (STAILQ_NEXT(curelm, field) != (elm)) \
+ curelm = STAILQ_NEXT(curelm, field); \
+ if ((STAILQ_NEXT(curelm, field) = \
+ STAILQ_NEXT(STAILQ_NEXT(curelm, field), field)) == NULL)\
+ (head)->stqh_last = &STAILQ_NEXT((curelm), field);\
+ } \
+} while (0)
+
+#define STAILQ_REMOVE_HEAD(head, field) do { \
+ if ((STAILQ_FIRST((head)) = \
+ STAILQ_NEXT(STAILQ_FIRST((head)), field)) == NULL) \
+ (head)->stqh_last = &STAILQ_FIRST((head)); \
+} while (0)
+
+#define STAILQ_REMOVE_HEAD_UNTIL(head, elm, field) do { \
+ if ((STAILQ_FIRST((head)) = STAILQ_NEXT((elm), field)) == NULL) \
+ (head)->stqh_last = &STAILQ_FIRST((head)); \
+} while (0)
+
+/*
+ * List declarations.
+ */
+#define ATH_LIST_HEAD(name, type) \
+struct name { \
+ struct type *lh_first; /* first element */ \
+}
+
+#define LIST_HEAD_INITIALIZER(head) \
+ { NULL }
+
+#define LIST_ENTRY(type) \
+struct { \
+ struct type *le_next; /* next element */ \
+ struct type **le_prev; /* address of previous next element */ \
+}
+
+/*
+ * List functions.
+ */
+
+#define LIST_EMPTY(head) ((head)->lh_first == NULL)
+
+#define LIST_FIRST(head) ((head)->lh_first)
+
+#define LIST_FOREACH(var, head, field) \
+ for ((var) = LIST_FIRST((head)); \
+ (var); \
+ (var) = LIST_NEXT((var), field))
+
+#define LIST_FOREACH_SAFE(var, head, field, tvar) \
+ for ((var) = LIST_FIRST((head)); \
+ (var) && ((tvar) = LIST_NEXT((var), field), 1); \
+ (var) = (tvar))
+
+#define LIST_INIT(head) do { \
+ LIST_FIRST((head)) = NULL; \
+} while (0)
+
+#define LIST_INSERT_AFTER(listelm, elm, field) do { \
+ if ((LIST_NEXT((elm), field) = LIST_NEXT((listelm), field)) != NULL)\
+ LIST_NEXT((listelm), field)->field.le_prev = \
+ &LIST_NEXT((elm), field); \
+ LIST_NEXT((listelm), field) = (elm); \
+ (elm)->field.le_prev = &LIST_NEXT((listelm), field); \
+} while (0)
+
+#define LIST_INSERT_BEFORE(listelm, elm, field) do { \
+ (elm)->field.le_prev = (listelm)->field.le_prev; \
+ LIST_NEXT((elm), field) = (listelm); \
+ *(listelm)->field.le_prev = (elm); \
+ (listelm)->field.le_prev = &LIST_NEXT((elm), field); \
+} while (0)
+
+#define LIST_INSERT_HEAD(head, elm, field) do { \
+ if ((LIST_NEXT((elm), field) = LIST_FIRST((head))) != NULL) \
+ LIST_FIRST((head))->field.le_prev = &LIST_NEXT((elm), field);\
+ LIST_FIRST((head)) = (elm); \
+ (elm)->field.le_prev = &LIST_FIRST((head)); \
+} while (0)
+
+#define LIST_NEXT(elm, field) ((elm)->field.le_next)
+
+#define LIST_REMOVE(elm, field) do { \
+ if (LIST_NEXT((elm), field) != NULL) \
+ LIST_NEXT((elm), field)->field.le_prev = \
+ (elm)->field.le_prev; \
+ *(elm)->field.le_prev = LIST_NEXT((elm), field); \
+} while (0)
+
+/*
+ * Tail queue declarations.
+ */
+#define TAILQ_HEAD(name, type) \
+struct name { \
+ struct type *tqh_first; /* first element */ \
+ struct type **tqh_last; /* addr of last next element */ \
+ TRACEBUF \
+}
+
+#define TAILQ_HEAD_INITIALIZER(head) \
+ { NULL, &(head).tqh_first }
+
+#define TAILQ_ENTRY(type) \
+struct { \
+ struct type *tqe_next; /* next element */ \
+ struct type **tqe_prev; /* address of previous next element */ \
+ TRACEBUF \
+}
+
+/*
+ * Tail queue functions.
+ */
+#define TAILQ_CONCAT(head1, head2, field) do { \
+ if (!TAILQ_EMPTY(head2)) { \
+ *(head1)->tqh_last = (head2)->tqh_first; \
+ (head2)->tqh_first->field.tqe_prev = (head1)->tqh_last; \
+ (head1)->tqh_last = (head2)->tqh_last; \
+ TAILQ_INIT((head2)); \
+ QMD_TRACE_HEAD(head); \
+ QMD_TRACE_HEAD(head2); \
+ } \
+} while (0)
+
+#define TAILQ_EMPTY(head) ((head)->tqh_first == NULL)
+
+#define TAILQ_FIRST(head) ((head)->tqh_first)
+
+#define TAILQ_FOREACH(var, head, field) \
+ for ((var) = TAILQ_FIRST((head)); \
+ (var); \
+ (var) = TAILQ_NEXT((var), field))
+
+#define TAILQ_FOREACH_SAFE(var, head, field, tvar) \
+ for ((var) = TAILQ_FIRST((head)); \
+ (var) && ((tvar) = TAILQ_NEXT((var), field), 1); \
+ (var) = (tvar))
+
+#define TAILQ_FOREACH_REVERSE(var, head, headname, field) \
+ for ((var) = TAILQ_LAST((head), headname); \
+ (var); \
+ (var) = TAILQ_PREV((var), headname, field))
+
+#define TAILQ_FOREACH_REVERSE_SAFE(var, head, headname, field, tvar) \
+ for ((var) = TAILQ_LAST((head), headname); \
+ (var) && ((tvar) = TAILQ_PREV((var), headname, field), 1); \
+ (var) = (tvar))
+
+#define TAILQ_INIT(head) do { \
+ TAILQ_FIRST((head)) = NULL; \
+ (head)->tqh_last = &TAILQ_FIRST((head)); \
+ QMD_TRACE_HEAD(head); \
+} while (0)
+
+#define TAILQ_INSERT_AFTER(head, listelm, elm, field) do { \
+ if ((TAILQ_NEXT((elm), field) = TAILQ_NEXT((listelm), field)) != NULL)\
+ TAILQ_NEXT((elm), field)->field.tqe_prev = \
+ &TAILQ_NEXT((elm), field); \
+ else { \
+ (head)->tqh_last = &TAILQ_NEXT((elm), field); \
+ QMD_TRACE_HEAD(head); \
+ } \
+ TAILQ_NEXT((listelm), field) = (elm); \
+ (elm)->field.tqe_prev = &TAILQ_NEXT((listelm), field); \
+ QMD_TRACE_ELEM(&(elm)->field); \
+ QMD_TRACE_ELEM(&listelm->field); \
+} while (0)
+
+#define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \
+ (elm)->field.tqe_prev = (listelm)->field.tqe_prev; \
+ TAILQ_NEXT((elm), field) = (listelm); \
+ *(listelm)->field.tqe_prev = (elm); \
+ (listelm)->field.tqe_prev = &TAILQ_NEXT((elm), field); \
+ QMD_TRACE_ELEM(&(elm)->field); \
+ QMD_TRACE_ELEM(&listelm->field); \
+} while (0)
+
+#define TAILQ_INSERT_HEAD(head, elm, field) do { \
+ if ((TAILQ_NEXT((elm), field) = TAILQ_FIRST((head))) != NULL) \
+ TAILQ_FIRST((head))->field.tqe_prev = \
+ &TAILQ_NEXT((elm), field); \
+ else \
+ (head)->tqh_last = &TAILQ_NEXT((elm), field); \
+ TAILQ_FIRST((head)) = (elm); \
+ (elm)->field.tqe_prev = &TAILQ_FIRST((head)); \
+ QMD_TRACE_HEAD(head); \
+ QMD_TRACE_ELEM(&(elm)->field); \
+} while (0)
+
+#define TAILQ_INSERT_TAIL(head, elm, field) do { \
+ TAILQ_NEXT((elm), field) = NULL; \
+ (elm)->field.tqe_prev = (head)->tqh_last; \
+ *(head)->tqh_last = (elm); \
+ (head)->tqh_last = &TAILQ_NEXT((elm), field); \
+ QMD_TRACE_HEAD(head); \
+ QMD_TRACE_ELEM(&(elm)->field); \
+} while (0)
+
+#define TAILQ_LAST(head, headname) \
+ (*(((struct headname *)((head)->tqh_last))->tqh_last))
+
+#define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next)
+
+#define TAILQ_PREV(elm, headname, field) \
+ (*(((struct headname *)((elm)->field.tqe_prev))->tqh_last))
+
+#define TAILQ_REMOVE(head, elm, field) do { \
+ if ((TAILQ_NEXT((elm), field)) != NULL) \
+ TAILQ_NEXT((elm), field)->field.tqe_prev = \
+ (elm)->field.tqe_prev; \
+ else { \
+ (head)->tqh_last = (elm)->field.tqe_prev; \
+ QMD_TRACE_HEAD(head); \
+ } \
+ *(elm)->field.tqe_prev = TAILQ_NEXT((elm), field); \
+ TRASHIT((elm)->field.tqe_next); \
+ TRASHIT((elm)->field.tqe_prev); \
+ QMD_TRACE_ELEM(&(elm)->field); \
+} while (0)
+
+
+#ifdef _KERNEL
+
+/*
+ * XXX insque() and remque() are an old way of handling certain queues.
+ * They bogusly assumes that all queue heads look alike.
+ */
+
+struct quehead {
+ struct quehead *qh_link;
+ struct quehead *qh_rlink;
+};
+
+#if defined(__GNUC__) || defined(__INTEL_COMPILER)
+
+static __inline void
+insque(void *a, void *b)
+{
+ struct quehead *element = (struct quehead *)a,
+ *head = (struct quehead *)b;
+
+ element->qh_link = head->qh_link;
+ element->qh_rlink = head;
+ head->qh_link = element;
+ element->qh_link->qh_rlink = element;
+}
+
+static __inline void
+remque(void *a)
+{
+ struct quehead *element = (struct quehead *)a;
+
+ element->qh_link->qh_rlink = element->qh_rlink;
+ element->qh_rlink->qh_link = element->qh_link;
+ element->qh_rlink = 0;
+}
+
+#else /* !(__GNUC__ || __INTEL_COMPILER) */
+
+void insque(void *a, void *b);
+void remque(void *a);
+
+#endif /* __GNUC__ || __INTEL_COMPILER */
+
+#endif /* _KERNEL */
+
+#endif /* !_SYS_QUEUE_H_ */
+
diff --git a/host/include/regDb.h b/host/include/regDb.h
new file mode 100644
index 0000000..562bb05
--- /dev/null
+++ b/host/include/regDb.h
@@ -0,0 +1,29 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2005-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __REG_DB_H__
+#define __REG_DB_H__
+
+#include "./regulatory/reg_dbschema.h"
+#include "./regulatory/reg_dbvalues.h"
+
+#endif /* __REG_DB_H__ */
diff --git a/host/include/regdump.h b/host/include/regdump.h
new file mode 100644
index 0000000..f28a7a6
--- /dev/null
+++ b/host/include/regdump.h
@@ -0,0 +1,59 @@
+//------------------------------------------------------------------------------
+// <copyright file="regdump.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __REGDUMP_H__
+#define __REGDUMP_H__
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+#if defined(AR6001)
+#include "AR6001/AR6001_regdump.h"
+#endif
+#if defined(AR6002)
+#include "AR6002/AR6002_regdump.h"
+#endif
+
+#if !defined(__ASSEMBLER__)
+/*
+ * Target CPU state at the time of failure is reflected
+ * in a register dump, which the Host can fetch through
+ * the diagnostic window.
+ */
+PREPACK struct register_dump_s {
+ A_UINT32 target_id; /* Target ID */
+ A_UINT32 assline; /* Line number (if assertion failure) */
+ A_UINT32 pc; /* Program Counter at time of exception */
+ A_UINT32 badvaddr; /* Virtual address causing exception */
+ CPU_exception_frame_t exc_frame; /* CPU-specific exception info */
+
+ /* Could copy top of stack here, too.... */
+} POSTPACK;
+#endif /* __ASSEMBLER__ */
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#endif /* __REGDUMP_H__ */
diff --git a/host/include/roaming.h b/host/include/roaming.h
new file mode 100644
index 0000000..098508b
--- /dev/null
+++ b/host/include/roaming.h
@@ -0,0 +1,41 @@
+//------------------------------------------------------------------------------
+// <copyright file="roaming.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _ROAMING_H_
+#define _ROAMING_H_
+
+/*
+ * The signal quality could be in terms of either snr or rssi. We should
+ * have an enum for both of them. For the time being, we are going to move
+ * it to wmi.h that is shared by both host and the target, since we are
+ * repartitioning the code to the host
+ */
+#define SIGNAL_QUALITY_NOISE_FLOOR -96
+#define SIGNAL_QUALITY_METRICS_NUM_MAX 2
+typedef enum {
+ SIGNAL_QUALITY_METRICS_SNR = 0,
+ SIGNAL_QUALITY_METRICS_RSSI,
+ SIGNAL_QUALITY_METRICS_ALL,
+} SIGNAL_QUALITY_METRICS_TYPE;
+
+#endif /* _ROAMING_H_ */
diff --git a/host/include/targaddrs.h b/host/include/targaddrs.h
new file mode 100644
index 0000000..3848f65
--- /dev/null
+++ b/host/include/targaddrs.h
@@ -0,0 +1,399 @@
+//------------------------------------------------------------------------------
+// <copyright file="targaddrs.h" company="Atheros">
+// Copyright (c) 2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __TARGADDRS_H__
+#define __TARGADDRS_H__
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+#if defined(AR6002)
+#include "AR6002/addrs.h"
+#endif
+
+/*
+ * AR6K option bits, to enable/disable various features.
+ * By default, all option bits are 0.
+ * These bits can be set in LOCAL_SCRATCH register 0.
+ */
+#define AR6K_OPTION_BMI_DISABLE 0x01 /* Disable BMI comm with Host */
+#define AR6K_OPTION_SERIAL_ENABLE 0x02 /* Enable serial port msgs */
+#define AR6K_OPTION_WDT_DISABLE 0x04 /* WatchDog Timer override */
+#define AR6K_OPTION_SLEEP_DISABLE 0x08 /* Disable system sleep */
+#define AR6K_OPTION_STOP_BOOT 0x10 /* Stop boot processes (for ATE) */
+#define AR6K_OPTION_ENABLE_NOANI 0x20 /* Operate without ANI */
+#define AR6K_OPTION_DSET_DISABLE 0x40 /* Ignore DataSets */
+#define AR6K_OPTION_IGNORE_FLASH 0x80 /* Ignore flash during bootup */
+
+/*
+ * xxx_HOST_INTEREST_ADDRESS is the address in Target RAM of the
+ * host_interest structure. It must match the address of the _host_interest
+ * symbol (see linker script).
+ *
+ * Host Interest is shared between Host and Target in order to coordinate
+ * between the two, and is intended to remain constant (with additions only
+ * at the end) across software releases.
+ *
+ * All addresses are available here so that it's possible to
+ * write a single binary that works with all Target Types.
+ * May be used in assembler code as well as C.
+ */
+#define AR6002_HOST_INTEREST_ADDRESS 0x00500400
+#define AR6003_HOST_INTEREST_ADDRESS 0x00540600
+#define MCKINLEY_HOST_INTEREST_ADDRESS 0x00400600
+
+
+#define HOST_INTEREST_MAX_SIZE 0x100
+
+#if !defined(__ASSEMBLER__)
+struct register_dump_s;
+struct dbglog_hdr_s;
+
+/*
+ * These are items that the Host may need to access
+ * via BMI or via the Diagnostic Window. The position
+ * of items in this structure must remain constant
+ * across firmware revisions!
+ *
+ * Types for each item must be fixed size across
+ * target and host platforms.
+ *
+ * More items may be added at the end.
+ */
+PREPACK64 struct host_interest_s {
+ /*
+ * Pointer to application-defined area, if any.
+ * Set by Target application during startup.
+ */
+ A_UINT32 hi_app_host_interest; /* 0x00 */
+
+ /* Pointer to register dump area, valid after Target crash. */
+ A_UINT32 hi_failure_state; /* 0x04 */
+
+ /* Pointer to debug logging header */
+ A_UINT32 hi_dbglog_hdr; /* 0x08 */
+
+ /* Indicates whether or not flash is present on Target.
+ * NB: flash_is_present indicator is here not just
+ * because it might be of interest to the Host; but
+ * also because it's set early on by Target's startup
+ * asm code and we need it to have a special RAM address
+ * so that it doesn't get reinitialized with the rest
+ * of data.
+ */
+ A_UINT32 hi_flash_is_present; /* 0x0c */
+
+ /*
+ * General-purpose flag bits, similar to AR6000_OPTION_* flags.
+ * Can be used by application rather than by OS.
+ */
+ A_UINT32 hi_option_flag; /* 0x10 */
+
+ /*
+ * Boolean that determines whether or not to
+ * display messages on the serial port.
+ */
+ A_UINT32 hi_serial_enable; /* 0x14 */
+
+ /* Start address of DataSet index, if any */
+ A_UINT32 hi_dset_list_head; /* 0x18 */
+
+ /* Override Target application start address */
+ A_UINT32 hi_app_start; /* 0x1c */
+
+ /* Clock and voltage tuning */
+ A_UINT32 hi_skip_clock_init; /* 0x20 */
+ A_UINT32 hi_core_clock_setting; /* 0x24 */
+ A_UINT32 hi_cpu_clock_setting; /* 0x28 */
+ A_UINT32 hi_system_sleep_setting; /* 0x2c */
+ A_UINT32 hi_xtal_control_setting; /* 0x30 */
+ A_UINT32 hi_pll_ctrl_setting_24ghz; /* 0x34 */
+ A_UINT32 hi_pll_ctrl_setting_5ghz; /* 0x38 */
+ A_UINT32 hi_ref_voltage_trim_setting; /* 0x3c */
+ A_UINT32 hi_clock_info; /* 0x40 */
+
+ /*
+ * Flash configuration overrides, used only
+ * when firmware is not executing from flash.
+ * (When using flash, modify the global variables
+ * with equivalent names.)
+ */
+ A_UINT32 hi_bank0_addr_value; /* 0x44 */
+ A_UINT32 hi_bank0_read_value; /* 0x48 */
+ A_UINT32 hi_bank0_write_value; /* 0x4c */
+ A_UINT32 hi_bank0_config_value; /* 0x50 */
+
+ /* Pointer to Board Data */
+ A_UINT32 hi_board_data; /* 0x54 */
+ A_UINT32 hi_board_data_initialized; /* 0x58 */
+
+ A_UINT32 hi_dset_RAM_index_table; /* 0x5c */
+
+ A_UINT32 hi_desired_baud_rate; /* 0x60 */
+ A_UINT32 hi_dbglog_config; /* 0x64 */
+ A_UINT32 hi_end_RAM_reserve_sz; /* 0x68 */
+ A_UINT32 hi_mbox_io_block_sz; /* 0x6c */
+
+ A_UINT32 hi_num_bpatch_streams; /* 0x70 -- unused */
+ A_UINT32 hi_mbox_isr_yield_limit; /* 0x74 */
+
+ A_UINT32 hi_refclk_hz; /* 0x78 */
+ A_UINT32 hi_ext_clk_detected; /* 0x7c */
+ A_UINT32 hi_dbg_uart_txpin; /* 0x80 */
+ A_UINT32 hi_dbg_uart_rxpin; /* 0x84 */
+ A_UINT32 hi_hci_uart_baud; /* 0x88 */
+ A_UINT32 hi_hci_uart_pin_assignments; /* 0x8C */
+ /* NOTE: byte [0] = tx pin, [1] = rx pin, [2] = rts pin, [3] = cts pin */
+ A_UINT32 hi_hci_uart_baud_scale_val; /* 0x90 */
+ A_UINT32 hi_hci_uart_baud_step_val; /* 0x94 */
+
+ A_UINT32 hi_allocram_start; /* 0x98 */
+ A_UINT32 hi_allocram_sz; /* 0x9c */
+ A_UINT32 hi_hci_bridge_flags; /* 0xa0 */
+ A_UINT32 hi_hci_uart_support_pins; /* 0xa4 */
+ /* NOTE: byte [0] = RESET pin (bit 7 is polarity), bytes[1]..bytes[3] are for future use */
+ A_UINT32 hi_hci_uart_pwr_mgmt_params; /* 0xa8 */
+ /* 0xa8 - [1]: 0 = UART FC active low, 1 = UART FC active high
+ * [31:16]: wakeup timeout in ms
+ */
+ /* Pointer to extended board Data */
+ A_UINT32 hi_board_ext_data; /* 0xac */
+ A_UINT32 hi_board_ext_data_config; /* 0xb0 */
+ /*
+ * Bit [0] : valid
+ * Bit[31:16: size
+ */
+ /*
+ * hi_reset_flag is used to do some stuff when target reset.
+ * such as restore app_start after warm reset or
+ * preserve host Interest area, or preserve ROM data, literals etc.
+ */
+ A_UINT32 hi_reset_flag; /* 0xb4 */
+ /* indicate hi_reset_flag is valid */
+ A_UINT32 hi_reset_flag_valid; /* 0xb8 */
+ A_UINT32 hi_hci_uart_pwr_mgmt_params_ext; /* 0xbc */
+ /* 0xbc - [31:0]: idle timeout in ms
+ */
+ /* ACS flags */
+ A_UINT32 hi_acs_flags; /* 0xc0 */
+ A_UINT32 hi_console_flags; /* 0xc4 */
+ A_UINT32 hi_nvram_state; /* 0xc8 */
+ A_UINT32 hi_option_flag2; /* 0xcc */
+
+ /* If non-zero, override values sent to Host in WMI_READY event. */
+ A_UINT32 hi_sw_version_override; /* 0xd0 */
+ A_UINT32 hi_abi_version_override; /* 0xd4 */
+
+ /* test applications flags */
+ A_UINT32 hi_test_apps_related ; /* 0xd8 */
+ /* location of test script */
+ A_UINT32 hi_ota_testscript; /* 0xdc */
+ /* location of CAL data */
+ A_UINT32 hi_cal_data; /* 0xe0 */
+
+} POSTPACK64;
+/* bitmap for hi_test_apps_related */
+#define HI_TEST_APPS_TESTSCRIPT_LOADED 0x00000001
+#define HI_TEST_APPS_CAL_DATA_AVAIL 0x00000002
+
+/* Bits defined in hi_option_flag */
+#define HI_OPTION_TIMER_WAR 0x01 /* Enable timer workaround */
+#define HI_OPTION_BMI_CRED_LIMIT 0x02 /* Limit BMI command credits */
+#define HI_OPTION_RELAY_DOT11_HDR 0x04 /* Relay Dot11 hdr to/from host */
+#define HI_OPTION_MAC_ADDR_METHOD 0x08 /* MAC addr method 0-locally administred 1-globally unique addrs */
+#define HI_OPTION_ENABLE_RFKILL 0x10 /* RFKill Enable Feature*/
+#define HI_OPTION_ENABLE_PROFILE 0x20 /* Enable CPU profiling */
+#define HI_OPTION_DISABLE_DBGLOG 0x40 /* Disable debug logging */
+#define HI_OPTION_SKIP_ERA_TRACKING 0x80 /* Skip Era Tracking */
+#define HI_OPTION_PAPRD_DISABLE 0x100 /* Disable PAPRD (debug) */
+#define HI_OPTION_NUM_DEV_LSB 0x200
+#define HI_OPTION_NUM_DEV_MSB 0x800
+#define HI_OPTION_DEV_MODE_LSB 0x1000
+#define HI_OPTION_DEV_MODE_MSB 0x8000000
+#define HI_OPTION_NO_LFT_STBL 0x10000000 /* Disable LowFreq Timer Stabilization */
+#define HI_OPTION_SKIP_REG_SCAN 0x20000000 /* Skip regulatory scan */
+#define HI_OPTION_INIT_REG_SCAN 0x40000000 /* Do regulatory scan during init before sending WMI ready event to host */
+#define HI_OPTION_FW_BRIDGE 0x80000000
+
+#define HI_OPTION_OFFLOAD_AMSDU 0x01
+#define HI_OPTION_MAC_ADDR_METHOD_SHIFT 3
+
+/* 2 bits of hi_option_flag are used to represent 3 modes */
+#define HI_OPTION_FW_MODE_IBSS 0x0 /* IBSS Mode */
+#define HI_OPTION_FW_MODE_BSS_STA 0x1 /* STA Mode */
+#define HI_OPTION_FW_MODE_AP 0x2 /* AP Mode */
+#define HI_OPTION_FW_MODE_BT30AMP 0x3 /* BT30 AMP Mode */
+
+/* 2 bits of hi_option flag are usedto represent 4 submodes */
+#define HI_OPTION_FW_SUBMODE_NONE 0x0 /* Normal mode */
+#define HI_OPTION_FW_SUBMODE_P2PDEV 0x1 /* p2p device mode */
+#define HI_OPTION_FW_SUBMODE_P2PCLIENT 0x2 /* p2p client mode */
+#define HI_OPTION_FW_SUBMODE_P2PGO 0x3 /* p2p go mode */
+
+/* Num dev Mask */
+#define HI_OPTION_NUM_DEV_MASK 0x7
+#define HI_OPTION_NUM_DEV_SHIFT 0x9
+
+#define HI_OPTION_RF_KILL_SHIFT 0x4
+#define HI_OPTION_RF_KILL_MASK 0x1
+
+/* firmware bridging */
+#define HI_OPTION_FW_BRIDGE_SHIFT 0x1f
+
+/* Fw Mode/SubMode Mask
+|-------------------------------------------------------------------------------|
+| SUB | SUB | SUB | SUB | | | | |
+| MODE[3] | MODE[2] | MODE[1] | MODE[0] | MODE[3] | MODE[2] | MODE[1] | MODE[0] |
+| (2) | (2) | (2) | (2) | (2) | (2) | (2) | (2) |
+|-------------------------------------------------------------------------------|
+*/
+#define HI_OPTION_FW_MODE_BITS 0x2
+#define HI_OPTION_FW_MODE_MASK 0x3
+#define HI_OPTION_FW_MODE_SHIFT 0xC
+#define HI_OPTION_ALL_FW_MODE_MASK 0xFF
+
+#define HI_OPTION_FW_SUBMODE_BITS 0x2
+#define HI_OPTION_FW_SUBMODE_MASK 0x3
+#define HI_OPTION_FW_SUBMODE_SHIFT 0x14
+#define HI_OPTION_ALL_FW_SUBMODE_MASK 0xFF00
+#define HI_OPTION_ALL_FW_SUBMODE_SHIFT 0x8
+
+/* hi_reset_flag */
+#define HI_RESET_FLAG_PRESERVE_APP_START 0x01 /* preserve App Start address */
+#define HI_RESET_FLAG_PRESERVE_HOST_INTEREST 0x02 /* preserve host interest */
+#define HI_RESET_FLAG_PRESERVE_ROMDATA 0x04 /* preserve ROM data */
+#define HI_RESET_FLAG_PRESERVE_NVRAM_STATE 0x08
+
+#define HI_RESET_FLAG_IS_VALID 0x12345678 /* indicate the reset flag is valid */
+
+#define ON_RESET_FLAGS_VALID() \
+ (HOST_INTEREST->hi_reset_flag_valid == HI_RESET_FLAG_IS_VALID)
+
+#define RESET_FLAGS_VALIDATE() \
+ (HOST_INTEREST->hi_reset_flag_valid = HI_RESET_FLAG_IS_VALID)
+
+#define RESET_FLAGS_INVALIDATE() \
+ (HOST_INTEREST->hi_reset_flag_valid = 0)
+
+#define ON_RESET_PRESERVE_APP_START() \
+ (HOST_INTEREST->hi_reset_flag & HI_RESET_FLAG_PRESERVE_APP_START)
+
+#define ON_RESET_PRESERVE_NVRAM_STATE() \
+ (HOST_INTEREST->hi_reset_flag & HI_RESET_FLAG_PRESERVE_NVRAM_STATE)
+
+#define ON_RESET_PRESERVE_HOST_INTEREST() \
+ (HOST_INTEREST->hi_reset_flag & HI_RESET_FLAG_PRESERVE_HOST_INTEREST)
+
+#define ON_RESET_PRESERVE_ROMDATA() \
+ (HOST_INTEREST->hi_reset_flag & HI_RESET_FLAG_PRESERVE_ROMDATA)
+
+#define HI_ACS_FLAGS_ENABLED (1 << 0) /* ACS is enabled */
+#define HI_ACS_FLAGS_USE_WWAN (1 << 1) /* Use physical WWAN device */
+#define HI_ACS_FLAGS_TEST_VAP (1 << 2) /* Use test VAP */
+
+/* CONSOLE FLAGS
+ *
+ * Bit Range Meaning
+ * --------- --------------------------------
+ * 2..0 UART ID (0 = Default)
+ * 3 Baud Select (0 = 9600, 1 = 115200)
+ * 30..4 Reserved
+ * 31 Enable Console
+ *
+ * */
+
+#define HI_CONSOLE_FLAGS_ENABLE (1 << 31)
+#define HI_CONSOLE_FLAGS_UART_MASK (0x7)
+#define HI_CONSOLE_FLAGS_UART_SHIFT 0
+#define HI_CONSOLE_FLAGS_BAUD_SELECT (1 << 3)
+
+/*
+ * Intended for use by Host software, this macro returns the Target RAM
+ * address of any item in the host_interest structure.
+ * Example: target_addr = AR6002_HOST_INTEREST_ITEM_ADDRESS(hi_board_data);
+ */
+#define AR6002_HOST_INTEREST_ITEM_ADDRESS(item) \
+ (A_UINT32)((unsigned long)&((((struct host_interest_s *)(AR6002_HOST_INTEREST_ADDRESS))->item)))
+
+#define AR6003_HOST_INTEREST_ITEM_ADDRESS(item) \
+ (A_UINT32)((unsigned long)&((((struct host_interest_s *)(AR6003_HOST_INTEREST_ADDRESS))->item)))
+
+#define MCKINLEY_HOST_INTEREST_ITEM_ADDRESS(item) \
+ ((A_UINT32)&((((struct host_interest_s *)(MCKINLEY_HOST_INTEREST_ADDRESS))->item)))
+
+#define HOST_INTEREST_DBGLOG_IS_ENABLED() \
+ (!(HOST_INTEREST->hi_option_flag & HI_OPTION_DISABLE_DBGLOG))
+
+#define HOST_INTEREST_PROFILE_IS_ENABLED() \
+ (HOST_INTEREST->hi_option_flag & HI_OPTION_ENABLE_PROFILE)
+
+#define LF_TIMER_STABILIZATION_IS_ENABLED() \
+ (!(HOST_INTEREST->hi_option_flag & HI_OPTION_NO_LFT_STBL))
+
+#define IS_AMSDU_OFFLAOD_ENABLED() \
+ ((HOST_INTEREST->hi_option_flag2 & HI_OPTION_OFFLOAD_AMSDU))
+
+/* Convert a Target virtual address into a Target physical address */
+#define AR6002_VTOP(vaddr) ((vaddr) & 0x001fffff)
+#define AR6003_VTOP(vaddr) ((vaddr) & 0x001fffff)
+#define MCKINLEY_VTOP(vaddr) (vaddr)
+#define TARG_VTOP(TargetType, vaddr) \
+ (((TargetType) == TARGET_TYPE_AR6002) ? AR6002_VTOP(vaddr) : \
+ (((TargetType) == TARGET_TYPE_AR6003) ? AR6003_VTOP(vaddr) : \
+ (((TargetType) == TARGET_TYPE_MCKINLEY) ? MCKINLEY_VTOP(vaddr) : 0)))
+
+#define HOST_INTEREST_ITEM_ADDRESS(TargetType, item) \
+ (((TargetType) == TARGET_TYPE_AR6002) ? AR6002_HOST_INTEREST_ITEM_ADDRESS(item) : \
+ (((TargetType) == TARGET_TYPE_AR6003) ? AR6003_HOST_INTEREST_ITEM_ADDRESS(item) : \
+ (((TargetType) == TARGET_TYPE_MCKINLEY) ? MCKINLEY_HOST_INTEREST_ITEM_ADDRESS(item) : 0)))
+
+/* override REV2 ROM's app start address */
+#define AR6002_REV2_APP_START_OVERRIDE 0x911A00
+#define AR6002_REV2_DATASET_PATCH_ADDRESS 0x52d8b0
+#define AR6002_REV2_APP_LOAD_ADDRESS 0x502070
+
+#define AR6003_REV2_APP_START_OVERRIDE 0x944C00
+#define AR6003_REV2_APP_LOAD_ADDRESS 0x543180
+#define AR6003_REV2_BOARD_EXT_DATA_ADDRESS 0x57E500
+#define AR6003_REV2_DATASET_PATCH_ADDRESS 0x57e884
+#define AR6003_REV2_RAM_RESERVE_SIZE 6912
+
+#define AR6003_REV3_APP_START_OVERRIDE 0x945E20
+#define AR6003_REV3_APP_LOAD_ADDRESS 0x545000
+#define AR6003_REV3_BOARD_EXT_DATA_ADDRESS 0x542330
+#define AR6003_REV3_DATASET_PATCH_ADDRESS 0x57FEC8
+#define AR6003_REV3_RAM_RESERVE_SIZE 512
+#define AR6003_REV3_RAM_RESERVE_SIZE_TCMD 4352
+
+/* # of A_UINT32 entries in targregs, used by DIAG_FETCH_TARG_REGS */
+#define AR6003_FETCH_TARG_REGS_COUNT 64
+#define MCKINLEY_FETCH_TARG_REGS_COUNT 64
+
+#endif /* !__ASSEMBLER__ */
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#endif /* __TARGADDRS_H__ */
diff --git a/host/include/target_reg_table.h b/host/include/target_reg_table.h
new file mode 100644
index 0000000..d868a00
--- /dev/null
+++ b/host/include/target_reg_table.h
@@ -0,0 +1,353 @@
+//------------------------------------------------------------------------------
+// <copyright file="target_reg_table.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Target register table macros and structure definitions
+//
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef TARGET_REG_TABLE_H_
+#define TARGET_REG_TABLE_H_
+
+#include "targaddrs.h"
+/*** WARNING : Add to the end of the TABLE! do not change the order ****/
+typedef struct targetdef_s {
+ A_UINT32 d_RTC_SOC_BASE_ADDRESS;
+ A_UINT32 d_RTC_WMAC_BASE_ADDRESS;
+ A_UINT32 d_SYSTEM_SLEEP_OFFSET;
+ A_UINT32 d_WLAN_SYSTEM_SLEEP_OFFSET;
+ A_UINT32 d_WLAN_SYSTEM_SLEEP_DISABLE_LSB;
+ A_UINT32 d_WLAN_SYSTEM_SLEEP_DISABLE_MASK;
+ A_UINT32 d_CLOCK_CONTROL_OFFSET;
+ A_UINT32 d_CLOCK_CONTROL_SI0_CLK_MASK;
+ A_UINT32 d_RESET_CONTROL_OFFSET;
+ A_UINT32 d_RESET_CONTROL_MBOX_RST_MASK;
+ A_UINT32 d_RESET_CONTROL_SI0_RST_MASK;
+ A_UINT32 d_WLAN_RESET_CONTROL_OFFSET;
+ A_UINT32 d_WLAN_RESET_CONTROL_COLD_RST_MASK;
+ A_UINT32 d_WLAN_RESET_CONTROL_WARM_RST_MASK;
+ A_UINT32 d_GPIO_BASE_ADDRESS;
+ A_UINT32 d_GPIO_PIN0_OFFSET;
+ A_UINT32 d_GPIO_PIN1_OFFSET;
+ A_UINT32 d_GPIO_PIN0_CONFIG_MASK;
+ A_UINT32 d_GPIO_PIN1_CONFIG_MASK;
+ A_UINT32 d_SI_CONFIG_BIDIR_OD_DATA_LSB;
+ A_UINT32 d_SI_CONFIG_BIDIR_OD_DATA_MASK;
+ A_UINT32 d_SI_CONFIG_I2C_LSB;
+ A_UINT32 d_SI_CONFIG_I2C_MASK;
+ A_UINT32 d_SI_CONFIG_POS_SAMPLE_LSB;
+ A_UINT32 d_SI_CONFIG_POS_SAMPLE_MASK;
+ A_UINT32 d_SI_CONFIG_INACTIVE_CLK_LSB;
+ A_UINT32 d_SI_CONFIG_INACTIVE_CLK_MASK;
+ A_UINT32 d_SI_CONFIG_INACTIVE_DATA_LSB;
+ A_UINT32 d_SI_CONFIG_INACTIVE_DATA_MASK;
+ A_UINT32 d_SI_CONFIG_DIVIDER_LSB;
+ A_UINT32 d_SI_CONFIG_DIVIDER_MASK;
+ A_UINT32 d_SI_BASE_ADDRESS;
+ A_UINT32 d_SI_CONFIG_OFFSET;
+ A_UINT32 d_SI_TX_DATA0_OFFSET;
+ A_UINT32 d_SI_TX_DATA1_OFFSET;
+ A_UINT32 d_SI_RX_DATA0_OFFSET;
+ A_UINT32 d_SI_RX_DATA1_OFFSET;
+ A_UINT32 d_SI_CS_OFFSET;
+ A_UINT32 d_SI_CS_DONE_ERR_MASK;
+ A_UINT32 d_SI_CS_DONE_INT_MASK;
+ A_UINT32 d_SI_CS_START_LSB;
+ A_UINT32 d_SI_CS_START_MASK;
+ A_UINT32 d_SI_CS_RX_CNT_LSB;
+ A_UINT32 d_SI_CS_RX_CNT_MASK;
+ A_UINT32 d_SI_CS_TX_CNT_LSB;
+ A_UINT32 d_SI_CS_TX_CNT_MASK;
+ A_UINT32 d_BOARD_DATA_SZ;
+ A_UINT32 d_BOARD_EXT_DATA_SZ;
+ A_UINT32 d_MBOX_BASE_ADDRESS;
+ A_UINT32 d_LOCAL_SCRATCH_OFFSET;
+ A_UINT32 d_CPU_CLOCK_OFFSET;
+ A_UINT32 d_LPO_CAL_OFFSET;
+ A_UINT32 d_GPIO_PIN10_OFFSET;
+ A_UINT32 d_GPIO_PIN11_OFFSET;
+ A_UINT32 d_GPIO_PIN12_OFFSET;
+ A_UINT32 d_GPIO_PIN13_OFFSET;
+ A_UINT32 d_CLOCK_GPIO_OFFSET;
+ A_UINT32 d_CPU_CLOCK_STANDARD_LSB;
+ A_UINT32 d_CPU_CLOCK_STANDARD_MASK;
+ A_UINT32 d_LPO_CAL_ENABLE_LSB;
+ A_UINT32 d_LPO_CAL_ENABLE_MASK;
+ A_UINT32 d_CLOCK_GPIO_BT_CLK_OUT_EN_LSB;
+ A_UINT32 d_CLOCK_GPIO_BT_CLK_OUT_EN_MASK;
+ A_UINT32 d_ANALOG_INTF_BASE_ADDRESS;
+ A_UINT32 d_GPIO_PIN9_OFFSET;
+} TARGET_REGISTER_TABLE;
+
+#define ATH_UNSUPPORTED_REG_OFFSET 0xffffffff
+#define ATH_SUPPORTED_BY_TARGET(reg_offset) ((reg_offset) != ATH_UNSUPPORTED_REG_OFFSET)
+
+#define BOARD_DATA_SZ_MAX 2048
+
+#if defined(MY_TARGET_DEF) /* { */
+#if defined(ATHR_WIN_DEF)
+#define ATH_REG_TABLE_DIRECT_ASSIGN
+#endif
+
+/* Cross-platform compatibility */
+#if !defined(SOC_RESET_CONTROL_OFFSET) && defined(RESET_CONTROL_OFFSET)
+#define SOC_RESET_CONTROL_OFFSET RESET_CONTROL_OFFSET
+#endif
+#if !defined(CLOCK_GPIO_OFFSET)
+#define CLOCK_GPIO_OFFSET ATH_UNSUPPORTED_REG_OFFSET
+#define CLOCK_GPIO_BT_CLK_OUT_EN_LSB 0
+#define CLOCK_GPIO_BT_CLK_OUT_EN_MASK 0
+#endif
+
+#ifdef ATH_REG_TABLE_DIRECT_ASSIGN
+
+static struct targetdef_s my_target_def = {
+ RTC_SOC_BASE_ADDRESS,
+ RTC_WMAC_BASE_ADDRESS,
+ SYSTEM_SLEEP_OFFSET,
+ WLAN_SYSTEM_SLEEP_OFFSET,
+ WLAN_SYSTEM_SLEEP_DISABLE_LSB,
+ WLAN_SYSTEM_SLEEP_DISABLE_MASK,
+ CLOCK_CONTROL_OFFSET,
+ CLOCK_CONTROL_SI0_CLK_MASK,
+ SOC_RESET_CONTROL_OFFSET,
+ RESET_CONTROL_MBOX_RST_MASK,
+ RESET_CONTROL_SI0_RST_MASK,
+ WLAN_RESET_CONTROL_OFFSET,
+ WLAN_RESET_CONTROL_COLD_RST_MASK,
+ WLAN_RESET_CONTROL_WARM_RST_MASK,
+ GPIO_BASE_ADDRESS,
+ GPIO_PIN0_OFFSET,
+ GPIO_PIN1_OFFSET,
+ GPIO_PIN0_CONFIG_MASK,
+ GPIO_PIN1_CONFIG_MASK,
+ SI_CONFIG_BIDIR_OD_DATA_LSB,
+ SI_CONFIG_BIDIR_OD_DATA_MASK,
+ SI_CONFIG_I2C_LSB,
+ SI_CONFIG_I2C_MASK,
+ SI_CONFIG_POS_SAMPLE_LSB,
+ SI_CONFIG_POS_SAMPLE_MASK,
+ SI_CONFIG_INACTIVE_CLK_LSB,
+ SI_CONFIG_INACTIVE_CLK_MASK,
+ SI_CONFIG_INACTIVE_DATA_LSB,
+ SI_CONFIG_INACTIVE_DATA_MASK,
+ SI_CONFIG_DIVIDER_LSB,
+ SI_CONFIG_DIVIDER_MASK,
+ SI_BASE_ADDRESS,
+ SI_CONFIG_OFFSET,
+ SI_TX_DATA0_OFFSET,
+ SI_TX_DATA1_OFFSET,
+ SI_RX_DATA0_OFFSET,
+ SI_RX_DATA1_OFFSET,
+ SI_CS_OFFSET,
+ SI_CS_DONE_ERR_MASK,
+ SI_CS_DONE_INT_MASK,
+ SI_CS_START_LSB,
+ SI_CS_START_MASK,
+ SI_CS_RX_CNT_LSB,
+ SI_CS_RX_CNT_MASK,
+ SI_CS_TX_CNT_LSB,
+ SI_CS_TX_CNT_MASK,
+ MY_TARGET_BOARD_DATA_SZ,
+ MY_TARGET_BOARD_EXT_DATA_SZ,
+ MBOX_BASE_ADDRESS,
+ LOCAL_SCRATCH_OFFSET,
+ CPU_CLOCK_OFFSET,
+ LPO_CAL_OFFSET,
+ GPIO_PIN10_OFFSET,
+ GPIO_PIN11_OFFSET,
+ GPIO_PIN12_OFFSET,
+ GPIO_PIN13_OFFSET,
+ CLOCK_GPIO_OFFSET,
+ CPU_CLOCK_STANDARD_LSB,
+ CPU_CLOCK_STANDARD_MASK,
+ LPO_CAL_ENABLE_LSB,
+ LPO_CAL_ENABLE_MASK,
+ CLOCK_GPIO_BT_CLK_OUT_EN_LSB,
+ CLOCK_GPIO_BT_CLK_OUT_EN_MASK,
+ ANALOG_INTF_BASE_ADDRESS,
+ GPIO_PIN9_OFFSET,
+};
+
+#else
+
+static struct targetdef_s my_target_def = {
+ .d_RTC_SOC_BASE_ADDRESS = RTC_SOC_BASE_ADDRESS,
+ .d_RTC_WMAC_BASE_ADDRESS = RTC_WMAC_BASE_ADDRESS,
+ .d_SYSTEM_SLEEP_OFFSET = WLAN_SYSTEM_SLEEP_OFFSET,
+ .d_WLAN_SYSTEM_SLEEP_OFFSET = WLAN_SYSTEM_SLEEP_OFFSET,
+ .d_WLAN_SYSTEM_SLEEP_DISABLE_LSB = WLAN_SYSTEM_SLEEP_DISABLE_LSB,
+ .d_WLAN_SYSTEM_SLEEP_DISABLE_MASK = WLAN_SYSTEM_SLEEP_DISABLE_MASK,
+ .d_CLOCK_CONTROL_OFFSET = CLOCK_CONTROL_OFFSET,
+ .d_CLOCK_CONTROL_SI0_CLK_MASK = CLOCK_CONTROL_SI0_CLK_MASK,
+ .d_RESET_CONTROL_OFFSET = SOC_RESET_CONTROL_OFFSET,
+ .d_RESET_CONTROL_MBOX_RST_MASK = RESET_CONTROL_MBOX_RST_MASK,
+ .d_RESET_CONTROL_SI0_RST_MASK = RESET_CONTROL_SI0_RST_MASK,
+ .d_WLAN_RESET_CONTROL_OFFSET = WLAN_RESET_CONTROL_OFFSET,
+ .d_WLAN_RESET_CONTROL_COLD_RST_MASK = WLAN_RESET_CONTROL_COLD_RST_MASK,
+ .d_WLAN_RESET_CONTROL_WARM_RST_MASK = WLAN_RESET_CONTROL_WARM_RST_MASK,
+ .d_GPIO_BASE_ADDRESS = GPIO_BASE_ADDRESS,
+ .d_GPIO_PIN0_OFFSET = GPIO_PIN0_OFFSET,
+ .d_GPIO_PIN1_OFFSET = GPIO_PIN1_OFFSET,
+ .d_GPIO_PIN0_CONFIG_MASK = GPIO_PIN0_CONFIG_MASK,
+ .d_GPIO_PIN1_CONFIG_MASK = GPIO_PIN1_CONFIG_MASK,
+ .d_SI_CONFIG_BIDIR_OD_DATA_LSB = SI_CONFIG_BIDIR_OD_DATA_LSB,
+ .d_SI_CONFIG_BIDIR_OD_DATA_MASK = SI_CONFIG_BIDIR_OD_DATA_MASK,
+ .d_SI_CONFIG_I2C_LSB = SI_CONFIG_I2C_LSB,
+ .d_SI_CONFIG_I2C_MASK = SI_CONFIG_I2C_MASK,
+ .d_SI_CONFIG_POS_SAMPLE_LSB = SI_CONFIG_POS_SAMPLE_LSB,
+ .d_SI_CONFIG_POS_SAMPLE_MASK = SI_CONFIG_POS_SAMPLE_MASK,
+ .d_SI_CONFIG_INACTIVE_CLK_LSB = SI_CONFIG_INACTIVE_CLK_LSB,
+ .d_SI_CONFIG_INACTIVE_CLK_MASK = SI_CONFIG_INACTIVE_CLK_MASK,
+ .d_SI_CONFIG_INACTIVE_DATA_LSB = SI_CONFIG_INACTIVE_DATA_LSB,
+ .d_SI_CONFIG_INACTIVE_DATA_MASK = SI_CONFIG_INACTIVE_DATA_MASK,
+ .d_SI_CONFIG_DIVIDER_LSB = SI_CONFIG_DIVIDER_LSB,
+ .d_SI_CONFIG_DIVIDER_MASK = SI_CONFIG_DIVIDER_MASK,
+ .d_SI_BASE_ADDRESS = SI_BASE_ADDRESS,
+ .d_SI_CONFIG_OFFSET = SI_CONFIG_OFFSET,
+ .d_SI_TX_DATA0_OFFSET = SI_TX_DATA0_OFFSET,
+ .d_SI_TX_DATA1_OFFSET = SI_TX_DATA1_OFFSET,
+ .d_SI_RX_DATA0_OFFSET = SI_RX_DATA0_OFFSET,
+ .d_SI_RX_DATA1_OFFSET = SI_RX_DATA1_OFFSET,
+ .d_SI_CS_OFFSET = SI_CS_OFFSET,
+ .d_SI_CS_DONE_ERR_MASK = SI_CS_DONE_ERR_MASK,
+ .d_SI_CS_DONE_INT_MASK = SI_CS_DONE_INT_MASK,
+ .d_SI_CS_START_LSB = SI_CS_START_LSB,
+ .d_SI_CS_START_MASK = SI_CS_START_MASK,
+ .d_SI_CS_RX_CNT_LSB = SI_CS_RX_CNT_LSB,
+ .d_SI_CS_RX_CNT_MASK = SI_CS_RX_CNT_MASK,
+ .d_SI_CS_TX_CNT_LSB = SI_CS_TX_CNT_LSB,
+ .d_SI_CS_TX_CNT_MASK = SI_CS_TX_CNT_MASK,
+ .d_BOARD_DATA_SZ = MY_TARGET_BOARD_DATA_SZ,
+ .d_BOARD_EXT_DATA_SZ = MY_TARGET_BOARD_EXT_DATA_SZ,
+ .d_MBOX_BASE_ADDRESS = MBOX_BASE_ADDRESS,
+ .d_LOCAL_SCRATCH_OFFSET = LOCAL_SCRATCH_OFFSET,
+ .d_CPU_CLOCK_OFFSET = CPU_CLOCK_OFFSET,
+ .d_LPO_CAL_OFFSET = LPO_CAL_OFFSET,
+ .d_GPIO_PIN10_OFFSET = GPIO_PIN10_OFFSET,
+ .d_GPIO_PIN11_OFFSET = GPIO_PIN11_OFFSET,
+ .d_GPIO_PIN12_OFFSET = GPIO_PIN12_OFFSET,
+ .d_GPIO_PIN13_OFFSET = GPIO_PIN13_OFFSET,
+ .d_CLOCK_GPIO_OFFSET = CLOCK_GPIO_OFFSET,
+ .d_CPU_CLOCK_STANDARD_LSB = CPU_CLOCK_STANDARD_LSB,
+ .d_CPU_CLOCK_STANDARD_MASK = CPU_CLOCK_STANDARD_MASK,
+ .d_LPO_CAL_ENABLE_LSB = LPO_CAL_ENABLE_LSB,
+ .d_LPO_CAL_ENABLE_MASK = LPO_CAL_ENABLE_MASK,
+ .d_CLOCK_GPIO_BT_CLK_OUT_EN_LSB = CLOCK_GPIO_BT_CLK_OUT_EN_LSB,
+ .d_CLOCK_GPIO_BT_CLK_OUT_EN_MASK = CLOCK_GPIO_BT_CLK_OUT_EN_MASK,
+ .d_ANALOG_INTF_BASE_ADDRESS = ANALOG_INTF_BASE_ADDRESS,
+ .d_GPIO_PIN9_OFFSET = GPIO_PIN9_OFFSET,
+};
+
+#endif
+
+#if MY_TARGET_BOARD_DATA_SZ > BOARD_DATA_SZ_MAX
+#error "BOARD_DATA_SZ_MAX is too small"
+#endif
+
+struct targetdef_s *MY_TARGET_DEF = &my_target_def;
+
+#else /* } { */
+
+#define RTC_SOC_BASE_ADDRESS (targetdef->d_RTC_SOC_BASE_ADDRESS)
+#define RTC_WMAC_BASE_ADDRESS (targetdef->d_RTC_WMAC_BASE_ADDRESS)
+#define SYSTEM_SLEEP_OFFSET (targetdef->d_SYSTEM_SLEEP_OFFSET)
+#define WLAN_SYSTEM_SLEEP_OFFSET (targetdef->d_WLAN_SYSTEM_SLEEP_OFFSET)
+#define WLAN_SYSTEM_SLEEP_DISABLE_LSB (targetdef->d_WLAN_SYSTEM_SLEEP_DISABLE_LSB)
+#define WLAN_SYSTEM_SLEEP_DISABLE_MASK (targetdef->d_WLAN_SYSTEM_SLEEP_DISABLE_MASK)
+#define CLOCK_CONTROL_OFFSET (targetdef->d_CLOCK_CONTROL_OFFSET)
+#define CLOCK_CONTROL_SI0_CLK_MASK (targetdef->d_CLOCK_CONTROL_SI0_CLK_MASK)
+#define RESET_CONTROL_OFFSET (targetdef->d_RESET_CONTROL_OFFSET)
+#define RESET_CONTROL_MBOX_RST_MASK (targetdef->d_RESET_CONTROL_MBOX_RST_MASK)
+#define RESET_CONTROL_SI0_RST_MASK (targetdef->d_RESET_CONTROL_SI0_RST_MASK)
+#define WLAN_RESET_CONTROL_OFFSET (targetdef->d_WLAN_RESET_CONTROL_OFFSET)
+#define WLAN_RESET_CONTROL_COLD_RST_MASK (targetdef->d_WLAN_RESET_CONTROL_COLD_RST_MASK)
+#define WLAN_RESET_CONTROL_WARM_RST_MASK (targetdef->d_WLAN_RESET_CONTROL_WARM_RST_MASK)
+#define GPIO_BASE_ADDRESS (targetdef->d_GPIO_BASE_ADDRESS)
+#define GPIO_PIN0_OFFSET (targetdef->d_GPIO_PIN0_OFFSET)
+#define GPIO_PIN1_OFFSET (targetdef->d_GPIO_PIN1_OFFSET)
+#define GPIO_PIN0_CONFIG_MASK (targetdef->d_GPIO_PIN0_CONFIG_MASK)
+#define GPIO_PIN1_CONFIG_MASK (targetdef->d_GPIO_PIN1_CONFIG_MASK)
+#define SI_CONFIG_BIDIR_OD_DATA_LSB (targetdef->d_SI_CONFIG_BIDIR_OD_DATA_LSB)
+#define SI_CONFIG_BIDIR_OD_DATA_MASK (targetdef->d_SI_CONFIG_BIDIR_OD_DATA_MASK)
+#define SI_CONFIG_I2C_LSB (targetdef->d_SI_CONFIG_I2C_LSB)
+#define SI_CONFIG_I2C_MASK (targetdef->d_SI_CONFIG_I2C_MASK)
+#define SI_CONFIG_POS_SAMPLE_LSB (targetdef->d_SI_CONFIG_POS_SAMPLE_LSB)
+#define SI_CONFIG_POS_SAMPLE_MASK (targetdef->d_SI_CONFIG_POS_SAMPLE_MASK)
+#define SI_CONFIG_INACTIVE_CLK_LSB (targetdef->d_SI_CONFIG_INACTIVE_CLK_LSB)
+#define SI_CONFIG_INACTIVE_CLK_MASK (targetdef->d_SI_CONFIG_INACTIVE_CLK_MASK)
+#define SI_CONFIG_INACTIVE_DATA_LSB (targetdef->d_SI_CONFIG_INACTIVE_DATA_LSB)
+#define SI_CONFIG_INACTIVE_DATA_MASK (targetdef->d_SI_CONFIG_INACTIVE_DATA_MASK)
+#define SI_CONFIG_DIVIDER_LSB (targetdef->d_SI_CONFIG_DIVIDER_LSB)
+#define SI_CONFIG_DIVIDER_MASK (targetdef->d_SI_CONFIG_DIVIDER_MASK)
+#define SI_BASE_ADDRESS (targetdef->d_SI_BASE_ADDRESS)
+#define SI_CONFIG_OFFSET (targetdef->d_SI_CONFIG_OFFSET)
+#define SI_TX_DATA0_OFFSET (targetdef->d_SI_TX_DATA0_OFFSET)
+#define SI_TX_DATA1_OFFSET (targetdef->d_SI_TX_DATA1_OFFSET)
+#define SI_RX_DATA0_OFFSET (targetdef->d_SI_RX_DATA0_OFFSET)
+#define SI_RX_DATA1_OFFSET (targetdef->d_SI_RX_DATA1_OFFSET)
+#define SI_CS_OFFSET (targetdef->d_SI_CS_OFFSET)
+#define SI_CS_DONE_ERR_MASK (targetdef->d_SI_CS_DONE_ERR_MASK)
+#define SI_CS_DONE_INT_MASK (targetdef->d_SI_CS_DONE_INT_MASK)
+#define SI_CS_START_LSB (targetdef->d_SI_CS_START_LSB)
+#define SI_CS_START_MASK (targetdef->d_SI_CS_START_MASK)
+#define SI_CS_RX_CNT_LSB (targetdef->d_SI_CS_RX_CNT_LSB)
+#define SI_CS_RX_CNT_MASK (targetdef->d_SI_CS_RX_CNT_MASK)
+#define SI_CS_TX_CNT_LSB (targetdef->d_SI_CS_TX_CNT_LSB)
+#define SI_CS_TX_CNT_MASK (targetdef->d_SI_CS_TX_CNT_MASK)
+#define EEPROM_SZ (targetdef->d_BOARD_DATA_SZ)
+#define EEPROM_EXT_SZ (targetdef->d_BOARD_EXT_DATA_SZ)
+#define MBOX_BASE_ADDRESS (targetdef->d_MBOX_BASE_ADDRESS)
+#define LOCAL_SCRATCH_OFFSET (targetdef->d_LOCAL_SCRATCH_OFFSET)
+#define CPU_CLOCK_OFFSET (targetdef->d_CPU_CLOCK_OFFSET)
+#define LPO_CAL_OFFSET (targetdef->d_LPO_CAL_OFFSET)
+#define GPIO_PIN10_OFFSET (targetdef->d_GPIO_PIN10_OFFSET)
+#define GPIO_PIN11_OFFSET (targetdef->d_GPIO_PIN11_OFFSET)
+#define GPIO_PIN12_OFFSET (targetdef->d_GPIO_PIN12_OFFSET)
+#define GPIO_PIN13_OFFSET (targetdef->d_GPIO_PIN13_OFFSET)
+#define CLOCK_GPIO_OFFSET (targetdef->d_CLOCK_GPIO_OFFSET)
+#define CPU_CLOCK_STANDARD_LSB (targetdef->d_CPU_CLOCK_STANDARD_LSB)
+#define CPU_CLOCK_STANDARD_MASK (targetdef->d_CPU_CLOCK_STANDARD_MASK)
+#define LPO_CAL_ENABLE_LSB (targetdef->d_LPO_CAL_ENABLE_LSB)
+#define LPO_CAL_ENABLE_MASK (targetdef->d_LPO_CAL_ENABLE_MASK)
+#define CLOCK_GPIO_BT_CLK_OUT_EN_LSB (targetdef->d_CLOCK_GPIO_BT_CLK_OUT_EN_LSB)
+#define CLOCK_GPIO_BT_CLK_OUT_EN_MASK (targetdef->d_CLOCK_GPIO_BT_CLK_OUT_EN_MASK)
+#define ANALOG_INTF_BASE_ADDRESS (targetdef->d_ANALOG_INTF_BASE_ADDRESS)
+#define GPIO_PIN9_OFFSET (targetdef->d_GPIO_PIN9_OFFSET)
+
+/* SET macros */
+#define WLAN_SYSTEM_SLEEP_DISABLE_SET(x) (((x) << WLAN_SYSTEM_SLEEP_DISABLE_LSB) & WLAN_SYSTEM_SLEEP_DISABLE_MASK)
+#define SI_CONFIG_BIDIR_OD_DATA_SET(x) (((x) << SI_CONFIG_BIDIR_OD_DATA_LSB) & SI_CONFIG_BIDIR_OD_DATA_MASK)
+#define SI_CONFIG_I2C_SET(x) (((x) << SI_CONFIG_I2C_LSB) & SI_CONFIG_I2C_MASK)
+#define SI_CONFIG_POS_SAMPLE_SET(x) (((x) << SI_CONFIG_POS_SAMPLE_LSB) & SI_CONFIG_POS_SAMPLE_MASK)
+#define SI_CONFIG_INACTIVE_CLK_SET(x) (((x) << SI_CONFIG_INACTIVE_CLK_LSB) & SI_CONFIG_INACTIVE_CLK_MASK)
+#define SI_CONFIG_INACTIVE_DATA_SET(x) (((x) << SI_CONFIG_INACTIVE_DATA_LSB) & SI_CONFIG_INACTIVE_DATA_MASK)
+#define SI_CONFIG_DIVIDER_SET(x) (((x) << SI_CONFIG_DIVIDER_LSB) & SI_CONFIG_DIVIDER_MASK)
+#define SI_CS_START_SET(x) (((x) << SI_CS_START_LSB) & SI_CS_START_MASK)
+#define SI_CS_RX_CNT_SET(x) (((x) << SI_CS_RX_CNT_LSB) & SI_CS_RX_CNT_MASK)
+#define SI_CS_TX_CNT_SET(x) (((x) << SI_CS_TX_CNT_LSB) & SI_CS_TX_CNT_MASK)
+#define LPO_CAL_ENABLE_SET(x) (((x) << LPO_CAL_ENABLE_LSB) & LPO_CAL_ENABLE_MASK)
+#define CPU_CLOCK_STANDARD_SET(x) (((x) << CPU_CLOCK_STANDARD_LSB) & CPU_CLOCK_STANDARD_MASK)
+#define CLOCK_GPIO_BT_CLK_OUT_EN_SET(x) (((x) << CLOCK_GPIO_BT_CLK_OUT_EN_LSB) & CLOCK_GPIO_BT_CLK_OUT_EN_MASK)
+extern struct targetdef_s *targetdef;
+
+#endif /* } */
+
+#endif /*TARGET_REG_TABLE_H_*/
diff --git a/host/include/testcmd.h b/host/include/testcmd.h
new file mode 100644
index 0000000..e47523c
--- /dev/null
+++ b/host/include/testcmd.h
@@ -0,0 +1,377 @@
+//------------------------------------------------------------------------------
+// <copyright file="testcmd.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef TESTCMD_H_
+#define TESTCMD_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#ifdef AR6002_REV2
+#define TCMD_MAX_RATES 12
+#else
+#define TCMD_MAX_RATES 28
+#endif
+
+//#define WMI_CMD_ID_SIZE 4
+//#define WMI_CMDS_SIZE_MAX 2048
+//#define TC_CMDS_GAP 16
+// should add up to the same size as buf[WMI_CMDS_SIZE_MAX]
+//#define TC_CMDS_SIZE_MAX (WMI_CMDS_SIZE_MAX - sizeof(TC_CMDS_HDR) - WMI_CMD_ID_SIZE - TC_CMDS_GAP)
+#define TC_CMDS_SIZE_MAX 256
+
+typedef enum {
+ ZEROES_PATTERN = 0,
+ ONES_PATTERN,
+ REPEATING_10,
+ PN7_PATTERN,
+ PN9_PATTERN,
+ PN15_PATTERN
+}TX_DATA_PATTERN;
+
+/* Continous tx
+ mode : TCMD_CONT_TX_OFF - Disabling continous tx
+ TCMD_CONT_TX_SINE - Enable continuous unmodulated tx
+ TCMD_CONT_TX_FRAME- Enable continuous modulated tx
+ freq : Channel freq in Mhz. (e.g 2412 for channel 1 in 11 g)
+dataRate: 0 - 1 Mbps
+ 1 - 2 Mbps
+ 2 - 5.5 Mbps
+ 3 - 11 Mbps
+ 4 - 6 Mbps
+ 5 - 9 Mbps
+ 6 - 12 Mbps
+ 7 - 18 Mbps
+ 8 - 24 Mbps
+ 9 - 36 Mbps
+ 10 - 28 Mbps
+ 11 - 54 Mbps
+ txPwr: twice the Tx power in dBm, actual dBm values of [5 -11] for unmod Tx,
+ [5-14] for mod Tx
+antenna: 1 - one antenna
+ 2 - two antenna
+Note : Enable/disable continuous tx test cmd works only when target is awake.
+*/
+
+typedef enum {
+ TCMD_CONT_TX_OFF = 0,
+ TCMD_CONT_TX_SINE,
+ TCMD_CONT_TX_FRAME,
+ TCMD_CONT_TX_TX99,
+ TCMD_CONT_TX_TX100,
+ TCMD_CONT_TX_OFFSETTONE,
+} TCMD_CONT_TX_MODE;
+
+typedef enum {
+ TCMD_WLAN_MODE_NOHT = 0,
+ TCMD_WLAN_MODE_HT20 = 1,
+ TCMD_WLAN_MODE_HT40PLUS = 2,
+ TCMD_WLAN_MODE_HT40MINUS = 3,
+ TCMD_WLAN_MODE_CCK = 4,
+
+ TCMD_WLAN_MODE_MAX,
+ TCMD_WLAN_MODE_INVALID = TCMD_WLAN_MODE_MAX,
+
+} TCMD_WLAN_MODE;
+
+typedef enum {
+ TPC_TX_PWR = 0,
+ TPC_FORCED_GAIN,
+ TPC_TGT_PWR
+} TPC_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 mode;
+ A_UINT32 freq;
+ A_UINT32 dataRate;
+ A_INT32 txPwr;
+ A_UINT32 antenna;
+ A_UINT32 enANI;
+ A_UINT32 scramblerOff;
+ A_UINT32 aifsn;
+ A_UINT16 pktSz;
+ A_UINT16 txPattern;
+ A_UINT32 shortGuard;
+ A_UINT32 numPackets;
+ A_UINT32 wlanMode;
+ A_UINT32 tpcm;
+} POSTPACK TCMD_CONT_TX;
+
+#define TCMD_TXPATTERN_ZERONE 0x1
+#define TCMD_TXPATTERN_ZERONE_DIS_SCRAMBLE 0x2
+
+/* Continuous Rx
+ act: TCMD_CONT_RX_PROMIS - promiscuous mode (accept all incoming frames)
+ TCMD_CONT_RX_FILTER - filter mode (accept only frames with dest
+ address equal specified
+ mac address (set via act =3)
+ TCMD_CONT_RX_REPORT off mode (disable cont rx mode and get the
+ report from the last cont
+ Rx test)
+
+ TCMD_CONT_RX_SETMAC - set MacAddr mode (sets the MAC address for the
+ target. This Overrides
+ the default MAC address.)
+
+*/
+typedef enum {
+ TCMD_CONT_RX_PROMIS =0,
+ TCMD_CONT_RX_FILTER,
+ TCMD_CONT_RX_REPORT,
+ TCMD_CONT_RX_SETMAC,
+ TCMD_CONT_RX_SET_ANT_SWITCH_TABLE,
+ TC_CMD_RESP,
+} TCMD_CONT_RX_ACT;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 act;
+ A_UINT32 enANI;
+ PREPACK union {
+ struct PREPACK TCMD_CONT_RX_PARA {
+ A_UINT32 freq;
+ A_UINT32 antenna;
+ A_UINT32 wlanMode;
+ } POSTPACK para;
+ struct PREPACK TCMD_CONT_RX_REPORT {
+ A_UINT32 totalPkt;
+ A_INT32 rssiInDBm;
+ A_UINT32 crcErrPkt;
+ A_UINT32 secErrPkt;
+ A_UINT16 rateCnt[TCMD_MAX_RATES];
+ A_UINT16 rateCntShortGuard[TCMD_MAX_RATES];
+ } POSTPACK report;
+ struct PREPACK TCMD_CONT_RX_MAC {
+ A_UCHAR addr[ATH_MAC_LEN];
+ A_UCHAR btaddr[ATH_MAC_LEN];
+ A_UINT16 regDmn[2];
+ A_UINT32 otpWriteFlag;
+ } POSTPACK mac;
+ struct PREPACK TCMD_CONT_RX_ANT_SWITCH_TABLE {
+ A_UINT32 antswitch1;
+ A_UINT32 antswitch2;
+ }POSTPACK antswitchtable;
+ } POSTPACK u;
+} POSTPACK TCMD_CONT_RX;
+
+/* Force sleep/wake test cmd
+ mode: TCMD_PM_WAKEUP - Wakeup the target
+ TCMD_PM_SLEEP - Force the target to sleep.
+ */
+typedef enum {
+ TCMD_PM_WAKEUP = 1, /* be consistent with target */
+ TCMD_PM_SLEEP,
+ TCMD_PM_DEEPSLEEP
+} TCMD_PM_MODE;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 mode;
+} POSTPACK TCMD_PM;
+
+typedef enum {
+ TC_CMDS_VERSION_RESERVED=0,
+ TC_CMDS_VERSION_MDK,
+ TC_CMDS_VERSION_TS,
+ TC_CMDS_VERSION_LAST,
+} TC_CMDS_VERSION;
+
+typedef enum {
+ TC_CMDS_TS =0,
+ TC_CMDS_CAL,
+ TC_CMDS_TPCCAL = TC_CMDS_CAL,
+ TC_CMDS_TPCCAL_WITH_OTPWRITE,
+ TC_CMDS_OTPDUMP,
+ TC_CMDS_OTPSTREAMWRITE,
+ TC_CMDS_EFUSEDUMP,
+ TC_CMDS_EFUSEWRITE,
+ TC_CMDS_READTHERMAL,
+ TC_CMDS_PM_CAL,
+ TC_CMDS_PSAT_CAL,
+ TC_CMDS_PSAT_CAL_RESULT,
+ TC_CMDS_CAL_PWRS,
+ TC_CMDS_WRITE_CAL_2_OTP,
+ TC_CMDS_CHAR_PSAT,
+ TC_CMDS_CHAR_PSAT_RESULT,
+ TC_CMDS_PM_CAL_RESULT,
+ TC_CMDS_SINIT_WAIT,
+ TC_CMDS_SINIT_LOAD_AUTO,
+ TC_CMDS_COUNT
+} TC_CMDS_ACT;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 act;
+ PREPACK union {
+ A_UINT32 enANI; // to be identical to CONT_RX struct
+ struct PREPACK {
+ A_UINT16 length;
+ A_UINT8 version;
+ A_UINT8 bufLen;
+ } POSTPACK parm;
+ } POSTPACK u;
+} POSTPACK TC_CMDS_HDR;
+
+typedef PREPACK struct {
+ TC_CMDS_HDR hdr;
+ A_UINT8 buf[TC_CMDS_SIZE_MAX];
+} POSTPACK TC_CMDS;
+
+typedef PREPACK struct {
+ A_UINT32 testCmdId;
+ A_UINT32 regAddr;
+ A_UINT32 val;
+ A_UINT16 flag;
+} POSTPACK TCMD_SET_REG;
+
+typedef enum {
+ TCMD_CONT_TX_ID,
+ TCMD_CONT_RX_ID,
+ TCMD_PM_ID,
+ TC_CMDS_ID,
+ TCMD_SET_REG_ID,
+
+ /*For synergy purpose we added the following tcmd id but these
+ tcmd's will not go to the firmware instead we will write values
+ to the NV area */
+
+ TCMD_NIC_MAC = 100,
+ TCMD_CAL_FILE_INDEX = 101,
+} TCMD_ID;
+
+typedef PREPACK struct
+{
+ A_UINT32 testCmdId;
+ A_UINT8 mac_address[ATH_MAC_LEN];
+} POSTPACK TCMD_NIC_MAC_S;
+
+typedef PREPACK struct
+{
+ A_UINT32 testCmdId;
+ A_UINT32 cal_file_index;
+} POSTPACK TCMD_CAL_FILE_INDEX_S;
+
+typedef PREPACK union {
+ TCMD_CONT_TX contTx;
+ TCMD_CONT_RX contRx;
+ TCMD_PM pm;
+ // New test cmds from ART/MDK ...
+ TC_CMDS tcCmds;
+ TCMD_SET_REG setReg;
+} POSTPACK TEST_CMD;
+
+typedef enum {
+ TC_MSG_RESERVED,
+ TC_MSG_PSAT_CAL_RESULTS,
+ TC_MSG_CAL_POWER,
+ TC_MSG_CHAR_PSAT_RESULTS,
+ TC_MSG_PM_CAL_RESULTS,
+ TC_MSG_PSAT_CAL_ACK,
+ TC_MSG_COUNT
+} TC_MSG_ID;
+
+typedef PREPACK struct {
+ A_INT8 olpcGainDelta_diff;
+ A_INT8 olpcGainDelta_abs;
+ A_UINT8 thermCalVal;
+ A_UINT8 numTryBF;
+ A_UINT32 cmac_olpc;
+ A_UINT32 cmac_psat;
+ A_UINT16 cmac_olpc_pcdac;
+ A_UINT16 cmac_psat_pcdac;
+ A_INT16 lineSlope;
+ A_INT16 lineVariance;
+ A_UINT16 psatParm;
+ A_UINT8 reserved[2];
+} POSTPACK OLPCGAIN_THERM_DUPLET;
+
+#if !defined(WHAL_NUM_11G_CAL_PIERS_EXT)
+#define WHAL_NUM_11G_CAL_PIERS_EXT 16
+#define WHAL_NUM_11A_CAL_PIERS_EXT 32
+#endif
+#define PSAT_WHAL_NUM_11G_CAL_PIERS_MAX 3
+#define PSAT_WHAL_NUM_11A_CAL_PIERS_MAX 5
+typedef PREPACK struct {
+ OLPCGAIN_THERM_DUPLET olpcGainTherm2G[PSAT_WHAL_NUM_11G_CAL_PIERS_MAX];
+ OLPCGAIN_THERM_DUPLET olpcGainTherm5G[PSAT_WHAL_NUM_11A_CAL_PIERS_MAX];
+} POSTPACK PSAT_CAL_RESULTS;
+
+#define _MAX_TX_GAIN_ENTRIES 32
+typedef PREPACK struct {
+ A_UINT32 cmac_i[_MAX_TX_GAIN_ENTRIES];
+ A_UINT8 pcdac[_MAX_TX_GAIN_ENTRIES];
+
+ A_UINT8 freq;
+ A_UINT8 an_txrf3_rdiv2g;
+ A_UINT8 an_txrf3_pdpredist2g;
+ A_UINT8 an_rxtx2_mxrgain;
+ A_UINT8 an_rxrf_bias1_pwd_ic25mxr2gh;
+ A_UINT8 an_bias2_pwd_ic25rxrf;
+ A_UINT8 an_bb1_i2v_curr2x;
+ A_UINT8 an_txrf3_capdiv2g;
+
+// A_UINT32 cmac_q[_MAX_TX_GAIN_ENTRIES];
+} POSTPACK CHAR_PSAT_RESULTS;
+
+typedef PREPACK struct {
+ A_INT16 txPwr2G_t10[WHAL_NUM_11G_CAL_PIERS_EXT];
+ A_INT16 txPwr5G_t10[WHAL_NUM_11A_CAL_PIERS_EXT];
+} POSTPACK CAL_TXPWR;
+
+typedef PREPACK struct {
+ A_UINT8 thermCalVal;
+ A_UINT8 future[3];
+} POSTPACK PM_CAL_RESULTS;
+
+typedef PREPACK struct {
+ TC_MSG_ID msgId;
+ PREPACK union {
+ PSAT_CAL_RESULTS psatCalResults;
+ CAL_TXPWR txPwrs;
+ CHAR_PSAT_RESULTS psatCharResults;
+ PM_CAL_RESULTS pmCalResults;
+ } POSTPACK msg;
+
+} POSTPACK TC_MSG;
+
+typedef struct _psat_sweep_table {
+ A_UINT8 an_txrf3_rdiv2g; // [0,3] _RDIV2G_MIN, _RDIV2G_MAX
+ A_UINT8 an_txrf3_pdpredist2g; // [0,1] _PDPREDIST2G_MIN, _PDPREDIST2G_MAX
+ A_UINT8 an_rxtx2_mxrgain; // [0,3] _MXRGAIN_MIN, _MXRGAIN_MAX
+ A_UINT8 an_rxrf_bias1_pwd_ic25mxr2gh; // [0,3] _PWD_IC25MX2GH_MIN, _PWD_IC25MXRGH_MAX
+ A_UINT8 an_bias2_pwd_ic25rxrf; // [0,3] _PWD_IC25RXRF_MIN, _PWD_RC25RXRF_MAX
+ A_UINT8 an_bb1_i2v_curr2x; // [0,1] _I2V_CURR2X_MIN, _I2V_CURR2X_MAX
+ A_UINT8 an_txrf3_capdiv2g; // [0,15] _CAPDIV2G_MIN, _CAPDIV2G_MAX
+ A_INT8 olpcPsatCmacDelta; // olpcPsatCmacDelta
+ A_UINT16 psatParm;
+ A_UINT16 padding2;
+} PSAT_SWEEP_TABLE;
+#define NUM_PSAT_CHAR_PARMS 7
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* TESTCMD_H_ */
diff --git a/host/include/tlpm.h b/host/include/tlpm.h
new file mode 100644
index 0000000..39c5930
--- /dev/null
+++ b/host/include/tlpm.h
@@ -0,0 +1,38 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __TLPM_H__
+#define __TLPM_H__
+
+/* idle timeout in 16-bit value as in HOST_INTEREST hi_hci_uart_pwr_mgmt_params */
+#define TLPM_DEFAULT_IDLE_TIMEOUT_MS 1000
+/* hex in LSB and MSB for HCI command */
+#define TLPM_DEFAULT_IDLE_TIMEOUT_LSB 0xE8
+#define TLPM_DEFAULT_IDLE_TIMEOUT_MSB 0x3
+
+/* wakeup timeout in 8-bit value as in HOST_INTEREST hi_hci_uart_pwr_mgmt_params */
+#define TLPM_DEFAULT_WAKEUP_TIMEOUT_MS 10
+
+/* default UART FC polarity is low */
+#define TLPM_DEFAULT_UART_FC_POLARITY 0
+
+#endif
diff --git a/host/include/utils_api.h b/host/include/utils_api.h
new file mode 100644
index 0000000..d3aad4e
--- /dev/null
+++ b/host/include/utils_api.h
@@ -0,0 +1,103 @@
+//------------------------------------------------------------------------------
+// <copyright file="utils_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Utility Macros & Functions common across OS.
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HOST_UTILS_API_H_
+#define _HOST_UTILS_API_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* unaligned little endian access */
+#define LE_READ_2(p) \
+ ((A_UINT16) \
+ ((((A_UINT8 *)(p))[0] ) | (((A_UINT8 *)(p))[1] << 8)))
+
+#define LE_READ_4(p) \
+ ((A_UINT32) \
+ ((((A_UINT8 *)(p))[0] ) | (((A_UINT8 *)(p))[1] << 8) | \
+ (((A_UINT8 *)(p))[2] << 16) | (((A_UINT8 *)(p))[3] << 24)))
+
+#define WPA_GET_BE16(a) ((A_UINT16) (((a)[0] << 8) | (a)[1]))
+#define WPA_PUT_BE16(a, val) \
+ do { \
+ (a)[0] = ((A_UINT16) (val)) >> 8; \
+ (a)[1] = ((A_UINT16) (val)) & 0xff; \
+ } while (0)
+
+#define WPA_GET_LE16(a) ((A_UINT16) (((a)[1] << 8) | (a)[0]))
+#define WPA_PUT_LE16(a, val) \
+ do { \
+ (a)[1] = ((A_UINT16) (val)) >> 8; \
+ (a)[0] = ((A_UINT16) (val)) & 0xff; \
+ } while (0)
+
+#define WPA_GET_BE24(a) ((((A_UINT32) (a)[0]) << 16) | (((A_UINT32) (a)[1]) << 8) | \
+ ((A_UINT32) (a)[2]))
+#define WPA_PUT_BE24(a, val) \
+ do { \
+ (a)[0] = (A_UINT8) ((((A_UINT32) (val)) >> 16) & 0xff); \
+ (a)[1] = (A_UINT8) ((((A_UINT32) (val)) >> 8) & 0xff); \
+ (a)[2] = (A_UINT8) (((A_UINT32) (val)) & 0xff); \
+ } while (0)
+
+#define WPA_GET_BE32(a) ((((A_UINT32) (a)[0]) << 24) | (((A_UINT32) (a)[1]) << 16) | \
+ (((A_UINT32) (a)[2]) << 8) | ((A_UINT32) (a)[3]))
+#define WPA_PUT_BE32(a, val) \
+ do { \
+ (a)[0] = (A_UINT8) ((((A_UINT32) (val)) >> 24) & 0xff); \
+ (a)[1] = (A_UINT8) ((((A_UINT32) (val)) >> 16) & 0xff); \
+ (a)[2] = (A_UINT8) ((((A_UINT32) (val)) >> 8) & 0xff); \
+ (a)[3] = (A_UINT8) (((A_UINT32) (val)) & 0xff); \
+ } while (0)
+
+#define WPA_GET_LE32(a) ((((A_UINT32) (a)[3]) << 24) | (((A_UINT32) (a)[2]) << 16) | \
+ (((A_UINT32) (a)[1]) << 8) | ((A_UINT32) (a)[0]))
+#define WPA_PUT_LE32(a, val) \
+ do { \
+ (a)[3] = (A_UINT8) ((((A_UINT32) (val)) >> 24) & 0xff); \
+ (a)[2] = (A_UINT8) ((((A_UINT32) (val)) >> 16) & 0xff); \
+ (a)[1] = (A_UINT8) ((((A_UINT32) (val)) >> 8) & 0xff); \
+ (a)[0] = (A_UINT8) (((A_UINT32) (val)) & 0xff); \
+ } while (0)
+
+
+#define WPA_OUI 0xf25000
+
+static int __inline
+iswscoui(const A_UINT8 *frm)
+{
+ return frm[1] > 3 && LE_READ_4(frm+2) == ((0x04<<24)|WPA_OUI);
+}
+
+static inline int is_zero_mac_addr(const A_UINT8 *addr)
+{
+ return !(addr[0] | addr[1] | addr[2] | addr[3] | addr[4] | addr[5]);
+}
+
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif /* _HOST_UTILS_API_H_ */
diff --git a/host/include/wac_defs.h b/host/include/wac_defs.h
new file mode 100644
index 0000000..ea695ff
--- /dev/null
+++ b/host/include/wac_defs.h
@@ -0,0 +1,56 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __WAC_API_H__
+#define __WAC_API_H__
+
+typedef enum {
+ WAC_SET,
+ WAC_GET,
+} WAC_REQUEST_TYPE;
+
+typedef enum {
+ WAC_ADD,
+ WAC_DEL,
+ WAC_GET_STATUS,
+ WAC_GET_IE,
+} WAC_COMMAND;
+
+typedef enum {
+ PRBREQ,
+ PRBRSP,
+ BEACON,
+} WAC_FRAME_TYPE;
+
+typedef enum {
+ WAC_FAILED_NO_WAC_AP = -4,
+ WAC_FAILED_LOW_RSSI = -3,
+ WAC_FAILED_INVALID_PARAM = -2,
+ WAC_FAILED_REJECTED = -1,
+ WAC_SUCCESS = 0,
+ WAC_DISABLED = 1,
+ WAC_PROCEED_FIRST_PHASE,
+ WAC_PROCEED_SECOND_PHASE,
+} WAC_STATUS;
+
+
+#endif
diff --git a/host/include/wlan_api.h b/host/include/wlan_api.h
new file mode 100644
index 0000000..15eeadf
--- /dev/null
+++ b/host/include/wlan_api.h
@@ -0,0 +1,157 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains the API for the host wlan module
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HOST_WLAN_API_H_
+#define _HOST_WLAN_API_H_
+
+#ifdef ATHR_NWIFI
+#include <ndis.h>
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include <a_osapi.h>
+
+struct ieee80211_node_table;
+struct ieee80211_frame;
+
+struct ieee80211_common_ie {
+ A_UINT16 ie_chan;
+ A_UINT8 *ie_tstamp;
+ A_UINT8 *ie_ssid;
+ A_UINT8 *ie_rates;
+ A_UINT8 *ie_xrates;
+ A_UINT8 *ie_country;
+ A_UINT8 *ie_wpa;
+ A_UINT8 *ie_rsn;
+ A_UINT8 *ie_wmm;
+ A_UINT8 *ie_ath;
+ A_UINT16 ie_capInfo;
+ A_UINT16 ie_beaconInt;
+ A_UINT8 *ie_tim;
+ A_UINT8 *ie_chswitch;
+ A_UINT8 ie_erp;
+ A_UINT8 *ie_wsc;
+ A_UINT8 *ie_htcap;
+ A_UINT8 *ie_htop;
+#ifdef HS20_ENABLE
+ A_UINT8 *ie_hs20;
+ A_UINT8 *ie_extcap;
+#endif
+#ifdef WAPI_ENABLE
+ A_UINT8 *ie_wapi;
+#endif
+
+#ifdef ATHR_NWIFI
+ A_UINT8 *ie_wsc_becon;
+ A_UINT8 *ie_wsc_probe;
+#endif
+
+};
+
+typedef struct bss {
+ A_UINT8 ni_macaddr[6];
+ A_UINT8 ni_snr;
+ A_INT16 ni_rssi;
+ struct bss *ni_list_next;
+ struct bss *ni_list_prev;
+ struct bss *ni_hash_next;
+ struct bss *ni_hash_prev;
+ struct ieee80211_common_ie ni_cie;
+#ifdef P2P
+ void *p2p_dev;
+#endif /* P2P */
+ A_UINT8 *ni_buf;
+ A_UINT16 ni_framelen;
+ A_UINT8 ni_frametype; /* frame type in ni_buf */
+ struct ieee80211_node_table *ni_table;
+ A_UINT32 ni_refcnt;
+ int ni_scangen;
+
+#ifdef ATHR_NWIFI
+ ULONGLONG HostTimestamp;
+#else
+ A_UINT32 ni_tstamp;
+ A_UINT32 ni_actcnt;
+#endif
+#ifdef OS_ROAM_MANAGEMENT
+ A_UINT32 ni_si_gen;
+#endif
+} bss_t;
+
+typedef void wlan_node_iter_func(void *arg, bss_t *);
+
+bss_t *wlan_node_alloc(struct ieee80211_node_table *nt, int wh_size);
+void wlan_node_free(bss_t *ni);
+void wlan_setup_node(struct ieee80211_node_table *nt, bss_t *ni,
+ const A_UINT8 *macaddr);
+bss_t *wlan_find_node(struct ieee80211_node_table *nt, const A_UINT8 *macaddr);
+void wlan_node_reclaim(struct ieee80211_node_table *nt, bss_t *ni);
+A_STATUS wlan_node_buf_update(struct ieee80211_node_table *nt, bss_t *ni, A_UINT32 len);
+void wlan_free_allnodes(struct ieee80211_node_table *nt);
+void wlan_iterate_nodes(struct ieee80211_node_table *nt, wlan_node_iter_func *f,
+ void *arg);
+
+void wlan_node_table_init(void *wmip, struct ieee80211_node_table *nt);
+void wlan_node_table_reset(struct ieee80211_node_table *nt);
+void wlan_node_table_cleanup(struct ieee80211_node_table *nt);
+
+A_STATUS wlan_parse_beacon(A_UINT8 *buf, int framelen,
+ struct ieee80211_common_ie *cie);
+
+A_UINT16 wlan_ieee2freq(int chan);
+A_UINT32 wlan_freq2ieee(A_UINT16 freq);
+
+void wlan_set_nodeage(struct ieee80211_node_table *nt, A_UINT32 nodeAge);
+
+#ifdef ATHR_NWIFI
+void
+wlan_refresh_scan_table (struct ieee80211_node_table *nt, ULONGLONG OldestAllowedEntry);
+#else
+void
+wlan_refresh_inactive_nodes (struct ieee80211_node_table *nt);
+#endif
+
+bss_t *
+wlan_find_Ssidnode (struct ieee80211_node_table *nt, A_UCHAR *pSsid,
+ A_UINT32 ssidLength, A_BOOL bIsWPA2, A_BOOL bMatchSSID);
+
+void
+wlan_node_return (struct ieee80211_node_table *nt, bss_t *ni);
+
+bss_t *wlan_node_remove(struct ieee80211_node_table *nt, A_UINT8 *bssid);
+
+bss_t *
+wlan_find_matching_Ssidnode (struct ieee80211_node_table *nt, A_UCHAR *pSsid,
+ A_UINT32 ssidLength, A_UINT32 dot11AuthMode, A_UINT32 authMode,
+ A_UINT32 pairwiseCryptoType, A_UINT32 grpwiseCryptoTyp);
+
+void wlan_node_update_timestamp(struct ieee80211_node_table *nt, bss_t *ni);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _HOST_WLAN_API_H_ */
diff --git a/host/include/wlan_defs.h b/host/include/wlan_defs.h
new file mode 100644
index 0000000..458e96c
--- /dev/null
+++ b/host/include/wlan_defs.h
@@ -0,0 +1,88 @@
+//------------------------------------------------------------------------------
+// <copyright file="wlan_defs.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef __WLAN_DEFS_H__
+#define __WLAN_DEFS_H__
+
+/*
+ * This file contains WLAN definitions that may be used across both
+ * Host and Target software.
+ */
+
+typedef enum {
+ MODE_11A = 0, /* 11a Mode */
+ MODE_11G = 1, /* 11b/g Mode */
+ MODE_11B = 2, /* 11b Mode */
+ MODE_11GONLY = 3, /* 11g only Mode */
+#ifdef SUPPORT_11N
+ MODE_11NA_HT20 = 4, /* 11a HT20 mode */
+ MODE_11NG_HT20 = 5, /* 11g HT20 mode */
+ MODE_11NA_HT40 = 6, /* 11a HT40 mode */
+ MODE_11NG_HT40 = 7, /* 11g HT40 mode */
+ MODE_UNKNOWN = 8,
+ MODE_MAX = 8
+#else
+ MODE_UNKNOWN = 4,
+ MODE_MAX = 4
+#endif
+} WLAN_PHY_MODE;
+
+typedef enum {
+ WLAN_11A_CAPABILITY = 1,
+ WLAN_11G_CAPABILITY = 2,
+ WLAN_11AG_CAPABILITY = 3,
+}WLAN_CAPABILITY;
+
+#ifdef SUPPORT_11N
+#ifdef SUPPORT_2SS
+typedef A_UINT64 A_RATEMASK;
+#else
+typedef unsigned long A_RATEMASK;
+#endif /* SUPPORT_2SS */
+#else
+typedef unsigned short A_RATEMASK;
+#endif /* SUPPORT_11N */
+
+#ifdef SUPPORT_11N
+#define IS_MODE_11A(mode) (((mode) == MODE_11A) || \
+ ((mode) == MODE_11NA_HT20) || \
+ ((mode) == MODE_11NA_HT40))
+#define IS_MODE_11B(mode) ((mode) == MODE_11B)
+#define IS_MODE_11G(mode) (((mode) == MODE_11G) || \
+ ((mode) == MODE_11GONLY) || \
+ ((mode) == MODE_11NG_HT20) || \
+ ((mode) == MODE_11NG_HT40))
+#define IS_MODE_11GN(mode) (((mode) == MODE_11NG_HT20) || \
+ ((mode) == MODE_11NG_HT40))
+#define IS_MODE_11GONLY(mode) ((mode) == MODE_11GONLY)
+#define IS_MODE_11AN(mode) (((mode) == MODE_11NA_HT20) || \
+ ((mode) == MODE_11NA_HT40))
+#define IS_MODE_11N(mode) ((IS_MODE_11GN(mode)) || (IS_MODE_11AN(mode)))
+#else
+#define IS_MODE_11A(mode) ((mode) == MODE_11A)
+#define IS_MODE_11B(mode) ((mode) == MODE_11B)
+#define IS_MODE_11G(mode) (((mode) == MODE_11G) || \
+ ((mode) == MODE_11GONLY))
+#define IS_MODE_11GONLY(mode) ((mode) == MODE_11GONLY)
+#endif /* SUPPORT_11N */
+
+#endif /* __WLANDEFS_H__ */
diff --git a/host/include/wlan_dset.h b/host/include/wlan_dset.h
new file mode 100644
index 0000000..16481e1
--- /dev/null
+++ b/host/include/wlan_dset.h
@@ -0,0 +1,33 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2007-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef __WLAN_DSET_H__
+#define __WLAN_DSET_H__
+
+typedef PREPACK struct wow_config_dset {
+
+ A_UINT8 valid_dset;
+ A_UINT8 gpio_enable;
+ A_UINT16 gpio_pin;
+} POSTPACK WOW_CONFIG_DSET;
+
+#endif
diff --git a/host/include/wmi.h b/host/include/wmi.h
new file mode 100644
index 0000000..228db7c
--- /dev/null
+++ b/host/include/wmi.h
@@ -0,0 +1,3918 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+/*
+ * This file contains the definitions of the WMI protocol specified in the
+ * Wireless Module Interface (WMI). It includes definitions of all the
+ * commands and events. Commands are messages from the host to the WM.
+ * Events and Replies are messages from the WM to the host.
+ *
+ * Ownership of correctness in regards to commands
+ * belongs to the host driver and the WMI is not required to validate
+ * parameters for value, proper range, or any other checking.
+ *
+ */
+
+#ifndef _WMI_H_
+#define _WMI_H_
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+#include "wmix.h"
+#include "wlan_defs.h"
+#ifdef ATH_SUPPORT_DFS
+#include "dfs_common.h"
+#endif
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define HTC_PROTOCOL_VERSION 0x0002
+#define HTC_PROTOCOL_REVISION 0x0000
+
+#define WMI_PROTOCOL_VERSION 0x0002
+#define WMI_PROTOCOL_REVISION 0x0000
+
+#define ATH_MAC_LEN 6 /* length of mac in bytes */
+#define WMI_CMD_MAX_LEN 100
+#define WMI_CONTROL_MSG_MAX_LEN 256
+#define WMI_OPT_CONTROL_MSG_MAX_LEN 1536
+#define IS_ETHERTYPE(_typeOrLen) ((_typeOrLen) >= 0x0600)
+#define RFC1042OUI {0x00, 0x00, 0x00}
+
+#define IP_ETHERTYPE 0x0800
+
+#define WMI_IMPLICIT_PSTREAM 0xFF
+#define WMI_MAX_THINSTREAM 15
+
+#ifdef AR6002_REV2
+#define IBSS_MAX_NUM_STA 4
+#else
+#define IBSS_MAX_NUM_STA 8
+#endif
+
+#define COUNTRY_CODE_PRESENT 0x80
+#define SPACE 0x20
+
+#define WMI_MODE_MAX 8
+#define WMI_MAX_RATE_MASK 2
+#define WMI_NETWORK_TYPE(networkType) ((networkType) & 0x000F)
+#define WMI_CONNECTED_PHYMODE(networkType) (((networkType) & 0x0F00) >> 8)
+
+PREPACK struct host_app_area_s {
+ A_UINT32 wmi_protocol_ver;
+} POSTPACK;
+
+/*
+ * Data Path
+ */
+typedef PREPACK struct {
+ A_UINT8 dstMac[ATH_MAC_LEN];
+ A_UINT8 srcMac[ATH_MAC_LEN];
+ A_UINT16 typeOrLen;
+} POSTPACK ATH_MAC_HDR;
+
+typedef PREPACK struct {
+ A_UINT8 dsap;
+ A_UINT8 ssap;
+ A_UINT8 cntl;
+ A_UINT8 orgCode[3];
+ A_UINT16 etherType;
+} POSTPACK ATH_LLC_SNAP_HDR;
+
+typedef enum {
+ DATA_MSGTYPE = 0x0,
+ CNTL_MSGTYPE,
+ SYNC_MSGTYPE,
+ OPT_MSGTYPE,
+} WMI_MSG_TYPE;
+
+
+/*
+ * Macros for operating on WMI_DATA_HDR (info) field
+ */
+
+#define WMI_DATA_HDR_MSG_TYPE_MASK 0x03
+#define WMI_DATA_HDR_MSG_TYPE_SHIFT 0
+#define WMI_DATA_HDR_UP_MASK 0x07
+#define WMI_DATA_HDR_UP_SHIFT 2
+/* In AP mode, the same bit (b5) is used to indicate Power save state in
+ * the Rx dir and More data bit state in the tx direction.
+ */
+#define WMI_DATA_HDR_PS_MASK 0x1
+#define WMI_DATA_HDR_PS_SHIFT 5
+
+#define WMI_DATA_HDR_MORE_MASK 0x1
+#define WMI_DATA_HDR_MORE_SHIFT 5
+
+typedef enum {
+ WMI_DATA_HDR_DATA_TYPE_802_3 = 0,
+ WMI_DATA_HDR_DATA_TYPE_802_11,
+ WMI_DATA_HDR_DATA_TYPE_ACL,
+} WMI_DATA_HDR_DATA_TYPE;
+
+/* Bitmap of data header flags */
+typedef enum {
+ WMI_DATA_HDR_FLAGS_MORE = 0x1,
+ WMI_DATA_HDR_FLAGS_EOSP = 0x2,
+} WMI_DATA_HDR_FLAGS;
+
+#define WMI_DATA_HDR_DATA_TYPE_MASK 0x3
+#define WMI_DATA_HDR_DATA_TYPE_SHIFT 6
+
+#define WMI_DATA_HDR_SET_MORE_BIT(h) ((h)->info |= (WMI_DATA_HDR_MORE_MASK << WMI_DATA_HDR_MORE_SHIFT))
+#define WMI_DATA_HDR_HAS_MORE_BIT(h) ((h)->info & (WMI_DATA_HDR_MORE_MASK << WMI_DATA_HDR_MORE_SHIFT))
+
+#define WMI_DATA_HDR_IS_MSG_TYPE(h, t) (((h)->info & (WMI_DATA_HDR_MSG_TYPE_MASK)) == (t))
+#define WMI_DATA_HDR_SET_MSG_TYPE(h, t) (h)->info = (((h)->info & ~(WMI_DATA_HDR_MSG_TYPE_MASK << WMI_DATA_HDR_MSG_TYPE_SHIFT)) | (t << WMI_DATA_HDR_MSG_TYPE_SHIFT))
+#define WMI_DATA_HDR_GET_UP(h) (((h)->info >> WMI_DATA_HDR_UP_SHIFT) & WMI_DATA_HDR_UP_MASK)
+#define WMI_DATA_HDR_SET_UP(h, p) (h)->info = (((h)->info & ~(WMI_DATA_HDR_UP_MASK << WMI_DATA_HDR_UP_SHIFT)) | (p << WMI_DATA_HDR_UP_SHIFT))
+
+#define WMI_DATA_HDR_GET_DATA_TYPE(h) (((h)->info >> WMI_DATA_HDR_DATA_TYPE_SHIFT) & WMI_DATA_HDR_DATA_TYPE_MASK)
+#define WMI_DATA_HDR_SET_DATA_TYPE(h, p) (h)->info = (((h)->info & ~(WMI_DATA_HDR_DATA_TYPE_MASK << WMI_DATA_HDR_DATA_TYPE_SHIFT)) | ((p) << WMI_DATA_HDR_DATA_TYPE_SHIFT))
+
+#define WMI_DATA_HDR_GET_DOT11(h) (WMI_DATA_HDR_GET_DATA_TYPE((h)) == WMI_DATA_HDR_DATA_TYPE_802_11)
+#define WMI_DATA_HDR_SET_DOT11(h, p) WMI_DATA_HDR_SET_DATA_TYPE((h), (p))
+
+/* Macros for operating on WMI_DATA_HDR (info2) field */
+#define WMI_DATA_HDR_SEQNO_MASK 0xFFF
+#define WMI_DATA_HDR_SEQNO_SHIFT 0
+
+#define WMI_DATA_HDR_AMSDU_MASK 0x1
+#define WMI_DATA_HDR_AMSDU_SHIFT 12
+
+#define WMI_DATA_HDR_META_MASK 0x7
+#define WMI_DATA_HDR_META_SHIFT 13
+
+#define GET_SEQ_NO(_v) ((_v) & WMI_DATA_HDR_SEQNO_MASK)
+#define GET_ISMSDU(_v) ((_v) & WMI_DATA_HDR_AMSDU_MASK)
+
+#define WMI_DATA_HDR_GET_SEQNO(h) GET_SEQ_NO((h)->info2 >> WMI_DATA_HDR_SEQNO_SHIFT)
+#define WMI_DATA_HDR_SET_SEQNO(h, _v) ((h)->info2 = ((h)->info2 & ~(WMI_DATA_HDR_SEQNO_MASK << WMI_DATA_HDR_SEQNO_SHIFT)) | (GET_SEQ_NO(_v) << WMI_DATA_HDR_SEQNO_SHIFT))
+
+#define WMI_DATA_HDR_IS_AMSDU(h) GET_ISMSDU((h)->info2 >> WMI_DATA_HDR_AMSDU_SHIFT)
+#define WMI_DATA_HDR_SET_AMSDU(h, _v) ((h)->info2 = ((h)->info2 & ~(WMI_DATA_HDR_AMSDU_MASK << WMI_DATA_HDR_AMSDU_SHIFT)) | (GET_ISMSDU(_v) << WMI_DATA_HDR_AMSDU_SHIFT))
+
+#define WMI_DATA_HDR_GET_META(h) (((h)->info2 >> WMI_DATA_HDR_META_SHIFT) & WMI_DATA_HDR_META_MASK)
+#define WMI_DATA_HDR_SET_META(h, _v) ((h)->info2 = ((h)->info2 & ~(WMI_DATA_HDR_META_MASK << WMI_DATA_HDR_META_SHIFT)) | ((_v) << WMI_DATA_HDR_META_SHIFT))
+
+/* Macros for operating on WMI_DATA_HDR (info3) field */
+#define WMI_DATA_HDR_DEVID_MASK 0xF
+#define WMI_DATA_HDR_DEVID_SHIFT 0
+#define GET_DEVID(_v) ((_v) & WMI_DATA_HDR_DEVID_MASK)
+
+#define WMI_DATA_HDR_GET_DEVID(h) (((h)->info3 >> WMI_DATA_HDR_DEVID_SHIFT) & WMI_DATA_HDR_DEVID_MASK)
+#define WMI_DATA_HDR_SET_DEVID(h, _v) ((h)->info3 = ((h)->info3 & ~(WMI_DATA_HDR_DEVID_MASK << WMI_DATA_HDR_DEVID_SHIFT)) | (GET_DEVID(_v) << WMI_DATA_HDR_DEVID_SHIFT))
+
+#define WMI_DATA_HDR_TRIGGER_MASK 0x1
+#define WMI_DATA_HDR_TRIGGER_SHIFT 4
+#define WMI_DATA_HDR_SET_TRIGGER(h, _v) ((h)->info3 = ((h)->info3 & ~(WMI_DATA_HDR_TRIGGER_MASK << WMI_DATA_HDR_TRIGGER_SHIFT)) | ((_v) << WMI_DATA_HDR_TRIGGER_SHIFT))
+#define WMI_DATA_HDR_IS_TRIGGER(h) ((((h)->info3 >> WMI_DATA_HDR_TRIGGER_SHIFT) & WMI_DATA_HDR_TRIGGER_MASK) == WMI_DATA_HDR_TRIGGER_MASK)
+
+#define WMI_DATA_HDR_EOSP_MASK WMI_DATA_HDR_TRIGGER_MASK
+#define WMI_DATA_HDR_EOSP_SHIFT WMI_DATA_HDR_TRIGGER_SHIFT
+
+#define WMI_DATA_HDR_SET_EOSP_BIT(h) ((h)->info3 |= (WMI_DATA_HDR_EOSP_MASK << WMI_DATA_HDR_EOSP_SHIFT))
+#define WMI_DATA_HDR_HAS_EOSP_BIT(h) ((h)->info3 & (WMI_DATA_HDR_EOSP_MASK << WMI_DATA_HDR_EOSP_SHIFT))
+
+typedef PREPACK struct {
+ A_INT8 rssi;
+ A_UINT8 info; /* usage of 'info' field(8-bit):
+ * b1:b0 - WMI_MSG_TYPE
+ * b4:b3:b2 - UP(tid)
+ * b5 - Used in AP mode. More-data in tx dir, PS in rx.
+ * b7:b6 - Dot3 header(0),
+ * Dot11 Header(1),
+ * ACL data(2)
+ */
+
+ A_UINT16 info2; /* usage of 'info2' field(16-bit):
+ * b11:b0 - seq_no
+ * b12 - A-MSDU?
+ * b15:b13 - META_DATA_VERSION 0 - 7
+ */
+ A_UINT16 info3; /* b3:b2:b1:b0 - device id
+ * b4 - Used in AP mode. uAPSD trigger in rx, EOSP in tx
+ */
+} POSTPACK WMI_DATA_HDR;
+
+/*
+ * TX META VERSION DEFINITIONS
+ */
+#define WMI_MAX_TX_META_SZ (12)
+#define WMI_MAX_TX_META_VERSION (7)
+#define WMI_META_VERSION_1 (0x01)
+#define WMI_META_VERSION_2 (0X02)
+#define WMI_META_VERSION_3 (0x03)
+
+#define WMI_ACL_TO_DOT11_HEADROOM 36
+
+#if 0 /* removed to prevent compile errors for WM.. */
+typedef PREPACK struct {
+/* intentionally empty. Default version is no meta data. */
+} POSTPACK WMI_TX_META_V0;
+#endif
+
+typedef PREPACK struct {
+ A_UINT8 pktID; /* The packet ID to identify the tx request */
+ A_UINT8 ratePolicyID; /* The rate policy to be used for the tx of this frame */
+} POSTPACK WMI_TX_META_V1;
+
+
+#define WMI_CSUM_DIR_TX (0x1)
+#define TX_CSUM_CALC_FILL (0x1)
+typedef PREPACK struct {
+ A_UINT8 csumStart; /*Offset from start of the Payload(SNAP header) for csum calculation to begin */
+ A_UINT8 csumDest; /*Offset from start of Payload(SNAP header) where final csum goes*/
+ A_UINT8 csumFlags; /*Flag for check sum engine to be offloaded to device*/
+} POSTPACK WMI_TX_META_V2;
+
+/* WMI_META_TX_FLAG... are used as TX qualifiers for frames containing WMI_TX_RATE_SCHEDULE in the
+ * meta data. 0 or more of these flags should be assigned to the flags member of the schedule. */
+#define WMI_META_TX_FLAG_ACK 0x01 // frame needs ACK response from receiver
+#define WMI_META_TX_FLAG_SET_RETRY_BIT 0x02 // device will set retry bit in MAC header for retried frames.
+#define WMI_META_TX_FLAG_SET_DURATION 0x04 // device will fill duration field in MAC header
+/* NOTE: If WMI_META_TX_FLAG_USE_PREFIX == 0 device will NOT use prefix frame.
+ * If WMI_META_TX_FLAG_USE_PREFIX == 1 && WMI_META_TX_FLAG_PREFIX_RTS == 0 device will use CTS prefix.
+ * If WMI_META_TX_FLAG_USE_PREFIX == 1 && WMI_META_TX_FLAG_PREFIX_RTS == 1 device will use RTS prefix.
+ */
+#define WMI_META_TX_FLAG_USE_PREFIX 0x08 // device will send either RTS or CTS frame prior to subject frame.
+#define WMI_META_TX_FLAG_PREFIX_RTS 0x10 // device will send RTS and wait for CTS prior to sending subject frame.
+#define WMI_META_TX_LOAD_TSF 0x20 // device will fill the TSF field during transmit procedure. <Beacons/probe responses>
+
+/* WMI_TX_RATE_SCHEDULE - Acts as a host-provided rate schedule to replace what would be normally determined
+ * by firmware. This allows the host to specify what rates and attempts should be used to transmit the
+ * frame. */
+typedef PREPACK struct {
+#define WMI_TX_MAX_RATE_SERIES (4)
+ A_UINT8 rateSeries[WMI_TX_MAX_RATE_SERIES]; //rate index for each series. first invalid rate terminates series.
+ A_UINT8 trySeries[WMI_TX_MAX_RATE_SERIES]; //number of tries for each series.
+ A_UINT8 flags; // combination of WMI_META_TX_FLAG...
+ A_UINT8 accessCategory; // should be WMM_AC_BE for managment frames and multicast frames.
+ //A_UINT8 keyIndex;
+ //
+}POSTPACK WMI_TX_RATE_SCHEDULE;
+
+typedef PREPACK struct {
+ WMI_TX_RATE_SCHEDULE rateSched;
+ A_UINT8 pktID; /* The packet ID to identify the tx request */
+} POSTPACK WMI_TX_META_V3;
+
+/*
+ * RX META VERSION DEFINITIONS
+ */
+/* if RX meta data is present at all then the meta data field
+ * will consume WMI_MAX_RX_META_SZ bytes of space between the
+ * WMI_DATA_HDR and the payload. How much of the available
+ * Meta data is actually used depends on which meta data
+ * version is active. */
+#define WMI_MAX_RX_META_SZ (12)
+#define WMI_MAX_RX_META_VERSION (7)
+
+#define WMI_RX_STATUS_OK 0 /* success */
+#define WMI_RX_STATUS_DECRYPT_ERR 1 /* decrypt error */
+#define WMI_RX_STATUS_MIC_ERR 2 /* tkip MIC error */
+#define WMI_RX_STATUS_ERR 3 /* undefined error */
+
+#define WMI_RX_FLAGS_AGGR 0x0001 /* part of AGGR */
+#define WMI_RX_FlAGS_STBC 0x0002 /* used STBC */
+#define WMI_RX_FLAGS_SGI 0x0004 /* used SGI */
+#define WMI_RX_FLAGS_HT 0x0008 /* is HT packet */
+/* the flags field is also used to store the CRYPTO_TYPE of the frame
+ * that value is shifted by WMI_RX_FLAGS_CRYPTO_SHIFT */
+#define WMI_RX_FLAGS_CRYPTO_SHIFT 4
+#define WMI_RX_FLAGS_CRYPTO_MASK 0x1f
+#define WMI_RX_META_GET_CRYPTO(flags) (((flags) >> WMI_RX_FLAGS_CRYPTO_SHIFT) & WMI_RX_FLAGS_CRYPTO_MASK)
+
+#if 0 /* removed to prevent compile errors for WM.. */
+typedef PREPACK struct {
+/* intentionally empty. Default version is no meta data. */
+} POSTPACK WMI_RX_META_VERSION_0;
+#endif
+
+typedef PREPACK struct {
+ A_UINT8 status; /* one of WMI_RX_STATUS_... */
+ A_UINT8 rix; /* rate index mapped to rate at which this packet was received. */
+ A_UINT8 rssi; /* rssi of packet */
+ A_UINT8 channel;/* rf channel during packet reception */
+ A_UINT16 flags; /* a combination of WMI_RX_FLAGS_... */
+} POSTPACK WMI_RX_META_V1;
+
+#define RX_CSUM_VALID_FLAG (0x1)
+typedef PREPACK struct {
+ A_UINT16 csum;
+ A_UINT8 csumFlags;/* bit 0 set -partial csum valid
+ bit 1 set -test mode */
+} POSTPACK WMI_RX_META_V2;
+
+
+
+#define WMI_GET_DEVICE_ID(info1) ((info1) & 0xF)
+/* Macros for operating on WMI_CMD_HDR (info1) field */
+#define WMI_CMD_HDR_DEVID_MASK 0xF
+#define WMI_CMD_HDR_DEVID_SHIFT 0
+#define GET_CMD_DEVID(_v) ((_v) & WMI_CMD_HDR_DEVID_MASK)
+
+#define WMI_CMD_HDR_GET_DEVID(h) (((h)->info1 >> WMI_CMD_HDR_DEVID_SHIFT) & WMI_CMD_HDR_DEVID_MASK)
+#define WMI_CMD_HDR_SET_DEVID(h, _v) ((h)->info1 = ((h)->info1 & ~(WMI_CMD_HDR_DEVID_MASK << WMI_CMD_HDR_DEVID_SHIFT)) | (GET_CMD_DEVID(_v) << WMI_CMD_HDR_DEVID_SHIFT))
+
+/*
+ * Control Path
+ */
+typedef PREPACK struct {
+ A_UINT16 commandId;
+/*
+ * info1 - 16 bits
+ * b03:b00 - id
+ * b15:b04 - unused
+ */
+ A_UINT16 info1;
+
+ A_UINT16 reserved; /* For alignment */
+} POSTPACK WMI_CMD_HDR; /* used for commands and events */
+
+/*
+ * List of Commnands
+ */
+typedef enum {
+ WMI_CONNECT_CMDID = 0x0001,
+ WMI_RECONNECT_CMDID,
+ WMI_DISCONNECT_CMDID,
+ WMI_SYNCHRONIZE_CMDID,
+ WMI_CREATE_PSTREAM_CMDID,
+ WMI_DELETE_PSTREAM_CMDID,
+ WMI_START_SCAN_CMDID,
+ WMI_SET_SCAN_PARAMS_CMDID,
+ WMI_SET_BSS_FILTER_CMDID,
+ WMI_SET_PROBED_SSID_CMDID, /* 10 */
+ WMI_SET_LISTEN_INT_CMDID,
+ WMI_SET_BMISS_TIME_CMDID,
+ WMI_SET_DISC_TIMEOUT_CMDID,
+ WMI_GET_CHANNEL_LIST_CMDID,
+ WMI_SET_BEACON_INT_CMDID,
+ WMI_GET_STATISTICS_CMDID,
+ WMI_SET_CHANNEL_PARAMS_CMDID,
+ WMI_SET_POWER_MODE_CMDID,
+ WMI_SET_IBSS_PM_CAPS_CMDID,
+ WMI_SET_POWER_PARAMS_CMDID, /* 20 */
+ WMI_SET_POWERSAVE_TIMERS_POLICY_CMDID,
+ WMI_ADD_CIPHER_KEY_CMDID,
+ WMI_DELETE_CIPHER_KEY_CMDID,
+ WMI_ADD_KRK_CMDID,
+ WMI_DELETE_KRK_CMDID,
+ WMI_SET_PMKID_CMDID,
+ WMI_SET_TX_PWR_CMDID,
+ WMI_GET_TX_PWR_CMDID,
+ WMI_SET_ASSOC_INFO_CMDID,
+ WMI_ADD_BAD_AP_CMDID, /* 30 */
+ WMI_DELETE_BAD_AP_CMDID,
+ WMI_SET_TKIP_COUNTERMEASURES_CMDID,
+ WMI_RSSI_THRESHOLD_PARAMS_CMDID,
+ WMI_TARGET_ERROR_REPORT_BITMASK_CMDID,
+ WMI_SET_ACCESS_PARAMS_CMDID,
+ WMI_SET_RETRY_LIMITS_CMDID,
+ WMI_RESERVED1,
+ WMI_RESERVED2,
+ WMI_SET_VOICE_PKT_SIZE_CMDID,
+ WMI_SET_MAX_SP_LEN_CMDID, /* 40 */
+ WMI_SET_ROAM_CTRL_CMDID,
+ WMI_GET_ROAM_TBL_CMDID,
+ WMI_GET_ROAM_DATA_CMDID,
+ WMI_ENABLE_RM_CMDID,
+ WMI_SET_MAX_OFFHOME_DURATION_CMDID,
+ WMI_EXTENSION_CMDID, /* Non-wireless extensions */
+ WMI_SNR_THRESHOLD_PARAMS_CMDID,
+ WMI_LQ_THRESHOLD_PARAMS_CMDID,
+ WMI_SET_LPREAMBLE_CMDID,
+ WMI_SET_RTS_CMDID, /* 50 */
+ WMI_CLR_RSSI_SNR_CMDID,
+ WMI_SET_FIXRATES_CMDID,
+ WMI_GET_FIXRATES_CMDID,
+ WMI_SET_AUTH_MODE_CMDID,
+ WMI_SET_REASSOC_MODE_CMDID,
+ WMI_SET_WMM_CMDID,
+ WMI_SET_WMM_TXOP_CMDID,
+ WMI_TEST_CMDID,
+ /* COEX AR6002 only*/
+ WMI_SET_BT_STATUS_CMDID,
+ WMI_SET_BT_PARAMS_CMDID, /* 60 */
+
+ WMI_SET_KEEPALIVE_CMDID,
+ WMI_GET_KEEPALIVE_CMDID,
+ WMI_SET_APPIE_CMDID,
+ WMI_GET_APPIE_CMDID,
+ WMI_SET_WSC_STATUS_CMDID,
+
+ /* Wake on Wireless */
+ WMI_SET_HOST_SLEEP_MODE_CMDID,
+ WMI_SET_WOW_MODE_CMDID,
+ WMI_GET_WOW_LIST_CMDID,
+ WMI_ADD_WOW_PATTERN_CMDID,
+ WMI_DEL_WOW_PATTERN_CMDID, /* 70 */
+
+ WMI_SET_FRAMERATES_CMDID,
+ WMI_SET_AP_PS_CMDID,
+ WMI_SET_QOS_SUPP_CMDID,
+ /* WMI_THIN_RESERVED_... mark the start and end
+ * values for WMI_THIN_RESERVED command IDs. These
+ * command IDs can be found in wmi_thin.h */
+ WMI_THIN_RESERVED_START = 0x8000,
+ WMI_THIN_RESERVED_END = 0x8fff,
+ /*
+ * Developer commands starts at 0xF000
+ */
+ WMI_SET_BITRATE_CMDID = 0xF000,
+ WMI_GET_BITRATE_CMDID,
+ WMI_SET_WHALPARAM_CMDID,
+
+
+ /*Should add the new command to the tail for compatible with
+ * etna.
+ */
+ WMI_SET_MAC_ADDRESS_CMDID,
+ WMI_SET_AKMP_PARAMS_CMDID,
+ WMI_SET_PMKID_LIST_CMDID,
+ WMI_GET_PMKID_LIST_CMDID,
+ WMI_ABORT_SCAN_CMDID,
+ WMI_SET_TARGET_EVENT_REPORT_CMDID,
+
+ // Unused
+ WMI_UNUSED1,
+ WMI_UNUSED2,
+
+ /*
+ * AP mode commands
+ */
+ WMI_AP_HIDDEN_SSID_CMDID, /* F00B */
+ WMI_AP_SET_NUM_STA_CMDID,
+ WMI_AP_ACL_POLICY_CMDID,
+ WMI_AP_ACL_MAC_LIST_CMDID,
+ WMI_AP_CONFIG_COMMIT_CMDID,
+ WMI_AP_SET_MLME_CMDID, /* F010 */
+ WMI_AP_SET_PVB_CMDID,
+ WMI_AP_CONN_INACT_CMDID,
+ WMI_AP_PROT_SCAN_TIME_CMDID,
+ WMI_AP_SET_COUNTRY_CMDID,
+ WMI_AP_SET_DTIM_CMDID,
+ WMI_AP_MODE_STAT_CMDID,
+
+ WMI_SET_IP_CMDID, /* F017 */
+ WMI_SET_PARAMS_CMDID,
+ WMI_SET_MCAST_FILTER_CMDID,
+ WMI_DEL_MCAST_FILTER_CMDID,
+
+ WMI_ALLOW_AGGR_CMDID, /* F01B */
+ WMI_ADDBA_REQ_CMDID,
+ WMI_DELBA_REQ_CMDID,
+ WMI_SET_HT_CAP_CMDID,
+ WMI_SET_HT_OP_CMDID,
+ WMI_SET_TX_SELECT_RATES_CMDID,
+ WMI_SET_TX_SGI_PARAM_CMDID,
+ WMI_SET_RATE_POLICY_CMDID,
+
+ WMI_HCI_CMD_CMDID, /* F023 */
+ WMI_RX_FRAME_FORMAT_CMDID,
+ WMI_SET_THIN_MODE_CMDID,
+ WMI_SET_BT_WLAN_CONN_PRECEDENCE_CMDID,
+
+ WMI_AP_SET_11BG_RATESET_CMDID, /* F027 */
+ WMI_SET_PMK_CMDID,
+ WMI_MCAST_FILTER_CMDID,
+ /* COEX CMDID AR6003*/
+ WMI_SET_BTCOEX_FE_ANT_CMDID, /* F02A */
+ WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID,
+ WMI_SET_BTCOEX_SCO_CONFIG_CMDID,
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMDID,
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMDID,
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMDID,
+ WMI_SET_BTCOEX_DEBUG_CMDID,
+ WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID,
+ WMI_GET_BTCOEX_STATS_CMDID,
+ WMI_GET_BTCOEX_CONFIG_CMDID,
+
+ WMI_SET_DFS_ENABLE_CMDID, /* F034 */
+ WMI_SET_DFS_MINRSSITHRESH_CMDID,
+ WMI_SET_DFS_MAXPULSEDUR_CMDID,
+ WMI_DFS_RADAR_DETECTED_CMDID,
+
+ /* P2P CMDS */
+ WMI_P2P_SET_CONFIG_CMDID, /* F038 */
+ WMI_WPS_SET_CONFIG_CMDID,
+ WMI_SET_REQ_DEV_ATTR_CMDID,
+ WMI_P2P_FIND_CMDID,
+ WMI_P2P_STOP_FIND_CMDID,
+ WMI_P2P_GO_NEG_START_CMDID,
+ WMI_P2P_LISTEN_CMDID,
+
+ WMI_CONFIG_TX_MAC_RULES_CMDID,
+ WMI_SET_PROMISCUOUS_MODE_CMDID,/* F040 */
+ WMI_RX_FRAME_FILTER_CMDID,
+ WMI_SET_CHANNEL_CMDID,
+
+ /* WAC commands */
+ WMI_ENABLE_WAC_CMDID,
+ WMI_WAC_SCAN_REPLY_CMDID,
+ WMI_WAC_CTRL_REQ_CMDID,
+ WMI_SET_DIV_PARAMS_CMDID,
+
+ WMI_GET_PMK_CMDID,
+ WMI_SET_PASSPHRASE_CMDID,
+ WMI_SEND_ASSOC_RES_CMDID,
+ WMI_SET_ASSOC_REQ_RELAY_CMDID,
+ WMI_GET_RFKILL_MODE_CMDID,
+ WMI_SET_RFKILL_MODE_CMDID,
+
+ /* ACS command, consists of sub-commands */
+ WMI_ACS_CTRL_CMDID,
+
+ /* Ultra low power store / recall commands */
+ WMI_STORERECALL_CONFIGURE_CMDID,
+ WMI_STORERECALL_RECALL_CMDID,
+ WMI_STORERECALL_HOST_READY_CMDID,
+ WMI_FORCE_TARGET_ASSERT_CMDID,
+ WMI_SET_EXCESS_TX_RETRY_THRES_CMDID,
+
+ WMI_P2P_GO_NEG_REQ_RSP_CMDID, /* F053 */
+ WMI_P2P_GRP_INIT_CMDID,
+ WMI_P2P_GRP_FORMATION_DONE_CMDID,
+ WMI_P2P_INVITE_CMDID,
+ WMI_P2P_INVITE_REQ_RSP_CMDID,
+ WMI_P2P_PROV_DISC_REQ_CMDID,
+ WMI_P2P_SET_CMDID,
+
+ WMI_AP_SET_APSD_CMDID, /* F05A */
+ WMI_AP_APSD_BUFFERED_TRAFFIC_CMDID,
+
+ WMI_P2P_SDPD_TX_CMDID, /* F05C */
+ WMI_P2P_STOP_SDPD_CMDID,
+ WMI_P2P_CANCEL_CMDID,
+ WMI_STA_BMISS_ENHANCE_CMDID,
+ WMI_AP_SET_IDLE_CLOSE_TIME_CMDID,
+ WMI_SEND_HS20_ACTION_CMDID,
+
+} WMI_COMMAND_ID;
+
+/*
+ * Frame Types
+ */
+typedef enum {
+ WMI_FRAME_BEACON = 0,
+ WMI_FRAME_PROBE_REQ,
+ WMI_FRAME_PROBE_RESP,
+ WMI_FRAME_ASSOC_REQ,
+ WMI_FRAME_ASSOC_RESP,
+ WMI_NUM_MGMT_FRAME
+} WMI_MGMT_FRAME_TYPE;
+
+/*
+ * Connect Command
+ */
+typedef enum {
+ INFRA_NETWORK = 0x01,
+ ADHOC_NETWORK = 0x02,
+ ADHOC_CREATOR = 0x04,
+ AP_NETWORK = 0x10,
+} NETWORK_TYPE;
+
+typedef enum {
+ SUBTYPE_NONE,
+ SUBTYPE_BT,
+ SUBTYPE_P2PDEV,
+ SUBTYPE_P2PCLIENT,
+ SUBTYPE_P2PGO,
+} NETWORK_SUBTYPE;
+
+typedef enum {
+ OPEN_AUTH = 0x01,
+ SHARED_AUTH = 0x02,
+ LEAP_AUTH = 0x04, /* different from IEEE_AUTH_MODE definitions */
+} DOT11_AUTH_MODE;
+
+typedef enum {
+ WMI_NONE_AUTH = 0x01,
+ WMI_WPA_AUTH = 0x02,
+ WMI_WPA2_AUTH = 0x04,
+ WMI_WPA_PSK_AUTH = 0x08,
+ WMI_WPA2_PSK_AUTH = 0x10,
+ WMI_WPA_AUTH_CCKM = 0x20,
+ WMI_WPA2_AUTH_CCKM = 0x40,
+} AUTH_MODE;
+
+typedef enum {
+ NONE_CRYPT = 0x01,
+ WEP_CRYPT = 0x02,
+ TKIP_CRYPT = 0x04,
+ AES_CRYPT = 0x08,
+#ifdef WAPI_ENABLE
+ WAPI_CRYPT = 0x10,
+#endif /*WAPI_ENABLE*/
+} CRYPTO_TYPE;
+
+#define WMI_MIN_CRYPTO_TYPE NONE_CRYPT
+#define WMI_MAX_CRYPTO_TYPE (AES_CRYPT + 1)
+
+#ifdef WAPI_ENABLE
+#undef WMI_MAX_CRYPTO_TYPE
+#define WMI_MAX_CRYPTO_TYPE (WAPI_CRYPT + 1)
+#endif /* WAPI_ENABLE */
+
+#ifdef WAPI_ENABLE
+#define IW_ENCODE_ALG_SM4 0x20
+/*
+ * Defined this to be some very high bit because it is less likely to be
+ * clobbered by future changes to the kernel's wireless.h file
+*/
+#define IW_AUTH_CIPHER_SMS4 0x40000000
+#endif
+
+#define WMI_MIN_KEY_INDEX 0
+#define WMI_MAX_KEY_INDEX 3
+
+#ifdef WAPI_ENABLE
+#undef WMI_MAX_KEY_INDEX
+#define WMI_MAX_KEY_INDEX 7 /* wapi grpKey 0-3, prwKey 4-7 */
+#endif /* WAPI_ENABLE */
+
+#define WMI_MAX_KEY_LEN 32
+
+#define WMI_MAX_SSID_LEN 32
+
+typedef enum {
+ CONNECT_ASSOC_POLICY_USER = 0x0001,
+ CONNECT_SEND_REASSOC = 0x0002,
+ CONNECT_IGNORE_WPAx_GROUP_CIPHER = 0x0004,
+ CONNECT_PROFILE_MATCH_DONE = 0x0008,
+ CONNECT_IGNORE_AAC_BEACON = 0x0010,
+ CONNECT_CSA_FOLLOW_BSS = 0x0020,
+ CONNECT_DO_WPA_OFFLOAD = 0x0040,
+ CONNECT_DO_NOT_DEAUTH = 0x0080,
+ CONNECT_WPS_FLAG = 0x0100,
+ CONNECT_IGNORE_BSSID_HINT = 0x0200,
+ CONNECT_STAY_AWAKE = 0x0400,
+ /* AP configuration flags */
+ AP_NO_DISASSOC_UPON_DEAUTH = 0x10000
+} WMI_CONNECT_CTRL_FLAGS_BITS;
+
+#define DEFAULT_CONNECT_CTRL_FLAGS (CONNECT_CSA_FOLLOW_BSS)
+
+typedef PREPACK struct {
+ A_UINT8 networkType;
+ A_UINT8 dot11AuthMode;
+ A_UINT8 authMode;
+ A_UINT8 pairwiseCryptoType;
+ A_UINT8 pairwiseCryptoLen;
+ A_UINT8 groupCryptoType;
+ A_UINT8 groupCryptoLen;
+ A_UINT8 ssidLength;
+ A_UCHAR ssid[WMI_MAX_SSID_LEN];
+ A_UINT16 channel;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT32 ctrl_flags;
+} POSTPACK WMI_CONNECT_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT32 divIdleTime;
+ A_UINT8 antRssiThresh;
+ A_UINT8 divEnable;
+ A_UINT16 active_treshold_rate;
+} POSTPACK WMI_DIV_PARAMS_CMD;
+
+/*
+ * WMI_RECONNECT_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT16 channel; /* hint */
+ A_UINT8 bssid[ATH_MAC_LEN]; /* mandatory if set */
+} POSTPACK WMI_RECONNECT_CMD;
+
+/*
+ * WMI_SET_PMK_CMDID
+ */
+#define WMI_PMK_LEN 32
+typedef PREPACK struct {
+ A_UINT8 pmk[WMI_PMK_LEN];
+} POSTPACK WMI_SET_PMK_CMD, WMI_GET_PMK_REPLY;
+
+/*
+ * WMI_SET_PASSPHRASE_CMDID
+ */
+#define WMI_PASSPHRASE_LEN 64
+typedef PREPACK struct {
+ A_UCHAR ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 passphrase[WMI_PASSPHRASE_LEN];
+ A_UINT8 ssid_len;
+ A_UINT8 passphrase_len;
+} POSTPACK WMI_SET_PASSPHRASE_CMD;
+
+/*
+ * WMI_SET_EXCESS_TX_RETRY_THRES_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT32 threshold;
+} POSTPACK WMI_SET_EXCESS_TX_RETRY_THRES_CMD;
+
+/*
+ * WMI_ADD_CIPHER_KEY_CMDID
+ */
+typedef enum {
+ PAIRWISE_USAGE = 0x00,
+ GROUP_USAGE = 0x01,
+ TX_USAGE = 0x02, /* default Tx Key - Static WEP only */
+} KEY_USAGE;
+
+/*
+ * Bit Flag
+ * Bit 0 - Initialise TSC - default is Initialize
+ */
+#define KEY_OP_INIT_TSC 0x01
+#define KEY_OP_INIT_RSC 0x02
+#ifdef WAPI_ENABLE
+#define KEY_OP_INIT_WAPIPN 0x10
+#endif /* WAPI_ENABLE */
+
+#define KEY_OP_INIT_VAL 0x03 /* Default Initialise the TSC & RSC */
+#define KEY_OP_VALID_MASK 0x03
+
+typedef PREPACK struct {
+ A_UINT8 keyIndex;
+ A_UINT8 keyType;
+ A_UINT8 keyUsage; /* KEY_USAGE */
+ A_UINT8 keyLength;
+ A_UINT8 keyRSC[8]; /* key replay sequence counter */
+ A_UINT8 key[WMI_MAX_KEY_LEN];
+ A_UINT8 key_op_ctrl; /* Additional Key Control information */
+ A_UINT8 key_macaddr[ATH_MAC_LEN];
+} POSTPACK WMI_ADD_CIPHER_KEY_CMD;
+
+/*
+ * WMI_DELETE_CIPHER_KEY_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 keyIndex;
+} POSTPACK WMI_DELETE_CIPHER_KEY_CMD;
+
+#define WMI_KRK_LEN 16
+/*
+ * WMI_ADD_KRK_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 krk[WMI_KRK_LEN];
+} POSTPACK WMI_ADD_KRK_CMD;
+
+/*
+ * WMI_SET_TKIP_COUNTERMEASURES_CMDID
+ */
+typedef enum {
+ WMI_TKIP_CM_DISABLE = 0x0,
+ WMI_TKIP_CM_ENABLE = 0x1,
+} WMI_TKIP_CM_CONTROL;
+
+typedef PREPACK struct {
+ A_UINT8 cm_en; /* WMI_TKIP_CM_CONTROL */
+} POSTPACK WMI_SET_TKIP_COUNTERMEASURES_CMD;
+
+/*
+ * WMI_SET_PMKID_CMDID
+ */
+
+#define WMI_PMKID_LEN 16
+
+typedef enum {
+ PMKID_DISABLE = 0,
+ PMKID_ENABLE = 1,
+} PMKID_ENABLE_FLG;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 enable; /* PMKID_ENABLE_FLG */
+ A_UINT8 pmkid[WMI_PMKID_LEN];
+} POSTPACK WMI_SET_PMKID_CMD;
+
+/*
+ * WMI_START_SCAN_CMD
+ */
+typedef enum {
+ WMI_LONG_SCAN = 0,
+ WMI_SHORT_SCAN = 1,
+} WMI_SCAN_TYPE;
+
+typedef PREPACK struct {
+ A_BOOL forceFgScan;
+ A_BOOL isLegacy; /* For Legacy Cisco AP compatibility */
+ A_UINT32 homeDwellTime; /* Maximum duration in the home channel(milliseconds) */
+ A_UINT32 forceScanInterval; /* Time interval between scans (milliseconds)*/
+ A_UINT8 scanType; /* WMI_SCAN_TYPE */
+ A_UINT8 numChannels; /* how many channels follow */
+ A_UINT16 channelList[1]; /* channels in Mhz */
+} POSTPACK WMI_START_SCAN_CMD;
+
+/*
+ * WMI_SET_SCAN_PARAMS_CMDID
+ */
+#define WMI_SHORTSCANRATIO_DEFAULT 3
+/*
+ * Warning: ScanCtrlFlag value of 0xFF is used to disable all flags in WMI_SCAN_PARAMS_CMD
+ * Do not add any more flags to WMI_SCAN_CTRL_FLAG_BITS
+ */
+typedef enum {
+ CONNECT_SCAN_CTRL_FLAGS = 0x01, /* set if can scan in the Connect cmd */
+ SCAN_CONNECTED_CTRL_FLAGS = 0x02, /* set if scan for the SSID it is */
+ /* already connected to */
+ ACTIVE_SCAN_CTRL_FLAGS = 0x04, /* set if enable active scan */
+ ROAM_SCAN_CTRL_FLAGS = 0x08, /* set if enable roam scan when bmiss and lowrssi */
+ REPORT_BSSINFO_CTRL_FLAGS = 0x10, /* set if follows customer BSSINFO reporting rule */
+ ENABLE_AUTO_CTRL_FLAGS = 0x20, /* if disabled, target doesn't
+ scan after a disconnect event */
+ ENABLE_SCAN_ABORT_EVENT = 0x40 /* Scan complete event with canceled status will be generated when a scan is prempted before it gets completed */
+} WMI_SCAN_CTRL_FLAGS_BITS;
+
+#define CAN_SCAN_IN_CONNECT(flags) (flags & CONNECT_SCAN_CTRL_FLAGS)
+#define CAN_SCAN_CONNECTED(flags) (flags & SCAN_CONNECTED_CTRL_FLAGS)
+#define ENABLE_ACTIVE_SCAN(flags) (flags & ACTIVE_SCAN_CTRL_FLAGS)
+#define ENABLE_ROAM_SCAN(flags) (flags & ROAM_SCAN_CTRL_FLAGS)
+#define CONFIG_REPORT_BSSINFO(flags) (flags & REPORT_BSSINFO_CTRL_FLAGS)
+#define IS_AUTO_SCAN_ENABLED(flags) (flags & ENABLE_AUTO_CTRL_FLAGS)
+#define SCAN_ABORT_EVENT_ENABLED(flags) (flags & ENABLE_SCAN_ABORT_EVENT)
+
+#define DEFAULT_SCAN_CTRL_FLAGS (CONNECT_SCAN_CTRL_FLAGS| SCAN_CONNECTED_CTRL_FLAGS| ACTIVE_SCAN_CTRL_FLAGS| ROAM_SCAN_CTRL_FLAGS | ENABLE_AUTO_CTRL_FLAGS)
+
+
+typedef PREPACK struct {
+ A_UINT16 fg_start_period; /* seconds */
+ A_UINT16 fg_end_period; /* seconds */
+ A_UINT16 bg_period; /* seconds */
+ A_UINT16 maxact_chdwell_time; /* msec */
+ A_UINT16 pas_chdwell_time; /* msec */
+ A_UINT8 shortScanRatio; /* how many shorts scan for one long */
+ A_UINT8 scanCtrlFlags;
+ A_UINT16 minact_chdwell_time; /* msec */
+ A_UINT16 maxact_scan_per_ssid; /* max active scans per ssid */
+ A_UINT32 max_dfsch_act_time; /* msecs */
+} POSTPACK WMI_SCAN_PARAMS_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 chan_index;
+ A_INT8 bang_radar;
+} POSTPACK WMI_RADAR_DETECTED_CMD;
+
+/*
+ * WMI_SET_BSS_FILTER_CMDID
+ */
+typedef enum {
+ NONE_BSS_FILTER = 0x0, /* no beacons forwarded */
+ ALL_BSS_FILTER, /* all beacons forwarded */
+ PROFILE_FILTER, /* only beacons matching profile */
+ ALL_BUT_PROFILE_FILTER, /* all but beacons matching profile */
+ CURRENT_BSS_FILTER, /* only beacons matching current BSS */
+ ALL_BUT_BSS_FILTER, /* all but beacons matching BSS */
+ PROBED_SSID_FILTER, /* beacons matching probed ssid */
+ LAST_BSS_FILTER, /* marker only */
+} WMI_BSS_FILTER;
+
+typedef PREPACK struct {
+ A_UINT8 bssFilter; /* see WMI_BSS_FILTER */
+ A_UINT8 reserved1; /* For alignment */
+ A_UINT16 reserved2; /* For alignment */
+ A_UINT32 ieMask;
+} POSTPACK WMI_BSS_FILTER_CMD;
+
+/*
+ * WMI_SET_PROBED_SSID_CMDID
+ */
+#define MAX_PROBED_SSID_INDEX 15
+
+typedef enum {
+ DISABLE_SSID_FLAG = 0, /* disables entry */
+ SPECIFIC_SSID_FLAG = 0x01, /* probes specified ssid */
+ ANY_SSID_FLAG = 0x02, /* probes for any ssid */
+} WMI_SSID_FLAG;
+
+typedef PREPACK struct {
+ A_UINT8 entryIndex; /* 0 to MAX_PROBED_SSID_INDEX */
+ A_UINT8 flag; /* WMI_SSID_FLG */
+ A_UINT8 ssidLength;
+ A_UINT8 ssid[32];
+} POSTPACK WMI_PROBED_SSID_CMD;
+
+/*
+ * WMI_SET_LISTEN_INT_CMDID
+ * The Listen interval is between 15 and 3000 TUs
+ */
+#define MIN_LISTEN_INTERVAL 15
+#define MAX_LISTEN_INTERVAL 5000
+#define MIN_LISTEN_BEACONS 1
+#define MAX_LISTEN_BEACONS 50
+
+typedef PREPACK struct {
+ A_UINT16 listenInterval;
+ A_UINT16 numBeacons;
+} POSTPACK WMI_LISTEN_INT_CMD;
+
+/*
+ * WMI_SET_BEACON_INT_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT16 beaconInterval;
+} POSTPACK WMI_BEACON_INT_CMD;
+
+/*
+ * WMI_SET_BMISS_TIME_CMDID
+ * valid values are between 1000 and 5000 TUs
+ */
+
+#define MIN_BMISS_TIME 1000
+#define MAX_BMISS_TIME 5000
+#define MIN_BMISS_BEACONS 1
+#define MAX_BMISS_BEACONS 50
+
+typedef PREPACK struct {
+ A_UINT16 bmissTime;
+ A_UINT16 numBeacons;
+} POSTPACK WMI_BMISS_TIME_CMD;
+
+/*
+ * WMI_SET_POWER_MODE_CMDID
+ */
+typedef enum {
+ REC_POWER = 0x01,
+ MAX_PERF_POWER,
+} WMI_POWER_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 powerMode; /* WMI_POWER_MODE */
+} POSTPACK WMI_POWER_MODE_CMD;
+
+typedef PREPACK struct {
+ A_INT8 status; /* WMI_SET_PARAMS_REPLY */
+} POSTPACK WMI_SET_PARAMS_REPLY;
+
+typedef PREPACK struct {
+ A_UINT32 opcode;
+ A_UINT32 length;
+ A_CHAR buffer[1]; /* WMI_SET_PARAMS */
+} POSTPACK WMI_SET_PARAMS_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 multicast_mac[ATH_MAC_LEN]; /* WMI_SET_MCAST_FILTER */
+} POSTPACK WMI_SET_MCAST_FILTER_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 enable; /* WMI_MCAST_FILTER */
+} POSTPACK WMI_MCAST_FILTER_CMD;
+
+/*
+ * WMI_SET_POWER_PARAMS_CMDID
+ */
+typedef enum {
+ IGNORE_DTIM = 0x01,
+ NORMAL_DTIM = 0x02,
+ STICK_DTIM = 0x03,
+ AUTO_DTIM = 0x04,
+} WMI_DTIM_POLICY;
+
+/* Policy to determnine whether TX should wakeup WLAN if sleeping */
+typedef enum {
+ TX_WAKEUP_UPON_SLEEP = 1,
+ TX_DONT_WAKEUP_UPON_SLEEP = 2
+} WMI_TX_WAKEUP_POLICY_UPON_SLEEP;
+
+/*
+ * Policy to determnine whether power save failure event should be sent to
+ * host during scanning
+ */
+typedef enum {
+ SEND_POWER_SAVE_FAIL_EVENT_ALWAYS = 1,
+ IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN = 2,
+} POWER_SAVE_FAIL_EVENT_POLICY;
+
+typedef PREPACK struct {
+ A_UINT16 idle_period; /* msec */
+ A_UINT16 pspoll_number;
+ A_UINT16 dtim_policy;
+ A_UINT16 tx_wakeup_policy;
+ A_UINT16 num_tx_to_wakeup;
+ A_UINT16 ps_fail_event_policy;
+} POSTPACK WMI_POWER_PARAMS_CMD;
+
+/* Adhoc power save types */
+typedef enum {
+ ADHOC_PS_DISABLE=1,
+ ADHOC_PS_ATH=2,
+ ADHOC_PS_IEEE=3,
+ ADHOC_PS_OTHER=4,
+} WMI_ADHOC_PS_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 power_saving;
+ A_UINT8 ttl; /* number of beacon periods */
+ A_UINT16 atim_windows; /* msec */
+ A_UINT16 timeout_value; /* msec */
+} POSTPACK WMI_IBSS_PM_CAPS_CMD;
+
+/* AP power save types */
+typedef enum {
+ AP_PS_DISABLE=1,
+ AP_PS_ATH=2,
+} WMI_AP_PS_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 idle_time; /* in msec */
+ A_UINT32 ps_period; /* in usec */
+ A_UINT8 sleep_period; /* in ps periods */
+ A_UINT8 psType;
+} POSTPACK WMI_AP_PS_CMD;
+
+/*
+ * WMI_SET_POWERSAVE_TIMERS_POLICY_CMDID
+ */
+typedef enum {
+ IGNORE_TIM_ALL_QUEUES_APSD = 0,
+ PROCESS_TIM_ALL_QUEUES_APSD = 1,
+ IGNORE_TIM_SIMULATED_APSD = 2,
+ PROCESS_TIM_SIMULATED_APSD = 3,
+} APSD_TIM_POLICY;
+
+typedef PREPACK struct {
+ A_UINT16 psPollTimeout; /* msec */
+ A_UINT16 triggerTimeout; /* msec */
+ A_UINT32 apsdTimPolicy; /* TIM behavior with ques APSD enabled. Default is IGNORE_TIM_ALL_QUEUES_APSD */
+ A_UINT32 simulatedAPSDTimPolicy; /* TIM behavior with simulated APSD enabled. Default is PROCESS_TIM_SIMULATED_APSD */
+} POSTPACK WMI_POWERSAVE_TIMERS_POLICY_CMD;
+
+/*
+ * WMI_SET_VOICE_PKT_SIZE_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT16 voicePktSize;
+} POSTPACK WMI_SET_VOICE_PKT_SIZE_CMD;
+
+/*
+ * WMI_SET_MAX_SP_LEN_CMDID
+ */
+typedef enum {
+ DELIVER_ALL_PKT = 0x0,
+ DELIVER_2_PKT = 0x1,
+ DELIVER_4_PKT = 0x2,
+ DELIVER_6_PKT = 0x3,
+} APSD_SP_LEN_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 maxSPLen;
+} POSTPACK WMI_SET_MAX_SP_LEN_CMD;
+
+/*
+ * WMI_SET_DISC_TIMEOUT_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 disconnectTimeout; /* seconds */
+} POSTPACK WMI_DISC_TIMEOUT_CMD;
+
+typedef enum {
+ UPLINK_TRAFFIC = 0,
+ DNLINK_TRAFFIC = 1,
+ BIDIR_TRAFFIC = 2,
+} DIR_TYPE;
+
+typedef enum {
+ DISABLE_FOR_THIS_AC = 0,
+ ENABLE_FOR_THIS_AC = 1,
+ ENABLE_FOR_ALL_AC = 2,
+} VOICEPS_CAP_TYPE;
+
+typedef enum {
+ TRAFFIC_TYPE_APERIODIC = 0,
+ TRAFFIC_TYPE_PERIODIC = 1,
+}TRAFFIC_TYPE;
+
+/*
+ * WMI_SYNCHRONIZE_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 dataSyncMap;
+} POSTPACK WMI_SYNC_CMD;
+
+/*
+ * WMI_CREATE_PSTREAM_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT32 minServiceInt; /* in milli-sec */
+ A_UINT32 maxServiceInt; /* in milli-sec */
+ A_UINT32 inactivityInt; /* in milli-sec */
+ A_UINT32 suspensionInt; /* in milli-sec */
+ A_UINT32 serviceStartTime;
+ A_UINT32 minDataRate; /* in bps */
+ A_UINT32 meanDataRate; /* in bps */
+ A_UINT32 peakDataRate; /* in bps */
+ A_UINT32 maxBurstSize;
+ A_UINT32 delayBound;
+ A_UINT32 minPhyRate; /* in bps */
+ A_UINT32 sba;
+ A_UINT32 mediumTime;
+ A_UINT16 nominalMSDU; /* in octects */
+ A_UINT16 maxMSDU; /* in octects */
+ A_UINT8 trafficClass;
+ A_UINT8 trafficDirection; /* DIR_TYPE */
+ A_UINT8 rxQueueNum;
+ A_UINT8 trafficType; /* TRAFFIC_TYPE */
+ A_UINT8 voicePSCapability; /* VOICEPS_CAP_TYPE */
+ A_UINT8 tsid;
+ A_UINT8 userPriority; /* 802.1D user priority */
+ A_UINT8 nominalPHY; /* nominal phy rate */
+} POSTPACK WMI_CREATE_PSTREAM_CMD;
+
+/*
+ * WMI_DELETE_PSTREAM_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficDirection;
+ A_UINT8 trafficClass;
+ A_UINT8 tsid;
+} POSTPACK WMI_DELETE_PSTREAM_CMD;
+
+/*
+ * WMI_SET_CHANNEL_PARAMS_CMDID
+ */
+typedef enum {
+ WMI_11A_MODE = 0x1,
+ WMI_11G_MODE = 0x2,
+ WMI_11AG_MODE = 0x3,
+ WMI_11B_MODE = 0x4,
+ WMI_11GONLY_MODE = 0x5,
+} WMI_PHY_MODE;
+
+#define WMI_MAX_CHANNELS 32
+
+typedef PREPACK struct {
+ A_UINT8 reserved1;
+ A_UINT8 scanParam; /* set if enable scan */
+ A_UINT8 phyMode; /* see WMI_PHY_MODE */
+ A_UINT8 numChannels; /* how many channels follow */
+ A_UINT16 channelList[1]; /* channels in Mhz */
+} POSTPACK WMI_CHANNEL_PARAMS_CMD;
+
+
+/*
+ * WMI_RSSI_THRESHOLD_PARAMS_CMDID
+ * Setting the polltime to 0 would disable polling.
+ * Threshold values are in the ascending order, and should agree to:
+ * (lowThreshold_lowerVal < lowThreshold_upperVal < highThreshold_lowerVal
+ * < highThreshold_upperVal)
+ */
+
+typedef PREPACK struct WMI_RSSI_THRESHOLD_PARAMS{
+ A_UINT32 pollTime; /* Polling time as a factor of LI */
+ A_INT16 thresholdAbove1_Val; /* lowest of upper */
+ A_INT16 thresholdAbove2_Val;
+ A_INT16 thresholdAbove3_Val;
+ A_INT16 thresholdAbove4_Val;
+ A_INT16 thresholdAbove5_Val;
+ A_INT16 thresholdAbove6_Val; /* highest of upper */
+ A_INT16 thresholdBelow1_Val; /* lowest of bellow */
+ A_INT16 thresholdBelow2_Val;
+ A_INT16 thresholdBelow3_Val;
+ A_INT16 thresholdBelow4_Val;
+ A_INT16 thresholdBelow5_Val;
+ A_INT16 thresholdBelow6_Val; /* highest of bellow */
+ A_UINT8 weight; /* "alpha" */
+ A_UINT8 reserved[3];
+} POSTPACK WMI_RSSI_THRESHOLD_PARAMS_CMD;
+
+/*
+ * WMI_SNR_THRESHOLD_PARAMS_CMDID
+ * Setting the polltime to 0 would disable polling.
+ */
+
+typedef PREPACK struct WMI_SNR_THRESHOLD_PARAMS{
+ A_UINT32 pollTime; /* Polling time as a factor of LI */
+ A_UINT8 weight; /* "alpha" */
+ A_UINT8 thresholdAbove1_Val; /* lowest of uppper*/
+ A_UINT8 thresholdAbove2_Val;
+ A_UINT8 thresholdAbove3_Val;
+ A_UINT8 thresholdAbove4_Val; /* highest of upper */
+ A_UINT8 thresholdBelow1_Val; /* lowest of bellow */
+ A_UINT8 thresholdBelow2_Val;
+ A_UINT8 thresholdBelow3_Val;
+ A_UINT8 thresholdBelow4_Val; /* highest of bellow */
+ A_UINT8 reserved[3];
+} POSTPACK WMI_SNR_THRESHOLD_PARAMS_CMD;
+
+/*
+ * WMI_LQ_THRESHOLD_PARAMS_CMDID
+ */
+typedef PREPACK struct WMI_LQ_THRESHOLD_PARAMS {
+ A_UINT8 enable;
+ A_UINT8 thresholdAbove1_Val;
+ A_UINT8 thresholdAbove2_Val;
+ A_UINT8 thresholdAbove3_Val;
+ A_UINT8 thresholdAbove4_Val;
+ A_UINT8 thresholdBelow1_Val;
+ A_UINT8 thresholdBelow2_Val;
+ A_UINT8 thresholdBelow3_Val;
+ A_UINT8 thresholdBelow4_Val;
+ A_UINT8 reserved[3];
+} POSTPACK WMI_LQ_THRESHOLD_PARAMS_CMD;
+
+typedef enum {
+ WMI_LPREAMBLE_DISABLED = 0,
+ WMI_LPREAMBLE_ENABLED
+} WMI_LPREAMBLE_STATUS;
+
+typedef enum {
+ WMI_IGNORE_BARKER_IN_ERP = 0,
+ WMI_DONOT_IGNORE_BARKER_IN_ERP
+} WMI_PREAMBLE_POLICY;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+ A_UINT8 preamblePolicy;
+}POSTPACK WMI_SET_LPREAMBLE_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 threshold;
+}POSTPACK WMI_SET_RTS_CMD;
+
+/*
+ * WMI_TARGET_ERROR_REPORT_BITMASK_CMDID
+ * Sets the error reporting event bitmask in target. Target clears it
+ * upon an error. Subsequent errors are counted, but not reported
+ * via event, unless the bitmask is set again.
+ */
+typedef PREPACK struct {
+ A_UINT32 bitmask;
+} POSTPACK WMI_TARGET_ERROR_REPORT_BITMASK;
+
+/*
+ * WMI_SET_TX_PWR_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 dbM; /* in dbM units */
+} POSTPACK WMI_SET_TX_PWR_CMD, WMI_TX_PWR_REPLY;
+
+/*
+ * WMI_SET_ASSOC_INFO_CMDID
+ *
+ * A maximum of 2 private IEs can be sent in the [Re]Assoc request.
+ * A 3rd one, the CCX version IE can also be set from the host.
+ */
+#define WMI_MAX_ASSOC_INFO_TYPE 2
+#define WMI_CCX_VER_IE 2 /* ieType to set CCX Version IE */
+
+#define WMI_MAX_ASSOC_INFO_LEN 240
+
+typedef PREPACK struct {
+ A_UINT8 ieType;
+ A_UINT8 bufferSize;
+ A_UINT8 assocInfo[1]; /* up to WMI_MAX_ASSOC_INFO_LEN */
+} POSTPACK WMI_SET_ASSOC_INFO_CMD;
+
+
+/*
+ * WMI_GET_TX_PWR_CMDID does not take any parameters
+ */
+
+/*
+ * WMI_ADD_BAD_AP_CMDID
+ */
+#define WMI_MAX_BAD_AP_INDEX 1
+
+typedef PREPACK struct {
+ A_UINT8 badApIndex; /* 0 to WMI_MAX_BAD_AP_INDEX */
+ A_UINT8 bssid[ATH_MAC_LEN];
+} POSTPACK WMI_ADD_BAD_AP_CMD;
+
+/*
+ * WMI_DELETE_BAD_AP_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 badApIndex; /* 0 to WMI_MAX_BAD_AP_INDEX */
+} POSTPACK WMI_DELETE_BAD_AP_CMD;
+
+/*
+ * WMI_SET_ACCESS_PARAMS_CMDID
+ */
+#define WMI_DEFAULT_TXOP_ACPARAM 0 /* implies one MSDU */
+#define WMI_DEFAULT_ECWMIN_ACPARAM 4 /* corresponds to CWmin of 15 */
+#define WMI_DEFAULT_ECWMAX_ACPARAM 10 /* corresponds to CWmax of 1023 */
+#define WMI_MAX_CW_ACPARAM 15 /* maximum eCWmin or eCWmax */
+#define WMI_DEFAULT_AIFSN_ACPARAM 2
+#define WMI_MAX_AIFSN_ACPARAM 15
+typedef PREPACK struct {
+ A_UINT16 txop; /* in units of 32 usec */
+ A_UINT8 eCWmin;
+ A_UINT8 eCWmax;
+ A_UINT8 aifsn;
+ A_UINT8 ac;
+} POSTPACK WMI_SET_ACCESS_PARAMS_CMD;
+
+
+/*
+ * WMI_SET_RETRY_LIMITS_CMDID
+ *
+ * This command is used to customize the number of retries the
+ * wlan device will perform on a given frame.
+ */
+#define WMI_MIN_RETRIES 2
+#define WMI_MAX_RETRIES 13
+typedef enum {
+ MGMT_FRAMETYPE = 0,
+ CONTROL_FRAMETYPE = 1,
+ DATA_FRAMETYPE = 2
+} WMI_FRAMETYPE;
+
+typedef PREPACK struct {
+ A_UINT8 frameType; /* WMI_FRAMETYPE */
+ A_UINT8 trafficClass; /* applies only to DATA_FRAMETYPE */
+ A_UINT8 maxRetries;
+ A_UINT8 enableNotify;
+} POSTPACK WMI_SET_RETRY_LIMITS_CMD;
+
+/*
+ * WMI_SET_ROAM_CTRL_CMDID
+ *
+ * This command is used to influence the Roaming behaviour
+ * Set the host biases of the BSSs before setting the roam mode as bias
+ * based.
+ */
+
+/*
+ * Different types of Roam Control
+ */
+
+typedef enum {
+ WMI_FORCE_ROAM = 1, /* Roam to the specified BSSID */
+ WMI_SET_ROAM_MODE = 2, /* default ,progd bias, no roam */
+ WMI_SET_HOST_BIAS = 3, /* Set the Host Bias */
+ WMI_SET_LOWRSSI_SCAN_PARAMS = 4, /* Set lowrssi Scan parameters */
+} WMI_ROAM_CTRL_TYPE;
+
+#define WMI_MIN_ROAM_CTRL_TYPE WMI_FORCE_ROAM
+#define WMI_MAX_ROAM_CTRL_TYPE WMI_SET_LOWRSSI_SCAN_PARAMS
+
+/*
+ * ROAM MODES
+ */
+
+typedef enum {
+ WMI_DEFAULT_ROAM_MODE = 1, /* RSSI based ROAM */
+ WMI_HOST_BIAS_ROAM_MODE = 2, /* HOST BIAS based ROAM */
+ WMI_LOCK_BSS_MODE = 3 /* Lock to the Current BSS - no Roam */
+} WMI_ROAM_MODE;
+
+/*
+ * BSS HOST BIAS INFO
+ */
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_INT8 bias;
+} POSTPACK WMI_BSS_BIAS;
+
+typedef PREPACK struct {
+ A_UINT8 numBss;
+ WMI_BSS_BIAS bssBias[1];
+} POSTPACK WMI_BSS_BIAS_INFO;
+
+typedef PREPACK struct WMI_LOWRSSI_SCAN_PARAMS {
+ A_UINT16 lowrssi_scan_period;
+ A_INT16 lowrssi_scan_threshold;
+ A_INT16 lowrssi_roam_threshold;
+ A_UINT8 roam_rssi_floor;
+ A_UINT8 reserved[1]; /* For alignment */
+} POSTPACK WMI_LOWRSSI_SCAN_PARAMS;
+
+typedef PREPACK struct {
+ PREPACK union {
+ A_UINT8 bssid[ATH_MAC_LEN]; /* WMI_FORCE_ROAM */
+ A_UINT8 roamMode; /* WMI_SET_ROAM_MODE */
+ WMI_BSS_BIAS_INFO bssBiasInfo; /* WMI_SET_HOST_BIAS */
+ WMI_LOWRSSI_SCAN_PARAMS lrScanParams;
+ } POSTPACK info;
+ A_UINT8 roamCtrlType ;
+} POSTPACK WMI_SET_ROAM_CTRL_CMD;
+
+/*
+ * WMI_SET_BT_WLAN_CONN_PRECEDENCE_CMDID
+ */
+typedef enum {
+ BT_WLAN_CONN_PRECDENCE_WLAN=0, /* Default */
+ BT_WLAN_CONN_PRECDENCE_PAL,
+} BT_WLAN_CONN_PRECEDENCE;
+
+typedef PREPACK struct {
+ A_UINT8 precedence;
+} POSTPACK WMI_SET_BT_WLAN_CONN_PRECEDENCE;
+
+/*
+ * WMI_ENABLE_RM_CMDID
+ */
+typedef PREPACK struct {
+ A_BOOL enable_radio_measurements;
+} POSTPACK WMI_ENABLE_RM_CMD;
+
+/*
+ * WMI_SET_MAX_OFFHOME_DURATION_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 max_offhome_duration;
+} POSTPACK WMI_SET_MAX_OFFHOME_DURATION_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 frequency;
+ A_UINT8 threshold;
+} POSTPACK WMI_SET_HB_CHALLENGE_RESP_PARAMS_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 enable;
+} POSTPACK WMI_SET_DFS_CMD;
+
+
+typedef enum {
+ WMI_CCX_RM_STATUS_UNKNOWN = 0,
+ WMI_CCX_RM_REPORT_SENT,
+ WMI_CCX_RM_REFUSE_REPORT_SENT,
+ WMI_CCX_RM_STATUS_MAX
+} WMI_CCX_RM_STATUS_TYPE;
+
+/*---------------------- BTCOEX RELATED -------------------------------------*/
+/*----------------------COMMON to AR6002 and AR6003 -------------------------*/
+typedef enum {
+ BT_STREAM_UNDEF = 0,
+ BT_STREAM_SCO, /* SCO stream */
+ BT_STREAM_A2DP, /* A2DP stream */
+ BT_STREAM_SCAN, /* BT Discovery or Page */
+ BT_STREAM_ESCO,
+ BT_STREAM_MAX
+} BT_STREAM_TYPE;
+
+typedef enum {
+ BT_PARAM_SCO_PSPOLL_LATENCY_ONE_FOURTH =1,
+ BT_PARAM_SCO_PSPOLL_LATENCY_HALF,
+ BT_PARAM_SCO_PSPOLL_LATENCY_THREE_FOURTH,
+} BT_PARAMS_SCO_PSPOLL_LATENCY;
+
+typedef enum {
+ BT_PARAMS_SCO_STOMP_SCO_NEVER =1,
+ BT_PARAMS_SCO_STOMP_SCO_ALWAYS,
+ BT_PARAMS_SCO_STOMP_SCO_IN_LOWRSSI,
+} BT_PARAMS_SCO_STOMP_RULES;
+
+typedef enum {
+ BT_STATUS_UNDEF = 0,
+ BT_STATUS_ON,
+ BT_STATUS_OFF,
+ BT_STATUS_MAX
+} BT_STREAM_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 streamType;
+ A_UINT8 status;
+} POSTPACK WMI_SET_BT_STATUS_CMD;
+
+typedef enum {
+ BT_ANT_TYPE_UNDEF=0,
+ BT_ANT_TYPE_DUAL,
+ BT_ANT_TYPE_SPLITTER,
+ BT_ANT_TYPE_SWITCH,
+ BT_ANT_TYPE_HIGH_ISO_DUAL
+} BT_ANT_FRONTEND_CONFIG;
+
+typedef enum {
+ BT_COLOCATED_DEV_BTS4020=0,
+ BT_COLCATED_DEV_CSR ,
+ BT_COLOCATED_DEV_VALKYRIE
+} BT_COLOCATED_DEV_TYPE;
+
+/*********************** Applicable to AR6002 ONLY ******************************/
+
+typedef enum {
+ BT_PARAM_SCO = 1, /* SCO stream parameters */
+ BT_PARAM_A2DP ,
+ BT_PARAM_ANTENNA_CONFIG,
+ BT_PARAM_COLOCATED_BT_DEVICE,
+ BT_PARAM_ACLCOEX,
+ BT_PARAM_11A_SEPARATE_ANT,
+ BT_PARAM_MAX
+} BT_PARAM_TYPE;
+
+
+#define BT_SCO_ALLOW_CLOSE_RANGE_OPT (1 << 0)
+#define BT_SCO_FORCE_AWAKE_OPT (1 << 1)
+#define BT_SCO_SET_RSSI_OVERRIDE(flags) ((flags) |= (1 << 2))
+#define BT_SCO_GET_RSSI_OVERRIDE(flags) (((flags) >> 2) & 0x1)
+#define BT_SCO_SET_RTS_OVERRIDE(flags) ((flags) |= (1 << 3))
+#define BT_SCO_GET_RTS_OVERRIDE(flags) (((flags) >> 3) & 0x1)
+#define BT_SCO_GET_MIN_LOW_RATE_CNT(flags) (((flags) >> 8) & 0xFF)
+#define BT_SCO_GET_MAX_LOW_RATE_CNT(flags) (((flags) >> 16) & 0xFF)
+#define BT_SCO_SET_MIN_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 8)
+#define BT_SCO_SET_MAX_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 16)
+
+typedef PREPACK struct {
+ A_UINT32 numScoCyclesForceTrigger; /* Number SCO cycles after which
+ force a pspoll. default = 10 */
+ A_UINT32 dataResponseTimeout; /* Timeout Waiting for Downlink pkt
+ in response for ps-poll,
+ default = 10 msecs */
+ A_UINT32 stompScoRules;
+ A_UINT32 scoOptFlags; /* SCO Options Flags :
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 Force awake during close range
+ 2 If set use host supplied RSSI for OPT
+ 3 If set use host supplied RTS COUNT for OPT
+ 4..7 Unused
+ 8..15 Low Data Rate Min Cnt
+ 16..23 Low Data Rate Max Cnt
+ */
+
+ A_UINT8 stompDutyCyleVal; /* Sco cycles to limit ps-poll queuing
+ if stomped */
+ A_UINT8 stompDutyCyleMaxVal; /*firm ware increases stomp duty cycle
+ gradually uptill this value on need basis*/
+ A_UINT8 psPollLatencyFraction; /* Fraction of idle
+ period, within which
+ additional ps-polls
+ can be queued */
+ A_UINT8 noSCOSlots; /* Number of SCO Tx/Rx slots.
+ HVx, EV3, 2EV3 = 2 */
+ A_UINT8 noIdleSlots; /* Number of Bluetooth idle slots between
+ consecutive SCO Tx/Rx slots
+ HVx, EV3 = 4
+ 2EV3 = 10 */
+ A_UINT8 scoOptOffRssi;/*RSSI value below which we go to ps poll*/
+ A_UINT8 scoOptOnRssi; /*RSSI value above which we reenter opt mode*/
+ A_UINT8 scoOptRtsCount;
+} POSTPACK BT_PARAMS_SCO;
+
+#define BT_A2DP_ALLOW_CLOSE_RANGE_OPT (1 << 0)
+#define BT_A2DP_FORCE_AWAKE_OPT (1 << 1)
+#define BT_A2DP_SET_RSSI_OVERRIDE(flags) ((flags) |= (1 << 2))
+#define BT_A2DP_GET_RSSI_OVERRIDE(flags) (((flags) >> 2) & 0x1)
+#define BT_A2DP_SET_RTS_OVERRIDE(flags) ((flags) |= (1 << 3))
+#define BT_A2DP_GET_RTS_OVERRIDE(flags) (((flags) >> 3) & 0x1)
+#define BT_A2DP_GET_MIN_LOW_RATE_CNT(flags) (((flags) >> 8) & 0xFF)
+#define BT_A2DP_GET_MAX_LOW_RATE_CNT(flags) (((flags) >> 16) & 0xFF)
+#define BT_A2DP_SET_MIN_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 8)
+#define BT_A2DP_SET_MAX_LOW_RATE_CNT(flags,val) (flags) |= (((val) & 0xFF) << 16)
+
+typedef PREPACK struct {
+ A_UINT32 a2dpWlanUsageLimit; /* MAX time firmware uses the medium for
+ wlan, after it identifies the idle time
+ default (30 msecs) */
+ A_UINT32 a2dpBurstCntMin; /* Minimum number of bluetooth data frames
+ to replenish Wlan Usage limit (default 3) */
+ A_UINT32 a2dpDataRespTimeout;
+ A_UINT32 a2dpOptFlags; /* A2DP Option flags:
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 Force awake during close range
+ 2 If set use host supplied RSSI for OPT
+ 3 If set use host supplied RTS COUNT for OPT
+ 4..7 Unused
+ 8..15 Low Data Rate Min Cnt
+ 16..23 Low Data Rate Max Cnt
+ */
+ A_UINT8 isCoLocatedBtRoleMaster;
+ A_UINT8 a2dpOptOffRssi;/*RSSI value below which we go to ps poll*/
+ A_UINT8 a2dpOptOnRssi; /*RSSI value above which we reenter opt mode*/
+ A_UINT8 a2dpOptRtsCount;
+}POSTPACK BT_PARAMS_A2DP;
+
+/* During BT ftp/ BT OPP or any another data based acl profile on bluetooth
+ (non a2dp).*/
+typedef PREPACK struct {
+ A_UINT32 aclWlanMediumUsageTime; /* Wlan usage time during Acl (non-a2dp)
+ coexistence (default 30 msecs) */
+ A_UINT32 aclBtMediumUsageTime; /* Bt usage time during acl coexistence
+ (default 30 msecs)*/
+ A_UINT32 aclDataRespTimeout;
+ A_UINT32 aclDetectTimeout; /* ACL coexistence enabled if we get
+ 10 Pkts in X msec(default 100 msecs) */
+ A_UINT32 aclmaxPktCnt; /* No of ACL pkts to receive before
+ enabling ACL coex */
+
+}POSTPACK BT_PARAMS_ACLCOEX;
+
+typedef PREPACK struct {
+ PREPACK union {
+ BT_PARAMS_SCO scoParams;
+ BT_PARAMS_A2DP a2dpParams;
+ BT_PARAMS_ACLCOEX aclCoexParams;
+ A_UINT8 antType; /* 0 -Disabled (default)
+ 1 - BT_ANT_TYPE_DUAL
+ 2 - BT_ANT_TYPE_SPLITTER
+ 3 - BT_ANT_TYPE_SWITCH */
+ A_UINT8 coLocatedBtDev; /* 0 - BT_COLOCATED_DEV_BTS4020 (default)
+ 1 - BT_COLCATED_DEV_CSR
+ 2 - BT_COLOCATED_DEV_VALKYRIe
+ */
+ } POSTPACK info;
+ A_UINT8 paramType ;
+} POSTPACK WMI_SET_BT_PARAMS_CMD;
+
+/************************ END AR6002 BTCOEX *******************************/
+/*-----------------------AR6003 BTCOEX -----------------------------------*/
+
+/* ---------------WMI_SET_BTCOEX_FE_ANT_CMDID --------------------------*/
+/* Indicates front end antenna configuration. This command needs to be issued
+ * right after initialization and after WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID.
+ * AR6003 enables coexistence and antenna switching based on the configuration.
+ */
+typedef enum {
+ WMI_BTCOEX_NOT_ENABLED = 0,
+ WMI_BTCOEX_FE_ANT_SINGLE =1,
+ WMI_BTCOEX_FE_ANT_DUAL=2,
+ WMI_BTCOEX_FE_ANT_DUAL_HIGH_ISO=3,
+ WMI_BTCOEX_FE_ANT_BYPASS_MODE=4,
+ WMI_BTCOEX_FE_ANT_COMBINE_MODE=5,
+ WMI_BTCOEX_FE_ANT_TYPE_MAX
+}WMI_BTCOEX_FE_ANT_TYPE;
+
+typedef PREPACK struct {
+ A_UINT8 btcoexFeAntType; /* 1 - WMI_BTCOEX_FE_ANT_SINGLE for single antenna front end
+ 2 - WMI_BTCOEX_FE_ANT_DUAL for dual antenna front end
+ (for isolations less 35dB, for higher isolation there
+ is not need to pass this command).
+ (not implemented)
+ */
+}POSTPACK WMI_SET_BTCOEX_FE_ANT_CMD;
+
+/* -------------WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID ----------------*/
+/* Indicate the bluetooth chip to the firmware. Firmware can have different algorithm based
+ * bluetooth chip type.Based on bluetooth device, different coexistence protocol would be used.
+ */
+typedef PREPACK struct {
+ A_UINT8 btcoexCoLocatedBTdev; /*1 - Qcom BT (3 -wire PTA)
+ 2 - CSR BT (3 wire PTA)
+ 3 - Atheros 3001 BT (3 wire PTA)
+ 4 - STE bluetooth (4-wire ePTA)
+ 5 - Atheros 3002 BT (4-wire MCI)
+ defaults= 3 (Atheros 3001 BT )
+ */
+}POSTPACK WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD;
+
+/* -------------WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMDID ------------*/
+/* Configuration parameters during bluetooth inquiry and page. Page configuration
+ * is applicable only on interfaces which can distinguish page (applicable only for ePTA -
+ * STE bluetooth).
+ * Bluetooth inquiry start and end is indicated via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID.
+ * During this the station will be power-save mode.
+ */
+typedef PREPACK struct {
+ A_UINT32 btInquiryDataFetchFrequency;/* The frequency of querying the AP for data
+ (via pspoll) is configured by this parameter.
+ "default = 10 ms" */
+
+ A_UINT32 protectBmissDurPostBtInquiry;/* The firmware will continue to be in inquiry state
+ for configured duration, after inquiry completion
+ . This is to ensure other bluetooth transactions
+ (RDP, SDP profiles, link key exchange ...etc)
+ goes through smoothly without wifi stomping.
+ default = 10 secs*/
+
+ A_UINT32 maxpageStomp; /*Applicable only for STE-BT interface. Currently not
+ used */
+ A_UINT32 btInquiryPageFlag; /* Not used */
+}POSTPACK WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD;
+
+/*---------------------WMI_SET_BTCOEX_SCO_CONFIG_CMDID ---------------*/
+/* Configure SCO parameters. These parameters would be used whenever firmware is indicated
+ * of (e)SCO profile on bluetooth ( via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID).
+ * Configration of BTCOEX_SCO_CONFIG data structure are common configuration and applies
+ * ps-poll mode and opt mode.
+ * Ps-poll Mode - Station is in power-save and retrieves downlink data between sco gaps.
+ * Opt Mode - station is in awake state and access point can send data to station any time.
+ * BTCOEX_PSPOLLMODE_SCO_CONFIG - Configuration applied only during ps-poll mode.
+ * BTCOEX_OPTMODE_SCO_CONFIG - Configuration applied only during opt mode.
+ */
+#define WMI_SCO_CONFIG_FLAG_ALLOW_OPTIMIZATION (1 << 0)
+#define WMI_SCO_CONFIG_FLAG_IS_EDR_CAPABLE (1 << 1)
+#define WMI_SCO_CONFIG_FLAG_IS_BT_MASTER (1 << 2)
+#define WMI_SCO_CONFIG_FLAG_FW_DETECT_OF_PER (1 << 3)
+typedef PREPACK struct {
+ A_UINT32 scoSlots; /* Number of SCO Tx/Rx slots.
+ HVx, EV3, 2EV3 = 2 */
+ A_UINT32 scoIdleSlots; /* Number of Bluetooth idle slots between
+ consecutive SCO Tx/Rx slots
+ HVx, EV3 = 4
+ 2EV3 = 10
+ */
+ A_UINT32 scoFlags; /* SCO Options Flags :
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 Is EDR capable or Not
+ 2 IS Co-located Bt role Master
+ 3 Firmware determines the periodicity of SCO.
+ */
+
+ A_UINT32 linkId; /* applicable to STE-BT - not used */
+}POSTPACK BTCOEX_SCO_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 scoCyclesForceTrigger; /* Number SCO cycles after which
+ force a pspoll. default = 10 */
+ A_UINT32 scoDataResponseTimeout; /* Timeout Waiting for Downlink pkt
+ in response for ps-poll,
+ default = 20 msecs */
+
+ A_UINT32 scoStompDutyCyleVal; /* not implemented */
+
+ A_UINT32 scoStompDutyCyleMaxVal; /*Not implemented */
+
+ A_UINT32 scoPsPollLatencyFraction; /* Fraction of idle
+ period, within which
+ additional ps-polls can be queued
+ 1 - 1/4 of idle duration
+ 2 - 1/2 of idle duration
+ 3 - 3/4 of idle duration
+ default =2 (1/2)
+ */
+}POSTPACK BTCOEX_PSPOLLMODE_SCO_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 scoStompCntIn100ms;/*max number of SCO stomp in 100ms allowed in
+ opt mode. If exceeds the configured value,
+ switch to ps-poll mode
+ default = 3 */
+
+ A_UINT32 scoContStompMax; /* max number of continous stomp allowed in opt mode.
+ if excedded switch to pspoll mode
+ default = 3 */
+
+ A_UINT32 scoMinlowRateMbps; /* Low rate threshold */
+
+ A_UINT32 scoLowRateCnt; /* number of low rate pkts (< scoMinlowRateMbps) allowed in 100 ms.
+ If exceeded switch/stay to ps-poll mode, lower stay in opt mode.
+ default = 36
+ */
+
+ A_UINT32 scoHighPktRatio; /*(Total Rx pkts in 100 ms + 1)/
+ ((Total tx pkts in 100 ms - No of high rate pkts in 100 ms) + 1) in 100 ms,
+ if exceeded switch/stay in opt mode and if lower switch/stay in pspoll mode.
+ default = 5 (80% of high rates)
+ */
+
+ A_UINT32 scoMaxAggrSize; /* Max number of Rx subframes allowed in this mode. (Firmware re-negogiates
+ max number of aggregates if it was negogiated to higher value
+ default = 1
+ Recommended value Basic rate headsets = 1, EDR (2-EV3) =4.
+ */
+}POSTPACK BTCOEX_OPTMODE_SCO_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 scanInterval;
+ A_UINT32 maxScanStompCnt;
+}POSTPACK BTCOEX_WLANSCAN_SCO_CONFIG;
+
+typedef PREPACK struct {
+ BTCOEX_SCO_CONFIG scoConfig;
+ BTCOEX_PSPOLLMODE_SCO_CONFIG scoPspollConfig;
+ BTCOEX_OPTMODE_SCO_CONFIG scoOptModeConfig;
+ BTCOEX_WLANSCAN_SCO_CONFIG scoWlanScanConfig;
+}POSTPACK WMI_SET_BTCOEX_SCO_CONFIG_CMD;
+
+/* ------------------WMI_SET_BTCOEX_A2DP_CONFIG_CMDID -------------------*/
+/* Configure A2DP profile parameters. These parameters would be used whenver firmware is indicated
+ * of A2DP profile on bluetooth ( via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID).
+ * Configuration of BTCOEX_A2DP_CONFIG data structure are common configuration and applies to
+ * ps-poll mode and opt mode.
+ * Ps-poll Mode - Station is in power-save and retrieves downlink data between a2dp data bursts.
+ * Opt Mode - station is in power save during a2dp bursts and awake in the gaps.
+ * BTCOEX_PSPOLLMODE_A2DP_CONFIG - Configuration applied only during ps-poll mode.
+ * BTCOEX_OPTMODE_A2DP_CONFIG - Configuration applied only during opt mode.
+ */
+
+#define WMI_A2DP_CONFIG_FLAG_ALLOW_OPTIMIZATION (1 << 0)
+#define WMI_A2DP_CONFIG_FLAG_IS_EDR_CAPABLE (1 << 1)
+#define WMI_A2DP_CONFIG_FLAG_IS_BT_ROLE_MASTER (1 << 2)
+#define WMI_A2DP_CONFIG_FLAG_IS_A2DP_HIGH_PRI (1 << 3)
+#define WMI_A2DP_CONFIG_FLAG_FIND_BT_ROLE (1 << 4)
+
+typedef PREPACK struct {
+ A_UINT32 a2dpFlags; /* A2DP Option flags:
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 IS EDR capable
+ 2 IS Co-located Bt role Master
+ 3 a2dp traffic is high priority
+ 4 Fw detect the role of bluetooth.
+ */
+ A_UINT32 linkId; /* Applicable only to STE-BT - not used */
+
+}POSTPACK BTCOEX_A2DP_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 a2dpWlanMaxDur; /* MAX time firmware uses the medium for
+ wlan, after it identifies the idle time
+ default (30 msecs) */
+
+ A_UINT32 a2dpMinBurstCnt; /* Minimum number of bluetooth data frames
+ to replenish Wlan Usage limit (default 3) */
+
+ A_UINT32 a2dpDataRespTimeout; /* Max duration firmware waits for downlink
+ by stomping on bluetooth
+ after ps-poll is acknowledged.
+ default = 20 ms
+ */
+}POSTPACK BTCOEX_PSPOLLMODE_A2DP_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 a2dpMinlowRateMbps; /* Low rate threshold */
+
+ A_UINT32 a2dpLowRateCnt; /* number of low rate pkts (< a2dpMinlowRateMbps) allowed in 100 ms.
+ If exceeded switch/stay to ps-poll mode, lower stay in opt mode.
+ default = 36
+ */
+
+ A_UINT32 a2dpHighPktRatio; /*(Total Rx pkts in 100 ms + 1)/
+ ((Total tx pkts in 100 ms - No of high rate pkts in 100 ms) + 1) in 100 ms,
+ if exceeded switch/stay in opt mode and if lower switch/stay in pspoll mode.
+ default = 5 (80% of high rates)
+ */
+
+ A_UINT32 a2dpMaxAggrSize; /* Max number of Rx subframes allowed in this mode. (Firmware re-negogiates
+ max number of aggregates if it was negogiated to higher value
+ default = 1
+ Recommended value Basic rate headsets = 1, EDR (2-EV3) =8.
+ */
+ A_UINT32 a2dpPktStompCnt; /*number of a2dp pkts that can be stomped per burst.
+ default = 6*/
+
+}POSTPACK BTCOEX_OPTMODE_A2DP_CONFIG;
+
+typedef PREPACK struct {
+ BTCOEX_A2DP_CONFIG a2dpConfig;
+ BTCOEX_PSPOLLMODE_A2DP_CONFIG a2dppspollConfig;
+ BTCOEX_OPTMODE_A2DP_CONFIG a2dpOptConfig;
+}POSTPACK WMI_SET_BTCOEX_A2DP_CONFIG_CMD;
+
+/*------------ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMDID---------------------*/
+/* Configure non-A2dp ACL profile parameters.The starts of ACL profile can either be
+ * indicated via WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID orenabled via firmware detection
+ * which is configured via "aclCoexFlags".
+ * Configration of BTCOEX_ACLCOEX_CONFIG data structure are common configuration and applies
+ * ps-poll mode and opt mode.
+ * Ps-poll Mode - Station is in power-save and retrieves downlink data during wlan medium.
+ * Opt Mode - station is in power save during bluetooth medium time and awake during wlan duration.
+ * (Not implemented yet)
+ *
+ * BTCOEX_PSPOLLMODE_ACLCOEX_CONFIG - Configuration applied only during ps-poll mode.
+ * BTCOEX_OPTMODE_ACLCOEX_CONFIG - Configuration applied only during opt mode.
+ */
+
+#define WMI_ACLCOEX_FLAGS_ALLOW_OPTIMIZATION (1 << 0)
+#define WMI_ACLCOEX_FLAGS_DISABLE_FW_DETECTION (1 << 1)
+
+typedef PREPACK struct {
+ A_UINT32 aclWlanMediumDur; /* Wlan usage time during Acl (non-a2dp)
+ coexistence (default 30 msecs)
+ */
+
+ A_UINT32 aclBtMediumDur; /* Bt usage time during acl coexistence
+ (default 30 msecs)
+ */
+
+ A_UINT32 aclDetectTimeout; /* BT activity observation time limit.
+ In this time duration, number of bt pkts are counted.
+ If the Cnt reaches "aclPktCntLowerLimit" value
+ for "aclIterToEnableCoex" iteration continuously,
+ firmware gets into ACL coexistence mode.
+ Similarly, if bt traffic count during ACL coexistence
+ has not reached "aclPktCntLowerLimit" continuously
+ for "aclIterToEnableCoex", then ACL coexistence is
+ disabled.
+ -default 100 msecs
+ */
+
+ A_UINT32 aclPktCntLowerLimit; /* Acl Pkt Cnt to be received in duration of
+ "aclDetectTimeout" for
+ "aclIterForEnDis" times to enabling ACL coex.
+ Similar logic is used to disable acl coexistence.
+ (If "aclPktCntLowerLimit" cnt of acl pkts
+ are not seen by the for "aclIterForEnDis"
+ then acl coexistence is disabled).
+ default = 10
+ */
+
+ A_UINT32 aclIterForEnDis; /* number of Iteration of "aclPktCntLowerLimit" for Enabling and
+ Disabling Acl Coexistence.
+ default = 3
+ */
+
+ A_UINT32 aclPktCntUpperLimit; /* This is upperBound limit, if there is more than
+ "aclPktCntUpperLimit" seen in "aclDetectTimeout",
+ ACL coexistence is enabled right away.
+ - default 15*/
+
+ A_UINT32 aclCoexFlags; /* A2DP Option flags:
+ bits: meaning:
+ 0 Allow Close Range Optimization
+ 1 disable Firmware detection
+ (Currently supported configuration is aclCoexFlags =0)
+ */
+
+ A_UINT32 linkId; /* Applicable only for STE-BT - not used */
+
+}POSTPACK BTCOEX_ACLCOEX_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 aclDataRespTimeout; /* Max duration firmware waits for downlink
+ by stomping on bluetooth
+ after ps-poll is acknowledged.
+ default = 20 ms */
+
+}POSTPACK BTCOEX_PSPOLLMODE_ACLCOEX_CONFIG;
+
+
+/* Not implemented yet*/
+typedef PREPACK struct {
+ A_UINT32 aclCoexMinlowRateMbps;
+ A_UINT32 aclCoexLowRateCnt;
+ A_UINT32 aclCoexHighPktRatio;
+ A_UINT32 aclCoexMaxAggrSize;
+ A_UINT32 aclPktStompCnt;
+}POSTPACK BTCOEX_OPTMODE_ACLCOEX_CONFIG;
+
+typedef PREPACK struct {
+ BTCOEX_ACLCOEX_CONFIG aclCoexConfig;
+ BTCOEX_PSPOLLMODE_ACLCOEX_CONFIG aclCoexPspollConfig;
+ BTCOEX_OPTMODE_ACLCOEX_CONFIG aclCoexOptConfig;
+}POSTPACK WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD;
+
+/* -----------WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID ------------------*/
+typedef enum {
+ WMI_BTCOEX_BT_PROFILE_SCO =1,
+ WMI_BTCOEX_BT_PROFILE_A2DP,
+ WMI_BTCOEX_BT_PROFILE_INQUIRY_PAGE,
+ WMI_BTCOEX_BT_PROFILE_ACLCOEX,
+}WMI_BTCOEX_BT_PROFILE;
+
+typedef PREPACK struct {
+ A_UINT32 btProfileType;
+ A_UINT32 btOperatingStatus;
+ A_UINT32 btLinkId;
+}WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD;
+
+/*--------------------- WMI_SET_BTCOEX_DEBUG_CMDID ---------------------*/
+/* Used for firmware development and debugging */
+typedef PREPACK struct {
+ A_UINT32 btcoexDbgParam1;
+ A_UINT32 btcoexDbgParam2;
+ A_UINT32 btcoexDbgParam3;
+ A_UINT32 btcoexDbgParam4;
+ A_UINT32 btcoexDbgParam5;
+}WMI_SET_BTCOEX_DEBUG_CMD;
+
+/*---------------------WMI_GET_BTCOEX_CONFIG_CMDID --------------------- */
+/* Command to firmware to get configuration parameters of the bt profile
+ * reported via WMI_BTCOEX_CONFIG_EVENTID */
+typedef PREPACK struct {
+ A_UINT32 btProfileType; /* 1 - SCO
+ 2 - A2DP
+ 3 - INQUIRY_PAGE
+ 4 - ACLCOEX
+ */
+ A_UINT32 linkId; /* not used */
+}WMI_GET_BTCOEX_CONFIG_CMD;
+
+/*------------------WMI_REPORT_BTCOEX_CONFIG_EVENTID------------------- */
+/* Event from firmware to host, sent in response to WMI_GET_BTCOEX_CONFIG_CMDID
+ * */
+typedef PREPACK struct {
+ A_UINT32 btProfileType;
+ A_UINT32 linkId; /* not used */
+ PREPACK union {
+ WMI_SET_BTCOEX_SCO_CONFIG_CMD scoConfigCmd;
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMD a2dpConfigCmd;
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD aclcoexConfig;
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD btinquiryPageConfigCmd;
+ } POSTPACK info;
+} POSTPACK WMI_BTCOEX_CONFIG_EVENT;
+
+/*------------- WMI_REPORT_BTCOEX_BTCOEX_STATS_EVENTID--------------------*/
+/* Used for firmware development and debugging*/
+typedef PREPACK struct {
+ A_UINT32 highRatePktCnt;
+ A_UINT32 firstBmissCnt;
+ A_UINT32 psPollFailureCnt;
+ A_UINT32 nullFrameFailureCnt;
+ A_UINT32 optModeTransitionCnt;
+}BTCOEX_GENERAL_STATS;
+
+typedef PREPACK struct {
+ A_UINT32 scoStompCntAvg;
+ A_UINT32 scoStompIn100ms;
+ A_UINT32 scoMaxContStomp;
+ A_UINT32 scoAvgNoRetries;
+ A_UINT32 scoMaxNoRetriesIn100ms;
+}BTCOEX_SCO_STATS;
+
+typedef PREPACK struct {
+ A_UINT32 a2dpBurstCnt;
+ A_UINT32 a2dpMaxBurstCnt;
+ A_UINT32 a2dpAvgIdletimeIn100ms;
+ A_UINT32 a2dpAvgStompCnt;
+}BTCOEX_A2DP_STATS;
+
+typedef PREPACK struct {
+ A_UINT32 aclPktCntInBtTime;
+ A_UINT32 aclStompCntInWlanTime;
+ A_UINT32 aclPktCntIn100ms;
+}BTCOEX_ACLCOEX_STATS;
+
+typedef PREPACK struct {
+ BTCOEX_GENERAL_STATS coexStats;
+ BTCOEX_SCO_STATS scoStats;
+ BTCOEX_A2DP_STATS a2dpStats;
+ BTCOEX_ACLCOEX_STATS aclCoexStats;
+}WMI_BTCOEX_STATS_EVENT;
+
+
+/*--------------------------END OF BTCOEX -------------------------------------*/
+
+/* WAC commands
+ */
+
+
+typedef PREPACK struct {
+ A_UINT32 period;
+ A_UINT32 threshold;
+ A_INT32 rssi;
+ A_BOOL enable;
+ A_CHAR wps_pin[8];
+}WMI_WAC_ENABLE_CMD;
+
+typedef enum {
+ WAC_MORE_SCAN = -1,
+ WAC_SEND_PROBE_IDX = 0,
+}WAC_SUBCMD;
+
+typedef PREPACK struct {
+ WAC_SUBCMD cmdid;
+}WMI_WAC_SCAN_REPLY_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 req;
+ A_UINT8 cmd;
+ A_UINT8 frame;
+ A_UINT8 ie[17];
+ A_INT32 status;
+}WMI_WAC_CTRL_REQ_CMD;
+
+/* END OF WAC */
+
+typedef PREPACK struct {
+ A_UINT32 sleepState;
+}WMI_REPORT_SLEEP_STATE_EVENT;
+
+typedef enum {
+ WMI_REPORT_SLEEP_STATUS_IS_DEEP_SLEEP =0,
+ WMI_REPORT_SLEEP_STATUS_IS_AWAKE
+} WMI_REPORT_SLEEP_STATUS;
+typedef enum {
+ DISCONN_EVT_IN_RECONN = 0, /* default */
+ NO_DISCONN_EVT_IN_RECONN
+} TARGET_EVENT_REPORT_CONFIG;
+
+typedef PREPACK struct {
+ A_UINT32 evtConfig;
+} POSTPACK WMI_SET_TARGET_EVENT_REPORT_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT16 cmd_buf_sz; /* HCI cmd buffer size */
+ A_UINT8 buf[1]; /* Absolute HCI cmd */
+} POSTPACK WMI_HCI_CMD;
+
+/*
+ * Command Replies
+ */
+
+/*
+ * WMI_GET_CHANNEL_LIST_CMDID reply
+ */
+typedef PREPACK struct {
+ A_UINT8 reserved1;
+ A_UINT8 numChannels; /* number of channels in reply */
+ A_UINT16 channelList[1]; /* channel in Mhz */
+} POSTPACK WMI_CHANNEL_LIST_REPLY;
+
+typedef enum {
+ A_SUCCEEDED = A_OK,
+ A_FAILED_DELETE_STREAM_DOESNOT_EXIST=250,
+ A_SUCCEEDED_MODIFY_STREAM=251,
+ A_FAILED_INVALID_STREAM = 252,
+ A_FAILED_MAX_THINSTREAMS = 253,
+ A_FAILED_CREATE_REMOVE_PSTREAM_FIRST = 254,
+} PSTREAM_REPLY_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 status; /* PSTREAM_REPLY_STATUS */
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficClass;
+ A_UINT8 trafficDirection; /* DIR_TYPE */
+} POSTPACK WMI_CRE_PRIORITY_STREAM_REPLY;
+
+typedef PREPACK struct {
+ A_UINT8 status; /* PSTREAM_REPLY_STATUS */
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficDirection; /* DIR_TYPE */
+ A_UINT8 trafficClass;
+} POSTPACK WMI_DEL_PRIORITY_STREAM_REPLY;
+
+/*
+ * List of Events (target to host)
+ */
+typedef enum {
+ WMI_READY_EVENTID = 0x1001,
+ WMI_CONNECT_EVENTID,
+ WMI_DISCONNECT_EVENTID,
+ WMI_BSSINFO_EVENTID,
+ WMI_CMDERROR_EVENTID,
+ WMI_REGDOMAIN_EVENTID,
+ WMI_PSTREAM_TIMEOUT_EVENTID,
+ WMI_NEIGHBOR_REPORT_EVENTID,
+ WMI_TKIP_MICERR_EVENTID,
+ WMI_SCAN_COMPLETE_EVENTID, /* 0x100a */
+ WMI_REPORT_STATISTICS_EVENTID,
+ WMI_RSSI_THRESHOLD_EVENTID,
+ WMI_ERROR_REPORT_EVENTID,
+ WMI_OPT_RX_FRAME_EVENTID,
+ WMI_REPORT_ROAM_TBL_EVENTID,
+ WMI_EXTENSION_EVENTID,
+ WMI_CAC_EVENTID,
+ WMI_SNR_THRESHOLD_EVENTID,
+ WMI_LQ_THRESHOLD_EVENTID,
+ WMI_TX_RETRY_ERR_EVENTID, /* 0x1014 */
+ WMI_REPORT_ROAM_DATA_EVENTID,
+ WMI_TEST_EVENTID,
+ WMI_APLIST_EVENTID,
+ WMI_GET_WOW_LIST_EVENTID,
+ WMI_GET_PMKID_LIST_EVENTID,
+ WMI_CHANNEL_CHANGE_EVENTID,
+ WMI_PEER_NODE_EVENTID,
+ WMI_PSPOLL_EVENTID,
+ WMI_DTIMEXPIRY_EVENTID,
+ WMI_WLAN_VERSION_EVENTID,
+ WMI_SET_PARAMS_REPLY_EVENTID,
+ WMI_ADDBA_REQ_EVENTID, /*0x1020 */
+ WMI_ADDBA_RESP_EVENTID,
+ WMI_DELBA_REQ_EVENTID,
+ WMI_TX_COMPLETE_EVENTID,
+ WMI_HCI_EVENT_EVENTID,
+ WMI_ACL_DATA_EVENTID,
+ WMI_REPORT_SLEEP_STATE_EVENTID,
+
+ WMI_WAPI_REKEY_EVENTID,
+
+ WMI_REPORT_BTCOEX_STATS_EVENTID,
+ WMI_REPORT_BTCOEX_CONFIG_EVENTID,
+ WMI_GET_PMK_EVENTID,
+
+ /* DFS Events */
+ WMI_DFS_HOST_ATTACH_EVENTID,
+ WMI_DFS_HOST_INIT_EVENTID,
+ WMI_DFS_RESET_DELAYLINES_EVENTID,
+ WMI_DFS_RESET_RADARQ_EVENTID,
+ WMI_DFS_RESET_AR_EVENTID,
+ WMI_DFS_RESET_ARQ_EVENTID, /*0x1030*/
+ WMI_DFS_SET_DUR_MULTIPLIER_EVENTID,
+ WMI_DFS_SET_BANGRADAR_EVENTID,
+ WMI_DFS_SET_DEBUGLEVEL_EVENTID,
+ WMI_DFS_PHYERR_EVENTID,
+ /* CCX Evants */
+ WMI_CCX_RM_STATUS_EVENTID,
+
+ /* P2P Events */
+ WMI_P2P_GO_NEG_RESULT_EVENTID,
+
+ WMI_WAC_SCAN_DONE_EVENTID,
+ WMI_WAC_REPORT_BSS_EVENTID,
+ WMI_WAC_START_WPS_EVENTID,
+ WMI_WAC_CTRL_REQ_REPLY_EVENTID,
+
+ /*RFKILL Events*/
+ WMI_RFKILL_STATE_CHANGE_EVENTID,
+ WMI_RFKILL_GET_MODE_CMD_EVENTID,
+
+ /* More P2P Events */
+ WMI_P2P_GO_NEG_REQ_EVENTID,
+ WMI_P2P_INVITE_REQ_EVENTID,
+ WMI_P2P_INVITE_RCVD_RESULT_EVENTID,
+ WMI_P2P_INVITE_SENT_RESULT_EVENTID, /*1040*/
+ WMI_P2P_PROV_DISC_RESP_EVENTID,
+ WMI_P2P_PROV_DISC_REQ_EVENTID,
+ WMI_P2P_START_SDPD_EVENTID,
+ WMI_P2P_SDPD_RX_EVENTID,
+
+ /* Special event used to notify host that AR6003
+ * has processed sleep command (needed to prevent
+ * a late incoming credit report from crashing
+ * the system)
+ */
+ WMI_SET_HOST_SLEEP_MODE_CMD_PROCESSED_EVENTID,
+
+ WMI_THIN_RESERVED_START_EVENTID = 0x8000,
+ /* Events in this range are reserved for thinmode
+ * See wmi_thin.h for actual definitions */
+ WMI_THIN_RESERVED_END_EVENTID = 0x8fff,
+
+ WMI_SET_CHANNEL_EVENTID,
+ WMI_ASSOC_REQ_EVENTID,
+
+
+ /* generic ACS event */
+ WMI_ACS_EVENTID,
+ WMI_REPORT_WMM_PARAMS_EVENTID,
+ WMI_STORERECALL_STORE_EVENTID,
+
+ /* AP idle close time event */
+ WMI_AP_IDLE_CLOSE_TIMEOUT_EVENTID,
+ WMI_HS20_RX_EVENTID,
+} WMI_EVENT_ID;
+
+typedef enum {
+ WMI_11A_CAPABILITY = 1,
+ WMI_11G_CAPABILITY = 2,
+ WMI_11AG_CAPABILITY = 3,
+ WMI_11NA_CAPABILITY = 4,
+ WMI_11NG_CAPABILITY = 5,
+ WMI_11NAG_CAPABILITY = 6,
+ // END CAPABILITY
+ WMI_11N_CAPABILITY_OFFSET = (WMI_11NA_CAPABILITY - WMI_11A_CAPABILITY),
+} WMI_PHY_CAPABILITY;
+
+typedef PREPACK struct {
+ A_UINT8 macaddr[ATH_MAC_LEN];
+ A_UINT8 phyCapability; /* WMI_PHY_CAPABILITY */
+} POSTPACK WMI_READY_EVENT_1;
+
+typedef PREPACK struct {
+ A_UINT32 sw_version;
+ A_UINT32 abi_version;
+ A_UINT8 macaddr[ATH_MAC_LEN];
+ A_UINT8 phyCapability; /* WMI_PHY_CAPABILITY */
+} POSTPACK WMI_READY_EVENT_2;
+
+#if defined(ATH_TARGET)
+#ifdef AR6002_REV2
+#define WMI_READY_EVENT WMI_READY_EVENT_1 /* AR6002_REV2 target code */
+#else
+#define WMI_READY_EVENT WMI_READY_EVENT_2 /* AR6001, AR6002_REV4, AR6002_REV6 */
+#endif
+#else
+#define WMI_READY_EVENT WMI_READY_EVENT_2 /* host code */
+#endif
+
+
+/*
+ * Connect Event
+ *
+ * In STA mode networkType comes along with connected phy mode
+ * To get networkType, WMI_NETWORK_TYPE (networkType)
+ * To get connected phymode, WMI_CONNECTED_PHYMODE(networkType)
+ * will give the phymode value.
+ */
+typedef PREPACK struct {
+ PREPACK union {
+ struct {
+ A_UINT16 channel;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT16 listenInterval;
+ A_UINT16 beaconInterval;
+ A_UINT32 networkType;
+ } infra_ibss_bss;
+ struct {
+ A_UINT8 phymode;
+ A_UINT8 aid;
+ A_UINT8 mac_addr[ATH_MAC_LEN];
+ A_UINT8 auth;
+ A_UINT8 keymgmt;
+ A_UINT16 cipher;
+ A_UINT8 apsd_info;
+ A_UINT8 unused[3];
+ } ap_sta;
+ struct {
+ A_UINT16 channel;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 unused[8];
+ } ap_bss;
+ } POSTPACK u;
+ A_UINT8 beaconIeLen;
+ A_UINT8 assocReqLen;
+ A_UINT8 assocRespLen;
+ A_UINT8 assocInfo[1];
+} POSTPACK WMI_CONNECT_EVENT;
+
+
+typedef struct {
+ A_UINT8 status;
+ A_UINT8 rspType;
+} WMI_ASSOCREQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 host_accept;
+ A_UINT8 host_reasonCode;
+ A_UINT8 target_status;
+ A_UINT8 sta_mac_addr[ATH_MAC_LEN];
+ A_UINT8 rspType;
+} POSTPACK WMI_SEND_ASSOCRES_CMD;
+
+typedef struct {
+ A_UINT8 enable;
+} WMI_SET_ASSOCREQ_RELAY;
+
+/*
+ * Disconnect Event
+ */
+typedef enum {
+ NO_NETWORK_AVAIL = 0x01,
+ LOST_LINK = 0x02, /* bmiss */
+ DISCONNECT_CMD = 0x03,
+ BSS_DISCONNECTED = 0x04,
+ AUTH_FAILED = 0x05,
+ ASSOC_FAILED = 0x06,
+ NO_RESOURCES_AVAIL = 0x07,
+ CSERV_DISCONNECT = 0x08,
+ INVALID_PROFILE = 0x0a,
+ DOT11H_CHANNEL_SWITCH = 0x0b,
+ PROFILE_MISMATCH = 0x0c,
+ CONNECTION_EVICTED = 0x0d,
+ IBSS_MERGE = 0x0e,
+ EXCESS_TX_RETRY = 0x0f, /* TX frames failed after excessive retries */
+} WMI_DISCONNECT_REASON;
+
+typedef PREPACK struct {
+ A_UINT16 protocolReasonStatus; /* reason code, see 802.11 spec. */
+ A_UINT8 bssid[ATH_MAC_LEN]; /* set if known */
+ A_UINT8 disconnectReason ; /* see WMI_DISCONNECT_REASON */
+ A_UINT8 assocRespLen;
+ A_UINT8 assocInfo[1];
+} POSTPACK WMI_DISCONNECT_EVENT;
+
+/*
+ * BSS Info Event.
+ * Mechanism used to inform host of the presence and characteristic of
+ * wireless networks present. Consists of bss info header followed by
+ * the beacon or probe-response frame body. The 802.11 header is not included.
+ */
+typedef enum {
+ BEACON_FTYPE = 0x1,
+ PROBERESP_FTYPE,
+ ACTION_MGMT_FTYPE,
+ PROBEREQ_FTYPE,
+} WMI_BI_FTYPE;
+
+enum {
+ BSS_ELEMID_CHANSWITCH = 0x01,
+ BSS_ELEMID_ATHEROS = 0x02,
+};
+
+typedef PREPACK struct {
+ A_UINT16 channel;
+ A_UINT8 frameType; /* see WMI_BI_FTYPE */
+ A_UINT8 snr;
+ A_INT16 rssi;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT32 ieMask;
+} POSTPACK WMI_BSS_INFO_HDR;
+
+/*
+ * BSS INFO HDR version 2.0
+ * With 6 bytes HTC header and 6 bytes of WMI header
+ * WMI_BSS_INFO_HDR cannot be accomodated in the removed 802.11 management
+ * header space.
+ * - Reduce the ieMask to 2 bytes as only two bit flags are used
+ * - Remove rssi and compute it on the host. rssi = snr - 95
+ */
+typedef PREPACK struct {
+ A_UINT16 channel;
+ A_UINT8 frameType; /* see WMI_BI_FTYPE */
+ A_UINT8 snr;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT16 ieMask;
+} POSTPACK WMI_BSS_INFO_HDR2;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 pin[8];
+} POSTPACK WMI_WPS_PIN_INFO;
+
+typedef PREPACK struct {
+ PREPACK union {
+ A_UINT8 ie[17];
+ A_INT32 wac_status;
+ } POSTPACK info;
+} POSTPACK WMI_GET_WAC_INFO;
+
+/*
+ * Command Error Event
+ */
+typedef enum {
+ INVALID_PARAM = 0x01,
+ ILLEGAL_STATE = 0x02,
+ INTERNAL_ERROR = 0x03,
+ DFS_CHANNEL = 0x04,
+} WMI_ERROR_CODE;
+
+typedef PREPACK struct {
+ A_UINT16 commandId;
+ A_UINT8 errorCode;
+} POSTPACK WMI_CMD_ERROR_EVENT;
+
+/*
+ * New Regulatory Domain Event
+ */
+typedef PREPACK struct {
+ A_UINT32 regDomain;
+} POSTPACK WMI_REG_DOMAIN_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 txQueueNumber;
+ A_UINT8 rxQueueNumber;
+ A_UINT8 trafficDirection;
+ A_UINT8 trafficClass;
+} POSTPACK WMI_PSTREAM_TIMEOUT_EVENT;
+
+/*
+ * The WMI_NEIGHBOR_REPORT Event is generated by the target to inform
+ * the host of BSS's it has found that matches the current profile.
+ * It can be used by the host to cache PMKs and/to initiate pre-authentication
+ * if the BSS supports it. The first bssid is always the current associated
+ * BSS.
+ * The bssid and bssFlags information repeats according to the number
+ * or APs reported.
+ */
+typedef enum {
+ WMI_DEFAULT_BSS_FLAGS = 0x00,
+ WMI_PREAUTH_CAPABLE_BSS = 0x01,
+ WMI_PMKID_VALID_BSS = 0x02,
+} WMI_BSS_FLAGS;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 bssFlags; /* see WMI_BSS_FLAGS */
+} POSTPACK WMI_NEIGHBOR_INFO;
+
+typedef PREPACK struct {
+ A_INT8 numberOfAps;
+ WMI_NEIGHBOR_INFO neighbor[1];
+} POSTPACK WMI_NEIGHBOR_REPORT_EVENT;
+
+/*
+ * TKIP MIC Error Event
+ */
+typedef PREPACK struct {
+ A_UINT8 keyid;
+ A_UINT8 ismcast;
+} POSTPACK WMI_TKIP_MICERR_EVENT;
+
+/*
+ * WMI_SCAN_COMPLETE_EVENTID - no parameters (old), staus parameter (new)
+ */
+typedef PREPACK struct {
+ A_INT32 status;
+} POSTPACK WMI_SCAN_COMPLETE_EVENT;
+
+typedef PREPACK struct {
+ A_INT32 rm_type;
+ A_INT32 status;
+} POSTPACK WMI_CCX_RM_STATUS_EVENT;
+
+#define MAX_OPT_DATA_LEN 1400
+
+/*
+ * WMI_SET_ADHOC_BSSID_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+} POSTPACK WMI_SET_ADHOC_BSSID_CMD;
+
+/*
+ * Special frame receive Event.
+ * Mechanism used to inform host of the receiption of the special frames.
+ * Consists of special frame info header followed by special frame body.
+ * The 802.11 header is not included.
+ */
+typedef PREPACK struct {
+ A_UINT16 channel;
+ A_UINT8 frameType; /* see WMI_OPT_FTYPE */
+ A_INT8 snr;
+ A_UINT8 srcAddr[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+} POSTPACK WMI_OPT_RX_INFO_HDR;
+
+/*
+ * Reporting statistics.
+ */
+typedef PREPACK struct {
+ A_UINT32 tx_packets;
+ A_UINT32 tx_bytes;
+ A_UINT32 tx_unicast_pkts;
+ A_UINT32 tx_unicast_bytes;
+ A_UINT32 tx_multicast_pkts;
+ A_UINT32 tx_multicast_bytes;
+ A_UINT32 tx_broadcast_pkts;
+ A_UINT32 tx_broadcast_bytes;
+ A_UINT32 tx_rts_success_cnt;
+ A_UINT32 tx_packet_per_ac[4];
+ A_UINT32 tx_errors_per_ac[4];
+
+ A_UINT32 tx_errors;
+ A_UINT32 tx_failed_cnt;
+ A_UINT32 tx_retry_cnt;
+ A_UINT32 tx_mult_retry_cnt;
+ A_UINT32 tx_rts_fail_cnt;
+ A_INT32 tx_unicast_rate;
+}POSTPACK tx_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 rx_packets;
+ A_UINT32 rx_bytes;
+ A_UINT32 rx_unicast_pkts;
+ A_UINT32 rx_unicast_bytes;
+ A_UINT32 rx_multicast_pkts;
+ A_UINT32 rx_multicast_bytes;
+ A_UINT32 rx_broadcast_pkts;
+ A_UINT32 rx_broadcast_bytes;
+ A_UINT32 rx_fragment_pkt;
+
+ A_UINT32 rx_errors;
+ A_UINT32 rx_crcerr;
+ A_UINT32 rx_key_cache_miss;
+ A_UINT32 rx_decrypt_err;
+ A_UINT32 rx_duplicate_frames;
+ A_INT32 rx_unicast_rate;
+}POSTPACK rx_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 tkip_local_mic_failure;
+ A_UINT32 tkip_counter_measures_invoked;
+ A_UINT32 tkip_replays;
+ A_UINT32 tkip_format_errors;
+ A_UINT32 ccmp_format_errors;
+ A_UINT32 ccmp_replays;
+}POSTPACK tkip_ccmp_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 power_save_failure_cnt;
+ A_UINT16 stop_tx_failure_cnt;
+ A_UINT16 atim_tx_failure_cnt;
+ A_UINT16 atim_rx_failure_cnt;
+ A_UINT16 bcn_rx_failure_cnt;
+}POSTPACK pm_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 cs_bmiss_cnt;
+ A_UINT32 cs_lowRssi_cnt;
+ A_UINT16 cs_connect_cnt;
+ A_UINT16 cs_disconnect_cnt;
+ A_INT16 cs_aveBeacon_rssi;
+ A_UINT16 cs_roam_count;
+ A_INT16 cs_rssi;
+ A_UINT8 cs_snr;
+ A_UINT8 cs_aveBeacon_snr;
+ A_UINT8 cs_lastRoam_msec;
+} POSTPACK cserv_stats_t;
+
+typedef PREPACK struct {
+ tx_stats_t tx_stats;
+ rx_stats_t rx_stats;
+ tkip_ccmp_stats_t tkipCcmpStats;
+}POSTPACK wlan_net_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 arp_received;
+ A_UINT32 arp_matched;
+ A_UINT32 arp_replied;
+} POSTPACK arp_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 wow_num_pkts_dropped;
+ A_UINT16 wow_num_events_discarded;
+ A_UINT8 wow_num_host_pkt_wakeups;
+ A_UINT8 wow_num_host_event_wakeups;
+} POSTPACK wlan_wow_stats_t;
+
+typedef PREPACK struct {
+ A_UINT32 lqVal;
+ A_INT32 noise_floor_calibation;
+ pm_stats_t pmStats;
+ wlan_net_stats_t txrxStats;
+ wlan_wow_stats_t wowStats;
+ arp_stats_t arpStats;
+ cserv_stats_t cservStats;
+} POSTPACK WMI_TARGET_STATS;
+
+/*
+ * WMI_RSSI_THRESHOLD_EVENTID.
+ * Indicate the RSSI events to host. Events are indicated when we breach a
+ * thresold value.
+ */
+typedef enum{
+ WMI_RSSI_THRESHOLD1_ABOVE = 0,
+ WMI_RSSI_THRESHOLD2_ABOVE,
+ WMI_RSSI_THRESHOLD3_ABOVE,
+ WMI_RSSI_THRESHOLD4_ABOVE,
+ WMI_RSSI_THRESHOLD5_ABOVE,
+ WMI_RSSI_THRESHOLD6_ABOVE,
+ WMI_RSSI_THRESHOLD1_BELOW,
+ WMI_RSSI_THRESHOLD2_BELOW,
+ WMI_RSSI_THRESHOLD3_BELOW,
+ WMI_RSSI_THRESHOLD4_BELOW,
+ WMI_RSSI_THRESHOLD5_BELOW,
+ WMI_RSSI_THRESHOLD6_BELOW
+}WMI_RSSI_THRESHOLD_VAL;
+
+typedef PREPACK struct {
+ A_INT16 rssi;
+ A_UINT8 range;
+}POSTPACK WMI_RSSI_THRESHOLD_EVENT;
+
+/*
+ * WMI_ERROR_REPORT_EVENTID
+ */
+typedef enum{
+ WMI_TARGET_PM_ERR_FAIL = 0x00000001,
+ WMI_TARGET_KEY_NOT_FOUND = 0x00000002,
+ WMI_TARGET_DECRYPTION_ERR = 0x00000004,
+ WMI_TARGET_BMISS = 0x00000008,
+ WMI_PSDISABLE_NODE_JOIN = 0x00000010,
+ WMI_TARGET_COM_ERR = 0x00000020,
+ WMI_TARGET_FATAL_ERR = 0x00000040,
+ WMI_TARGET_BCN_FOUND = 0x00000080
+} WMI_TARGET_ERROR_VAL;
+
+typedef PREPACK struct {
+ A_UINT32 errorVal;
+}POSTPACK WMI_TARGET_ERROR_REPORT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 retrys;
+}POSTPACK WMI_TX_RETRY_ERR_EVENT;
+
+typedef enum{
+ WMI_SNR_THRESHOLD1_ABOVE = 1,
+ WMI_SNR_THRESHOLD1_BELOW,
+ WMI_SNR_THRESHOLD2_ABOVE,
+ WMI_SNR_THRESHOLD2_BELOW,
+ WMI_SNR_THRESHOLD3_ABOVE,
+ WMI_SNR_THRESHOLD3_BELOW,
+ WMI_SNR_THRESHOLD4_ABOVE,
+ WMI_SNR_THRESHOLD4_BELOW
+} WMI_SNR_THRESHOLD_VAL;
+
+typedef PREPACK struct {
+ A_UINT8 range; /* WMI_SNR_THRESHOLD_VAL */
+ A_UINT8 snr;
+}POSTPACK WMI_SNR_THRESHOLD_EVENT;
+
+typedef enum{
+ WMI_LQ_THRESHOLD1_ABOVE = 1,
+ WMI_LQ_THRESHOLD1_BELOW,
+ WMI_LQ_THRESHOLD2_ABOVE,
+ WMI_LQ_THRESHOLD2_BELOW,
+ WMI_LQ_THRESHOLD3_ABOVE,
+ WMI_LQ_THRESHOLD3_BELOW,
+ WMI_LQ_THRESHOLD4_ABOVE,
+ WMI_LQ_THRESHOLD4_BELOW
+} WMI_LQ_THRESHOLD_VAL;
+
+typedef PREPACK struct {
+ A_INT32 lq;
+ A_UINT8 range; /* WMI_LQ_THRESHOLD_VAL */
+}POSTPACK WMI_LQ_THRESHOLD_EVENT;
+/*
+ * WMI_REPORT_ROAM_TBL_EVENTID
+ */
+#define MAX_ROAM_TBL_CAND 5
+
+typedef PREPACK struct {
+ A_INT32 roam_util;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_INT8 rssi;
+ A_INT8 rssidt;
+ A_INT8 last_rssi;
+ A_INT8 util;
+ A_INT8 bias;
+ A_UINT8 reserved; /* For alignment */
+} POSTPACK WMI_BSS_ROAM_INFO;
+
+
+typedef PREPACK struct {
+ A_UINT16 roamMode;
+ A_UINT16 numEntries;
+ WMI_BSS_ROAM_INFO bssRoamInfo[1];
+} POSTPACK WMI_TARGET_ROAM_TBL;
+
+/*
+ * WMI_HCI_EVENT_EVENTID
+ */
+typedef PREPACK struct {
+ A_UINT16 evt_buf_sz; /* HCI event buffer size */
+ A_UINT8 buf[1]; /* HCI event */
+} POSTPACK WMI_HCI_EVENT;
+
+/*
+ * WMI_CAC_EVENTID
+ */
+typedef enum {
+ CAC_INDICATION_ADMISSION = 0x00,
+ CAC_INDICATION_ADMISSION_RESP = 0x01,
+ CAC_INDICATION_DELETE = 0x02,
+ CAC_INDICATION_NO_RESP = 0x03,
+}CAC_INDICATION;
+
+#define WMM_TSPEC_IE_LEN 63
+
+typedef PREPACK struct {
+ A_UINT8 ac;
+ A_UINT8 cac_indication;
+ A_UINT8 statusCode;
+ A_UINT8 tspecSuggestion[WMM_TSPEC_IE_LEN];
+}POSTPACK WMI_CAC_EVENT;
+
+/*
+ * WMI_APLIST_EVENTID
+ */
+
+typedef enum {
+ APLIST_VER1 = 1,
+} APLIST_VER;
+
+typedef PREPACK struct {
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT16 channel;
+} POSTPACK WMI_AP_INFO_V1;
+
+typedef PREPACK union {
+ WMI_AP_INFO_V1 apInfoV1;
+} POSTPACK WMI_AP_INFO;
+
+typedef PREPACK struct {
+ A_UINT8 apListVer;
+ A_UINT8 numAP;
+ WMI_AP_INFO apList[1];
+} POSTPACK WMI_APLIST_EVENT;
+
+/*
+ * developer commands
+ */
+
+/*
+ * WMI_SET_BITRATE_CMDID
+ *
+ * Get bit rate cmd uses same definition as set bit rate cmd
+ */
+typedef enum {
+ RATE_AUTO = -1,
+ RATE_1Mb = 0,
+ RATE_2Mb = 1,
+ RATE_5_5Mb = 2,
+ RATE_11Mb = 3,
+ RATE_6Mb = 4,
+ RATE_9Mb = 5,
+ RATE_12Mb = 6,
+ RATE_18Mb = 7,
+ RATE_24Mb = 8,
+ RATE_36Mb = 9,
+ RATE_48Mb = 10,
+ RATE_54Mb = 11,
+ RATE_MCS_0_20 = 12,
+ RATE_MCS_1_20 = 13,
+ RATE_MCS_2_20 = 14,
+ RATE_MCS_3_20 = 15,
+ RATE_MCS_4_20 = 16,
+ RATE_MCS_5_20 = 17,
+ RATE_MCS_6_20 = 18,
+ RATE_MCS_7_20 = 19,
+ RATE_MCS_0_40 = 20,
+ RATE_MCS_1_40 = 21,
+ RATE_MCS_2_40 = 22,
+ RATE_MCS_3_40 = 23,
+ RATE_MCS_4_40 = 24,
+ RATE_MCS_5_40 = 25,
+ RATE_MCS_6_40 = 26,
+ RATE_MCS_7_40 = 27,
+} WMI_BIT_RATE;
+
+typedef PREPACK struct {
+ A_INT8 rateIndex; /* see WMI_BIT_RATE */
+ A_INT8 mgmtRateIndex;
+ A_INT8 ctlRateIndex;
+} POSTPACK WMI_BIT_RATE_CMD;
+
+
+typedef PREPACK struct {
+ A_INT8 rateIndex; /* see WMI_BIT_RATE */
+} POSTPACK WMI_BIT_RATE_REPLY;
+
+
+/*
+ * WMI_SET_FIXRATES_CMDID
+ *
+ * Get fix rates cmd uses same definition as set fix rates cmd
+ */
+#define FIX_RATE_1Mb ((A_UINT32)0x1)
+#define FIX_RATE_2Mb ((A_UINT32)0x2)
+#define FIX_RATE_5_5Mb ((A_UINT32)0x4)
+#define FIX_RATE_11Mb ((A_UINT32)0x8)
+#define FIX_RATE_6Mb ((A_UINT32)0x10)
+#define FIX_RATE_9Mb ((A_UINT32)0x20)
+#define FIX_RATE_12Mb ((A_UINT32)0x40)
+#define FIX_RATE_18Mb ((A_UINT32)0x80)
+#define FIX_RATE_24Mb ((A_UINT32)0x100)
+#define FIX_RATE_36Mb ((A_UINT32)0x200)
+#define FIX_RATE_48Mb ((A_UINT32)0x400)
+#define FIX_RATE_54Mb ((A_UINT32)0x800)
+#define FIX_RATE_MCS_0_20 ((A_UINT32)0x1000)
+#define FIX_RATE_MCS_1_20 ((A_UINT32)0x2000)
+#define FIX_RATE_MCS_2_20 ((A_UINT32)0x4000)
+#define FIX_RATE_MCS_3_20 ((A_UINT32)0x8000)
+#define FIX_RATE_MCS_4_20 ((A_UINT32)0x10000)
+#define FIX_RATE_MCS_5_20 ((A_UINT32)0x20000)
+#define FIX_RATE_MCS_6_20 ((A_UINT32)0x40000)
+#define FIX_RATE_MCS_7_20 ((A_UINT32)0x80000)
+#define FIX_RATE_MCS_0_40 ((A_UINT32)0x100000)
+#define FIX_RATE_MCS_1_40 ((A_UINT32)0x200000)
+#define FIX_RATE_MCS_2_40 ((A_UINT32)0x400000)
+#define FIX_RATE_MCS_3_40 ((A_UINT32)0x800000)
+#define FIX_RATE_MCS_4_40 ((A_UINT32)0x1000000)
+#define FIX_RATE_MCS_5_40 ((A_UINT32)0x2000000)
+#define FIX_RATE_MCS_6_40 ((A_UINT32)0x4000000)
+#define FIX_RATE_MCS_7_40 ((A_UINT32)0x8000000)
+
+typedef PREPACK struct {
+ A_UINT32 fixRateMask[WMI_MAX_RATE_MASK]; /* see WMI_BIT_RATE */
+} POSTPACK WMI_FIX_RATES_CMD, WMI_FIX_RATES_REPLY;
+
+typedef PREPACK struct {
+ A_UINT8 bEnableMask;
+ A_UINT8 frameType; /* type and subtype */
+ A_UINT8 reserved[2]; /* for alignment */
+ A_UINT32 frameRateMask[WMI_MAX_RATE_MASK]; /* see WMI_BIT_RATE */
+} POSTPACK WMI_FRAME_RATES_CMD, WMI_FRAME_RATES_REPLY;
+
+/*
+ * WMI_SET_RECONNECT_AUTH_MODE_CMDID
+ *
+ * Set authentication mode
+ */
+typedef enum {
+ RECONN_DO_AUTH = 0x00,
+ RECONN_NOT_AUTH = 0x01
+} WMI_AUTH_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 mode;
+} POSTPACK WMI_SET_AUTH_MODE_CMD;
+
+/*
+ * WMI_SET_REASSOC_MODE_CMDID
+ *
+ * Set authentication mode
+ */
+typedef enum {
+ REASSOC_DO_DISASSOC = 0x00,
+ REASSOC_DONOT_DISASSOC = 0x01
+} WMI_REASSOC_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 mode;
+}POSTPACK WMI_SET_REASSOC_MODE_CMD;
+
+typedef enum {
+ ROAM_DATA_TIME = 1, /* Get The Roam Time Data */
+} ROAM_DATA_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 disassoc_time;
+ A_UINT32 no_txrx_time;
+ A_UINT32 assoc_time;
+ A_UINT32 allow_txrx_time;
+ A_UINT8 disassoc_bssid[ATH_MAC_LEN];
+ A_INT8 disassoc_bss_rssi;
+ A_UINT8 assoc_bssid[ATH_MAC_LEN];
+ A_INT8 assoc_bss_rssi;
+} POSTPACK WMI_TARGET_ROAM_TIME;
+
+typedef PREPACK struct {
+ PREPACK union {
+ WMI_TARGET_ROAM_TIME roamTime;
+ } POSTPACK u;
+ A_UINT8 roamDataType ;
+} POSTPACK WMI_TARGET_ROAM_DATA;
+
+typedef enum {
+ WMI_WMM_DISABLED = 0,
+ WMI_WMM_ENABLED
+} WMI_WMM_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+}POSTPACK WMI_SET_WMM_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+}POSTPACK WMI_SET_QOS_SUPP_CMD;
+
+typedef enum {
+ WMI_TXOP_DISABLED = 0,
+ WMI_TXOP_ENABLED
+} WMI_TXOP_CFG;
+
+typedef PREPACK struct {
+ A_UINT8 txopEnable;
+}POSTPACK WMI_SET_WMM_TXOP_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 keepaliveInterval;
+} POSTPACK WMI_SET_KEEPALIVE_CMD;
+
+typedef PREPACK struct {
+ A_BOOL configured;
+ A_UINT8 keepaliveInterval;
+} POSTPACK WMI_GET_KEEPALIVE_CMD;
+
+/*
+ * Add Application specified IE to a management frame
+ */
+#define WMI_MAX_IE_LEN 255
+
+typedef PREPACK struct {
+ A_UINT8 mgmtFrmType; /* one of WMI_MGMT_FRAME_TYPE */
+ A_UINT8 ieLen; /* Length of the IE that should be added to the MGMT frame */
+ A_UINT8 ieInfo[1];
+} POSTPACK WMI_SET_APPIE_CMD;
+
+/*
+ * Add Application specified IE to a management frame
+ */
+typedef PREPACK struct {
+ A_UINT8 ieInfo[1];
+} POSTPACK WMI_SEND_ACTION_CMD;
+
+/*
+ * Notify the WSC registration status to the target
+ */
+#define WSC_REG_ACTIVE 1
+#define WSC_REG_INACTIVE 0
+/* Generic Hal Interface for setting hal paramters. */
+/* Add new Set HAL Param cmdIds here for newer params */
+typedef enum {
+ WHAL_SETCABTO_CMDID = 1,
+}WHAL_CMDID;
+
+typedef PREPACK struct {
+ A_UINT8 cabTimeOut;
+} POSTPACK WHAL_SETCABTO_PARAM;
+
+typedef PREPACK struct {
+ A_UINT8 whalCmdId;
+ A_UINT8 data[1];
+} POSTPACK WHAL_PARAMCMD;
+
+
+#define WOW_MAX_FILTER_LISTS 2 /*4*/
+#define WOW_MAX_FILTERS_PER_LIST 4
+#define WOW_PATTERN_SIZE 64
+#define WOW_MASK_SIZE 64
+
+#define MAC_MAX_FILTERS_PER_LIST 7
+
+typedef PREPACK struct {
+ A_UINT8 wow_valid_filter;
+ A_UINT8 wow_filter_id;
+ A_UINT8 wow_filter_size;
+ A_UINT8 wow_filter_offset;
+ A_UINT8 wow_filter_mask[WOW_MASK_SIZE];
+ A_UINT8 wow_filter_pattern[WOW_PATTERN_SIZE];
+} POSTPACK WOW_FILTER;
+
+
+typedef PREPACK struct {
+ A_UINT8 wow_valid_list;
+ A_UINT8 wow_list_id;
+ A_UINT8 wow_num_filters;
+ A_UINT8 wow_total_list_size;
+ WOW_FILTER list[WOW_MAX_FILTERS_PER_LIST];
+} POSTPACK WOW_FILTER_LIST;
+
+typedef PREPACK struct {
+ A_UINT8 valid_filter;
+ A_UINT8 mac_addr[ATH_MAC_LEN];
+} POSTPACK MAC_FILTER;
+
+
+typedef PREPACK struct {
+ A_UINT8 total_list_size;
+ A_UINT8 enable;
+ MAC_FILTER list[MAC_MAX_FILTERS_PER_LIST];
+} POSTPACK MAC_FILTER_LIST;
+
+#define MAX_IP_ADDRS 2
+typedef PREPACK struct {
+ A_UINT32 ips[MAX_IP_ADDRS]; /* IP in Network Byte Order */
+} POSTPACK WMI_SET_IP_CMD;
+
+typedef PREPACK struct {
+ A_BOOL awake;
+ A_BOOL asleep;
+} POSTPACK WMI_SET_HOST_SLEEP_MODE_CMD;
+
+typedef enum {
+ WOW_FILTER_SSID = 0x1
+} WMI_WOW_FILTER;
+
+typedef PREPACK struct {
+ A_BOOL enable_wow;
+ WMI_WOW_FILTER filter;
+ A_UINT16 hostReqDelay;
+} POSTPACK WMI_SET_WOW_MODE_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 filter_list_id;
+} POSTPACK WMI_GET_WOW_LIST_CMD;
+
+/*
+ * WMI_GET_WOW_LIST_CMD reply
+ */
+typedef PREPACK struct {
+ A_UINT8 num_filters; /* number of patterns in reply */
+ A_UINT8 this_filter_num; /* this is filter # x of total num_filters */
+ A_UINT8 wow_mode;
+ A_UINT8 host_mode;
+ WOW_FILTER wow_filters[1];
+} POSTPACK WMI_GET_WOW_LIST_REPLY;
+
+typedef PREPACK struct {
+ A_UINT8 filter_list_id;
+ A_UINT8 filter_size;
+ A_UINT8 filter_offset;
+ A_UINT8 filter[1];
+} POSTPACK WMI_ADD_WOW_PATTERN_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 filter_list_id;
+ A_UINT16 filter_id;
+} POSTPACK WMI_DEL_WOW_PATTERN_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 macaddr[ATH_MAC_LEN];
+} POSTPACK WMI_SET_MAC_ADDRESS_CMD;
+
+/*
+ * WMI_SET_AKMP_PARAMS_CMD
+ */
+
+#define WMI_AKMP_MULTI_PMKID_EN 0x000001
+
+typedef PREPACK struct {
+ A_UINT32 akmpInfo;
+} POSTPACK WMI_SET_AKMP_PARAMS_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 pmkid[WMI_PMKID_LEN];
+} POSTPACK WMI_PMKID;
+
+/*
+ * WMI_SET_PMKID_LIST_CMD
+ */
+#define WMI_MAX_PMKID_CACHE 8
+
+typedef PREPACK struct {
+ A_UINT32 numPMKID;
+ WMI_PMKID pmkidList[WMI_MAX_PMKID_CACHE];
+} POSTPACK WMI_SET_PMKID_LIST_CMD;
+
+/*
+ * WMI_GET_PMKID_LIST_CMD Reply
+ * Following the Number of PMKIDs is the list of PMKIDs
+ */
+typedef PREPACK struct {
+ A_UINT32 numPMKID;
+ A_UINT8 bssidList[ATH_MAC_LEN][1];
+ WMI_PMKID pmkidList[1];
+} POSTPACK WMI_PMKID_LIST_REPLY;
+
+typedef PREPACK struct {
+ A_UINT16 oldChannel;
+ A_UINT32 newChannel;
+} POSTPACK WMI_CHANNEL_CHANGE_EVENT;
+
+typedef PREPACK struct {
+ A_UINT32 version;
+} POSTPACK WMI_WLAN_VERSION_EVENT;
+
+
+/* WMI_ADDBA_REQ_EVENTID */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 win_sz;
+ A_UINT16 st_seq_no;
+ A_UINT8 status; /* f/w response for ADDBA Req; OK(0) or failure(!=0) */
+} POSTPACK WMI_ADDBA_REQ_EVENT;
+
+/* WMI_ADDBA_RESP_EVENTID */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 status; /* OK(0), failure (!=0) */
+ A_UINT16 amsdu_sz; /* Three values: Not supported(0), 3839, 8k */
+} POSTPACK WMI_ADDBA_RESP_EVENT;
+
+/* WMI_DELBA_EVENTID
+ * f/w received a DELBA for peer and processed it.
+ * Host is notified of this
+ */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 is_peer_initiator;
+ A_UINT16 reason_code;
+} POSTPACK WMI_DELBA_EVENT;
+
+
+#ifdef WAPI_ENABLE
+#define WAPI_REKEY_UCAST 1
+#define WAPI_REKEY_MCAST 2
+typedef PREPACK struct {
+ A_UINT8 type;
+ A_UINT8 macAddr[ATH_MAC_LEN];
+} POSTPACK WMI_WAPIREKEY_EVENT;
+#endif
+
+
+/* WMI_ALLOW_AGGR_CMDID
+ * Configures tid's to allow ADDBA negotiations
+ * on each tid, in each direction
+ */
+typedef PREPACK struct {
+ A_UINT16 tx_allow_aggr; /* 16-bit mask to allow uplink ADDBA negotiation - bit position indicates tid*/
+ A_UINT16 rx_allow_aggr; /* 16-bit mask to allow donwlink ADDBA negotiation - bit position indicates tid*/
+} POSTPACK WMI_ALLOW_AGGR_CMD;
+
+/* WMI_ADDBA_REQ_CMDID
+ * f/w starts performing ADDBA negotiations with peer
+ * on the given tid
+ */
+typedef PREPACK struct {
+ A_UINT8 tid;
+} POSTPACK WMI_ADDBA_REQ_CMD;
+
+/* WMI_DELBA_REQ_CMDID
+ * f/w would teardown BA with peer.
+ * is_send_initiator indicates if it's or tx or rx side
+ */
+typedef PREPACK struct {
+ A_UINT8 tid;
+ A_UINT8 is_sender_initiator;
+
+} POSTPACK WMI_DELBA_REQ_CMD;
+
+#define PEER_NODE_JOIN_EVENT 0x00
+#define PEER_NODE_LEAVE_EVENT 0x01
+#define PEER_FIRST_NODE_JOIN_EVENT 0x10
+#define PEER_LAST_NODE_LEAVE_EVENT 0x11
+typedef PREPACK struct {
+ A_UINT8 eventCode;
+ A_UINT8 peerMacAddr[ATH_MAC_LEN];
+} POSTPACK WMI_PEER_NODE_EVENT;
+
+#define IEEE80211_FRAME_TYPE_MGT 0x00
+#define IEEE80211_FRAME_TYPE_CTL 0x04
+
+typedef PREPACK struct {
+ A_UINT32 rules; /* combination of WMI_WRT_... values */
+} POSTPACK WMI_CONFIG_TX_MAC_RULES_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 enable; /* 1 == device operates in promiscuous mode , 0 == normal mode <default> */
+} POSTPACK WMI_SET_PROMISCUOUS_MODE_CMD;
+
+typedef enum {
+ RADIO_STATE_OFF = 0x1,
+ RADIO_STATE_ON = 0x2,
+ RADIO_STATE_INVALID = 0xFF
+}RFKILL_RADIO_STATE;
+
+typedef PREPACK struct {
+ A_UINT8 GPIOPinNumber;
+ A_UINT8 IntrType;
+ A_UINT8 RadioState;
+} POSTPACK WMI_RFKILL_MODE_CMD;
+
+/*
+ * Transmit complete event data structure(s)
+ */
+
+
+typedef PREPACK struct {
+#define TX_COMPLETE_STATUS_SUCCESS 0
+#define TX_COMPLETE_STATUS_RETRIES 1
+#define TX_COMPLETE_STATUS_NOLINK 2
+#define TX_COMPLETE_STATUS_TIMEOUT 3
+#define TX_COMPLETE_STATUS_OTHER 4
+
+ A_UINT8 status; /* one of TX_COMPLETE_STATUS_... */
+ A_UINT8 pktID; /* packet ID to identify parent packet */
+ A_UINT8 rateIdx; /* rate index on successful transmission */
+ A_UINT8 ackFailures; /* number of ACK failures in tx attempt */
+#if 0 /* optional params currently ommitted. */
+ A_UINT32 queueDelay; // usec delay measured Tx Start time - host delivery time
+ A_UINT32 mediaDelay; // usec delay measured ACK rx time - host delivery time
+#endif
+} POSTPACK TX_COMPLETE_MSG_V1; /* version 1 of tx complete msg */
+
+typedef PREPACK struct {
+ A_UINT8 numMessages; /* number of tx comp msgs following this struct */
+ A_UINT8 msgLen; /* length in bytes for each individual msg following this struct */
+ A_UINT8 msgType; /* version of tx complete msg data following this struct */
+ A_UINT8 reserved; /* individual messages follow this header */
+} POSTPACK WMI_TX_COMPLETE_EVENT;
+
+#define WMI_TXCOMPLETE_VERSION_1 (0x01)
+
+
+/*
+ * ------- AP Mode definitions --------------
+ */
+
+/*
+ * !!! Warning !!!
+ * -Changing the following values needs compilation of both driver and firmware
+ */
+#ifdef AR6002_REV2
+#define AP_MAX_NUM_STA 4
+#else
+#define AP_MAX_NUM_STA 10
+#endif
+
+/*Maximum no. of virtual interface supported*/
+#define NUM_DEV 3
+#define NUM_CONN (AP_MAX_NUM_STA + NUM_DEV)
+
+#define AP_ACL_SIZE 10
+#define IEEE80211_MAX_IE 256
+#define MCAST_AID 0xFF /* Spl. AID used to set DTIM flag in the beacons */
+#define DEF_AP_COUNTRY_CODE "US "
+#define DEF_AP_WMODE_G WMI_11G_MODE
+#define DEF_AP_WMODE_AG WMI_11AG_MODE
+#define DEF_AP_DTIM 5
+#define DEF_BEACON_INTERVAL 100
+
+/* ACS scan policy */
+
+typedef enum {
+ AP_ACS_NORMAL = 0, /* 1, 6, 11 */
+ AP_ACS_DISABLE_CH11, /* 1, 6 */
+ AP_ACS_INCLUDE_CH13, /* 1, 5, 9, 13 */
+ AP_ACS_DISABLE_CH1, /* dont use 1 */
+ AP_ACS_DISABLE_CH1_6, /* dont use 1 & 6 */
+ AP_ACS_POLICY_MAX
+}WMI_AP_ACS_POLICY_LIST;
+
+/* AP mode disconnect reasons */
+#define AP_DISCONNECT_STA_LEFT 101
+#define AP_DISCONNECT_FROM_HOST 102
+#define AP_DISCONNECT_COMM_TIMEOUT 103
+#define AP_DISCONNECT_MAX_STA 104
+#define AP_DISCONNECT_ACL 105
+#define AP_DISCONNECT_STA_ROAM 106
+#define AP_DISCONNECT_DFS_CHANNEL 107
+/*
+ * Used with WMI_AP_HIDDEN_SSID_CMDID
+ */
+#define HIDDEN_SSID_FALSE 0
+#define HIDDEN_SSID_TRUE 1
+typedef PREPACK struct {
+ A_UINT8 hidden_ssid;
+} POSTPACK WMI_AP_HIDDEN_SSID_CMD;
+
+/*
+ * Used with WMI_AP_ACL_POLICY_CMDID
+ */
+#define AP_ACL_DISABLE 0x00
+#define AP_ACL_ALLOW_MAC 0x01
+#define AP_ACL_DENY_MAC 0x02
+#define AP_ACL_RETAIN_LIST_MASK 0x80
+typedef PREPACK struct {
+ A_UINT8 policy;
+} POSTPACK WMI_AP_ACL_POLICY_CMD;
+
+/*
+ * Used with WMI_AP_ACL_MAC_LIST_CMDID
+ */
+#define ADD_MAC_ADDR 1
+#define DEL_MAC_ADDR 2
+typedef PREPACK struct {
+ A_UINT8 action;
+ A_UINT8 index;
+ A_UINT8 mac[ATH_MAC_LEN];
+ A_UINT8 wildcard;
+} POSTPACK WMI_AP_ACL_MAC_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 index;
+ A_UINT8 acl_mac[AP_ACL_SIZE][ATH_MAC_LEN];
+ A_UINT8 wildcard[AP_ACL_SIZE];
+ A_UINT8 policy;
+} POSTPACK WMI_AP_ACL;
+
+/*
+ * Used with WMI_AP_SET_NUM_STA_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 num_sta;
+} POSTPACK WMI_AP_NUM_STA_CMD;
+
+/*
+ * Used with WMI_AP_SET_MLME_CMDID
+ */
+typedef PREPACK struct {
+ A_UINT8 mac[ATH_MAC_LEN];
+ A_UINT16 reason; /* 802.11 reason code */
+ A_UINT8 cmd; /* operation to perform */
+/* MLME Commands */
+#define WMI_AP_MLME_ASSOC 1 /* associate station */
+#define WMI_AP_DISASSOC 2 /* disassociate station */
+#define WMI_AP_DEAUTH 3 /* deauthenticate station */
+#define WMI_AP_MLME_AUTHORIZE 4 /* authorize station */
+#define WMI_AP_MLME_UNAUTHORIZE 5 /* unauthorize station */
+} POSTPACK WMI_AP_SET_MLME_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 period;
+} POSTPACK WMI_AP_CONN_INACT_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 period_min;
+ A_UINT32 dwell_ms;
+} POSTPACK WMI_AP_PROT_SCAN_TIME_CMD;
+
+typedef PREPACK struct {
+ A_BOOL flag;
+ A_UINT16 rsvd;
+ A_UINT16 aid;
+} POSTPACK WMI_AP_SET_PVB_CMD;
+
+#define WMI_DISABLE_REGULATORY_CODE "FF"
+
+typedef PREPACK struct {
+ A_UCHAR countryCode[3];
+} POSTPACK WMI_AP_SET_COUNTRY_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 dtim;
+} POSTPACK WMI_AP_SET_DTIM_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 band; /* specifies which band to apply these values */
+ A_UINT8 enable; /* allows 11n to be disabled on a per band basis */
+ A_UINT8 chan_width_40M_supported;
+ A_UINT8 short_GI_20MHz;
+ A_UINT8 short_GI_40MHz;
+ A_UINT8 intolerance_40MHz;
+ A_UINT8 max_ampdu_len_exp;
+} POSTPACK WMI_SET_HT_CAP_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 sta_chan_width;
+} POSTPACK WMI_SET_HT_OP_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 rateMasks[WMI_MODE_MAX*WMI_MAX_RATE_MASK];
+} POSTPACK WMI_SET_TX_SELECT_RATES_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 sgiMask[WMI_MAX_RATE_MASK];
+ A_UINT8 sgiPERThreshold;
+} POSTPACK WMI_SET_TX_SGI_PARAM_CMD;
+
+#define DEFAULT_SGI_MASK_L32 0x08080000
+#define DEFAULT_SGI_MASK_U32 0x00000000
+#define DEFAULT_SGI_PER 10
+
+typedef PREPACK struct {
+ A_UINT32 rateField[WMI_MAX_RATE_MASK]; /* 1 bit per rate corresponding to index */
+#define WMI_RATE_POLICY_ID_MAX 5
+ A_UINT8 id; /* valid values == 1->WMI_RATE_POLICY_ID_MAX */
+ A_UINT8 shortTrys;
+ A_UINT8 longTrys;
+ A_UINT8 reserved; /* padding */
+} POSTPACK WMI_SET_RATE_POLICY_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 metaVersion; /* version of meta data for rx packets <0 = default> (0-7 = valid) */
+ A_UINT8 dot11Hdr; /* 1 == leave .11 header intact , 0 == replace .11 header with .3 <default> */
+ A_UINT8 defragOnHost; /* 1 == defragmentation is performed by host, 0 == performed by target <default> */
+ A_UINT8 reserved[1]; /* alignment */
+} POSTPACK WMI_RX_FRAME_FORMAT_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT8 enable; /* 1 == device operates in thin mode , 0 == normal mode <default> */
+ A_UINT8 reserved[3];
+} POSTPACK WMI_SET_THIN_MODE_CMD;
+
+
+typedef PREPACK struct {
+ A_UINT16 channel; /* frequency in Mhz */
+ //A_UINT8 mode; // HT20 or HT40
+ //A_UINT8 secondary; // if mode == HT40 secondary channel above | below
+} POSTPACK WMI_SET_CHANNEL_CMD;
+
+
+typedef enum {
+ WMI_SET_CHANNEL_RES_SUCCESS = 0, // device has joined the network
+ WMI_SET_CHANNEL_RES_FAIL, // device failed for unspecified reason
+}WMI_SET_CHANNEL_RESULT;
+
+typedef PREPACK struct {
+ A_UINT8 result; /* the result of the join cmd. one of WMI_THIN_JOIN_RESULT */
+ A_UINT8 reserved[3]; /* alignment */
+} POSTPACK WMI_SET_CHANNEL_EVENT;
+
+typedef enum {
+ WMI_FILTERMASK_MGMT=0,
+ WMI_FILTERMASK_CTRL,
+ WMI_FILTERMASK_DATA,
+ WMI_FILTERMASK_MAX
+}WMI_FILTERMASK_INDEX;
+
+typedef PREPACK struct {
+ A_UINT16 filtermask[WMI_FILTERMASK_MAX];
+ A_UINT16 reserved; /* alignment */
+} POSTPACK WMI_RX_FRAME_FILTER_CMD;
+
+/* AP mode events */
+/* WMI_PS_POLL_EVENT */
+typedef PREPACK struct {
+ A_UINT16 aid;
+} POSTPACK WMI_PSPOLL_EVENT;
+
+typedef PREPACK struct {
+ A_UINT32 tx_bytes;
+ A_UINT32 tx_pkts;
+ A_UINT32 tx_error;
+ A_UINT32 tx_discard;
+ A_UINT32 rx_bytes;
+ A_UINT32 rx_pkts;
+ A_UINT32 rx_error;
+ A_UINT32 rx_discard;
+ A_UINT32 aid;
+} POSTPACK WMI_PER_STA_STAT;
+
+#define AP_GET_STATS 0
+#define AP_CLEAR_STATS 1
+
+typedef PREPACK struct {
+ A_UINT32 action;
+ WMI_PER_STA_STAT sta[AP_MAX_NUM_STA];
+} POSTPACK WMI_AP_MODE_STAT;
+
+#define AP_11BG_RATESET1 1
+#define AP_11BG_RATESET2 2
+#define DEF_AP_11BG_RATESET AP_11BG_RATESET1
+typedef PREPACK struct {
+ A_UINT8 rateset;
+} POSTPACK WMI_AP_SET_11BG_RATESET_CMD;
+/*
+ * End of AP mode definitions
+ */
+
+struct _wmm_params {
+ A_UINT8 acm; /* ACM parameter */
+ A_UINT8 aifsn; /* AIFSN parameters */
+ A_UINT8 logcwmin; /* cwmin in exponential form */
+ A_UINT8 logcwmax; /* cwmax in exponential form */
+ A_UINT16 txopLimit; /* txopLimit */
+};
+
+/* WMI_REPORT_WMM_PARAMS_EVENT */
+typedef PREPACK struct {
+ struct _wmm_params wmm_params[4];
+} POSTPACK WMI_REPORT_WMM_PARAMS_EVENT;
+
+/* P2P module definitions */
+
+/* P2P module commands */
+typedef PREPACK struct {
+ A_UINT8 go_intent;
+ A_UINT8 country[3];
+ A_UINT8 reg_class;
+ A_UINT8 listen_channel;
+ A_UINT8 op_reg_class;
+ A_UINT8 op_channel;
+ A_UINT16 config_methods;
+} POSTPACK WMI_P2P_SET_CONFIG_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 categ;
+ A_UINT16 sub_categ;
+} POSTPACK device_type_tuple;
+
+typedef PREPACK struct {
+ device_type_tuple pri_dev_type;
+ //A_UINT8 pri_device_type[8];
+#define MAX_P2P_SEC_DEVICE_TYPES 5
+ device_type_tuple sec_dev_type[MAX_P2P_SEC_DEVICE_TYPES];
+#define WPS_UUID_LEN 16
+ A_UINT8 uuid[WPS_UUID_LEN];
+#define WPS_MAX_DEVNAME_LEN 32
+ A_UINT8 device_name[WPS_MAX_DEVNAME_LEN];
+ A_UINT8 dev_name_len;
+} POSTPACK WMI_WPS_SET_CONFIG_CMD;
+
+typedef PREPACK struct {
+ device_type_tuple pri_dev_type;
+ device_type_tuple sec_dev_type[MAX_P2P_SEC_DEVICE_TYPES];
+ A_UINT8 device_addr[ATH_MAC_LEN];
+} POSTPACK WMI_SET_REQ_DEV_ATTR_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 ssidLength;
+ A_UINT8 ssid[WMI_MAX_SSID_LEN];
+} POSTPACK P2P_SSID;
+
+typedef enum wmi_p2p_discovery_type {
+ WMI_P2P_FIND_START_WITH_FULL,
+ WMI_P2P_FIND_ONLY_SOCIAL,
+ WMI_P2P_FIND_PROGRESSIVE
+} WMI_P2P_DISC_TYPE;
+
+typedef PREPACK struct {
+ A_UINT32 timeout;
+ WMI_P2P_DISC_TYPE type;
+} POSTPACK WMI_P2P_FIND_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 listen_freq;
+ A_UINT16 force_freq;
+ A_UINT16 go_oper_freq;
+ A_UINT8 dialog_token;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT8 own_interface_addr[ATH_MAC_LEN];
+ A_UINT8 member_in_go_dev[ATH_MAC_LEN];
+ A_UINT8 go_dev_dialog_token;
+ P2P_SSID peer_go_ssid;
+ A_UINT8 wps_method;
+ A_UINT8 dev_capab;
+ A_INT8 go_intent;
+ A_UINT8 persistent_grp;
+} POSTPACK WMI_P2P_GO_NEG_START_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 persistent_group;
+ A_UINT8 group_formation;
+} POSTPACK WMI_P2P_GRP_INIT_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT8 grp_formation_status;
+} POSTPACK WMI_P2P_GRP_FORMATION_DONE_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 timeout;
+}POSTPACK WMI_P2P_LISTEN_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 listen_freq;
+ A_UINT16 force_freq;
+ A_UINT8 status;
+ A_INT8 go_intent;
+ A_UINT8 wps_buf[512];
+ A_UINT16 wps_buflen;
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 dialog_token;
+ A_UINT8 wps_method;
+ A_UINT8 persistent_grp;
+ A_UINT8 sa[ATH_MAC_LEN];
+}POSTPACK WMI_P2P_GO_NEG_REQ_RSP_CMD;
+
+typedef enum {
+ WMI_P2P_INVITE_ROLE_GO,
+ WMI_P2P_INVITE_ROLE_ACTIVE_GO,
+ WMI_P2P_INVITE_ROLE_CLIENT,
+} WMI_P2P_INVITE_ROLE;
+
+typedef PREPACK struct {
+ WMI_P2P_INVITE_ROLE role;
+ A_UINT16 listen_freq;
+ A_UINT16 force_freq;
+ A_UINT8 dialog_token;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID ssid;
+ A_UINT8 is_persistent;
+ A_UINT8 wps_method;
+}POSTPACK WMI_P2P_INVITE_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 force_freq;
+ A_UINT8 status;
+ A_UINT8 dialog_token;
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 is_go;
+ A_UINT8 group_bssid[ATH_MAC_LEN];
+}POSTPACK WMI_P2P_INVITE_REQ_RSP_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 wps_method;
+ A_UINT16 listen_freq;
+ A_UINT8 dialog_token;
+ A_UINT8 peer[ATH_MAC_LEN];
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID go_oper_ssid;
+}POSTPACK WMI_P2P_PROV_DISC_REQ_CMD;
+
+typedef enum {
+ WMI_P2P_CONFID_LISTEN_CHANNEL=1,
+ WMI_P2P_CONFID_CROSS_CONNECT=2,
+ WMI_P2P_CONFID_SSID_POSTFIX=3,
+ WMI_P2P_CONFID_INTRA_BSS=4,
+ WMI_P2P_CONFID_CONCURRENT_MODE=5,
+ WMI_P2P_CONFID_GO_INTENT=6,
+ WMI_P2P_CONFID_DEV_NAME=7,
+
+} WMI_P2P_CONF_ID;
+
+typedef PREPACK struct {
+ A_UINT8 reg_class;
+ A_UINT8 listen_channel;
+}POSTPACK WMI_P2P_LISTEN_CHANNEL;
+
+typedef PREPACK struct {
+ A_UINT8 flag;
+}POSTPACK WMI_P2P_SET_CROSS_CONNECT;
+
+typedef PREPACK struct {
+ A_UINT8 flag;
+}POSTPACK WMI_P2P_SET_CONCURRENT_MODE;
+
+typedef PREPACK struct {
+ A_UINT8 ssid_postfix[WMI_MAX_SSID_LEN-9];
+ A_UINT8 ssid_postfix_len;
+}POSTPACK WMI_P2P_SET_SSID_POSTFIX;
+
+typedef PREPACK struct {
+ A_UINT8 value;
+}POSTPACK WMI_P2P_SET_GO_INTENT;
+
+typedef PREPACK struct {
+ A_UINT8 dev_name[WPS_MAX_DEVNAME_LEN];
+ A_UINT8 dev_name_len;
+}POSTPACK WMI_P2P_SET_DEV_NAME;
+
+typedef PREPACK struct {
+ A_UINT8 flag;
+}POSTPACK WMI_P2P_SET_INTRA_BSS;
+
+typedef PREPACK struct {
+ A_UINT8 config_id; /* set to one of WMI_P2P_CONF_ID */
+ PREPACK union {
+ WMI_P2P_LISTEN_CHANNEL listen_ch;
+ WMI_P2P_SET_CROSS_CONNECT cross_conn;
+ WMI_P2P_SET_SSID_POSTFIX ssid_postfix;
+ WMI_P2P_SET_INTRA_BSS intra_bss;
+ WMI_P2P_SET_CONCURRENT_MODE concurrent_mode;
+ WMI_P2P_SET_GO_INTENT go_intent;
+ WMI_P2P_SET_DEV_NAME device_name;
+ }POSTPACK val;
+}POSTPACK WMI_P2P_SET_CMD;
+
+#define WMI_P2P_MAX_TLV_LEN 1024
+typedef enum {
+ WMI_P2P_SD_TYPE_GAS_INITIAL_REQ = 0x1,
+ WMI_P2P_SD_TYPE_GAS_INITIAL_RESP = 0x2,
+ WMI_P2P_SD_TYPE_GAS_COMEBACK_REQ = 0x3,
+ WMI_P2P_SD_TYPE_GAS_COMEBACK_RESP = 0x4,
+ WMI_P2P_PD_TYPE_RESP = 0x5,
+ WMI_P2P_SD_TYPE_STATUS_IND = 0x6,
+} WMI_P2P_SDPD_TYPE;
+
+typedef enum {
+ WMI_P2P_SDPD_TRANSACTION_PENDING = 0x1,
+ WMI_P2P_SDPD_TRANSACTION_COMP = 0x2,
+} WMI_P2P_SDPD_TRANSACTION_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 type;
+ A_UINT8 dialog_token;
+ A_UINT8 frag_id;
+ A_UINT8 reserved1; /* alignment */
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT16 freq;
+ A_UINT16 status_code;
+ A_UINT16 comeback_delay;
+ A_UINT16 tlv_length;
+ A_UINT16 update_indic;
+ A_UINT16 total_length;
+ A_UINT16 reserved2; /* future */
+ A_UINT8 tlv[WMI_P2P_MAX_TLV_LEN];
+} POSTPACK WMI_P2P_SDPD_TX_CMD;
+
+/* P2P module events */
+
+typedef PREPACK struct {
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT8 wps_buf[512];
+ A_UINT16 wps_buflen;
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 dialog_token;
+}POSTPACK WMI_P2P_GO_NEG_REQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT16 freq;
+ A_INT8 status;
+ A_UINT8 role_go;
+ A_UINT8 ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 ssid_len;
+#define WMI_MAX_PASSPHRASE_LEN 9
+ A_CHAR pass_phrase[WMI_MAX_PASSPHRASE_LEN];
+ A_UINT8 peer_device_addr[ATH_MAC_LEN];
+ A_UINT8 peer_interface_addr[ATH_MAC_LEN];
+ A_UINT8 wps_method;
+ A_UINT8 persistent_grp;
+} POSTPACK WMI_P2P_GO_NEG_RESULT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 p2p_buf[512];
+ A_UINT16 p2p_buflen;
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID ssid;
+ A_UINT8 is_persistent;
+ A_UINT8 dialog_token;
+} POSTPACK WMI_P2P_INVITE_REQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT16 oper_freq;
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 is_bssid_valid;
+ A_UINT8 go_dev_addr[ATH_MAC_LEN];
+ P2P_SSID ssid;
+ A_UINT8 status;
+} POSTPACK WMI_P2P_INVITE_RCVD_RESULT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 status;
+ A_UINT8 bssid[ATH_MAC_LEN];
+ A_UINT8 is_bssid_valid;
+} POSTPACK WMI_P2P_INVITE_SENT_RESULT_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 sa[ATH_MAC_LEN];
+ A_UINT16 wps_config_method;
+ A_UINT8 dev_addr[ATH_MAC_LEN];
+#define WPS_DEV_TYPE_LEN 8
+ A_UINT8 pri_dev_type[WPS_DEV_TYPE_LEN];
+ A_UINT8 device_name[WPS_MAX_DEVNAME_LEN];
+ A_UINT8 dev_name_len;
+ A_UINT16 dev_config_methods;
+ A_UINT8 device_capab;
+ A_UINT8 group_capab;
+} POSTPACK WMI_P2P_PROV_DISC_REQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 peer[ATH_MAC_LEN];
+ A_UINT16 config_methods;
+} POSTPACK WMI_P2P_PROV_DISC_RESP_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 type;
+ A_UINT8 transaction_status;
+ A_UINT8 dialog_token;
+ A_UINT8 frag_id;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+ A_UINT16 freq;
+ A_UINT16 status_code;
+ A_UINT16 comeback_delay;
+ A_UINT16 tlv_length;
+ A_UINT16 update_indic;
+// Variable length TLV will be placed after the event
+} POSTPACK WMI_P2P_SDPD_RX_EVENT;
+
+typedef PREPACK struct {
+ A_UINT16 tlv_length;
+// Variable length TLV will be placed after the event
+} POSTPACK WMI_HS20_RX_EVENT;
+
+typedef PREPACK struct {
+ A_UINT8 event_id; /* event identifier */
+ A_UINT8 length; /* number of bytes of data that follows */
+ A_UINT8 data[1]; /* start of event data */
+} POSTPACK WMI_ACS_EVENT_MSG;
+
+#define WMI_ACS_EVENT_HDR_LEN (sizeof(WMI_ACS_EVENT_MSG) - sizeof(A_UINT8))
+
+typedef PREPACK struct {
+ A_UINT8 ctrl_id; /* control identifier */
+ A_UINT8 length; /* number of bytes of data to follow */
+ A_UINT8 data[1]; /* start of control data */
+} POSTPACK WMI_ACS_CTRL_MSG;
+
+#define WMI_ACS_CTRL_HDR_LEN (sizeof(WMI_ACS_CTRL_MSG) - sizeof(A_UINT8))
+
+/* STORE / RECALL Commands AND Events DEFINITION START */
+typedef PREPACK struct {
+ A_UINT8 enable;
+#define STRRCL_RECIPIENT_HOST 1
+ A_UINT8 recipient;
+} POSTPACK WMI_STORERECALL_CONFIGURE_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 length; /* number of bytes of data to follow */
+ A_UINT8 data[1]; /* start of data */
+} POSTPACK WMI_STORERECALL_RECALL_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 sleep_msec;
+ A_UINT8 store_after_tx_empty;
+ A_UINT8 store_after_fresh_beacon_rx;
+} POSTPACK WMI_STORERECALL_HOST_READY_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 msec_sleep; /* time between power off/on */
+ A_UINT32 length; /* length of following data */
+ A_UINT8 data[1]; /* start of data */
+} POSTPACK WMI_STORERECALL_STORE_EVENT;
+
+/* STORE / RECALL Commands AND Events DEFINITION END */
+
+typedef enum {
+ WMI_AP_APSD_DISABLED = 0,
+ WMI_AP_APSD_ENABLED
+} WMI_AP_APSD_STATUS;
+
+typedef PREPACK struct {
+ A_UINT8 enable;
+} POSTPACK WMI_AP_SET_APSD_CMD;
+
+typedef enum {
+ WMI_AP_APSD_NO_DELIVERY_FRAMES_FOR_THIS_TRIGGER = 0x1,
+} WMI_AP_APSD_BUFFERED_TRAFFIC_FLAGS;
+
+typedef PREPACK struct {
+ A_UINT16 aid;
+ A_UINT16 bitmap;
+ A_UINT32 flags;
+} POSTPACK WMI_AP_APSD_BUFFERED_TRAFFIC_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 enable;
+} POSTPACK WMI_STA_BMISS_ENHANCE_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 freq;
+} POSTPACK WMI_LTE_FREQ_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 time_val_sec;
+} POSTPACK WMI_AP_IDLE_CLOSE_TIME_CMD;
+
+/*
+ * These constants are used with A_WLAN_BAND_SET.
+ */
+#define A_BAND_24GHZ 0
+#define A_BAND_5GHZ 1
+#define A_NUM_BANDS 2
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WMI_H_ */
diff --git a/host/include/wmi_api.h b/host/include/wmi_api.h
new file mode 100644
index 0000000..57177f9
--- /dev/null
+++ b/host/include/wmi_api.h
@@ -0,0 +1,582 @@
+//------------------------------------------------------------------------------
+// <copyright file="wmi_api.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains the definitions for the Wireless Module Interface (WMI).
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _WMI_API_H_
+#define _WMI_API_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+ /* WMI converts a dix frame with an ethernet payload (up to 1500 bytes)
+ * to an 802.3 frame (adds SNAP header) and adds on a WMI data header */
+#define WMI_MAX_TX_DATA_FRAME_LENGTH (1500 + sizeof(WMI_DATA_HDR) + sizeof(ATH_MAC_HDR) + sizeof(ATH_LLC_SNAP_HDR))
+
+ /* A normal WMI data frame */
+#define WMI_MAX_NORMAL_RX_DATA_FRAME_LENGTH (1500 + sizeof(WMI_DATA_HDR) + sizeof(ATH_MAC_HDR) + sizeof(ATH_LLC_SNAP_HDR))
+
+ /* An AMSDU frame */ /* The MAX AMSDU length of AR6003 is 3839 */
+#define WMI_MAX_AMSDU_RX_DATA_FRAME_LENGTH (3840 + sizeof(WMI_DATA_HDR) + sizeof(ATH_MAC_HDR) + sizeof(ATH_LLC_SNAP_HDR))
+
+/*
+ * IP QoS Field definitions according to 802.1p
+ */
+#define BEST_EFFORT_PRI 0
+#define BACKGROUND_PRI 1
+#define EXCELLENT_EFFORT_PRI 3
+#define CONTROLLED_LOAD_PRI 4
+#define VIDEO_PRI 5
+#define VOICE_PRI 6
+#define NETWORK_CONTROL_PRI 7
+#define MAX_NUM_PRI 8
+
+#define UNDEFINED_PRI (0xff)
+
+#define WMI_IMPLICIT_PSTREAM_INACTIVITY_INT 5000 /* 5 seconds */
+
+#define A_ROUND_UP(x, y) ((((x) + ((y) - 1)) / (y)) * (y))
+
+typedef enum {
+ ATHEROS_COMPLIANCE = 0x1,
+}TSPEC_PARAM_COMPLIANCE;
+
+struct wmi_t;
+
+void *wmi_init(void *devt, int devid);
+
+void wmi_qos_state_init(struct wmi_t *wmip);
+void wmi_shutdown(struct wmi_t *wmip);
+HTC_ENDPOINT_ID wmi_get_control_ep(struct wmi_t * wmip);
+void wmi_set_control_ep(struct wmi_t * wmip, HTC_ENDPOINT_ID eid);
+void wmi_set_host_sleep_mode_event_fn_ptr(struct wmi_t *wmip,
+ void (*host_sleep_mode_event_fn)(void *), void *host_sleep_mode_event_fn_arg);
+A_UINT16 wmi_get_mapped_qos_queue(struct wmi_t *, A_UINT8);
+A_STATUS wmi_dix_2_dot3(struct wmi_t *wmip, void *osbuf);
+A_STATUS wmi_data_hdr_add(struct wmi_t *wmip, void *osbuf, A_UINT8 msgType, A_UINT32 flags , WMI_DATA_HDR_DATA_TYPE data_type,A_UINT8 metaVersion, void *pTxMetaS);
+A_STATUS wmi_dot3_2_dix(void *osbuf);
+
+A_STATUS wmi_dot11_hdr_remove (struct wmi_t *wmip, void *osbuf);
+A_STATUS wmi_dot11_hdr_add(struct wmi_t *wmip, void *osbuf, NETWORK_TYPE mode);
+
+A_STATUS wmi_data_hdr_remove(struct wmi_t *wmip, void *osbuf);
+A_STATUS wmi_syncpoint(struct wmi_t *wmip);
+A_STATUS wmi_syncpoint_reset(struct wmi_t *wmip);
+A_UINT8 wmi_implicit_create_pstream(struct wmi_t *wmip, void *osbuf, A_UINT32 layer2Priority, A_BOOL wmmEnabled);
+
+A_UINT8 wmi_determine_userPriority (A_UINT8 *pkt, A_UINT32 layer2Pri);
+
+A_STATUS wmi_control_rx(struct wmi_t *wmip, void *osbuf);
+void wmi_iterate_nodes(struct wmi_t *wmip, wlan_node_iter_func *f, void *arg);
+void wmi_scan_report_lock(struct wmi_t *wmip);
+void wmi_scan_report_unlock(struct wmi_t *wmip);
+void wmi_free_allnodes(struct wmi_t *wmip);
+bss_t *wmi_find_node(struct wmi_t *wmip, const A_UINT8 *macaddr);
+void wmi_free_node(struct wmi_t *wmip, const A_UINT8 *macaddr);
+
+
+typedef enum {
+ NO_SYNC_WMIFLAG = 0,
+ SYNC_BEFORE_WMIFLAG, /* transmit all queued data before cmd */
+ SYNC_AFTER_WMIFLAG, /* any new data waits until cmd execs */
+ SYNC_BOTH_WMIFLAG,
+ END_WMIFLAG /* end marker */
+} WMI_SYNC_FLAG;
+
+A_STATUS wmi_cmd_send(struct wmi_t *wmip, void *osbuf, WMI_COMMAND_ID cmdId,
+ WMI_SYNC_FLAG flag);
+
+A_STATUS wmi_connect_cmd(struct wmi_t *wmip,
+ NETWORK_TYPE netType,
+ DOT11_AUTH_MODE dot11AuthMode,
+ AUTH_MODE authMode,
+ CRYPTO_TYPE pairwiseCrypto,
+ A_UINT8 pairwiseCryptoLen,
+ CRYPTO_TYPE groupCrypto,
+ A_UINT8 groupCryptoLen,
+ int ssidLength,
+ A_UCHAR *ssid,
+ A_UINT8 *bssid,
+ A_UINT16 channel,
+ A_UINT32 ctrl_flags);
+
+A_STATUS wmi_set_div_param_cmd(struct wmi_t *wmip, A_UINT32 divIdleTime,
+ A_UINT8 antRssiThresh, A_UINT8 divEnable, A_UINT16 active_treshold_rate);
+
+
+A_STATUS wmi_reconnect_cmd(struct wmi_t *wmip,
+ A_UINT8 *bssid,
+ A_UINT16 channel);
+A_STATUS wmi_disconnect_cmd(struct wmi_t *wmip);
+A_STATUS wmi_getrev_cmd(struct wmi_t *wmip);
+A_STATUS wmi_startscan_cmd(struct wmi_t *wmip, WMI_SCAN_TYPE scanType,
+ A_BOOL forceFgScan, A_BOOL isLegacy,
+ A_UINT32 homeDwellTime, A_UINT32 forceScanInterval,
+ A_INT8 numChan, A_UINT16 *channelList);
+A_STATUS wmi_scanparams_cmd(struct wmi_t *wmip, A_UINT16 fg_start_sec,
+ A_UINT16 fg_end_sec, A_UINT16 bg_sec,
+ A_UINT16 minact_chdw_msec,
+ A_UINT16 maxact_chdw_msec, A_UINT16 pas_chdw_msec,
+ A_UINT8 shScanRatio, A_UINT8 scanCtrlFlags,
+ A_UINT32 max_dfsch_act_time,
+ A_UINT16 maxact_scan_per_ssid);
+A_STATUS wmi_bssfilter_cmd(struct wmi_t *wmip, A_UINT8 filter, A_UINT32 ieMask);
+A_STATUS wmi_probedSsid_cmd(struct wmi_t *wmip, A_UINT8 index, A_UINT8 flag,
+ A_UINT8 ssidLength, A_UCHAR *ssid);
+A_STATUS wmi_listeninterval_cmd(struct wmi_t *wmip, A_UINT16 listenInterval, A_UINT16 listenBeacons);
+A_STATUS wmi_bmisstime_cmd(struct wmi_t *wmip, A_UINT16 bmisstime, A_UINT16 bmissbeacons);
+A_STATUS wmi_associnfo_cmd(struct wmi_t *wmip, A_UINT8 ieType,
+ A_UINT8 ieLen, A_UINT8 *ieInfo);
+A_STATUS wmi_powermode_cmd(struct wmi_t *wmip, A_UINT8 powerMode);
+A_STATUS wmi_powermode_cmd_w_psminfo(struct wmi_t *wmip, A_UINT8 _psm_info,A_UINT8 _default);
+A_STATUS wmi_ibsspmcaps_cmd(struct wmi_t *wmip, A_UINT8 pmEnable, A_UINT8 ttl,
+ A_UINT16 atim_windows, A_UINT16 timeout_value);
+A_STATUS wmi_apps_cmd(struct wmi_t *wmip, A_UINT8 psType, A_UINT32 idle_time,
+ A_UINT32 ps_period, A_UINT8 sleep_period);
+A_STATUS wmi_pmparams_cmd(struct wmi_t *wmip, A_UINT16 idlePeriod,
+ A_UINT16 psPollNum, A_UINT16 dtimPolicy,
+ A_UINT16 wakup_tx_policy, A_UINT16 num_tx_to_wakeup,
+ A_UINT16 ps_fail_event_policy);
+A_STATUS wmi_disctimeout_cmd(struct wmi_t *wmip, A_UINT8 timeout);
+A_STATUS wmi_sync_cmd(struct wmi_t *wmip, A_UINT8 syncNumber);
+A_STATUS wmi_create_pstream_cmd(struct wmi_t *wmip, WMI_CREATE_PSTREAM_CMD *pstream);
+A_STATUS wmi_delete_pstream_cmd(struct wmi_t *wmip, A_UINT8 trafficClass, A_UINT8 streamID);
+A_STATUS wmi_set_framerate_cmd(struct wmi_t *wmip, A_UINT8 bEnable, A_UINT8 type, A_UINT8 subType, A_UINT16 rateMask);
+A_STATUS wmi_set_bitrate_cmd(struct wmi_t *wmip, A_INT32 dataRate, A_INT32 mgmtRate, A_INT32 ctlRate);
+A_STATUS wmi_get_bitrate_cmd(struct wmi_t *wmip);
+A_INT8 wmi_validate_bitrate(struct wmi_t *wmip, A_INT32 rate, A_INT8 *rate_idx);
+A_STATUS wmi_get_regDomain_cmd(struct wmi_t *wmip);
+A_STATUS wmi_get_channelList_cmd(struct wmi_t *wmip);
+A_STATUS wmi_set_channelParams_cmd(struct wmi_t *wmip, A_UINT8 scanParam,
+ WMI_PHY_MODE mode, A_INT8 numChan,
+ A_UINT16 *channelList);
+
+A_STATUS wmi_set_snr_threshold_params(struct wmi_t *wmip,
+ WMI_SNR_THRESHOLD_PARAMS_CMD *snrCmd);
+A_STATUS wmi_set_rssi_threshold_params(struct wmi_t *wmip,
+ WMI_RSSI_THRESHOLD_PARAMS_CMD *rssiCmd);
+A_STATUS wmi_clr_rssi_snr(struct wmi_t *wmip);
+A_STATUS wmi_set_lq_threshold_params(struct wmi_t *wmip,
+ WMI_LQ_THRESHOLD_PARAMS_CMD *lqCmd);
+A_STATUS wmi_set_rts_cmd(struct wmi_t *wmip, A_UINT16 threshold);
+A_STATUS wmi_set_lpreamble_cmd(struct wmi_t *wmip, A_UINT8 status, A_UINT8 preamblePolicy);
+
+A_STATUS wmi_set_error_report_bitmask(struct wmi_t *wmip, A_UINT32 bitmask);
+
+A_STATUS wmi_get_challenge_resp_cmd(struct wmi_t *wmip, A_UINT32 cookie,
+ A_UINT32 source);
+
+A_STATUS wmi_config_debug_module_cmd(struct wmi_t *wmip, A_UINT16 mmask,
+ A_UINT16 tsr, A_BOOL rep, A_UINT16 size,
+ A_UINT32 valid);
+
+A_STATUS wmi_get_stats_cmd(struct wmi_t *wmip);
+
+A_STATUS wmi_addKey_cmd(struct wmi_t *wmip, A_UINT8 keyIndex,
+ CRYPTO_TYPE keyType, A_UINT8 keyUsage,
+ A_UINT8 keyLength,A_UINT8 *keyRSC,
+ A_UINT8 *keyMaterial, A_UINT8 key_op_ctrl, A_UINT8 *mac,
+ WMI_SYNC_FLAG sync_flag);
+A_STATUS wmi_add_krk_cmd(struct wmi_t *wmip, A_UINT8 *krk);
+A_STATUS wmi_delete_krk_cmd(struct wmi_t *wmip);
+A_STATUS wmi_deleteKey_cmd(struct wmi_t *wmip, A_UINT8 keyIndex);
+A_STATUS wmi_set_akmp_params_cmd(struct wmi_t *wmip,
+ WMI_SET_AKMP_PARAMS_CMD *akmpParams);
+A_STATUS wmi_get_pmkid_list_cmd(struct wmi_t *wmip);
+A_STATUS wmi_set_pmkid_list_cmd(struct wmi_t *wmip,
+ WMI_SET_PMKID_LIST_CMD *pmkInfo);
+A_STATUS wmi_abort_scan_cmd(struct wmi_t *wmip);
+A_STATUS wmi_set_txPwr_cmd(struct wmi_t *wmip, A_UINT8 dbM);
+A_STATUS wmi_get_txPwr_cmd(struct wmi_t *wmip);
+A_STATUS wmi_addBadAp_cmd(struct wmi_t *wmip, A_UINT8 apIndex, A_UINT8 *bssid);
+A_STATUS wmi_deleteBadAp_cmd(struct wmi_t *wmip, A_UINT8 apIndex);
+A_STATUS wmi_set_tkip_countermeasures_cmd(struct wmi_t *wmip, A_BOOL en);
+A_STATUS wmi_setPmkid_cmd(struct wmi_t *wmip, A_UINT8 *bssid, A_UINT8 *pmkId,
+ A_BOOL set);
+A_STATUS wmi_set_access_params_cmd(struct wmi_t *wmip, A_UINT8 ac, A_UINT16 txop,
+ A_UINT8 eCWmin, A_UINT8 eCWmax,
+ A_UINT8 aifsn);
+A_STATUS wmi_set_retry_limits_cmd(struct wmi_t *wmip, A_UINT8 frameType,
+ A_UINT8 trafficClass, A_UINT8 maxRetries,
+ A_UINT8 enableNotify);
+
+void wmi_get_current_bssid(struct wmi_t *wmip, A_UINT8 *bssid);
+
+A_STATUS wmi_get_roam_tbl_cmd(struct wmi_t *wmip);
+A_STATUS wmi_get_roam_data_cmd(struct wmi_t *wmip, A_UINT8 roamDataType);
+A_STATUS wmi_set_roam_ctrl_cmd(struct wmi_t *wmip, WMI_SET_ROAM_CTRL_CMD *p,
+ A_UINT8 size);
+A_STATUS wmi_set_powersave_timers_cmd(struct wmi_t *wmip,
+ WMI_POWERSAVE_TIMERS_POLICY_CMD *pCmd,
+ A_UINT8 size);
+
+A_STATUS wmi_set_opt_mode_cmd(struct wmi_t *wmip, A_UINT8 optMode);
+A_STATUS wmi_opt_tx_frame_cmd(struct wmi_t *wmip,
+ A_UINT8 frmType,
+ A_UINT8 *dstMacAddr,
+ A_UINT8 *bssid,
+ A_UINT16 optIEDataLen,
+ A_UINT8 *optIEData);
+
+A_STATUS wmi_set_adhoc_bconIntvl_cmd(struct wmi_t *wmip, A_UINT16 intvl);
+A_STATUS wmi_set_voice_pkt_size_cmd(struct wmi_t *wmip, A_UINT16 voicePktSize);
+A_STATUS wmi_set_max_sp_len_cmd(struct wmi_t *wmip, A_UINT8 maxSpLen);
+A_UINT8 convert_userPriority_to_trafficClass(A_UINT8 userPriority);
+A_UINT8 wmi_get_power_mode_cmd(struct wmi_t *wmip);
+A_STATUS wmi_verify_tspec_params(WMI_CREATE_PSTREAM_CMD *pCmd, A_BOOL tspecCompliance);
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+A_STATUS wmi_test_cmd(struct wmi_t *wmip, A_UINT8 *buf, A_UINT32 len);
+#endif
+
+A_STATUS wmi_set_bt_status_cmd(struct wmi_t *wmip, A_UINT8 streamType, A_UINT8 status);
+A_STATUS wmi_set_bt_params_cmd(struct wmi_t *wmip, WMI_SET_BT_PARAMS_CMD* cmd);
+
+A_STATUS wmi_set_btcoex_fe_ant_cmd(struct wmi_t *wmip, WMI_SET_BTCOEX_FE_ANT_CMD * cmd);
+
+A_STATUS wmi_set_btcoex_colocated_bt_dev_cmd(struct wmi_t *wmip,
+ WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD * cmd);
+
+A_STATUS wmi_set_btcoex_btinquiry_page_config_cmd(struct wmi_t *wmip,
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD *cmd);
+
+A_STATUS wmi_set_btcoex_sco_config_cmd(struct wmi_t *wmip,
+ WMI_SET_BTCOEX_SCO_CONFIG_CMD * cmd);
+
+A_STATUS wmi_set_btcoex_a2dp_config_cmd(struct wmi_t *wmip,
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMD* cmd);
+
+
+A_STATUS wmi_set_btcoex_aclcoex_config_cmd(struct wmi_t *wmip, WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD* cmd);
+
+A_STATUS wmi_set_btcoex_debug_cmd(struct wmi_t *wmip, WMI_SET_BTCOEX_DEBUG_CMD * cmd);
+
+A_STATUS wmi_set_btcoex_bt_operating_status_cmd(struct wmi_t * wmip,
+ WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD * cmd);
+
+A_STATUS wmi_get_btcoex_config_cmd(struct wmi_t * wmip, WMI_GET_BTCOEX_CONFIG_CMD * cmd);
+
+A_STATUS wmi_get_btcoex_stats_cmd(struct wmi_t * wmip);
+
+A_STATUS wmi_SGI_cmd(struct wmi_t *wmip, A_UINT32 *sgiMask, A_UINT8 sgiPERThreshold);
+
+/*
+ * This function is used to configure the fix rates mask to the target.
+ */
+A_STATUS wmi_set_fixrates_cmd(struct wmi_t *wmip, A_UINT32 *fixRatesMask);
+A_STATUS wmi_get_ratemask_cmd(struct wmi_t *wmip);
+
+A_STATUS wmi_set_authmode_cmd(struct wmi_t *wmip, A_UINT8 mode);
+
+A_STATUS wmi_set_reassocmode_cmd(struct wmi_t *wmip, A_UINT8 mode);
+
+A_STATUS wmi_set_qos_supp_cmd(struct wmi_t *wmip,A_UINT8 status);
+A_STATUS wmi_set_wmm_cmd(struct wmi_t *wmip, WMI_WMM_STATUS status);
+A_STATUS wmi_set_wmm_txop(struct wmi_t *wmip, WMI_TXOP_CFG txEnable);
+A_STATUS wmi_set_country(struct wmi_t *wmip, A_UCHAR *countryCode);
+
+A_STATUS wmi_get_keepalive_configured(struct wmi_t *wmip);
+A_UINT8 wmi_get_keepalive_cmd(struct wmi_t *wmip);
+A_STATUS wmi_set_keepalive_cmd(struct wmi_t *wmip, A_UINT8 keepaliveInterval);
+
+A_STATUS wmi_set_appie_cmd(struct wmi_t *wmip, A_UINT8 mgmtFrmType,
+ A_UINT8 ieLen,A_UINT8 *ieInfo);
+
+A_STATUS wmi_send_action_frame_cmd(struct wmi_t *wmip, A_UINT16 ieLen,
+ A_UINT8 *ieInfo);
+
+A_STATUS wmi_set_halparam_cmd(struct wmi_t *wmip, A_UINT8 *cmd, A_UINT16 dataLen);
+
+A_INT32 wmi_get_rate(A_INT8 rateindex);
+
+A_STATUS wmi_set_ip_cmd(struct wmi_t *wmip, WMI_SET_IP_CMD *cmd);
+
+/*Wake on Wireless WMI commands*/
+A_STATUS wmi_set_host_sleep_mode_cmd(struct wmi_t *wmip, WMI_SET_HOST_SLEEP_MODE_CMD *cmd);
+A_STATUS wmi_set_wow_mode_cmd(struct wmi_t *wmip, WMI_SET_WOW_MODE_CMD *cmd);
+A_STATUS wmi_get_wow_list_cmd(struct wmi_t *wmip, WMI_GET_WOW_LIST_CMD *cmd);
+A_STATUS wmi_add_wow_pattern_cmd(struct wmi_t *wmip,
+ WMI_ADD_WOW_PATTERN_CMD *cmd, A_UINT8* pattern, A_UINT8* mask, A_UINT8 pattern_size);
+A_STATUS wmi_del_wow_pattern_cmd(struct wmi_t *wmip,
+ WMI_DEL_WOW_PATTERN_CMD *cmd);
+A_STATUS wmi_set_wsc_status_cmd(struct wmi_t *wmip, A_UINT32 status);
+
+A_STATUS
+wmi_set_params_cmd(struct wmi_t *wmip, A_UINT32 opcode, A_UINT32 length, A_CHAR* buffer);
+
+A_STATUS
+wmi_set_mcast_filter_cmd(struct wmi_t *wmip, A_UINT8 *filter);
+
+A_STATUS
+wmi_del_mcast_filter_cmd(struct wmi_t *wmip, A_UINT8 *filter);
+
+A_STATUS
+wmi_mcast_filter_cmd(struct wmi_t *wmip, A_UINT8 enable);
+
+bss_t *
+wmi_find_Ssidnode (struct wmi_t *wmip, A_UCHAR *pSsid,
+ A_UINT32 ssidLength, A_BOOL bIsWPA2, A_BOOL bMatchSSID);
+
+#ifdef ATHR_NWIFI
+void
+wmi_refresh_scan_table (struct wmi_t *wmip, ULONGLONG OldestAllowedEntry);
+#endif
+
+void
+wmi_node_return (struct wmi_t *wmip, bss_t *bss);
+
+void
+wmi_node_update_timestamp(struct wmi_t *wmip, bss_t *bss);
+
+void wmi_setup_node(struct wmi_t *wmip, bss_t *bss, const A_UINT8 *bssid);
+
+bss_t *wmi_node_alloc(struct wmi_t *wmip, A_UINT8 len);
+
+void
+wmi_set_nodeage(struct wmi_t *wmip, A_UINT32 nodeAge);
+
+#if defined(CONFIG_TARGET_PROFILE_SUPPORT)
+A_STATUS wmi_prof_cfg_cmd(struct wmi_t *wmip, A_UINT32 period, A_UINT32 nbins);
+A_STATUS wmi_prof_addr_set_cmd(struct wmi_t *wmip, A_UINT32 addr);
+A_STATUS wmi_prof_start_cmd(struct wmi_t *wmip);
+A_STATUS wmi_prof_stop_cmd(struct wmi_t *wmip);
+A_STATUS wmi_prof_count_get_cmd(struct wmi_t *wmip);
+#endif /* CONFIG_TARGET_PROFILE_SUPPORT */
+#ifdef OS_ROAM_MANAGEMENT
+void wmi_scan_indication (struct wmi_t *wmip);
+#endif
+
+A_STATUS
+wmi_set_target_event_report_cmd(struct wmi_t *wmip, WMI_SET_TARGET_EVENT_REPORT_CMD* cmd);
+
+bss_t *wmi_rm_current_bss (struct wmi_t *wmip, A_UINT8 *id);
+A_STATUS wmi_add_current_bss (struct wmi_t *wmip, A_UINT8 *id, bss_t *bss);
+
+
+/*
+ * AP mode
+ */
+A_STATUS
+wmi_ap_profile_commit(struct wmi_t *wmip, WMI_CONNECT_CMD *p);
+
+A_STATUS
+wmi_ap_set_hidden_ssid(struct wmi_t *wmip, A_UINT8 hidden_ssid);
+
+A_STATUS
+wmi_ap_set_num_sta(struct wmi_t *wmip, A_UINT8 num_sta);
+
+A_STATUS
+wmi_ap_set_dfs(struct wmi_t *wmip, A_UINT8 enable);
+
+A_STATUS
+wmi_ap_set_acl_policy(struct wmi_t *wmip, A_UINT8 policy);
+
+A_STATUS
+wmi_ap_acl_mac_list(struct wmi_t *wmip, WMI_AP_ACL_MAC_CMD *a);
+
+A_UINT8
+acl_add_del_mac(WMI_AP_ACL *a, WMI_AP_ACL_MAC_CMD *acl);
+
+A_STATUS
+wmi_ap_set_mlme(struct wmi_t *wmip, A_UINT8 cmd, A_UINT8 *mac, A_UINT16 reason);
+
+A_STATUS
+wmi_set_pvb_cmd(struct wmi_t *wmip, A_UINT16 aid, A_BOOL flag);
+
+A_STATUS
+wmi_ap_conn_inact_time(struct wmi_t *wmip, A_UINT32 period);
+
+A_STATUS
+wmi_ap_bgscan_time(struct wmi_t *wmip, A_UINT32 period, A_UINT32 dwell);
+
+A_STATUS
+wmi_ap_set_dtim(struct wmi_t *wmip, A_UINT8 dtim);
+
+A_STATUS
+wmi_ap_set_rateset(struct wmi_t *wmip, A_UINT8 rateset);
+
+A_STATUS
+wmi_set_ht_cap_cmd(struct wmi_t *wmip, WMI_SET_HT_CAP_CMD *cmd);
+
+A_STATUS
+wmi_get_ht_cap_cmd(struct wmi_t *wmip, WMI_SET_HT_CAP_CMD *cmd);
+
+A_STATUS
+wmi_set_ht_op_cmd(struct wmi_t *wmip, A_UINT8 sta_chan_width);
+
+A_STATUS
+wmi_send_hci_cmd(struct wmi_t *wmip, A_UINT8 *buf, A_UINT16 sz);
+
+A_STATUS
+wmi_set_tx_select_rates_cmd(struct wmi_t *wmip, A_UINT32 *pMaskArray);
+
+A_STATUS
+wmi_setup_aggr_cmd(struct wmi_t *wmip, A_UINT8 tid);
+
+A_STATUS
+wmi_delete_aggr_cmd(struct wmi_t *wmip, A_UINT8 tid, A_UINT8 uplink);
+
+A_STATUS
+wmi_allow_aggr_cmd(struct wmi_t *wmip, A_UINT16 tx_tidmask, A_UINT16 rx_tidmask);
+
+A_STATUS
+wmi_set_rx_frame_format_cmd(struct wmi_t *wmip, A_UINT8 rxMetaVersion, A_BOOL rxDot11Hdr, A_BOOL defragOnHost);
+
+A_STATUS
+wmi_set_thin_mode_cmd(struct wmi_t *wmip, A_BOOL bThinMode);
+
+A_STATUS
+wmi_set_wlan_conn_precedence_cmd(struct wmi_t *wmip, BT_WLAN_CONN_PRECEDENCE precedence);
+
+A_STATUS
+wmi_set_pmk_cmd(struct wmi_t *wmip, A_UINT8 *pmk);
+
+A_STATUS
+wmi_set_passphrase_cmd(struct wmi_t *wmip, WMI_SET_PASSPHRASE_CMD *cmd);
+
+A_STATUS
+wmi_set_excess_tx_retry_thres_cmd(struct wmi_t *wmip, WMI_SET_EXCESS_TX_RETRY_THRES_CMD *cmd);
+
+A_STATUS
+wmi_assoc_req_enable_cmd(struct wmi_t *wmip, A_UINT8 enable);
+
+A_STATUS
+wmi_assoc_req_report_cmd (struct wmi_t *wmip, A_UINT8 host_accept, A_UINT8 host_reaspncode, A_UINT8 target_status, A_UINT8 *sta_mac_addr, A_UINT8 rspType);
+
+#ifdef P2P
+A_STATUS
+wmi_p2p_discover(struct wmi_t *wmip, WMI_P2P_FIND_CMD *find_param);
+
+A_STATUS
+wmi_p2p_stop_find(struct wmi_t *wmip);
+
+A_STATUS
+wmi_p2p_cancel(struct wmi_t *wmip);
+
+A_STATUS
+wmi_p2p_listen(struct wmi_t *wmip, A_UINT32 timeout);
+
+A_STATUS
+wmi_p2p_go_neg_start(struct wmi_t *wmip, WMI_P2P_GO_NEG_START_CMD *go_param);
+
+A_STATUS wmi_p2p_sdpd_tx_cmd(struct wmi_t *wmip, WMI_P2P_SDPD_TX_CMD *buf);
+
+A_STATUS wmi_p2p_stop_sdpd(struct wmi_t *wmip);
+
+A_STATUS wmi_p2p_go_neg_rsp_cmd(struct wmi_t *wmip, A_UINT8 status,
+ A_UINT8 go_intent, A_UINT32 wps_method, A_UINT16 listen_freq,
+ A_UINT8 *wpsbuf, A_UINT32 wpslen, A_UINT8 *p2pbuf, A_UINT32 p2plen,
+ A_UINT8 dialog_token, A_UINT8 persistent_grp, A_UINT8 *sa);
+
+A_STATUS
+wmi_p2p_set_config(struct wmi_t *wmip, WMI_P2P_SET_CONFIG_CMD *config);
+
+A_STATUS
+wmi_wps_set_config(struct wmi_t *wmip, WMI_WPS_SET_CONFIG_CMD *wps_config);
+
+A_STATUS wmi_p2p_grp_init_cmd(struct wmi_t *wmip, WMI_P2P_GRP_INIT_CMD *buf);
+
+A_STATUS wmi_p2p_grp_done_cmd(struct wmi_t *wmip,
+ WMI_P2P_GRP_FORMATION_DONE_CMD *buf);
+
+A_STATUS wmi_p2p_invite_cmd(struct wmi_t *wmip, WMI_P2P_INVITE_CMD *buf);
+
+A_STATUS wmi_p2p_invite_req_rsp_cmd(struct wmi_t *wmip, A_UINT8 status,
+ A_INT8 is_go, A_UINT8 *grp_bssid, A_UINT8 *p2pbuf,
+ A_UINT8 p2plen, A_UINT8 dialog_token);
+
+A_STATUS wmi_p2p_prov_disc_cmd(struct wmi_t *wmip,
+ WMI_P2P_PROV_DISC_REQ_CMD *buf);
+
+A_STATUS wmi_p2p_set_cmd(struct wmi_t *wmip, WMI_P2P_SET_CMD *buf);
+
+#endif /* P2P */
+
+A_UINT16
+wmi_ieee2freq (int chan);
+
+A_UINT32
+wmi_freq2ieee (A_UINT16 freq);
+
+bss_t *
+wmi_find_matching_Ssidnode (struct wmi_t *wmip, A_UCHAR *pSsid,
+ A_UINT32 ssidLength,
+ A_UINT32 dot11AuthMode, A_UINT32 authMode,
+ A_UINT32 pairwiseCryptoType, A_UINT32 grpwiseCryptoTyp);
+
+A_STATUS
+wmi_radarDetected_cmd(struct wmi_t *wmip, A_INT16 chan_index, A_INT8 bang_radar);
+
+A_STATUS
+wmi_set_dfs_maxpulsedur_cmd(struct wmi_t *wmip, A_UINT32 value);
+
+A_STATUS
+wmi_set_dfs_minrssithresh_cmd(struct wmi_t *wmip, A_INT32 rssi);
+
+A_STATUS
+wmi_beacon2bssnode (struct wmi_t *wmip, A_UINT8 *datap, int len, A_UINT8 *bssid, A_UINT16 channel);
+
+A_STATUS
+wmi_set_tx_mac_rules_cmd (struct wmi_t *wmip, A_UINT32 rules);
+
+A_STATUS
+wmi_set_promiscuous_mode_cmd (struct wmi_t *wmip, A_BOOL bMode);
+
+//WAC
+A_STATUS wmi_wac_enable_cmd(struct wmi_t *wmip, WMI_WAC_ENABLE_CMD *param);
+
+A_STATUS
+wmi_wac_scan_reply_cmd(struct wmi_t *wmip, WAC_SUBCMD param);
+
+A_STATUS
+wmi_wac_ctrl_req_cmd(struct wmi_t *wmip, WMI_WAC_CTRL_REQ_CMD *param);
+
+#ifdef CONFIG_WLAN_RFKILL
+A_STATUS
+wmi_get_rfkill_mode_cmd(struct wmi_t *wmip);
+
+A_STATUS
+wmi_set_rfkill_mode_cmd(struct wmi_t *wmip,WMI_RFKILL_MODE_CMD *pCmd);
+
+#endif
+
+A_STATUS
+wmi_force_target_assert(struct wmi_t *wmip);
+
+A_STATUS
+wmi_ap_set_apsd(struct wmi_t *wmip, A_UINT8 enable);
+
+A_STATUS
+wmi_set_apsd_buffered_traffic_cmd(struct wmi_t *wmip, A_UINT16 aid, A_UINT16 bitmap, A_UINT32 flags);
+
+A_STATUS
+wmi_sta_bmiss_enhance_cmd(struct wmi_t *wmip, A_UINT8 enable);
+
+A_STATUS
+wmi_ap_set_idle_close_time(struct wmi_t *wmip, A_UINT32 time_val_sec);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WMI_API_H_ */
diff --git a/host/include/wmi_host.h b/host/include/wmi_host.h
new file mode 100644
index 0000000..06d8e4d
--- /dev/null
+++ b/host/include/wmi_host.h
@@ -0,0 +1,111 @@
+//------------------------------------------------------------------------------
+// <copyright file="wmi_host.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains local definitios for the wmi host module.
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _WMI_HOST_H_
+#define _WMI_HOST_H_
+
+#include "roaming.h"
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+struct wmi_stats {
+ A_UINT32 cmd_len_err;
+ A_UINT32 cmd_id_err;
+};
+
+#define LE_READ_4(p) \
+ ((A_UINT32) \
+ ((((A_UINT8 *)(p))[0] ) | (((A_UINT8 *)(p))[1] << 8) | \
+ (((A_UINT8 *)(p))[2] << 16) | (((A_UINT8 *)(p))[3] << 24)))
+
+
+#define SSID_IE_LEN_INDEX 13
+
+
+/* Host side link management data structures */
+#define SIGNAL_QUALITY_THRESHOLD_LEVELS 6
+#define SIGNAL_QUALITY_UPPER_THRESHOLD_LEVELS SIGNAL_QUALITY_THRESHOLD_LEVELS
+#define SIGNAL_QUALITY_LOWER_THRESHOLD_LEVELS SIGNAL_QUALITY_THRESHOLD_LEVELS
+typedef struct sq_threshold_params_s {
+ A_INT16 upper_threshold[SIGNAL_QUALITY_UPPER_THRESHOLD_LEVELS];
+ A_INT16 lower_threshold[SIGNAL_QUALITY_LOWER_THRESHOLD_LEVELS];
+ A_UINT32 upper_threshold_valid_count;
+ A_UINT32 lower_threshold_valid_count;
+ A_UINT32 polling_interval;
+ A_UINT8 weight;
+ A_UINT8 last_rssi; //normally you would expect this to be bss specific but we keep only one instance because its only valid when the device is in a connected state. Not sure if it belongs to host or target.
+ A_UINT8 last_rssi_poll_event; //Not sure if it belongs to host or target
+} SQ_THRESHOLD_PARAMS;
+
+/*
+ * Virtual device specific wmi_t data structure
+ */
+
+struct wmi_t {
+ void *wmi_devt;
+ struct ieee80211_node_table wmi_scan_table;
+ A_UINT8 wmi_bssid[ATH_MAC_LEN];
+ A_UINT8 wmi_powerMode;
+ A_UINT8 wmi_phyMode;
+ A_UINT8 wmi_keepaliveInterval;
+ SQ_THRESHOLD_PARAMS wmi_SqThresholdParams[SIGNAL_QUALITY_METRICS_NUM_MAX];
+ CRYPTO_TYPE wmi_pair_crypto_type;
+ CRYPTO_TYPE wmi_grp_crypto_type;
+ WMI_SET_HT_CAP_CMD wmi_ht_cap[A_NUM_BANDS];
+ A_BOOL wmi_is_wmm_enabled;
+ A_UINT8 wmi_dev_index;
+ struct wmi_stats wmi_stats;
+ A_UINT8 wmi_user_phy;
+ A_UINT8 wmi_user_ht[A_NUM_BANDS];
+ void (* host_sleep_mode_event_fn)(void *);
+ void *host_sleep_mode_event_fn_arg;
+};
+
+/*
+ * Virtual device independent wmi data structure
+ */
+
+struct wmi_priv_t {
+ A_BOOL wmi_ready;
+ A_BOOL wmi_numQoSStream;
+ A_UINT8 wmi_fatPipeExists;
+ A_UINT16 wmi_streamExistsForAC[WMM_NUM_AC];
+ HTC_ENDPOINT_ID wmi_endpoint_id;
+ A_MUTEX_T wmi_lock;
+};
+#define LOCK_WMI(w) A_MUTEX_LOCK(&(w)->wmi_lock);
+#define UNLOCK_WMI(w) A_MUTEX_UNLOCK(&(w)->wmi_lock);
+
+int
+iswmmoui(const A_UINT8 *frm);
+
+int
+iswmmparam(const A_UINT8 *frm);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WMI_HOST_H_ */
diff --git a/host/include/wmi_parser.h b/host/include/wmi_parser.h
new file mode 100644
index 0000000..da78b28
--- /dev/null
+++ b/host/include/wmi_parser.h
@@ -0,0 +1,39 @@
+//------------------------------------------------------------------------------
+// <copyright file="wmi_parser.h" company="Atheros">
+// Copyright (c) 2011 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//
+// <summary>
+// WMI Command/Event Parser
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifndef _WMI_PARSER_
+#define _WMI_PARSER_
+
+void wmi_cmd_decode(WMI_COMMAND_ID cmdId);
+
+#endif
+
+
+
+
diff --git a/host/include/wmi_thin.h b/host/include/wmi_thin.h
new file mode 100644
index 0000000..2495e08
--- /dev/null
+++ b/host/include/wmi_thin.h
@@ -0,0 +1,371 @@
+//------------------------------------------------------------------------------
+// <copyright file="wmi_thin.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+/*
+ * This file contains the definitions of the WMI protocol specified in the
+ * Wireless Module Interface (WMI). It includes definitions of all the
+ * commands and events. Commands are messages from the host to the WM.
+ * Events and Replies are messages from the WM to the host.
+ *
+ * Ownership of correctness in regards to WMI commands
+ * belongs to the host driver and the WM is not required to validate
+ * parameters for value, proper range, or any other checking.
+ *
+ */
+
+#ifndef _WMI_THIN_H_
+#define _WMI_THIN_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+typedef enum {
+ WMI_THIN_CONFIG_CMDID = 0x8000, // WMI_THIN_RESERVED_START
+ WMI_THIN_SET_MIB_CMDID,
+ WMI_THIN_GET_MIB_CMDID,
+ WMI_THIN_JOIN_CMDID,
+ WMI_THIN_CONNECT_CMDID,
+ WMI_THIN_RESET_CMDID,
+ /* add new CMDID's here */
+ WMI_THIN_RESERVED_END_CMDID = 0x8fff // WMI_THIN_RESERVED_END
+} WMI_THIN_COMMAND_ID;
+
+typedef enum{
+ TEMPLATE_FRM_FIRST = 0,
+ TEMPLATE_FRM_PROBE_REQ =TEMPLATE_FRM_FIRST,
+ TEMPLATE_FRM_BEACON,
+ TEMPLATE_FRM_PROBE_RESP,
+ TEMPLATE_FRM_NULL,
+ TEMPLATE_FRM_QOS_NULL,
+ TEMPLATE_FRM_PSPOLL,
+ TEMPLATE_FRM_MAX
+}WMI_TEMPLATE_FRM_TYPE;
+
+/* TEMPLATE_FRM_LEN... represent the maximum allowable
+ * data lengths (bytes) for each frame type */
+#define TEMPLATE_FRM_LEN_PROBE_REQ (256) /* Symbian dictates a minimum of 256 for these 3 frame types */
+#define TEMPLATE_FRM_LEN_BEACON (256)
+#define TEMPLATE_FRM_LEN_PROBE_RESP (256)
+#define TEMPLATE_FRM_LEN_NULL (32)
+#define TEMPLATE_FRM_LEN_QOS_NULL (32)
+#define TEMPLATE_FRM_LEN_PSPOLL (32)
+#define TEMPLATE_FRM_LEN_SUM (TEMPLATE_FRM_LEN_PROBE_REQ + TEMPLATE_FRM_LEN_BEACON + TEMPLATE_FRM_LEN_PROBE_RESP + \
+ TEMPLATE_FRM_LEN_NULL + TEMPLATE_FRM_LEN_QOS_NULL + TEMPLATE_FRM_LEN_PSPOLL)
+
+
+/* MAC Header Build Rules */
+/* These values allow the host to configure the
+ * target code that is responsible for constructing
+ * the MAC header. In cases where the MAC header
+ * is provided by the host framework, the target
+ * has a diminished responsibility over what fields
+ * it must write. This will vary from framework to framework.
+ * Symbian requires different behavior from MAC80211 which
+ * requires different behavior from MS Native Wifi. */
+#define WMI_WRT_VER_TYPE 0x00000001
+#define WMI_WRT_DURATION 0x00000002
+#define WMI_WRT_DIRECTION 0x00000004
+#define WMI_WRT_POWER 0x00000008
+#define WMI_WRT_WEP 0x00000010
+#define WMI_WRT_MORE 0x00000020
+#define WMI_WRT_BSSID 0x00000040
+#define WMI_WRT_QOS 0x00000080
+#define WMI_WRT_SEQNO 0x00000100
+#define WMI_GUARD_TX 0x00000200 /* prevents TX ops that are not allowed for a current state */
+#define WMI_WRT_DEFAULT_CONFIG (WMI_WRT_VER_TYPE | WMI_WRT_DURATION | WMI_WRT_DIRECTION | \
+ WMI_WRT_POWER | WMI_WRT_MORE | WMI_WRT_WEP | WMI_WRT_BSSID | \
+ WMI_WRT_QOS | WMI_WRT_SEQNO | WMI_GUARD_TX)
+
+/* WMI_THIN_CONFIG_TXCOMPLETE -- Used to configure the params and content for
+ * TX Complete messages the will come from the Target. these messages are
+ * disabled by default but can be enabled using this structure and the
+ * WMI_THIN_CONFIG_CMDID. */
+typedef PREPACK struct {
+ A_UINT8 version; /* the versioned type of messages to use or 0 to disable */
+ A_UINT8 countThreshold; /* msg count threshold triggering a tx complete message */
+ A_UINT16 timeThreshold; /* timeout interval in MSEC triggering a tx complete message */
+} POSTPACK WMI_THIN_CONFIG_TXCOMPLETE;
+
+/* WMI_THIN_CONFIG_DECRYPT_ERR -- Used to configure behavior for received frames
+ * that have decryption errors. The default behavior is to discard the frame
+ * without notification. Alternately, the MAC Header is forwarded to the host
+ * with the failed status. */
+typedef PREPACK struct {
+ A_UINT8 enable; /* 1 == send decrypt errors to the host, 0 == don't */
+ A_UINT8 reserved[3]; /* align padding */
+} POSTPACK WMI_THIN_CONFIG_DECRYPT_ERR;
+
+/* WMI_THIN_CONFIG_TX_MAC_RULES -- Used to configure behavior for transmitted
+ * frames that require partial MAC header construction. These rules
+ * are used by the target to indicate which fields need to be written. */
+typedef PREPACK struct {
+ A_UINT32 rules; /* combination of WMI_WRT_... values */
+} POSTPACK WMI_THIN_CONFIG_TX_MAC_RULES;
+
+/* WMI_THIN_CONFIG_RX_FILTER_RULES -- Used to configure behavior for received
+ * frames as to which frames should get forwarded to the host and which
+ * should get processed internally. */
+typedef PREPACK struct {
+ A_UINT32 rules; /* combination of WMI_FILT_... values */
+} POSTPACK WMI_THIN_CONFIG_RX_FILTER_RULES;
+
+
+/* WMI_THIN_CONFIG_CIPHER_ENCAP -- Used to configure behavior for both
+ * TX and RX frames regarding security cipher encapsulation. The host may specify
+ * whether or not the firmware is responsible for cipher
+ * encapsulation. If the firmware is responsible it will add the security header
+ * and trailer for TX frames and remove the header and trailer for Rx frames. Also,
+ * the firmware will examine the resource counter if any and behave appropriately when
+ * a bad value is detected. If the host indicates responsibility for encapsulation
+ * then it is responsible for all aspects of encapsulation, however the device will
+ * still perform the encryption and decryption of the frame payload if a key has
+ * been provided. */
+typedef PREPACK struct {
+ A_UINT8 enable; /* enables/disables firmware cipher encapsulation */
+ A_UINT8 reserved[3]; /* align padding */
+} POSTPACK WMI_THIN_CONFIG_CIPHER_ENCAP;
+
+/* WMI_THIN_CONFIG_CMD -- Used to contain some combination of the above
+ * WMI_THIN_CONFIG_... structures. The actual combination is indicated
+ * by the value of cfgField. Each bit in this field corresponds to
+ * one of the above structures. */
+typedef PREPACK struct {
+#define WMI_THIN_CFG_TXCOMP 0x00000001
+#define WMI_THIN_CFG_DECRYPT 0x00000002
+#define WMI_THIN_UNUSED1 0x00000004 /* used to be WMI_THIN_CFG_MAC_RULES */
+#define WMI_THIN_CFG_FILTER_RULES 0x00000008
+#define WMI_THIN_CFG_CIPHER_ENCAP 0x00000010
+ A_UINT32 cfgField; /* combination of WMI_THIN_CFG_... describes contents of config command */
+ A_UINT16 length; /* length in bytes of appended sub-commands */
+ A_UINT8 reserved[2]; /* align padding */
+} POSTPACK WMI_THIN_CONFIG_CMD;
+
+/* MIB Access Identifiers tailored for Symbian. */
+enum {
+ MIB_ID_STA_MAC = 1, // [READONLY]
+ MIB_ID_RX_LIFE_TIME, // [NOT IMPLEMENTED]
+ MIB_ID_SLOT_TIME, // [READ/WRITE]
+ MIB_ID_RTS_THRESHOLD, // [READ/WRITE]
+ MIB_ID_CTS_TO_SELF, // [READ/WRITE]
+ MIB_ID_TEMPLATE_FRAME, // [WRITE ONLY]
+ MIB_ID_RXFRAME_FILTER, // [READ/WRITE]
+ MIB_ID_BEACON_FILTER_TABLE, // [WRITE ONLY]
+ MIB_ID_BEACON_FILTER, // [READ/WRITE]
+ MIB_ID_BEACON_LOST_COUNT, // [WRITE ONLY]
+ MIB_ID_RSSI_THRESHOLD, // [WRITE ONLY]
+ MIB_ID_HT_CAP, // [NOT IMPLEMENTED]
+ MIB_ID_HT_OP, // [NOT IMPLEMENTED]
+ MIB_ID_HT_2ND_BEACON, // [NOT IMPLEMENTED]
+ MIB_ID_HT_BLOCK_ACK, // [NOT IMPLEMENTED]
+ MIB_ID_PREAMBLE, // [READ/WRITE]
+ /*MIB_ID_GROUP_ADDR_TABLE,*/
+ /*MIB_ID_WEP_DEFAULT_KEY_ID */ // satisfied by wmi_addKey_cmd()
+ /*MIB_ID_TX_POWER */
+ /*MIB_ID_ARP_IP_TABLE */
+ /*MIB_ID_SLEEP_MODE */
+ /*MIB_ID_WAKE_INTERVAL*/
+ /*MIB_ID_STAT_TABLE*/
+ /*MIB_ID_IBSS_PWR_SAVE*/
+ /*MIB_ID_COUNTERS_TABLE*/
+ /*MIB_ID_ETHERTYPE_FILTER*/
+ /*MIB_ID_BC_UDP_FILTER*/
+
+};
+
+typedef PREPACK struct {
+ A_UINT8 addr[ATH_MAC_LEN];
+} POSTPACK WMI_THIN_MIB_STA_MAC;
+
+typedef PREPACK struct {
+ A_UINT32 time; // units == msec
+} POSTPACK WMI_THIN_MIB_RX_LIFE_TIME;
+
+typedef PREPACK struct {
+ A_UINT8 enable; //1 = on, 0 = off
+} POSTPACK WMI_THIN_MIB_CTS_TO_SELF;
+
+typedef PREPACK struct {
+ A_UINT32 time; // units == usec
+} POSTPACK WMI_THIN_MIB_SLOT_TIME;
+
+typedef PREPACK struct {
+ A_UINT16 length; //units == bytes
+} POSTPACK WMI_THIN_MIB_RTS_THRESHOLD;
+
+typedef PREPACK struct {
+ A_UINT8 type; // type of frame
+ A_UINT8 rate; // tx rate to be used (one of WMI_BIT_RATE)
+ A_UINT16 length; // num bytes following this structure as the template data
+} POSTPACK WMI_THIN_MIB_TEMPLATE_FRAME;
+
+typedef PREPACK struct {
+#define FRAME_FILTER_PROMISCUOUS 0x00000001
+#define FRAME_FILTER_BSSID 0x00000002
+ A_UINT32 filterMask;
+} POSTPACK WMI_THIN_MIB_RXFRAME_FILTER;
+
+
+#define IE_FILTER_TREATMENT_CHANGE 1
+#define IE_FILTER_TREATMENT_APPEAR 2
+
+typedef PREPACK struct {
+ A_UINT8 ie;
+ A_UINT8 treatment;
+} POSTPACK WMI_THIN_MIB_BEACON_FILTER_TABLE;
+
+typedef PREPACK struct {
+ A_UINT8 ie;
+ A_UINT8 treatment;
+ A_UINT8 oui[3];
+ A_UINT8 type;
+ A_UINT16 version;
+} POSTPACK WMI_THIN_MIB_BEACON_FILTER_TABLE_OUI;
+
+typedef PREPACK struct {
+ A_UINT16 numElements;
+ A_UINT8 entrySize; // sizeof(WMI_THIN_MIB_BEACON_FILTER_TABLE) on host cpu may be 2 may be 4
+ A_UINT8 reserved;
+} POSTPACK WMI_THIN_MIB_BEACON_FILTER_TABLE_HEADER;
+
+typedef PREPACK struct {
+ A_UINT32 count; /* num beacons between deliveries */
+ A_UINT8 enable;
+ A_UINT8 reserved[3];
+} POSTPACK WMI_THIN_MIB_BEACON_FILTER;
+
+typedef PREPACK struct {
+ A_UINT32 count; /* num consec lost beacons after which send event */
+} POSTPACK WMI_THIN_MIB_BEACON_LOST_COUNT;
+
+typedef PREPACK struct {
+ A_UINT8 rssi; /* the low threshold which can trigger an event warning */
+ A_UINT8 tolerance; /* the range above and below the threshold to prevent event flooding to the host. */
+ A_UINT8 count; /* the sample count of consecutive frames necessary to trigger an event. */
+ A_UINT8 reserved[1]; /* padding */
+} POSTPACK WMI_THIN_MIB_RSSI_THRESHOLD;
+
+
+typedef PREPACK struct {
+ A_UINT32 cap;
+ A_UINT32 rxRateField;
+ A_UINT32 beamForming;
+ A_UINT8 addr[ATH_MAC_LEN];
+ A_UINT8 enable;
+ A_UINT8 stbc;
+ A_UINT8 maxAMPDU;
+ A_UINT8 msduSpacing;
+ A_UINT8 mcsFeedback;
+ A_UINT8 antennaSelCap;
+} POSTPACK WMI_THIN_MIB_HT_CAP;
+
+typedef PREPACK struct {
+ A_UINT32 infoField;
+ A_UINT32 basicRateField;
+ A_UINT8 protection;
+ A_UINT8 secondChanneloffset;
+ A_UINT8 channelWidth;
+ A_UINT8 reserved;
+} POSTPACK WMI_THIN_MIB_HT_OP;
+
+typedef PREPACK struct {
+#define SECOND_BEACON_PRIMARY 1
+#define SECOND_BEACON_EITHER 2
+#define SECOND_BEACON_SECONDARY 3
+ A_UINT8 cfg;
+ A_UINT8 reserved[3]; /* padding */
+} POSTPACK WMI_THIN_MIB_HT_2ND_BEACON;
+
+typedef PREPACK struct {
+ A_UINT8 txTIDField;
+ A_UINT8 rxTIDField;
+ A_UINT8 reserved[2]; /* padding */
+} POSTPACK WMI_THIN_MIB_HT_BLOCK_ACK;
+
+typedef PREPACK struct {
+ A_UINT8 enableLong; // 1 == long preamble, 0 == short preamble
+ A_UINT8 reserved[3];
+} POSTPACK WMI_THIN_MIB_PREAMBLE;
+
+typedef PREPACK struct {
+ A_UINT16 length; /* the length in bytes of the appended MIB data */
+ A_UINT8 mibID; /* the ID of the MIB element being set */
+ A_UINT8 reserved; /* align padding */
+} POSTPACK WMI_THIN_SET_MIB_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 mibID; /* the ID of the MIB element being set */
+ A_UINT8 reserved[3]; /* align padding */
+} POSTPACK WMI_THIN_GET_MIB_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 basicRateMask; /* bit mask of basic rates */
+ A_UINT32 beaconIntval; /* TUs */
+ A_UINT16 atimWindow; /* TUs */
+ A_UINT16 channel; /* frequency in Mhz */
+ A_UINT8 networkType; /* INFRA_NETWORK | ADHOC_NETWORK */
+ A_UINT8 ssidLength; /* 0 - 32 */
+ A_UINT8 probe; /* != 0 : issue probe req at start */
+ A_UINT8 reserved; /* alignment */
+ A_UCHAR ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 bssid[ATH_MAC_LEN];
+} POSTPACK WMI_THIN_JOIN_CMD;
+
+typedef PREPACK struct {
+ A_UINT16 dtim; /* dtim interval in num beacons */
+ A_UINT16 aid; /* 80211 association ID from Assoc resp */
+} POSTPACK WMI_THIN_CONNECT_CMD;
+
+typedef PREPACK struct {
+ A_UINT8 reserved[4];
+} POSTPACK WMI_THIN_RESET_CMD;
+
+typedef enum {
+ WMI_THIN_EVENTID_RESERVED_START = 0x8000,
+ WMI_THIN_GET_MIB_EVENTID,
+ WMI_THIN_JOIN_EVENTID,
+
+ /* Add new THIN EVENTID's here */
+ WMI_THIN_EVENTID_RESERVED_END = 0x8fff
+} WMI_THIN_EVENT_ID;
+
+/* Possible values for WMI_THIN_JOIN_EVENT.result */
+typedef enum {
+ WMI_THIN_JOIN_RES_SUCCESS = 0, // device has joined the network
+ WMI_THIN_JOIN_RES_FAIL, // device failed for unspecified reason
+ WMI_THIN_JOIN_RES_TIMEOUT, // device failed due to no beacon rx in time limit
+ WMI_THIN_JOIN_RES_BAD_PARAM, // device failed due to bad cmd param.
+ WMI_THIN_JOIN_RES_IBSS_START, // device started new IBSS network.
+}WMI_THIN_JOIN_RESULT;
+
+typedef PREPACK struct {
+ A_UINT8 result; /* the result of the join cmd. one of WMI_THIN_JOIN_RESULT */
+ A_UINT8 reserved[3]; /* alignment */
+} POSTPACK WMI_THIN_JOIN_EVENT;
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WMI_THIN_H_ */
diff --git a/host/include/wmix.h b/host/include/wmix.h
new file mode 100644
index 0000000..50ccd55
--- /dev/null
+++ b/host/include/wmix.h
@@ -0,0 +1,280 @@
+//------------------------------------------------------------------------------
+// <copyright file="wmix.h" company="Atheros">
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// Wifi driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+
+/*
+ * This file contains extensions of the WMI protocol specified in the
+ * Wireless Module Interface (WMI). It includes definitions of all
+ * extended commands and events. Extensions include useful commands
+ * that are not directly related to wireless activities. They may
+ * be hardware-specific, and they might not be supported on all
+ * implementations.
+ *
+ * Extended WMIX commands are encapsulated in a WMI message with
+ * cmd=WMI_EXTENSION_CMD.
+ */
+
+#ifndef _WMIX_H_
+#define _WMIX_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#ifndef ATH_TARGET
+#include "athstartpack.h"
+#endif
+
+#include "dbglog.h"
+
+/*
+ * Extended WMI commands are those that are needed during wireless
+ * operation, but which are not really wireless commands. This allows,
+ * for instance, platform-specific commands. Extended WMI commands are
+ * embedded in a WMI command message with WMI_COMMAND_ID=WMI_EXTENSION_CMDID.
+ * Extended WMI events are similarly embedded in a WMI event message with
+ * WMI_EVENT_ID=WMI_EXTENSION_EVENTID.
+ */
+typedef PREPACK struct {
+ A_UINT32 commandId;
+} POSTPACK WMIX_CMD_HDR;
+
+typedef enum {
+ WMIX_DSETOPEN_REPLY_CMDID = 0x2001,
+ WMIX_DSETDATA_REPLY_CMDID,
+ WMIX_GPIO_OUTPUT_SET_CMDID,
+ WMIX_GPIO_INPUT_GET_CMDID,
+ WMIX_GPIO_REGISTER_SET_CMDID,
+ WMIX_GPIO_REGISTER_GET_CMDID,
+ WMIX_GPIO_INTR_ACK_CMDID,
+ WMIX_HB_CHALLENGE_RESP_CMDID,
+ WMIX_DBGLOG_CFG_MODULE_CMDID,
+ WMIX_PROF_CFG_CMDID, /* 0x200a */
+ WMIX_PROF_ADDR_SET_CMDID,
+ WMIX_PROF_START_CMDID,
+ WMIX_PROF_STOP_CMDID,
+ WMIX_PROF_COUNT_GET_CMDID,
+} WMIX_COMMAND_ID;
+
+typedef enum {
+ WMIX_DSETOPENREQ_EVENTID = 0x3001,
+ WMIX_DSETCLOSE_EVENTID,
+ WMIX_DSETDATAREQ_EVENTID,
+ WMIX_GPIO_INTR_EVENTID,
+ WMIX_GPIO_DATA_EVENTID,
+ WMIX_GPIO_ACK_EVENTID,
+ WMIX_HB_CHALLENGE_RESP_EVENTID,
+ WMIX_DBGLOG_EVENTID,
+ WMIX_PROF_COUNT_EVENTID,
+} WMIX_EVENT_ID;
+
+/*
+ * =============DataSet support=================
+ */
+
+/*
+ * WMIX_DSETOPENREQ_EVENTID
+ * DataSet Open Request Event
+ */
+typedef PREPACK struct {
+ A_UINT32 dset_id;
+ A_UINT32 targ_dset_handle; /* echo'ed, not used by Host, */
+ A_UINT32 targ_reply_fn; /* echo'ed, not used by Host, */
+ A_UINT32 targ_reply_arg; /* echo'ed, not used by Host, */
+} POSTPACK WMIX_DSETOPENREQ_EVENT;
+
+/*
+ * WMIX_DSETCLOSE_EVENTID
+ * DataSet Close Event
+ */
+typedef PREPACK struct {
+ A_UINT32 access_cookie;
+} POSTPACK WMIX_DSETCLOSE_EVENT;
+
+/*
+ * WMIX_DSETDATAREQ_EVENTID
+ * DataSet Data Request Event
+ */
+typedef PREPACK struct {
+ A_UINT32 access_cookie;
+ A_UINT32 offset;
+ A_UINT32 length;
+ A_UINT32 targ_buf; /* echo'ed, not used by Host, */
+ A_UINT32 targ_reply_fn; /* echo'ed, not used by Host, */
+ A_UINT32 targ_reply_arg; /* echo'ed, not used by Host, */
+} POSTPACK WMIX_DSETDATAREQ_EVENT;
+
+typedef PREPACK struct {
+ A_UINT32 status;
+ A_UINT32 targ_dset_handle;
+ A_UINT32 targ_reply_fn;
+ A_UINT32 targ_reply_arg;
+ A_UINT32 access_cookie;
+ A_UINT32 size;
+ A_UINT32 version;
+} POSTPACK WMIX_DSETOPEN_REPLY_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 status;
+ A_UINT32 targ_buf;
+ A_UINT32 targ_reply_fn;
+ A_UINT32 targ_reply_arg;
+ A_UINT32 length;
+ A_UINT8 buf[1];
+} POSTPACK WMIX_DSETDATA_REPLY_CMD;
+
+
+/*
+ * =============GPIO support=================
+ * NB: Some of the WMIX APIs use a 32-bit mask. On Targets that support
+ * more than 32 GPIO pins, those APIs only support the first 32 GPIO pins.
+ */
+
+#include "gpio.h"
+
+/*
+ * Set GPIO pin output state.
+ * In order for output to be driven, a pin must be enabled for output.
+ * This can be done during initialization through the GPIO Configuration
+ * DataSet, or during operation with the enable_mask.
+ *
+ * If a request is made to simultaneously set/clear or set/disable or
+ * clear/disable or disable/enable, results are undefined.
+ */
+typedef PREPACK struct {
+ A_UINT32 set_mask; /* pins to set */
+ A_UINT32 clear_mask; /* pins to clear */
+ A_UINT32 enable_mask; /* pins to enable for output */
+ A_UINT32 disable_mask; /* pins to disable/tristate */
+} POSTPACK WMIX_GPIO_OUTPUT_SET_CMD;
+
+/*
+ * Set a GPIO register. For debug/exceptional cases.
+ * Values for gpioreg_id are GPIO_ID_*, defined in a
+ * platform-dependent header, gpio.h.
+ */
+typedef PREPACK struct {
+ A_UINT32 gpioreg_id; /* GPIO register ID */
+ A_UINT32 value; /* value to write */
+} POSTPACK WMIX_GPIO_REGISTER_SET_CMD;
+
+/* Get a GPIO register. For debug/exceptional cases. */
+typedef PREPACK struct {
+ A_UINT32 gpioreg_id; /* GPIO register to read */
+} POSTPACK WMIX_GPIO_REGISTER_GET_CMD;
+
+/*
+ * Host acknowledges and re-arms GPIO interrupts. A single
+ * message should be used to acknowledge all interrupts that
+ * were delivered in an earlier WMIX_GPIO_INTR_EVENT message.
+ */
+typedef PREPACK struct {
+ A_UINT32 ack_mask; /* interrupts to acknowledge */
+} POSTPACK WMIX_GPIO_INTR_ACK_CMD;
+
+/*
+ * Target informs Host of GPIO interrupts that have ocurred since the
+ * last WMIX_GIPO_INTR_ACK_CMD was received. Additional information --
+ * the current GPIO input values is provided -- in order to support
+ * use of a GPIO interrupt as a Data Valid signal for other GPIO pins.
+ */
+typedef PREPACK struct {
+ A_UINT32 intr_mask; /* pending GPIO interrupts */
+ A_UINT32 input_values; /* recent GPIO input values */
+} POSTPACK WMIX_GPIO_INTR_EVENT;
+
+/*
+ * Target responds to Host's earlier WMIX_GPIO_INPUT_GET_CMDID request
+ * using a GPIO_DATA_EVENT with
+ * value set to the mask of GPIO pin inputs and
+ * reg_id set to GPIO_ID_NONE
+ *
+ *
+ * Target responds to Hosts's earlier WMIX_GPIO_REGISTER_GET_CMDID request
+ * using a GPIO_DATA_EVENT with
+ * value set to the value of the requested register and
+ * reg_id identifying the register (reflects the original request)
+ * NB: reg_id supports the future possibility of unsolicited
+ * WMIX_GPIO_DATA_EVENTs (for polling GPIO input), and it may
+ * simplify Host GPIO support.
+ */
+typedef PREPACK struct {
+ A_UINT32 value;
+ A_UINT32 reg_id;
+} POSTPACK WMIX_GPIO_DATA_EVENT;
+
+/*
+ * =============Error Detection support=================
+ */
+
+/*
+ * WMIX_HB_CHALLENGE_RESP_CMDID
+ * Heartbeat Challenge Response command
+ */
+typedef PREPACK struct {
+ A_UINT32 cookie;
+ A_UINT32 source;
+} POSTPACK WMIX_HB_CHALLENGE_RESP_CMD;
+
+/*
+ * WMIX_HB_CHALLENGE_RESP_EVENTID
+ * Heartbeat Challenge Response Event
+ */
+#define WMIX_HB_CHALLENGE_RESP_EVENT WMIX_HB_CHALLENGE_RESP_CMD
+
+typedef PREPACK struct {
+ struct dbglog_config_s config;
+} POSTPACK WMIX_DBGLOG_CFG_MODULE_CMD;
+
+/*
+ * =============Target Profiling support=================
+ */
+
+typedef PREPACK struct {
+ A_UINT32 period; /* Time (in 30.5us ticks) between samples */
+ A_UINT32 nbins;
+} POSTPACK WMIX_PROF_CFG_CMD;
+
+typedef PREPACK struct {
+ A_UINT32 addr;
+} POSTPACK WMIX_PROF_ADDR_SET_CMD;
+
+/*
+ * Target responds to Hosts's earlier WMIX_PROF_COUNT_GET_CMDID request
+ * using a WMIX_PROF_COUNT_EVENT with
+ * addr set to the next address
+ * count set to the corresponding count
+ */
+typedef PREPACK struct {
+ A_UINT32 addr;
+ A_UINT32 count;
+} POSTPACK WMIX_PROF_COUNT_EVENT;
+
+#ifndef ATH_TARGET
+#include "athendpack.h"
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _WMIX_H_ */
diff --git a/host/os/linux/Makefile b/host/os/linux/Makefile
new file mode 100644
index 0000000..66728d4
--- /dev/null
+++ b/host/os/linux/Makefile
@@ -0,0 +1,312 @@
+#------------------------------------------------------------------------------
+# <copyright file="makefile" company="Atheros">
+# Copyright (c) 2005-2010 Atheros Corporation. All rights reserved.
+#
+#
+# Permission to use, copy, modify, and/or distribute this software for any
+# purpose with or without fee is hereby granted, provided that the above
+# copyright notice and this permission notice appear in all copies.
+#
+# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+#
+#
+#------------------------------------------------------------------------------
+#==============================================================================
+# Author(s): ="Atheros"
+#==============================================================================
+#######################################################################################
+# AR6K Kernel Module makefile.
+#
+# This makefile is invoked by the master makefile in the linux kernel, the linux kernel
+# source must be initially compiled. The top level make will invoke the main linux kernel
+# makefile which will subsequently pick up this makefile.
+#
+#######################################################################################
+
+
+REV ?= 2
+
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/include
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/../include
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/wlan/include
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/os/linux/include
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/os/
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/bmi/include
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/../include/AR6002
+
+EXTRA_CFLAGS += -DLINUX -D__KERNEL__ \
+ -DTCMD -DSEND_EVENT_TO_APP -DUSER_KEYS \
+ -DNO_SYNC_FLUSH -DHTC_EP_STAT_PROFILING -DWLAN_HEADERS\
+ -DATH_AR6K_11N_SUPPORT \
+ -DSUPPORT_11N \
+ -DWAPI_ENABLE \
+ -DHS20_ENABLE #\
+ -DMULTIPLE_FRAMES_PER_INTERRUPT -DAR6000REV$(REV) \
+ -DBLOCK_TX_PATH_FLAG -DCHECKSUM_OFFLOAD \
+
+ifeq ($(ATH_BUILD_BTFILTER),yes)
+ EXTRA_CFLAGS += -DBTCOEX
+ EXTRA_CFLAGS += -DCONFIG_BT
+endif
+
+ifeq ($(ATH_BMISS_ENHANCEMENT),yes)
+ EXTRA_CFLAGS += -DBMISS_ENHANCEMENT
+endif
+
+
+ifeq ($(ATH_CFG80211_ENV),yes)
+ EXTRA_CFLAGS += -DATH6K_CONFIG_CFG80211
+ # EXTRA_CFLAGS += -DCFG80211_WAPI_ENABLE
+endif
+
+ifeq ($(ATH_INIT_MODE_DRV_ENABLED), yes)
+ifeq ($(ATH_AR600x_WB31_XXX),yes)
+EXTRA_CFLAGS += -DAR600x_WB31_XXX
+else
+ifeq ($(ATH_AR600x_SD32_XXX),yes)
+EXTRA_CFLAGS += -DAR600x_SD32_XXX
+else
+EXTRA_CFLAGS += -DAR600x_SD31_XXX
+endif
+endif
+EXTRA_CFLAGS += -DINIT_MODE_DRV_ENABLED -DBMIENABLE_SET
+endif
+
+ifeq ($(ATH_ANDROID_ENV),yes)
+ EXTRA_CFLAGS += -DANDROID_ENV -D__linux__ $(ATH_ANDROID_BUILD_FLAGS)
+ EXTRA_CFLAGS += -DINIT_MODE_DRV_ENABLED -DBMIENABLE_SET -DAR600x_SD31_XXX \
+ -DATH6KL_CONFIG_HIF_VIRTUAL_SCATTER \
+ -DCONFIG_AP_VIRTUAL_ADAPTER_SUPPORT
+ifeq ($(ATH_AR6K_HCI_BRIDGE),yes)
+ EXTRA_CFLAGS += -DSETUPHCI_ENABLED -DSETUPBTDEV_ENABLED \
+ -DATH6KL_CONFIG_GPIO_BT_RESET -DAR600x_BT_AR3001
+endif
+endif
+
+ifeq ($(ATH_AR6K_HCI_PAL),yes)
+ EXTRA_CFLAGS += -DSETUPHCIPAL_ENABLED
+ifeq ($(ATH_AR6K_DEBUG_HCI_PAL),yes)
+ EXTRA_CFLAGS += -DHCIPAL_DEBUG
+endif
+endif
+
+ifeq ($(ATH_SOFTMAC_FILE_USED),yes)
+ EXTRA_CFLAGS += -DSOFTMAC_FILE_USED
+endif
+
+ifeq ($(ATH_AR6K_OTA_TEST_MODE),yes)
+ EXTRA_CFLAGS += -DATH6K_CONFIG_OTA_MODE
+endif
+
+ifeq ($(ATH_AR6K_HCI_BRIDGE),yes)
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/miscdrv/ar3kps
+EXTRA_CFLAGS += -I$(ATH_SRC_BASE)/../include/AR6002/hw4.0
+
+EXTRA_CFLAGS += -DATH_AR6K_ENABLE_GMBOX \
+ -DHCI_TRANSPORT_SDIO
+
+ifeq ($(ATH_AR6K_BUILTIN_HCI_TRANSPORT),no)
+EXTRA_CFLAGS += -DEXPORT_HCI_BRIDGE_INTERFACE
+endif
+endif
+
+
+ifeq ($(ATH_HTC_RAW_INT_ENV),yes)
+ EXTRA_CFLAGS += -DHTC_RAW_INTERFACE
+endif
+
+ifeq ($(ATH_DEBUG_DRIVER),yes)
+ EXTRA_CFLAGS += -DDEBUG -DATH_DEBUG_MODULE
+endif
+
+ifeq ($(ATH_USE_PREALLOC_BUFFER),yes)
+ EXTRA_CFLAGS += -DUSE_PREALLOC_BUFFER
+endif
+
+ifeq ($(ATH_BUILD_P2P),yes)
+ EXTRA_CFLAGS += -DP2P
+endif
+
+ifeq ($(AR6002_REV),4)
+ EXTRA_CFLAGS += -DAR6002_REV4
+endif
+
+ifneq ("$(wildcard $(ATH_SRC_BASE)/../include/AR6002/hw2.0)","")
+ EXTRA_CFLAGS += -DAR6002_HEADERS_DEF
+endif
+
+ifneq ("$(wildcard $(ATH_SRC_BASE)/../include/AR6002/hw4.0)","")
+ EXTRA_CFLAGS += -DAR6003_HEADERS_DEF
+endif
+
+ifneq ("$(wildcard $(ATH_SRC_BASE)/../include/AR6002/hw6.0)","")
+ EXTRA_CFLAGS += -DMCKINLEY_HEADERS_DEF
+endif
+
+ifneq ($(ATH_OS_SUB_TYPE),linux_2_4)
+# linux 2.6 and higher kernel module build settings
+EXTRA_CFLAGS += -DKERNEL_2_6
+obj-m += ar6000.o
+ifeq ($(ATH_AR6K_BUILTIN_HCI_TRANSPORT),no)
+obj-m += bt_hci_sdio.o
+endif
+-include $(ATH_SRC_BASE)/hif/$(ATH_HIF_TYPE)/Makefile
+
+ifneq ($(ATH_HIF_MESSAGE_BASED),yes)
+ar6000-objs += ../../htc2/AR6000/ar6k.o \
+ ../../htc2/AR6000/ar6k_events.o \
+ ../../htc2/htc_send.o \
+ ../../htc2/htc_recv.o \
+ ../../htc2/htc_services.o \
+ ../../htc2/htc.o
+endif
+
+ifeq ($(ATH_HIF_MESSAGE_BASED),yes)
+ar6000-objs += ../../htc_thin/htc_send.o \
+ ../../htc_thin/htc_recv.o \
+ ../../htc_thin/htc_services.o \
+ ../../htc_thin/htc.o
+endif
+
+
+ar6000-objs += ../../bmi/src/bmi.o \
+ ar6000_drv.o \
+ ar6000_pm.o \
+ ar6000_raw_if.o \
+ netbuf.o \
+ wireless_ext.o \
+ ioctl.o \
+ ../../miscdrv/common_drv.o \
+ ../../miscdrv/credit_dist.o \
+ ../../wmi/wmi.o \
+ ../../reorder/rcv_aggr.o \
+ ../../wlan/src/wlan_node.o \
+ ../../wlan/src/wlan_recv_beacon.o \
+ ../../wlan/src/wlan_utils.o \
+ ../../regtable/regtable.o \
+ ../../regtable/AR6003def.o
+
+ifeq ($(ATH_BUILD_P2P),yes)
+ar6000-objs += ../../p2p/p2p_main.o
+endif
+
+ifeq ($(ATH_HIF_TYPE),sdio)
+ar6000-objs += ../../hif/common/hif_bmi_reg_access.o \
+ ../../hif/common/hif_diag_reg_access.o
+
+endif
+
+ifeq ($(ATH_CFG80211_ENV),yes)
+ar6000-objs += cfg80211.o
+endif
+
+ifneq ($(ATH_AR6K_BUILTIN_HCI_TRANSPORT),no)
+ar6000-objs += hci_bridge.o
+endif
+
+ifneq ($(ATH_AR6K_BUILTIN_HCI_PAL),no)
+ar6000-objs += ar6k_pal.o
+else
+obj-m += ar6k_pal.o
+endif
+
+ifeq ($(ATH_AR6K_HCI_BRIDGE),yes)
+ar6000-objs += ../../htc2/AR6000/ar6k_gmbox.o \
+ ../../htc2/AR6000/ar6k_gmbox_hciuart.o
+ifneq ($(ATH_AR6K_BUILTIN_HCI_TRANSPORT),no)
+ar6000-objs += ../../miscdrv/ar3kconfig.o \
+ ../../miscdrv/ar3kps/ar3kpsconfig.o \
+ ../../miscdrv/ar3kps/ar3kpsparser.o
+else
+ar6000-objs += export_hci_transport.o
+endif
+
+ifeq ($(ATH_AR6K_BUILTIN_HCI_TRANSPORT),no)
+bt_hci_sdio-objs += hci_bridge.o \
+ ../../miscdrv/ar3kconfig.o \
+ ../../miscdrv/ar3kps/ar3kpsconfig.o \
+ ../../miscdrv/ar3kps/ar3kpsparser.o
+endif
+endif
+
+ifeq ($(ATH_ANDROID_ENV),yes)
+ ar6000-objs += ar6000_android.o
+endif
+
+ifeq ($(ATH_AR6K_DEBUG_ALLOC),yes)
+ EXTRA_CFLAGS += -DAR6K_ALLOC_DEBUG
+ ar6000-objs += ar6k_mem_debug.o
+endif
+
+endif
+
+ifeq ($(ATH_OS_SUB_TYPE),linux_2_4)
+# linux 2.4 kernel module build settings
+EXTRA_CFLAGS += -DKERNEL_2_4
+
+O_TARGET := ar6000.o
+# need export line for module export
+export-objs := ar6000_drv.o
+-include $(ATH_SRC_BASE)/hif/$(ATH_HIF_TYPE)/Makefile
+obj-y += $(ATH_SRC_BASE)/htc2/htc.o \
+ $(ATH_SRC_BASE)/htc2/htc_send.o \
+ $(ATH_SRC_BASE)/htc2/htc_recv.o \
+ $(ATH_SRC_BASE)/htc2/htc_services.o \
+ $(ATH_SRC_BASE)/htc2/AR6000/ar6k.o \
+ $(ATH_SRC_BASE)/htc2/AR6000/ar6k_events.o \
+ $(ATH_SRC_BASE)/bmi/src/bmi.o \
+ $(ATH_SRC_BASE)/wmi/wmi.o \
+ $(ATH_SRC_BASE)/reorder/rcv_aggr.o \
+ $(ATH_SRC_BASE)/wlan/src/wlan_node.o \
+ $(ATH_SRC_BASE)/wlan/src/wlan_recv_beacon.o \
+ $(ATH_SRC_BASE)/wlan/src/wlan_utils.o \
+ $(ATH_SRC_BASE)/os/linux/ar6000_drv.o \
+ $(ATH_SRC_BASE)/os/linux/ar6000_raw_if.o \
+ $(ATH_SRC_BASE)/os/linux/wireless_ext.o \
+ $(ATH_SRC_BASE)/os/linux/ioctl.o \
+ $(ATH_SRC_BASE)/os/linux/netbuf.o \
+ $(ATH_SRC_BASE)/miscdrv/common_drv.o \
+ $(ATH_SRC_BASE)/miscdrv/credit_dist.o
+
+ifeq ($(ATH_HIF_TYPE),SPI2)
+obj-y += $(ATH_SRC_BASE)/hif/common/hif_bmi_reg_access.o \
+ $(ATH_SRC_BASE)/hif/common/hif_diag_reg_access.o
+
+endif
+
+obj-m += htc.o \
+ htc_send.o \
+ htc_recv.o \
+ htc_services.o \
+ ar6k_events.o \
+ ar6k.o \
+ hif.o \
+ bmi.o \
+ wmi.o \
+ wlan_node.o \
+ wlan_recv_beacon.o \
+ wlan_utils.o \
+ ar6000_drv.o \
+ ar6000_raw_if.o \
+ common_drv.o \
+ credit_dist.o \
+ netbuf.o \
+ wireless_ext.o \
+ rcv_aggr.o \
+ ioctl.o \
+ ar6000.o
+
+ifeq ($(ATH_HIF_TYPE),SPI2)
+obj-m += hif_bmi_reg_access.o \
+ hif_diag_reg_access.o
+
+endif
+
+include $(ATH_LINUXPATH)/Rules.make
+endif
diff --git a/host/os/linux/ar6000_android.c b/host/os/linux/ar6000_android.c
new file mode 100644
index 0000000..1b526e3
--- /dev/null
+++ b/host/os/linux/ar6000_android.c
@@ -0,0 +1,1213 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+#include "ar6000_drv.h"
+#include "htc.h"
+#include <linux/vmalloc.h>
+#include <linux/fs.h>
+
+#ifdef CONFIG_HAS_WAKELOCK
+#include <linux/wakelock.h>
+#endif
+#ifdef CONFIG_HAS_EARLYSUSPEND
+#include <linux/earlysuspend.h>
+#endif
+
+#ifdef CONFIG_MMC_MSM
+A_BOOL enable_mmc_host_detect_change = 1;
+#else
+A_BOOL enable_mmc_host_detect_change = 0;
+#endif
+static void ar6000_enable_mmchost_detect_change(int enable);
+
+#if defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM7X27) && defined(CONFIG_MSM_SOC_REV_A)
+
+#include <linux/device.h>
+#include <mach/vreg.h>
+#include <linux/gpio.h>
+#include <mach/rpc_pmapp.h>
+#include <linux/err.h>
+
+
+#define WLAN_GPIO_EXT_POR_N 134
+#define A0_CLOCK
+
+static const char *id = "WLAN";
+
+enum {
+ WLAN_VREG_L17 = 0,
+ WLAN_VREG_L19
+};
+
+struct wlan_vreg_info {
+ const char *vreg_id;
+ unsigned int vreg_level;
+ unsigned int pmapp_id;
+ unsigned int is_vreg_pin_controlled;
+ struct vreg *vreg;
+};
+
+
+static struct wlan_vreg_info vreg_info[] = {
+ {"bt", 3300, 21, 1, NULL},
+ {"wlan4", 1800, 23, 1, NULL},
+};
+
+
+void msm7x27a_wifi_power(bool on);
+#endif /* CONFIG_MMC_MSM */
+
+
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+#ifndef KERNEL_VERSION_ANDROID
+char fwpath[256] = "/lib/firmware/atheros/target/AR6003_844";
+#else
+char fwpath[256] = "/system/wifi";
+#endif /*KERNEL_VERSION_ANDROID*/
+
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) */
+int wowledon;
+unsigned int enablelogcat;
+
+extern int bmienable;
+extern struct net_device *ar6000_devices[];
+extern char ifname[IFNAMSIZ];
+
+#ifdef CONFIG_HAS_WAKELOCK
+extern struct wake_lock ar6k_wow_wake_lock;
+struct wake_lock ar6k_init_wake_lock;
+#endif
+extern int num_device;
+
+const char def_ifname[] = "wlan0";
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+module_param_string(fwpath, fwpath, sizeof(fwpath), 0644);
+module_param(enablelogcat, uint, 0644);
+module_param(wowledon, int, 0644);
+#else
+#define __user
+/* for linux 2.4 and lower */
+MODULE_PARAM(wowledon,"i");
+#endif
+
+#ifdef CONFIG_HAS_EARLYSUSPEND
+static int screen_is_off;
+static struct early_suspend ar6k_early_suspend;
+#endif
+
+static A_STATUS (*ar6000_avail_ev_p)(void *, void *);
+
+#if defined(ANDROID_ENV) && defined(CONFIG_ANDROID_LOGGER) && (!defined(CONFIG_MMC_MSM) || LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32))
+int logger_write(const enum logidx index,
+ const unsigned char prio,
+ const char __kernel * const tag,
+ const char __kernel * const fmt,
+ ...)
+{
+ int ret = 0;
+ va_list vargs;
+ struct file *filp = (struct file *)-ENOENT;
+ mm_segment_t oldfs;
+ struct iovec vec[3];
+ int tag_bytes = strlen(tag) + 1, msg_bytes;
+ char *msg;
+ va_start(vargs, fmt);
+ msg = kvasprintf(GFP_ATOMIC, fmt, vargs);
+ va_end(vargs);
+ if (!msg)
+ return -ENOMEM;
+ if (in_interrupt()) {
+ /* we have no choice since aio_write may be blocked */
+ printk(KERN_ALERT "%s", msg);
+ goto out_free_message;
+ }
+ msg_bytes = strlen(msg) + 1;
+ if (msg_bytes <= 1) /* empty message? */
+ goto out_free_message; /* don't bother, then */
+ if ((msg_bytes + tag_bytes + 1) > 2048) {
+ ret = -E2BIG;
+ goto out_free_message;
+ }
+
+ vec[0].iov_base = (unsigned char *) &prio;
+ vec[0].iov_len = 1;
+ vec[1].iov_base = (void *) tag;
+ vec[1].iov_len = strlen(tag) + 1;
+ vec[2].iov_base = (void *) msg;
+ vec[2].iov_len = strlen(msg) + 1;
+
+ oldfs = get_fs();
+ set_fs(KERNEL_DS);
+ do {
+ filp = filp_open("/dev/log/main", O_WRONLY, S_IRUSR);
+ if (IS_ERR(filp) || !filp->f_op) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: filp_open /dev/log/main error\n", __FUNCTION__));
+ ret = -ENOENT;
+ break;
+ }
+
+ if (filp->f_op->aio_write) {
+ int nr_segs = sizeof(vec) / sizeof(vec[0]);
+ int len = vec[0].iov_len + vec[1].iov_len + vec[2].iov_len;
+ struct kiocb kiocb;
+ init_sync_kiocb(&kiocb, filp);
+ kiocb.ki_pos = 0;
+ kiocb.ki_left = len;
+ kiocb.ki_nbytes = len;
+ ret = filp->f_op->aio_write(&kiocb, vec, nr_segs, kiocb.ki_pos);
+ }
+
+ } while (0);
+
+ if (!IS_ERR(filp)) {
+ filp_close(filp, NULL);
+ }
+ set_fs(oldfs);
+out_free_message:
+ if (msg) {
+ kfree(msg);
+ }
+ return ret;
+}
+#endif
+
+int android_logger_lv(void *module, int mask)
+{
+ switch (mask) {
+ case ATH_DEBUG_ERR:
+ return 6;
+ case ATH_DEBUG_INFO:
+ return 4;
+ case ATH_DEBUG_WARN:
+ return 5;
+ case ATH_DEBUG_TRC:
+ return 3;
+ default:
+#ifdef DEBUG
+ if (!module) {
+ return 3;
+ } else if (module == &GET_ATH_MODULE_DEBUG_VAR_NAME(driver)) {
+ return (mask <=ATH_DEBUG_MAKE_MODULE_MASK(3)) ? 3 : 2;
+ } else if (module == &GET_ATH_MODULE_DEBUG_VAR_NAME(htc)) {
+ return 2;
+ } else {
+ return 3;
+ }
+#else
+ return 3; /* DEBUG */
+#endif
+ }
+}
+
+int android_readwrite_file(const A_CHAR *filename, A_CHAR *rbuf, const A_CHAR *wbuf, size_t length)
+{
+ int ret = 0;
+ struct file *filp = (struct file *)-ENOENT;
+ mm_segment_t oldfs;
+ oldfs = get_fs();
+ set_fs(KERNEL_DS);
+ do {
+ int mode = (wbuf) ? O_RDWR : O_RDONLY;
+ filp = filp_open(filename, mode, S_IRUSR);
+ if (IS_ERR(filp) || !filp->f_op) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: file %s filp_open error\n", __FUNCTION__, filename));
+ ret = -ENOENT;
+ break;
+ }
+
+ if (length==0) {
+ /* Read the length of the file only */
+ struct inode *inode;
+
+ inode = GET_INODE_FROM_FILEP(filp);
+ if (!inode) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Get inode from %s failed\n", __FUNCTION__, filename));
+ ret = -ENOENT;
+ break;
+ }
+ ret = i_size_read(inode->i_mapping->host);
+ break;
+ }
+
+ if (wbuf) {
+ if ( (ret=filp->f_op->write(filp, wbuf, length, &filp->f_pos)) < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Write %u bytes to file %s error %d\n", __FUNCTION__,
+ length, filename, ret));
+ break;
+ }
+ } else {
+ if ( (ret=filp->f_op->read(filp, rbuf, length, &filp->f_pos)) < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Read %u bytes from file %s error %d\n", __FUNCTION__,
+ length, filename, ret));
+ break;
+ }
+ }
+ } while (0);
+
+ if (!IS_ERR(filp)) {
+ filp_close(filp, NULL);
+ }
+ set_fs(oldfs);
+
+ return ret;
+}
+
+int android_request_firmware(const struct firmware **firmware_p, const char *name,
+ struct device *device)
+{
+ int ret = 0;
+ struct firmware *firmware;
+ char filename[256];
+ const char *raw_filename = name;
+ *firmware_p = firmware = A_MALLOC(sizeof(*firmware));
+ if (!firmware)
+ return -ENOMEM;
+ A_MEMZERO(firmware, sizeof(*firmware));
+ do {
+ size_t length, bufsize, bmisize;
+
+ if (snprintf(filename, sizeof(filename), "%s/%s", fwpath,
+ raw_filename) >= sizeof(filename)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("snprintf: %s/%s\n", fwpath, raw_filename));
+ ret = -1;
+ break;
+ }
+ if ( (ret=android_readwrite_file(filename, NULL, NULL, 0)) < 0) {
+ break;
+ } else {
+ length = ret;
+ }
+
+ if (strcmp(raw_filename, "softmac") == 0) {
+ bufsize = length = 17;
+ } else {
+ bufsize = ALIGN(length, PAGE_SIZE);
+ bmisize = A_ROUND_UP(length, 4);
+ bufsize = max(bmisize, bufsize);
+ }
+ firmware->data = vmalloc(bufsize);
+ firmware->size = length;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC, ("AR6K: %s(): raw_filename=%s, bufsize=%d\n", __FUNCTION__, raw_filename, bufsize));
+
+ if (!firmware->data) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s: Cannot allocate buffer for firmware\n", __FUNCTION__));
+ ret = -ENOMEM;
+ break;
+ }
+
+ if ( (ret=android_readwrite_file(filename, (char*)firmware->data, NULL, length)) != length) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s: file read error, ret %d request %d\n", __FUNCTION__, ret, length));
+ ret = -1;
+ break;
+ }
+
+ } while (0);
+
+ if (ret<0) {
+ if (firmware) {
+ if (firmware->data)
+ vfree(firmware->data);
+ A_FREE(firmware);
+ }
+ *firmware_p = NULL;
+ } else {
+ ret = 0;
+ }
+ return ret;
+}
+
+void android_release_firmware(const struct firmware *firmware)
+{
+ if (firmware) {
+ if (firmware->data)
+ vfree(firmware->data);
+ kfree(firmware);
+ }
+}
+
+static A_STATUS ar6000_android_avail_ev(void *context, void *hif_handle)
+{
+ A_STATUS ret;
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock(&ar6k_init_wake_lock);
+#endif
+ ar6000_enable_mmchost_detect_change(0);
+ ret = ar6000_avail_ev_p(context, hif_handle);
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_unlock(&ar6k_init_wake_lock);
+#endif
+ return ret;
+}
+
+static int android_do_ioctl_direct(struct net_device *dev, int cmd, struct ifreq *ifr, void *data)
+{
+ int ret = -EIO;
+ int (*do_ioctl)(struct net_device *, struct ifreq *, int);
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29)
+ do_ioctl = dev->do_ioctl;
+#else
+ do_ioctl = dev->netdev_ops->ndo_do_ioctl;
+#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29) */
+
+ ifr->ifr_ifru.ifru_data = (__force void __user *)data;
+
+ if (do_ioctl) {
+ mm_segment_t oldfs = get_fs();
+ set_fs(KERNEL_DS);
+ ret = do_ioctl(dev, ifr, cmd);
+ set_fs(oldfs);
+ }
+ return ret;
+}
+
+static int ar6000_cscan(struct net_device *dev, struct iw_point *data, char *cmdbuf)
+{
+ char *ptr = cmdbuf;
+ int iocmd = SIOCSIWSCAN - SIOCSIWCOMMIT;
+ const iw_handler setScan = dev->wireless_handlers->standard[iocmd];
+ A_INT32 home_dwell=0, pas_dwell=0, act_dwell=0;
+ A_UCHAR ssid[IW_ESSID_MAX_SIZE+1] = { 0 };
+ A_INT32 ssid_len = 0, ie_len;
+ A_UINT8 index = 1; /* reserve index 0 for wext */
+ A_INT32 ch = 0,len=data->length ;
+ A_CHAR nprobe, scantype;
+ struct iw_freq chList[IW_MAX_FREQUENCIES];
+ A_UCHAR *scanBuf = (A_UCHAR*)(ptr+ 12);
+ A_UCHAR *scanEnd = (A_UCHAR*)(ptr + len);
+ A_BOOL broadcastSsid = FALSE;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+
+ while ( scanBuf < scanEnd )
+ {
+ A_UCHAR *sp = scanBuf;
+ switch (*scanBuf)
+ {
+ case 'S': /* SSID section */
+ if (ssid_len > 0 && index < MAX_PROBED_SSID_INDEX) {
+ /* setup the last parsed ssid, reserve index 0 for wext */
+ if (wmi_probedSsid_cmd(arPriv->arWmi, index,
+ SPECIFIC_SSID_FLAG, ssid_len, ssid) == A_OK) {
+ ++index;
+ if (arSta->scanSpecificSsid<index) {
+ arSta->scanSpecificSsid = index;
+ }
+ }
+ }
+ ie_len = ((scanBuf + 1) < scanEnd) ? ((A_INT32)*(scanBuf+1) + 1) : 0;
+ if ((scanBuf+ie_len) < scanEnd ) {
+ ssid_len = *(scanBuf+1);
+ if (ssid_len == 0) {
+ broadcastSsid = TRUE;
+ } else {
+ A_MEMCPY(ssid, scanBuf+2, ssid_len);
+ ssid[ssid_len] = '\0';
+ }
+ }
+ scanBuf += 1 + ie_len;
+ break;
+ case 'C': /* Channel section */
+ if (scanBuf+1 < scanEnd) {
+ int value = *(scanBuf+1);
+ if (value == 0) {
+ ch = 0; /* scan for all channels */
+ } else if (ch < IW_MAX_FREQUENCIES) {
+ if (value>1000) {
+ chList[ch].e = 1;
+ chList[ch].m = value * 100000;
+ } else {
+ chList[ch].e = 0;
+ chList[ch].m = value;
+ }
+ ++ch;
+ }
+ }
+ scanBuf += 2;
+ break;
+ case 'P': /* Passive dwell section */
+ if (scanBuf+2 < scanEnd) {
+ pas_dwell = *(scanBuf+1) + (*(scanBuf+2) << 8);
+ }
+ scanBuf += 3;
+ break;
+ case 'H': /* Home dwell section */
+ if (scanBuf+2 < scanEnd) {
+ home_dwell = *(scanBuf+1) + (*(scanBuf+2) << 8);
+ }
+ scanBuf += 3;
+ break;
+ case 'N': /* Number of probe section */
+ if (scanBuf+1 < scanEnd) {
+ nprobe = *(scanBuf+1);
+ }
+ scanBuf += 2;
+ break;
+ case 'A': /* Active dwell section */
+ if (scanBuf+2 < scanEnd) {
+ act_dwell = *(scanBuf+1) + (*(scanBuf+2) << 8);
+ }
+ scanBuf += 3;
+ break;
+ case 'T': /* Scan active type section */
+ if (scanBuf+1 < scanEnd) {
+ scantype = *(scanBuf+1);
+ }
+ scanBuf += 2;
+ break;
+ default:
+ break;
+ } /* switch */
+ if (sp == scanBuf) {
+ return -1; /* parsing error */
+ }
+ }/* while */
+
+ if (ssid_len>0)
+ {
+ A_UINT8 idx; /* Clean up the last specific scan items */
+ for (idx=index; idx<arSta->scanSpecificSsid; ++idx) {
+ wmi_probedSsid_cmd(arPriv->arWmi, idx, DISABLE_SSID_FLAG, 0, NULL);
+ }
+ arSta->scanSpecificSsid = index;
+ /*
+ * There is no way to know when we need to send broadcast probe in current Android wpa_supplicant_6
+ * combo scan implemenation. Always force to sent it here uniti future Android version will set
+ * the broadcast flags for combo scan.
+ */
+#if 0
+ if (broadcastSsid)
+#endif
+ {
+ /* setup the last index as broadcast SSID for combo scan */
+ ++arSta->scanSpecificSsid;
+ wmi_probedSsid_cmd(arPriv->arWmi, index, ANY_SSID_FLAG, 0, NULL);
+ }
+ }
+
+ if (pas_dwell>0) {
+ /* TODO: Should we change our passive dwell? There may be some impact for bt-coex */
+ }
+
+ if (home_dwell>0) {
+ /* TODO: Should we adjust home_dwell? How to pass it to wext handler? */
+ }
+
+ if (setScan) {
+ union iwreq_data miwr;
+ struct iw_request_info minfo;
+ struct iw_scan_req scanreq, *pScanReq = NULL;
+
+ A_MEMZERO(&minfo, sizeof(minfo));
+ A_MEMZERO(&miwr, sizeof(miwr));
+ A_MEMZERO(&scanreq, sizeof(scanreq));
+
+ if (ssid_len > 0) {
+ pScanReq = &scanreq;
+ memcpy(scanreq.essid, ssid, ssid_len);
+ scanreq.essid_len = ssid_len;
+ miwr.data.flags |= IW_SCAN_THIS_ESSID;
+ }
+ if (ch > 0) {
+ pScanReq = &scanreq;
+ scanreq.num_channels = ch;
+ memcpy(scanreq.channel_list, chList, ch * sizeof(chList[0]));
+ miwr.data.flags |= IW_SCAN_THIS_FREQ;
+ }
+ if (pScanReq) {
+ miwr.data.pointer = (__force void __user *)&scanreq;
+ miwr.data.length = sizeof(scanreq);
+ }
+ minfo.cmd = SIOCSIWSCAN;
+ return setScan(dev, &minfo, &miwr, (char*)pScanReq);
+ }
+ return -1;
+}
+
+int android_ioctl_siwpriv(struct net_device *dev,
+ struct iw_request_info *__info,
+ struct iw_point *data, char *__extra)
+{
+ char cmd[32]; /* assume that android command will not excess 32 */
+ char buf[32];
+ char *cmdbuf;
+ int len = sizeof(cmd)-1;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+
+ if (!data->pointer) {
+ return -EOPNOTSUPP;
+ }
+ if (data->length < len) {
+ len = data->length;
+ }
+ if (copy_from_user(cmd, data->pointer, len)) {
+ return -EIO;
+ }
+ cmd[len] = 0;
+
+ if (strcasecmp(cmd, "RSSI")==0 || strcasecmp(cmd, "RSSI-APPROX") == 0) {
+ int rssi = -200;
+ struct iw_statistics *iwStats;
+ struct iw_statistics* (*get_iwstats)(struct net_device *);
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
+ get_iwstats = dev->get_wireless_stats;
+#else
+ get_iwstats = dev->wireless_handlers->get_wireless_stats;
+#endif
+ if (get_iwstats && arPriv->arConnected) {
+ iwStats = get_iwstats(dev);
+ if (iwStats) {
+ rssi = iwStats->qual.qual;
+ if (rssi == 255)
+ rssi = -200;
+ else
+ rssi += (161 - 256);
+ }
+ }
+ len = snprintf(buf, data->length, "SSID rssi %d\n", rssi) + 1;
+ return (copy_to_user(data->pointer, buf, len)==0) ? len : -1;
+ } else if (strcasecmp(cmd, "LINKSPEED")==0) {
+ /* We skip to use SIOCGIWRATE since Android always asked LINKSPEED just after RSSI*/
+ unsigned int speed_mbps;
+ if (arPriv->arConnected) {
+ speed_mbps = arPriv->arTargetStats.tx_unicast_rate / 1000;
+ } else {
+ speed_mbps = 1;
+ }
+ len = snprintf(buf, data->length, "LinkSpeed %u\n", speed_mbps) + 1;
+ return (copy_to_user(data->pointer, buf, len)==0) ? len : -1;
+ } else if (memcmp(cmd, "CSCAN S\x01\x00\x00S\x00", 12)==0) {
+
+ int ret=0;
+
+ if (!(cmdbuf = A_MALLOC(data->length)))
+ return -ENOMEM;
+
+ if (copy_from_user(cmdbuf, data->pointer, data->length)) {
+ A_FREE(cmdbuf);
+ return -EFAULT;
+ }
+
+ ret = ar6000_cscan(dev,data, cmdbuf);
+
+ A_FREE(cmdbuf);
+ return ret;
+
+ } else if (strcasecmp(cmd, "MACADDR")==0) {
+ /* reply comes back in the form "Macaddr = XX:XX:XX:XX:XX:XX" where XX */
+ A_UCHAR *mac = dev->dev_addr;
+ len = snprintf(buf, data->length, "Macaddr = %02X:%02X:%02X:%02X:%02X:%02X\n",
+ mac[0], mac[1], mac[2],
+ mac[3], mac[4], mac[5]) + 1;
+ return (copy_to_user(data->pointer, buf, len)==0) ? len : -1;
+ } else if (strcasecmp(cmd, "SCAN-ACTIVE")==0) {
+ return 0; /* unsupport function. Suppress the error */
+ } else if (strcasecmp(cmd, "SCAN-PASSIVE")==0) {
+ return 0; /* unsupport function. Suppress the error */
+ } else if (strcasecmp(cmd, "START")==0 || strcasecmp(cmd, "STOP")==0) {
+ struct ifreq ifr;
+ char userBuf[16];
+ int ex_arg = (strcasecmp(cmd, "START")==0) ? WLAN_ENABLED : WLAN_DISABLED;
+ int ret;
+ A_MEMZERO(userBuf, sizeof(userBuf));
+ ((int *)userBuf)[0] = AR6000_XIOCTRL_WMI_SET_WLAN_STATE;
+ ((int *)userBuf)[1] = ex_arg;
+ ret = android_do_ioctl_direct(dev, AR6000_IOCTL_EXTENDED, &ifr, userBuf);
+ if (ret==0) {
+ /* Send wireless event which need by android supplicant */
+ union iwreq_data wrqu;
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = strlen(cmd);
+ wireless_send_event(dev, IWEVCUSTOM, &wrqu, cmd);
+ }
+ return ret;
+ } else if (strncasecmp(cmd, "POWERMODE ", 10)==0) {
+ int mode;
+ if (sscanf(cmd, "%*s %d", &mode) == 1) {
+ int iocmd = SIOCSIWPOWER - SIOCSIWCOMMIT;
+ iw_handler setPower = dev->wireless_handlers->standard[iocmd];
+ if (setPower) {
+ union iwreq_data miwr;
+ struct iw_request_info minfo;
+ A_MEMZERO(&minfo, sizeof(minfo));
+ A_MEMZERO(&miwr, sizeof(miwr));
+ minfo.cmd = SIOCSIWPOWER;
+ if (mode == 0 /* auto */)
+ miwr.power.disabled = 0;
+ else if (mode == 1 /* active */)
+ miwr.power.disabled = 1;
+ else
+ return -1;
+ return setPower(dev, &minfo, &miwr, NULL);
+ }
+ }
+ return -1;
+ } else if (strcasecmp(cmd, "GETPOWER")==0) {
+ struct ifreq ifr;
+ int userBuf[2];
+ A_MEMZERO(userBuf, sizeof(userBuf));
+ ((int *)userBuf)[0] = AR6000_XIOCTRL_WMI_GET_POWER_MODE;
+ if (android_do_ioctl_direct(dev, AR6000_IOCTL_EXTENDED, &ifr, userBuf)>=0) {
+ WMI_POWER_MODE_CMD *getPowerMode = (WMI_POWER_MODE_CMD *)userBuf;
+ len = snprintf(buf, data->length, "powermode = %u\n",
+ (getPowerMode->powerMode==MAX_PERF_POWER) ? 1/*active*/ : 0/*auto*/) + 1;
+ return (copy_to_user(data->pointer, buf, len)==0) ? len : -1;
+ }
+ return -1;
+ } else if (strcasecmp(cmd, "GETBAND")==0) {
+ int band; /*0: auto, 1: 5GHz only, 2: 2.4GHz Only*/
+ switch (arPriv->arPhyCapability) {
+ case WMI_11A_CAPABILITY:
+ case WMI_11NA_CAPABILITY:
+ band = 1;
+ break;
+ case WMI_11NG_CAPABILITY:
+ case WMI_11G_CAPABILITY:
+ band = 2;
+ break;
+ case WMI_11AG_CAPABILITY:
+ case WMI_11NAG_CAPABILITY:
+ default:
+ band = 0;
+ break;
+ }
+ len = snprintf(buf, data->length, "Band %d\n", band) + 1;
+ return (copy_to_user(data->pointer, buf, len)==0) ? len : -1;
+ } else if (strncasecmp(cmd, "SETBAND ", 8)==0) {
+ int band;
+ if (sscanf(cmd, "%*s %d", &band) == 1) {
+ switch (band) {
+ case 1: /* 5GHz Only*/
+ /* TODO: Using WMI_CHANNEL_PARAMS_CMD to disable all 5GHz channels? */
+ break;
+ case 2: /* 5GHz Only*/
+ /* TODO: Using WMI_CHANNEL_PARAMS_CMD to disable all 2.4GHz channels? */
+ break;
+ case 0: /* auto */
+ default:
+ break;
+ }
+ return 0;
+ }
+ return -1;
+ } else if (strncasecmp(cmd, "SETSUSPENDOPT ", 14)==0) {
+ int enable;
+ if (sscanf(cmd, "%*s %d", &enable)==1) {
+ /*
+ * We set our suspend mode by wlan_config.h now.
+ * Should we follow Android command?? TODO
+ */
+ return 0;
+ }
+ return -1;
+ } else if (strcasecmp(cmd, "SCAN-CHANNELS")==0) {
+ // reply comes back in the form "Scan-Channels = X" where X is the number of channels
+ int iocmd = SIOCGIWRANGE - SIOCSIWCOMMIT;
+ iw_handler getRange = dev->wireless_handlers->standard[iocmd];
+ if (getRange) {
+ union iwreq_data miwr;
+ struct iw_request_info minfo;
+ struct iw_range range;
+ A_MEMZERO(&minfo, sizeof(minfo));
+ A_MEMZERO(&miwr, sizeof(miwr));
+ A_MEMZERO(&range, sizeof(range));
+ minfo.cmd = SIOCGIWRANGE;
+ miwr.data.pointer = (__force void __user *) ⦥
+ miwr.data.length = sizeof(range);
+ getRange(dev, &minfo, &miwr, (char*)&range);
+ }
+ if (arSta->arNumChannels!=-1) {
+ len = snprintf(buf, data->length, "Scan-Channels = %d\n", arSta->arNumChannels) + 1;
+ return (copy_to_user(data->pointer, buf, len)==0) ? len : -1;
+ }
+ return -1;
+ } else if (strncasecmp(cmd, "SCAN-CHANNELS ", 14)==0 ||
+ strncasecmp(cmd, "COUNTRY ", 8)==0) {
+ /*
+ * Set the available channels with WMI_SET_CHANNELPARAMS cmd
+ * However, the channels will be limited by the eeprom regulator domain
+ * Try to use a regulator domain which will not limited the channels range.
+ */
+ int i;
+ int chan = 0;
+ A_UINT16 *clist;
+ struct ifreq ifr;
+ char ioBuf[256];
+ WMI_CHANNEL_PARAMS_CMD *chParamCmd = (WMI_CHANNEL_PARAMS_CMD *)ioBuf;
+ if (strncasecmp(cmd, "COUNTRY ", 8)==0) {
+ char *country = cmd + 8;
+ if (strcasecmp(country, "US")==0) {
+ chan = 11;
+ } else if (strcasecmp(country, "JP")==0) {
+ chan = 14;
+ } else if (strcasecmp(country, "EU")==0) {
+ chan = 13;
+ }
+ } else if (sscanf(cmd, "%*s %d", &chan) != 1) {
+ return -1;
+ }
+ if ( (chan != 11) && (chan != 13) && (chan != 14)) {
+ return -1;
+ }
+ if (arPriv->arNextMode == AP_NETWORK) {
+ return -1;
+ }
+ A_MEMZERO(&ifr, sizeof(ifr));
+ A_MEMZERO(ioBuf, sizeof(ioBuf));
+
+ chParamCmd->phyMode = WMI_11G_MODE;
+ clist = chParamCmd->channelList;
+ chParamCmd->numChannels = chan;
+ chParamCmd->scanParam = 1;
+ for (i = 0; i < chan; i++) {
+ clist[i] = wlan_ieee2freq(i + 1);
+ }
+
+ return android_do_ioctl_direct(dev, AR6000_IOCTL_WMI_SET_CHANNELPARAMS, &ifr, ioBuf);
+ } else if (strncasecmp(cmd, "BTCOEXMODE ", 11)==0) {
+ int mode;
+ if (sscanf(cmd, "%*s %d", &mode)==1) {
+ /*
+ * Android disable BT-COEX when obtaining dhcp packet except there is headset is connected
+ * It enable the BT-COEX after dhcp process is finished
+ * We ignore since we have our way to do bt-coex during dhcp obtaining.
+ */
+ switch (mode) {
+ case 1: /* Disable*/
+ break;
+ case 0: /* Enable */
+ /* fall through */
+ case 2: /* Sense*/
+ /* fall through */
+ default:
+ break;
+ }
+ return 0; /* ignore it */
+ }
+ return -1;
+ } else if (strcasecmp(cmd, "BTCOEXSCAN-START")==0) {
+ /* Android enable or disable Bluetooth coexistence scan mode. When this mode is on,
+ * some of the low-level scan parameters used by the driver are changed to
+ * reduce interference with A2DP streaming.
+ */
+ return 0; /* ignore it since we have btfilter */
+ } else if (strcasecmp(cmd, "BTCOEXSCAN-STOP")==0) {
+ return 0; /* ignore it since we have btfilter */
+ } else if (strncasecmp(cmd, "RXFILTER-ADD ", 13)==0) {
+ return 0; /* ignore it */
+ } else if (strncasecmp(cmd, "RXFILTER-REMOVE ", 16)==0) {
+ return 0; /* ignoret it */
+ } else if (strcasecmp(cmd, "RXFILTER-START")==0 || strcasecmp(cmd, "RXFILTER-STOP")==0) {
+ unsigned int flags = dev->flags;
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
+ int mc_count = dev->mc_count;
+#else
+ int mc_count = netdev_mc_count(dev);
+#endif
+ if (strcasecmp(cmd, "RXFILTER-START")==0) {
+ if (mc_count > 0 || (flags & IFF_MULTICAST) ) {
+ flags &= ~IFF_MULTICAST;
+ }
+ } else {
+ flags |= IFF_MULTICAST;
+ }
+ if (flags != dev->flags) {
+ dev_change_flags(dev, flags);
+ }
+ return 0;
+ }
+
+ return -EOPNOTSUPP;
+}
+
+#if defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM7X27) && defined(CONFIG_MSM_SOC_REV_A)
+void msm7x27a_wifi_power(bool on)
+{
+
+ int rc = 0, index = 0;
+ static int resultFlag = 0, flag = 1;
+
+ for (index = 0; index < ARRAY_SIZE(vreg_info); index++) {
+ vreg_info[index].vreg = vreg_get(NULL,
+ vreg_info[index].vreg_id);
+ if (IS_ERR(vreg_info[index].vreg)) {
+ pr_err("%s:%s vreg get failed %ld\n",
+ __func__, vreg_info[index].vreg_id,
+ PTR_ERR(vreg_info[index].vreg));
+ rc = PTR_ERR(vreg_info[index].vreg);
+ if (on)
+ goto vreg_fail;
+ else
+ continue;
+ }
+
+ if (on) {
+ rc = vreg_set_level(vreg_info[index].vreg,
+ vreg_info[index].vreg_level);
+ if (rc) {
+ pr_err("%s:%s vreg set level failed %d\n",
+ __func__, vreg_info[index].vreg_id, rc);
+ goto vreg_fail;
+ }
+
+ rc = vreg_enable(vreg_info[index].vreg);
+ if (rc) {
+ pr_err("%s:%s vreg enable failed %d\n",
+ __func__,
+ vreg_info[index].vreg_id, rc);
+ goto vreg_fail;
+ }
+
+ if (vreg_info[index].is_vreg_pin_controlled) {
+ rc = pmapp_vreg_lpm_pincntrl_vote(id,
+ vreg_info[index].pmapp_id,
+ PMAPP_CLOCK_ID_A0, 1);
+ if (rc) {
+ pr_err("%s:%s pmapp_vreg_lpm_pincntrl_vote"
+ " for enable failed %d\n",
+ __func__,
+ vreg_info[index].vreg_id, rc);
+ goto vreg_fail;
+ }
+ }
+
+
+ if (index == WLAN_VREG_L17)
+ usleep(5);
+ else if (index == WLAN_VREG_L19)
+ usleep(10);
+
+ printk("\n vote for %s vreg. \n",vreg_info[index].vreg_id);
+
+ } else {
+ if (vreg_info[index].is_vreg_pin_controlled) {
+ rc = pmapp_vreg_lpm_pincntrl_vote(id,
+ vreg_info[index].pmapp_id,
+ PMAPP_CLOCK_ID_A0, 0);
+ if (rc) {
+ pr_err("%s:%s pmapp_vreg_lpm_pincntrl_vote"
+ " for disable failed %d\n",
+ __func__,
+ vreg_info[index].vreg_id, rc);
+ }
+ }
+ rc = vreg_disable(vreg_info[index].vreg);
+ if (rc) {
+ pr_err("%s:%s vreg disable failed %d\n",
+ __func__,
+ vreg_info[index].vreg_id, rc);
+ }
+
+ printk("\n vote against %s vreg. \n",vreg_info[index].vreg_id);
+ }
+ }
+
+ if (on) {
+ rc = gpio_request(WLAN_GPIO_EXT_POR_N, "WLAN_DEEP_SLEEP_N");
+ if (rc) {
+ pr_err("WLAN reset GPIO %d request failed %d\n",
+ WLAN_GPIO_EXT_POR_N, rc);
+ goto fail;
+ }
+ if(flag)
+ {
+ flag=0;
+ rc = gpio_direction_output(WLAN_GPIO_EXT_POR_N, 1);
+ if (rc < 0) {
+ pr_err("WLAN reset GPIO %d set direction failed %d\n",
+ WLAN_GPIO_EXT_POR_N, rc);
+ goto fail_gpio_dir_out;
+ }
+ }
+
+#ifdef A0_CLOCK
+ rc = pmapp_clock_vote(id, PMAPP_CLOCK_ID_A0, PMAPP_CLOCK_VOTE_ON);
+ printk("\nVote for A0 clock done\n");
+
+ rc = pmapp_clock_vote(id, PMAPP_CLOCK_ID_A0, PMAPP_CLOCK_VOTE_PIN_CTRL);
+ if (rc) {
+ pr_err("%s: Configuring A0 clock to Pin controllable failed %d\n",
+ __func__, rc);
+ }
+#else
+
+ rc = pmapp_clock_vote(id, PMAPP_CLOCK_ID_A0, PMAPP_CLOCK_VOTE_OFF);
+ printk("\nVote against A0 clock done\n");
+#endif
+ if (rc) {
+ pr_err("%s: Configuring A0 to turn off"
+ " failed %d\n", __func__, rc);
+ }
+ printk("\n vote for WLAN GPIO 134 done. \n");
+
+ } else {
+
+ if(!resultFlag){
+ gpio_set_value_cansleep(WLAN_GPIO_EXT_POR_N, 0);
+ rc = gpio_direction_input(WLAN_GPIO_EXT_POR_N);
+ if (rc) {
+ pr_err("WLAN reset GPIO %d set direction failed %d\n",
+ WLAN_GPIO_EXT_POR_N, rc);
+ }
+ gpio_free(WLAN_GPIO_EXT_POR_N);
+ printk("\n vote against WLAN GPIO 134 done. \n");
+ }
+ rc = pmapp_clock_vote(id, PMAPP_CLOCK_ID_A0,
+ PMAPP_CLOCK_VOTE_OFF);
+ if (rc) {
+ pr_err("%s: Configuring A0 to turn OFF"
+ " failed %d\n", __func__, rc);
+ }
+ }
+
+ printk("Interface %s success \n",on?"initialization":"deinitialization");
+ resultFlag = 0;
+ return;
+
+fail_gpio_dir_out:
+ gpio_free(WLAN_GPIO_EXT_POR_N);
+vreg_fail:
+ index--;
+ while (index > 0) {
+ rc = vreg_disable(vreg_info[index].vreg);
+ if (rc) {
+ pr_err("%s:%s vreg disable failed %d\n",
+ __func__, vreg_info[index].vreg_id, rc);
+ }
+ index--;
+ }
+ if (!on)
+ goto fail;
+fail:
+ resultFlag = 1;
+ printk("Interface %s failed \n",on?"initialization":"deinitialization");
+ return;
+}
+#endif
+
+/* Useful for qualcom platform to detect our wlan card for mmc stack */
+static void ar6000_enable_mmchost_detect_change(int enable)
+{
+#ifdef CONFIG_MMC_MSM
+#if defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM7X27) && defined(CONFIG_MSM_SOC_REV_A)
+#define MMC_MSM_DEV "msm_sdcc.2"
+#else
+#define MMC_MSM_DEV "msm_sdcc.1"
+#endif
+ char buf[3];
+ int length;
+
+ if (!enable_mmc_host_detect_change) {
+ return;
+ }
+ length = snprintf(buf, sizeof(buf), "%d\n", enable ? 1 : 0);
+ android_readwrite_file("/sys/devices/platform/" MMC_MSM_DEV "/polling", NULL, buf, length);
+ A_MDELAY(50);
+#endif
+}
+
+#ifdef CONFIG_HAS_EARLYSUSPEND
+static void android_early_suspend(struct early_suspend *h)
+{
+ screen_is_off = 1;
+}
+
+static void android_late_resume(struct early_suspend *h)
+{
+ screen_is_off = 0;
+}
+#endif
+
+void android_module_init(OSDRV_CALLBACKS *osdrvCallbacks)
+{
+ bmienable = 1;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+ if (ifname[0] == '\0') {
+ if (strlcpy(ifname, def_ifname, sizeof(ifname)) >= sizeof(ifname)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("strlcpy: def_ifname %s\n", def_ifname));
+ return;
+ }
+ }
+#endif
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock_init(&ar6k_init_wake_lock, WAKE_LOCK_SUSPEND, "ar6k_init");
+#endif
+#ifdef CONFIG_HAS_EARLYSUSPEND
+ ar6k_early_suspend.suspend = android_early_suspend;
+ ar6k_early_suspend.resume = android_late_resume;
+ ar6k_early_suspend.level = EARLY_SUSPEND_LEVEL_BLANK_SCREEN;
+ register_early_suspend(&ar6k_early_suspend);
+#endif
+
+ ar6000_avail_ev_p = osdrvCallbacks->deviceInsertedHandler;
+ osdrvCallbacks->deviceInsertedHandler = ar6000_android_avail_ev;
+
+ ar6000_enable_mmchost_detect_change(1);
+}
+
+void android_module_exit(void)
+{
+#ifdef CONFIG_HAS_EARLYSUSPEND
+ unregister_early_suspend(&ar6k_early_suspend);
+#endif
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock_destroy(&ar6k_init_wake_lock);
+#endif
+ ar6000_enable_mmchost_detect_change(1);
+ /* disable polling again after we remove our wlan card */
+ ar6000_enable_mmchost_detect_change(0);
+}
+
+#ifdef CONFIG_PM
+void android_ar6k_check_wow_status(AR_SOFTC_T *ar, struct sk_buff *skb, A_BOOL isEvent)
+{
+#ifdef CONFIG_HAS_WAKELOCK
+ unsigned long wake_timeout = 5; /* 50 milli seconds for normal window's ping test */
+#endif
+ AR_SOFTC_DEV_T *arPriv;
+ A_UINT8 i;
+ A_BOOL needWake = FALSE;
+ for(i = 0; i < num_device; i++)
+ {
+ arPriv = ar->arDev[i];
+ if (
+#ifdef CONFIG_HAS_EARLYSUSPEND
+ screen_is_off &&
+#endif
+ skb && arPriv->arConnected) {
+ if (isEvent) {
+ if (A_NETBUF_LEN(skb) >= sizeof(A_UINT16)) {
+ A_UINT16 cmd = *(const A_UINT16 *)A_NETBUF_DATA(skb);
+ switch (cmd) {
+ case WMI_CONNECT_EVENTID:
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_timeout = 5;
+#endif
+ needWake = TRUE;
+ break;
+ default:
+ /* dont wake lock the system for other event */
+ break;
+ }
+ }
+ } else if (A_NETBUF_LEN(skb) >= sizeof(ATH_MAC_HDR)) {
+ ATH_MAC_HDR *datap = (ATH_MAC_HDR *)A_NETBUF_DATA(skb);
+ if (!IEEE80211_IS_MULTICAST(datap->dstMac)) {
+ switch (A_BE2CPU16(datap->typeOrLen)) {
+ case 0x0800: /* IP */
+ if (A_NETBUF_LEN(skb)>=24 &&
+ *((A_UCHAR*)A_NETBUF_DATA(skb)+23)==0x11) {
+ A_UCHAR *udpPkt = (A_UCHAR*)A_NETBUF_DATA(skb)+14;
+ A_UINT8 ihl = (*udpPkt & 0x0f) * sizeof(A_UINT32);
+ const A_UCHAR ipsec_keepalive[] = {
+ 0x11, 0x94, 0x11, 0x94, 0x00, 0x09, 0x00, 0x00, 0xff
+ };
+ udpPkt += ihl;
+ if (A_NETBUF_LEN(skb)>=14+ihl+sizeof(ipsec_keepalive) &&
+ !memcmp(udpPkt, ipsec_keepalive, sizeof(ipsec_keepalive)-3) &&
+ udpPkt[8]==0xff) {
+ /*
+ * RFC 3948 UDP Encapsulation of IPsec ESP Packets
+ * Source and Destination port must be 4500
+ * Receivers MUST NOT depend upon the UDP checksum being zero
+ * Sender must use 1 byte payload with 0xff
+ * Receiver SHOULD ignore a received NAT-keepalive packet
+ *
+ * IPSec over UDP NAT keepalive packet. Just ignore
+ */
+ break;
+ }
+ }
+ case 0x888e: /* EAPOL */
+ case 0x88c7: /* RSN_PREAUTH */
+ case 0x88b4: /* WAPI */
+ needWake = TRUE;
+ break;
+ case 0x0806: /* ARP is not important to hold wake lock */
+ needWake = (arPriv->arNetworkType==AP_NETWORK);
+ break;
+ default:
+ break;
+ }
+ } else if ( !IEEE80211_IS_BROADCAST(datap->dstMac) ) {
+ if (A_NETBUF_LEN(skb)>=14+20 ) {
+ /* check if it is mDNS packets */
+ A_UINT8 *dstIpAddr = (A_UINT8*)(A_NETBUF_DATA(skb)+14+20-4);
+ struct net_device *ndev = arPriv->arNetDev;
+ needWake = ((dstIpAddr[3] & 0xf8) == 0xf8) &&
+ (arPriv->arNetworkType==AP_NETWORK ||
+ (ndev->flags & IFF_ALLMULTI || ndev->flags & IFF_MULTICAST));
+ }
+ }else if (arPriv->arNetworkType==AP_NETWORK) {
+ switch (A_BE2CPU16(datap->typeOrLen)) {
+ case 0x0800: /* IP */
+ if (A_NETBUF_LEN(skb)>=14+20+2) {
+ A_UINT16 dstPort = *(A_UINT16*)(A_NETBUF_DATA(skb)+14+20);
+ dstPort = A_BE2CPU16(dstPort);
+ needWake = (dstPort == 0x43); /* dhcp request */
+ }
+ break;
+ case 0x0806:
+ needWake = TRUE;
+ default:
+ break;
+ }
+ }
+ }
+ }
+ }
+ if (needWake) {
+#ifdef CONFIG_HAS_WAKELOCK
+ /* keep host wake up if there is any event and packate comming in*/
+ wake_lock_timeout(&ar6k_wow_wake_lock, wake_timeout);
+#endif
+ if (wowledon) {
+ char buf[32];
+ int len = 0;
+ if ((len = snprintf(buf, sizeof(buf), "on")) >= sizeof(buf)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("snprintf: on\n"));
+ return;
+ }
+ android_readwrite_file("/sys/power/state", NULL, buf, len);
+
+ if ((len = snprintf(buf, sizeof(buf), "%d", 127)) >= sizeof(buf)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("snprintf: unable to write 127\n"));
+ return;
+ }
+ android_readwrite_file("/sys/class/leds/lcd-backlight/brightness",
+ NULL, buf,len);
+ }
+ }
+}
+#endif /* CONFIG_PM */
+
+void android_send_reload_event(AR_SOFTC_DEV_T *arPriv)
+{
+ struct net_device *ndev = arPriv->arNetDev;
+ union iwreq_data wrqu;
+ const char reloadEvt[] = "HANG";
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = strlen(reloadEvt);
+ wireless_send_event(ndev, IWEVCUSTOM, &wrqu, reloadEvt);
+}
diff --git a/host/os/linux/ar6000_drv.c b/host/os/linux/ar6000_drv.c
new file mode 100644
index 0000000..b0c32c1
--- /dev/null
+++ b/host/os/linux/ar6000_drv.c
@@ -0,0 +1,9504 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+/*
+ * This driver is a pseudo ethernet driver to access the Atheros AR6000
+ * WLAN Device
+ */
+#include <linux/vmalloc.h>
+#include "ar6000_drv.h"
+#ifdef ATH6K_CONFIG_CFG80211
+#include "cfg80211.h"
+#endif /* ATH6K_CONFIG_CFG80211 */
+#include "htc.h"
+#include "wmi_filter_linux.h"
+#include "epping_test.h"
+#include "wlan_config.h"
+#include "ar3kconfig.h"
+#ifdef ATH_SUPPORT_DFS
+#include "dfs_host.h"
+#endif
+#include "ar6k_pal.h"
+#include "AR6002/addrs.h"
+#include "target_reg_table.h"
+#ifdef P2P
+#include "p2p_api.h"
+#endif
+#include "a_drv_api.h"
+
+#ifdef CONFIG_PLAT_AMBARELLA
+#include <mach/board.h>
+#include <plat/sd.h>
+#endif
+
+/* LINUX_HACK_FUDGE_FACTOR -- this is used to provide a workaround for linux behavior. When
+ * the meta data was added to the header it was found that linux did not correctly provide
+ * enough headroom. However when more headroom was requested beyond what was truly needed
+ * Linux gave the requested headroom. Therefore to get the necessary headroom from Linux
+ * the driver requests more than is needed by the amount = LINUX_HACK_FUDGE_FACTOR */
+#define LINUX_HACK_FUDGE_FACTOR 16
+#define BDATA_BDADDR_OFFSET 28
+
+A_UINT8 bcast_mac[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+A_UINT8 null_mac[] = {0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
+
+#ifdef DEBUG
+
+#define ATH_DEBUG_DBG_LOG ATH_DEBUG_MAKE_MODULE_MASK(0)
+#define ATH_DEBUG_WLAN_CONNECT ATH_DEBUG_MAKE_MODULE_MASK(1)
+#define ATH_DEBUG_WLAN_SCAN ATH_DEBUG_MAKE_MODULE_MASK(2)
+#define ATH_DEBUG_WLAN_TX ATH_DEBUG_MAKE_MODULE_MASK(3)
+#define ATH_DEBUG_WLAN_RX ATH_DEBUG_MAKE_MODULE_MASK(4)
+#define ATH_DEBUG_HTC_RAW ATH_DEBUG_MAKE_MODULE_MASK(5)
+#define ATH_DEBUG_HCI_BRIDGE ATH_DEBUG_MAKE_MODULE_MASK(6)
+
+static ATH_DEBUG_MASK_DESCRIPTION driver_debug_desc[] = {
+ { ATH_DEBUG_DBG_LOG , "Target Debug Logs"},
+ { ATH_DEBUG_WLAN_CONNECT , "WLAN connect"},
+ { ATH_DEBUG_WLAN_SCAN , "WLAN scan"},
+ { ATH_DEBUG_WLAN_TX , "WLAN Tx"},
+ { ATH_DEBUG_WLAN_RX , "WLAN Rx"},
+ { ATH_DEBUG_HTC_RAW , "HTC Raw IF tracing"},
+ { ATH_DEBUG_HCI_BRIDGE , "HCI Bridge Setup"},
+ { ATH_DEBUG_HCI_RECV , "HCI Recv tracing"},
+ { ATH_DEBUG_HCI_DUMP , "HCI Packet dumps"},
+};
+
+ATH_DEBUG_INSTANTIATE_MODULE_VAR(driver,
+ "driver",
+ "Linux Driver Interface",
+ ATH_DEBUG_MASK_DEFAULTS | ATH_DEBUG_WLAN_SCAN |
+ ATH_DEBUG_HCI_BRIDGE,
+ ATH_DEBUG_DESCRIPTION_COUNT(driver_debug_desc),
+ driver_debug_desc);
+
+#endif
+
+
+#define IS_MAC_NULL(mac) (mac[0]==0 && mac[1]==0 && mac[2]==0 && mac[3]==0 && mac[4]==0 && mac[5]==0)
+#define IS_MAC_BCAST(mac) (*mac==0xff)
+
+#define DESCRIPTION "Driver to access the AR600x Device, version " __stringify(__VER_MAJOR_) "." __stringify(__VER_MINOR_) "." __stringify(__VER_PATCH_) "." __stringify(__BUILD_NUMBER_)
+
+MODULE_AUTHOR("Qualcomm Atheros");
+MODULE_DESCRIPTION(DESCRIPTION);
+MODULE_LICENSE("Dual BSD/GPL");
+
+#ifndef REORG_APTC_HEURISTICS
+#undef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+#endif /* REORG_APTC_HEURISTICS */
+
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+A_TIMER aptcTimer[NUM_DEV];
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+// callbacks registered by HCI transport driver
+HCI_TRANSPORT_CALLBACKS ar6kHciTransCallbacks = { NULL };
+#endif
+
+unsigned int processDot11Hdr = 0;
+char targetconf[10]={0,};
+int bmienable = BMIENABLE_DEFAULT;
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+char ifname[IFNAMSIZ] = {0,};
+char devmode[32] ={0,};
+char submode[32] ={0,};
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) */
+
+int regcode = 0;
+int wlaninitmode = WLAN_INIT_MODE_DEFAULT;
+unsigned int bypasswmi = 0;
+unsigned int debuglevel = 0;
+int tspecCompliance = ATHEROS_COMPLIANCE;
+unsigned int busspeedlow = 0;
+unsigned int onebitmode = 0;
+unsigned int skipflash = 0;
+unsigned int wmitimeout = 2;
+unsigned int wlanNodeCaching = 1;
+unsigned int enableuartprint = ENABLEUARTPRINT_DEFAULT;
+unsigned int logWmiRawMsgs = 0;
+unsigned int enabletimerwar = 0;
+unsigned int fwmode = 1;
+unsigned int fwsubmode = 0;
+unsigned int mbox_yield_limit = 99;
+unsigned int enablerssicompensation = 0;
+int reduce_credit_dribble = 1 + HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_ONE_HALF;
+int allow_trace_signal = 0;
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+unsigned int testmode =0;
+#endif
+unsigned int firmware_bridge = 0;
+
+unsigned int irqprocmode = HIF_DEVICE_IRQ_SYNC_ONLY;//HIF_DEVICE_IRQ_ASYNC_SYNC;
+unsigned int panic_on_assert = 1;
+unsigned int nohifscattersupport = NOHIFSCATTERSUPPORT_DEFAULT;
+
+unsigned int setuphci = SETUPHCI_DEFAULT;
+unsigned int setuphcipal = SETUPHCIPAL_DEFAULT;
+unsigned int loghci = 0;
+unsigned int setupbtdev = SETUPBTDEV_DEFAULT;
+#ifndef EXPORT_HCI_BRIDGE_INTERFACE
+unsigned int ar3khcibaud = AR3KHCIBAUD_DEFAULT;
+unsigned int hciuartscale = HCIUARTSCALE_DEFAULT;
+unsigned int hciuartstep = HCIUARTSTEP_DEFAULT;
+#endif
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+unsigned int csumOffload=0;
+unsigned int csumOffloadTest=0;
+#endif
+unsigned int eppingtest=0;
+unsigned int regscanmode=0;
+unsigned int num_device=1;
+unsigned char ar6k_init=FALSE;
+unsigned int rtc_reset_only_on_exit=0;
+unsigned int mac_addr_method=0;
+A_BOOL avail_ev_called=FALSE;
+
+#if defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM7X27) && defined(CONFIG_MSM_SOC_REV_A)
+unsigned int refClock = 19200000;
+#else
+unsigned int refClock = 26000000;
+#endif
+
+unsigned int max_psq_depth = MAX_DEFAULT_PS_QUEUE_DEPTH;
+
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+module_param_string(ifname, ifname, sizeof(ifname), 0644);
+module_param(regcode, int, 0644);
+module_param(wlaninitmode, int, 0644);
+module_param(bmienable, int, 0644);
+module_param(bypasswmi, uint, 0644);
+module_param(debuglevel, uint, 0644);
+module_param(tspecCompliance, int, 0644);
+module_param(onebitmode, uint, 0644);
+module_param(busspeedlow, uint, 0644);
+module_param(skipflash, uint, 0644);
+module_param(wmitimeout, uint, 0644);
+module_param(wlanNodeCaching, uint, 0644);
+module_param(logWmiRawMsgs, uint, 0644);
+module_param(enableuartprint, uint, 0644);
+module_param(enabletimerwar, uint, 0644);
+module_param(mbox_yield_limit, uint, 0644);
+module_param(reduce_credit_dribble, int, 0644);
+module_param(allow_trace_signal, int, 0644);
+module_param(enablerssicompensation, uint, 0644);
+module_param(processDot11Hdr, uint, 0644);
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+module_param(csumOffload, uint, 0644);
+#endif
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+module_param(testmode, uint, 0644);
+#endif
+module_param(firmware_bridge, uint, 0644);
+module_param(irqprocmode, uint, 0644);
+module_param(nohifscattersupport, uint, 0644);
+module_param(panic_on_assert, uint, 0644);
+module_param(setuphci, uint, 0644);
+module_param(setuphcipal, uint, 0644);
+module_param(loghci, uint, 0644);
+module_param(setupbtdev, uint, 0644);
+#ifndef EXPORT_HCI_BRIDGE_INTERFACE
+module_param(ar3khcibaud, uint, 0644);
+module_param(hciuartscale, uint, 0644);
+module_param(hciuartstep, uint, 0644);
+#endif
+module_param(eppingtest, uint, 0644);
+module_param(regscanmode, uint, 0644);
+module_param_string(devmode, devmode, sizeof(devmode), 0644);
+module_param_string(submode, submode, sizeof(submode), 0644);
+module_param_string(targetconf, targetconf, sizeof(targetconf), 0644);
+module_param(rtc_reset_only_on_exit, uint, 0644);
+module_param(mac_addr_method, uint, 0644);
+module_param(refClock, uint, 0644);
+module_param(max_psq_depth, uint, 0644);
+#else
+
+#define __user
+/* for linux 2.4 and lower */
+MODULE_PARM(bmienable,"i");
+MODULE_PARM(wlaninitmode,"i");
+MODULE_PARM(bypasswmi,"i");
+MODULE_PARM(debuglevel, "i");
+MODULE_PARM(onebitmode,"i");
+MODULE_PARM(busspeedlow, "i");
+MODULE_PARM(skipflash, "i");
+MODULE_PARM(wmitimeout, "i");
+MODULE_PARM(wlanNodeCaching, "i");
+MODULE_PARM(enableuartprint,"i");
+MODULE_PARM(logWmiRawMsgs, "i");
+MODULE_PARM(enabletimerwar,"i");
+MODULE_PARM(mbox_yield_limit,"i");
+MODULE_PARM(reduce_credit_dribble,"i");
+MODULE_PARM(allow_trace_signal,"i");
+MODULE_PARM(enablerssicompensation,"i");
+MODULE_PARM(processDot11Hdr,"i");
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+MODULE_PARM(csumOffload,"i");
+#endif
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+MODULE_PARM(testmode, "i");
+#endif
+MODULE_PARM(irqprocmode, "i");
+MODULE_PARM(nohifscattersupport, "i");
+MODULE_PARM(panic_on_assert, "i");
+MODULE_PARM(setuphci, "i");
+MODULE_PARM(setuphcipal, "i");
+MODULE_PARM(loghci, "i");
+MODULE_PARM(regscanmode, "i");
+MODULE_PARM(rtc_reset_only_on_exit, "i");
+MODULE_PARM(mac_addr_method, "i");
+MODULE_PARM(refClock, "i");
+MODULE_PARM(max_psq_depth, "i");
+#endif
+
+#if WLAN_CONFIG_FIRST_SCAN_2G_ONLY
+unsigned int first_scan_2g_only = WLAN_CONFIG_FIRST_SCAN_2G_ONLY;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+module_param(first_scan_2g_only, uint, 0644);
+#else
+MODULE_PARM(first_scan_2g_only, "i");
+#endif
+#endif
+
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,10)
+/* in 2.6.10 and later this is now a pointer to a uint */
+unsigned int _mboxnum = HTC_MAILBOX_NUM_MAX;
+#define mboxnum &_mboxnum
+#else
+unsigned int mboxnum = HTC_MAILBOX_NUM_MAX;
+#endif
+
+#ifdef DEBUG
+A_UINT32 g_dbg_flags = DBG_DEFAULTS;
+unsigned int debugflags = 0;
+int debugdriver = 0;
+unsigned int debughtc = 0;
+unsigned int debugbmi = 0;
+unsigned int debughif = 0;
+unsigned int txcreditsavailable[HTC_MAILBOX_NUM_MAX] = {0};
+unsigned int txcreditsconsumed[HTC_MAILBOX_NUM_MAX] = {0};
+unsigned int txcreditintrenable[HTC_MAILBOX_NUM_MAX] = {0};
+unsigned int txcreditintrenableaggregate[HTC_MAILBOX_NUM_MAX] = {0};
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+module_param(debugflags, uint, 0644);
+module_param(debugdriver, int, 0644);
+module_param(debughtc, uint, 0644);
+module_param(debugbmi, uint, 0644);
+module_param(debughif, uint, 0644);
+module_param_array(txcreditsavailable, uint, mboxnum, 0644);
+module_param_array(txcreditsconsumed, uint, mboxnum, 0644);
+module_param_array(txcreditintrenable, uint, mboxnum, 0644);
+module_param_array(txcreditintrenableaggregate, uint, mboxnum, 0644);
+#else
+/* linux 2.4 and lower */
+MODULE_PARM(debugflags,"i");
+MODULE_PARM(debugdriver, "i");
+MODULE_PARM(debughtc, "i");
+MODULE_PARM(debugbmi, "i");
+MODULE_PARM(debughif, "i");
+MODULE_PARM(txcreditsavailable, "0-3i");
+MODULE_PARM(txcreditsconsumed, "0-3i");
+MODULE_PARM(txcreditintrenable, "0-3i");
+MODULE_PARM(txcreditintrenableaggregate, "0-3i");
+#endif
+
+#endif /* DEBUG */
+
+unsigned int resetok = 1;
+unsigned int tx_attempt[HTC_MAILBOX_NUM_MAX] = {0};
+unsigned int tx_post[HTC_MAILBOX_NUM_MAX] = {0};
+unsigned int tx_complete[HTC_MAILBOX_NUM_MAX] = {0};
+unsigned int hifBusRequestNumMax = 40;
+unsigned int war23838_disabled = 0;
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+unsigned int enableAPTCHeuristics = 1;
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+unsigned int psm_info = 99;
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+module_param_array(tx_attempt, uint, mboxnum, 0644);
+module_param_array(tx_post, uint, mboxnum, 0644);
+module_param_array(tx_complete, uint, mboxnum, 0644);
+module_param(hifBusRequestNumMax, uint, 0644);
+module_param(war23838_disabled, uint, 0644);
+module_param(resetok, uint, 0644);
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+module_param(enableAPTCHeuristics, uint, 0644);
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+module_param(psm_info, uint, 0444);
+#else
+MODULE_PARM(tx_attempt, "0-3i");
+MODULE_PARM(tx_post, "0-3i");
+MODULE_PARM(tx_complete, "0-3i");
+MODULE_PARM(hifBusRequestNumMax, "i");
+MODULE_PARM(war23838_disabled, "i");
+MODULE_PARM(resetok, "i");
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+MODULE_PARM(enableAPTCHeuristics, "i");
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+MODULE_PARM(psm_info, "i");
+#endif
+
+#ifdef BLOCK_TX_PATH_FLAG
+int blocktx = 0;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+module_param(blocktx, int, 0644);
+#else
+MODULE_PARM(blocktx, "i");
+#endif
+#endif /* BLOCK_TX_PATH_FLAG */
+
+static A_INT16 rssi_compensation_table[NUM_DEV][96];
+
+int reconnect_flag = 0;
+static ar6k_pal_config_t ar6k_pal_config_g;
+
+// Load unload synchronization
+DECLARE_WAIT_QUEUE_HEAD(load_complete);
+DECLARE_WAIT_QUEUE_HEAD(scan_complete);
+
+// Indicates if the module load completed
+static int mod_loaded = FALSE;
+
+/* Function declarations */
+static int ar6000_init_module(void);
+static void ar6000_cleanup_module(void);
+
+struct completion avail_ev_completion;
+
+int ar6000_init(struct net_device *dev);
+static int ar6000_open(struct net_device *dev);
+static int ar6000_close(struct net_device *dev);
+static int ar6000_init_control_info(AR_SOFTC_DEV_T *arPriv);
+static int ar6000_data_tx(struct sk_buff *skb, struct net_device *dev);
+
+void ar6000_destroy(struct net_device *dev, unsigned int unregister);
+void ar6000_cleanup(AR_SOFTC_T *ar);
+static void ar6000_detect_error(unsigned long ptr);
+static void ar6000_set_multicast_list(struct net_device *dev);
+static struct net_device_stats *ar6000_get_stats(struct net_device *dev);
+static struct iw_statistics *ar6000_get_iwstats(struct net_device * dev);
+
+static void disconnect_timer_handler(unsigned long ptr);
+
+void read_rssi_compensation_param(AR_SOFTC_T *ar);
+void target_register_tbl_attach(A_UINT32 target_type);
+static void ar6000_uapsd_trigger_frame_rx(AR_SOFTC_DEV_T *arPriv, conn_t *conn);
+static void delba_timer_callback(unsigned long ptr);
+static int ar6000_check_hold_conn_status(AR_SOFTC_DEV_T *arPriv, A_UINT8 conn_status);
+
+extern int android_readwrite_file(const A_CHAR *filename, A_CHAR *rbuf, const A_CHAR *wbuf, size_t length);
+ /* for android builds we call external APIs that handle firmware download and configuration */
+#ifdef ANDROID_ENV
+/* !!!! Interim android support to make it easier to patch the default driver for
+ * android use. You must define an external source file ar6000_android.c that handles the following
+ * APIs */
+extern void android_module_init(OSDRV_CALLBACKS *osdrvCallbacks);
+extern void android_module_exit(void);
+extern void android_send_reload_event(AR_SOFTC_DEV_T *arPriv);
+#define ANDROID_RELOAD_THRESHOLD_FOR_EP_FULL 5
+static int android_epfull_cnt;
+#endif
+/*
+ * HTC service connection handlers
+ */
+static A_STATUS ar6000_avail_ev(void *context, void *hif_handle);
+
+static A_STATUS ar6000_unavail_ev(void *context, void *hif_handle);
+
+A_STATUS ar6000_configure_target(AR_SOFTC_T *ar);
+
+static void ar6000_target_failure(void *Instance, A_STATUS Status);
+
+static void ar6000_rx(void *Context, HTC_PACKET *pPacket);
+
+static void ar6000_rx_refill(void *Context,HTC_ENDPOINT_ID Endpoint);
+
+static void ar6000_tx_complete(void *Context, HTC_PACKET_QUEUE *pPackets);
+
+static HTC_SEND_FULL_ACTION ar6000_tx_queue_full(void *Context, HTC_PACKET *pPacket);
+
+#ifdef ATH_AR6K_11N_SUPPORT
+static void ar6000_alloc_netbufs(A_NETBUF_QUEUE_T *q, A_UINT16 num);
+#endif
+static void ar6000_deliver_frames_to_nw_stack(void * dev, void *osbuf);
+//static void ar6000_deliver_frames_to_bt_stack(void * dev, void *osbuf);
+
+static HTC_PACKET *ar6000_alloc_amsdu_rxbuf(void *Context, HTC_ENDPOINT_ID Endpoint, int Length);
+
+static void ar6000_refill_amsdu_rxbufs(AR_SOFTC_T *ar, int Count);
+
+static void ar6000_cleanup_amsdu_rxbufs(AR_SOFTC_T *ar);
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,35)
+static ssize_t
+ar6000_sysfs_bmi_read(struct kobject *kobj, struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count);
+
+static ssize_t
+ar6000_sysfs_bmi_write(struct kobject *kobj, struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count);
+#else
+static ssize_t
+ar6000_sysfs_bmi_read(struct file *fp, struct kobject *kobj,
+ struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count);
+
+static ssize_t
+ar6000_sysfs_bmi_write(struct file *fp, struct kobject *kobj,
+ struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count);
+#endif
+
+static A_STATUS
+ar6000_sysfs_bmi_init(AR_SOFTC_T *ar);
+
+/* HCI PAL callback function declarations */
+A_STATUS ar6k_setup_hci_pal(AR_SOFTC_DEV_T *ar);
+void ar6k_cleanup_hci_pal(AR_SOFTC_DEV_T *ar);
+
+static void
+ar6000_sysfs_bmi_deinit(AR_SOFTC_T *ar);
+
+A_STATUS
+ar6000_sysfs_bmi_get_config(AR_SOFTC_T *ar, A_UINT32 mode);
+
+/*
+ * Static variables
+ */
+
+struct net_device *ar6000_devices[NUM_DEV];
+extern struct iw_handler_def ath_iw_handler_def;
+static void ar6000_cookie_init(AR_SOFTC_T *ar);
+static void ar6000_cookie_cleanup(AR_SOFTC_T *ar);
+static void ar6000_free_cookie(AR_SOFTC_T *ar, struct ar_cookie * cookie);
+static struct ar_cookie *ar6000_alloc_cookie(AR_SOFTC_T *ar);
+
+#ifdef USER_KEYS
+static A_STATUS ar6000_reinstall_keys(AR_SOFTC_DEV_T *arPriv,A_UINT8 key_op_ctrl);
+#endif
+
+
+static struct ar_cookie s_ar_cookie_mem[MAX_COOKIE_NUM];
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,29)
+static struct net_device_ops ar6000_netdev_ops = {
+ .ndo_init = NULL,
+ .ndo_open = ar6000_open,
+ .ndo_stop = ar6000_close,
+ .ndo_get_stats = ar6000_get_stats,
+ .ndo_do_ioctl = ar6000_ioctl,
+ .ndo_start_xmit = ar6000_data_tx,
+ .ndo_set_multicast_list = ar6000_set_multicast_list,
+ .ndo_change_mtu = eth_change_mtu,
+};
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,29) */
+
+/* Debug log support */
+
+/*
+ * Flag to govern whether the debug logs should be parsed in the kernel
+ * or reported to the application.
+ */
+#define REPORT_DEBUG_LOGS_TO_APP
+
+A_STATUS
+ar6000_set_host_app_area(AR_SOFTC_T *ar)
+{
+ A_UINT32 address, data;
+ struct host_app_area_s host_app_area;
+
+ /* Fetch the address of the host_app_area_s instance in the host interest area */
+ address = TARG_VTOP(ar->arTargetType, HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_app_host_interest));
+ if (ar6000_ReadRegDiag(ar->arHifDevice, &address, &data) != A_OK) {
+ return A_ERROR;
+ }
+ address = TARG_VTOP(ar->arTargetType, data);
+ host_app_area.wmi_protocol_ver = WMI_PROTOCOL_VERSION;
+ if (ar6000_WriteDataDiag(ar->arHifDevice, address,
+ (A_UCHAR *)&host_app_area,
+ sizeof(struct host_app_area_s)) != A_OK)
+ {
+ return A_ERROR;
+ }
+
+ return A_OK;
+}
+
+A_UINT32
+dbglog_get_debug_hdr_ptr(AR_SOFTC_T *ar)
+{
+ A_UINT32 param;
+ A_UINT32 address;
+ A_STATUS status;
+
+ address = TARG_VTOP(ar->arTargetType, HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_dbglog_hdr));
+ if ((status = ar6000_ReadDataDiag(ar->arHifDevice, address,
+ (A_UCHAR *)¶m, 4)) != A_OK)
+ {
+ param = 0;
+ }
+
+ return param;
+}
+
+/*
+ * The dbglog module has been initialized. Its ok to access the relevant
+ * data stuctures over the diagnostic window.
+ */
+void
+ar6000_dbglog_init_done(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ ar->dbglog_init_done = TRUE;
+}
+
+A_UINT32
+dbglog_get_debug_fragment(A_INT8 *datap, A_UINT32 len, A_UINT32 limit)
+{
+ A_INT32 *buffer;
+ A_UINT32 count;
+ A_UINT32 numargs;
+ A_UINT32 length;
+ A_UINT32 fraglen;
+
+ count = fraglen = 0;
+ buffer = (A_INT32 *)datap;
+ length = (limit >> 2);
+
+ if (len <= limit) {
+ fraglen = len;
+ } else {
+ while (count < length) {
+ numargs = DBGLOG_GET_NUMARGS(buffer[count]);
+ fraglen = (count << 2);
+ count += numargs + 1;
+ }
+ }
+
+ return fraglen;
+}
+
+void
+dbglog_parse_debug_logs(A_INT8 *datap, A_UINT32 len)
+{
+ A_INT32 *buffer;
+ A_UINT32 count;
+ A_UINT32 timestamp;
+ A_UINT32 debugid;
+ A_UINT32 moduleid;
+ A_UINT32 numargs;
+ A_UINT32 length;
+
+ count = 0;
+ buffer = (A_INT32 *)datap;
+ length = (len >> 2);
+ while (count < length) {
+ debugid = DBGLOG_GET_DBGID(buffer[count]);
+ moduleid = DBGLOG_GET_MODULEID(buffer[count]);
+ numargs = DBGLOG_GET_NUMARGS(buffer[count]);
+ timestamp = DBGLOG_GET_TIMESTAMP(buffer[count]);
+ switch (numargs) {
+ case 0:
+ AR_DEBUG_PRINTF(ATH_DEBUG_DBG_LOG,("%d %d (%d)\n", moduleid, debugid, timestamp));
+ break;
+
+ case 1:
+ AR_DEBUG_PRINTF(ATH_DEBUG_DBG_LOG,("%d %d (%d): 0x%x\n", moduleid, debugid,
+ timestamp, buffer[count+1]));
+ break;
+
+ case 2:
+ AR_DEBUG_PRINTF(ATH_DEBUG_DBG_LOG,("%d %d (%d): 0x%x, 0x%x\n", moduleid, debugid,
+ timestamp, buffer[count+1], buffer[count+2]));
+ break;
+
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Invalid args: %d\n", numargs));
+ }
+ count += numargs + 1;
+ }
+}
+
+int
+ar6000_dbglog_get_debug_logs(AR_SOFTC_T *ar)
+{
+ struct dbglog_hdr_s debug_hdr;
+ struct dbglog_buf_s debug_buf;
+ A_UINT32 address;
+ A_UINT32 length;
+ A_UINT32 dropped;
+ A_UINT32 firstbuf;
+ A_UINT32 debug_hdr_ptr;
+
+ if (!ar->dbglog_init_done) return A_ERROR;
+
+
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ if (ar->dbgLogFetchInProgress) {
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ return A_EBUSY;
+ }
+
+ /* block out others */
+ ar->dbgLogFetchInProgress = TRUE;
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ debug_hdr_ptr = dbglog_get_debug_hdr_ptr(ar);
+ printk("debug_hdr_ptr: 0x%x\n", debug_hdr_ptr);
+
+ /* Get the contents of the ring buffer */
+ if (debug_hdr_ptr) {
+ address = TARG_VTOP(ar->arTargetType, debug_hdr_ptr);
+ length = sizeof(struct dbglog_hdr_s);
+ ar6000_ReadDataDiag(ar->arHifDevice, address,
+ (A_UCHAR *)&debug_hdr, length);
+ address = TARG_VTOP(ar->arTargetType, (A_UINT32)debug_hdr.dbuf);
+ firstbuf = address;
+ dropped = debug_hdr.dropped;
+ length = sizeof(struct dbglog_buf_s);
+ ar6000_ReadDataDiag(ar->arHifDevice, address,
+ (A_UCHAR *)&debug_buf, length);
+
+ do {
+ address = TARG_VTOP(ar->arTargetType, (A_UINT32)debug_buf.buffer);
+ length = debug_buf.length;
+ if ((length) && (debug_buf.length <= debug_buf.bufsize)) {
+ /* Rewind the index if it is about to overrun the buffer */
+ if (ar->log_cnt > (DBGLOG_HOST_LOG_BUFFER_SIZE - length)) {
+ ar->log_cnt = 0;
+ }
+ if(A_OK != ar6000_ReadDataDiag(ar->arHifDevice, address,
+ (A_UCHAR *)&ar->log_buffer[ar->log_cnt], length))
+ {
+ break;
+ }
+ ar6000_dbglog_event(ar->arDev[0], dropped, (A_INT8*)&ar->log_buffer[ar->log_cnt], length);
+ ar->log_cnt += length;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_DBG_LOG,("Length: %d (Total size: %d)\n",
+ debug_buf.length, debug_buf.bufsize));
+ }
+
+ address = TARG_VTOP(ar->arTargetType, (A_UINT32)debug_buf.next);
+ length = sizeof(struct dbglog_buf_s);
+ if(A_OK != ar6000_ReadDataDiag(ar->arHifDevice, address,
+ (A_UCHAR *)&debug_buf, length))
+ {
+ break;
+ }
+
+ } while (address != firstbuf);
+ }
+
+ ar->dbgLogFetchInProgress = FALSE;
+
+ return A_OK;
+}
+
+void
+ar6000_dbglog_event(AR_SOFTC_DEV_T *arPriv, A_UINT32 dropped,
+ A_INT8 *buffer, A_UINT32 length)
+{
+#ifdef REPORT_DEBUG_LOGS_TO_APP
+ #define MAX_WIRELESS_EVENT_SIZE 252
+ /*
+ * Break it up into chunks of MAX_WIRELESS_EVENT_SIZE bytes of messages.
+ * There seems to be a limitation on the length of message that could be
+ * transmitted to the user app via this mechanism.
+ */
+ A_UINT32 send, sent;
+
+ sent = 0;
+ send = dbglog_get_debug_fragment(&buffer[sent], length - sent,
+ MAX_WIRELESS_EVENT_SIZE);
+ while (send) {
+ ar6000_send_event_to_app(arPriv, WMIX_DBGLOG_EVENTID, (A_UINT8*)&buffer[sent], send);
+ sent += send;
+ send = dbglog_get_debug_fragment(&buffer[sent], length - sent,
+ MAX_WIRELESS_EVENT_SIZE);
+ }
+#else
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Dropped logs: 0x%x\nDebug info length: %d\n",
+ dropped, length));
+
+ /* Interpret the debug logs */
+ dbglog_parse_debug_logs((A_INT8*)buffer, length);
+#endif /* REPORT_DEBUG_LOGS_TO_APP */
+}
+
+void
+ar6000_parse_dev_mode(A_CHAR *mode)
+{
+ A_UINT8 i, match = FALSE, mode_len;
+#ifdef P2P
+ A_UINT8 val_mode, val_submode;
+#endif
+ A_UINT8 num_submode;
+
+ char *valid_modes[] = { "sta",
+ "ap",
+ "ibss",
+ "bt30amp",
+ "sta,ap",
+ "ap,sta",
+ "ap,ap",
+ "sta,sta",
+ "sta,bt30amp",
+ "sta,ap,ap"
+ };
+#ifdef P2P
+ char *valid_submodes[] = { "none",
+ "p2pdev",
+ /*"p2pclient",*/ //persistent p2p support
+ /*"p2pgo", */ // persistent p2p support
+ "none,none",
+ "none,none,none",
+ "none,p2pdev",
+ "p2pdev,none",
+ /*"none,p2pclient",*/ //persistent p2p support
+ /*"none,p2pgo"*/ // persistent p2p support
+ };
+#endif
+ A_CHAR *dev_mode;
+ A_CHAR *str;
+ A_UINT32 host_int = 0;
+
+ dev_mode = mode;
+ str = mode;
+ num_device = 0;
+ fwmode = 0;
+
+ mode_len = strlen(dev_mode);
+ for (i=0; i <= 9; i++) {
+ if ((mode_len == strlen(valid_modes[i])) && (strcmp(dev_mode,valid_modes[i]))==0) {
+ match = TRUE;
+ break;
+ }
+ }
+
+ if(!match) {
+ num_device = fwmode = 1;
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ERROR: Wrong mode. using default (single device STA mode).\n"));
+ return;
+ }
+
+ do
+ {
+ str++;
+ if(*str == ',' || *str == '\0') {
+ num_device++;
+ if(strncmp(dev_mode,"ap",2) == 0) {
+ host_int = HI_OPTION_FW_MODE_AP;
+ }
+ else if(strncmp(dev_mode,"sta",3) == 0) {
+ host_int = HI_OPTION_FW_MODE_BSS_STA;
+ }
+ else if(strncmp(dev_mode,"ibss",4) == 0 ) {
+ host_int = HI_OPTION_FW_MODE_IBSS;
+ } else if(strncmp(dev_mode,"bt30amp",7) == 0) {
+ host_int = HI_OPTION_FW_MODE_BT30AMP;
+ }
+
+ fwmode |= (host_int << ((num_device -1) * HI_OPTION_FW_MODE_BITS));
+ dev_mode = ++str;
+ }
+ }while(*dev_mode != '\0');
+
+ /* Validate submode if present */
+ if (!submode[0]) {
+ /* default "none" submode for all devices */
+ fwsubmode = 0;
+ return;
+ }
+
+ dev_mode = submode;
+ str = submode;
+ num_submode = 0;
+ fwsubmode = 0;
+ match = FALSE;
+
+#ifdef P2P
+ mode_len = strlen(dev_mode);
+ for (i=0; i<6; i++) {
+ if ((mode_len == strlen(valid_submodes[i])) && (strcmp(dev_mode,valid_submodes[i]))==0) {
+ match = TRUE;
+ break;
+ }
+ }
+
+ if (!match) {
+ fwsubmode = 0;
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ERROR: Wrong submode. using default (none for all devs).\n"));
+ return;
+ }
+
+ do
+ {
+ str++;
+ if(*str == ',' || *str == '\0') {
+ num_submode++;
+ if(strncmp(dev_mode,"none",4) == 0) {
+ host_int = HI_OPTION_FW_SUBMODE_NONE;
+ }
+ else if(strncmp(dev_mode,"p2pdev",6) == 0) {
+ host_int = HI_OPTION_FW_SUBMODE_P2PDEV;
+ }
+ else if(strncmp(dev_mode,"p2pclient",9) == 0 ) {
+ host_int = HI_OPTION_FW_SUBMODE_P2PCLIENT;
+ } else if(strncmp(dev_mode,"p2pgo",5) == 0 ) {
+ host_int = HI_OPTION_FW_SUBMODE_P2PGO;
+ }
+ fwsubmode |= (host_int << ((num_submode -1) * HI_OPTION_FW_SUBMODE_BITS));
+ dev_mode = ++str;
+ }
+ }while(*dev_mode != '\0');
+
+ /* Validate if the subopmode is specified for all the devs.
+ */
+ if (num_device != num_submode) {
+ /* default to "none" submode for all devices */
+ fwsubmode = 0;
+ return;
+ }
+
+ /* Validate if the submode specified is appropriate for the device modes
+ * specified for each device. The following is the validation recipe.
+ * fwmode fwsubmode
+ * -----------------------
+ * IBSS none
+ * STA none,p2pdev,p2pclient
+ * AP none,p2pgo
+ */
+ for (i=0; i<num_device; i++) {
+ val_mode = (fwmode >> (i * HI_OPTION_FW_MODE_BITS)) &
+ HI_OPTION_FW_MODE_MASK;
+ val_submode = (fwsubmode >> (i * HI_OPTION_FW_SUBMODE_BITS)) &
+ HI_OPTION_FW_SUBMODE_MASK;
+ switch (val_mode) {
+ case HI_OPTION_FW_MODE_IBSS:
+ if (val_submode != HI_OPTION_FW_SUBMODE_NONE) {
+ /* set submode to none */
+ fwsubmode &= ~(HI_OPTION_FW_SUBMODE_MASK << (i*HI_OPTION_FW_SUBMODE_BITS));
+ fwsubmode |= (HI_OPTION_FW_SUBMODE_NONE << (i * HI_OPTION_FW_SUBMODE_BITS));
+ }
+ break;
+
+ case HI_OPTION_FW_MODE_BSS_STA:
+ if (val_submode == HI_OPTION_FW_SUBMODE_P2PGO) {
+ /* set submode to none */
+ fwsubmode &= ~(HI_OPTION_FW_SUBMODE_MASK << (i*HI_OPTION_FW_SUBMODE_BITS));
+ fwsubmode |= (HI_OPTION_FW_SUBMODE_NONE << (i * HI_OPTION_FW_SUBMODE_BITS));
+ }
+
+ break;
+ case HI_OPTION_FW_MODE_AP:
+ if (val_submode == HI_OPTION_FW_SUBMODE_P2PDEV ||
+ val_submode == HI_OPTION_FW_SUBMODE_P2PCLIENT) {
+ /* set submode to none */
+ fwsubmode &= ~(HI_OPTION_FW_SUBMODE_MASK << (i*HI_OPTION_FW_SUBMODE_BITS));
+ fwsubmode |= (HI_OPTION_FW_SUBMODE_NONE << (i * HI_OPTION_FW_SUBMODE_BITS));
+ }
+ break;
+
+ default:
+ break;
+ }
+ }
+#endif
+ return;
+}
+
+static int __init
+ar6000_init_module(void)
+{
+ static int probed = 0;
+ A_STATUS status;
+ OSDRV_CALLBACKS osdrvCallbacks;
+
+ a_module_debug_support_init();
+ printk("init-AR6003-driver 844\n");
+
+#ifdef DEBUG
+ /* check for debug mask overrides */
+ if (debughtc != 0) {
+ ATH_DEBUG_SET_DEBUG_MASK(htc,debughtc);
+ }
+ if (debugbmi != 0) {
+ ATH_DEBUG_SET_DEBUG_MASK(bmi,debugbmi);
+ }
+ if (debughif != 0) {
+ ATH_DEBUG_SET_DEBUG_MASK(hif,debughif);
+ }
+ if (debugdriver != 0) {
+ ATH_DEBUG_SET_DEBUG_MASK(driver,debugdriver);
+ }
+
+#endif
+
+ A_REGISTER_MODULE_DEBUG_INFO(driver);
+ ar6k_init = FALSE;
+ A_MEMZERO(&osdrvCallbacks,sizeof(osdrvCallbacks));
+ osdrvCallbacks.deviceInsertedHandler = ar6000_avail_ev;
+ osdrvCallbacks.deviceRemovedHandler = ar6000_unavail_ev;
+
+#ifdef CONFIG_PM
+ osdrvCallbacks.deviceSuspendHandler = ar6000_suspend_ev;
+ osdrvCallbacks.deviceResumeHandler = ar6000_resume_ev;
+ osdrvCallbacks.devicePowerChangeHandler = ar6000_power_change_ev;
+#endif
+
+ init_completion(&avail_ev_completion);
+
+ ar6000_pm_init();
+ if(devmode[0])
+ ar6000_parse_dev_mode(devmode);
+
+#ifdef ANDROID_ENV
+ android_module_init(&osdrvCallbacks);
+#endif
+
+#ifdef DEBUG
+ /* Set the debug flags if specified at load time */
+ if(debugflags != 0)
+ {
+ g_dbg_flags = debugflags;
+ }
+#endif
+
+ if (probed) {
+ return -ENODEV;
+ }
+ probed++;
+
+#ifdef CONFIG_HOST_GPIO_SUPPORT
+ ar6000_gpio_init();
+#endif /* CONFIG_HOST_GPIO_SUPPORT */
+
+ status = HIFInit(&osdrvCallbacks);
+ if(status != A_OK)
+ return -ENODEV;
+
+ return 0;
+}
+
+#define AR6K_AVAIL_EV_COMPLETION_TIMEOUT (60 * HZ)
+
+static void __exit
+ar6000_cleanup_module(void)
+{
+ int i = 0;
+ struct net_device *ar6000_netdev;
+ AR_SOFTC_T *ar;
+ AR_SOFTC_DEV_T *arPriv = NULL;
+ unsigned long tmo = AR6K_AVAIL_EV_COMPLETION_TIMEOUT;
+
+ if (!wait_event_interruptible_timeout(load_complete, mod_loaded != FALSE, 5 * HZ)) {
+ printk(KERN_ERR "Load did not complete. Unload did not proceed\n");
+ return;
+ }
+ A_PRINTF("\nAR6K: %s()\n", __func__);
+
+ tmo = wait_for_completion_timeout(&avail_ev_completion, tmo);
+ if (tmo == 0) {
+ A_PRINTF("AR6K: wait for avail_ev_completion %d sec timeout\n",
+ AR6K_AVAIL_EV_COMPLETION_TIMEOUT / HZ);
+ }
+
+ if (ar6000_devices[0] != NULL) {
+ arPriv = (AR_SOFTC_DEV_T *) ar6k_priv(ar6000_devices[0]);
+ ar = arPriv->arSoftc;
+ ar6000_cleanup(ar);
+ }
+ for (i=0; i < num_device; i++) {
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+ /* Delete the Adaptive Power Control timer */
+ if (timer_pending(&aptcTimer[i])) {
+ del_timer_sync(&aptcTimer[i]);
+ }
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+ if (ar6000_devices[i] != NULL) {
+ arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ if (arPriv) {
+ A_UNTIMEOUT(&arPriv->arSta.disconnect_timer);
+ }
+ ar6000_netdev = ar6000_devices[i];
+ ar6000_devices[i] = NULL;
+ ar6000_destroy(ar6000_netdev, 1);
+ }
+ }
+#ifdef P2P
+ p2p_deinit();
+#endif /* P2P */
+
+ HIFShutDownDevice(NULL);
+
+ a_module_debug_support_cleanup();
+
+ ar6000_pm_exit();
+
+
+#ifdef ANDROID_ENV
+ android_module_exit();
+#endif
+ a_meminfo_report(TRUE);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ar6000_cleanup: success\n"));
+}
+
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+void
+aptcTimerHandler(unsigned long arg)
+{
+ A_UINT32 numbytes;
+ A_UINT32 throughput;
+ AR_SOFTC_T *ar;
+ A_STATUS status;
+ APTC_TRAFFIC_RECORD *aptcTR;
+ A_UNIT8 i;
+
+ ar = (AR_SOFTC_T *)arg;
+ A_ASSERT(ar != NULL);
+
+ for(i = 0; i < num_device; i++) {
+ aptcTR = ar->arDev[i].aptcTR;
+ A_ASSERT(!timer_pending(&aptcTimer[i]));
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ /* Get the number of bytes transferred */
+ numbytes = aptcTR->bytesTransmitted + aptcTR->bytesReceived;
+ aptcTR->bytesTransmitted = aptcTR->bytesReceived = 0;
+
+ /* Calculate and decide based on throughput thresholds */
+ throughput = ((numbytes * 8)/APTC_TRAFFIC_SAMPLING_INTERVAL); /* Kbps */
+ if (throughput < APTC_LOWER_THROUGHPUT_THRESHOLD) {
+ /* Enable Sleep and delete the timer */
+ A_ASSERT(ar->arWmiReady == TRUE);
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ status = wmi_powermode_cmd(ar->arWmi, REC_POWER);
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ A_ASSERT(status == A_OK);
+ aptcTR->timerScheduled = FALSE;
+ } else {
+ A_TIMEOUT_MS(&aptcTimer[i], APTC_TRAFFIC_SAMPLING_INTERVAL, 0);
+ }
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ }
+}
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+
+#ifdef ATH_AR6K_11N_SUPPORT
+static void
+ar6000_alloc_netbufs(A_NETBUF_QUEUE_T *q, A_UINT16 num)
+{
+ void * osbuf;
+
+ while(num) {
+ if((osbuf = A_NETBUF_ALLOC(AR6000_BUFFER_SIZE))) {
+ A_NETBUF_ENQUEUE(q, osbuf);
+ } else {
+ break;
+ }
+ num--;
+ }
+
+ if(num) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s(), allocation of netbuf failed", __func__));
+ }
+}
+#endif
+
+static struct bin_attribute bmi_attr = {
+ .attr = {.name = "bmi", .mode = 0600},
+ .read = ar6000_sysfs_bmi_read,
+ .write = ar6000_sysfs_bmi_write,
+};
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,35)
+static ssize_t
+ar6000_sysfs_bmi_read(struct kobject *kobj, struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count)
+#else
+static ssize_t
+ar6000_sysfs_bmi_read(struct file *fp, struct kobject *kobj,
+ struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count)
+#endif
+{
+ int index;
+ AR_SOFTC_DEV_T *arPriv;
+ AR_SOFTC_T *ar = NULL;
+ HIF_DEVICE_OS_DEVICE_INFO *osDevInfo;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("BMI: Read %d bytes\n", count));
+ for (index=0; index < num_device; index++) {
+ arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[index]);
+ ar = arPriv->arSoftc;
+ osDevInfo = &ar->osDevInfo;
+ if (kobj == (&(((struct device *)osDevInfo->pOSDevice)->kobj))) {
+ break;
+ }
+ }
+
+ if (ar == NULL) return 0;
+ if (index == num_device) return 0;
+
+ if ((BMIRawRead(ar->arHifDevice, (A_UCHAR*)buf, count, TRUE)) != A_OK) {
+ return 0;
+ }
+
+ return count;
+}
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,35)
+static ssize_t
+ar6000_sysfs_bmi_write(struct kobject *kobj, struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count)
+#else
+static ssize_t
+ar6000_sysfs_bmi_write(struct file *fp, struct kobject *kobj,
+ struct bin_attribute *bin_attr,
+ char *buf, loff_t pos, size_t count)
+#endif
+{
+ int index;
+ AR_SOFTC_DEV_T *arPriv;
+ AR_SOFTC_T *ar = NULL;
+ HIF_DEVICE_OS_DEVICE_INFO *osDevInfo;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("BMI: Write %d bytes\n", count));
+ for (index=0; index < num_device; index++) {
+ arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[index]);
+ ar = arPriv->arSoftc;
+ osDevInfo = &ar->osDevInfo;
+ if (kobj == (&(((struct device *)osDevInfo->pOSDevice)->kobj))) {
+ break;
+ }
+ }
+
+ if (ar == NULL) return 0;
+ if (index == num_device) return 0;
+
+ if ((BMIRawWrite(ar->arHifDevice, (A_UCHAR*)buf, count)) != A_OK) {
+ return 0;
+ }
+
+ return count;
+}
+
+static A_STATUS
+ar6000_sysfs_bmi_init(AR_SOFTC_T *ar)
+{
+ A_STATUS status;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("BMI: Creating sysfs entry\n"));
+ A_MEMZERO(&ar->osDevInfo, sizeof(HIF_DEVICE_OS_DEVICE_INFO));
+
+ /* Get the underlying OS device */
+ status = HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_GET_OS_DEVICE,
+ &ar->osDevInfo,
+ sizeof(HIF_DEVICE_OS_DEVICE_INFO));
+
+ if (A_FAILED(status)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("BMI: Failed to get OS device info from HIF\n"));
+ return A_ERROR;
+ }
+
+ /* Create a bmi entry in the sysfs filesystem */
+ if ((sysfs_create_bin_file(&(((struct device *)ar->osDevInfo.pOSDevice)->kobj), &bmi_attr)) < 0)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMI: Failed to create entry for bmi in sysfs filesystem\n"));
+ return A_ERROR;
+ }
+
+ return A_OK;
+}
+
+static void
+ar6000_sysfs_bmi_deinit(AR_SOFTC_T *ar)
+{
+ if (ar->osDevInfo.pOSDevice) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("BMI: Deleting sysfs entry\n"));
+ sysfs_remove_bin_file(&(((struct device *)ar->osDevInfo.pOSDevice)->kobj), &bmi_attr);
+ ar->osDevInfo.pOSDevice = NULL;
+ }
+}
+
+#define bmifn(fn) do { \
+ if ((fn) < A_OK) { \
+ A_PRINTF("BMI operation failed: %d\n", __LINE__); \
+ return A_ERROR; \
+ } \
+} while(0)
+
+#ifdef INIT_MODE_DRV_ENABLED
+
+#define MCKINLEY_MAC_ADDRESS_OFFSET 0x16
+static
+void calculate_crc(A_UINT32 TargetType, A_UCHAR *eeprom_data, size_t eeprom_size)
+{
+ A_UINT16 *ptr_crc;
+ A_UINT16 *ptr16_eeprom;
+ A_UINT16 checksum;
+ A_UINT32 i;
+
+ if (TargetType == TARGET_TYPE_AR6001)
+ {
+ ptr_crc = (A_UINT16 *)eeprom_data;
+ }
+ else if (TargetType == TARGET_TYPE_AR6003)
+ {
+ ptr_crc = (A_UINT16 *)((A_UCHAR *)eeprom_data + 0x04);
+ }
+ else if (TargetType == TARGET_TYPE_MCKINLEY)
+ {
+ eeprom_size = 1024;
+ ptr_crc = (A_UINT16 *)((A_UCHAR *)eeprom_data + 0x04);
+ }
+ else
+ {
+ ptr_crc = (A_UINT16 *)((A_UCHAR *)eeprom_data + 0x04);
+ }
+
+
+ // Clear the crc
+ *ptr_crc = 0;
+
+ // Recalculate new CRC
+ checksum = 0;
+ ptr16_eeprom = (A_UINT16 *)eeprom_data;
+ for (i = 0;i < eeprom_size; i += 2)
+ {
+ checksum = checksum ^ (*ptr16_eeprom);
+ ptr16_eeprom++;
+ }
+ checksum = 0xFFFF ^ checksum;
+ *ptr_crc = checksum;
+}
+
+#ifdef SOFTMAC_USED
+#define AR6002_MAC_ADDRESS_OFFSET 0x0A
+#define AR6003_MAC_ADDRESS_OFFSET 0x16
+
+static void
+ar6000_softmac(AR_SOFTC_T *ar, A_UCHAR *eeprom_data, size_t eeprom_size)
+{
+ A_UCHAR *ptr_mac;
+ switch (ar->arTargetType) {
+ case TARGET_TYPE_AR6002:
+ ptr_mac = (A_UINT8 *)((A_UCHAR *)eeprom_data + AR6002_MAC_ADDRESS_OFFSET);
+ break;
+ case TARGET_TYPE_AR6003:
+ ptr_mac = (A_UINT8 *)((A_UCHAR *)eeprom_data + AR6003_MAC_ADDRESS_OFFSET);
+ break;
+ case TARGET_TYPE_MCKINLEY:
+ ptr_mac = (A_UINT8 *)((A_UCHAR *)eeprom_data + MCKINLEY_MAC_ADDRESS_OFFSET);
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Invalid Target Type \n"));
+ return;
+ }
+ ptr_mac[0] = ambarella_board_generic.wifi0_mac[0];
+ ptr_mac[1] = ambarella_board_generic.wifi0_mac[1];
+ ptr_mac[2] = ambarella_board_generic.wifi0_mac[2];
+ ptr_mac[3] = ambarella_board_generic.wifi0_mac[3];
+ ptr_mac[4] = ambarella_board_generic.wifi0_mac[4];
+ ptr_mac[5] = ambarella_board_generic.wifi0_mac[5];
+
+ if (0==memcmp(ptr_mac, "\0\0\0\0\0\0",6)) {
+ ptr_mac[0] = 0x00;
+ ptr_mac[1] = 0x03;
+ ptr_mac[2] = 0x7F;
+ ptr_mac[3] = random32() & 0xff;
+ ptr_mac[4] = random32() & 0xff;
+ ptr_mac[5] = random32() & 0xff;
+ //memcpy(ptr_mac+3, "\3\4\5", 3);
+
+ ambarella_board_generic.wifi0_mac[0] = ptr_mac[0];
+ ambarella_board_generic.wifi0_mac[1] = ptr_mac[1];
+ ambarella_board_generic.wifi0_mac[2] = ptr_mac[2];
+ ambarella_board_generic.wifi0_mac[3] = ptr_mac[3];
+ ambarella_board_generic.wifi0_mac[4] = ptr_mac[4];
+ ambarella_board_generic.wifi0_mac[5] = ptr_mac[5];
+ }
+
+ calculate_crc(ar->arTargetType, eeprom_data, eeprom_size);
+}
+#endif
+
+#ifdef SOFTMAC_FILE_USED
+#define AR6002_MAC_ADDRESS_OFFSET 0x0A
+#define AR6003_MAC_ADDRESS_OFFSET 0x16
+static void
+ar6000_softmac_update(AR_SOFTC_T *ar, A_UCHAR *eeprom_data, size_t eeprom_size)
+{
+ /* We need to store the MAC, which comes either from the softmac file or is
+ * randomly generated, because we do not want to load a new MAC address
+ * if the chip goes into suspend and then is resumed later on. We ONLY
+ * want to load a new MAC if the driver is unloaded and then reloaded
+ */
+ static A_UCHAR random_mac[6];
+ const char *source = "random generated";
+ const struct firmware *softmac_entry;
+ A_UCHAR *ptr_mac;
+ switch (ar->arTargetType) {
+ case TARGET_TYPE_AR6002:
+ ptr_mac = (A_UINT8 *)((A_UCHAR *)eeprom_data + AR6002_MAC_ADDRESS_OFFSET);
+ break;
+ case TARGET_TYPE_AR6003:
+ ptr_mac = (A_UINT8 *)((A_UCHAR *)eeprom_data + AR6003_MAC_ADDRESS_OFFSET);
+ break;
+ case TARGET_TYPE_MCKINLEY:
+ ptr_mac = (A_UINT8 *)((A_UCHAR *)eeprom_data + MCKINLEY_MAC_ADDRESS_OFFSET);
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Invalid Target Type \n"));
+ return;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN,
+ ("MAC from EEPROM %02X:%02X:%02X:%02X:%02X:%02X\n",
+ ptr_mac[0], ptr_mac[1], ptr_mac[2],
+ ptr_mac[3], ptr_mac[4], ptr_mac[5]));
+
+ if (memcmp(random_mac, "\0\0\0\0\0\0", 6)!=0) {
+ memcpy(ptr_mac, random_mac, 6);
+ } else {
+ /* create a random MAC in case we cannot read file from system */
+ ptr_mac[0] = random_mac[0] = 2; /* locally administered */
+ ptr_mac[1] = random_mac[1] = 0x03;
+ ptr_mac[2] = random_mac[2] = 0x7F;
+ ptr_mac[3] = random_mac[3] = random32() & 0xff;
+ ptr_mac[4] = random_mac[4] = random32() & 0xff;
+ ptr_mac[5] = random_mac[5] = random32() & 0xff;
+ }
+#if defined(CONFIG_ARCH_MSM9615)
+ if ((A_REQUEST_FIRMWARE(&softmac_entry, "ath6k/AR6003/hw2.1.1/softmac", ((struct device *)ar->osDevInfo.pOSDevice))) == 0)
+#else
+ if ((A_REQUEST_FIRMWARE(&softmac_entry, "softmac", ((struct device *)ar->osDevInfo.pOSDevice))) == 0)
+#endif
+ {
+ A_CHAR *macbuf = A_MALLOC_NOWAIT(softmac_entry->size+1);
+ if (macbuf) {
+ unsigned int softmac[6];
+ memcpy(macbuf, softmac_entry->data, softmac_entry->size);
+ macbuf[softmac_entry->size] = '\0';
+ if (sscanf(macbuf, "%02x:%02x:%02x:%02x:%02x:%02x",
+ &softmac[0], &softmac[1], &softmac[2],
+ &softmac[3], &softmac[4], &softmac[5])==6) {
+ int i;
+ for (i=0; i<6; ++i) {
+ ptr_mac[i] = softmac[i] & 0xff;
+ }
+ source = "softmac file";
+ A_MEMZERO(random_mac, sizeof(random_mac));
+ }
+ A_FREE(macbuf);
+ }
+ A_RELEASE_FIRMWARE(softmac_entry);
+ }
+
+ if (memcmp(random_mac, "\0\0\0\0\0\0", 6)!=0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Warning! Random MAC address is just for testing purpose\n"));
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN,
+ ("MAC from %s %02X:%02X:%02X:%02X:%02X:%02X\n", source,
+ ptr_mac[0], ptr_mac[1], ptr_mac[2],
+ ptr_mac[3], ptr_mac[4], ptr_mac[5]));
+ calculate_crc(ar->arTargetType, eeprom_data, eeprom_size);
+}
+#endif /* SOFTMAC_FILE_USED */
+
+static void
+ar6000_reg_update(AR_SOFTC_T *ar, A_UCHAR *eeprom_data, size_t eeprom_size, int regCode)
+{
+ A_UCHAR *ptr_reg;
+ switch (ar->arTargetType) {
+ case TARGET_TYPE_AR6002:
+ ptr_reg = (A_UINT8 *)((A_UCHAR *)eeprom_data + 8);
+ break;
+ case TARGET_TYPE_AR6003:
+ ptr_reg = (A_UINT8 *)((A_UCHAR *)eeprom_data + 12);
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Invalid Target Type \n"));
+ return;
+ }
+
+ ptr_reg[0] = (A_UCHAR)(regCode&0xFF);
+ ptr_reg[1] = (A_UCHAR)((regCode>>8)&0xFF);
+ calculate_crc(ar->arTargetType, eeprom_data, eeprom_size);
+}
+
+#ifdef ANDROID_ENV
+static void
+ar6000_psminfo_update(void)
+{
+ char psm_filename[256];
+
+ do {
+ int ret = 0;
+ size_t length;
+ u8 *pdata = NULL;
+
+ snprintf(psm_filename, sizeof(psm_filename), "/data/.psm.info");
+
+ if ( (ret = android_readwrite_file(psm_filename, NULL, NULL, 0)) < 0) {
+ break;
+ } else {
+ length = ret;
+ }
+ pdata = vmalloc(length);
+ if (!pdata) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s: Cannot allocate buffer for psm_info (%d)\n", __FUNCTION__,length));
+ break;
+ }
+
+ if ( android_readwrite_file(psm_filename, (char*)pdata, NULL, length) != length) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s: file read error, length %d\n", __FUNCTION__, length));
+ vfree(pdata);
+ break;
+ }
+ psm_info = *pdata - '0';
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%s: psm_info is %d\n", __FUNCTION__, psm_info));
+ vfree(pdata);
+ } while (0);
+}
+#endif
+
+
+static A_STATUS
+ar6000_transfer_bin_file(AR_SOFTC_T *ar, AR6K_BIN_FILE file, A_UINT32 address, A_BOOL compressed)
+{
+ A_STATUS status;
+ const char *filename;
+ const struct firmware *fw_entry;
+ A_UINT32 fw_entry_size;
+ A_UCHAR *tempEeprom;
+ A_UINT32 board_data_size;
+
+ switch (file) {
+ case AR6K_OTP_FILE:
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_OTP_FILE;
+ } else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ filename = AR6003_REV3_OTP_FILE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown firmware revision: %d\n", ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ break;
+
+ case AR6K_FIRMWARE_FILE:
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_FIRMWARE_FILE;
+ } else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ if(ar->arVersion.targetconf_ver == AR6003_SUBVER_ROUTER)
+ filename = AR6003_REV3_ROUTER_FIRMWARE_FILE;
+ else if (ar->arVersion.targetconf_ver == AR6003_SUBVER_MOBILE)
+ filename = AR6003_REV3_MOBILE_FIRMWARE_FILE;
+ else if (ar->arVersion.targetconf_ver == AR6003_SUBVER_TABLET)
+ filename = AR6003_REV3_TABLET_FIRMWARE_FILE;
+ else
+ filename = AR6003_REV3_DEFAULT_FIRMWARE_FILE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown firmware revision: %d\n", ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s firmware will be loaded\n", filename));
+
+
+ if (eppingtest) {
+ bypasswmi = TRUE;
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_EPPING_FIRMWARE_FILE;
+ } else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ filename = AR6003_REV3_EPPING_FIRMWARE_FILE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("eppingtest : unsupported firmware revision: %d\n",
+ ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ compressed = 0;
+ }
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+ if(testmode == 1) {
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_TCMD_FIRMWARE_FILE;
+ } else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ filename = AR6003_REV3_TCMD_FIRMWARE_FILE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown firmware revision: %d\n", ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ compressed = 0;
+ }
+#endif
+#ifdef HTC_RAW_INTERFACE
+ if (!eppingtest && bypasswmi) {
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_ART_FIRMWARE_FILE;
+ } else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ filename = AR6003_REV3_ART_FIRMWARE_FILE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown firmware revision: %d\n", ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ compressed = 0;
+ }
+#endif
+ break;
+
+ case AR6K_PATCH_FILE:
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_PATCH_FILE;
+ } else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ filename = AR6003_REV3_PATCH_FILE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown firmware revision: %d\n", ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ break;
+
+ case AR6K_BOARD_DATA_FILE:
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_BOARD_DATA_FILE;
+ } else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ filename = AR6003_REV3_BOARD_DATA_FILE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown firmware revision: %d\n", ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ break;
+
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown file type: %d\n", file));
+ return A_ERROR;
+ }
+ if ((A_REQUEST_FIRMWARE(&fw_entry, filename, ((struct device *)ar->osDevInfo.pOSDevice))) != 0)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to get %s\n", filename));
+ return A_ENOENT;
+ }
+
+ fw_entry_size = fw_entry->size;
+ tempEeprom = NULL;
+
+ /* Load extended board data for AR6003 */
+ if ((file==AR6K_BOARD_DATA_FILE) && (fw_entry->data)) {
+ A_UINT32 board_ext_address;
+ A_INT32 board_ext_data_size;
+
+ tempEeprom = A_MALLOC_NOWAIT(fw_entry->size);
+ if (!tempEeprom) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Memory allocation failed\n"));
+ A_RELEASE_FIRMWARE(fw_entry);
+ return A_ERROR;
+ }
+
+ board_data_size = (((ar)->arTargetType == TARGET_TYPE_AR6002) ? AR6002_BOARD_DATA_SZ : \
+ (((ar)->arTargetType == TARGET_TYPE_AR6003) ? AR6003_BOARD_DATA_SZ : 0));
+
+ board_ext_data_size = 0;
+ if (ar->arTargetType == TARGET_TYPE_AR6002) {
+ board_ext_data_size = AR6002_BOARD_EXT_DATA_SZ;
+ } else if (ar->arTargetType == TARGET_TYPE_AR6003) {
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ board_ext_data_size = AR6003_VER2_BOARD_EXT_DATA_SZ;
+ } else {
+ board_ext_data_size = AR6003_BOARD_EXT_DATA_SZ;
+ }
+ }
+
+ /* AR6003 2.1.1 support 1792 bytes and 2048 bytes board file */
+ if ((board_ext_data_size) &&
+ (fw_entry->size < (board_data_size + board_ext_data_size)))
+ {
+ board_ext_data_size = fw_entry->size - board_data_size;
+ if (board_ext_data_size < 0) {
+ board_ext_data_size = 0;
+ }
+ }
+
+ A_MEMCPY(tempEeprom, (A_UCHAR *)fw_entry->data, fw_entry->size);
+
+#ifdef SOFTMAC_FILE_USED
+ ar6000_softmac_update(ar, tempEeprom, board_data_size);
+#endif
+#ifdef SOFTMAC_USED
+ ar6000_softmac(ar, tempEeprom, board_data_size);
+#endif
+
+ if (regcode!=0) {
+ ar6000_reg_update(ar, tempEeprom, board_data_size, regcode);
+ }
+
+#ifdef ANDROID_ENV
+ ar6000_psminfo_update();
+#endif
+ /* Determine where in Target RAM to write Board Data */
+ bmifn(BMIReadMemory(ar->arHifDevice, HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_board_ext_data), (A_UCHAR *)&board_ext_address, 4));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("Board extended Data download address: 0x%x\n", board_ext_address));
+
+ /* check whether the target has allocated memory for extended board data and file contains extended board data */
+ if ((board_ext_address) && (fw_entry->size == (board_data_size + board_ext_data_size))) {
+ A_UINT32 param;
+
+ status = BMIWriteMemory(ar->arHifDevice, board_ext_address, (A_UCHAR *)(((A_UINT32)tempEeprom) + board_data_size), board_ext_data_size);
+
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("BMI operation failed: %d\n", __LINE__));
+ A_RELEASE_FIRMWARE(fw_entry);
+ return A_ERROR;
+ }
+
+ /* Record the fact that extended board Data IS initialized */
+ param = (board_ext_data_size << 16) | 1;
+ bmifn(BMIWriteMemory(ar->arHifDevice, HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_board_ext_data_config), (A_UCHAR *)¶m, 4));
+ }
+ fw_entry_size = board_data_size;
+ }
+
+ if (compressed) {
+ status = BMIFastDownload(ar->arHifDevice, address, (A_UCHAR *)fw_entry->data, fw_entry_size);
+ } else {
+ if (file==AR6K_BOARD_DATA_FILE && fw_entry->data)
+ {
+ status = BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)tempEeprom, fw_entry_size);
+ }
+ else
+ {
+ status = BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)fw_entry->data, fw_entry_size);
+ }
+ }
+
+ if (tempEeprom) {
+ A_FREE(tempEeprom);
+ }
+
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("BMI operation failed: %d\n", __LINE__));
+ A_RELEASE_FIRMWARE(fw_entry);
+ return A_ERROR;
+ }
+ A_RELEASE_FIRMWARE(fw_entry);
+ return A_OK;
+}
+#endif /* INIT_MODE_DRV_ENABLED */
+
+A_STATUS
+ar6000_update_bdaddr(AR_SOFTC_T *ar)
+{
+
+ if (setupbtdev != 0) {
+ A_UINT32 address;
+
+ if (BMIReadMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_board_data), (A_UCHAR *)&address, 4) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIReadMemory for hi_board_data failed\n"));
+ return A_ERROR;
+ }
+
+ if (BMIReadMemory(ar->arHifDevice, address + BDATA_BDADDR_OFFSET, (A_UCHAR *)ar->bdaddr, 6) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIReadMemory for BD address failed\n"));
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BDADDR 0x%x:0x%x:0x%x:0x%x:0x%x:0x%x\n", ar->bdaddr[0],
+ ar->bdaddr[1], ar->bdaddr[2], ar->bdaddr[3],
+ ar->bdaddr[4], ar->bdaddr[5]));
+ }
+
+return A_OK;
+}
+
+A_STATUS
+ar6000_sysfs_bmi_get_config(AR_SOFTC_T *ar, A_UINT32 mode)
+{
+#if defined(INIT_MODE_DRV_ENABLED) && defined(CONFIG_HOST_TCMD_SUPPORT)
+ const char *filename;
+ const struct firmware *fw_entry;
+#endif
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("BMI: Requesting device specific configuration\n"));
+
+ if (mode == WLAN_INIT_MODE_UDEV) {
+ A_CHAR version[16];
+ const struct firmware *fw_entry;
+
+ /* Get config using udev through a script in user space */
+ if (snprintf(version, sizeof(version), "%2.2x",
+ ar->arVersion.target_ver) >= sizeof(version)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("snprintf: Target version-%2.2x\n",
+ ar->arVersion.target_ver));
+ return A_ERROR;
+ }
+ if ((A_REQUEST_FIRMWARE(&fw_entry, version, ((struct device *)ar->osDevInfo.pOSDevice))) != 0)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("BMI: Failure to get configuration for target version: %s\n", version));
+ return A_ERROR;
+ }
+
+ A_RELEASE_FIRMWARE(fw_entry);
+#ifdef INIT_MODE_DRV_ENABLED
+ } else {
+ /* The config is contained within the driver itself */
+ A_STATUS status;
+ A_UINT32 param, options, sleep, address;
+
+ /* Temporarily disable system sleep */
+ address = MBOX_BASE_ADDRESS + LOCAL_SCRATCH_OFFSET;
+ bmifn(BMIReadSOCRegister(ar->arHifDevice, address, ¶m));
+ options = param;
+ param |= AR6K_OPTION_SLEEP_DISABLE;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ address = RTC_WMAC_BASE_ADDRESS + WLAN_SYSTEM_SLEEP_OFFSET;
+ bmifn(BMIReadSOCRegister(ar->arHifDevice, address, ¶m));
+ sleep = param;
+ param |= WLAN_SYSTEM_SLEEP_DISABLE_SET(1);
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("old options: %d, old sleep: %d\n", options, sleep));
+
+ if (ar->arTargetType == TARGET_TYPE_MCKINLEY) {
+ /* Run at 40/44MHz by default */
+ param = CPU_CLOCK_STANDARD_SET(0);
+ } else if (ar->arTargetType == TARGET_TYPE_AR6003) {
+ /* Program analog PLL register */
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, ANALOG_INTF_BASE_ADDRESS + 0x284, 0xF9104001));
+ /* Run at 80/88MHz by default */
+ param = CPU_CLOCK_STANDARD_SET(1);
+ } else {
+ /* Run at 40/44MHz by default */
+ param = CPU_CLOCK_STANDARD_SET(0);
+ }
+ address = RTC_SOC_BASE_ADDRESS + CPU_CLOCK_OFFSET;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ param = 0;
+ if (ar->arTargetType == TARGET_TYPE_AR6002) {
+ bmifn(BMIReadMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_ext_clk_detected),
+ (A_UCHAR *)¶m, 4));
+ }
+
+ /* LPO_CAL.ENABLE = 1 if no external clk is detected */
+ if (param != 1) {
+ address = RTC_SOC_BASE_ADDRESS + LPO_CAL_OFFSET;
+ param = LPO_CAL_ENABLE_SET(1);
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+ }
+
+ /* Venus2.0: Lower SDIO pad drive strength */
+ if ((ar->arVersion.target_ver == AR6003_REV2_VERSION) ||
+ (ar->arVersion.target_ver == AR6003_REV3_VERSION))
+ {
+ param = 0x28;
+ address = GPIO_BASE_ADDRESS + GPIO_PIN9_OFFSET;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ param = 0x20;
+ address = GPIO_BASE_ADDRESS + GPIO_PIN10_OFFSET;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ address = GPIO_BASE_ADDRESS + GPIO_PIN11_OFFSET;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ address = GPIO_BASE_ADDRESS + GPIO_PIN12_OFFSET;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ address = GPIO_BASE_ADDRESS + GPIO_PIN13_OFFSET;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+ }
+
+ /* Change the clock with module parameter refclock Mhz */
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, 0x540678, refClock));
+
+#ifdef FORCE_INTERNAL_CLOCK
+ /* Ignore external clock, if any, and force use of internal clock */
+ if (ar->arTargetType == TARGET_TYPE_AR6003 || ar->arTargetType == TARGET_TYPE_MCKINLEY) {
+ /* hi_ext_clk_detected = 0 */
+ param = 0;
+ bmifn(BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_ext_clk_detected),
+ (A_UCHAR *)¶m, 4));
+
+ /* CLOCK_CONTROL &= ~LF_CLK32 */
+ address = RTC_BASE_ADDRESS + CLOCK_CONTROL_ADDRESS;
+ bmifn(BMIReadSOCRegister(ar->arHifDevice, address, ¶m));
+ param &= (~CLOCK_CONTROL_LF_CLK32_SET(1));
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+ }
+#endif /* FORCE_INTERNAL_CLOCK */
+
+ /* Transfer Board Data from Target EEPROM to Target RAM */
+ if (ar->arTargetType == TARGET_TYPE_AR6003 || ar->arTargetType == TARGET_TYPE_MCKINLEY) {
+ /* Determine where in Target RAM to write Board Data */
+ bmifn(BMIReadMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_board_data),
+ (A_UCHAR *)&address, 4));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("Board Data download address: 0x%x\n", address));
+
+ /* Write EEPROM data to Target RAM */
+ if ((status=ar6000_transfer_bin_file(ar, AR6K_BOARD_DATA_FILE, address, FALSE)) != A_OK) {
+ return A_ERROR;
+ }
+
+ /* Record the fact that Board Data IS initialized */
+ param = 1;
+ bmifn(BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_board_data_initialized),
+ (A_UCHAR *)¶m, 4));
+
+ /* Transfer One time Programmable data */
+ AR6K_APP_LOAD_ADDRESS(address, ar->arVersion.target_ver);
+ if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ address = BMI_SEGMENTED_WRITE_ADDR;
+ }
+ status = ar6000_transfer_bin_file(ar, AR6K_OTP_FILE, address, TRUE);
+ if (status == A_OK) {
+ /* Execute the OTP code */
+#ifdef SOFTMAC_FILE_USED
+ param = 1;
+#else
+ param = 0;
+#endif
+
+#ifdef SOFTMAC_USED
+ param = 1;
+#else
+ param = 0;
+#endif
+
+ if (regcode != 0)
+ param |= 0x2;
+ AR6K_APP_START_OVERRIDE_ADDRESS(address, ar->arVersion.target_ver);
+ bmifn(BMIExecute(ar->arHifDevice, address, ¶m));
+ } else if (status != A_ENOENT) {
+ return A_ERROR;
+ }
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Programming of board data for chip %d not supported\n", ar->arTargetType));
+ return A_ERROR;
+ }
+
+ /* Download Target firmware */
+ AR6K_APP_LOAD_ADDRESS(address, ar->arVersion.target_ver);
+ if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ address = BMI_SEGMENTED_WRITE_ADDR;
+ }
+ if ((ar6000_transfer_bin_file(ar, AR6K_FIRMWARE_FILE, address, TRUE)) != A_OK) {
+ return A_ERROR;
+ }
+
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION)
+ {
+ /* Set starting address for firmware */
+ AR6K_APP_START_OVERRIDE_ADDRESS(address, ar->arVersion.target_ver);
+ bmifn(BMISetAppStart(ar->arHifDevice, address));
+ }
+
+ /* Apply the patches */
+ if (ar->arTargetType == TARGET_TYPE_AR6003) {
+ AR6K_DATASET_PATCH_ADDRESS(address, ar->arVersion.target_ver);
+ if ((ar6000_transfer_bin_file(ar, AR6K_PATCH_FILE, address, FALSE)) != A_OK) {
+ return A_ERROR;
+ }
+ param = address;
+ bmifn(BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_dset_list_head),
+ (A_UCHAR *)¶m, 4));
+ }
+
+ /* Restore system sleep */
+ address = RTC_WMAC_BASE_ADDRESS + WLAN_SYSTEM_SLEEP_OFFSET;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, sleep));
+
+ address = MBOX_BASE_ADDRESS + LOCAL_SCRATCH_OFFSET;
+ param = options | 0x20;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ if (ar->arTargetType == TARGET_TYPE_AR6003 || ar->arTargetType == TARGET_TYPE_MCKINLEY) {
+ /* Configure GPIO AR6003 UART */
+#ifndef CONFIG_AR600x_DEBUG_UART_TX_PIN
+#define CONFIG_AR600x_DEBUG_UART_TX_PIN 8
+#endif
+ param = CONFIG_AR600x_DEBUG_UART_TX_PIN;
+ bmifn(BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_dbg_uart_txpin),
+ (A_UCHAR *)¶m, 4));
+
+#if (CONFIG_AR600x_DEBUG_UART_TX_PIN == 23)
+ if (ATH_REGISTER_SUPPORTED_BY_TARGET(CLOCK_GPIO_OFFSET)) {
+ address = GPIO_BASE_ADDRESS + CLOCK_GPIO_OFFSET;
+ bmifn(BMIReadSOCRegister(ar->arHifDevice, address, ¶m));
+ param |= CLOCK_GPIO_BT_CLK_OUT_EN_SET(1);
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+ } else {
+ /* AR6004 has no need for a CLOCK_GPIO register */
+ }
+#endif
+
+ /* Configure GPIO for BT Reset */
+#ifdef ATH6KL_CONFIG_GPIO_BT_RESET
+#define CONFIG_AR600x_BT_RESET_PIN 0x16
+ param = CONFIG_AR600x_BT_RESET_PIN;
+ bmifn(BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_hci_uart_support_pins),
+ (A_UCHAR *)¶m, 4));
+#endif /* ATH6KL_CONFIG_GPIO_BT_RESET */
+
+ /* Configure UART flow control polarity */
+#ifndef CONFIG_ATH6KL_BT_UART_FC_POLARITY
+#define CONFIG_ATH6KL_BT_UART_FC_POLARITY 0
+#endif
+
+#if (CONFIG_ATH6KL_BT_UART_FC_POLARITY == 1)
+ if ((ar->arVersion.target_ver == AR6003_REV2_VERSION) ||
+ (ar->arVersion.target_ver == AR6003_REV3_VERSION))
+ {
+ param = ((CONFIG_ATH6KL_BT_UART_FC_POLARITY << 1) & 0x2);
+ bmifn(BMIWriteMemory(ar->arHifDevice, HOST_INTEREST_ITEM_ADDRESS(ar, hi_hci_uart_pwr_mgmt_params), (A_UCHAR *)¶m, 4));
+ }
+#endif /* CONFIG_ATH6KL_BT_UART_FC_POLARITY */
+ }
+#ifdef HTC_RAW_INTERFACE
+ if (!eppingtest && bypasswmi) {
+ /* Don't run BMIDone for ART mode and force resetok=0 */
+ resetok = 0;
+ msleep(1000);
+ param = 1;
+ status = BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_board_data_initialized),
+ (A_UCHAR *)¶m, 4);
+ }
+#endif /* HTC_RAW_INTERFACE */
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+ if (testmode == 2) {
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ filename = AR6003_REV2_UTF_FIRMWARE_FILE;
+ if ((A_REQUEST_FIRMWARE(&fw_entry, filename, ((struct device *)ar->osDevInfo.pOSDevice))) != 0)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to get %s\n", filename));
+ return A_ENOENT;
+ }
+ /* Download Target firmware */
+ AR6K_APP_LOAD_ADDRESS(address, ar->arVersion.target_ver);
+ status = BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)fw_entry->data, fw_entry->size);
+
+ address = HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_end_RAM_reserve_sz);
+ param = 11008;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ address = 0x57D884;
+ filename = AR6003_REV2_TESTSCRIPT_FILE;
+ if ((A_REQUEST_FIRMWARE(&fw_entry, filename, ((struct device *)ar->osDevInfo.pOSDevice))) != 0)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to get %s\n", filename));
+ return A_ENOENT;
+ }
+ status = BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)fw_entry->data, fw_entry->size);
+
+ param = 0x57D884;
+ address = HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_ota_testscript);
+ bmifn(BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)¶m, 4));
+
+ address = HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_test_apps_related);
+ bmifn(BMIReadSOCRegister(ar->arHifDevice, address, ¶m));
+ param |= 1;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ A_RELEASE_FIRMWARE(fw_entry);
+ }
+ else if (ar->arVersion.target_ver == AR6003_REV3_VERSION) {
+ filename = AR6003_REV3_UTF_FIRMWARE_FILE;
+ if ((A_REQUEST_FIRMWARE(&fw_entry, filename, ((struct device *)ar->osDevInfo.pOSDevice))) != 0)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to get %s\n", filename));
+ return A_ENOENT;
+ }
+ /* Download Target firmware */
+ address = BMI_SEGMENTED_WRITE_ADDR;
+ status = BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)fw_entry->data, fw_entry->size);
+
+ address = HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_end_RAM_reserve_sz);
+ param = 4096;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ address = 0x57EF74;
+ filename = AR6003_REV3_TESTSCRIPT_FILE;
+ if ((A_REQUEST_FIRMWARE(&fw_entry, filename, ((struct device *)ar->osDevInfo.pOSDevice))) != 0)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to get %s\n", filename));
+ return A_ENOENT;
+ }
+ status = BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)fw_entry->data, fw_entry->size);
+
+ param = 0x57EF74;
+ address = HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_ota_testscript);
+ bmifn(BMIWriteMemory(ar->arHifDevice, address, (A_UCHAR *)¶m, 4));
+
+ address = HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_test_apps_related);
+ bmifn(BMIReadSOCRegister(ar->arHifDevice, address, ¶m));
+ param |= 1;
+ bmifn(BMIWriteSOCRegister(ar->arHifDevice, address, param));
+
+ A_RELEASE_FIRMWARE(fw_entry);
+ }
+ }
+#endif
+#endif /* INIT_MODE_DRV_ENABLED */
+ }
+
+ return A_OK;
+}
+
+A_STATUS
+ar6000_configure_target(AR_SOFTC_T *ar)
+{
+ A_UINT32 param;
+ if (enableuartprint) {
+ param = 1;
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_serial_enable),
+ (A_UCHAR *)¶m,
+ 4)!= A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for enableuartprint failed \n"));
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Serial console prints enabled\n"));
+ }
+
+ /* Tell target which HTC version it is used*/
+ param = HTC_PROTOCOL_VERSION;
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_app_host_interest),
+ (A_UCHAR *)¶m,
+ 4)!= A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for htc version failed \n"));
+ return A_ERROR;
+ }
+
+ if (enabletimerwar) {
+ A_UINT32 param;
+
+ if (BMIReadMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4)!= A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIReadMemory for enabletimerwar failed \n"));
+ return A_ERROR;
+ }
+
+ param |= HI_OPTION_TIMER_WAR;
+
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for enabletimerwar failed \n"));
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Timer WAR enabled\n"));
+ }
+
+ /* set the firmware mode to STA/IBSS/AP */
+ {
+ A_UINT32 param;
+
+ if (BMIReadMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4)!= A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIReadMemory for setting fwmode failed \n"));
+ return A_ERROR;
+ }
+
+ param |= (num_device << HI_OPTION_NUM_DEV_SHIFT);
+ param |= (fwmode << HI_OPTION_FW_MODE_SHIFT);
+ param |= (mac_addr_method << HI_OPTION_MAC_ADDR_METHOD_SHIFT);
+ param |= (firmware_bridge << HI_OPTION_FW_BRIDGE_SHIFT);
+ param |= (fwsubmode << HI_OPTION_FW_SUBMODE_SHIFT);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("NUM_DEV=%d FWMODE=0x%x FWSUBMODE=0x%x FWBR_BUF %d\n",
+ num_device, fwmode, fwsubmode, firmware_bridge));
+
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for setting fwmode failed \n"));
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Firmware mode set\n"));
+ }
+#ifdef ATH6KL_DISABLE_TARGET_DBGLOGS
+ {
+ A_UINT32 param;
+
+ if (BMIReadMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4)!= A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIReadMemory for disabling debug logs failed\n"));
+ return A_ERROR;
+ }
+
+ param |= HI_OPTION_DISABLE_DBGLOG;
+
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for HI_OPTION_DISABLE_DBGLOG\n"));
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Firmware mode set\n"));
+ }
+#endif /* ATH6KL_DISABLE_TARGET_DBGLOGS */
+
+ if (regscanmode) {
+ A_UINT32 param;
+
+ if (BMIReadMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4)!= A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIReadMemory for setting regscanmode failed\n"));
+ return A_ERROR;
+ }
+
+ if (regscanmode == 1) {
+ param |= HI_OPTION_SKIP_REG_SCAN;
+ } else if (regscanmode == 2) {
+ param |= HI_OPTION_INIT_REG_SCAN;
+ }
+
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_option_flag),
+ (A_UCHAR *)¶m,
+ 4) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for setting regscanmode failed\n"));
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Regulatory scan mode set\n"));
+ }
+
+ /*
+ * Hardcode the address use for the extended board data
+ * Ideally this should be pre-allocate by the OS at boot time
+ * But since it is a new feature and board data is loaded
+ * at init time, we have to workaround this from host.
+ * It is difficult to patch the firmware boot code,
+ * but possible in theory.
+ */
+ if (ar->arTargetType == TARGET_TYPE_AR6003) {
+ A_UINT32 ramReservedSz;
+ if (ar->arVersion.target_ver == AR6003_REV2_VERSION) {
+ param = AR6003_REV2_BOARD_EXT_DATA_ADDRESS;
+ ramReservedSz = AR6003_REV2_RAM_RESERVE_SIZE;
+ } else {
+ param = AR6003_REV3_BOARD_EXT_DATA_ADDRESS;
+ if (testmode) {
+ ramReservedSz = AR6003_REV3_RAM_RESERVE_SIZE_TCMD;
+ } else {
+ ramReservedSz = AR6003_REV3_RAM_RESERVE_SIZE;
+ }
+ }
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_board_ext_data),
+ (A_UCHAR *)¶m,
+ 4) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for hi_board_ext_data failed \n"));
+ return A_ERROR;
+ }
+ if (BMIWriteMemory(ar->arHifDevice,
+ HOST_INTEREST_ITEM_ADDRESS(ar->arTargetType, hi_end_RAM_reserve_sz),
+ (A_UCHAR *)&ramReservedSz, 4) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BMIWriteMemory for hi_end_RAM_reserve_sz failed \n"));
+ return A_ERROR;
+ }
+ }
+
+
+ /* since BMIInit is called in the driver layer, we have to set the block
+ * size here for the target */
+
+ if (A_FAILED(ar6000_set_htc_params(ar->arHifDevice,
+ ar->arTargetType,
+ mbox_yield_limit,
+ 0 /* use default number of control buffers */
+ ))) {
+ return A_ERROR;
+ }
+
+ if (setupbtdev != 0) {
+ if (A_FAILED(ar6000_set_hci_bridge_flags(ar->arHifDevice,
+ ar->arTargetType,
+ setupbtdev))) {
+ return A_ERROR;
+ }
+ }
+
+ return A_OK;
+}
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24)
+static void ar6000_ethtool_get_drvinfo(struct net_device *dev,
+ struct ethtool_drvinfo *info)
+{
+ A_STATUS status;
+ HIF_DEVICE_OS_DEVICE_INFO osDevInfo;
+ AR_SOFTC_T *ar;
+ AR_SOFTC_DEV_T *arPriv;
+ struct ar6000_version *revinfo;
+ if((dev == NULL) || ((arPriv = ar6k_priv(dev)) == NULL)) {
+ return;
+ }
+ ar = arPriv->arSoftc;
+ revinfo = &ar->arVersion;
+ strcpy(info->driver, "AR6000");
+ snprintf(info->version, sizeof(info->version), "%u.%u.%u.%u",
+ ((revinfo->host_ver)&0xf0000000)>>28,
+ ((revinfo->host_ver)&0x0f000000)>>24,
+ ((revinfo->host_ver)&0x00ff0000)>>16,
+ ((revinfo->host_ver)&0x0000ffff));
+ snprintf(info->fw_version, sizeof(info->fw_version), "%u.%u.%u.%u",
+ ((revinfo->wlan_ver)&0xf0000000)>>28,
+ ((revinfo->wlan_ver)&0x0f000000)>>24,
+ ((revinfo->wlan_ver)&0x00ff0000)>>16,
+ ((revinfo->wlan_ver)&0x0000ffff));
+
+ status = HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_GET_OS_DEVICE,
+ &osDevInfo,
+ sizeof(HIF_DEVICE_OS_DEVICE_INFO));
+ if (A_SUCCESS(status) && osDevInfo.pOSDevice) {
+ struct device *dev = (struct device*)osDevInfo.pOSDevice;
+ if (dev->bus && dev->bus->name) {
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27)
+ const char *dinfo = dev_name(dev);
+#else
+ const char *dinfo = kobject_name(&dev->kobj);
+#endif
+ snprintf(info->bus_info, sizeof(info->bus_info), dinfo);
+ }
+ }
+}
+
+static u32 ar6000_ethtool_get_link(struct net_device *dev)
+{
+ AR_SOFTC_DEV_T *arPriv;
+ return ((arPriv = ar6k_priv(dev))!=NULL) ? arPriv->arConnected : 0;
+}
+
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+static u32 ar6000_ethtool_get_rx_csum(struct net_device *dev)
+{
+ AR_SOFTC_DEV_T *arPriv;
+ if((dev == NULL) || ((arPriv = ar6k_priv(dev)) == NULL)) {
+ return 0;
+ }
+ return (arPriv->arSoftc->rxMetaVersion==WMI_META_VERSION_2);
+}
+
+static int ar6000_ethtool_set_rx_csum(struct net_device *dev, u32 enable)
+{
+ AR_SOFTC_T *ar;
+ AR_SOFTC_DEV_T *arPriv;
+ A_UINT8 metaVersion;
+ if((dev == NULL) || ((arPriv = ar6k_priv(dev)) == NULL)) {
+ return -EIO;
+ }
+ ar = arPriv->arSoftc;
+ if (ar->arWmiReady == FALSE || ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+ metaVersion = (enable) ? WMI_META_VERSION_2 : 0;
+ if ((wmi_set_rx_frame_format_cmd(arPriv->arWmi, metaVersion, processDot11Hdr, processDot11Hdr)) != A_OK) {
+ return -EFAULT;
+ }
+ ar->rxMetaVersion = metaVersion;
+ return 0;
+}
+
+static u32 ar6000_ethtool_get_tx_csum(struct net_device *dev)
+{
+ return csumOffload;
+}
+
+static int ar6000_ethtool_set_tx_csum(struct net_device *dev, u32 enable)
+{
+ csumOffload = enable;
+ if(enable){
+ dev->features |= NETIF_F_IP_CSUM;
+ } else {
+ dev->features &= ~NETIF_F_IP_CSUM;
+ }
+ return 0;
+}
+#endif /* CONFIG_CHECKSUM_OFFLOAD */
+
+static const struct ethtool_ops ar6000_ethtool_ops = {
+ .get_drvinfo = ar6000_ethtool_get_drvinfo,
+ .get_link = ar6000_ethtool_get_link,
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+ .get_rx_csum = ar6000_ethtool_get_rx_csum,
+ .set_rx_csum = ar6000_ethtool_set_rx_csum,
+ .get_tx_csum = ar6000_ethtool_get_tx_csum,
+ .set_tx_csum = ar6000_ethtool_set_tx_csum,
+#endif /* CONFIG_CHECKSUM_OFFLOAD */
+};
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24) */
+
+/*
+ * HTC Event handlers
+ */
+static A_STATUS
+ar6000_avail_ev(void *context, void *hif_handle)
+{
+ int i;
+ struct net_device *dev;
+ void *ar_netif;
+ AR_SOFTC_T *ar=NULL;
+ AR_SOFTC_DEV_T *arPriv;
+ int device_index = 0;
+ HTC_INIT_INFO htcInfo;
+#ifdef ATH6K_CONFIG_CFG80211
+ struct wireless_dev *wdev;
+#endif /* ATH6K_CONFIG_CFG80211 */
+ A_STATUS init_status = A_OK;
+ unsigned char devnum = 0;
+ unsigned char cnt = 0;
+#ifdef SET_NETDEV_DEV
+ HIF_DEVICE_OS_DEVICE_INFO osDevInfo;
+ A_MEMZERO(&osDevInfo, sizeof(osDevInfo));
+ if (A_OK != HIFConfigureDevice(hif_handle, HIF_DEVICE_GET_OS_DEVICE,
+ &osDevInfo, sizeof(osDevInfo))) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s: Failed to get OS device instance\n",
+ __func__));
+ return A_ERROR;
+ }
+#endif
+ /*
+ * If ar6000_avail_ev is called more than once, this means that
+ * multiple AR600x devices have been inserted into the system.
+ * We do not support more than one AR600x device at this time.
+ */
+ if (avail_ev_called) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("ERROR: More than one AR600x device not supported by driver\n"));
+ complete(&avail_ev_completion);
+ return A_ERROR;
+ }
+
+ avail_ev_called = TRUE;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ar6000_available\n"));
+
+
+
+ ar = A_MALLOC(sizeof(AR_SOFTC_T));
+
+ if (ar == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("AR_SOFTC: can not allocate\n"));
+ complete(&avail_ev_completion);
+ return A_ERROR;
+ }
+ A_MEMZERO(ar, sizeof(AR_SOFTC_T));
+
+#ifdef ATH_AR6K_11N_SUPPORT
+ if(aggr_init(ar6000_alloc_netbufs, ar6000_deliver_frames_to_nw_stack) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s() Failed to initialize aggr.\n", __func__));
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+#endif
+
+ A_MEMZERO((A_UINT8 *)ar->connTbl, NUM_CONN * sizeof(conn_t));
+ /* Init the PS queues */
+ for (i=0; i < NUM_CONN ; i++) {
+#ifdef ATH_AR6K_11N_SUPPORT
+ if ((ar->connTbl[i].conn_aggr = aggr_init_conn()) == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s() Failed to initialize aggr.\n", __func__));
+ A_FREE(ar);
+ complete(&avail_ev_completion);
+ return A_ERROR;
+ }
+#endif
+ A_MUTEX_INIT(&ar->connTbl[i].psqLock);
+ A_NETBUF_QUEUE_INIT(&ar->connTbl[i].psq);
+ A_NETBUF_QUEUE_INIT(&ar->connTbl[i].apsdq);
+ }
+ if (ifname[0] == '\0')
+ strcpy(ifname, "wlan0");
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+ if(ifname[0]) {
+ for(i = 0; i < strlen(ifname); i++) {
+ if(ifname[i] >= '0' && ifname[i] <= '9' ) {
+ devnum = (devnum * 10) + (ifname[i] - '0');
+ }
+ else {
+ cnt++;
+ }
+ }
+ ifname[cnt]='\0';
+ }
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) */
+ ar->arConfNumDev = num_device;
+ for (i=0; i < num_device; i++) {
+
+ if (ar6000_devices[i] != NULL) {
+ break;
+ }
+
+ /* Save this. It gives a bit better readability especially since */
+ /* we use another local "i" variable below. */
+ device_index = i;
+
+#ifdef ATH6K_CONFIG_CFG80211
+#ifdef SET_NETDEV_DEV
+ wdev = ar6k_cfg80211_init(osDevInfo.pOSDevice);
+#else
+ wdev = ar6k_cfg80211_init(NULL);
+#endif
+
+ if (IS_ERR(wdev)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: ar6k_cfg80211_init failed\n", __func__));
+ complete(&avail_ev_completion);
+ return A_ERROR;
+ }
+ ar_netif = wdev_priv(wdev);
+#else
+ dev = alloc_etherdev(sizeof(AR_SOFTC_DEV_T));
+ if (dev == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_available: can't alloc etherdev\n"));
+ A_FREE(ar);
+ complete(&avail_ev_completion);
+ return A_ERROR;
+ }
+ ether_setup(dev);
+ ar_netif = ar6k_priv(dev);
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ if (ar_netif == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Can't allocate ar6k priv memory\n", __func__));
+ A_FREE(ar);
+ complete(&avail_ev_completion);
+ return A_ERROR;
+ }
+
+ A_MEMZERO(ar_netif, sizeof(AR_SOFTC_DEV_T));
+ arPriv = (AR_SOFTC_DEV_T *)ar_netif;
+
+#ifdef ATH6K_CONFIG_CFG80211
+ arPriv->wdev = wdev;
+ wdev->iftype = NL80211_IFTYPE_STATION;
+
+ dev = alloc_netdev_mq(0, "wlan%d", ether_setup, NUM_SUBQUEUE);
+ if (!dev) {
+ printk(KERN_CRIT "AR6K: no memory for network device instance\n");
+ ar6k_cfg80211_deinit(arPriv);
+ A_FREE(ar);
+ return A_ERROR;
+ }
+
+ dev->ieee80211_ptr = wdev;
+ SET_NETDEV_DEV(dev, wiphy_dev(wdev->wiphy));
+ wdev->netdev = dev;
+ arPriv->arNetworkType = INFRA_NETWORK;
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+ if (ifname[0])
+ {
+ sprintf(dev->name, "%s%d", ifname,(devnum + device_index));
+ }
+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) */
+
+#ifdef SET_MODULE_OWNER
+ SET_MODULE_OWNER(dev);
+#endif
+
+#ifdef SET_NETDEV_DEV
+#if 0
+ if (ar_netif) {
+ HIF_DEVICE_OS_DEVICE_INFO osDevInfo;
+ A_MEMZERO(&osDevInfo, sizeof(osDevInfo));
+ if ( A_SUCCESS( HIFConfigureDevice(hif_handle, HIF_DEVICE_GET_OS_DEVICE,
+ &osDevInfo, sizeof(osDevInfo))) ) {
+ SET_NETDEV_DEV(dev, osDevInfo.pOSDevice);
+ }
+ }
+#endif
+#endif
+
+ arPriv->arNetDev = dev;
+ ar6000_devices[device_index] = dev;
+ arPriv->arSoftc = ar;
+ ar->arDev[device_index] = arPriv;
+ ar->arWlanState = WLAN_ENABLED;
+ arPriv->arDeviceIndex = device_index;
+
+ ar->arWlanPowerState = WLAN_POWER_STATE_ON;
+
+#ifndef ATH6K_CONFIG_CFG80211
+#ifdef SET_NETDEV_DEV
+ SET_NETDEV_DEV(dev, osDevInfo.pOSDevice);
+#endif
+#endif
+
+ if(ar6000_init_control_info(arPriv) != A_OK) {
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+ init_waitqueue_head(&arPriv->arEvent);
+
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+ A_INIT_TIMER(&aptcTimer[i], aptcTimerHandler, ar);
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+
+ spin_lock_init(&arPriv->arPrivLock);
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29)
+ dev->open = &ar6000_open;
+ dev->stop = &ar6000_close;
+ dev->hard_start_xmit = &ar6000_data_tx;
+ dev->get_stats = &ar6000_get_stats;
+
+ /* dev->tx_timeout = ar6000_tx_timeout; */
+ dev->do_ioctl = &ar6000_ioctl;
+ dev->set_multicast_list = &ar6000_set_multicast_list;
+#else
+ dev->netdev_ops = &ar6000_netdev_ops;
+#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29) */
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24)
+ dev->ethtool_ops = &ar6000_ethtool_ops;
+#endif
+ dev->watchdog_timeo = AR6000_TX_TIMEOUT;
+ dev->wireless_handlers = &ath_iw_handler_def;
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19)
+ dev->get_wireless_stats = ar6000_get_iwstats; /*Displayed via proc fs */
+#else
+ ath_iw_handler_def.get_wireless_stats = ar6000_get_iwstats; /*Displayed via proc fs */
+#endif
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+ if(csumOffload){
+
+ dev->features |= NETIF_F_IP_CSUM;/*advertise kernel capability
+ to do TCP/UDP CSUM offload for IPV4*/
+ }
+#endif
+ if (processDot11Hdr) {
+ dev->hard_header_len = sizeof(struct ieee80211_qosframe) + sizeof(ATH_LLC_SNAP_HDR) + sizeof(WMI_DATA_HDR) + HTC_HEADER_LEN + WMI_MAX_TX_META_SZ + LINUX_HACK_FUDGE_FACTOR;
+ } else {
+ /*
+ * We need the OS to provide us with more headroom in order to
+ * perform dix to 802.3, WMI header encap, and the HTC header
+ */
+ dev->hard_header_len = ETH_HLEN + sizeof(ATH_LLC_SNAP_HDR) +
+ sizeof(WMI_DATA_HDR) + HTC_HEADER_LEN + WMI_MAX_TX_META_SZ + LINUX_HACK_FUDGE_FACTOR;
+ }
+
+ if (!bypasswmi && !eppingtest)
+ {
+ /* Indicate that WMI is enabled (although not ready yet) */
+ arPriv->arWmiEnabled = TRUE;
+ if ((arPriv->arWmi = wmi_init((void *) arPriv,arPriv->arDeviceIndex)) == NULL)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s() Failed to initialize WMI.\n", __func__));
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%s() Got WMI @ 0x%08x.\n", __func__,
+ (unsigned int) arPriv->arWmi));
+ }
+#ifdef P2P
+ /* Allocate P2P module context if this dev is in any of the P2P modes.
+ * For non-P2P devices, this may be allocated just in time when the
+ * device assumes a P2P submode. This may be needed when we do
+ * mode switch between none and P2P submodes. For later enhancement.
+ */
+ if (arPriv->arNetworkSubType == SUBTYPE_P2PDEV ||
+ arPriv->arNetworkSubType == SUBTYPE_P2PCLIENT ||
+ arPriv->arNetworkSubType == SUBTYPE_P2PGO) {
+ arPriv->p2p_ctx = p2p_init(arPriv);
+ if (arPriv->p2p_ctx == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s() Failed to initialize p2p_ctx.\n", __func__));
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+ p2p_update_capability(A_WMI_GET_P2P_CTX(arPriv),arPriv->arNetworkSubType,num_device);
+ }
+#endif /* P2P */
+ }
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+ if(testmode) {
+ ar->arTargetMode = AR6000_TCMD_MODE;
+ }else {
+ ar->arTargetMode = AR6000_WLAN_MODE;
+ }
+#endif
+ ar->arWlanOff = FALSE; /* We are in ON state */
+#ifdef CONFIG_PM
+ ar->arWowState = WLAN_WOW_STATE_NONE;
+ ar->arBTOff = TRUE; /* BT chip assumed to be OFF */
+ ar->arBTSharing = WLAN_CONFIG_BT_SHARING;
+ ar->arWlanOffConfig = WLAN_CONFIG_WLAN_OFF;
+ ar->arSuspendConfig = WLAN_CONFIG_PM_SUSPEND;
+ ar->arWow2Config = WLAN_CONFIG_PM_WOW2;
+#endif /* CONFIG_PM */
+
+ A_INIT_TIMER(&ar->arHBChallengeResp.timer, ar6000_detect_error, ar);
+ ar->arHBChallengeResp.seqNum = 0;
+ ar->arHBChallengeResp.outstanding = FALSE;
+ ar->arHBChallengeResp.missCnt = 0;
+ ar->arHBChallengeResp.frequency = AR6000_HB_CHALLENGE_RESP_FREQ_DEFAULT;
+ ar->arHBChallengeResp.missThres = AR6000_HB_CHALLENGE_RESP_MISS_THRES_DEFAULT;
+ ar->arHifDevice = hif_handle;
+ sema_init(&ar->arSem, 1);
+ ar->bIsDestroyProgress = FALSE;
+
+ ar->delbaState = REASON_DELBA_INIT;
+ ar->IsdelbaTimerInitialized = FALSE;
+ A_INIT_TIMER (&ar->delbaTimer, delba_timer_callback, ar);
+
+ ar->isHostAsleep = 0;
+
+ INIT_HTC_PACKET_QUEUE(&ar->amsdu_rx_buffer_queue);
+ /*
+ * If requested, perform some magic which requires no cooperation from
+ * the Target. It causes the Target to ignore flash and execute to the
+ * OS from ROM.
+ *
+ * This is intended to support recovery from a corrupted flash on Targets
+ * that support flash.
+ */
+ if (skipflash)
+ {
+ //ar6000_reset_device_skipflash(ar->arHifDevice);
+ }
+
+ BMIInit();
+
+ if (bmienable) {
+ ar6000_sysfs_bmi_init(ar);
+ }
+
+ {
+ struct bmi_target_info targ_info;
+ A_MEMZERO(&targ_info, sizeof(targ_info));
+ if (BMIGetTargetInfo(ar->arHifDevice, &targ_info) != A_OK) {
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+
+ ar->arVersion.target_ver = targ_info.target_ver;
+ ar->arTargetType = targ_info.target_type;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%s() TARGET TYPE: %d\n", __func__,ar->arTargetType));
+ target_register_tbl_attach(ar->arTargetType);
+
+ /* do any target-specific preparation that can be done through BMI */
+ if (ar6000_prepare_target(ar->arHifDevice,
+ targ_info.target_type,
+ targ_info.target_ver) != A_OK) {
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+
+ }
+ if (ar6000_configure_target(ar) != A_OK) {
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+
+ A_MEMZERO(&htcInfo,sizeof(htcInfo));
+ htcInfo.pContext = ar;
+ htcInfo.TargetFailure = ar6000_target_failure;
+
+ ar->arHtcTarget = HTCCreate(ar->arHifDevice,&htcInfo);
+
+ if (ar->arHtcTarget == NULL) {
+ init_status = A_ERROR;
+ goto avail_ev_failed;
+ }
+
+ spin_lock_init(&ar->arLock);
+
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+ if(csumOffload){
+
+ ar->rxMetaVersion=WMI_META_VERSION_2;/*if external frame work is also needed, change and use an extended rxMetaVerion*/
+ }
+#endif
+
+ HIFClaimDevice(ar->arHifDevice, ar);
+
+ if (bmienable)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("BMI enabled: %d\n", wlaninitmode));
+ if ((wlaninitmode == WLAN_INIT_MODE_UDEV) ||
+ (wlaninitmode == WLAN_INIT_MODE_DRV))
+ {
+ A_STATUS status = A_OK;
+ do {
+ if ((status = ar6000_sysfs_bmi_get_config(ar, wlaninitmode)) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_avail: ar6000_sysfs_bmi_get_config failed\n"));
+ break;
+ }
+
+ dev = ar6000_devices[0];
+#ifdef HTC_RAW_INTERFACE
+ if (!eppingtest && bypasswmi) {
+ break; /* Don't call ar6000_init for ART */
+ }
+#endif
+ status = (ar6000_init(dev)==0) ? A_OK : A_ERROR;
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_avail: ar6000_init\n"));
+ }
+ } while (FALSE);
+
+ if (status != A_OK) {
+ init_status = status;
+ goto avail_ev_failed;
+ }
+ }
+ }
+#ifdef CONFIG_PM
+ init_waitqueue_head(&ar->sleep_mode_cmd_completed_event);
+#endif
+ for (i=0; i < num_device; i++)
+ {
+ dev = ar6000_devices[i];
+ arPriv = ar6k_priv(dev);
+ ar = arPriv->arSoftc;
+
+ /* Don't install the init function if BMI is requested */
+ if (!bmienable) {
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29)
+ dev->init = ar6000_init;
+#else
+ ar6000_netdev_ops.ndo_init = ar6000_init;
+#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29) */
+ }
+
+ /* This runs the init function if registered */
+ if (register_netdev(dev)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("ar6000_avail: register_netdev failed\n"));
+ ar6000_cleanup(ar);
+ ar6000_devices[i] = NULL;
+ ar6000_destroy(dev, 0);
+ complete(&avail_ev_completion);
+ return A_ERROR;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ar6000_avail: name=%s hifdevice=0x%lx, dev=0x%lx (%d), ar=0x%lx\n",
+ dev->name, (unsigned long)ar->arHifDevice, (unsigned long)dev, device_index,
+ (unsigned long)ar));
+
+ }
+
+avail_ev_failed :
+ if (A_FAILED(init_status)) {
+ if (bmienable) {
+ ar6000_sysfs_bmi_deinit(ar);
+ }
+ for (i=0; i < num_device; i++)
+ {
+ dev = ar6000_devices[i];
+ arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ if(arPriv->arWmiEnabled == TRUE)
+ {
+ wmi_shutdown(arPriv->arWmi);
+ arPriv->arWmiEnabled = FALSE;
+ }
+ ar6000_devices[i] = NULL;
+ }
+ A_FREE(ar);
+ }
+ complete(&avail_ev_completion);
+
+ mod_loaded = TRUE;
+ wake_up_interruptible(&load_complete);
+
+ printk("Completed loading the module %s\n", __func__);
+ return init_status;
+}
+
+static void ar6000_target_failure(void *Instance, A_STATUS Status)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)Instance;
+ WMI_TARGET_ERROR_REPORT_EVENT errEvent;
+ static A_BOOL sip = FALSE;
+ A_UINT8 i;
+
+ if (Status != A_OK) {
+
+ printk(KERN_ERR "ar6000_target_failure: target asserted \n");
+
+ if (timer_pending(&ar->arHBChallengeResp.timer)) {
+ A_UNTIMEOUT(&ar->arHBChallengeResp.timer);
+ }
+
+ /* try dumping target assertion information (if any) */
+ ar6000_dump_target_assert_info(ar->arHifDevice,ar->arTargetType);
+
+ /*
+ * Fetch the logs from the target via the diagnostic
+ * window.
+ */
+ ar6000_dbglog_get_debug_logs(ar);
+
+ /* Report the error only once */
+ if (!sip) {
+ sip = TRUE;
+ errEvent.errorVal = WMI_TARGET_COM_ERR |
+ WMI_TARGET_FATAL_ERR;
+ for(i = 0; i < num_device; i++)
+ {
+
+ ar6000_send_event_to_app(ar->arDev[i], WMI_ERROR_REPORT_EVENTID,
+ (A_UINT8 *)&errEvent,
+ sizeof(WMI_TARGET_ERROR_REPORT_EVENT));
+
+ }
+ }
+ }
+}
+
+static A_STATUS
+ar6000_unavail_ev(void *context, void *hif_handle)
+{
+ unsigned int old_reset_ok = resetok;
+ A_UINT8 i;
+ struct net_device *ar6000_netdev;
+ AR_SOFTC_T *ar = (AR_SOFTC_T*)context;
+ resetok = 0; /* card is remove, don't reset */
+ ar6000_cleanup(ar);
+ resetok = old_reset_ok;
+ /* NULL out it's entry in the global list */
+ for(i = 0; i < num_device; i++) {
+ ar6000_netdev = ar6000_devices[i];
+ ar6000_devices[i] = NULL;
+ ar6000_destroy(ar6000_netdev, 1);
+ }
+
+ return A_OK;
+}
+
+/*
+ * EV93295 Kernel panic "cannot create duplicate filename 'bmi'"
+ */
+A_BOOL restart_endpoint_called = FALSE;
+
+void
+ar6000_restart_endpoint(AR_SOFTC_T *ar)
+{
+ A_STATUS status = A_OK;
+ AR_SOFTC_DEV_T *arPriv;
+ struct net_device *dev;
+ A_UINT8 i = 0;
+
+ if(restart_endpoint_called) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("AR6K: %s() already called.\n", __func__));
+ dump_stack();
+ return;
+ }
+ restart_endpoint_called = TRUE;
+
+ /*
+ * Call wmi_init for each device. This must be done BEFORE ar6000_init() is
+ * called, or we will get a null pointer exception in the wmi code. We must
+ * also set the arWmiEnabled flag for each device.
+ */
+ for(i = 0; i < num_device; i++) {
+ arPriv = ar->arDev[i];
+ arPriv->arWmiEnabled = TRUE;
+ if ((arPriv->arWmi = wmi_init((void *) arPriv,arPriv->arDeviceIndex)) == NULL)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s() Failed to initialize WMI.\n", __func__));
+ status = A_ERROR;
+ goto exit;
+ }
+ }
+
+ BMIInit();
+ if (bmienable) {
+ ar6000_sysfs_bmi_init(ar);
+ }
+ do {
+ if ( (status=ar6000_configure_target(ar))!=A_OK)
+ break;
+ if ( (status=ar6000_sysfs_bmi_get_config(ar, wlaninitmode)) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_avail: ar6000_sysfs_bmi_get_config failed\n"));
+ break;
+ }
+ } while(0);
+
+ dev = ar6000_devices[0];
+ status = (ar6000_init(dev)==0) ? A_OK : A_ERROR;
+
+ if (status != A_OK) {
+ goto exit;
+ }
+
+
+ for(i = 0; i < num_device; i++) {
+ arPriv = ar->arDev[i];
+ if (arPriv->arDoConnectOnResume &&
+ arPriv->arSsidLen &&
+ ar->arWlanState == WLAN_ENABLED)
+ {
+ ar6000_connect_to_ap(arPriv);
+ }
+ }
+
+ if (status == A_OK) {
+ restart_endpoint_called = FALSE;
+ return;
+ }
+
+exit:
+ for(i = 0; i < num_device; i++) {
+ arPriv = ar->arDev[i];
+ ar6000_devices[i] = NULL;
+ ar6000_destroy(arPriv->arNetDev, 1);
+ }
+ restart_endpoint_called = FALSE;
+}
+
+void
+ar6000_stop_endpoint(AR_SOFTC_T *ar, A_BOOL keepprofile, A_BOOL getdbglogs)
+{
+
+ AR_SOFTC_DEV_T *arPriv ;
+ A_UINT8 i;
+ A_UINT8 ctr;
+ AR_SOFTC_STA_T *arSta;
+
+ for(i = 0; i < num_device; i++)
+ {
+ arPriv = ar->arDev[i];
+ arSta = &arPriv->arSta;
+ /* Stop the transmit queues */
+ netif_stop_queue(arPriv->arNetDev);
+
+ /* Disable the target and the interrupts associated with it */
+ if (ar->arWmiReady == TRUE)
+ {
+ if (!bypasswmi) {
+ A_BOOL disconnectIssued;
+
+ arPriv->arDoConnectOnResume = arPriv->arConnected;
+
+ A_UNTIMEOUT(&arPriv->arSta.disconnect_timer);
+ A_UNTIMEOUT(&ar->ap_reconnect_timer);
+// AP + BTCOEX State variables resetted here.
+ ar->IsdelbaTimerInitialized = FALSE;
+ A_UNTIMEOUT(&ar->delbaTimer);
+ ar->delbaState = REASON_DELBA_INIT;
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+ /* Delete the Adaptive Power Control timer */
+ if (timer_pending(&aptcTimer[i])) {
+ del_timer_sync(&aptcTimer[i]);
+ }
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+#ifdef ATH_AR6K_11N_SUPPORT
+ for (ctr=0; ctr < NUM_CONN ; ctr++) {
+ aggr_module_destroy_timers(ar->connTbl[ctr].conn_aggr);
+ }
+#endif
+
+ if (!wait_event_interruptible_timeout(scan_complete, !arSta->scan_triggered, 2 * HZ)) {
+ printk(KERN_ERR "scan complete not received\n");
+ }
+
+ disconnectIssued = (arPriv->arConnected) || (arPriv->arSta.arConnectPending);
+ ar6000_disconnect(arPriv);
+ if (!keepprofile) {
+ ar6000_init_profile_info(arPriv);
+ }
+ if (getdbglogs) {
+ ar6000_dbglog_get_debug_logs(ar);
+ }
+ ar->arWmiReady = FALSE;
+ arPriv->arWmiEnabled = FALSE;
+ wmi_shutdown(arPriv->arWmi);
+ arPriv->arWmi = NULL;
+ /*
+ * After wmi_shudown all WMI events will be dropped.
+ * We need to cleanup the buffers allocated in AP mode
+ * and give disconnect notification to stack, which usually
+ * happens in the disconnect_event.
+ * Simulate the disconnect_event by calling the function directly.
+ * Sometimes disconnect_event will be received when the debug logs
+ * are collected.
+ */
+ if (disconnectIssued) {
+ if(arPriv->arNetworkType & AP_NETWORK) {
+ ar6000_disconnect_event(arPriv, DISCONNECT_CMD, bcast_mac, 0, NULL, 0);
+ } else {
+ ar6000_disconnect_event(arPriv, DISCONNECT_CMD, arPriv->arBssid, 0, NULL, 0);
+ }
+ }
+#ifdef USER_KEYS
+ arPriv->arSta.user_savedkeys_stat = USER_SAVEDKEYS_STAT_INIT;
+ arPriv->arSta.user_key_ctrl = 0;
+#endif
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%s(): WMI stopped\n", __func__));
+ }
+ else
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%s(): WMI not ready 0x%lx 0x%lx\n",
+ __func__, (unsigned long) ar, (unsigned long) arPriv->arWmi));
+ /* Shut down WMI if we have started it */
+ if(arPriv->arWmiEnabled == TRUE)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%s(): Shut down WMI\n", __func__));
+ arPriv->arWmiEnabled = FALSE;
+ wmi_shutdown(arPriv->arWmi);
+ arPriv->arWmi = NULL;
+ }
+ }
+ /* cleanup hci pal driver data structures */
+ if (setuphcipal && (arPriv->isBt30amp == TRUE)) {
+ ar6k_cleanup_hci_pal(arPriv);
+ }
+ }
+
+ if (ar->arHtcTarget != NULL) {
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ if (NULL != ar6kHciTransCallbacks.cleanupTransport) {
+ ar6kHciTransCallbacks.cleanupTransport(NULL);
+ }
+#else
+ // FIXME: workaround to reset BT's UART baud rate to default
+ if (NULL != ar->exitCallback) {
+ AR3K_CONFIG_INFO ar3kconfig;
+ A_STATUS status;
+
+ A_MEMZERO(&ar3kconfig,sizeof(ar3kconfig));
+ ar6000_set_default_ar3kconfig(ar, (void *)&ar3kconfig);
+ status = ar->exitCallback(&ar3kconfig);
+ if (A_OK != status) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Failed to reset AR3K baud rate! \n"));
+ }
+ }
+ // END workaround
+ if (setuphci)
+ ar6000_cleanup_hci(ar);
+#endif
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,(" Shutting down HTC .... \n"));
+ /* stop HTC */
+ HTCStop(ar->arHtcTarget);
+ ar6k_init = FALSE;
+ }
+
+ if (resetok) {
+ /* try to reset the device if we can
+ * The driver may have been configure NOT to reset the target during
+ * a debug session */
+ AR_DEBUG_PRINTF(ATH_DEBUG_ANY,(" Attempting to reset target on instance destroy.... \n"));
+ if (ar->arHifDevice != NULL) {
+#if defined(CONFIG_MMC_MSM) || defined(CONFIG_MMC_SDHCI_S3C)
+ A_BOOL coldReset = ((ar->arTargetType == TARGET_TYPE_AR6003)|| (ar->arTargetType == TARGET_TYPE_MCKINLEY)) ? TRUE: FALSE;
+#else
+ A_BOOL coldReset = (ar->arTargetType == TARGET_TYPE_MCKINLEY) ? TRUE: FALSE;
+#endif
+ ar6000_reset_device(ar->arHifDevice, ar->arTargetType, TRUE, coldReset);
+ }
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,(" Host does not want target reset. \n"));
+ }
+ /* Done with cookies */
+ ar6000_cookie_cleanup(ar);
+
+ /* cleanup any allocated AMSDU buffers */
+ ar6000_cleanup_amsdu_rxbufs(ar);
+
+ if (bmienable) {
+ ar6000_sysfs_bmi_deinit(ar);
+ }
+}
+
+void ar6000_cleanup(AR_SOFTC_T *ar)
+{
+ A_UINT8 ctr;
+ ar->bIsDestroyProgress = TRUE;
+
+ if (down_interruptible(&ar->arSem)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s(): down_interruptible failed \n", __func__));
+ return;
+ }
+
+ if (ar->arWlanPowerState != WLAN_POWER_STATE_CUT_PWR) {
+ /* only stop endpoint if we are not stop it in suspend_ev */
+ ar6000_stop_endpoint(ar, FALSE, TRUE);
+ } else {
+ /* clear up the platform power state before rmmod */
+ plat_setup_power(ar, 1, 0);
+ ar->arPlatPowerOff = FALSE;
+ }
+
+#ifdef ATH_AR6K_11N_SUPPORT
+ for (ctr=0; ctr < NUM_CONN ; ctr++) {
+ aggr_module_destroy_conn(ar->connTbl[ctr].conn_aggr);
+ }
+ aggr_module_destroy();
+#endif
+
+ ar->arWlanState = WLAN_DISABLED;
+
+ up(&ar->arSem);
+
+ if (ar->arHtcTarget != NULL) {
+ /* destroy HTC */
+ HTCDestroy(ar->arHtcTarget);
+ }
+ if (ar->arHifDevice != NULL) {
+ /*release the device so we do not get called back on remove incase we
+ * we're explicity destroyed by module unload */
+ HIFReleaseDevice(ar->arHifDevice);
+ HIFShutDownDevice(ar->arHifDevice);
+ }
+ /* Done with cookies */
+ ar6000_cookie_cleanup(ar);
+
+ /* cleanup any allocated AMSDU buffers */
+ ar6000_cleanup_amsdu_rxbufs(ar);
+
+ if (bmienable) {
+ ar6000_sysfs_bmi_deinit(ar);
+ }
+
+ /* Cleanup BMI */
+ BMICleanup();
+
+ /* Clear the tx counters */
+ memset(tx_attempt, 0, sizeof(tx_attempt));
+ memset(tx_post, 0, sizeof(tx_post));
+ memset(tx_complete, 0, sizeof(tx_complete));
+
+#ifdef HTC_RAW_INTERFACE
+ if (ar->arRawHtc) {
+ A_FREE(ar->arRawHtc);
+ ar->arRawHtc = NULL;
+ }
+#endif
+ A_UNTIMEOUT(&ar->ap_reconnect_timer);
+ A_UNTIMEOUT(&ar->arHBChallengeResp.timer);
+// AP + BTCOEX State variables resetted here.
+ ar->IsdelbaTimerInitialized = FALSE;
+ A_UNTIMEOUT(&ar->delbaTimer);
+ ar->delbaState = REASON_DELBA_INIT;
+ A_FREE(ar);
+
+}
+/*
+ * We need to differentiate between the surprise and planned removal of the
+ * device because of the following consideration:
+ * - In case of surprise removal, the hcd already frees up the pending
+ * for the device and hence there is no need to unregister the function
+ * driver inorder to get these requests. For planned removal, the function
+ * driver has to explictly unregister itself to have the hcd return all the
+ * pending requests before the data structures for the devices are freed up.
+ * Note that as per the current implementation, the function driver will
+ * end up releasing all the devices since there is no API to selectively
+ * release a particular device.
+ * - Certain commands issued to the target can be skipped for surprise
+ * removal since they will anyway not go through.
+ */
+void
+ar6000_destroy(struct net_device *dev, unsigned int unregister)
+{
+ AR_SOFTC_DEV_T *arPriv;
+ AR_SOFTC_AP_T *arAp;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("+ar6000_destroy \n"));
+
+ if((dev == NULL) || ((arPriv = ar6k_priv(dev)) == NULL))
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s(): Failed to get device structure.\n", __func__));
+ return;
+ }
+
+ aggr_module_destroy_conn(arPriv->conn_aggr);
+
+ if(arPriv->arNetworkType == AP_NETWORK)
+ {
+ arAp = &arPriv->arAp;
+
+#ifdef ATH_SUPPORT_DFS
+ dfs_detach_host(arAp->pDfs);
+#endif
+ }
+#ifdef P2P
+ A_FREE(arPriv->p2p_ctx);
+#endif /* P2P */
+ ar6k_init = FALSE;
+ /* Free up the device data structure */
+ if (unregister) {
+ unregister_netdev(dev);
+ }
+#ifndef HAVE_FREE_NETDEV
+ kfree(dev);
+#else
+ free_netdev(dev);
+#endif
+
+#ifdef ATH6K_CONFIG_CFG80211
+ ar6k_cfg80211_deinit(arPriv);
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("-ar6000_destroy \n"));
+}
+
+static void delba_timer_callback(unsigned long ptr)
+{
+ AR_SOFTC_T *ar= (AR_SOFTC_T *)ptr;
+ do
+ {
+ if (NULL != ar)
+ {
+ if (!ar->IsdelbaTimerInitialized)
+ {
+ break;
+ }
+
+ ar->IsdelbaTimerInitialized = FALSE;
+ A_UNTIMEOUT (&ar->delbaTimer);
+
+ ar6000_send_delba (ar, REASON_DELBA_TIMEOUT);
+ ar->delbaState = REASON_DELBA_INIT;
+ }
+
+ }while (FALSE);
+
+}
+
+static void ap_reconnect_timer_handler(unsigned long ptr)
+{
+ AR_SOFTC_T *ar= (AR_SOFTC_T *)ptr;
+ AR_SOFTC_DEV_T *arTempPriv = NULL;
+ A_UINT8 i=0;
+ A_UNTIMEOUT(&ar->ap_reconnect_timer);
+
+ if(ar->arHoldConnection){
+ for(i=0;i<ar->arConfNumDev;i++){
+ arTempPriv = ar->arDev[i];
+ if((AP_NETWORK == arTempPriv->arNetworkType) &&
+ (ar->arHoldConnection & (1<<arTempPriv->arDeviceIndex))){
+ ar->arHoldConnection &= ~(1<<arTempPriv->arDeviceIndex);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ap_reconnect_timer_handler: starting AP %d", arTempPriv->arDeviceIndex));
+ ar6000_ap_mode_profile_commit(arTempPriv);
+ break;
+ }
+ }
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ar6000_reconnect_timer_handler : no"
+ " device pending for connect\n"));
+ }
+}
+static void disconnect_timer_handler(unsigned long ptr)
+{
+ struct net_device *dev = (struct net_device *)ptr;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ A_UNTIMEOUT(&arPriv->arSta.disconnect_timer);
+
+ ar6000_init_profile_info(arPriv);
+
+ ar6000_disconnect(arPriv);
+}
+
+static void ar6000_detect_error(unsigned long ptr)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)ptr;
+ A_UINT8 i;
+ WMI_TARGET_ERROR_REPORT_EVENT errEvent;
+
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ if (ar->arHBChallengeResp.outstanding) {
+ ar->arHBChallengeResp.missCnt++;
+ } else {
+ ar->arHBChallengeResp.missCnt = 0;
+ }
+
+ if (ar->arHBChallengeResp.missCnt > ar->arHBChallengeResp.missThres) {
+ /* Send Error Detect event to the application layer and do not reschedule the error detection module timer */
+ ar->arHBChallengeResp.missCnt = 0;
+ ar->arHBChallengeResp.seqNum = 0;
+ errEvent.errorVal = WMI_TARGET_COM_ERR | WMI_TARGET_FATAL_ERR;
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ for(i = 0; i < num_device; i++)
+ {
+ ar6000_send_event_to_app(ar->arDev[i], WMI_ERROR_REPORT_EVENTID,
+ (A_UINT8 *)&errEvent,
+ sizeof(WMI_TARGET_ERROR_REPORT_EVENT));
+ }
+ return;
+ }
+
+ /* Generate the sequence number for the next challenge */
+ ar->arHBChallengeResp.seqNum++;
+ ar->arHBChallengeResp.outstanding = TRUE;
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ /* Send the challenge on the control channel */
+ if (wmi_get_challenge_resp_cmd(ar->arDev[0]->arWmi, ar->arHBChallengeResp.seqNum, DRV_HB_CHALLENGE) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unable to send heart beat challenge\n"));
+ }
+
+
+ /* Reschedule the timer for the next challenge */
+ A_TIMEOUT_MS(&ar->arHBChallengeResp.timer, ar->arHBChallengeResp.frequency * 1000, 0);
+}
+
+void ar6000_init_profile_info(AR_SOFTC_DEV_T *arPriv)
+{
+ A_UINT8 mode = 0;
+#ifdef P2P
+ A_UINT8 submode = 0;
+#endif
+ mode = ((fwmode >> (arPriv->arDeviceIndex * HI_OPTION_FW_MODE_BITS)) & (HI_OPTION_FW_MODE_MASK ));
+
+ switch(mode) {
+ case HI_OPTION_FW_MODE_IBSS:
+ arPriv->arNetworkType = arPriv->arNextMode = ADHOC_NETWORK;
+ break;
+ case HI_OPTION_FW_MODE_BSS_STA:
+ arPriv->arNetworkType = arPriv->arNextMode = INFRA_NETWORK;
+ break;
+ case HI_OPTION_FW_MODE_AP:
+ arPriv->arNetworkType = arPriv->arNextMode = AP_NETWORK;
+ break;
+ case HI_OPTION_FW_MODE_BT30AMP:
+ arPriv->arNetworkType = arPriv->arNextMode = INFRA_NETWORK;
+ arPriv->isBt30amp = TRUE;
+ break;
+ }
+
+#ifdef P2P
+ /* Initialize firware sub mode
+ */
+ submode = ((fwsubmode>>(arPriv->arDeviceIndex * HI_OPTION_FW_SUBMODE_BITS))
+ & (HI_OPTION_FW_SUBMODE_MASK));
+
+ switch(submode) {
+ case HI_OPTION_FW_SUBMODE_NONE:
+ arPriv->arNetworkSubType = SUBTYPE_NONE;
+ break;
+ case HI_OPTION_FW_SUBMODE_P2PDEV:
+ arPriv->arNetworkSubType = SUBTYPE_P2PDEV;
+ break;
+ case HI_OPTION_FW_SUBMODE_P2PCLIENT:
+ arPriv->arNetworkSubType = SUBTYPE_P2PCLIENT;
+ break;
+ case HI_OPTION_FW_SUBMODE_P2PGO:
+ arPriv->arNetworkSubType = SUBTYPE_P2PGO;
+ break;
+ }
+#endif
+
+ ar6000_init_mode_info(arPriv);
+}
+
+static int
+ar6000_init_control_info(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ arPriv->arWmiEnabled = FALSE;
+ ar->arVersion.host_ver = AR6K_SW_VERSION;
+
+ if(!(strcmp(targetconf,"mobile")))
+ ar->arVersion.targetconf_ver = AR6003_SUBVER_MOBILE;
+ else if(!(strcmp(targetconf,"tablet")))
+ ar->arVersion.targetconf_ver = AR6003_SUBVER_TABLET;
+ else if(!(strcmp(targetconf,"router")))
+ ar->arVersion.targetconf_ver = AR6003_SUBVER_ROUTER;
+ else
+ ar->arVersion.targetconf_ver = AR6003_SUBVER_DEFAULT;
+
+ ar6000_init_profile_info(arPriv);
+
+ if((arPriv->conn_aggr = aggr_init_conn()) == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s() Failed to initialize aggr.\n", __func__));
+ return A_ERROR;
+ }
+ return A_OK;
+}
+
+static int
+ar6000_open(struct net_device *dev)
+{
+ unsigned long flags;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ spin_lock_irqsave(&arPriv->arPrivLock, flags);
+
+#ifdef ATH6K_CONFIG_CFG80211
+ if(arPriv->arSoftc->arWlanState == WLAN_DISABLED) {
+ arPriv->arSoftc->arWlanState = WLAN_ENABLED;
+ }
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ if( arPriv->arConnected || bypasswmi) {
+ netif_carrier_on(dev);
+ /* Wake up the queues */
+ netif_wake_queue(dev);
+ }
+ else
+ netif_carrier_off(dev);
+
+ spin_unlock_irqrestore(&arPriv->arPrivLock, flags);
+ return 0;
+}
+
+static int
+ar6000_close(struct net_device *dev)
+{
+#ifdef ATH6K_CONFIG_CFG80211
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+#endif /* ATH6K_CONFIG_CFG80211 */
+ netif_stop_queue(dev);
+
+#ifdef ATH6K_CONFIG_CFG80211
+ ar6000_disconnect(arPriv);
+
+ if(arPriv->arSoftc->arWmiReady == TRUE) {
+ if (wmi_scanparams_cmd(arPriv->arWmi, 0xFFFF, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0) != A_OK) {
+ return -EIO;
+ }
+ arPriv->arSoftc->arWlanState = WLAN_DISABLED;
+ }
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ return 0;
+}
+
+/* connect to a service */
+static A_STATUS ar6000_connectservice(AR_SOFTC_DEV_T *arPriv,
+ HTC_SERVICE_CONNECT_REQ *pConnect,
+ char *pDesc)
+{
+ A_STATUS status;
+ HTC_SERVICE_CONNECT_RESP response;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ do {
+
+ A_MEMZERO(&response,sizeof(response));
+
+ status = HTCConnectService(ar->arHtcTarget,
+ pConnect,
+ &response);
+
+ if (A_FAILED(status)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,(" Failed to connect to %s service status:%d \n",
+ pDesc, status));
+ break;
+ }
+ switch (pConnect->ServiceID) {
+ case WMI_CONTROL_SVC :
+ if(!bypasswmi)
+ {
+ /* set control endpoint for WMI use */
+ wmi_set_control_ep(arPriv->arWmi, response.Endpoint);
+ /* save EP for fast lookup */
+ ar->arControlEp = response.Endpoint;
+ }
+ break;
+ case WMI_DATA_BE_SVC :
+ arSetAc2EndpointIDMap(ar, WMM_AC_BE, response.Endpoint);
+ break;
+ case WMI_DATA_BK_SVC :
+ arSetAc2EndpointIDMap(ar, WMM_AC_BK, response.Endpoint);
+ break;
+ case WMI_DATA_VI_SVC :
+ arSetAc2EndpointIDMap(ar, WMM_AC_VI, response.Endpoint);
+ break;
+ case WMI_DATA_VO_SVC :
+ arSetAc2EndpointIDMap(ar, WMM_AC_VO, response.Endpoint);
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ServiceID not mapped %d\n", pConnect->ServiceID));
+ status = A_EINVAL;
+ break;
+ }
+
+ } while (FALSE);
+
+ return status;
+}
+
+void ar6000_TxDataCleanup(AR_SOFTC_T *ar)
+{
+ /* flush all the data (non-control) streams
+ * we only flush packets that are tagged as data, we leave any control packets that
+ * were in the TX queues alone */
+ HTCFlushEndpoint(ar->arHtcTarget,
+ arAc2EndpointID(ar, WMM_AC_BE),
+ AR6K_DATA_PKT_TAG);
+ HTCFlushEndpoint(ar->arHtcTarget,
+ arAc2EndpointID(ar, WMM_AC_BK),
+ AR6K_DATA_PKT_TAG);
+ HTCFlushEndpoint(ar->arHtcTarget,
+ arAc2EndpointID(ar, WMM_AC_VI),
+ AR6K_DATA_PKT_TAG);
+ HTCFlushEndpoint(ar->arHtcTarget,
+ arAc2EndpointID(ar, WMM_AC_VO),
+ AR6K_DATA_PKT_TAG);
+}
+
+HTC_ENDPOINT_ID
+ar6000_ac2_endpoint_id ( void * devt, A_UINT8 ac)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *) devt;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ return(arAc2EndpointID(ar, ac));
+}
+
+A_UINT8
+ar6000_endpoint_id2_ac(void * devt, HTC_ENDPOINT_ID ep )
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *) devt;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ return(arEndpoint2Ac(ar, ep ));
+}
+
+
+/* This function does one time initialization for the lifetime of the device */
+int ar6000_init(struct net_device *dev)
+{
+ AR_SOFTC_DEV_T *arPriv;
+ AR_SOFTC_T *ar;
+ int ret = 0;
+ int i = 0;
+ int j = 0;
+ A_STATUS status;
+ A_INT32 timeleft;
+#if defined(INIT_MODE_DRV_ENABLED) && defined(ENABLE_COEXISTENCE)
+ WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD sbcb_cmd;
+ WMI_SET_BTCOEX_FE_ANT_CMD sbfa_cmd;
+#endif /* INIT_MODE_DRV_ENABLED && ENABLE_COEXISTENCE */
+
+ dev_hold(dev);
+
+ if(ar6k_init)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("AR6000 Initialised\n"));
+ goto ar6000_init_done;
+ }
+
+ ar6k_init = TRUE;
+ if((arPriv = ar6k_priv(dev)) == NULL)
+ {
+ ret = -EIO;
+ goto ar6000_init_done;
+ }
+
+ ar = arPriv->arSoftc;
+
+ if (wlaninitmode == WLAN_INIT_MODE_USR || wlaninitmode == WLAN_INIT_MODE_DRV) {
+
+ ar6000_update_bdaddr(ar);
+ }
+
+ if (enablerssicompensation) {
+ ar6000_copy_cust_data_from_target(ar->arHifDevice, ar->arTargetType);
+ read_rssi_compensation_param(ar);
+ for(j=0; j<num_device; j++) {
+ for (i=-95; i<=0; i++) {
+ rssi_compensation_table[j][0-i] = rssi_compensation_calc(ar->arDev[j],i);
+ }
+ }
+ }
+
+ /* Do we need to finish the BMI phase */
+
+ if ((wlaninitmode==WLAN_INIT_MODE_USR || wlaninitmode==WLAN_INIT_MODE_DRV) &&
+ (BMIDone(ar->arHifDevice) != A_OK))
+ {
+ ret = -EIO;
+ goto ar6000_init_done;
+ }
+
+ do {
+ HTC_SERVICE_CONNECT_REQ connect;
+
+ /* the reason we have to wait for the target here is that the driver layer
+ * has to init BMI in order to set the host block size,
+ */
+ status = HTCWaitTarget(ar->arHtcTarget);
+
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ A_MEMZERO(&connect,sizeof(connect));
+ /* meta data is unused for now */
+ connect.pMetaData = NULL;
+ connect.MetaDataLength = 0;
+ /* these fields are the same for all service endpoints */
+ connect.EpCallbacks.pContext = ar;
+ connect.EpCallbacks.EpTxCompleteMultiple = ar6000_tx_complete;
+ connect.EpCallbacks.EpRecv = ar6000_rx;
+ connect.EpCallbacks.EpRecvRefill = ar6000_rx_refill;
+ connect.EpCallbacks.EpSendFull = ar6000_tx_queue_full;
+ /* set the max queue depth so that our ar6000_tx_queue_full handler gets called.
+ * Linux has the peculiarity of not providing flow control between the
+ * NIC and the network stack. There is no API to indicate that a TX packet
+ * was sent which could provide some back pressure to the network stack.
+ * Under linux you would have to wait till the network stack consumed all sk_buffs
+ * before any back-flow kicked in. Which isn't very friendly.
+ * So we have to manage this ourselves */
+ connect.MaxSendQueueDepth = MAX_DEFAULT_SEND_QUEUE_DEPTH;
+ connect.EpCallbacks.RecvRefillWaterMark = AR6000_MAX_RX_BUFFERS / 4; /* set to 25 % */
+ if (0 == connect.EpCallbacks.RecvRefillWaterMark) {
+ connect.EpCallbacks.RecvRefillWaterMark++;
+ }
+ /* connect to control service */
+ connect.ServiceID = WMI_CONTROL_SVC;
+ status = ar6000_connectservice(arPriv,
+ &connect,
+ "WMI CONTROL");
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ connect.LocalConnectionFlags |= HTC_LOCAL_CONN_FLAGS_ENABLE_SEND_BUNDLE_PADDING;
+ /* limit the HTC message size on the send path, although we can receive A-MSDU frames of
+ * 4K, we will only send ethernet-sized (802.3) frames on the send path. */
+ connect.MaxSendMsgSize = WMI_MAX_TX_DATA_FRAME_LENGTH;
+
+ /* to reduce the amount of committed memory for larger A_MSDU frames, use the recv-alloc threshold
+ * mechanism for larger packets */
+ connect.EpCallbacks.RecvAllocThreshold = AR6000_BUFFER_SIZE;
+ connect.EpCallbacks.EpRecvAllocThresh = ar6000_alloc_amsdu_rxbuf;
+
+ /* for the remaining data services set the connection flag to reduce dribbling,
+ * if configured to do so */
+ if (reduce_credit_dribble) {
+ connect.ConnectionFlags |= HTC_CONNECT_FLAGS_REDUCE_CREDIT_DRIBBLE;
+ /* the credit dribble trigger threshold is (reduce_credit_dribble - 1) for a value
+ * of 0-3 */
+ connect.ConnectionFlags &= ~HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_MASK;
+ connect.ConnectionFlags |=
+ ((A_UINT16)reduce_credit_dribble - 1) & HTC_CONNECT_FLAGS_THRESHOLD_LEVEL_MASK;
+ }
+ /* connect to best-effort service */
+ connect.ServiceID = WMI_DATA_BE_SVC;
+
+ status = ar6000_connectservice(arPriv,
+ &connect,
+ "WMI DATA BE");
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ /* connect to back-ground
+ * map this to WMI LOW_PRI */
+ connect.ServiceID = WMI_DATA_BK_SVC;
+ status = ar6000_connectservice(arPriv,
+ &connect,
+ "WMI DATA BK");
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ /* connect to Video service, map this to
+ * to HI PRI */
+ connect.ServiceID = WMI_DATA_VI_SVC;
+ status = ar6000_connectservice(arPriv,
+ &connect,
+ "WMI DATA VI");
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ /* connect to VO service, this is currently not
+ * mapped to a WMI priority stream due to historical reasons.
+ * WMI originally defined 3 priorities over 3 mailboxes
+ * We can change this when WMI is reworked so that priorities are not
+ * dependent on mailboxes */
+ connect.ServiceID = WMI_DATA_VO_SVC;
+ status = ar6000_connectservice(arPriv,
+ &connect,
+ "WMI DATA VO");
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ A_ASSERT(arAc2EndpointID(ar,WMM_AC_BE) != 0);
+ A_ASSERT(arAc2EndpointID(ar,WMM_AC_BK) != 0);
+ A_ASSERT(arAc2EndpointID(ar,WMM_AC_VI) != 0);
+ A_ASSERT(arAc2EndpointID(ar,WMM_AC_VO) != 0);
+
+ /* setup access class priority mappings */
+ ar->arAcStreamPriMap[WMM_AC_BK] = 0; /* lowest */
+ ar->arAcStreamPriMap[WMM_AC_BE] = 1; /* */
+ ar->arAcStreamPriMap[WMM_AC_VI] = 2; /* */
+ ar->arAcStreamPriMap[WMM_AC_VO] = 3; /* highest */
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ if (setuphci && (NULL != ar6kHciTransCallbacks.setupTransport)) {
+ HCI_TRANSPORT_MISC_HANDLES hciHandles;
+
+ hciHandles.netDevice = ar->arNetDev;
+ hciHandles.hifDevice = ar->arHifDevice;
+ hciHandles.htcHandle = ar->arHtcTarget;
+ status = (A_STATUS)(ar6kHciTransCallbacks.setupTransport(&hciHandles));
+ }
+#else
+ if (setuphci) {
+ /* setup HCI */
+ status = ar6000_setup_hci(ar);
+ }
+#endif
+
+ } while (FALSE);
+
+ if (A_FAILED(status)) {
+ ret = -EIO;
+ goto ar6000_init_done;
+ }
+
+ /*
+ * give our connected endpoints some buffers
+ */
+
+ ar6000_rx_refill(ar, ar->arControlEp);
+ ar6000_rx_refill(ar, arAc2EndpointID(ar,WMM_AC_BE));
+
+ /*
+ * We will post the receive buffers only for SPE or endpoint ping testing so we are
+ * making it conditional on the 'bypasswmi' flag.
+ */
+ if (bypasswmi) {
+ ar6000_rx_refill(ar,arAc2EndpointID(ar,WMM_AC_BK));
+ ar6000_rx_refill(ar,arAc2EndpointID(ar,WMM_AC_VI));
+ ar6000_rx_refill(ar,arAc2EndpointID(ar,WMM_AC_VO));
+ }
+
+ /* allocate some buffers that handle larger AMSDU frames */
+ ar6000_refill_amsdu_rxbufs(ar,AR6000_MAX_AMSDU_RX_BUFFERS);
+
+ /* setup credit distribution */
+ ar6000_setup_credit_dist(ar->arHtcTarget, &ar->arCreditStateInfo);
+
+ /* Since cookies are used for HTC transports, they should be */
+ /* initialized prior to enabling HTC. */
+ ar6000_cookie_init(ar);
+
+ /* Initialize the control cookie counter to 0 */
+ ar->arControlCookieCount = 0;
+
+ /* start HTC */
+ status = HTCStart(ar->arHtcTarget);
+ if (status != A_OK) {
+ for(i = 0; i < num_device; i++)
+ {
+ if (ar->arDev[i]->arWmiEnabled == TRUE) {
+ wmi_shutdown(ar->arDev[i]->arWmi);
+ ar->arDev[i]->arWmiEnabled = FALSE;
+ ar->arDev[i]->arWmi = NULL;
+ }
+ }
+ ar6000_cookie_cleanup(ar);
+ ret = -EIO;
+ goto ar6000_init_done;
+ }
+
+ if (!bypasswmi) {
+ /* Wait for Wmi event to be ready */
+ timeleft = wait_event_interruptible_timeout(ar->arDev[0]->arEvent,
+ (ar->arWmiReady == TRUE), wmitimeout * HZ);
+
+ if (ar->arVersion.abi_ver != AR6K_ABI_VERSION) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ABI Version mismatch: Host(0x%x), Target(0x%x)\n", AR6K_ABI_VERSION, ar->arVersion.abi_ver));
+#ifndef ATH6KL_SKIP_ABI_VERSION_CHECK
+ ret = -EIO;
+ goto ar6000_init_done;
+#endif /* ATH6KL_SKIP_ABI_VERSION_CHECK */
+ }
+
+ if(!timeleft || signal_pending(current))
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("WMI is not ready or wait was interrupted\n"));
+ ret = -EIO;
+ goto ar6000_init_done;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%s() WMI is ready\n", __func__));
+
+ /* init PAL driver after WMI is ready */
+
+ if(setuphcipal) {
+ A_BOOL bt30ampDevFound = FALSE;
+ for (i=0; i < num_device; i++) {
+ if ( ar->arDev[i]->isBt30amp == TRUE ) {
+ status = ar6k_setup_hci_pal(ar->arDev[i]);
+ bt30ampDevFound = TRUE;
+ }
+
+ }
+ }
+
+ /* Communicate the wmi protocol verision to the target */
+ if ((ar6000_set_host_app_area(ar)) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unable to set the host app area\n"));
+ }
+
+ /* configure the device for rx dot11 header rules 0,0 are the default values
+ * therefore this command can be skipped if the inputs are 0,FALSE,FALSE.Required
+ if checksum offload is needed. Set RxMetaVersion to 2*/
+ if ((wmi_set_rx_frame_format_cmd(arPriv->arWmi,ar->rxMetaVersion, processDot11Hdr, processDot11Hdr)) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unable to set the rx frame format.\n"));
+ }
+
+#if defined(INIT_MODE_DRV_ENABLED) && defined(ENABLE_COEXISTENCE)
+ /* Configure the type of BT collocated with WLAN */
+ A_MEMZERO(&sbcb_cmd, sizeof(WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD));
+#ifdef CONFIG_AR600x_BT_QCOM
+ sbcb_cmd.btcoexCoLocatedBTdev = 1;
+#elif defined(CONFIG_AR600x_BT_CSR)
+ sbcb_cmd.btcoexCoLocatedBTdev = 2;
+#elif defined(CONFIG_AR600x_BT_AR3001)
+ sbcb_cmd.btcoexCoLocatedBTdev = 3;
+#else
+#error Unsupported Bluetooth Type
+#endif /* Collocated Bluetooth Type */
+
+ if ((wmi_set_btcoex_colocated_bt_dev_cmd(arPriv->arWmi, &sbcb_cmd)) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unable to set collocated BT type\n"));
+ }
+
+ /* Configure the type of BT collocated with WLAN */
+ A_MEMZERO(&sbfa_cmd, sizeof(WMI_SET_BTCOEX_FE_ANT_CMD));
+#ifdef CONFIG_AR600x_DUAL_ANTENNA
+ sbfa_cmd.btcoexFeAntType = 2;
+#elif defined(CONFIG_AR600x_SINGLE_ANTENNA)
+ sbfa_cmd.btcoexFeAntType = 1;
+#else
+#error Unsupported Front-End Antenna Configuration
+#endif /* AR600x Front-End Antenna Configuration */
+
+ if ((wmi_set_btcoex_fe_ant_cmd(arPriv->arWmi, &sbfa_cmd)) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unable to set fornt end antenna configuration\n"));
+ }
+#endif /* INIT_MODE_DRV_ENABLED && ENABLE_COEXISTENCE */
+ }
+
+ ar->arNumDataEndPts = 1;
+
+ if (bypasswmi) {
+ /* for tests like endpoint ping, the MAC address needs to be non-zero otherwise
+ * the data path through a raw socket is disabled */
+ dev->dev_addr[0] = 0x00;
+ dev->dev_addr[1] = 0x01;
+ dev->dev_addr[2] = 0x02;
+ dev->dev_addr[3] = 0xAA;
+ dev->dev_addr[4] = 0xBB;
+ dev->dev_addr[5] = 0xCC;
+ }
+
+
+ar6000_init_done:
+ dev_put(dev);
+
+ return ret;
+
+}
+
+
+void
+ar6000_bitrate_rx(void *devt, A_INT32 rateKbps)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+
+ arPriv->arBitRate = rateKbps;
+ wake_up(&arPriv->arEvent);
+}
+
+void
+ar6000_ratemask_rx(void *devt, A_UINT32 *ratemask)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+
+ arPriv->arRateMask[0] = ratemask[0];
+ arPriv->arRateMask[1] = ratemask[1];
+ wake_up(&arPriv->arEvent);
+}
+
+void
+ar6000_txPwr_rx(void *devt, A_UINT8 txPwr)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+
+ arPriv->arTxPwr = txPwr;
+ wake_up(&arPriv->arEvent);
+}
+
+
+void
+ar6000_channelList_rx(void *devt, A_INT8 numChan, A_UINT16 *chanList)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+
+ A_MEMCPY(arPriv->arSta.arChannelList, chanList, numChan * sizeof (A_UINT16));
+ arPriv->arSta.arNumChannels = numChan;
+
+ wake_up(&arPriv->arEvent);
+}
+
+A_UINT8
+ar6000_ibss_map_epid(struct sk_buff *skb, struct net_device *dev, A_UINT32 * mapNo)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UINT8 *datap;
+ ATH_MAC_HDR *macHdr;
+ A_UINT32 i, eptMap;
+
+ (*mapNo) = 0;
+ datap = A_NETBUF_DATA(skb);
+ macHdr = (ATH_MAC_HDR *)(datap + sizeof(WMI_DATA_HDR));
+ if (IEEE80211_IS_MULTICAST(macHdr->dstMac)) {
+ return ENDPOINT_2;
+ }
+
+ eptMap = -1;
+ for (i = 0; i < arSta->arNodeNum; i ++) {
+ if (IEEE80211_ADDR_EQ(macHdr->dstMac, arSta->arNodeMap[i].macAddress)) {
+ (*mapNo) = i + 1;
+ arSta->arNodeMap[i].txPending ++;
+ return arSta->arNodeMap[i].epId;
+ }
+
+ if ((eptMap == -1) && !arSta->arNodeMap[i].txPending) {
+ eptMap = i;
+ }
+ }
+
+ if (eptMap == -1) {
+ eptMap = arSta->arNodeNum;
+ arSta->arNodeNum ++;
+ A_ASSERT(arSta->arNodeNum <= MAX_NODE_NUM);
+ }
+
+ A_MEMCPY(arSta->arNodeMap[eptMap].macAddress, macHdr->dstMac, IEEE80211_ADDR_LEN);
+
+ for (i = ENDPOINT_2; i <= ENDPOINT_5; i ++) {
+ if (!ar->arTxPending[i]) {
+ arSta->arNodeMap[eptMap].epId = i;
+ break;
+ }
+ // No free endpoint is available, start redistribution on the inuse endpoints.
+ if (i == ENDPOINT_5) {
+ arSta->arNodeMap[eptMap].epId = arSta->arNexEpId;
+ arSta->arNexEpId ++;
+ if (arSta->arNexEpId > ENDPOINT_5) {
+ arSta->arNexEpId = ENDPOINT_2;
+ }
+ }
+ }
+
+ (*mapNo) = eptMap + 1;
+ arSta->arNodeMap[eptMap].txPending ++;
+
+ return arSta->arNodeMap[eptMap].epId;
+}
+
+#ifdef DEBUG
+static void ar6000_dump_skb(struct sk_buff *skb)
+{
+ u_char *ch;
+ for (ch = A_NETBUF_DATA(skb);
+ (A_UINT32)ch < ((A_UINT32)A_NETBUF_DATA(skb) +
+ A_NETBUF_LEN(skb)); ch++)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN,("%2.2x ", *ch));
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN,("\n"));
+}
+#endif
+
+#ifdef HTC_TEST_SEND_PKTS
+static void DoHTCSendPktsTest(AR_SOFTC_T *ar, int MapNo, HTC_ENDPOINT_ID eid, struct sk_buff *skb);
+#endif
+
+static int
+ar6000_data_tx(struct sk_buff *skb, struct net_device *dev)
+{
+#define AC_NOT_MAPPED 99
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+ A_UINT8 ac = AC_NOT_MAPPED;
+ HTC_ENDPOINT_ID eid = ENDPOINT_UNUSED;
+ A_UINT32 mapNo = 0;
+ int len;
+ struct ar_cookie *cookie;
+ A_BOOL checkAdHocPsMapping = FALSE;
+ HTC_TX_TAG htc_tag = AR6K_DATA_PKT_TAG;
+ A_UINT8 dot11Hdr = processDot11Hdr;
+ conn_t *conn = NULL;
+ A_UINT32 wmiDataFlags = 0;
+
+#ifdef AR6K_ALLOC_DEBUG
+ A_NETBUF_CHECK(skb);
+#endif
+
+#ifdef CONFIG_PM
+ if ((ar->arWowState != WLAN_WOW_STATE_NONE) || (ar->arWlanState == WLAN_DISABLED)) {
+ A_NETBUF_FREE(skb);
+ return 0;
+ }
+#endif /* CONFIG_PM */
+#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,13)
+ skb->list = NULL;
+#endif
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_TX,("ar6000_data_tx start - skb=0x%x, data=0x%x, len=0x%x\n",
+ (A_UINT32)skb, (A_UINT32)A_NETBUF_DATA(skb),
+ A_NETBUF_LEN(skb)));
+
+ /* If target is not associated */
+ if( (!arPriv->arConnected && !bypasswmi)
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+ /* TCMD doesnt support any data, free the buf and return */
+ || (ar->arTargetMode == AR6000_TCMD_MODE)
+#endif
+ ) {
+ A_NETBUF_FREE(skb);
+ return 0;
+ }
+
+ do {
+
+ if (ar->arWmiReady == FALSE && bypasswmi == 0) {
+ break;
+ }
+
+#ifdef BLOCK_TX_PATH_FLAG
+ if (blocktx) {
+ break;
+ }
+#endif /* BLOCK_TX_PATH_FLAG */
+
+ /* AP mode Power save processing */
+ /* If the dst STA is in sleep state, queue the pkt in its PS queue */
+
+ if (arPriv->arNetworkType == AP_NETWORK) {
+ ATH_MAC_HDR *datap = (ATH_MAC_HDR *)A_NETBUF_DATA(skb);
+ struct sk_buff *skb_to_drop = NULL;
+
+ /* If the dstMac is a Multicast address & atleast one of the
+ * associated STA is in PS mode, then queue the pkt to the
+ * mcastq
+ */
+ if (IEEE80211_IS_MULTICAST(datap->dstMac)) {
+ A_UINT8 ctr=0;
+ A_BOOL qMcast=FALSE;
+
+ for (ctr=0; ctr<NUM_CONN; ctr++) {
+ if(ar->connTbl[ctr].arPriv == arPriv) {
+ if (STA_IS_PWR_SLEEP((&ar->connTbl[ctr]))) {
+ qMcast = TRUE;
+ }
+ }
+ }
+ if(qMcast) {
+ /* If this transmit is not because of a Dtim Expiry q it */
+ if (arAp->DTIMExpired == FALSE) {
+ A_BOOL isMcastqEmpty = FALSE;
+
+ A_MUTEX_LOCK(&arAp->mcastpsqLock);
+
+ /* Check for queue depth, if overflowing then dequeue a
+ * packet so that there is room for new one
+ */
+ if (max_psq_depth != 0 &&
+ A_NETBUF_QUEUE_SIZE(&arAp->mcastpsq) >= max_psq_depth) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("TX Mcast PS queue is full, Depth:%d, Max:%d \n",
+ A_NETBUF_QUEUE_SIZE(&arAp->mcastpsq), max_psq_depth));
+
+ skb_to_drop = A_NETBUF_DEQUEUE(&arAp->mcastpsq);
+ }
+
+ isMcastqEmpty = A_NETBUF_QUEUE_EMPTY(&arAp->mcastpsq);
+ A_NETBUF_ENQUEUE(&arAp->mcastpsq, skb);
+ A_MUTEX_UNLOCK(&arAp->mcastpsqLock);
+
+ /* Free the SKB outside the lock */
+ if (skb_to_drop != NULL) {
+ A_NETBUF_FREE(skb_to_drop);
+ }
+
+ /* If this is the first Mcast pkt getting queued
+ * indicate to the target to set the BitmapControl LSB
+ * of the TIM IE.
+ */
+ if (isMcastqEmpty) {
+ wmi_set_pvb_cmd(arPriv->arWmi, MCAST_AID, 1);
+ }
+ return 0;
+ } else {
+ /* This transmit is because of Dtim expiry. Determine if
+ * MoreData bit has to be set.
+ */
+ A_MUTEX_LOCK(&arAp->mcastpsqLock);
+ if(!A_NETBUF_QUEUE_EMPTY(&arAp->mcastpsq)) {
+ wmiDataFlags |= WMI_DATA_HDR_FLAGS_MORE;
+ }
+ A_MUTEX_UNLOCK(&arAp->mcastpsqLock);
+ }
+ }
+ } else {
+ conn = ieee80211_find_conn(arPriv, datap->dstMac);
+ if (conn) {
+ if (STA_IS_PWR_SLEEP(conn)) {
+ /* If this transmit is not because of a PsPoll q it*/
+ if (!(STA_IS_PS_POLLED(conn) || STA_IS_APSD_TRIGGER(conn))) {
+ A_BOOL trigger = FALSE;
+ A_UINT32 cur_psq_len = 0;
+
+ if (conn->apsd_info) {
+ A_UINT8 up = 0;
+ A_UINT8 trafficClass;
+
+ if (arPriv->arWmmEnabled) {
+ A_UINT16 ipType = IP_ETHERTYPE;
+ A_UINT16 etherType;
+ A_UINT8 *ipHdr;
+
+ etherType = datap->typeOrLen;
+ if (IS_ETHERTYPE(A_BE2CPU16(etherType))) {
+ /* packet is in DIX format */
+ ipHdr = (A_UINT8 *)(datap + 1);
+ } else {
+ /* packet is in 802.3 format */
+ ATH_LLC_SNAP_HDR *llcHdr;
+
+ llcHdr = (ATH_LLC_SNAP_HDR *)(datap + 1);
+ etherType = llcHdr->etherType;
+ ipHdr = (A_UINT8 *)(llcHdr + 1);
+ }
+
+ if (etherType == A_CPU2BE16(ipType)) {
+ up = wmi_determine_userPriority (ipHdr, 0);
+ }
+ }
+ trafficClass = convert_userPriority_to_trafficClass(up);
+ if (conn->apsd_info & (1 << trafficClass)) {
+ trigger = TRUE;
+ }
+ }
+
+
+ if (trigger) {
+ A_BOOL isApsdqEmpty;
+ /* Queue the frames if the STA is sleeping */
+ A_MUTEX_LOCK(&conn->psqLock);
+
+ /* If max_psq_depth is 0 then no limit to queue size */
+ if (max_psq_depth != 0) {
+
+ /* APSD queue depth + PS queue depth should
+ * not be more than MAX PS queue depth
+ */
+ cur_psq_len = A_NETBUF_QUEUE_SIZE(&conn->apsdq) +
+ A_NETBUF_QUEUE_SIZE(&conn->psq);
+
+ /* Check for queue depth, if overflowing then
+ * dequeue a packet so that there is room for
+ * new one
+ */
+ if (cur_psq_len >= max_psq_depth) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("TX STA PS(APSD) queue is full, Depth:%d, Max:%d \n",
+ cur_psq_len, max_psq_depth));
+
+ skb_to_drop = A_NETBUF_DEQUEUE(&conn->apsdq);
+ }
+ }
+
+ isApsdqEmpty = A_NETBUF_QUEUE_EMPTY(&conn->apsdq);
+ A_NETBUF_ENQUEUE(&conn->apsdq, skb);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+
+ /* Free the SKB outside the lock */
+ if (skb_to_drop != NULL) {
+ A_NETBUF_FREE(skb_to_drop);
+ }
+
+ /* If this is the first pkt getting queued
+ * for this STA, update the PVB for this STA
+ */
+ if (isApsdqEmpty) {
+ wmi_set_apsd_buffered_traffic_cmd(arPriv->arWmi, conn->aid, 1, 0);
+ }
+ } else {
+ A_BOOL isPsqEmpty = FALSE;
+ /* Queue the frames if the STA is sleeping */
+ A_MUTEX_LOCK(&conn->psqLock);
+
+ /* If max_psq_depth is 0 then no limit to queue size */
+ if (max_psq_depth != 0) {
+
+ /* APSD queue depth + PS queue depth should
+ * not be more than MAX PS queue depth
+ */
+ cur_psq_len = A_NETBUF_QUEUE_SIZE(&conn->apsdq) +
+ A_NETBUF_QUEUE_SIZE(&conn->psq);
+
+ /* Check for queue depth, if overflowing then
+ * dequeue a packet so that there is room for
+ * new one
+ */
+ if (cur_psq_len >= max_psq_depth) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("TX STA PS queue is full, Depth:%d, Max:%d \n",
+ cur_psq_len, max_psq_depth));
+
+ skb_to_drop = A_NETBUF_DEQUEUE(&conn->psq);
+ }
+ }
+
+ /* Free the SKB outside the lock */
+ if (skb_to_drop != NULL) {
+ A_NETBUF_FREE(skb_to_drop);
+ }
+ isPsqEmpty = A_NETBUF_QUEUE_EMPTY(&conn->psq);
+ A_NETBUF_ENQUEUE(&conn->psq, skb);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+
+ /* If this is the first pkt getting queued
+ * for this STA, update the PVB for this STA
+ */
+ if (isPsqEmpty) {
+ wmi_set_pvb_cmd(arPriv->arWmi, conn->aid, 1);
+ }
+ }
+
+ return 0;
+ } else {
+ /*
+ * This tx is because of a PsPoll or trigger. Determine if
+ * MoreData bit has to be set
+ */
+ A_MUTEX_LOCK(&conn->psqLock);
+ if (STA_IS_PS_POLLED(conn)) {
+ if (!A_NETBUF_QUEUE_EMPTY(&conn->psq)) {
+ wmiDataFlags |= WMI_DATA_HDR_FLAGS_MORE;
+ }
+ } else {
+ /*
+ * This tx is because of a uAPSD trigger, determine
+ * more and EOSP bit. Set EOSP is queue is empty
+ * or sufficient frames is delivered for this trigger
+ */
+ if (!A_NETBUF_QUEUE_EMPTY(&conn->apsdq)) {
+ wmiDataFlags |= WMI_DATA_HDR_FLAGS_MORE;
+ }
+ if (STA_IS_APSD_EOSP(conn)) {
+ wmiDataFlags |= WMI_DATA_HDR_FLAGS_EOSP;
+ }
+ }
+ A_MUTEX_UNLOCK(&conn->psqLock);
+ }
+ }
+ } else {
+
+ /* non existent STA. drop the frame */
+ A_NETBUF_FREE(skb);
+ return 0;
+ }
+ }
+ }
+
+ if (arPriv->arWmiEnabled) {
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+ A_UINT8 csumStart=0;
+ A_UINT8 csumDest=0;
+ A_UINT8 csum=skb->ip_summed;
+ if(csumOffload && (csum==CHECKSUM_PARTIAL)){
+ csumStart=skb->csum_start-(skb->network_header-skb->head)+sizeof(ATH_LLC_SNAP_HDR);
+ csumDest=skb->csum_offset+csumStart;
+ }
+#endif
+ if (A_NETBUF_HEADROOM(skb) < dev->hard_header_len - LINUX_HACK_FUDGE_FACTOR) {
+ struct sk_buff *newbuf;
+
+ /*
+ * We really should have gotten enough headroom but sometimes
+ * we still get packets with not enough headroom. Copy the packet.
+ */
+ len = A_NETBUF_LEN(skb);
+ newbuf = A_NETBUF_ALLOC(len);
+ if (newbuf == NULL) {
+ break;
+ }
+ A_NETBUF_PUT(newbuf, len);
+ A_MEMCPY(A_NETBUF_DATA(newbuf), A_NETBUF_DATA(skb), len);
+ A_NETBUF_FREE(skb);
+ skb = newbuf;
+ /* fall through and assemble header */
+ }
+
+ if (dot11Hdr) {
+ if (wmi_dot11_hdr_add(arPriv->arWmi,skb,arPriv->arNetworkType) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_data_tx-wmi_dot11_hdr_add failed\n"));
+ break;
+ }
+ } else {
+ if (wmi_dix_2_dot3(arPriv->arWmi, skb) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_data_tx - wmi_dix_2_dot3 failed\n"));
+ break;
+ }
+ }
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+ if(csumOffload && (csum ==CHECKSUM_PARTIAL)){
+ WMI_TX_META_V2 metaV2;
+ metaV2.csumStart =csumStart;
+ metaV2.csumDest = csumDest;
+ metaV2.csumFlags = 0x1;/*instruct target to calculate checksum*/
+ if (wmi_data_hdr_add(arPriv->arWmi, skb, DATA_MSGTYPE, wmiDataFlags, dot11Hdr,
+ WMI_META_VERSION_2,&metaV2) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_data_tx - wmi_data_hdr_add failed\n"));
+ break;
+ }
+
+ }
+ else
+#endif
+ {
+ if (wmi_data_hdr_add(arPriv->arWmi, skb, DATA_MSGTYPE, wmiDataFlags, dot11Hdr,0,NULL) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000_data_tx - wmi_data_hdr_add failed\n"));
+ break;
+ }
+ }
+
+
+ if ((arPriv->arNetworkType == ADHOC_NETWORK) &&
+ arSta->arIbssPsEnable && arPriv->arConnected) {
+ /* flag to check adhoc mapping once we take the lock below: */
+ checkAdHocPsMapping = TRUE;
+
+ } else {
+ A_UINT32 layer2Priority = 0;
+ /* 256->263 are magic values in Linux for passing directly
+ * 802.1d priority from VLAN tags, etc
+ */
+ if (skb->priority >= 256 && skb->priority <= 263) {
+ layer2Priority = skb->priority - 256;
+ }
+ /* get the stream mapping */
+ ac = wmi_implicit_create_pstream(arPriv->arWmi, skb, layer2Priority, arPriv->arWmmEnabled);
+ }
+
+ } else {
+ EPPING_HEADER *eppingHdr;
+
+ eppingHdr = A_NETBUF_DATA(skb);
+
+ if (IS_EPPING_PACKET(eppingHdr)) {
+ /* the stream ID is mapped to an access class */
+ ac = eppingHdr->StreamNo_h;
+ /* some EPPING packets cannot be dropped no matter what access class it was
+ * sent on. We can change the packet tag to guarantee it will not get dropped */
+ if (IS_EPING_PACKET_NO_DROP(eppingHdr)) {
+ htc_tag = AR6K_CONTROL_PKT_TAG;
+ }
+
+ if (ac == HCI_TRANSPORT_STREAM_NUM) {
+ /* pass this to HCI */
+#ifndef EXPORT_HCI_BRIDGE_INTERFACE
+ if (A_SUCCESS(hci_test_send(ar,skb))) {
+ return 0;
+ }
+#endif
+ /* set AC to discard this skb */
+ ac = AC_NOT_MAPPED;
+ } else {
+ /* a quirk of linux, the payload of the frame is 32-bit aligned and thus the addition
+ * of the HTC header will mis-align the start of the HTC frame, so we add some
+ * padding which will be stripped off in the target */
+ if (EPPING_ALIGNMENT_PAD > 0) {
+ A_NETBUF_PUSH(skb, EPPING_ALIGNMENT_PAD);
+ }
+ }
+
+ } else {
+ /* not a ping packet, drop it */
+ ac = AC_NOT_MAPPED;
+ }
+ }
+
+ } while (FALSE);
+
+ /* did we succeed ? */
+ if ((ac == AC_NOT_MAPPED) && !checkAdHocPsMapping) {
+ /* cleanup and exit */
+ A_NETBUF_FREE(skb);
+ AR6000_STAT_INC(arPriv, tx_dropped);
+ AR6000_STAT_INC(arPriv, tx_aborted_errors);
+ return 0;
+ }
+
+ cookie = NULL;
+
+ /* take the lock to protect driver data */
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ do {
+
+ if (checkAdHocPsMapping) {
+ eid = ar6000_ibss_map_epid(skb, dev, &mapNo);
+ }else {
+ eid = arAc2EndpointID (ar, ac);
+ }
+ /* validate that the endpoint is connected */
+ if (eid == 0 || eid == ENDPOINT_UNUSED ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,(" eid %d is NOT mapped!\n", eid));
+ break;
+ }
+ /* allocate resource for this packet */
+ cookie = ar6000_alloc_cookie(ar);
+
+ if (cookie != NULL) {
+ /* update counts while the lock is held */
+ ar->arTxPending[eid]++;
+ ar->arTotalTxDataPending++;
+ if (htc_tag == AR6K_CONTROL_PKT_TAG) {
+ /* This cookie allocated for a control packet, update count */
+ ar->arControlCookieCount++;
+ }
+ }
+
+ } while (FALSE);
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ if (cookie != NULL) {
+ cookie->arc_bp[0] = (A_UINT32)skb;
+ cookie->arc_bp[1] = mapNo;
+ SET_HTC_PACKET_INFO_TX(&cookie->HtcPkt,
+ cookie,
+ A_NETBUF_DATA(skb),
+ A_NETBUF_LEN(skb),
+ eid,
+ htc_tag);
+
+#ifdef DEBUG
+ if (debugdriver >= 3) {
+ ar6000_dump_skb(skb);
+ }
+#endif
+#ifdef HTC_TEST_SEND_PKTS
+ DoHTCSendPktsTest(ar,mapNo,eid,skb);
+#endif
+ /* HTC interface is asynchronous, if this fails, cleanup will happen in
+ * the ar6000_tx_complete callback */
+ HTCSendPkt(ar->arHtcTarget, &cookie->HtcPkt);
+ } else {
+ /* no packet to send, cleanup */
+ A_NETBUF_FREE(skb);
+ AR6000_STAT_INC(arPriv, tx_dropped);
+ AR6000_STAT_INC(arPriv, tx_aborted_errors);
+ }
+
+ return 0;
+}
+
+int
+ar6000_acl_data_tx(struct sk_buff *skb, AR_SOFTC_DEV_T *arPriv)
+{
+ struct ar_cookie *cookie;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ HTC_ENDPOINT_ID eid = ENDPOINT_UNUSED;
+
+ cookie = NULL;
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ /* For now we send ACL on BE endpoint: We can also have a dedicated EP */
+ eid = arAc2EndpointID (ar, 0);
+ /* allocate resource for this packet */
+ cookie = ar6000_alloc_cookie(ar);
+
+ if (cookie != NULL) {
+ /* update counts while the lock is held */
+ ar->arTxPending[eid]++;
+ ar->arTotalTxDataPending++;
+ }
+
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ if (cookie != NULL) {
+ cookie->arc_bp[0] = (A_UINT32)skb;
+ cookie->arc_bp[1] = 0;
+ SET_HTC_PACKET_INFO_TX(&cookie->HtcPkt,
+ cookie,
+ A_NETBUF_DATA(skb),
+ A_NETBUF_LEN(skb),
+ eid,
+ AR6K_DATA_PKT_TAG);
+
+ /* HTC interface is asynchronous, if this fails, cleanup will happen in
+ * the ar6000_tx_complete callback */
+ HTCSendPkt(ar->arHtcTarget, &cookie->HtcPkt);
+ } else {
+ /* no packet to send, cleanup */
+ A_NETBUF_FREE(skb);
+ AR6000_STAT_INC(arPriv, tx_dropped);
+ AR6000_STAT_INC(arPriv, tx_aborted_errors);
+ }
+ return 0;
+}
+
+
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+static void
+tvsub(register struct timeval *out, register struct timeval *in)
+{
+ if((out->tv_usec -= in->tv_usec) < 0) {
+ out->tv_sec--;
+ out->tv_usec += 1000000;
+ }
+ out->tv_sec -= in->tv_sec;
+}
+
+void
+applyAPTCHeuristics(AR_SOFTC_DEV_T *arPriv)
+{
+ A_UINT32 duration;
+ A_UINT32 numbytes;
+ A_UINT32 throughput;
+ struct timeval ts;
+ A_STATUS status;
+ APTC_TRAFFIC_RECORD *aptcTR;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ aptcTR = arPriv->aptcTR;
+
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+
+ if ((enableAPTCHeuristics) && (!aptcTR->timerScheduled)) {
+ do_gettimeofday(&ts);
+ tvsub(&ts, &aptcTR->samplingTS);
+ duration = ts.tv_sec * 1000 + ts.tv_usec / 1000; /* ms */
+ numbytes = aptcTR->bytesTransmitted + aptcTR->bytesReceived;
+
+ if (duration > APTC_TRAFFIC_SAMPLING_INTERVAL) {
+ /* Initialize the time stamp and byte count */
+ aptcTR->bytesTransmitted = aptcTR->bytesReceived = 0;
+ do_gettimeofday(&aptcTR->samplingTS);
+
+ /* Calculate and decide based on throughput thresholds */
+ throughput = ((numbytes * 8) / duration);
+ if (throughput > APTC_UPPER_THROUGHPUT_THRESHOLD) {
+ /* Disable Sleep and schedule a timer */
+ A_ASSERT(ar->arWmiReady == TRUE);
+ AR6000_SPIN_UNLOCK(&arPriv->ariPrivLock, 0);
+ status = wmi_powermode_cmd(arPriv->arWmi, MAX_PERF_POWER);
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ A_TIMEOUT_MS(&aptcTimer[arPriv->arDeviceIndex], APTC_TRAFFIC_SAMPLING_INTERVAL, 0);
+ aptcTR->timerScheduled = TRUE;
+ }
+ }
+ }
+
+ AR6000_SPIN_UNLOCK(&arPriv->arLock, 0);
+}
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+
+static HTC_SEND_FULL_ACTION ar6000_tx_queue_full(void *Context, HTC_PACKET *pPacket)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)Context;
+ HTC_SEND_FULL_ACTION action = HTC_SEND_FULL_KEEP;
+ A_BOOL stopNet = FALSE;
+ HTC_ENDPOINT_ID Endpoint = HTC_GET_ENDPOINT_FROM_PKT(pPacket);
+ A_UINT8 i;
+ AR_SOFTC_DEV_T *arPriv;
+ A_UINT32 controlCookieThreshold, highPriorityCookieThreshold;
+
+ do {
+
+ if (bypasswmi) {
+ int accessClass;
+
+ if (HTC_GET_TAG_FROM_PKT(pPacket) == AR6K_CONTROL_PKT_TAG) {
+ /* don't drop special control packets */
+ break;
+ }
+
+ accessClass = arEndpoint2Ac(ar,Endpoint);
+ /* for endpoint ping testing drop Best Effort and Background */
+ if ((accessClass == WMM_AC_BE) || (accessClass == WMM_AC_BK)) {
+ action = HTC_SEND_FULL_DROP;
+ stopNet = FALSE;
+ } else {
+ /* keep but stop the netqueues */
+ stopNet = TRUE;
+ }
+ break;
+ }
+
+ if (Endpoint == ar->arControlEp) {
+ /* under normal WMI if this is getting full, then something is running rampant
+ * the host should not be exhausting the WMI queue with too many commands
+ * the only exception to this is during testing using endpointping */
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ /* set flag to handle subsequent messages */
+ ar->arWMIControlEpFull = TRUE;
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("WMI Control Endpoint is FULL!!! \n"));
+ /* no need to stop the network */
+ stopNet = FALSE;
+ break;
+ }
+
+ /* if we get here, we are dealing with data endpoints getting full */
+
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ controlCookieThreshold = MAX_CONTROL_COOKIE_NUM - ar->arControlCookieCount;
+ highPriorityCookieThreshold = controlCookieThreshold + MAX_HIGH_PRIORITY_COOKIE_NUM;
+
+ if (ar->arCookieCount <= controlCookieThreshold) {
+ /* the last few cookies are reserved exclusively for sending
+ * control messages on the 4 data endpoints and the control endpoint. Each of
+ * the 4 data endpoints could need up to 2 sync messages (if we are using
+ * SYNC_BOTH_WMIFLAG) so we need to reserve 11 cookies (2*WMM_NUM_AC=2*4=8)
+ * for the data endpoints and 3 for the control endpoint (one WMI_ADD_CIPHER_CMDID
+ * command and two WMI_SYNCHRONIZE_CMDID commands). This is why we MUST reserve
+ * some cookies for control messages; SYNC messages are important and dropping
+ * these would effectively make the WiFi connection useless because the AP would be
+ * using a different encryption key. So, we reserve 11 cookies for sending SYNC
+ * messages, plus one additional (just in case someone happens to issue a wmi command
+ * during the rekey process)
+ */
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ if (HTC_GET_TAG_FROM_PKT(pPacket) == AR6K_CONTROL_PKT_TAG) {
+ /* don't drop control packets issued on ANY data endpoint */
+ break;
+ } else {
+ /* If cookie count is below controlCookieThreshold and this is NOT a control
+ * message, stop it from being sent.
+ */
+ action = HTC_SEND_FULL_DROP;
+ stopNet = FALSE;
+ break;
+ }
+ }
+
+ /* the last highPriorityCookieThreshold "batch" of cookies (except for the last
+ * controlCookieThreshold cookies which are captured by the statement above)
+ * are reserved for the highest priority active stream */
+ if (ar->arAcStreamPriMap[arEndpoint2Ac(ar,Endpoint)] < ar->arHiAcStreamActivePri &&
+ ar->arCookieCount <= highPriorityCookieThreshold) {
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ /* this stream's priority is less than the highest active priority, we
+ * give preference to the highest priority stream by directing
+ * HTC to drop the packet that overflowed */
+ action = HTC_SEND_FULL_DROP;
+ /* since we are dropping packets, no need to stop the network */
+ stopNet = FALSE;
+ break;
+ }
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ } while (FALSE);
+
+ if (stopNet) {
+ for(i = 0; i < num_device; i++)
+ {
+ arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ arPriv->arNetQueueStopped = TRUE;
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ /* one of the data endpoints queues is getting full..need to stop network stack
+ * the queue will resume in ar6000_tx_complete() */
+ netif_stop_queue(ar6000_devices[i]);
+ }
+ }
+ else
+ {
+ /* in adhoc mode, we cannot differentiate traffic priorities so there is no need to
+ * continue, however we should stop the network */
+ for(i = 0; i < num_device; i++)
+ {
+ arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ if(arPriv->arNetworkType == ADHOC_NETWORK) {
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ arPriv->arNetQueueStopped = TRUE;
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ /* one of the data endpoints queues is getting full..need to stop network stack
+ * the queue will resume in ar6000_tx_complete() */
+ netif_stop_queue(ar6000_devices[i]);
+ }
+ }
+ }
+ return action;
+}
+
+
+static void
+ar6000_tx_complete(void *Context, HTC_PACKET_QUEUE *pPacketQueue)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)Context;
+ A_UINT32 mapNo = 0;
+ A_STATUS status;
+ struct ar_cookie * ar_cookie;
+ HTC_ENDPOINT_ID eid;
+ A_BOOL wakeEvent = FALSE;
+ struct sk_buff_head skb_queue;
+ HTC_PACKET *pPacket;
+ struct sk_buff *pktSkb;
+ A_BOOL flushing[NUM_DEV];
+ A_INT8 devid = -1;
+ AR_SOFTC_DEV_T *arPriv = NULL;
+ AR_SOFTC_STA_T *arSta;
+ A_UINT8 i;
+
+ skb_queue_head_init(&skb_queue);
+
+ /* lock the driver as we update internal state */
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ /* reap completed packets */
+ while (!HTC_QUEUE_EMPTY(pPacketQueue)) {
+
+ pPacket = HTC_PACKET_DEQUEUE(pPacketQueue);
+
+ ar_cookie = (struct ar_cookie *)pPacket->pPktContext;
+ A_ASSERT(ar_cookie);
+
+ status = pPacket->Status;
+ pktSkb = (struct sk_buff *)ar_cookie->arc_bp[0];
+ eid = pPacket->Endpoint;
+ mapNo = ar_cookie->arc_bp[1];
+
+ if(pktSkb == NULL || pPacket->pBuffer != A_NETBUF_DATA(pktSkb))
+ {
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ return;
+ }
+
+ A_ASSERT(pktSkb);
+ A_ASSERT(pPacket->pBuffer == A_NETBUF_DATA(pktSkb));
+
+ /* add this to the list, use faster non-lock API */
+ __skb_queue_tail(&skb_queue,pktSkb);
+
+ if (A_SUCCESS(status)) {
+ A_ASSERT(pPacket->ActualLength == A_NETBUF_LEN(pktSkb));
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_TX,("ar6000_tx_complete skb=0x%x data=0x%x len=0x%x eid=%d ",
+ (A_UINT32)pktSkb, (A_UINT32)pPacket->pBuffer,
+ pPacket->ActualLength,
+ eid));
+
+ ar->arTxPending[eid]--;
+
+ if(!bypasswmi)
+ {
+
+ if (eid != ar->arControlEp) {
+ WMI_DATA_HDR *dhdr = (WMI_DATA_HDR *)A_NETBUF_DATA(pktSkb);
+ ar->arTotalTxDataPending--;
+ devid = WMI_DATA_HDR_GET_DEVID(dhdr);
+ arPriv = ar->arDev[devid];
+ }
+
+ if (eid == ar->arControlEp)
+ {
+ WMI_CMD_HDR *cmhdr = (WMI_CMD_HDR*)A_NETBUF_DATA(pktSkb);
+ if (ar->arWMIControlEpFull) {
+ /* since this packet completed, the WMI EP is no longer full */
+ ar->arWMIControlEpFull = FALSE;
+#ifdef ANDROID_ENV
+ android_epfull_cnt = 0;
+#endif
+ }
+
+ if (ar->arTxPending[eid] == 0) {
+ wakeEvent = TRUE;
+ }
+ devid = WMI_CMD_HDR_GET_DEVID(cmhdr);
+ arPriv = ar->arDev[devid];
+ }
+ }
+ else
+ {
+ devid = 0;
+ arPriv = ar->arDev[devid];
+ }
+
+
+ if (A_FAILED(status)) {
+ if (status == A_ECANCELED || status == A_ECOMM ) {
+ /* a packet was flushed */
+ flushing[devid] = TRUE;
+ }
+ AR6000_STAT_INC(arPriv, tx_errors);
+ if (status != A_NO_RESOURCE && status != A_ECOMM ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s() -TX ERROR, status: 0x%x\n", __func__,
+ status));
+ }
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_TX,("OK\n"));
+ flushing[devid] = FALSE;
+ AR6000_STAT_INC(arPriv, tx_packets);
+ arPriv->arNetStats.tx_bytes += A_NETBUF_LEN(pktSkb);
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+ arPriv->aptcTR.bytesTransmitted += a_netbuf_to_len(pktSkb);
+ applyAPTCHeuristics(arPriv);
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+ }
+
+ // TODO this needs to be looked at
+ if (arPriv->arNetworkType == ADHOC_NETWORK)
+ {
+ arSta = &arPriv->arSta;
+ if((arSta->arIbssPsEnable && (eid != ar->arControlEp) && mapNo))
+ {
+ mapNo --;
+ arSta->arNodeMap[mapNo].txPending --;
+
+ if (!arSta->arNodeMap[mapNo].txPending && (mapNo == (arSta->arNodeNum - 1))) {
+ A_UINT32 i;
+ for (i = arSta->arNodeNum; i > 0; i --) {
+ if (!arSta->arNodeMap[i - 1].txPending) {
+ A_MEMZERO(&arSta->arNodeMap[i - 1], sizeof(struct ar_node_mapping));
+ arSta->arNodeNum --;
+ } else {
+ break;
+ }
+ }
+ }
+ }
+ }
+
+ ar6000_free_cookie(ar, ar_cookie);
+ if (HTC_GET_TAG_FROM_PKT(pPacket) == AR6K_CONTROL_PKT_TAG) {
+ /* If we just freed a control packet, update the count */
+ ar->arControlCookieCount--;
+ }
+
+ if (arPriv->arNetQueueStopped) {
+ arPriv->arNetQueueStopped = FALSE;
+ }
+ }
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ /* lock is released, we can freely call other kernel APIs */
+
+ /* free all skbs in our local list */
+ while (!skb_queue_empty(&skb_queue)) {
+ /* use non-lock version */
+ pktSkb = __skb_dequeue(&skb_queue);
+ A_NETBUF_FREE(pktSkb);
+ }
+ for(i = 0; i < num_device; i++) {
+ arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ if (((arPriv->arNetworkType == INFRA_NETWORK ) && (arPriv->arConnected == TRUE))
+ || (bypasswmi)) {
+ if (!flushing[i]) {
+ /* don't wake the queue if we are flushing, other wise it will just
+ * keep queueing packets, which will keep failing */
+
+ netif_wake_queue(arPriv->arNetDev);
+ }
+ }
+
+ if (wakeEvent) {
+ wake_up(&arPriv->arEvent);
+ }
+ }
+
+}
+
+conn_t *
+ieee80211_find_conn(AR_SOFTC_DEV_T *arPriv, A_UINT8 *node_addr)
+{
+ conn_t *conn = NULL;
+ A_UINT8 i;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (IS_MAC_NULL(node_addr)) {
+ return NULL;
+ }
+
+ for (i = 0; i < NUM_CONN; i++) {
+ if (IEEE80211_ADDR_EQ(node_addr, ar->connTbl[i].mac)) {
+ conn = &ar->connTbl[i];
+ break;
+ }
+ }
+
+ return conn;
+}
+
+conn_t *ieee80211_find_conn_for_aid(AR_SOFTC_DEV_T *arPriv, A_UINT8 aid)
+{
+ conn_t *conn = NULL;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (arPriv->arNetworkType != AP_NETWORK) {
+ conn = NULL;
+ } else if( (aid > 0) && (aid < NUM_CONN) ) {
+ if (ar->connTbl[aid-1].aid == aid) {
+ conn = &ar->connTbl[aid-1];
+ }
+ }
+ return conn;
+}
+
+void *get_aggr_ctx(AR_SOFTC_DEV_T *arPriv, conn_t *conn)
+{
+ if (arPriv->arNetworkType != AP_NETWORK) {
+ return (arPriv->conn_aggr);
+ } else {
+ return (conn->conn_aggr);
+ }
+}
+
+/*
+ * Receive event handler. This is called by HTC when a packet is received
+ */
+int pktcount;
+static void
+ar6000_rx(void *Context, HTC_PACKET *pPacket)
+{
+ AR_SOFTC_T *ar = NULL;
+ struct sk_buff *skb = NULL;
+ int minHdrLen;
+ A_UINT8 containsDot11Hdr = 0;
+ A_STATUS status;
+ HTC_ENDPOINT_ID ept;
+ conn_t *conn = NULL;
+ AR_SOFTC_DEV_T *arPriv = NULL;
+ A_UINT8 devid ;
+ ATH_MAC_HDR *multicastcheck_datap = NULL;
+
+ if(Context == NULL || pPacket == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ANY, ("AR6K: Context is null or pPacket is null\n"));
+ goto rx_done;
+ }
+ ar = (AR_SOFTC_T *)Context;
+ skb = (struct sk_buff *)pPacket->pPktContext;
+ status = pPacket->Status;
+ ept = pPacket->Endpoint;
+
+ A_ASSERT((status != A_OK) ||
+ (pPacket->pBuffer == (A_NETBUF_DATA(skb) + HTC_HEADER_LEN)));
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_RX,("ar6000_rx ar=0x%x eid=%d, skb=0x%x, data=0x%x, len=0x%x status:%d",
+ (A_UINT32)ar, ept, (A_UINT32)skb, (A_UINT32)pPacket->pBuffer,
+ pPacket->ActualLength, status));
+
+ if (status != A_OK) {
+ if (status != A_ECANCELED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("RX ERR (%d) \n",status));
+ }
+ A_NETBUF_FREE(skb);
+ goto rx_done;
+ }
+
+ /* take lock to protect buffer counts
+ * and adaptive power throughput state */
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ A_NETBUF_PUT(skb, pPacket->ActualLength + HTC_HEADER_LEN);
+ A_NETBUF_PULL(skb, HTC_HEADER_LEN);
+
+ if(!bypasswmi)
+ {
+ if(ept == ar->arControlEp) {
+ WMI_CMD_HDR *cmhdr = (WMI_CMD_HDR*)A_NETBUF_DATA(skb);
+ devid = WMI_CMD_HDR_GET_DEVID(cmhdr);
+ arPriv = ar->arDev[devid];
+ }
+ else {
+ WMI_DATA_HDR *dhdr = (WMI_DATA_HDR *)A_NETBUF_DATA(skb);
+ devid = WMI_DATA_HDR_GET_DEVID(dhdr);
+ arPriv = ar->arDev[devid];
+ }
+ }
+ else
+ {
+ devid = 0;
+ arPriv = ar->arDev[devid];
+ }
+
+ if (A_SUCCESS(status)) {
+ AR6000_STAT_INC(arPriv, rx_packets);
+ arPriv->arNetStats.rx_bytes += pPacket->ActualLength;
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+ arPriv->aptcTR.bytesReceived += pPacket->ActualLength;
+ applyAPTCHeuristics(arPriv);
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+
+
+#ifdef DEBUG
+ if (debugdriver >= 2) {
+ ar6000_dump_skb(skb);
+ }
+#endif /* DEBUG */
+ }
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ skb->dev = arPriv->arNetDev;
+ if (status != A_OK) {
+ AR6000_STAT_INC(arPriv, rx_errors);
+ A_NETBUF_FREE(skb);
+ } else if (arPriv->arWmiEnabled == TRUE) {
+ if (ept == ar->arControlEp) {
+ /*
+ * this is a wmi control msg
+ */
+#ifdef CONFIG_PM
+ ar6000_check_wow_status(ar, skb, TRUE);
+#endif /* CONFIG_PM */
+ wmi_control_rx(arPriv->arWmi, skb);
+ } else {
+ WMI_DATA_HDR *dhdr = (WMI_DATA_HDR *)A_NETBUF_DATA(skb);
+ A_UINT8 is_amsdu, tid, is_acl_data_frame;
+ is_acl_data_frame = WMI_DATA_HDR_GET_DATA_TYPE(dhdr) == WMI_DATA_HDR_DATA_TYPE_ACL;
+#ifdef CONFIG_PM
+ ar6000_check_wow_status(ar, NULL, FALSE);
+#endif /* CONFIG_PM */
+ /*
+ * this is a wmi data packet
+ */
+ // NWF
+
+ if (processDot11Hdr) {
+ minHdrLen = sizeof(WMI_DATA_HDR) + sizeof(struct ieee80211_frame) + sizeof(ATH_LLC_SNAP_HDR);
+ } else {
+ minHdrLen = sizeof (WMI_DATA_HDR) + sizeof(ATH_MAC_HDR) +
+ sizeof(ATH_LLC_SNAP_HDR);
+ }
+
+ /* In the case of AP mode we may receive NULL data frames
+ * that do not have LLC hdr. They are 16 bytes in size.
+ * Allow these frames in the AP mode.
+ * ACL data frames don't follow ethernet frame bounds for
+ * min length
+ */
+ if (arPriv->arNetworkType != AP_NETWORK && !is_acl_data_frame &&
+ ((pPacket->ActualLength < minHdrLen) ||
+ (pPacket->ActualLength > AR6000_MAX_RX_MESSAGE_SIZE)))
+ {
+ /*
+ * packet is too short or too long
+ */
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("TOO SHORT or TOO LONG\n"));
+ AR6000_STAT_INC(arPriv, rx_errors);
+ AR6000_STAT_INC(arPriv, rx_length_errors);
+ A_NETBUF_FREE(skb);
+ } else {
+ A_UINT16 seq_no;
+ A_UINT8 meta_type;
+
+#if 0
+ /* Access RSSI values here */
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("RSSI %d\n",
+ ((WMI_DATA_HDR *) A_NETBUF_DATA(skb))->rssi));
+#endif
+ /* Get the Power save state of the STA */
+ if (arPriv->arNetworkType == AP_NETWORK) {
+ A_UINT8 psState=0,prevPsState;
+ ATH_MAC_HDR *datap=NULL;
+ A_UINT16 offset;
+ A_UINT8 triggerState;
+
+ meta_type = WMI_DATA_HDR_GET_META(dhdr);
+
+ psState = (((WMI_DATA_HDR *)A_NETBUF_DATA(skb))->info
+ >> WMI_DATA_HDR_PS_SHIFT) & WMI_DATA_HDR_PS_MASK;
+ triggerState = WMI_DATA_HDR_IS_TRIGGER(dhdr);
+
+
+ offset = sizeof(WMI_DATA_HDR);
+
+ switch (meta_type) {
+ case 0:
+ break;
+ case WMI_META_VERSION_1:
+ offset += sizeof(WMI_RX_META_V1);
+ break;
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+ case WMI_META_VERSION_2:
+ offset += sizeof(WMI_RX_META_V2);
+ break;
+#endif
+ default:
+ break;
+ }
+#ifdef DIX_RX_OFFLOAD
+#define SKIP_LLC_LEN 8
+ /*DIX to ETHERNET hdr conversion is offloaded to firmware */
+ /*Empty LLC header is moved to get ethernet header*/
+ A_UINT32 datalen = (A_UINT32)A_NETBUF_LEN(skb)-offset;
+
+ is_amsdu = WMI_DATA_HDR_IS_AMSDU(dhdr);
+ containsDot11Hdr = WMI_DATA_HDR_GET_DOT11(dhdr);
+ if(!containsDot11Hdr && !is_amsdu && !is_acl_data_frame
+ && datalen >= (sizeof(ATH_MAC_HDR) + sizeof(ATH_LLC_SNAP_HDR))) {
+ datap = (ATH_MAC_HDR *)((A_INT8*)A_NETBUF_DATA(skb)+offset+SKIP_LLC_LEN);
+ }
+ else {
+ datap = (ATH_MAC_HDR *)((A_INT8*)A_NETBUF_DATA(skb)+offset);
+ }
+
+#else
+ datap = (ATH_MAC_HDR *)(A_NETBUF_DATA(skb)+offset);
+#endif
+ conn = ieee80211_find_conn(arPriv, datap->srcMac);
+
+ if (conn) {
+ /* if there is a change in PS state of the STA,
+ * take appropriate steps.
+ * 1. If Sleep-->Awake, flush the psq for the STA
+ * Clear the PVB for the STA.
+ * 2. If Awake-->Sleep, Starting queueing frames
+ * the STA.
+ */
+ prevPsState = STA_IS_PWR_SLEEP(conn);
+ if (psState) {
+ STA_SET_PWR_SLEEP(conn);
+ } else {
+ STA_CLR_PWR_SLEEP(conn);
+ }
+
+ if (STA_IS_PWR_SLEEP(conn)) {
+ /* Accept trigger only when the station is in sleep */
+ if (triggerState) {
+ ar6000_uapsd_trigger_frame_rx(arPriv, conn);
+ }
+ }
+
+ if (prevPsState ^ STA_IS_PWR_SLEEP(conn)) {
+ A_BOOL isApsdqEmptyAtStart;
+
+ if (!STA_IS_PWR_SLEEP(conn)) {
+
+ A_MUTEX_LOCK(&conn->psqLock);
+
+ while (!A_NETBUF_QUEUE_EMPTY(&conn->psq)) {
+ struct sk_buff *skb=NULL;
+
+ skb = A_NETBUF_DEQUEUE(&conn->psq);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+ ar6000_data_tx(skb,arPriv->arNetDev);
+ A_MUTEX_LOCK(&conn->psqLock);
+ }
+
+ isApsdqEmptyAtStart = A_NETBUF_QUEUE_EMPTY(&conn->apsdq);
+
+ while (!A_NETBUF_QUEUE_EMPTY(&conn->apsdq)) {
+ struct sk_buff *skb=NULL;
+
+ skb = A_NETBUF_DEQUEUE(&conn->apsdq);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+ ar6000_data_tx(skb,arPriv->arNetDev);
+ A_MUTEX_LOCK(&conn->psqLock);
+ }
+
+ A_MUTEX_UNLOCK(&conn->psqLock);
+
+ /* Clear the APSD buffered bitmap for this STA */
+ if (!isApsdqEmptyAtStart) {
+ wmi_set_apsd_buffered_traffic_cmd(arPriv->arWmi, conn->aid, 0, 0);
+ }
+
+ /* Clear the PVB for this STA */
+ wmi_set_pvb_cmd(arPriv->arWmi, conn->aid, 0);
+ }
+ }
+
+ } else {
+ /* This frame is from a STA that is not associated*/
+ A_NETBUF_FREE(skb);
+ goto rx_done;
+ }
+
+ /* Drop NULL data frames here */
+ if((pPacket->ActualLength < minHdrLen) ||
+ (pPacket->ActualLength > AR6000_MAX_RX_MESSAGE_SIZE)) {
+ A_NETBUF_FREE(skb);
+ goto rx_done;
+ }
+ }
+
+ is_amsdu = WMI_DATA_HDR_IS_AMSDU(dhdr);
+ tid = WMI_DATA_HDR_GET_UP(dhdr);
+ seq_no = WMI_DATA_HDR_GET_SEQNO(dhdr);
+ meta_type = WMI_DATA_HDR_GET_META(dhdr);
+ containsDot11Hdr = WMI_DATA_HDR_GET_DOT11(dhdr);
+
+ wmi_data_hdr_remove(arPriv->arWmi, skb);
+
+ switch (meta_type) {
+ case WMI_META_VERSION_1:
+ {
+ WMI_RX_META_V1 *pMeta = (WMI_RX_META_V1 *)A_NETBUF_DATA(skb);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("META %d %d %d %d %x\n", pMeta->status, pMeta->rix, pMeta->rssi, pMeta->channel, pMeta->flags));
+ A_NETBUF_PULL((void*)skb, sizeof(WMI_RX_META_V1));
+ break;
+ }
+#ifdef CONFIG_CHECKSUM_OFFLOAD
+ case WMI_META_VERSION_2:
+ {
+ WMI_RX_META_V2 *pMeta = (WMI_RX_META_V2 *)A_NETBUF_DATA(skb);
+ if(pMeta->csumFlags & 0x1){
+ skb->ip_summed=CHECKSUM_COMPLETE;
+ skb->csum=(pMeta->csum);
+ }
+ A_NETBUF_PULL((void*)skb, sizeof(WMI_RX_META_V2));
+ break;
+ }
+#endif
+ default:
+ break;
+ }
+
+ A_ASSERT(status == A_OK);
+
+ /* NWF: print the 802.11 hdr bytes */
+ if(containsDot11Hdr) {
+ status = wmi_dot11_hdr_remove(arPriv->arWmi,skb);
+ } else if(!is_amsdu && !is_acl_data_frame) {
+#ifdef DIX_RX_OFFLOAD
+ /*Skip the conversion its offloaded to firmware*/
+ if(A_NETBUF_PULL(skb, sizeof(ATH_LLC_SNAP_HDR)) != A_OK) {
+ status = A_NO_MEMORY;
+ }
+ else {
+ status = A_OK;
+ }
+#else
+ status = wmi_dot3_2_dix(skb);
+#endif
+ }
+
+ if (status != A_OK) {
+ /* Drop frames that could not be processed (lack of memory, etc.) */
+ A_NETBUF_FREE(skb);
+ goto rx_done;
+ }
+
+ if (is_acl_data_frame) {
+ A_NETBUF_PUSH(skb, sizeof(int));
+ *((short *)A_NETBUF_DATA(skb)) = WMI_ACL_DATA_EVENTID;
+ /* send the data packet to PAL driver */
+ if(ar6k_pal_config_g.fpar6k_pal_recv_pkt) {
+ if((*ar6k_pal_config_g.fpar6k_pal_recv_pkt)(arPriv->hcipal_info, skb) == TRUE)
+ goto rx_done;
+ }
+ }
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,0)
+ /*
+ * extra push and memcpy, for eth_type_trans() of 2.4 kernel
+ * will pull out hard_header_len bytes of the skb.
+ */
+ A_NETBUF_PUSH(skb, sizeof(WMI_DATA_HDR) + sizeof(ATH_LLC_SNAP_HDR) + HTC_HEADER_LEN);
+ A_MEMCPY(A_NETBUF_DATA(skb), A_NETBUF_DATA(skb) + sizeof(WMI_DATA_HDR) +
+ sizeof(ATH_LLC_SNAP_HDR) + HTC_HEADER_LEN, sizeof(ATH_MAC_HDR));
+#endif
+
+#ifdef ATH_AR6K_11N_SUPPORT
+ multicastcheck_datap = (ATH_MAC_HDR *)A_NETBUF_DATA(skb);
+ /*
+ * Do not pass multicast/bcast data packets to aggregation module
+ * incase of STA mode
+ */
+ if (!(((IEEE80211_IS_MULTICAST(multicastcheck_datap->dstMac))) && (arPriv->arNetworkType == INFRA_NETWORK))){
+ aggr_process_recv_frm(get_aggr_ctx(arPriv, conn), tid, seq_no, is_amsdu, (void **)&skb);
+ }
+#endif
+ ar6000_deliver_frames_to_nw_stack((void *) arPriv->arNetDev, (void *)skb);
+ }
+ }
+ } else {
+ if (EPPING_ALIGNMENT_PAD > 0) {
+ A_NETBUF_PULL(skb, EPPING_ALIGNMENT_PAD);
+ }
+ ar6000_deliver_frames_to_nw_stack((void *)arPriv->arNetDev, (void *)skb);
+ }
+
+rx_done:
+
+ return;
+}
+
+static void
+ar6000_deliver_frames_to_nw_stack(void *dev, void *osbuf)
+{
+ struct sk_buff *skb = (struct sk_buff *)osbuf;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if(skb) {
+ skb->dev = dev;
+ if ((skb->dev->flags & IFF_UP) == IFF_UP) {
+
+ if (arPriv->arNetworkType == AP_NETWORK) {
+
+ struct sk_buff *skb1 = NULL;
+ ATH_MAC_HDR *datap;
+ struct net_device *net_dev = arPriv->arNetDev;
+
+#ifdef CONFIG_PM
+ ar6000_check_wow_status(ar, skb, FALSE);
+#endif /* CONFIG_PM */
+
+
+ datap = (ATH_MAC_HDR *)A_NETBUF_DATA(skb);
+
+ if (IEEE80211_IS_MULTICAST(datap->dstMac)) {
+
+ /* Bcast/Mcast frames should be sent to the OS
+ * stack as well as on the air.
+ */
+ skb1 = skb_copy(skb,GFP_ATOMIC);
+ } else {
+
+ /* Search for a connected STA with dstMac as
+ * the Mac address. If found send the frame to
+ * it on the air else send the frame up the stack
+ */
+
+ AR_SOFTC_DEV_T *to_arPriv = NULL;
+ A_UINT8 is_forward = 0;
+ conn_t *to_conn = NULL;
+
+ to_conn = ieee80211_find_conn(arPriv, datap->dstMac);
+
+ if (to_conn) {
+ to_arPriv = (AR_SOFTC_DEV_T *)to_conn->arPriv;
+ /* Forward data within BSS */
+ if(arPriv == to_arPriv) {
+ is_forward = arPriv->arAp.intra_bss;
+ } else {
+ /* Forward data within mBSS */
+ is_forward = ar->inter_bss;
+ net_dev = to_arPriv->arNetDev;
+ }
+ if(is_forward && net_dev) {
+ skb1 = skb;
+ skb = NULL;
+ } else {
+ A_NETBUF_FREE(skb);
+ skb = NULL;
+ return;
+ }
+ }
+
+ }
+
+ if (skb1) {
+ ar6000_data_tx(skb1, net_dev);
+ if (!skb)
+ return;
+ }
+ }
+
+#ifdef CONFIG_PM
+ ar6000_check_wow_status(ar, skb, FALSE);
+#endif /* CONFIG_PM */
+ skb->protocol = eth_type_trans(skb, skb->dev);
+ /*
+ * If this routine is called on a ISR (Hard IRQ) or DSR (Soft IRQ)
+ * or tasklet use the netif_rx to deliver the packet to the stack
+ * netif_rx will queue the packet onto the receive queue and mark
+ * the softirq thread has a pending action to complete. Kernel will
+ * schedule the softIrq kernel thread after processing the DSR.
+ *
+ * If this routine is called on a process context, use netif_rx_ni
+ * which will schedle the softIrq kernel thread after queuing the packet.
+ */
+ if (in_interrupt()) {
+ A_NETIF_RX(skb);
+ } else {
+ A_NETIF_RX_NI(skb);
+ }
+ } else {
+ A_NETBUF_FREE(skb);
+ }
+ }
+}
+
+#if 0
+static void
+ar6000_deliver_frames_to_bt_stack(void *dev, void *osbuf)
+{
+ struct sk_buff *skb = (struct sk_buff *)osbuf;
+
+ if(skb) {
+ skb->dev = dev;
+ if ((skb->dev->flags & IFF_UP) == IFF_UP) {
+ skb->protocol = htons(ETH_P_CONTROL);
+ netif_rx(skb);
+ } else {
+ A_NETBUF_FREE(skb);
+ }
+ }
+}
+#endif
+
+static void
+ar6000_rx_refill(void *Context, HTC_ENDPOINT_ID Endpoint)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)Context;
+ void *osBuf;
+ int RxBuffers;
+ int buffersToRefill;
+ HTC_PACKET *pPacket;
+ HTC_PACKET_QUEUE queue;
+
+ buffersToRefill = (int)AR6000_MAX_RX_BUFFERS -
+ HTCGetNumRecvBuffers(ar->arHtcTarget, Endpoint);
+
+ if (buffersToRefill <= 0) {
+ /* fast return, nothing to fill */
+ return;
+ }
+
+ INIT_HTC_PACKET_QUEUE(&queue);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_RX,("ar6000_rx_refill: providing htc with %d buffers at eid=%d\n",
+ buffersToRefill, Endpoint));
+
+ for (RxBuffers = 0; RxBuffers < buffersToRefill; RxBuffers++) {
+ osBuf = A_NETBUF_ALLOC(AR6000_BUFFER_SIZE);
+ if (NULL == osBuf) {
+ break;
+ }
+ /* the HTC packet wrapper is at the head of the reserved area
+ * in the skb */
+ pPacket = (HTC_PACKET *)(A_NETBUF_HEAD(osBuf));
+ /* set re-fill info */
+ SET_HTC_PACKET_INFO_RX_REFILL(pPacket,osBuf,A_NETBUF_DATA(osBuf),AR6000_BUFFER_SIZE,Endpoint);
+ /* add to queue */
+ HTC_PACKET_ENQUEUE(&queue,pPacket);
+ }
+
+ if (!HTC_QUEUE_EMPTY(&queue)) {
+ /* add packets */
+ HTCAddReceivePktMultiple(ar->arHtcTarget, &queue);
+ }
+
+}
+
+ /* clean up our amsdu buffer list */
+static void ar6000_cleanup_amsdu_rxbufs(AR_SOFTC_T *ar)
+{
+ HTC_PACKET *pPacket;
+ void *osBuf;
+
+ /* empty AMSDU buffer queue and free OS bufs */
+ while (TRUE) {
+
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ pPacket = HTC_PACKET_DEQUEUE(&ar->amsdu_rx_buffer_queue);
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ if (NULL == pPacket) {
+ break;
+ }
+
+ osBuf = pPacket->pPktContext;
+ if (NULL == osBuf) {
+ A_ASSERT(FALSE);
+ break;
+ }
+
+ A_NETBUF_FREE(osBuf);
+ }
+
+}
+
+
+ /* refill the amsdu buffer list */
+static void ar6000_refill_amsdu_rxbufs(AR_SOFTC_T *ar, int Count)
+{
+ HTC_PACKET *pPacket;
+ void *osBuf;
+
+ while (Count > 0) {
+ osBuf = A_NETBUF_ALLOC(AR6000_AMSDU_BUFFER_SIZE);
+ if (NULL == osBuf) {
+ break;
+ }
+ /* the HTC packet wrapper is at the head of the reserved area
+ * in the skb */
+ pPacket = (HTC_PACKET *)(A_NETBUF_HEAD(osBuf));
+ /* set re-fill info */
+ SET_HTC_PACKET_INFO_RX_REFILL(pPacket,osBuf,A_NETBUF_DATA(osBuf),AR6000_AMSDU_BUFFER_SIZE,0);
+
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ /* put it in the list */
+ HTC_PACKET_ENQUEUE(&ar->amsdu_rx_buffer_queue,pPacket);
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ Count--;
+ }
+
+}
+
+ /* callback to allocate a large receive buffer for a pending packet. This function is called when
+ * an HTC packet arrives whose length exceeds a threshold value
+ *
+ * We use a pre-allocated list of buffers of maximum AMSDU size (4K). Under linux it is more optimal to
+ * keep the allocation size the same to optimize cached-slab allocations.
+ *
+ * */
+static HTC_PACKET *ar6000_alloc_amsdu_rxbuf(void *Context, HTC_ENDPOINT_ID Endpoint, int Length)
+{
+ HTC_PACKET *pPacket = NULL;
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)Context;
+ int refillCount = 0;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_RX,("ar6000_alloc_amsdu_rxbuf: eid=%d, Length:%d\n",Endpoint,Length));
+
+ do {
+
+ if (Length <= AR6000_BUFFER_SIZE) {
+ /* shouldn't be getting called on normal sized packets */
+ A_ASSERT(FALSE);
+ break;
+ }
+
+ if (Length > AR6000_AMSDU_BUFFER_SIZE) {
+ A_ASSERT(FALSE);
+ break;
+ }
+
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ /* allocate a packet from the list */
+ pPacket = HTC_PACKET_DEQUEUE(&ar->amsdu_rx_buffer_queue);
+ /* see if we need to refill again */
+ refillCount = AR6000_MAX_AMSDU_RX_BUFFERS - HTC_PACKET_QUEUE_DEPTH(&ar->amsdu_rx_buffer_queue);
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ if (NULL == pPacket) {
+ break;
+ }
+ /* set actual endpoint ID */
+ pPacket->Endpoint = Endpoint;
+
+ } while (FALSE);
+
+ if (refillCount >= AR6000_AMSDU_REFILL_THRESHOLD) {
+ ar6000_refill_amsdu_rxbufs(ar,refillCount);
+ }
+
+ return pPacket;
+}
+
+static void
+ar6000_set_multicast_list(struct net_device *dev)
+{
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 35)
+ int mc_count = dev->mc_count;
+ struct dev_mc_list *mc;
+ int j;
+#else
+ int mc_count = netdev_mc_count(dev);
+ struct netdev_hw_addr *ha;
+#endif
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ int i;
+ A_BOOL enableAll, disableAll;
+ enum {
+ IGNORE = 0,
+ MATCH = 1,
+ ADD = 2,
+ DELETE = 3
+ } action[MAC_MAX_FILTERS_PER_LIST];
+ A_BOOL mcValid;
+ A_UINT8 *mac;
+ A_UINT8 *filter;
+ A_BOOL filterValid;
+
+ if (ar->arWmiReady == FALSE || ar->arWlanState == WLAN_DISABLED)
+ return;
+
+ enableAll = FALSE;
+ disableAll = FALSE;
+
+ /*
+ * Enable receive all multicast, if
+ * 1. promiscous mode,
+ * 2. Allow all multicast
+ * 3. H/W supported filters is less than application requested filter
+ */
+ if ((dev->flags & IFF_PROMISC) ||
+ (dev->flags & IFF_ALLMULTI) ||
+ (mc_count > MAC_MAX_FILTERS_PER_LIST))
+ {
+ enableAll = TRUE;
+ } else {
+ /* Disable all multicast if interface has multicast disable or list is empty */
+ if ((!(dev->flags & IFF_MULTICAST)) || (!mc_count)) {
+ disableAll = TRUE;
+ }
+ }
+
+ /*
+ * Firmware behaviour
+ * enableAll - set filter to enable and delete valid filters
+ * disableAll - set filter to disable and delete valid filers
+ * filter - set valid filters
+ */
+
+ /*
+ * Pass 1: Mark all the valid filters to delete
+ */
+ for (i=0; i<MAC_MAX_FILTERS_PER_LIST; i++) {
+ filter = arPriv->mcast_filters[i];
+ filterValid = (filter[1] || filter[2]);
+ if (filterValid) {
+ action[i] = DELETE;
+ } else {
+ action[i] = IGNORE;
+ }
+ }
+
+ if ((!enableAll) && (!disableAll)) {
+ /*
+ * Pass 2: Mark all filters which match the previous ones
+ */
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
+ for (j = 0, mc = dev->mc_list; mc && (j < dev->mc_count);
+ j++, mc = mc->next) {
+ mac = mc->dmi_addr;
+#else
+ netdev_for_each_mc_addr(ha, dev) {
+ mac = ha->addr;
+#endif
+
+ mcValid = (mac[2] || mac[3] || mac[4] || mac[5]);
+ if (mcValid) {
+ for (i=0; i<MAC_MAX_FILTERS_PER_LIST; i++) {
+ filter = arPriv->mcast_filters[i];
+ if ((A_MEMCMP(filter, &mac[0], AR_MCAST_FILTER_MAC_ADDR_SIZE)) == 0) {
+ action[i] = MATCH;
+ break;
+ }
+ }
+ }
+ }
+
+ /*
+ * Delete old entries and free-up space for new additions
+ */
+ for (i = 0; i < MAC_MAX_FILTERS_PER_LIST; i++) {
+ filter = arPriv->mcast_filters[i];
+ if (action[i] == DELETE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Delete Filter %d = %02x:%02x:%02x:%02x:%02x:%02x\n",
+ i, filter[0], filter[1], filter[2], filter[3], filter[4], filter[5]));
+ wmi_del_mcast_filter_cmd(arPriv->arWmi, filter);
+ A_MEMZERO(filter, AR_MCAST_FILTER_MAC_ADDR_SIZE);
+ /* Make this available for further additions */
+ action[i] = IGNORE;
+ }
+ }
+
+ /*
+ * Pass 3: Add new filters to empty slots
+ */
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
+ for (j = 0, mc = dev->mc_list; mc && (j < dev->mc_count);
+ j++, mc = mc->next) {
+#else
+ netdev_for_each_mc_addr(ha, dev) {
+
+#endif
+ A_BOOL match;
+ A_INT32 free;
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
+ mac = mc->dmi_addr;
+#else
+ mac = ha->addr;
+#endif
+ mcValid = (mac[2] || mac[3] || mac[4] || mac[5]);
+ if (mcValid) {
+ match = FALSE;
+ free = -1;
+ for (i=0; i<MAC_MAX_FILTERS_PER_LIST; i++) {
+ A_UINT8 *filter = arPriv->mcast_filters[i];
+ if ((A_MEMCMP(filter, &mac[0], AR_MCAST_FILTER_MAC_ADDR_SIZE)) == 0) {
+ match = TRUE;
+ break;
+ } else if (action[i] != MATCH && action[i] != ADD) {
+ if (free == -1) {
+ free = i; // Mark the first free index
+ }
+ }
+ }
+ if ((!match) && (free != -1)) {
+ filter = arPriv->mcast_filters[free];
+ A_MEMCPY(filter, &mac[0], AR_MCAST_FILTER_MAC_ADDR_SIZE);
+ action[free] = ADD;
+ }
+ }
+ }
+ }
+
+
+ for (i=0; i<MAC_MAX_FILTERS_PER_LIST; i++) {
+ filter = arPriv->mcast_filters[i];
+ if (action[i] == DELETE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Delete Filter %d = %02x:%02x:%02x:%02x:%02x:%02x\n",
+ i, filter[0], filter[1], filter[2], filter[3], filter[4], filter[5]));
+ wmi_del_mcast_filter_cmd(arPriv->arWmi, filter);
+ A_MEMZERO(filter, AR_MCAST_FILTER_MAC_ADDR_SIZE);
+ } else if (action[i] == ADD) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Add Filter %d = %02x:%02x:%02x:%02x:%02x:%02x\n",
+ i, filter[0], filter[1], filter[2], filter[3],filter[4],filter[5]));
+ wmi_set_mcast_filter_cmd(arPriv->arWmi, filter);
+ } else if (action[i] == MATCH) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Keep Filter %d = %02x:%02x:%02x:%02x:%02x:%02x\n",
+ i, filter[0], filter[1], filter[2], filter[3],filter[4],filter[5]));
+ }
+ }
+
+ if (enableAll) {
+ /* target allow all multicast packets if fitler enable and fitler list is zero */
+ wmi_mcast_filter_cmd(arPriv->arWmi, TRUE);
+ } else if (disableAll) {
+ /* target drop multicast packets if fitler disable and fitler list is zero */
+ wmi_mcast_filter_cmd(arPriv->arWmi, FALSE);
+ }
+}
+
+static struct net_device_stats *
+ar6000_get_stats(struct net_device *dev)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ return &arPriv->arNetStats;
+}
+
+static struct iw_statistics *
+ar6000_get_iwstats(struct net_device * dev)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ TARGET_STATS *pStats = &arPriv->arTargetStats;
+ struct iw_statistics * pIwStats = &arPriv->arIwStats;
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+ if (ar->bIsDestroyProgress || ar->arWmiReady == FALSE || ar->arWlanState == WLAN_DISABLED || testmode)
+#else
+ if (ar->bIsDestroyProgress || ar->arWmiReady == FALSE || ar->arWlanState == WLAN_DISABLED)
+#endif
+ {
+ pIwStats->status = 0;
+ pIwStats->qual.qual = 0;
+ pIwStats->qual.level =0;
+ pIwStats->qual.noise = 0;
+ pIwStats->discard.code =0;
+ pIwStats->discard.retries=0;
+ pIwStats->miss.beacon =0;
+ return pIwStats;
+ }
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+ /*
+ * The in_atomic function is used to determine if the scheduling is
+ * allowed in the current context or not. This was introduced in 2.6
+ * From what I have read on the differences between 2.4 and 2.6, the
+ * 2.4 kernel did not support preemption and so this check might not
+ * be required for 2.4 kernels.
+ */
+ if (in_atomic())
+ {
+ if (wmi_get_stats_cmd(arPriv->arWmi) == A_OK) {
+ }
+
+ pIwStats->status = 1 ;
+ pIwStats->qual.qual = pStats->cs_aveBeacon_rssi - 161;
+ pIwStats->qual.level =pStats->cs_aveBeacon_rssi; /* noise is -95 dBm */
+ pIwStats->qual.noise = pStats->noise_floor_calibation;
+ pIwStats->discard.code = pStats->rx_decrypt_err;
+ pIwStats->discard.retries = pStats->tx_retry_cnt;
+ pIwStats->miss.beacon = pStats->cs_bmiss_cnt;
+ return pIwStats;
+ }
+#endif /* LINUX_VERSION_CODE */
+ dev_hold(dev);
+
+ pIwStats->status = 0;
+
+ if (down_interruptible(&ar->arSem)) {
+ goto err_exit;
+ }
+
+ do {
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ break;
+ }
+
+ arPriv->statsUpdatePending = TRUE;
+
+ if(wmi_get_stats_cmd(arPriv->arWmi) != A_OK) {
+ break;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->statsUpdatePending == FALSE, wmitimeout * HZ);
+ if (signal_pending(current)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000 : WMI get stats timeout \n"));
+ break;
+ }
+ pIwStats->status = 1 ;
+ pIwStats->qual.qual = pStats->cs_aveBeacon_rssi - 161;
+ pIwStats->qual.level =pStats->cs_aveBeacon_rssi; /* noise is -95 dBm */
+ pIwStats->qual.noise = pStats->noise_floor_calibation;
+ pIwStats->discard.code = pStats->rx_decrypt_err;
+ pIwStats->discard.retries = pStats->tx_retry_cnt;
+ pIwStats->miss.beacon = pStats->cs_bmiss_cnt;
+ } while (0);
+ up(&ar->arSem);
+
+err_exit:
+
+ dev_put(dev);
+ return pIwStats;
+}
+
+void
+ar6000_ready_event(void *devt, A_UINT8 *datap, A_UINT8 phyCap, A_UINT32 sw_ver, A_UINT32 abi_ver)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+ struct net_device *dev;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UINT8 i, j, k;
+ AR_SOFTC_STA_T *arSta;
+
+ ar->arWmiReady = TRUE;
+ ar->arVersion.wlan_ver = sw_ver;
+ ar->arVersion.abi_ver = abi_ver;
+ wake_up(&arPriv->arEvent);
+
+ for(i = 0; i < num_device ; i++) {
+ dev = ar6000_devices[i];
+ arPriv = ar->arDev[i];
+ arPriv->arPhyCapability = phyCap;
+ if (arPriv->arPhyCapability == WMI_11NAG_CAPABILITY){
+ arPriv->phymode = DEF_AP_WMODE_AG;
+ } else {
+ arPriv->phymode = DEF_AP_WMODE_G;
+ }
+ A_MEMCPY(dev->dev_addr, datap, AR6000_ETH_ADDR_LEN);
+
+ if (i > 0) {
+ if(mac_addr_method) {
+ k = dev->dev_addr[5];
+ dev->dev_addr[5] += i;
+ for(j=5; j>3; j--) {
+ if(dev->dev_addr[j] > k) {
+ break;
+ }
+ k = dev->dev_addr[j-1];
+ dev->dev_addr[j-1]++;
+ }
+ } else {
+ dev->dev_addr[0] = (((dev->dev_addr[0]) ^ (1 << i))) | 0x02;
+ }
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("DEV%d mac address = %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x\n",
+ i, dev->dev_addr[0], dev->dev_addr[1],
+ dev->dev_addr[2], dev->dev_addr[3],
+ dev->dev_addr[4], dev->dev_addr[5]));
+
+#ifdef AR6K_ENABLE_HCI_PAL
+ ar6k_hci_pal_info_t *pHciPalInfo = (ar6k_hci_pal_info_t *)ar->hcipal_info;
+ pHciPalInfo->hdev->bdaddr.b[0]=dev->dev_addr[5];
+ pHciPalInfo->hdev->bdaddr.b[1]=dev->dev_addr[4];
+ pHciPalInfo->hdev->bdaddr.b[2]=dev->dev_addr[3];
+ pHciPalInfo->hdev->bdaddr.b[3]=dev->dev_addr[2];
+ pHciPalInfo->hdev->bdaddr.b[4]=dev->dev_addr[1];
+ pHciPalInfo->hdev->bdaddr.b[5]=dev->dev_addr[0];
+
+#endif
+
+#if (WLAN_CONFIG_PSPOLL_NUM) || (WLAN_CONFIG_DTIM_POLICY) || \
+ (WLAN_CONFIG_IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN)
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("AR6K: %s: PSPOLL_NUM = %d, DTIM_POLICY = %d, PS_FAIL_EVENT_POLICY = %d\n",
+ __FUNCTION__, WLAN_CONFIG_PSPOLL_NUM, WLAN_CONFIG_DTIM_POLICY,
+ WLAN_CONFIG_IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN));
+
+ wmi_pmparams_cmd(arPriv->arWmi,
+ 0, /* idlePeriod */
+ WLAN_CONFIG_PSPOLL_NUM, /* psPollNum */
+ WLAN_CONFIG_DTIM_POLICY, /* dtimPolicy */
+ 0, /* tx_wakeup_policy */
+ 1, /* num_tx_to_wakeup */
+ WLAN_CONFIG_IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN /* ps_fail_event_policy */ );
+#endif
+#if WLAN_CONFIG_DONOT_IGNORE_BARKER_IN_ERP
+ wmi_set_lpreamble_cmd(arPriv->arWmi, 0, WMI_DONOT_IGNORE_BARKER_IN_ERP);
+#endif
+
+ wmi_set_keepalive_cmd(arPriv->arWmi, WLAN_CONFIG_KEEP_ALIVE_INTERVAL);
+
+#ifdef BMISS_ENHANCEMENT
+ /* This code has been added to enable the new algorithm to prevent BMISS
+ * Enabling this right now only for single dev opertaing mode */
+ if (num_device == 1) {
+ wmi_sta_bmiss_enhance_cmd(arPriv->arWmi, 1);
+ }
+#endif
+
+ /* BG scan should be enabled for p2p operation */
+ A_PRINTF("AR6K: targetconf_ver : %d\n", ar->arVersion.targetconf_ver);
+ if (ar->arVersion.targetconf_ver == AR6003_SUBVER_DEFAULT) {
+ WMI_SET_ROAM_CTRL_CMD roamCtrl;
+
+ if (arPriv->arNetworkType != AP_NETWORK) {
+ arSta = &arPriv->arSta;
+
+ /* if psm_info is 0, disable background scan for OTA */
+ if (!psm_info) {
+ arSta->scParams.bg_period = 65535;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6K: bg scan interval = %d, active dwell time = %d passive dwell time = %d\n",
+ arSta->scParams.bg_period, arSta->scParams.maxact_chdwell_time,
+ arSta->scParams.pas_chdwell_time));
+
+ wmi_scanparams_cmd(arPriv->arWmi,
+ arSta->scParams.fg_start_period,
+ arSta->scParams.fg_end_period,
+ arSta->scParams.bg_period,
+ arSta->scParams.minact_chdwell_time,
+ arSta->scParams.maxact_chdwell_time,
+ arSta->scParams.pas_chdwell_time,
+ arSta->scParams.shortScanRatio,
+ arSta->scParams.scanCtrlFlags,
+ arSta->scParams.max_dfsch_act_time,
+ arSta->scParams.maxact_scan_per_ssid);
+ }
+
+ A_MEMZERO(&roamCtrl, sizeof(roamCtrl));
+ roamCtrl.roamCtrlType = WMI_SET_LOWRSSI_SCAN_PARAMS;
+ roamCtrl.info.lrScanParams.lowrssi_scan_period = 65535; //low rssi scanning disabled
+ wmi_set_roam_ctrl_cmd(arPriv->arWmi, &roamCtrl, sizeof(roamCtrl));
+ }
+
+
+#if WLAN_CONFIG_DISABLE_11N
+ {
+ WMI_SET_HT_CAP_CMD htCap;
+
+ A_MEMZERO(&htCap, sizeof(WMI_SET_HT_CAP_CMD));
+ htCap.band = 0;
+ wmi_set_ht_cap_cmd(arPriv->arWmi, &htCap);
+
+ htCap.band = 1;
+ wmi_set_ht_cap_cmd(arPriv->arWmi, &htCap);
+ }
+#endif /* WLAN_CONFIG_DISABLE_11N */
+
+#ifdef ATH6K_CONFIG_OTA_MODE
+ wmi_powermode_cmd(arPriv->arWmi, MAX_PERF_POWER);
+#else
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6K: %s: psm.info is %d (0: MAX_PERF_POWER, 1:REC_POWER)\n", __FUNCTION__, psm_info));
+ wmi_powermode_cmd_w_psminfo(arPriv->arWmi, psm_info, 0);
+#endif
+ wmi_disctimeout_cmd(arPriv->arWmi, WLAN_CONFIG_DISCONNECT_TIMEOUT);
+ }
+}
+
+A_STATUS
+ar6000_ap_mode_probe_rx(AR_SOFTC_DEV_T *arPriv, A_UINT8 *datap, int len)
+{
+ struct sk_buff *skb;
+ WMI_BSS_INFO_HDR *bih = (WMI_BSS_INFO_HDR *)datap;
+ A_UINT8 *buf = NULL;
+
+ if((arPriv->arNetworkType != AP_NETWORK) ||
+ (arPriv->arNetworkSubType != SUBTYPE_NONE)) {
+ return A_ERROR;
+ }
+
+ buf = datap + sizeof(WMI_BSS_INFO_HDR);
+ len -= sizeof(WMI_BSS_INFO_HDR);
+ len += 6; /* For adding MAC addr */
+ if ((skb = A_NETBUF_ALLOC_RAW(len)) != NULL) {
+ A_NETBUF_PUT(skb, len);
+ A_MEMCPY(A_NETBUF_DATA(skb), bih->bssid, 6);
+ A_MEMCPY(A_NETBUF_DATA(skb)+6, buf, len-6);
+ skb->dev = arPriv->arNetDev;
+ skb_reset_mac_header(skb);
+ skb->ip_summed = CHECKSUM_NONE;
+ skb->pkt_type = PACKET_OTHERHOST;
+ skb->protocol = __constant_htons(0x0019);
+ A_NETIF_RX(skb);
+ }
+ return A_OK;
+}
+#ifdef P2P
+A_UINT8 get_connected_sta_cnt(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UINT8 i, cnt=0;
+ for(i=0;i<NUM_CONN;i++) {
+ if(ar->connTbl[i].arPriv == arPriv) {
+ cnt++;
+ }
+ }
+ return cnt;
+}
+#endif
+void
+add_new_sta(AR_SOFTC_DEV_T *arPriv, A_UINT8 *mac, A_UINT16 aid, A_UINT8 *wpaie,
+ A_UINT8 ielen, A_UINT8 keymgmt, A_UINT8 ucipher, A_UINT8 auth, A_UINT8 wmode, A_UINT8 apsd_info,
+ A_UINT8 HT_present)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+ A_UINT8 free_slot=aid-1;
+
+ A_MEMCPY(ar->connTbl[free_slot].mac, mac, ATH_MAC_LEN);
+ A_MEMCPY(ar->connTbl[free_slot].wpa_ie, wpaie, ielen);
+ ar->connTbl[free_slot].arPriv = arPriv;
+ ar->connTbl[free_slot].aid = aid;
+ ar->connTbl[free_slot].keymgmt = keymgmt;
+ ar->connTbl[free_slot].ucipher = ucipher;
+ ar->connTbl[free_slot].auth = auth;
+ ar->connTbl[free_slot].wmode = wmode;
+ ar->connTbl[free_slot].apsd_info= apsd_info;
+ ar->connTbl[free_slot].HT_present = HT_present;
+ ar->connTbl[free_slot].flags = 0;
+ ar->arAPStats[free_slot].aid = aid;
+ arAp->sta_list_index = arAp->sta_list_index | (1 << free_slot);
+ aggr_reset_state(ar->connTbl[free_slot].conn_aggr, (void *) arPriv->arNetDev);
+#ifdef P2P
+ if((arPriv->arNetworkSubType == SUBTYPE_P2PGO) && (arPriv->num_sta == get_connected_sta_cnt(arPriv))) {
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv), P2P_GROUP_CAPAB_GROUP_LIMIT,1);
+ }
+#endif
+}
+
+void
+ar6000_connect_event(AR_SOFTC_DEV_T *arPriv, WMI_CONNECT_EVENT *pEvt)
+{
+ union iwreq_data wrqu;
+ int i, beacon_ie_pos, assoc_resp_ie_pos, assoc_req_ie_pos;
+ static const char *tag1 = "ASSOCINFO(ReqIEs=";
+ static const char *tag2 = "ASSOCRESPIE=";
+ static const char *beaconIetag = "BEACONIE=";
+ char buf[WMI_CONTROL_MSG_MAX_LEN * 2 + strlen(tag1) + 1];
+ char *pos;
+ A_UINT8 key_op_ctrl;
+ unsigned long flags;
+ struct ieee80211req_key *ik;
+ CRYPTO_TYPE keyType = NONE_CRYPT;
+ AR_SOFTC_STA_T *arSta;
+ struct ieee80211_frame *wh;
+ A_UINT8 *frm, *efrm, *ssid, *rates, *xrates, *wpaie, wpaLen=0;
+ A_UINT16 subtype;
+ A_UINT8 beaconIeLen;
+ A_UINT8 assocReqLen;
+ A_UINT8 assocRespLen;
+ A_UINT8 *assocInfo;
+ A_UINT8 *bssid;
+ A_INT8 rate_idx;
+ A_UINT8 HT_present = 0;
+
+ beaconIeLen = pEvt->beaconIeLen;
+ assocReqLen = pEvt->assocReqLen;
+ assocRespLen = pEvt->assocRespLen;
+ assocInfo = pEvt->assocInfo;
+
+ /* BSSID and MAC_ADDR is in the same location for all modes */
+ bssid = pEvt->u.infra_ibss_bss.bssid;
+
+ if(arPriv->arNetworkType & AP_NETWORK) {
+ struct net_device *dev = arPriv->arNetDev;
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+ A_UINT8 aid, wmode, keymgmt, auth_alg;
+
+ if(A_MEMCMP(dev->dev_addr, bssid, ATH_MAC_LEN)==0) {
+ ik = &arAp->ap_mode_bkey;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AP%d: [UP] SSID %s MAC %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x\n",
+ arPriv->arDeviceIndex, arPriv->arSsid,
+ bssid[0], bssid[1], bssid[2], bssid[3], bssid[4], bssid[5]));
+
+ arPriv->arChannelHint = pEvt->u.ap_bss.channel;
+ arPriv->arBssChannel = arPriv->arChannelHint;
+ arPriv->arConnected = TRUE;
+
+ A_MEMCPY(arPriv->arAp.ap_country_code, pEvt->u.ap_sta.unused,
+ sizeof(arPriv->arAp.ap_country_code));
+
+ /* Concurrency: Process the pending connect of the other virtual device(s) */
+ ar6000_check_hold_conn_status(arPriv, TRUE);
+#ifdef P2P
+ if(arPriv->arNetworkSubType == SUBTYPE_P2PDEV) {
+ arPriv->arNetworkSubType = SUBTYPE_P2PGO;
+ p2p_update_capability(A_WMI_GET_P2P_CTX(arPriv),arPriv->arNetworkSubType,num_device);
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv), P2P_GROUP_CAPAB_GROUP_LIMIT,0);
+ }
+#endif
+
+
+#ifdef WAPI_ENABLE
+ if( (arPriv->arAuthMode == WMI_NONE_AUTH) &&
+ (arPriv->arPairwiseCrypto == WAPI_CRYPT) ) {
+ ap_set_wapi_key(arPriv, ik);
+ }
+#endif
+ if(arPriv->arAuthMode &
+ (WMI_WPA_PSK_AUTH|WMI_WPA2_PSK_AUTH|WMI_WPA_AUTH|WMI_WPA2_AUTH))
+ {
+ switch (ik->ik_type) {
+ case IEEE80211_CIPHER_TKIP:
+ keyType = TKIP_CRYPT;
+ break;
+ case IEEE80211_CIPHER_AES_CCM:
+ keyType = AES_CRYPT;
+ break;
+ default:
+ goto skip_key;
+ }
+
+ wmi_addKey_cmd(arPriv->arWmi, ik->ik_keyix, keyType, GROUP_USAGE,
+ ik->ik_keylen, (A_UINT8 *)&ik->ik_keyrsc,
+ ik->ik_keydata, KEY_OP_INIT_VAL, ik->ik_macaddr,
+ SYNC_BOTH_WMIFLAG);
+ }
+skip_key:
+ wmi_bssfilter_cmd(arPriv->arWmi, NONE_BSS_FILTER, 0);
+
+ arPriv->arConnected = TRUE;
+ return;
+ }
+
+ wh = (struct ieee80211_frame *) (assocInfo + beaconIeLen);
+ subtype = wh->i_fc[0] & IEEE80211_FC0_SUBTYPE_MASK;
+ frm = (A_UINT8 *)&wh[1];
+ efrm = assocInfo + beaconIeLen + assocReqLen;
+
+ /* capability information */
+ frm += 2;
+
+ /* listen int */
+ frm += 2;
+
+ /* Reassoc will have current AP addr field */
+ if(subtype == IEEE80211_FC0_SUBTYPE_REASSOC_REQ) {
+ frm += 6;
+ }
+
+ ssid = rates = xrates = wpaie = NULL;
+ while (frm < efrm) {
+ switch (*frm) {
+/* currently unused */
+/*
+ case IEEE80211_ELEMID_SSID:
+ ssid = frm;
+ break;
+ case IEEE80211_ELEMID_RATES:
+ rates = frm;
+ break;
+ case IEEE80211_ELEMID_XRATES:
+ xrates = frm;
+ break;
+*/
+ case IEEE80211_ELEMID_VENDOR:
+ if( (frm[1] > 3) && (frm[2] == 0x00) && (frm[3] == 0x50) &&
+ (frm[4] == 0xF2) && ((frm[5] == 0x01) || (frm[5] == 0x04)) )
+ {
+ wpaie = frm;
+ wpaLen = wpaie[1]+2;
+ }
+ break;
+ case IEEE80211_ELEMID_RSN:
+ wpaie = frm;
+ wpaLen = wpaie[1]+2;
+ break;
+#ifdef WAPI_ENABLE
+ case IEEE80211_ELEMID_WAPI:
+ wpaie = frm;
+ wpaLen = wpaie[1]+2;
+ break;
+#endif
+ case IEEE80211_ELEMID_HTCAP_ANA:
+ HT_present = 1;
+ break;
+ }
+ frm += frm[1] + 2;
+ }
+
+ aid = pEvt->u.ap_sta.aid;
+ wmode = pEvt->u.ap_sta.phymode;
+ keymgmt = pEvt->u.ap_sta.keymgmt;
+ auth_alg = pEvt->u.ap_sta.auth;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("NEW STA %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x \n "
+ " AID=%d AUTH=%d WMODE=%d KEYMGMT=%d CIPHER=%d APSD=%x\n",
+ pEvt->u.ap_sta.mac_addr[0], pEvt->u.ap_sta.mac_addr[1], pEvt->u.ap_sta.mac_addr[2],
+ pEvt->u.ap_sta.mac_addr[3], pEvt->u.ap_sta.mac_addr[4], pEvt->u.ap_sta.mac_addr[5],
+ aid, auth_alg, wmode, keymgmt, pEvt->u.ap_sta.cipher, pEvt->u.ap_sta.apsd_info));
+
+ add_new_sta(arPriv, pEvt->u.ap_sta.mac_addr, aid, wpaie, wpaLen, keymgmt,
+ pEvt->u.ap_sta.cipher, auth_alg, wmode, pEvt->u.ap_sta.apsd_info,HT_present);
+
+ /* Send event to application */
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ A_MEMCPY(wrqu.addr.sa_data, pEvt->u.ap_sta.mac_addr, ATH_MAC_LEN);
+ wireless_send_event(arPriv->arNetDev, IWEVREGISTERED, &wrqu, NULL);
+ /* In case the queue is stopped when we switch modes, this will
+ * wake it up
+ */
+ netif_wake_queue(arPriv->arNetDev);
+ return;
+ }
+#ifdef ATH6K_CONFIG_CFG80211
+ ar6k_cfg80211_connect_event(arPriv, pEvt->u.infra_ibss_bss.channel, bssid,
+ pEvt->u.infra_ibss_bss.listenInterval, pEvt->u.infra_ibss_bss.beaconInterval,
+ pEvt->u.infra_ibss_bss.networkType, beaconIeLen,
+ assocReqLen, assocRespLen,
+ assocInfo);
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ arPriv->arChannelHint = pEvt->u.infra_ibss_bss.channel;
+ arPriv->arBssChannel = arPriv->arChannelHint;
+ arPriv->arConnected = TRUE;
+ arSta = &arPriv->arSta;
+ arSta->arConnectPending = FALSE;
+
+ /* Concurrency: Process the pending connect of the other virtual device(s) */
+ ar6000_check_hold_conn_status(arPriv, TRUE);
+
+ A_MEMCPY(arPriv->arBssid, bssid, sizeof(arPriv->arBssid));
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 connected event on freq %d ", pEvt->u.infra_ibss_bss.channel));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("with bssid %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x "
+ " listenInterval=%d, beaconInterval = %d, beaconIeLen = %d assocReqLen=%d"
+ " assocRespLen =%d\n",
+ bssid[0], bssid[1], bssid[2],
+ bssid[3], bssid[4], bssid[5],
+ pEvt->u.infra_ibss_bss.listenInterval, pEvt->u.infra_ibss_bss.beaconInterval,
+ beaconIeLen, assocReqLen, assocRespLen));
+ if (pEvt->u.infra_ibss_bss.networkType & ADHOC_NETWORK) {
+ /* Disable BG Scan for ADHOC NETWORK */
+ wmi_scanparams_cmd(arPriv->arWmi, 0, 0,
+ 0xFFFF, 0, 0, 0, WMI_SHORTSCANRATIO_DEFAULT,DEFAULT_SCAN_CTRL_FLAGS, 0, 0);
+ if (pEvt->u.infra_ibss_bss.networkType & ADHOC_CREATOR) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Network: Adhoc (Creator)\n"));
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Network: Adhoc (Joiner)\n"));
+ }
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Network: Infrastructure\n"));
+ }
+
+ if ((arPriv->arNetworkType == INFRA_NETWORK)) {
+ if (arSta->arConnectPending) {
+ wmi_listeninterval_cmd(arPriv->arWmi, arSta->arListenIntervalT, arSta->arListenIntervalB);
+ }
+ if (arPriv->arBitRate != -1) {
+ if ((wmi_validate_bitrate(arPriv->arWmi, arPriv->arBitRate, &rate_idx)) != A_OK){
+ printk("User set rate cannot be used\n");
+ arPriv->arBitRate = -1;
+ }
+ }
+ }
+#ifdef P2P
+ if(arPriv->arNetworkSubType == SUBTYPE_P2PDEV) {
+ arPriv->arNetworkSubType = SUBTYPE_P2PCLIENT;
+ p2p_update_capability(A_WMI_GET_P2P_CTX(arPriv),arPriv->arNetworkSubType,num_device);
+ }
+#endif
+
+ if (beaconIeLen && (sizeof(buf) > (9 + beaconIeLen * 2))) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\nBeaconIEs= "));
+
+ beacon_ie_pos = 0;
+ A_MEMZERO(buf, sizeof(buf));
+ sprintf(buf, "%s", beaconIetag);
+ pos = buf + 9;
+ for (i = beacon_ie_pos; i < beacon_ie_pos + beaconIeLen; i++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("%2.2x ", assocInfo[i]));
+ sprintf(pos, "%2.2x", assocInfo[i]);
+ pos += 2;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\n"));
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = strlen(buf);
+ if (wrqu.data.length <= IW_CUSTOM_MAX) {
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Fail to send BeaconIEs to upper layer\n"));
+ }
+ }
+
+ if (assocRespLen && (sizeof(buf) > (12 + (assocRespLen * 2))))
+ {
+ assoc_resp_ie_pos = beaconIeLen + assocReqLen +
+ sizeof(A_UINT16) + /* capinfo*/
+ sizeof(A_UINT16) + /* status Code */
+ sizeof(A_UINT16) ; /* associd */
+ A_MEMZERO(buf, sizeof(buf));
+ sprintf(buf, "%s", tag2);
+ pos = buf + 12;
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\nAssocRespIEs= "));
+ /*
+ * The Association Response Frame w.o. the WLAN header is delivered to
+ * the host, so skip over to the IEs
+ */
+ for (i = assoc_resp_ie_pos; i < assoc_resp_ie_pos + assocRespLen - 6; i++)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("%2.2x ", assocInfo[i]));
+ sprintf(pos, "%2.2x", assocInfo[i]);
+ pos += 2;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\n"));
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = strlen(buf);
+ if (wrqu.data.length <= IW_CUSTOM_MAX) {
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+ } else {
+#if (WIRELESS_EXT >= 18)
+ wrqu.data.length = (assocRespLen - 6);
+ wireless_send_event(arPriv->arNetDev, IWEVASSOCRESPIE, &wrqu, &assocInfo[assoc_resp_ie_pos]);
+#else
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Fail to send Association Response to upper layer\n"));
+#endif
+ }
+ }
+
+ if (assocReqLen && (sizeof(buf) > (17 + (assocReqLen * 2)))) {
+ /*
+ * assoc Request includes capability and listen interval. Skip these.
+ */
+ assoc_req_ie_pos = beaconIeLen +
+ sizeof(A_UINT16) + /* capinfo*/
+ sizeof(A_UINT16); /* listen interval */
+
+ A_MEMZERO(buf, sizeof(buf));
+ sprintf(buf, "%s", tag1);
+ pos = buf + 17;
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("AssocReqIEs= "));
+ for (i = assoc_req_ie_pos; i < assoc_req_ie_pos + assocReqLen - 4; i++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("%2.2x ", assocInfo[i]));
+ sprintf(pos, "%2.2x", assocInfo[i]);
+ pos += 2;;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\n"));
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = strlen(buf);
+ if (wrqu.data.length <= IW_CUSTOM_MAX) {
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+ } else {
+#if (WIRELESS_EXT >= 18)
+ wrqu.data.length = (assocReqLen - 4);
+ wireless_send_event(arPriv->arNetDev, IWEVASSOCREQIE, &wrqu, &assocInfo[assoc_req_ie_pos]);
+#else
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Fail to send Association Request to upper layer\n"));
+#endif
+ }
+ }
+
+#ifdef USER_KEYS
+ if (arSta->user_savedkeys_stat == USER_SAVEDKEYS_STAT_RUN &&
+ arSta->user_saved_keys.keyOk == TRUE)
+ {
+ key_op_ctrl = KEY_OP_VALID_MASK & ~KEY_OP_INIT_TSC;
+
+ if (arSta->user_key_ctrl & AR6000_USER_SETKEYS_RSC_UNCHANGED) {
+ key_op_ctrl &= ~KEY_OP_INIT_RSC;
+ } else {
+ key_op_ctrl |= KEY_OP_INIT_RSC;
+ }
+ ar6000_reinstall_keys(arPriv, key_op_ctrl);
+ }
+#endif /* USER_KEYS */
+
+ netif_wake_queue(arPriv->arNetDev);
+
+ /* For CFG80211 the key configuration and the default key comes in after connect so no point in plumbing invalid keys */
+#ifndef ATH6K_CONFIG_CFG80211
+ if ((pEvt->u.infra_ibss_bss.networkType & ADHOC_NETWORK) &&
+ (OPEN_AUTH == arPriv->arDot11AuthMode) &&
+ (WMI_NONE_AUTH == arPriv->arAuthMode) &&
+ (WEP_CRYPT == arPriv->arPairwiseCrypto))
+ {
+ if (!arPriv->arConnected) {
+ wmi_addKey_cmd(arPriv->arWmi,
+ arPriv->arDefTxKeyIndex,
+ WEP_CRYPT,
+ GROUP_USAGE | TX_USAGE,
+ arPriv->arWepKeyList[arPriv->arDefTxKeyIndex].arKeyLen,
+ NULL,
+ arPriv->arWepKeyList[arPriv->arDefTxKeyIndex].arKey, KEY_OP_INIT_VAL, NULL,
+ NO_SYNC_WMIFLAG);
+ }
+ }
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ /* Update connect & link status atomically */
+ spin_lock_irqsave(&arPriv->arPrivLock, flags);
+ netif_carrier_on(arPriv->arNetDev);
+ spin_unlock_irqrestore(&arPriv->arPrivLock, flags);
+ /* reset the rx aggr state */
+ aggr_reset_state(arPriv->conn_aggr, (void *) arPriv->arNetDev);
+ reconnect_flag = 0;
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ A_MEMCPY(wrqu.addr.sa_data, bssid, IEEE80211_ADDR_LEN);
+ wrqu.addr.sa_family = ARPHRD_ETHER;
+ wireless_send_event(arPriv->arNetDev, SIOCGIWAP, &wrqu, NULL);
+ if ((arPriv->arNetworkType == ADHOC_NETWORK) && arSta->arIbssPsEnable) {
+ A_MEMZERO(arSta->arNodeMap, sizeof(arSta->arNodeMap));
+ arSta->arNodeNum = 0;
+ arSta->arNexEpId = ENDPOINT_2;
+ }
+ if (!arSta->arUserBssFilter) {
+ wmi_bssfilter_cmd(arPriv->arWmi, NONE_BSS_FILTER, 0);
+ }
+}
+
+void ar6000_set_numdataendpts(AR_SOFTC_DEV_T *arPriv, A_UINT32 num)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_ASSERT(num <= (HTC_MAILBOX_NUM_MAX - 1));
+ ar->arNumDataEndPts = num;
+}
+
+void
+sta_cleanup(AR_SOFTC_DEV_T *arPriv, A_UINT8 i)
+{
+ struct sk_buff *skb;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+
+ /* empty the queued pkts in the PS queue if any */
+ A_MUTEX_LOCK(&ar->connTbl[i].psqLock);
+ while (!A_NETBUF_QUEUE_EMPTY(&ar->connTbl[i].psq)) {
+ skb = A_NETBUF_DEQUEUE(&ar->connTbl[i].psq);
+ A_NETBUF_FREE(skb);
+ }
+ while (!A_NETBUF_QUEUE_EMPTY(&ar->connTbl[i].apsdq)) {
+ skb = A_NETBUF_DEQUEUE(&ar->connTbl[i].apsdq);
+ A_NETBUF_FREE(skb);
+ }
+ A_MUTEX_UNLOCK(&ar->connTbl[i].psqLock);
+#ifdef P2P
+ if((arPriv->arNetworkSubType == SUBTYPE_P2PGO) && (arPriv->num_sta <= get_connected_sta_cnt(arPriv))) {
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv), P2P_GROUP_CAPAB_GROUP_LIMIT,0);
+ }
+#endif
+
+ /* Zero out the state fields */
+ A_MEMZERO(&ar->arAPStats[i], sizeof(WMI_PER_STA_STAT));
+ A_MEMZERO(&ar->connTbl[i].mac, ATH_MAC_LEN);
+ A_MEMZERO(&ar->connTbl[i].wpa_ie, IEEE80211_MAX_IE);
+ ar->connTbl[i].aid = 0;
+ ar->connTbl[i].flags = 0;
+ ar->connTbl[i].arPriv = NULL;
+ ar->connTbl[i].HT_present = 0;
+
+ arAp->sta_list_index =arAp->sta_list_index & ~(1 << i);
+ aggr_reset_state(ar->connTbl[i].conn_aggr, NULL);
+}
+
+void
+ar6000_ap_cleanup(AR_SOFTC_DEV_T *arPriv)
+{
+ A_UINT8 ctr;
+ struct sk_buff *skb;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("DEL ALL STA\n"));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AP%d: [DOWN] SSID %s\n", arPriv->arDeviceIndex, arPriv->arSsid));
+
+// AP + BTCOEX State variables resetted here.
+ ar->IsdelbaTimerInitialized = FALSE;
+ A_UNTIMEOUT(&ar->delbaTimer);
+ ar->delbaState = REASON_DELBA_INIT;
+
+ for (ctr=0; ctr < NUM_CONN; ctr++) {
+ if(ar->connTbl[ctr].arPriv == arPriv) {
+ remove_sta(arPriv, ar->connTbl[ctr].mac, 0);
+ }
+ }
+ A_MUTEX_LOCK(&arAp->mcastpsqLock);
+ while (!A_NETBUF_QUEUE_EMPTY(&arAp->mcastpsq)) {
+ skb = A_NETBUF_DEQUEUE(&arAp->mcastpsq);
+ A_NETBUF_FREE(skb);
+ }
+ A_MUTEX_UNLOCK(&arAp->mcastpsqLock);
+ arPriv->arConnected = FALSE;
+ arPriv->arTxPwr = 0;
+ arPriv->arTxPwrSet = FALSE;
+}
+
+A_UINT8
+remove_sta(AR_SOFTC_DEV_T *arPriv, A_UINT8 *mac, A_UINT16 reason)
+{
+ A_UINT8 i, removed=0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ union iwreq_data wrqu;
+ struct sk_buff *skb;
+
+ if(IS_MAC_NULL(mac)) {
+ return removed;
+ }
+
+ if(reason == AP_DISCONNECT_MAX_STA) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("MAX STA %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x\n", mac[0],
+ mac[1], mac[2], mac[3], mac[4], mac[5]));
+ return removed;
+ } else if(reason == AP_DISCONNECT_ACL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ACL STA %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x\n", mac[0],
+ mac[1], mac[2], mac[3], mac[4], mac[5]));
+ return removed;
+ }
+
+ for(i=0; i < NUM_CONN; i++) {
+ if(A_MEMCMP(ar->connTbl[i].mac, mac, ATH_MAC_LEN)==0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("DEL STA %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x "
+ " aid=%d REASON=%d\n", mac[0], mac[1], mac[2],
+ mac[3], mac[4], mac[5], ar->connTbl[i].aid, reason));
+
+ sta_cleanup(arPriv, i);
+ removed = 1;
+
+ /* Send event to application */
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ A_MEMCPY(wrqu.addr.sa_data, mac, ATH_MAC_LEN);
+ wireless_send_event(arPriv->arNetDev, IWEVEXPIRED, &wrqu, NULL);
+
+ break;
+ }
+ }
+
+ /* If there are no more associated STAs, empty the mcast PS q */
+ if (arPriv->arAp.sta_list_index == 0) {
+ A_MUTEX_LOCK(&arPriv->arAp.mcastpsqLock);
+ while (!A_NETBUF_QUEUE_EMPTY(&arPriv->arAp.mcastpsq)) {
+ skb = A_NETBUF_DEQUEUE(&arPriv->arAp.mcastpsq);
+ A_NETBUF_FREE(skb);
+ }
+ A_MUTEX_UNLOCK(&arPriv->arAp.mcastpsqLock);
+
+ /* Clear the LSB of the BitMapCtl field of the TIM IE */
+ if (ar->arWmiReady) {
+ wmi_set_pvb_cmd(arPriv->arWmi, MCAST_AID, 0);
+ }
+ }
+
+ return removed;
+}
+
+void
+ar6000_disconnect_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 reason, A_UINT8 *bssid,
+ A_UINT8 assocRespLen, A_UINT8 *assocInfo, A_UINT16 protocolReasonStatus)
+{
+ A_UINT8 i;
+ unsigned long flags;
+ union iwreq_data wrqu;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_BOOL bt30Devfound = FALSE;
+#ifdef P2P
+ if((arPriv->arNetworkSubType == SUBTYPE_P2PCLIENT) || (arPriv->arNetworkSubType == SUBTYPE_P2PGO)
+ || (arPriv->arNetworkSubType == SUBTYPE_P2PDEV)){
+ if(!(IS_MAC_BCAST(bssid)))
+ p2p_clear_group_peer(arPriv->p2p_ctx);
+ }
+#endif
+
+ if(arPriv->arNetworkType & AP_NETWORK) {
+ if(IS_MAC_BCAST(bssid)) {
+ A_UINT32 tmp_regCode;
+
+ tmp_regCode = arPriv->arRegCode;
+ if(protocolReasonStatus != AP_DISCONNECT_STA_ROAM) {
+ arPriv->arBssChannel = 0;
+ arPriv->arChannelHint = 0;
+ } else {
+ arPriv->is_sta_roaming = TRUE;
+ }
+ ar6000_ap_cleanup(arPriv);
+ arPriv->arRegCode = tmp_regCode;
+
+ /* Concurrency: Process the pending connect of the other virtual device(s) */
+ ar6000_check_hold_conn_status(arPriv, FALSE);
+
+ if ((protocolReasonStatus == AP_DISCONNECT_STA_ROAM) || (protocolReasonStatus == AP_DISCONNECT_DFS_CHANNEL)) {
+ ar->arHoldConnection |= (1<<arPriv->arDeviceIndex);
+ arPriv->ap_profile_flag = TRUE;
+ }
+
+#ifdef P2P
+ if(arPriv->arNetworkSubType == SUBTYPE_P2PGO) {
+ arPriv->arNextMode = INFRA_NETWORK;
+ ar6000_init_mode_info(arPriv);
+ arPriv->arNetworkType = INFRA_NETWORK;
+ arPriv->arNetworkSubType = SUBTYPE_P2PDEV;
+ p2p_update_capability(A_WMI_GET_P2P_CTX(arPriv),arPriv->arNetworkSubType,num_device);
+ }
+#endif
+ } else {
+ remove_sta(arPriv, bssid, protocolReasonStatus);
+ }
+ return;
+ }
+
+#ifdef ATH6K_CONFIG_CFG80211
+ ar6k_cfg80211_disconnect_event(arPriv, reason, bssid,
+ assocRespLen, assocInfo,
+ protocolReasonStatus);
+#endif /* ATH6K_CONFIG_CFG80211 */
+ /*Skip DISCONNECT event for host intaitated Diconnect cmd*/
+ if((!arPriv->arSta.arHostDisconnect) || (protocolReasonStatus != 0)) {
+ /* Send disconnect event to supplicant */
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.addr.sa_family = ARPHRD_ETHER;
+ wireless_send_event(arPriv->arNetDev, SIOCGIWAP, &wrqu, NULL);
+ }
+
+ /* it is necessary to clear the host-side rx aggregation state */
+ aggr_reset_state(arPriv->conn_aggr, NULL);
+
+ A_UNTIMEOUT(&arPriv->arSta.disconnect_timer);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 disconnected"));
+ if (bssid[0] || bssid[1] || bssid[2] || bssid[3] || bssid[4] || bssid[5]) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,(" from %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x ",
+ bssid[0], bssid[1], bssid[2], bssid[3], bssid[4], bssid[5]));
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Disconnect Reason is %d, Status Code is %d", reason, protocolReasonStatus));
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\nDisconnect Reason is %d", reason));
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\nProtocol Reason/Status Code is %d", protocolReasonStatus));
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\nAssocResp Frame = %s",
+ assocRespLen ? " " : "NULL"));
+ for (i = 0; i < assocRespLen; i++) {
+ if (!(i % 0x10)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\n"));
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("%2.2x ", assocInfo[i]));
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("\n"));
+ /*
+ * If the event is due to disconnect cmd from the host, only they the target
+ * would stop trying to connect. Under any other condition, target would
+ * keep trying to connect.
+ *
+ */
+ if( reason == DISCONNECT_CMD)
+ {
+ if ((!arPriv->arSta.arUserBssFilter) && (ar->arWmiReady) && (ar->arWlanState != WLAN_DISABLED)) {
+ wmi_bssfilter_cmd(arPriv->arWmi, NONE_BSS_FILTER, 0);
+ }
+ } else {
+ arPriv->arSta.arConnectPending = TRUE;
+ if (((reason == ASSOC_FAILED) && (protocolReasonStatus == 0x11)) ||
+ ((reason == ASSOC_FAILED) && (protocolReasonStatus == 0x0) && (reconnect_flag == 1))) {
+ arPriv->arConnected = TRUE;
+ return;
+ }
+ }
+
+ /* In the case of p2p-client, if we get a NO_NETWORK_AVAIL or LOST_LINK reason from the
+ * firmware, issue a wmi_disconnect_cmd to the firmware to reset the firmware back to p2p-dev
+ * state.
+ */
+#ifdef P2P
+ if ((arPriv->arNetworkSubType == SUBTYPE_P2PCLIENT) &&
+ (reason == NO_NETWORK_AVAIL || reason == LOST_LINK) ) {
+ ar6000_disconnect(arPriv);
+ }
+#endif /* P2P */
+
+ if (((reason == NO_NETWORK_AVAIL) || (reason == LOST_LINK)) && (ar->arWmiReady))
+ {
+ bss_t *pWmiSsidnode = NULL;
+ wmi_scan_report_lock(arPriv->arWmi);
+ /* remove the current associated bssid node */
+ wmi_free_node (arPriv->arWmi, bssid);
+
+ /*
+ * In case any other same SSID nodes are present
+ * remove it, since those nodes also not available now
+ */
+ do
+ {
+ /*
+ * Find the nodes based on SSID and remove it
+ * NOTE :: This case will not work out for Hidden-SSID
+ */
+ pWmiSsidnode = wmi_find_Ssidnode (arPriv->arWmi, arPriv->arSsid, arPriv->arSsidLen, FALSE, TRUE);
+
+ if (pWmiSsidnode)
+ {
+ wmi_free_node (arPriv->arWmi, pWmiSsidnode->ni_macaddr);
+ }
+
+ }while (pWmiSsidnode);
+ wmi_scan_report_unlock(arPriv->arWmi);
+
+ ar6000_init_profile_info(arPriv);
+ wmi_disconnect_cmd(arPriv->arWmi);
+ }
+
+ /* Update connect & link status atomically */
+ spin_lock_irqsave(&arPriv->arPrivLock, flags);
+
+ netif_carrier_off(arPriv->arNetDev);
+ spin_unlock_irqrestore(&arPriv->arPrivLock, flags);
+#ifdef P2P
+ if(arPriv->arNetworkSubType == SUBTYPE_P2PCLIENT) {
+ arPriv->arNextMode = INFRA_NETWORK;
+ ar6000_init_mode_info(arPriv);
+ arPriv->arNetworkType = INFRA_NETWORK;
+ arPriv->arNetworkSubType = SUBTYPE_P2PDEV;
+ p2p_update_capability(A_WMI_GET_P2P_CTX(arPriv),arPriv->arNetworkSubType,num_device);
+ }
+#endif
+
+ if( (reason != CSERV_DISCONNECT) || (reconnect_flag != 1) ) {
+ reconnect_flag = 0;
+ }
+
+#ifdef USER_KEYS
+ if (reason != CSERV_DISCONNECT)
+ {
+ arPriv->arSta.user_savedkeys_stat = USER_SAVEDKEYS_STAT_INIT;
+ arPriv->arSta.user_key_ctrl = 0;
+ }
+#endif /* USER_KEYS */
+
+ netif_stop_queue(arPriv->arNetDev);
+ A_MEMZERO(arPriv->arBssid, sizeof(arPriv->arBssid));
+ arPriv->arBssChannel = 0;
+ arPriv->arSta.arBeaconInterval = 0;
+ arPriv->arConnected = FALSE;
+ arPriv->arChannelHint = 0;
+ arPriv->arTxPwr = 0;
+ arPriv->arTxPwrSet = FALSE;
+
+ /* Concurrency: Process the pending connect of the other virtual device(s) */
+ ar6000_check_hold_conn_status(arPriv, FALSE);
+
+ for (i=0; i < num_device; i++) {
+ AR_SOFTC_DEV_T *temparPriv;
+ temparPriv = ar->arDev[i];
+ if (temparPriv->isBt30amp == TRUE) {
+ bt30Devfound = TRUE;
+ }
+ }
+ if (bt30Devfound == FALSE) {
+ ar6000_TxDataCleanup(ar);
+ }
+
+ if (arPriv->arNetworkType == ADHOC_NETWORK){
+ /* Reset Scan params to default */
+ wmi_scanparams_cmd(arPriv->arWmi, 0, 0,
+ 60, 0, 0, 0, WMI_SHORTSCANRATIO_DEFAULT,DEFAULT_SCAN_CTRL_FLAGS, 0, 0);
+ }
+}
+
+void
+ar6000_regDomain_event(AR_SOFTC_DEV_T *arPriv, A_UINT32 regCode)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 Reg Code = 0x%x\n", regCode));
+ arPriv->arRegCode = regCode;
+}
+
+#ifdef ATH_AR6K_11N_SUPPORT
+#define BA_EVT_GET_CONNID(a) ((a)>>4)
+#define BA_EVT_GET_TID(b) ((b)&0xF)
+
+void
+ar6000_aggr_rcv_addba_req_evt(AR_SOFTC_DEV_T *arPriv, WMI_ADDBA_REQ_EVENT *evt)
+{
+ A_UINT8 connid = BA_EVT_GET_CONNID(evt->tid);
+ A_UINT8 tid = BA_EVT_GET_TID(evt->tid);
+ conn_t *conn = ieee80211_find_conn_for_aid(arPriv, connid);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ADDBA REQ: tid=%d, connid=%d, status=%d, win_sz=%d\n", tid, connid, evt->status, evt->win_sz));
+ if(((arPriv->arNetworkType == INFRA_NETWORK) || (conn != NULL)) && evt->status == 0) {
+ aggr_recv_addba_req_evt(get_aggr_ctx(arPriv, conn), tid, evt->st_seq_no, evt->win_sz);
+ }
+}
+
+void
+ar6000_aggr_rcv_addba_resp_evt(AR_SOFTC_DEV_T *arPriv, WMI_ADDBA_RESP_EVENT *evt)
+{
+ A_UINT8 connid = BA_EVT_GET_CONNID(evt->tid);
+ A_UINT8 tid = BA_EVT_GET_TID(evt->tid);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ADDBA RSP: tid=%d, connid=%d, status=%d, sz=%d\n", tid, connid, evt->status, evt->amsdu_sz));
+ if(evt->status == 0) {
+ }
+}
+
+void
+ar6000_aggr_rcv_delba_req_evt(AR_SOFTC_DEV_T *arPriv, WMI_DELBA_EVENT *evt)
+{
+ A_UINT8 connid = BA_EVT_GET_CONNID(evt->tid);
+ A_UINT8 tid = BA_EVT_GET_TID(evt->tid);
+ conn_t *conn = ieee80211_find_conn_for_aid(arPriv, connid);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("DELBA REQ: tid=%d, connid=%d\n", tid, connid));
+ if(((arPriv->arNetworkType == INFRA_NETWORK) || (conn != NULL)) && (!evt->is_peer_initiator)) {
+ aggr_recv_delba_req_evt(get_aggr_ctx(arPriv, conn), tid);
+ }
+}
+#endif
+
+void register_pal_cb(ar6k_pal_config_t *palConfig_p)
+{
+ ar6k_pal_config_g = *palConfig_p;
+}
+
+void
+ar6000_hci_event_rcv_evt(AR_SOFTC_DEV_T *arPriv, WMI_HCI_EVENT *cmd)
+{
+ void *osbuf = NULL;
+ A_INT8 i;
+ A_UINT8 size, *buf;
+ A_STATUS ret = A_OK;
+
+ size = cmd->evt_buf_sz + 4;
+ osbuf = A_NETBUF_ALLOC(size);
+ if (osbuf == NULL) {
+ ret = A_NO_MEMORY;
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Error in allocating netbuf \n"));
+ return;
+ }
+
+ A_NETBUF_PUT(osbuf, size);
+ buf = (A_UINT8 *)A_NETBUF_DATA(osbuf);
+ /* First 2-bytes carry HCI event/ACL data type
+ * the next 2 are free
+ */
+ *((short *)buf) = WMI_HCI_EVENT_EVENTID;
+ buf += sizeof(int);
+ A_MEMCPY(buf, cmd->buf, cmd->evt_buf_sz);
+
+ if(ar6k_pal_config_g.fpar6k_pal_recv_pkt)
+ {
+ /* pass the cmd packet to PAL driver */
+ if((*ar6k_pal_config_g.fpar6k_pal_recv_pkt)(arPriv->hcipal_info, osbuf) == TRUE)
+ return;
+ }
+ ar6000_deliver_frames_to_nw_stack(arPriv->arNetDev, osbuf);
+ if(loghci) {
+ A_PRINTF_LOG("HCI Event From PAL <-- \n");
+ for(i = 0; i < cmd->evt_buf_sz; i++) {
+ A_PRINTF_LOG("0x%02x ", cmd->buf[i]);
+ if((i % 10) == 0) {
+ A_PRINTF_LOG("\n");
+ }
+ }
+ A_PRINTF_LOG("\n");
+ A_PRINTF_LOG("==================================\n");
+ }
+}
+
+void
+ar6000_neighborReport_event(AR_SOFTC_DEV_T *arPriv, int numAps, WMI_NEIGHBOR_INFO *info)
+{
+#if WIRELESS_EXT >= 18
+ struct iw_pmkid_cand *pmkcand;
+#else /* WIRELESS_EXT >= 18 */
+ static const char *tag = "PRE-AUTH";
+ char buf[128];
+#endif /* WIRELESS_EXT >= 18 */
+
+ union iwreq_data wrqu;
+ int i;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 Neighbor Report Event\n"));
+ for (i=0; i < numAps; info++, i++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("bssid %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x ",
+ info->bssid[0], info->bssid[1], info->bssid[2],
+ info->bssid[3], info->bssid[4], info->bssid[5]));
+ if (info->bssFlags & WMI_PREAUTH_CAPABLE_BSS) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("preauth-cap"));
+ }
+ if (info->bssFlags & WMI_PMKID_VALID_BSS) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,(" pmkid-valid\n"));
+ continue; /* we skip bss if the pmkid is already valid */
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\n"));
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+#if WIRELESS_EXT >= 18
+ pmkcand = A_MALLOC_NOWAIT(sizeof(struct iw_pmkid_cand));
+ A_MEMZERO(pmkcand, sizeof(struct iw_pmkid_cand));
+ pmkcand->index = i;
+ pmkcand->flags = info->bssFlags;
+ A_MEMCPY(pmkcand->bssid.sa_data, info->bssid, ATH_MAC_LEN);
+ wrqu.data.length = sizeof(struct iw_pmkid_cand);
+ wireless_send_event(arPriv->arNetDev, IWEVPMKIDCAND, &wrqu, (char *)pmkcand);
+ A_FREE(pmkcand);
+#else /* WIRELESS_EXT >= 18 */
+ snprintf(buf, sizeof(buf), "%s%2.2x%2.2x%2.2x%2.2x%2.2x%2.2x%2.2x%2.2x",
+ tag,
+ info->bssid[0], info->bssid[1], info->bssid[2],
+ info->bssid[3], info->bssid[4], info->bssid[5],
+ i, info->bssFlags);
+ wrqu.data.length = strlen(buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+#endif /* WIRELESS_EXT >= 18 */
+ }
+}
+
+void
+ar6000_indicate_proberesp(AR_SOFTC_DEV_T *arPriv , A_UINT8* pData , A_UINT16 len ,A_UINT8* bssid)
+{
+}
+
+void
+ar6000_indicate_beacon(AR_SOFTC_DEV_T *arPriv, A_UINT8* pData , A_UINT16 len ,A_UINT8* bssid)
+{
+}
+
+void
+ar6000_assoc_req_report_event (void *context, A_UINT8 status, A_UINT8 rspType, A_UINT8* pData, int len)
+{
+}
+
+#ifdef ATH_SUPPORT_DFS
+
+void ar6000_dfs_attach_event(AR_SOFTC_DEV_T *arPriv, WMI_DFS_HOST_ATTACH_EVENT *capinfo)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ arAp->pDfs = dfs_attach_host(arPriv, NULL, capinfo);
+ if(arAp->pDfs)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\nDFS host attached\n"));
+ }
+ else
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\nDFS host ptr NULL\n"));
+ }
+}
+
+void ar6000_dfs_init_event(AR_SOFTC_DEV_T *arPriv, WMI_DFS_HOST_INIT_EVENT *info)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_init_radar_filters_host(arAp->pDfs, info);
+}
+
+void ar6000_dfs_phyerr_event(AR_SOFTC_DEV_T *arPriv, WMI_DFS_PHYERR_EVENT *info)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_process_phyerr_host(arAp->pDfs, info);
+}
+
+void ar6000_dfs_reset_delaylines_event(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_reset_alldelaylines(arAp->pDfs);
+}
+
+void ar6000_dfs_reset_radarq_event(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_reset_radarq(arAp->pDfs);
+}
+
+void ar6000_dfs_reset_ar_event(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_reset_ar(arAp->pDfs);
+}
+
+void ar6000_dfs_reset_arq_event(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_reset_arq(arAp->pDfs);
+}
+
+void ar6000_dfs_set_dur_multiplier_event(AR_SOFTC_DEV_T *arPriv, A_UINT32 value)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_set_dur_multiplier(arAp->pDfs, value);
+}
+
+void ar6000_dfs_set_bangradar_event(AR_SOFTC_DEV_T *arPriv, A_UINT32 value)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_bangradar_enable(arAp->pDfs, value);
+}
+
+void ar6000_dfs_set_debuglevel_event(AR_SOFTC_DEV_T *arPriv, A_UINT32 value)
+{
+ AR_SOFTC_AP_T *arAp=&arPriv->arAp;
+ dfs_set_debug_level_host(arAp->pDfs, value);
+}
+
+A_STATUS ar6000_dfs_set_maxpulsedur_cmd(AR_SOFTC_DEV_T *arPriv, A_UINT32 value)
+{
+ return wmi_set_dfs_maxpulsedur_cmd(arPriv->arWmi, value);
+}
+
+A_STATUS ar6000_dfs_radar_detected_cmd(AR_SOFTC_DEV_T *arPriv, A_INT16 chan_index, A_INT8 bang_radar)
+{
+ return wmi_radarDetected_cmd(arPriv->arWmi, chan_index, bang_radar);
+}
+
+A_STATUS ar6000_dfs_set_minrssithresh_cmd(AR_SOFTC_DEV_T *arPriv, A_INT32 rssi)
+{
+ return wmi_set_dfs_minrssithresh_cmd(arPriv->arWmi, rssi);
+}
+
+#endif /* ATH_SUPPORT_DFS */
+
+void
+ar6000_tkip_micerr_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 keyid, A_BOOL ismcast)
+{
+ static const char *tag = "MLME-MICHAELMICFAILURE.indication";
+ char buf[128];
+ union iwreq_data wrqu;
+
+ /*
+ * For AP case, keyid will have aid of STA which sent pkt with
+ * MIC error. Use this aid to get MAC & send it to hostapd.
+ */
+ if (arPriv->arNetworkType == AP_NETWORK) {
+ conn_t *s = ieee80211_find_conn_for_aid(arPriv, (keyid >> 2));
+ if(!s){
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("AP TKIP MIC error received from Invalid aid / STA not found =%d\n", keyid));
+ return;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("AP TKIP MIC error received from aid=%d\n", keyid));
+ snprintf(buf,sizeof(buf), "%s addr=%2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x",
+ tag, s->mac[0],s->mac[1],s->mac[2],s->mac[3],s->mac[4],s->mac[5]);
+ } else {
+
+#ifdef ATH6K_CONFIG_CFG80211
+ ar6k_cfg80211_tkip_micerr_event(arPriv, keyid, ismcast);
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("AR6000 TKIP MIC error received for keyid %d %scast\n",
+ keyid & 0x3, ismcast ? "multi": "uni"));
+ snprintf(buf, sizeof(buf), "%s(keyid=%d %sicast)", tag, keyid & 0x3,
+ ismcast ? "mult" : "un");
+ }
+
+ memset(&wrqu, 0, sizeof(wrqu));
+ wrqu.data.length = strlen(buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+void
+ar6000_scanComplete_event(AR_SOFTC_DEV_T *arPriv, A_STATUS status)
+{
+
+#ifdef ATH6K_CONFIG_CFG80211
+ ar6k_cfg80211_scanComplete_event(arPriv, status);
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+ if ((arPriv->arSoftc->arWmiReady) && (arPriv->arWmiEnabled) && (arPriv->arSoftc->arWlanState==WLAN_ENABLED)) {
+ if (!arPriv->arSta.arUserBssFilter) {
+ wmi_bssfilter_cmd(arPriv->arWmi, NONE_BSS_FILTER, 0);
+ }
+ }
+ if (arPriv->arSta.scan_triggered) {
+ union iwreq_data wrqu;
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wireless_send_event(arPriv->arNetDev, SIOCGIWSCAN, &wrqu, NULL);
+ arPriv->arSta.scan_triggered = 0;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,( "AR6000 scan complete: %d\n", status));
+ wake_up_interruptible(&scan_complete);
+}
+
+void
+ar6000_targetStats_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 *ptr, A_UINT32 len)
+{
+ A_UINT8 ac, i;
+
+ if(arPriv->arNetworkType == AP_NETWORK) {
+ WMI_AP_MODE_STAT *p = (WMI_AP_MODE_STAT *)ptr;
+ WMI_PER_STA_STAT *ap = arPriv->arSoftc->arAPStats;
+
+ if (len < sizeof(*p)) {
+ return;
+ }
+
+ for(ac=0;ac<AP_MAX_NUM_STA;ac++) {
+ if(p->sta[ac].aid == 0) {
+ continue;
+ }
+ i = p->sta[ac].aid-1;
+
+ ap[i].tx_bytes += p->sta[ac].tx_bytes;
+ ap[i].tx_pkts += p->sta[ac].tx_pkts;
+ ap[i].tx_error += p->sta[ac].tx_error;
+ ap[i].tx_discard += p->sta[ac].tx_discard;
+ ap[i].rx_bytes += p->sta[ac].rx_bytes;
+ ap[i].rx_pkts += p->sta[ac].rx_pkts;
+ ap[i].rx_error += p->sta[ac].rx_error;
+ ap[i].rx_discard += p->sta[ac].rx_discard;
+ }
+ } else {
+ WMI_TARGET_STATS *pTarget = (WMI_TARGET_STATS *)ptr;
+ TARGET_STATS *pStats = &arPriv->arTargetStats;
+
+ if (len < sizeof(*pTarget)) {
+ return;
+ }
+
+ // Update the RSSI of the connected bss.
+ if (arPriv->arConnected) {
+ bss_t *pConnBss = NULL;
+ wmi_scan_report_lock(arPriv->arWmi);
+
+ pConnBss = wmi_find_node(arPriv->arWmi,arPriv->arBssid);
+ if (pConnBss)
+ {
+ pConnBss->ni_rssi = pTarget->cservStats.cs_aveBeacon_rssi;
+ pConnBss->ni_snr = pTarget->cservStats.cs_aveBeacon_snr;
+ wmi_node_return(arPriv->arWmi, pConnBss);
+ }
+ wmi_scan_report_unlock(arPriv->arWmi);
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 updating target stats\n"));
+ pStats->tx_packets += pTarget->txrxStats.tx_stats.tx_packets;
+ pStats->tx_bytes += pTarget->txrxStats.tx_stats.tx_bytes;
+ pStats->tx_unicast_pkts += pTarget->txrxStats.tx_stats.tx_unicast_pkts;
+ pStats->tx_unicast_bytes += pTarget->txrxStats.tx_stats.tx_unicast_bytes;
+ pStats->tx_multicast_pkts += pTarget->txrxStats.tx_stats.tx_multicast_pkts;
+ pStats->tx_multicast_bytes += pTarget->txrxStats.tx_stats.tx_multicast_bytes;
+ pStats->tx_broadcast_pkts += pTarget->txrxStats.tx_stats.tx_broadcast_pkts;
+ pStats->tx_broadcast_bytes += pTarget->txrxStats.tx_stats.tx_broadcast_bytes;
+ pStats->tx_rts_success_cnt += pTarget->txrxStats.tx_stats.tx_rts_success_cnt;
+ for(ac = 0; ac < WMM_NUM_AC; ac++)
+ pStats->tx_packet_per_ac[ac] += pTarget->txrxStats.tx_stats.tx_packet_per_ac[ac];
+ pStats->tx_errors += pTarget->txrxStats.tx_stats.tx_errors;
+ pStats->tx_failed_cnt += pTarget->txrxStats.tx_stats.tx_failed_cnt;
+ pStats->tx_retry_cnt += pTarget->txrxStats.tx_stats.tx_retry_cnt;
+ pStats->tx_mult_retry_cnt += pTarget->txrxStats.tx_stats.tx_mult_retry_cnt;
+ pStats->tx_rts_fail_cnt += pTarget->txrxStats.tx_stats.tx_rts_fail_cnt;
+ pStats->tx_unicast_rate = wmi_get_rate(pTarget->txrxStats.tx_stats.tx_unicast_rate);
+
+ pStats->rx_packets += pTarget->txrxStats.rx_stats.rx_packets;
+ pStats->rx_bytes += pTarget->txrxStats.rx_stats.rx_bytes;
+ pStats->rx_unicast_pkts += pTarget->txrxStats.rx_stats.rx_unicast_pkts;
+ pStats->rx_unicast_bytes += pTarget->txrxStats.rx_stats.rx_unicast_bytes;
+ pStats->rx_multicast_pkts += pTarget->txrxStats.rx_stats.rx_multicast_pkts;
+ pStats->rx_multicast_bytes += pTarget->txrxStats.rx_stats.rx_multicast_bytes;
+ pStats->rx_broadcast_pkts += pTarget->txrxStats.rx_stats.rx_broadcast_pkts;
+ pStats->rx_broadcast_bytes += pTarget->txrxStats.rx_stats.rx_broadcast_bytes;
+ pStats->rx_fragment_pkt += pTarget->txrxStats.rx_stats.rx_fragment_pkt;
+ pStats->rx_errors += pTarget->txrxStats.rx_stats.rx_errors;
+ pStats->rx_crcerr += pTarget->txrxStats.rx_stats.rx_crcerr;
+ pStats->rx_key_cache_miss += pTarget->txrxStats.rx_stats.rx_key_cache_miss;
+ pStats->rx_decrypt_err += pTarget->txrxStats.rx_stats.rx_decrypt_err;
+ pStats->rx_duplicate_frames += pTarget->txrxStats.rx_stats.rx_duplicate_frames;
+ pStats->rx_unicast_rate = wmi_get_rate(pTarget->txrxStats.rx_stats.rx_unicast_rate);
+
+
+ pStats->tkip_local_mic_failure
+ += pTarget->txrxStats.tkipCcmpStats.tkip_local_mic_failure;
+ pStats->tkip_counter_measures_invoked
+ += pTarget->txrxStats.tkipCcmpStats.tkip_counter_measures_invoked;
+ pStats->tkip_replays += pTarget->txrxStats.tkipCcmpStats.tkip_replays;
+ pStats->tkip_format_errors += pTarget->txrxStats.tkipCcmpStats.tkip_format_errors;
+ pStats->ccmp_format_errors += pTarget->txrxStats.tkipCcmpStats.ccmp_format_errors;
+ pStats->ccmp_replays += pTarget->txrxStats.tkipCcmpStats.ccmp_replays;
+
+ pStats->power_save_failure_cnt += pTarget->pmStats.power_save_failure_cnt;
+ pStats->noise_floor_calibation = pTarget->noise_floor_calibation;
+
+ pStats->cs_bmiss_cnt += pTarget->cservStats.cs_bmiss_cnt;
+ pStats->cs_lowRssi_cnt += pTarget->cservStats.cs_lowRssi_cnt;
+ pStats->cs_connect_cnt += pTarget->cservStats.cs_connect_cnt;
+ pStats->cs_disconnect_cnt += pTarget->cservStats.cs_disconnect_cnt;
+ pStats->cs_aveBeacon_snr = pTarget->cservStats.cs_aveBeacon_snr;
+ pStats->cs_aveBeacon_rssi = pTarget->cservStats.cs_aveBeacon_rssi;
+
+ if (enablerssicompensation) {
+ pStats->cs_aveBeacon_rssi =
+ rssi_compensation_calc(arPriv, pStats->cs_aveBeacon_rssi);
+ }
+ pStats->cs_lastRoam_msec = pTarget->cservStats.cs_lastRoam_msec;
+ pStats->cs_snr = pTarget->cservStats.cs_snr;
+ pStats->cs_rssi = pTarget->cservStats.cs_rssi;
+
+ pStats->lq_val = pTarget->lqVal;
+
+ pStats->wow_num_pkts_dropped += pTarget->wowStats.wow_num_pkts_dropped;
+ pStats->wow_num_host_pkt_wakeups += pTarget->wowStats.wow_num_host_pkt_wakeups;
+ pStats->wow_num_host_event_wakeups += pTarget->wowStats.wow_num_host_event_wakeups;
+ pStats->wow_num_events_discarded += pTarget->wowStats.wow_num_events_discarded;
+ pStats->arp_received += pTarget->arpStats.arp_received;
+ pStats->arp_matched += pTarget->arpStats.arp_matched;
+ pStats->arp_replied += pTarget->arpStats.arp_replied;
+
+ if (arPriv->statsUpdatePending) {
+ arPriv->statsUpdatePending = FALSE;
+ wake_up(&arPriv->arEvent);
+ }
+ }
+}
+
+void
+ar6000_rssiThreshold_event(AR_SOFTC_DEV_T *arPriv, WMI_RSSI_THRESHOLD_VAL newThreshold, A_INT16 rssi)
+{
+ USER_RSSI_THOLD userRssiThold;
+
+ rssi = rssi + SIGNAL_QUALITY_NOISE_FLOOR;
+
+ if (enablerssicompensation) {
+ rssi = rssi_compensation_calc(arPriv, rssi);
+ }
+
+ /* Send an event to the app */
+ userRssiThold.tag = arPriv->arSta.rssi_map[newThreshold].tag;
+ userRssiThold.rssi = rssi;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("rssi Threshold range = %d tag = %d rssi = %d\n", newThreshold,
+ userRssiThold.tag, userRssiThold.rssi));
+
+ ar6000_send_event_to_app(arPriv, WMI_RSSI_THRESHOLD_EVENTID,(A_UINT8 *)&userRssiThold, sizeof(USER_RSSI_THOLD));
+}
+
+
+void
+ar6000_hbChallengeResp_event(AR_SOFTC_DEV_T *arPriv, A_UINT32 cookie, A_UINT32 source)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ if (source == APP_HB_CHALLENGE) {
+ /* Report it to the app in case it wants a positive acknowledgement */
+ ar6000_send_event_to_app(arPriv, WMIX_HB_CHALLENGE_RESP_EVENTID,
+ (A_UINT8 *)&cookie, sizeof(cookie));
+ } else {
+ /* This would ignore the replys that come in after their due time */
+ if (cookie == ar->arHBChallengeResp.seqNum) {
+ ar->arHBChallengeResp.outstanding = FALSE;
+ }
+ }
+}
+
+
+void
+ar6000_reportError_event(AR_SOFTC_DEV_T *arPriv, WMI_TARGET_ERROR_VAL errorVal)
+{
+ char *errString[] = {
+ [WMI_TARGET_PM_ERR_FAIL] "WMI_TARGET_PM_ERR_FAIL",
+ [WMI_TARGET_KEY_NOT_FOUND] "WMI_TARGET_KEY_NOT_FOUND",
+ [WMI_TARGET_DECRYPTION_ERR] "WMI_TARGET_DECRYPTION_ERR",
+ [WMI_TARGET_BMISS] "WMI_TARGET_BMISS",
+ [WMI_PSDISABLE_NODE_JOIN] "WMI_PSDISABLE_NODE_JOIN"
+ };
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("AR6000 Error on Target. Error = 0x%x\n", errorVal));
+
+ /* One error is reported at a time, and errorval is a bitmask */
+ if(errorVal & (errorVal - 1))
+ return;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("AR6000 Error type = "));
+ switch(errorVal)
+ {
+ case WMI_TARGET_PM_ERR_FAIL:
+ case WMI_TARGET_KEY_NOT_FOUND:
+ case WMI_TARGET_DECRYPTION_ERR:
+ case WMI_TARGET_BMISS:
+ case WMI_PSDISABLE_NODE_JOIN:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s\n", errString[errorVal]));
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("INVALID\n"));
+ break;
+ }
+
+}
+
+
+void
+ar6000_cac_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 ac, A_UINT8 cacIndication,
+ A_UINT8 statusCode, A_UINT8 *tspecSuggestion)
+{
+ WMM_TSPEC_IE *tspecIe;
+
+ /*
+ * This is the TSPEC IE suggestion from AP.
+ * Suggestion provided by AP under some error
+ * cases, could be helpful for the host app.
+ * Check documentation.
+ */
+ tspecIe = (WMM_TSPEC_IE *)tspecSuggestion;
+
+ /*
+ * What do we do, if we get TSPEC rejection? One thought
+ * that comes to mind is implictly delete the pstream...
+ */
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 CAC notification. "
+ "AC = %d, cacIndication = 0x%x, statusCode = 0x%x\n",
+ ac, cacIndication, statusCode));
+}
+
+void
+ar6000_channel_change_event(AR_SOFTC_DEV_T *arPriv, A_UINT16 oldChannel,
+ A_UINT16 newChannel)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Channel Change notification\nOld Channel: %d, New Channel: %d\n",
+ oldChannel, newChannel));
+}
+
+#define AR6000_PRINT_BSSID(_pBss) do { \
+ A_PRINTF("%2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x ",\
+ (_pBss)[0],(_pBss)[1],(_pBss)[2],(_pBss)[3],\
+ (_pBss)[4],(_pBss)[5]); \
+} while(0)
+
+void
+ar6000_roam_tbl_event(AR_SOFTC_DEV_T *arPriv, WMI_TARGET_ROAM_TBL *pTbl)
+{
+ A_UINT8 i;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ROAM TABLE NO OF ENTRIES is %d ROAM MODE is %d\n",
+ pTbl->numEntries, pTbl->roamMode));
+ for (i= 0; i < pTbl->numEntries; i++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("[%d]bssid %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x ", i,
+ pTbl->bssRoamInfo[i].bssid[0], pTbl->bssRoamInfo[i].bssid[1],
+ pTbl->bssRoamInfo[i].bssid[2],
+ pTbl->bssRoamInfo[i].bssid[3],
+ pTbl->bssRoamInfo[i].bssid[4],
+ pTbl->bssRoamInfo[i].bssid[5]));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("RSSI %d RSSIDT %d LAST RSSI %d UTIL %d ROAM_UTIL %d"
+ " BIAS %d\n",
+ pTbl->bssRoamInfo[i].rssi,
+ pTbl->bssRoamInfo[i].rssidt,
+ pTbl->bssRoamInfo[i].last_rssi,
+ pTbl->bssRoamInfo[i].util,
+ pTbl->bssRoamInfo[i].roam_util,
+ pTbl->bssRoamInfo[i].bias));
+ }
+}
+
+void
+ar6000_wow_list_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 num_filters, WMI_GET_WOW_LIST_REPLY *wow_reply)
+{
+ A_UINT8 i,j;
+
+ /*Each event now contains exactly one filter, see bug 26613*/
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("WOW pattern %d of %d patterns\n", wow_reply->this_filter_num, wow_reply->num_filters));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("wow mode = %s host mode = %s\n",
+ (wow_reply->wow_mode == 0? "disabled":"enabled"),
+ (wow_reply->host_mode == 1 ? "awake":"asleep")));
+
+
+ /*If there are no patterns, the reply will only contain generic
+ WoW information. Pattern information will exist only if there are
+ patterns present. Bug 26716*/
+
+ /* If this event contains pattern information, display it*/
+ if (wow_reply->this_filter_num) {
+ i=0;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("id=%d size=%d offset=%d\n",
+ wow_reply->wow_filters[i].wow_filter_id,
+ wow_reply->wow_filters[i].wow_filter_size,
+ wow_reply->wow_filters[i].wow_filter_offset));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("wow pattern = "));
+ for (j=0; j< wow_reply->wow_filters[i].wow_filter_size; j++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%2.2x",wow_reply->wow_filters[i].wow_filter_pattern[j]));
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\nwow mask = "));
+ for (j=0; j< wow_reply->wow_filters[i].wow_filter_size; j++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%2.2x",wow_reply->wow_filters[i].wow_filter_mask[j]));
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\n"));
+ }
+}
+
+/*
+ * Report the Roaming related data collected on the target
+ */
+void
+ar6000_display_roam_time(WMI_TARGET_ROAM_TIME *p)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Disconnect Data : BSSID: "));
+ AR6000_PRINT_BSSID(p->disassoc_bssid);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,(" RSSI %d DISASSOC Time %d NO_TXRX_TIME %d\n",
+ p->disassoc_bss_rssi,p->disassoc_time,
+ p->no_txrx_time));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Connect Data: BSSID: "));
+ AR6000_PRINT_BSSID(p->assoc_bssid);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,(" RSSI %d ASSOC Time %d TXRX_TIME %d\n",
+ p->assoc_bss_rssi,p->assoc_time,
+ p->allow_txrx_time));
+}
+
+void
+ar6000_roam_data_event(AR_SOFTC_DEV_T *arPriv, WMI_TARGET_ROAM_DATA *p)
+{
+ switch (p->roamDataType) {
+ case ROAM_DATA_TIME:
+ ar6000_display_roam_time(&p->u.roamTime);
+ break;
+ default:
+ break;
+ }
+}
+
+void
+ar6000_bssInfo_event_rx(AR_SOFTC_DEV_T *arPriv, A_UINT8 *datap, int len)
+{
+ struct sk_buff *skb;
+ WMI_BSS_INFO_HDR *bih = (WMI_BSS_INFO_HDR *)datap;
+
+
+ if (!arPriv->arSta.arMgmtFilter) {
+ return;
+ }
+ if (((arPriv->arSta.arMgmtFilter & IEEE80211_FILTER_TYPE_BEACON) &&
+ (bih->frameType != BEACON_FTYPE)) ||
+ ((arPriv->arSta.arMgmtFilter & IEEE80211_FILTER_TYPE_PROBE_RESP) &&
+ (bih->frameType != PROBERESP_FTYPE)))
+ {
+ return;
+ }
+
+ if ((skb = A_NETBUF_ALLOC_RAW(len)) != NULL) {
+
+ A_NETBUF_PUT(skb, len);
+ A_MEMCPY(A_NETBUF_DATA(skb), datap, len);
+ skb->dev = arPriv->arNetDev;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+ A_MEMCPY(skb_mac_header(skb), A_NETBUF_DATA(skb), 6);
+#else
+ skb->mac.raw = A_NETBUF_DATA(skb);
+#endif
+ skb->ip_summed = CHECKSUM_NONE;
+ skb->pkt_type = PACKET_OTHERHOST;
+ skb->protocol = __constant_htons(0x0019);
+ A_NETIF_RX(skb);
+ }
+}
+
+A_UINT32 wmiSendCmdNum;
+
+A_STATUS
+ar6000_control_tx(void *devt, void *osbuf, HTC_ENDPOINT_ID eid)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_STATUS status = A_OK;
+ struct ar_cookie *cookie = NULL;
+ int i;
+
+#ifdef CONFIG_PM
+ if (ar->arWowState == WLAN_WOW_STATE_SUSPENDED) {
+ return A_EACCES;
+ }
+#endif /* CONFIG_PM */
+ /* take lock to protect ar6000_alloc_cookie() */
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ do {
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_TX,("ar_contrstatus = ol_tx: skb=0x%x, len=0x%x eid =%d\n",
+ (A_UINT32)osbuf, A_NETBUF_LEN(osbuf), eid));
+
+ if (ar->arWMIControlEpFull && (eid == ar->arControlEp)) {
+ /* control endpoint is full, don't allocate resources, we
+ * are just going to drop this packet */
+ cookie = NULL;
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,(" WMI Control EP full, dropping packet : 0x%X, len:%d \n",
+ (A_UINT32)osbuf, A_NETBUF_LEN(osbuf)));
+#ifdef ANDROID_ENV
+ if (++android_epfull_cnt > ANDROID_RELOAD_THRESHOLD_FOR_EP_FULL) {
+ android_send_reload_event(arPriv);
+ android_epfull_cnt = 0;
+ }
+#endif
+ } else {
+ cookie = ar6000_alloc_cookie(ar);
+ }
+
+ if (cookie == NULL) {
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ if(logWmiRawMsgs) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("WMI cmd send, msgNo %d :", wmiSendCmdNum));
+ for(i = 0; i < a_netbuf_to_len(osbuf); i++)
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%x ", ((A_UINT8 *)a_netbuf_to_data(osbuf))[i]));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\n"));
+ }
+
+ wmiSendCmdNum++;
+
+ } while (FALSE);
+
+ if (cookie != NULL) {
+ /* got a structure to send it out on */
+ ar->arTxPending[eid]++;
+
+ if (eid != ar->arControlEp) {
+ ar->arTotalTxDataPending++;
+ }
+
+ /* Increment number of cookies allocated for control packets */
+ ar->arControlCookieCount++;
+ }
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ if (cookie != NULL) {
+ cookie->arc_bp[0] = (A_UINT32)osbuf;
+ cookie->arc_bp[1] = 0;
+ SET_HTC_PACKET_INFO_TX(&cookie->HtcPkt,
+ cookie,
+ A_NETBUF_DATA(osbuf),
+ A_NETBUF_LEN(osbuf),
+ eid,
+ AR6K_CONTROL_PKT_TAG);
+ /* this interface is asynchronous, if there is an error, cleanup will happen in the
+ * TX completion callback */
+ HTCSendPkt(ar->arHtcTarget, &cookie->HtcPkt);
+ status = A_OK;
+ }
+
+ return status;
+}
+
+/* indicate tx activity or inactivity on a WMI stream */
+void ar6000_indicate_tx_activity(void *devt, A_UINT8 TrafficClass, A_BOOL Active)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ HTC_ENDPOINT_ID eid ;
+ int i;
+
+ if (ar->arWmiReady) {
+ eid = arAc2EndpointID(ar, TrafficClass);
+
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+
+ ar->arAcStreamActive[TrafficClass] = Active;
+
+ if (Active) {
+ /* when a stream goes active, keep track of the active stream with the highest priority */
+
+ if (ar->arAcStreamPriMap[TrafficClass] > ar->arHiAcStreamActivePri) {
+ /* set the new highest active priority */
+ ar->arHiAcStreamActivePri = ar->arAcStreamPriMap[TrafficClass];
+ }
+
+ } else {
+ /* when a stream goes inactive, we may have to search for the next active stream
+ * that is the highest priority */
+
+ if (ar->arHiAcStreamActivePri == ar->arAcStreamPriMap[TrafficClass]) {
+
+ /* the highest priority stream just went inactive */
+
+ /* reset and search for the "next" highest "active" priority stream */
+ ar->arHiAcStreamActivePri = 0;
+ for (i = 0; i < WMM_NUM_AC; i++) {
+ if (ar->arAcStreamActive[i]) {
+ if (ar->arAcStreamPriMap[i] > ar->arHiAcStreamActivePri) {
+ /* set the new highest active priority */
+ ar->arHiAcStreamActivePri = ar->arAcStreamPriMap[i];
+ }
+ }
+ }
+ }
+ }
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ } else {
+ /* for mbox ping testing, the traffic class is mapped directly as a stream ID,
+ * see handling of AR6000_XIOCTL_TRAFFIC_ACTIVITY_CHANGE in ioctl.c
+ * convert the stream ID to a endpoint */
+ eid = arAc2EndpointID(ar, TrafficClass);
+ }
+
+ /* notify HTC, this may cause credit distribution changes */
+
+ HTCIndicateActivityChange(ar->arHtcTarget,
+ eid,
+ Active);
+
+}
+
+void
+ar6000_btcoex_config_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 *ptr, A_UINT32 len)
+{
+
+ WMI_BTCOEX_CONFIG_EVENT *pBtcoexConfig = (WMI_BTCOEX_CONFIG_EVENT *)ptr;
+ WMI_BTCOEX_CONFIG_EVENT *pArbtcoexConfig =&arPriv->arBtcoexConfig;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 BTCOEX CONFIG EVENT \n"));
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("received config event\n"));
+ pArbtcoexConfig->btProfileType = pBtcoexConfig->btProfileType;
+ pArbtcoexConfig->linkId = pBtcoexConfig->linkId;
+
+ switch (pBtcoexConfig->btProfileType) {
+ case WMI_BTCOEX_BT_PROFILE_SCO:
+ A_MEMCPY(&pArbtcoexConfig->info.scoConfigCmd, &pBtcoexConfig->info.scoConfigCmd,
+ sizeof(WMI_SET_BTCOEX_SCO_CONFIG_CMD));
+ break;
+ case WMI_BTCOEX_BT_PROFILE_A2DP:
+ A_MEMCPY(&pArbtcoexConfig->info.a2dpConfigCmd, &pBtcoexConfig->info.a2dpConfigCmd,
+ sizeof(WMI_SET_BTCOEX_A2DP_CONFIG_CMD));
+ break;
+ case WMI_BTCOEX_BT_PROFILE_ACLCOEX:
+ A_MEMCPY(&pArbtcoexConfig->info.aclcoexConfig, &pBtcoexConfig->info.aclcoexConfig,
+ sizeof(WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD));
+ break;
+ case WMI_BTCOEX_BT_PROFILE_INQUIRY_PAGE:
+ A_MEMCPY(&pArbtcoexConfig->info.btinquiryPageConfigCmd, &pBtcoexConfig->info.btinquiryPageConfigCmd,
+ sizeof(WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD));
+ break;
+ }
+ if (arPriv->statsUpdatePending) {
+ arPriv->statsUpdatePending = FALSE;
+ wake_up(&arPriv->arEvent);
+ }
+}
+
+void
+ar6000_btcoex_stats_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 *ptr, A_UINT32 len)
+{
+ WMI_BTCOEX_STATS_EVENT *pBtcoexStats = (WMI_BTCOEX_STATS_EVENT *)ptr;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6000 BTCOEX CONFIG EVENT \n"));
+
+ A_MEMCPY(&arPriv->arBtcoexStats, pBtcoexStats, sizeof(WMI_BTCOEX_STATS_EVENT));
+
+ if (arPriv->statsUpdatePending) {
+ arPriv->statsUpdatePending = FALSE;
+ wake_up(&arPriv->arEvent);
+ }
+
+}
+
+void
+ar6000_wacinfo_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 *ptr, A_UINT32 len)
+{
+#ifdef WAC
+ WMI_GET_WAC_INFO *pWacInfo = (WMI_GET_WAC_INFO *)ptr;
+
+ A_MEMCPY(&arPriv->wacInfo, pWacInfo, sizeof(WMI_GET_WAC_INFO));
+
+ if (arPriv->statsUpdatePending) {
+ arPriv->statsUpdatePending = FALSE;
+ wake_up(&arPriv->arEvent);
+ }
+#endif
+}
+
+static int __init
+__ar6000_init_module(void)
+{
+ int status = 0;
+
+ status = ar6000_init_module();
+
+#ifdef CONFIG_PLAT_AMBARELLA
+ if (!status) {
+ ambarella_detect_sd_slot(ambarella_board_generic.wifi_sd_bus,
+ ambarella_board_generic.wifi_sd_slot, 1);
+ }
+#endif
+
+ return status;
+}
+
+static void __exit
+__ar6000_cleanup_module(void)
+{
+ ar6000_cleanup_module();
+#ifdef CONFIG_PLAT_AMBARELLA
+ ambarella_detect_sd_slot(ambarella_board_generic.wifi_sd_bus,
+ ambarella_board_generic.wifi_sd_slot, 0);
+#endif
+}
+
+module_init(__ar6000_init_module);
+module_exit(__ar6000_cleanup_module);
+
+/* Init cookie queue */
+static void
+ar6000_cookie_init(AR_SOFTC_T *ar)
+{
+ A_UINT32 i;
+
+ ar->arCookieList = NULL;
+ ar->arCookieCount = 0;
+
+ A_MEMZERO(s_ar_cookie_mem, sizeof(s_ar_cookie_mem));
+
+ for (i = 0; i < MAX_COOKIE_NUM; i++) {
+ ar6000_free_cookie(ar, &s_ar_cookie_mem[i]);
+ }
+}
+
+/* cleanup cookie queue */
+static void
+ar6000_cookie_cleanup(AR_SOFTC_T *ar)
+{
+ /* It is gone .... */
+ ar->arCookieList = NULL;
+ ar->arCookieCount = 0;
+ ar->arControlCookieCount = 0;
+}
+
+/* Init cookie queue */
+static void
+ar6000_free_cookie(AR_SOFTC_T *ar, struct ar_cookie * cookie)
+{
+ /* Insert first */
+ A_ASSERT(ar != NULL);
+ A_ASSERT(cookie != NULL);
+
+ cookie->arc_list_next = ar->arCookieList;
+ ar->arCookieList = cookie;
+ ar->arCookieCount++;
+}
+
+/* cleanup cookie queue */
+static struct ar_cookie *
+ar6000_alloc_cookie(AR_SOFTC_T *ar)
+{
+ struct ar_cookie *cookie;
+
+ cookie = ar->arCookieList;
+ if(cookie != NULL)
+ {
+ ar->arCookieList = cookie->arc_list_next;
+ ar->arCookieCount--;
+ }
+
+ return cookie;
+}
+
+#ifdef SEND_EVENT_TO_APP
+/*
+ * This function is used to send event which come from taget to
+ * the application. The buf which send to application is include
+ * the event ID and event content.
+ */
+#define EVENT_ID_LEN 2
+void ar6000_send_event_to_app(AR_SOFTC_DEV_T *arPriv, A_UINT16 eventId,
+ A_UINT8 *datap, int len)
+{
+
+#if (WIRELESS_EXT >= 15)
+
+/* note: IWEVCUSTOM only exists in wireless extensions after version 15 */
+
+ char *buf;
+ A_UINT16 size;
+ union iwreq_data wrqu;
+
+ size = len + EVENT_ID_LEN;
+
+ if (size > IW_CUSTOM_MAX) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("WMI event ID : 0x%4.4X, len = %d too big for IWEVCUSTOM (max=%d) \n",
+ eventId, size, IW_CUSTOM_MAX));
+ return;
+ }
+
+ /*Dont send DISCONNECT event to APP for host drv intiated Disconnect cmd*/
+ if((eventId == WMI_DISCONNECT_EVENTID) && arPriv->arSta.arHostDisconnect ) {
+ arPriv->arSta.arHostDisconnect = 0;
+
+ }
+
+ buf = A_MALLOC_NOWAIT(size);
+ if (NULL == buf){
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s: failed to allocate %d bytes\n", __func__, size));
+ return;
+ }
+
+ A_MEMZERO(buf, size);
+ A_MEMCPY(buf, &eventId, EVENT_ID_LEN);
+ A_MEMCPY(buf+EVENT_ID_LEN, datap, len);
+
+ //AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("event ID = %d,len = %d\n",*(A_UINT16*)buf, size));
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = size;
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+ A_FREE(buf);
+
+#ifdef ANDROID_ENV
+ if (eventId == WMI_ERROR_REPORT_EVENTID) {
+ android_send_reload_event(arPriv);
+ }
+#endif /* ANDROID_ENV */
+
+#endif
+
+
+}
+
+/*
+ * This function is used to send events larger than 256 bytes
+ * to the application. The buf which is sent to application
+ * includes the event ID and event content.
+ */
+void ar6000_send_generic_event_to_app(AR_SOFTC_DEV_T *arPriv, A_UINT16 eventId,
+ A_UINT8 *datap, int len)
+{
+
+#if (WIRELESS_EXT >= 18)
+
+/* IWEVGENIE exists in wireless extensions version 18 onwards */
+
+ char *buf;
+ A_UINT16 size;
+ union iwreq_data wrqu;
+
+ size = len + EVENT_ID_LEN;
+
+ if (size > IW_GENERIC_IE_MAX) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("WMI event ID : 0x%4.4X, len = %d too big for IWEVGENIE (max=%d) \n",
+ eventId, size, IW_GENERIC_IE_MAX));
+ return;
+ }
+
+ buf = A_MALLOC_NOWAIT(size);
+ if (NULL == buf){
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("%s: failed to allocate %d bytes\n", __func__, size));
+ return;
+ }
+
+ A_MEMZERO(buf, size);
+ A_MEMCPY(buf, &eventId, EVENT_ID_LEN);
+ A_MEMCPY(buf+EVENT_ID_LEN, datap, len);
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = size;
+ wireless_send_event(arPriv->arNetDev, IWEVGENIE, &wrqu, buf);
+
+ A_FREE(buf);
+
+#endif /* (WIRELESS_EXT >= 18) */
+
+}
+#endif /* SEND_EVENT_TO_APP */
+
+
+void
+ar6000_tx_retry_err_event(void *devt)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Tx retries reach maximum!\n"));
+}
+
+void
+ar6000_snrThresholdEvent_rx(void *devt, WMI_SNR_THRESHOLD_VAL newThreshold, A_UINT8 snr)
+{
+ WMI_SNR_THRESHOLD_EVENT event;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+
+ event.range = newThreshold;
+ event.snr = snr;
+
+ ar6000_send_event_to_app(arPriv, WMI_SNR_THRESHOLD_EVENTID, (A_UINT8 *)&event,
+ sizeof(WMI_SNR_THRESHOLD_EVENT));
+}
+
+void
+ar6000_lqThresholdEvent_rx(void *devt, WMI_LQ_THRESHOLD_VAL newThreshold, A_UINT8 lq)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("lq threshold range %d, lq %d\n", newThreshold, lq));
+}
+
+
+
+A_UINT32
+a_copy_to_user(void *to, const void *from, A_UINT32 n)
+{
+ return(copy_to_user(to, from, n));
+}
+
+A_UINT32
+a_copy_from_user(void *to, const void *from, A_UINT32 n)
+{
+ return(copy_from_user(to, from, n));
+}
+
+
+A_STATUS
+ar6000_get_driver_cfg(struct net_device *dev,
+ A_UINT16 cfgParam,
+ void *result)
+{
+ A_STATUS ret = A_OK;
+
+ switch(cfgParam)
+ {
+ case AR6000_DRIVER_CFG_GET_WLANNODECACHING:
+ *((A_UINT32 *)result) = wlanNodeCaching;
+ break;
+ case AR6000_DRIVER_CFG_LOG_RAW_WMI_MSGS:
+ *((A_UINT32 *)result) = logWmiRawMsgs;
+ break;
+ default:
+ ret = A_EINVAL;
+ break;
+ }
+
+ return ret;
+}
+
+void
+ar6000_keepalive_rx(void *devt, A_UINT8 configured)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)devt;
+
+ arPriv->arSta.arKeepaliveConfigured = configured;
+ wake_up(&arPriv->arEvent);
+}
+
+void
+ar6000_pmkid_list_event(void *devt, A_UINT8 numPMKID, WMI_PMKID *pmkidList,
+ A_UINT8 *bssidList)
+{
+ A_UINT8 i, j;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Number of Cached PMKIDs is %d\n", numPMKID));
+
+ for (i = 0; i < numPMKID; i++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\nBSSID %d ", i));
+ for (j = 0; j < ATH_MAC_LEN; j++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%2.2x", bssidList[j]));
+ }
+ bssidList += (ATH_MAC_LEN + WMI_PMKID_LEN);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("\nPMKID %d ", i));
+ for (j = 0; j < WMI_PMKID_LEN; j++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("%2.2x", pmkidList->pmkid[j]));
+ }
+ pmkidList = (WMI_PMKID *)((A_UINT8 *)pmkidList + ATH_MAC_LEN +
+ WMI_PMKID_LEN);
+ }
+}
+
+void ar6000_pspoll_event(AR_SOFTC_DEV_T *arPriv,A_UINT8 aid)
+{
+ conn_t *conn=NULL;
+ A_BOOL isPsqEmpty = FALSE;
+
+ conn = ieee80211_find_conn_for_aid(arPriv, aid);
+
+ if(!conn) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("PS-POLL from invalid STA\n"));
+ return;
+ }
+
+ /* If the PS q for this STA is not empty, dequeue and send a pkt from
+ * the head of the q. Also update the More data bit in the WMI_DATA_HDR
+ * if there are more pkts for this STA in the PS q. If there are no more
+ * pkts for this STA, update the PVB for this STA.
+ */
+ A_MUTEX_LOCK(&conn->psqLock);
+ isPsqEmpty = A_NETBUF_QUEUE_EMPTY(&conn->psq);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+
+ if (isPsqEmpty) {
+ /* TODO:No buffered pkts for this STA. Send out a NULL data frame */
+ } else {
+ struct sk_buff *skb = NULL;
+
+ A_MUTEX_LOCK(&conn->psqLock);
+ skb = A_NETBUF_DEQUEUE(&conn->psq);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+ /* Set the STA flag to PSPolled, so that the frame will go out */
+ STA_SET_PS_POLLED(conn);
+ ar6000_data_tx(skb, arPriv->arNetDev);
+ STA_CLR_PS_POLLED(conn);
+
+ A_MUTEX_LOCK(&conn->psqLock);
+ isPsqEmpty = A_NETBUF_QUEUE_EMPTY(&conn->psq);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+
+ }
+
+ /* Clear the PVB for this STA if the queue has become empty */
+ if (isPsqEmpty) {
+ wmi_set_pvb_cmd(arPriv->arWmi, conn->aid, 0);
+ }
+}
+
+void ar6000_dtimexpiry_event(AR_SOFTC_DEV_T *arPriv)
+{
+ A_BOOL isMcastQueued = FALSE;
+ struct sk_buff *skb = NULL;
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+
+ /* If there are no associated STAs, ignore the DTIM expiry event.
+ * There can be potential race conditions where the last associated
+ * STA may disconnect & before the host could clear the 'Indicate DTIM'
+ * request to the firmware, the firmware would have just indicated a DTIM
+ * expiry event. The race is between 'clear DTIM expiry cmd' going
+ * from the host to the firmware & the DTIM expiry event happening from
+ * the firmware to the host.
+ */
+ if (arAp->sta_list_index == 0) {
+ return;
+ }
+
+ A_MUTEX_LOCK(&arAp->mcastpsqLock);
+ isMcastQueued = A_NETBUF_QUEUE_EMPTY(&arAp->mcastpsq);
+ A_MUTEX_UNLOCK(&arAp->mcastpsqLock);
+
+ if(isMcastQueued == TRUE) {
+ return;
+ }
+
+ /* Flush the mcast psq to the target */
+ /* Set the STA flag to DTIMExpired, so that the frame will go out */
+ arAp->DTIMExpired = TRUE;
+
+ A_MUTEX_LOCK(&arAp->mcastpsqLock);
+ while (!A_NETBUF_QUEUE_EMPTY(&arAp->mcastpsq)) {
+ skb = A_NETBUF_DEQUEUE(&arAp->mcastpsq);
+ A_MUTEX_UNLOCK(&arAp->mcastpsqLock);
+
+ ar6000_data_tx(skb, arPriv->arNetDev);
+
+ A_MUTEX_LOCK(&arAp->mcastpsqLock);
+ }
+ A_MUTEX_UNLOCK(&arAp->mcastpsqLock);
+
+ /* Reset the DTIMExpired flag back to 0 */
+ arAp->DTIMExpired = FALSE;
+
+ /* Clear the LSB of the BitMapCtl field of the TIM IE */
+ wmi_set_pvb_cmd(arPriv->arWmi, MCAST_AID, 0);
+}
+
+static void ar6000_uapsd_trigger_frame_rx(AR_SOFTC_DEV_T *arPriv, conn_t *conn)
+{
+ A_BOOL isApsdqEmpty;
+ A_BOOL isApsdqEmptyAtStart;
+ A_UINT32 numFramesToDeliver;
+
+ /* If the APSD q for this STA is not empty, dequeue and send a pkt from
+ * the head of the q. Also update the More data bit in the WMI_DATA_HDR
+ * if there are more pkts for this STA in the APSD q. If there are no more
+ * pkts for this STA, update the APSD bitmap for this STA.
+ */
+
+ numFramesToDeliver = (conn->apsd_info >> 4) & 0xF;
+
+ /* Number of frames to send in a service period is indicated by the station
+ * in the QOS_INFO of the association request
+ * If it is zero, send all frames
+ */
+ if (!numFramesToDeliver) {
+ numFramesToDeliver = 0xFFFF;
+ }
+
+ A_MUTEX_LOCK(&conn->psqLock);
+ isApsdqEmpty = A_NETBUF_QUEUE_EMPTY(&conn->apsdq);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+ isApsdqEmptyAtStart = isApsdqEmpty;
+
+ while ((!isApsdqEmpty) && (numFramesToDeliver)) {
+ struct sk_buff *skb = NULL;
+
+ A_MUTEX_LOCK(&conn->psqLock);
+ skb = A_NETBUF_DEQUEUE(&conn->apsdq);
+ isApsdqEmpty = A_NETBUF_QUEUE_EMPTY(&conn->apsdq);
+ A_MUTEX_UNLOCK(&conn->psqLock);
+
+ /* Set the STA flag to Trigger delivery, so that the frame will go out */
+ STA_SET_APSD_TRIGGER(conn);
+ numFramesToDeliver--;
+
+ /* Last frame in the service period, set EOSP or queue empty */
+ if ((isApsdqEmpty) || (!numFramesToDeliver)) {
+ STA_SET_APSD_EOSP(conn);
+ }
+ ar6000_data_tx(skb, arPriv->arNetDev);
+ STA_CLR_APSD_TRIGGER(conn);
+ STA_CLR_APSD_EOSP(conn);
+ }
+
+ if (isApsdqEmpty) {
+ if (isApsdqEmptyAtStart) {
+ wmi_set_apsd_buffered_traffic_cmd(arPriv->arWmi, conn->aid, 0,
+ WMI_AP_APSD_NO_DELIVERY_FRAMES_FOR_THIS_TRIGGER);
+ } else {
+ wmi_set_apsd_buffered_traffic_cmd(arPriv->arWmi, conn->aid, 0, 0);
+ }
+ }
+
+ return;
+}
+
+void
+read_rssi_compensation_param(AR_SOFTC_T *ar)
+{
+ A_UINT8 *cust_data_ptr;
+ USER_RSSI_CPENSATION *rssi_compensation_param;
+//#define RSSICOMPENSATION_PRINT
+#ifdef RSSICOMPENSATION_PRINT
+ A_INT16 i;
+ cust_data_ptr = ar6000_get_cust_data_buffer(ar->arTargetType);
+ for (i=0; i<16; i++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("cust_data_%d = %x \n", i, *(A_UINT8 *)cust_data_ptr));
+ cust_data_ptr += 1;
+ }
+#endif
+ rssi_compensation_param = &ar->rssi_compensation_param;
+ cust_data_ptr = ar6000_get_cust_data_buffer(ar->arTargetType);
+
+ rssi_compensation_param->customerID = *(A_UINT16 *)cust_data_ptr & 0xffff;
+ rssi_compensation_param->enable = *(A_UINT16 *)(cust_data_ptr+2) & 0xffff;
+ rssi_compensation_param->bg_param_a = *(A_UINT16 *)(cust_data_ptr+4) & 0xffff;
+ rssi_compensation_param->bg_param_b = *(A_UINT16 *)(cust_data_ptr+6) & 0xffff;
+ rssi_compensation_param->a_param_a = *(A_UINT16 *)(cust_data_ptr+8) & 0xffff;
+ rssi_compensation_param->a_param_b = *(A_UINT16 *)(cust_data_ptr+10) &0xffff;
+ rssi_compensation_param->reserved = *(A_UINT32 *)(cust_data_ptr+12);
+
+#ifdef RSSICOMPENSATION_PRINT
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("customerID = 0x%x \n", rssi_compensation_param->customerID));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("enable = 0x%x \n", rssi_compensation_param->enable));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("bg_param_a = 0x%x and %d \n", rssi_compensation_param->bg_param_a, rssi_compensation_param->bg_param_a));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("bg_param_b = 0x%x and %d \n", rssi_compensation_param->bg_param_b, rssi_compensation_param->bg_param_b));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("a_param_a = 0x%x and %d \n", rssi_compensation_param->a_param_a, rssi_compensation_param->a_param_a));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("a_param_b = 0x%x and %d \n", rssi_compensation_param->a_param_b, rssi_compensation_param->a_param_b));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Last 4 bytes = 0x%x \n", rssi_compensation_param->reserved));
+#endif
+
+ if (rssi_compensation_param->enable != 0x1) {
+ rssi_compensation_param->enable = 0;
+ }
+
+ return;
+}
+
+A_INT32
+rssi_compensation_calc_tcmd(AR_SOFTC_T *ar, A_UINT32 freq, A_INT32 rssi, A_UINT32 totalPkt)
+{
+ USER_RSSI_CPENSATION *rssi_compensation_param;
+
+ rssi_compensation_param = &ar->rssi_compensation_param;
+
+ if (freq > 5000)
+ {
+ if (rssi_compensation_param->enable)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, (">>> 11a\n"));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi before compensation = %d, totalPkt = %d\n", rssi,totalPkt));
+ rssi = rssi * rssi_compensation_param->a_param_a + totalPkt * rssi_compensation_param->a_param_b;
+ rssi = (rssi-50) /100;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi after compensation = %d\n", rssi));
+ }
+ }
+ else
+ {
+ if (rssi_compensation_param->enable)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, (">>> 11bg\n"));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi before compensation = %d, totalPkt = %d\n", rssi,totalPkt));
+ rssi = rssi * rssi_compensation_param->bg_param_a + totalPkt * rssi_compensation_param->bg_param_b;
+ rssi = (rssi-50) /100;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi after compensation = %d\n", rssi));
+ }
+ }
+
+ return rssi;
+}
+
+A_INT16
+rssi_compensation_calc(AR_SOFTC_DEV_T *arPriv, A_INT16 rssi)
+{
+ USER_RSSI_CPENSATION *rssi_compensation_param;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ rssi_compensation_param = &ar->rssi_compensation_param;
+
+ if (arPriv->arBssChannel > 5000)
+ {
+ if (rssi_compensation_param->enable)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, (">>> 11a\n"));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi before compensation = %d\n", rssi));
+ rssi = rssi * rssi_compensation_param->a_param_a + rssi_compensation_param->a_param_b;
+ rssi = (rssi-50) /100;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi after compensation = %d\n", rssi));
+ }
+ }
+ else
+ {
+ if (rssi_compensation_param->enable)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, (">>> 11bg\n"));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi before compensation = %d\n", rssi));
+ rssi = rssi * rssi_compensation_param->bg_param_a + rssi_compensation_param->bg_param_b;
+ rssi = (rssi-50) /100;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi after compensation = %d\n", rssi));
+ }
+ }
+
+ return rssi;
+}
+
+A_INT16
+rssi_compensation_reverse_calc(AR_SOFTC_DEV_T *arPriv, A_INT16 rssi, A_BOOL Above)
+{
+ A_INT16 i;
+
+ USER_RSSI_CPENSATION *rssi_compensation_param;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ rssi_compensation_param = &ar->rssi_compensation_param;
+
+ if (arPriv->arBssChannel > 5000)
+ {
+ if (rssi_compensation_param->enable)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, (">>> 11a\n"));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi before rev compensation = %d\n", rssi));
+ rssi = rssi * 100;
+ rssi = (rssi - rssi_compensation_param->a_param_b) / rssi_compensation_param->a_param_a;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi after rev compensation = %d\n", rssi));
+ }
+ }
+ else
+ {
+ if (rssi_compensation_param->enable)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, (">>> 11bg\n"));
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi before rev compensation = %d\n", rssi));
+
+ if (Above) {
+ for (i=95; i>=0; i--) {
+ if (rssi <= rssi_compensation_table[arPriv->arDeviceIndex][i]) {
+ rssi = 0 - i;
+ break;
+ }
+ }
+ } else {
+ for (i=0; i<=95; i++) {
+ if (rssi >= rssi_compensation_table[arPriv->arDeviceIndex][i]) {
+ rssi = 0 - i;
+ break;
+ }
+ }
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("rssi after rev compensation = %d\n", rssi));
+ }
+ }
+
+ return rssi;
+}
+
+#ifdef WAPI_ENABLE
+void ap_wapi_rekey_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 type, A_UINT8 *mac)
+{
+ union iwreq_data wrqu;
+ A_CHAR buf[20];
+
+ A_MEMZERO(buf, sizeof(buf));
+
+ strcpy(buf, "WAPI_REKEY");
+ buf[10] = type;
+ A_MEMCPY(&buf[11], mac, ATH_MAC_LEN);
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = 10+1+ATH_MAC_LEN;
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("WAPI REKEY - %d - %02x:%02x\n", type, mac[4], mac[5]));
+}
+#endif
+
+#ifdef P2P
+void *get_p2p_ctx(AR_SOFTC_DEV_T *arPriv)
+{
+ return (arPriv->p2p_ctx);
+}
+
+void *get_wmi_ctx(AR_SOFTC_DEV_T *arPriv)
+{
+ return (arPriv->arWmi);
+}
+
+NETWORK_SUBTYPE get_network_subtype(AR_SOFTC_DEV_T *arPriv)
+{
+ return (arPriv->arNetworkSubType);
+}
+
+#endif /* P2P */
+
+#ifdef USER_KEYS
+static A_STATUS
+
+ar6000_reinstall_keys(AR_SOFTC_DEV_T *arPriv, A_UINT8 key_op_ctrl)
+{
+ A_STATUS status = A_OK;
+ struct ieee80211req_key *uik = &arPriv->arSta.user_saved_keys.ucast_ik;
+ struct ieee80211req_key *bik = &arPriv->arSta.user_saved_keys.bcast_ik;
+ CRYPTO_TYPE keyType = arPriv->arSta.user_saved_keys.keyType;
+
+ if (IEEE80211_CIPHER_CCKM_KRK != uik->ik_type) {
+ if (NONE_CRYPT == keyType) {
+ goto _reinstall_keys_out;
+ }
+
+ if (uik->ik_keylen) {
+ status = wmi_addKey_cmd(arPriv->arWmi, uik->ik_keyix,
+ keyType, PAIRWISE_USAGE,
+ uik->ik_keylen, (A_UINT8 *)&uik->ik_keyrsc,
+ uik->ik_keydata, key_op_ctrl, uik->ik_macaddr, SYNC_BEFORE_WMIFLAG);
+ }
+
+ } else {
+ status = wmi_add_krk_cmd(arPriv->arWmi, uik->ik_keydata);
+ }
+
+ if (IEEE80211_CIPHER_CCKM_KRK != bik->ik_type) {
+ if (NONE_CRYPT == keyType) {
+ goto _reinstall_keys_out;
+ }
+
+ if (bik->ik_keylen) {
+ status = wmi_addKey_cmd(arPriv->arWmi, bik->ik_keyix,
+ keyType, GROUP_USAGE,
+ bik->ik_keylen, (A_UINT8 *)&bik->ik_keyrsc,
+ bik->ik_keydata, key_op_ctrl, bik->ik_macaddr, NO_SYNC_WMIFLAG);
+ }
+ } else {
+ status = wmi_add_krk_cmd(arPriv->arWmi, bik->ik_keydata);
+ }
+
+_reinstall_keys_out:
+ arPriv->arSta.user_savedkeys_stat = USER_SAVEDKEYS_STAT_INIT;
+ arPriv->arSta.user_key_ctrl = 0;
+
+ return status;
+}
+#endif /* USER_KEYS */
+
+
+void
+ar6000_dset_open_req(
+ void *context,
+ A_UINT32 id,
+ A_UINT32 targHandle,
+ A_UINT32 targReplyFn,
+ A_UINT32 targReplyArg)
+{
+}
+
+void
+ar6000_dset_close(
+ void *context,
+ A_UINT32 access_cookie)
+{
+ return;
+}
+
+void
+ar6000_dset_data_req(
+ void *context,
+ A_UINT32 accessCookie,
+ A_UINT32 offset,
+ A_UINT32 length,
+ A_UINT32 targBuf,
+ A_UINT32 targReplyFn,
+ A_UINT32 targReplyArg)
+{
+}
+void
+ar6000_init_mode_info(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+ arPriv->arChannelHint = 0;
+ arPriv->arDefTxKeyIndex = 0;
+ A_MEMZERO(arPriv->arBssid, sizeof(arPriv->arBssid));
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ A_MEMZERO(arPriv->arWepKeyList, sizeof(arPriv->arWepKeyList));
+ arPriv->arSsidLen = 0;
+ arPriv->arTxPwr = 0;
+ arPriv->arTxPwrSet = FALSE;
+ arPriv->arBitRate = -1;
+ arPriv->arMaxRetries = 0;
+ arPriv->arWmmEnabled = TRUE;
+ arPriv->ap_profile_flag = 0;
+ arPriv->num_sta = 0xFF;
+ ar->gNumSta = AP_MAX_NUM_STA;
+
+ if(arPriv->arNextMode == AP_NETWORK) {
+ AR_SOFTC_AP_T *arAp;
+ if(arPriv->arNetworkType != AP_NETWORK) {
+ A_MEMZERO(&arPriv->arSta,sizeof(AR_SOFTC_STA_T));
+ }
+ arAp = &arPriv->arAp;
+ arAp->intra_bss = 1;
+ ar->inter_bss = 1;
+
+ /* init the Mutexes */
+ A_NETBUF_QUEUE_INIT(&arAp->mcastpsq);
+ A_MUTEX_INIT(&arAp->mcastpsqLock);
+ A_MEMCPY(arAp->ap_country_code, DEF_AP_COUNTRY_CODE, 3);
+ if (arPriv->arPhyCapability == WMI_11NAG_CAPABILITY){
+ arPriv->phymode = DEF_AP_WMODE_AG;
+ } else {
+ arPriv->phymode = DEF_AP_WMODE_G;
+ }
+ arAp->ap_dtim_period = DEF_AP_DTIM;
+ arAp->ap_beacon_interval = DEF_BEACON_INTERVAL;
+ A_INIT_TIMER(&ar->ap_reconnect_timer,ap_reconnect_timer_handler, ar);
+ } else {
+ /*Station Mode intialisation*/
+ AR_SOFTC_STA_T *arSta;
+ if(arPriv->arNetworkType == AP_NETWORK) {
+ A_MEMZERO(&arPriv->arAp,sizeof(AR_SOFTC_AP_T));
+ }
+ arSta = &arPriv->arSta;
+ arSta->arListenIntervalT = A_DEFAULT_LISTEN_INTERVAL;
+ arSta->arListenIntervalB = 0;
+ arSta->arBmissTimeT = A_DEFAULT_BMISS_TIME;
+ arSta->arBmissTimeB = 0;
+ arSta->arRssi = 0;
+ arSta->arSkipScan = 0;
+ arSta->arBeaconInterval = 0;
+ arSta->scan_triggered = 0;
+ arSta->arConnectPending = FALSE;
+ A_MEMZERO(&arSta->scParams, sizeof(arSta->scParams));
+ arSta->scParams.shortScanRatio = WMI_SHORTSCANRATIO_DEFAULT;
+ arSta->scParams.scanCtrlFlags = DEFAULT_SCAN_CTRL_FLAGS;
+ A_MEMZERO(arSta->arReqBssid, sizeof(arSta->arReqBssid));
+ if (!arSta->disconnect_timer_inited) {
+ A_INIT_TIMER(&arSta->disconnect_timer, disconnect_timer_handler, arPriv->arNetDev);
+ arSta->disconnect_timer_inited = 1;
+ }
+ else
+ {
+ A_UNTIMEOUT(&arSta->disconnect_timer);
+ }
+ }
+}
+
+int
+ar6000_ap_set_num_sta(AR_SOFTC_T *ar, AR_SOFTC_DEV_T *arPriv, A_UINT8 num_sta)
+{
+ int ret = A_OK;
+ A_UINT8 i, total_num_sta;
+ AR_SOFTC_DEV_T *tpriv = NULL;
+
+ if(num_sta & 0x80) {
+ total_num_sta = (num_sta & (~0x80));
+ for(i=0; i<num_device; i++) {
+ tpriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ tpriv->num_sta = 0xFF;
+ }
+ } else {
+ total_num_sta = num_sta;
+ arPriv->num_sta = num_sta;
+ ar->gNumSta = 0xFF;
+ for(i=0; i<num_device; i++) {
+ tpriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ if((tpriv != arPriv) && (tpriv->num_sta !=0xFF) &&
+ (tpriv->arNetworkType == AP_NETWORK)) {
+ total_num_sta += tpriv->num_sta;
+ }
+ }
+ }
+
+ if(total_num_sta > AP_MAX_NUM_STA) {
+ ret = -EINVAL;
+ } else {
+ if(num_sta & 0x80) {
+ ar->gNumSta = (num_sta & (~0x80));
+ } else {
+ arPriv->num_sta = num_sta;
+ }
+ wmi_ap_set_num_sta(arPriv->arWmi, num_sta);
+ }
+
+ return ret;
+}
+
+int
+ar6000_ap_handle_lte_freq(AR_SOFTC_T *ar, AR_SOFTC_DEV_T *arPriv, A_UINT16 lteFreq)
+{
+ A_UINT8 i = 0, prev_acs = 0;
+ AR_SOFTC_DEV_T *arTempPriv = NULL;
+
+ for(i = 0;i < ar->arConfNumDev;i++) {
+ arTempPriv = ar->arDev[i];
+ if ((arTempPriv->arNetworkType == INFRA_NETWORK)) {
+ A_PRINTF("WLAN: Ignore LTE freq in STA mode\n");
+ return 0;
+ }
+ }
+
+ A_PRINTF("WLAN: LTE_FREQ: %d\n", lteFreq);
+ ar->lteFreq = lteFreq;
+ prev_acs = ar->arAcsPolicy;
+
+ /*
+ * Current algorithm to convert LTE freq to WLAN freq
+ *
+ * if 2496 <= f <= 2690
+ * bad_channel_set_to_be_avoided = [10, 11, 12, 13, 14];
+ * elseif 2300 <= f < 2350
+ * bad_channel_set_to_be_avoided = [1, 2, 3, 4];
+ * elseif 2350 <= f < 2370
+ * bad_channel_set_to_be_avoided = [1,2,3,4,5,6];
+ * elseif 2370 <= f <=2400
+ * bad_channel_set_to_be_avoided = [1,2,3,4,5,6,7,8,9];
+ * else
+ * bad_channel_set_to_be_avoided = []; end
+ */
+
+ /* Decide ACS policy based on LTE freq */
+ if(ar->lteFreq >= 2496 && ar->lteFreq <= 2690) {
+ ar->arAcsPolicy = AP_ACS_DISABLE_CH11;
+ } else if(ar->lteFreq >= 2300 && ar->lteFreq < 2350) {
+ ar->arAcsPolicy = AP_ACS_DISABLE_CH1;
+ } else if(ar->lteFreq >= 2350 && ar->lteFreq < 2370) {
+ ar->arAcsPolicy = AP_ACS_DISABLE_CH1_6;
+ } else if(ar->lteFreq >= 2370 && ar->lteFreq <= 2400) {
+ ar->arAcsPolicy = AP_ACS_DISABLE_CH1_6;
+ } else if (ar->lteFreq) {
+ A_PRINTF("WLAN: LTE_FREQ Out of range\n");
+ ar->lteFreq = 0;
+ } else {
+ ar->arAcsPolicy = 0;
+ A_PRINTF("WLAN: LTE_FREQ Disabled\n");
+ }
+
+ if (ar->arAcsPolicy && (ar->arAcsPolicy != prev_acs)) {
+ /* Stop all running APs and switch them to ACS */
+ for(i=0;i<ar->arConfNumDev;i++) {
+ arTempPriv = ar->arDev[i];
+ if(arTempPriv->arConnected) {
+ ar6000_disconnect(arTempPriv);
+ arTempPriv->arConnected = FALSE;
+ arTempPriv->arChannelHint = 0;
+ arTempPriv->ap_profile_flag = 1;
+ arTempPriv->arBssChannel = 0;
+ ar->arHoldConnection |= (1<<arTempPriv->arDeviceIndex);
+ }
+ }
+ }
+
+ return 0;
+}
+
+/*
+ * Check hold status of other concurrent devices during
+ * connect or disconnect of every virtual device
+ */
+static int
+ar6000_check_hold_conn_status(AR_SOFTC_DEV_T *arPriv, A_UINT8 conn_status)
+{
+ AR_SOFTC_DEV_T *arTempPriv = NULL;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_STATUS status = A_OK;
+
+ /* Concurrency: Process the pending connect of the other virtual device(s) */
+ if (ar->arHoldConnection) {
+ A_UINT8 connect_flag = 0, cnt = 0;
+
+ for(cnt=0;cnt<ar->arConfNumDev;cnt++) {
+ arTempPriv = ar->arDev[cnt];
+
+ //if(arTempPriv == arPriv) continue;
+
+ if(ar->arHoldConnection & (1<<arTempPriv->arDeviceIndex)) {
+ A_STATUS status = A_OK;
+
+ /* validate channel-hint vs home-channel */
+ status = ar6000_check_connect_request(ar->arDev[cnt], FALSE);
+ if(A_OK == status) {
+ connect_flag = TRUE;
+ break;
+ } else if(A_ERROR == status) {
+ ar->arHoldConnection &= ~(1<<ar->arDev[cnt]->arDeviceIndex);
+ }
+ }
+
+ if(conn_status) arTempPriv->arChannelHint = 0;
+
+ }
+
+ if(connect_flag) {
+ /* Profile commit happens at time-out */
+ A_TIMEOUT_MS(&ar->ap_reconnect_timer, 1*1000, 0);
+ }
+ status = A_OK;
+ } else {
+ status = A_ERROR;
+ }
+
+ return status;
+}
+
+/*
+ * (1) Check the status of other devices' connection
+ * (2) If there is atleast one device up already, validate the channelHint
+ * (3) If check_pending_status is set, check whether the current device conn
+ * needs to be kept on hold. Otherwise, do only channel validation
+ * return : A_ERROR - one of the above failed
+ * A_OK - success
+ * A_PENDING - if called during connect, the connect is kep on hold
+ * (assumed as success)
+ */
+A_STATUS
+ar6000_check_connect_request(AR_SOFTC_DEV_T *arPriv, A_UINT8 check_pending_status)
+{
+ A_UINT8 i;
+ A_STATUS ret_val = A_OK;
+ AR_SOFTC_DEV_T *temp_priv = NULL;
+ AR_SOFTC_STA_T *arSta = NULL;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ for(i=0; i<num_device; i++) {
+ temp_priv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ arSta = &temp_priv->arSta;
+
+ if(arPriv == temp_priv) continue;
+
+ if(arPriv->arNetworkType == AP_NETWORK && temp_priv->arConnected) {
+ if(temp_priv->arNetworkType == AP_NETWORK) {
+ if(((temp_priv->phymode == WMI_11A_MODE) && (arPriv->phymode != WMI_11A_MODE) && (arPriv->phymode != WMI_11AG_MODE)) ||
+ ((temp_priv->phymode != WMI_11A_MODE) && (arPriv->phymode == WMI_11A_MODE ))) {
+ A_PRINTF("ar6000_check_connect_request: One or more concurrent devices"
+ " conneted in different phy mode\n");
+ ret_val = A_ERROR;
+ break;
+ }
+ }
+ }
+
+ if( check_pending_status ) {
+ if( arPriv->arNextMode == AP_NETWORK )
+ {
+ /* If connecting device is AP and pending device is STA or AP, make
+ the connecting device's state as HOLD */
+ if( ((temp_priv->arNextMode == AP_NETWORK) &&
+ (temp_priv->arConnected) &&
+ (!temp_priv->arBssChannel)) ||
+ ((temp_priv->arNextMode == INFRA_NETWORK) &&
+ (arSta->arConnectPending == TRUE))) {
+ ar->arHoldConnection |= (1<<arPriv->arDeviceIndex);
+ A_PRINTF("ar6000_check_connect_request: dev %d on hold\n", arPriv->arDeviceIndex);
+
+ /* break & return sucess. Process it later */
+ ret_val = A_PENDING;
+ break;
+ }
+ } else if( arPriv->arNextMode == INFRA_NETWORK ) {
+ /* If the connecting device is STA and pending device is AP,
+ disconnect the pending device and put it in HOLD. Process it's
+ connect during STA connect */
+ if((temp_priv->arNextMode == AP_NETWORK) &&
+ (temp_priv->arConnected) &&
+ (!temp_priv->arBssChannel)) {
+ A_PRINTF("ar6000_check_connect_request : disconnecting AP dev %d",temp_priv->arDeviceIndex);
+ ar6000_disconnect(temp_priv);
+ temp_priv->ap_profile_flag = 1;
+ if(!(ar->arHoldConnection & (1<<temp_priv->arDeviceIndex))) {
+ ar->arHoldConnection |= (1<<temp_priv->arDeviceIndex);
+ }
+ continue;
+ } else if((temp_priv->arNextMode == INFRA_NETWORK) &&
+ (arSta->arConnectPending == TRUE)) {
+ /* STA-STA conc - not handled */
+ }
+ }
+ }
+
+ /* validate 'channel-hint v home-channel' */
+ if((temp_priv->arConnected) &&
+ (arPriv->arNextMode == AP_NETWORK)) {
+ A_UINT8 prev_phy_mode = arPriv->phymode;
+
+ if(arPriv->is_sta_roaming) {
+ arPriv->arChannelHint = 0;
+ arPriv->is_sta_roaming = FALSE;
+ }
+ if (!(((arPriv->arChannelHint >= 5180) && (temp_priv->arBssChannel >= 5180)) ||
+ ((arPriv->arChannelHint < 5180) && (temp_priv->arBssChannel < 5180))) ||
+ (arPriv->arChannelHint == 0)) {
+ if(prev_phy_mode && (temp_priv->arNetworkType == AP_NETWORK) &&
+ (arPriv->arNetworkType == AP_NETWORK)) {
+ arPriv->phymode = prev_phy_mode;
+ } else if (arPriv->arPhyCapability == WMI_11NAG_CAPABILITY){
+ arPriv->phymode = DEF_AP_WMODE_AG;
+ } else {
+ arPriv->phymode = DEF_AP_WMODE_G;
+ }
+ }
+
+ /* Copy station's regDomain to softAP interface */
+
+ if (temp_priv->arRegCode != arPriv->arRegCode) {
+
+ A_MEMCPY(arPriv->arAp.ap_country_code,
+ (A_UINT8 *)&temp_priv->arRegCode, 2);
+ arPriv->arAp.ap_country_code[2]=COUNTRY_CODE_PRESENT;
+
+ wmi_set_country(arPriv->arWmi,
+ arPriv->arAp.ap_country_code);
+ }
+
+ /* User has set the channel for this interface */
+ if(arPriv->arChannelHint) {
+ if(temp_priv->arBssChannel != arPriv->arChannelHint) {
+ A_PRINTF("ar6000_check_connect_request: Error: Channel should be %d"
+ "MHz. but it is %d\n", temp_priv->arBssChannel,
+ arPriv->arChannelHint);
+ arPriv->arChannelHint = 0;
+ /* channel mismatch is an error - say so */
+ ret_val = A_ERROR;
+ arPriv->phymode = prev_phy_mode;
+ break;
+ }
+ } else {
+ /* ACS is enabled for this interface */
+ if(temp_priv->arBssChannel) {
+ arPriv->arChannelHint = temp_priv->arBssChannel;
+ A_PRINTF("ar6000_check_connect_request:Selected Channel %d of dev %d\n",
+ temp_priv->arBssChannel,
+ temp_priv->arDeviceIndex);
+ /* go ahead with the connect on the other device's channel*/
+ ret_val = A_OK;
+ break;
+ }
+ }
+ }
+}
+
+ return ret_val;
+}
+
+int
+ar6000_ap_mode_profile_commit(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_CONNECT_CMD p;
+ unsigned long flags;
+
+ if (ar->isHostAsleep != 0) {
+ A_PRINTF("Cannot commit while host is in sleep mode!!!\n");
+ return -EOPNOTSUPP;
+ }
+
+ /* No change in AP's profile configuration */
+ if(arPriv->ap_profile_flag==0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("COMMIT: No change in profile!!!\n"));
+ return -ENODATA;
+ }
+
+ if(!arPriv->arSsidLen) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("SSID not set!!!\n"));
+ return -ECHRNG;
+ }
+
+ if(arPriv->arAuthMode == WMI_NONE_AUTH) {
+ if((arPriv->arPairwiseCrypto != NONE_CRYPT) &&
+#ifdef WAPI_ENABLE
+ (arPriv->arPairwiseCrypto != WAPI_CRYPT) &&
+#endif
+ (arPriv->arPairwiseCrypto != WEP_CRYPT)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Cipher not supported in AP mode Open auth\n"));
+ return -EOPNOTSUPP;
+ }
+ } else if(!(arPriv->arAuthMode &
+ (WMI_WPA_PSK_AUTH|WMI_WPA2_PSK_AUTH|WMI_WPA_AUTH|WMI_WPA2_AUTH))) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Key mgmt type not supported in AP mode\n"));
+ return -EOPNOTSUPP;
+ }
+
+ if ((arPriv->arAuthMode == WMI_NONE_AUTH) &&
+ (arPriv->arPairwiseCrypto == WEP_CRYPT))
+ {
+ ar6000_install_static_wep_keys(arPriv);
+ }
+
+ /* Update the arNetworkType */
+ arPriv->arNetworkType = arPriv->arNextMode;
+ arPriv->arBssChannel = 0;
+
+ A_MEMZERO(&p,sizeof(p));
+ p.ssidLength = arPriv->arSsidLen;
+ A_MEMCPY(p.ssid,arPriv->arSsid,p.ssidLength);
+
+ /*
+ * p.channel == 0 [Do ACS and choose 1, 6, or 11]
+ * p.channel == 1 [Do ACS and choose 1, or 6]
+ * p.channel == xxxx [No ACS, use xxxx freq]
+ */
+ if (((arPriv->phymode != WMI_11AG_MODE && arPriv->phymode != WMI_11A_MODE) && (IS_5G_CHANNEL(arPriv->arChannelHint))) ||
+ ((arPriv->phymode == WMI_11A_MODE) && !(IS_5G_CHANNEL(arPriv->arChannelHint)) && arPriv->arChannelHint)) {
+ A_PRINTF("ar6000_ap_mode_profile_commit: Channel hint not matching with phymode\n");
+ arPriv->arChannelHint = 0;
+ return -EINVAL;
+ }
+
+ if ((arPriv->arChannelHint == 0) && (ar->arAcsPolicy)) {
+ p.channel = ar->arAcsPolicy;
+ } else {
+ p.channel = arPriv->arChannelHint;
+ if ((arPriv->arChannelHint >= 5180) && (arPriv->arChannelHint <= 5825)) {
+ if (!(wmi_set_channelParams_cmd(arPriv->arWmi, 0, WMI_11A_MODE, 0, NULL))) {
+ arPriv->phymode = WMI_11A_MODE;
+ }
+ } else if ((arPriv->phymode == WMI_11AG_MODE)) {
+ if (!(wmi_set_channelParams_cmd(arPriv->arWmi, 0, WMI_11G_MODE, 0, NULL))) {
+ arPriv->phymode = WMI_11G_MODE;
+ }
+ }
+ }
+
+ p.networkType = arPriv->arNetworkType;
+ p.dot11AuthMode = arPriv->arDot11AuthMode;
+ p.authMode = arPriv->arAuthMode;
+ p.pairwiseCryptoType = arPriv->arPairwiseCrypto;
+ p.pairwiseCryptoLen = arPriv->arPairwiseCryptoLen;
+ p.groupCryptoType = arPriv->arGroupCrypto;
+ p.groupCryptoLen = arPriv->arGroupCryptoLen;
+ p.ctrl_flags = arPriv->arSta.arConnectCtrlFlags;
+
+#if WLAN_CONFIG_NO_DISASSOC_UPON_DEAUTH
+ p.ctrl_flags |= AP_NO_DISASSOC_UPON_DEAUTH;
+#endif
+ wmi_ap_profile_commit(arPriv->arWmi, &p);
+ spin_lock_irqsave(&arPriv->arPrivLock, flags);
+ arPriv->arConnected = TRUE;
+ netif_carrier_on(arPriv->arNetDev);
+ spin_unlock_irqrestore(&arPriv->arPrivLock, flags);
+ arPriv->ap_profile_flag = 0;
+
+ return 0;
+}
+
+A_STATUS
+ar6000_connect_to_ap(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+
+ /* The ssid length check prevents second "essid off" from the user,
+ to be treated as a connect cmd. The second "essid off" is ignored.
+ */
+ if((ar->arWmiReady == TRUE) && (arPriv->arSsidLen > 0) && arPriv->arNetworkType!=AP_NETWORK)
+ {
+ A_STATUS status;
+ if((ADHOC_NETWORK != arPriv->arNetworkType) &&
+ (WMI_NONE_AUTH==arPriv->arAuthMode) &&
+ (WEP_CRYPT==arPriv->arPairwiseCrypto)) {
+ ar6000_install_static_wep_keys(arPriv);
+ }
+
+ if (!arSta->arUserBssFilter) {
+ if (wmi_bssfilter_cmd(arPriv->arWmi, ALL_BSS_FILTER, 0) != A_OK) {
+ return -EIO;
+ }
+ }
+
+ /* Check for APs pending to be connected */
+ if( A_ERROR == ar6000_check_connect_request(arPriv, TRUE)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("ar6000_connect_to_ap:unknown error, hold %x",ar->arHoldConnection));
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("Connect called with authmode %d dot11 auth %d"\
+ " PW crypto %d PW crypto Len %d GRP crypto %d"\
+ " GRP crypto Len %d\n",
+ arPriv->arAuthMode, arPriv->arDot11AuthMode,
+ arPriv->arPairwiseCrypto, arPriv->arPairwiseCryptoLen,
+ arPriv->arGroupCrypto, arPriv->arGroupCryptoLen));
+ reconnect_flag = 0;
+ /* Set the listen interval into 1000TUs or more. This value will be indicated to Ap in the conn.
+ later set it back locally at the STA to 100/1000 TUs depending on the power mode */
+ if ((arPriv->arNetworkType == INFRA_NETWORK)) {
+ wmi_listeninterval_cmd(arPriv->arWmi, max(arSta->arListenIntervalT, (A_UINT16)A_MAX_WOW_LISTEN_INTERVAL), 0);
+ }
+ status = wmi_connect_cmd(arPriv->arWmi, arPriv->arNetworkType,
+ arPriv->arDot11AuthMode, arPriv->arAuthMode,
+ arPriv->arPairwiseCrypto, arPriv->arPairwiseCryptoLen,
+ arPriv->arGroupCrypto,arPriv->arGroupCryptoLen,
+ arPriv->arSsidLen, arPriv->arSsid,
+ arSta->arReqBssid, arPriv->arChannelHint,
+ arSta->arConnectCtrlFlags);
+ if (status != A_OK) {
+ wmi_listeninterval_cmd(arPriv->arWmi, arSta->arListenIntervalT, arSta->arListenIntervalB);
+ if (!arSta->arUserBssFilter) {
+ wmi_bssfilter_cmd(arPriv->arWmi, NONE_BSS_FILTER, 0);
+ }
+ return status;
+ }
+
+ if ((!(arSta->arConnectCtrlFlags & CONNECT_DO_WPA_OFFLOAD)) &&
+ ((WMI_WPA_PSK_AUTH == arPriv->arAuthMode) || (WMI_WPA2_PSK_AUTH == arPriv->arAuthMode)))
+ {
+ A_TIMEOUT_MS(&arSta->disconnect_timer, A_DISCONNECT_TIMER_INTERVAL, 0);
+ }
+
+ arSta->arConnectCtrlFlags &= ~CONNECT_DO_WPA_OFFLOAD;
+
+ arSta->arConnectPending = TRUE;
+ return status;
+ }
+ return A_ERROR;
+}
+
+A_STATUS
+ar6000_disconnect(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ if ((arPriv->arConnected == TRUE) || (arPriv->arSta.arConnectPending == TRUE)) {
+ wmi_disconnect_cmd(arPriv->arWmi);
+#ifdef P2P
+ if(arPriv->arNetworkSubType == SUBTYPE_P2PCLIENT) {
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->arConnected == FALSE, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ return -EINTR;
+ }
+ }
+#endif
+ /*
+ * Disconnect cmd is issued, clear connectPending.
+ * arConnected will be cleard in disconnect_event notification.
+ */
+ arPriv->arSta.arConnectPending = FALSE;
+ }
+ ar->arHoldConnection &= ~(1 << arPriv->arDeviceIndex);
+
+ return A_OK;
+}
+
+A_STATUS
+ar6000_ap_mode_get_wpa_ie(AR_SOFTC_DEV_T *arPriv, struct ieee80211req_wpaie *wpaie)
+{
+ conn_t *conn = NULL;
+ conn = ieee80211_find_conn(arPriv, wpaie->wpa_macaddr);
+
+ A_MEMZERO(wpaie->wpa_ie, IEEE80211_MAX_IE);
+ A_MEMZERO(wpaie->rsn_ie, IEEE80211_MAX_IE);
+
+ if(conn) {
+ A_MEMCPY(wpaie->wpa_ie, conn->wpa_ie, IEEE80211_MAX_IE);
+ }
+
+ return 0;
+}
+
+A_STATUS
+is_iwioctl_allowed(A_UINT8 mode, A_UINT16 cmd)
+{
+ if(cmd >= SIOCSIWCOMMIT && cmd <= SIOCGIWPOWER) {
+ cmd -= SIOCSIWCOMMIT;
+ if(sioctl_filter[cmd] == 0xFF) return A_OK;
+ if(sioctl_filter[cmd] & mode) return A_OK;
+ } else if(cmd >= SIOCIWFIRSTPRIV && cmd <= (SIOCIWFIRSTPRIV+30)) {
+ cmd -= SIOCIWFIRSTPRIV;
+ if(pioctl_filter[cmd] == 0xFF) return A_OK;
+ if(pioctl_filter[cmd] & mode) return A_OK;
+ } else {
+ return A_ERROR;
+ }
+ return A_ENOTSUP;
+}
+
+A_STATUS
+is_xioctl_allowed(A_UINT8 mode, A_UINT8 submode, int cmd)
+{
+ A_UINT8 mode_bits, submode_bits;
+ A_BOOL is_valid_mode=FALSE, is_valid_submode=FALSE;
+
+ if(sizeof(xioctl_filter)-1 < cmd) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Filter for this cmd=%d not defined\n",cmd));
+ return A_OK;
+ }
+
+ /* Valid for all modes/submodes */
+ if(xioctl_filter[cmd] == 0xFF) return A_OK;
+
+ /* Check if this cmd is valid for the set mode of this device.
+ */
+#define XIOCTL_FILTER_MODE_MASK 0x1F
+#define XIOCTL_FILTER_MODE_BIT_OFFSET 0x0
+ mode_bits = xioctl_filter[cmd] & XIOCTL_FILTER_MODE_MASK;
+
+ if (mode_bits & (mode << XIOCTL_FILTER_MODE_BIT_OFFSET)) {
+ /* Valid cmd for this mode */
+ is_valid_mode = TRUE;
+ }
+
+ /* Check if this cmd is valid for the set submode of this device.
+ */
+#define XIOCTL_FILTER_SUBMODE_MASK 0xE0
+#define XIOCTL_FILTER_SUBMODE_BIT_OFFSET 0x0
+ submode_bits = (xioctl_filter[cmd] & XIOCTL_FILTER_SUBMODE_MASK)>>XIOCTL_FILTER_SUBMODE_BIT_OFFSET;
+
+ if (submode == SUBTYPE_P2PDEV || submode == SUBTYPE_P2PCLIENT ||
+ submode == SUBTYPE_P2PGO) {
+ /* P2P Submode */
+ if (submode_bits & XIOCTL_FILTER_P2P_SUBMODE) {
+ is_valid_submode = TRUE;
+ }
+ } else {
+ /* Non P2P Sub mode */
+ if ((submode_bits & XIOCTL_FILTER_NONP2P_SUBMODE)) {
+ is_valid_submode = TRUE;
+ }
+ }
+
+ if (is_valid_mode && is_valid_submode) {
+ return A_OK;
+ }
+
+ return A_ERROR;
+}
+
+#ifdef WAPI_ENABLE
+int
+ap_set_wapi_key(AR_SOFTC_DEV_T *arPriv, void *ikey)
+{
+ struct ieee80211req_key *ik = (struct ieee80211req_key *)ikey;
+ KEY_USAGE keyUsage = 0;
+ A_STATUS status;
+
+ if (A_MEMCMP(ik->ik_macaddr, bcast_mac, IEEE80211_ADDR_LEN) == 0) {
+ keyUsage = GROUP_USAGE;
+ } else {
+ keyUsage = PAIRWISE_USAGE;
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("WAPI_KEY: Type:%d ix:%d mac:%02x:%02x len:%d\n",
+ keyUsage, ik->ik_keyix, ik->ik_macaddr[4], ik->ik_macaddr[5],
+ ik->ik_keylen));
+
+ status = wmi_addKey_cmd(arPriv->arWmi, ik->ik_keyix, WAPI_CRYPT, keyUsage,
+ ik->ik_keylen, (A_UINT8 *)&ik->ik_keyrsc,
+ ik->ik_keydata, KEY_OP_INIT_VAL, ik->ik_macaddr,
+ SYNC_BOTH_WMIFLAG);
+
+ if (A_OK != status) {
+ return -EIO;
+ }
+ return 0;
+}
+#endif
+
+#ifdef P2P
+
+void ar6000_p2p_prov_disc_req_event(AR_SOFTC_DEV_T *arPriv,
+ const A_UINT8 *peer, A_UINT16 wps_config_method,
+ const A_UINT8 *dev_addr, const A_UINT8 *pri_dev_type,
+ const A_UINT8 *dev_name, A_UINT8 dev_name_len,
+ A_UINT16 supp_config_methods, A_UINT8 dev_capab, A_UINT8 group_capab)
+{
+ union iwreq_data wrqu;
+ A_UINT8 buf[100];
+ A_UINT8 *pos=buf;
+
+ A_MEMZERO(pos, sizeof(buf));
+ A_MEMCPY(pos, "P2PPROVDISCREQ", 14);
+ pos += 14;
+
+ A_MEMCPY(pos, peer, IEEE80211_ADDR_LEN);
+ pos += IEEE80211_ADDR_LEN;
+
+ A_MEMCPY(pos, dev_addr, IEEE80211_ADDR_LEN);
+ pos += IEEE80211_ADDR_LEN;
+
+ A_MEMCPY(pos, pri_dev_type, 8);
+ pos += 8;
+
+ A_MEMCPY(pos, dev_name, dev_name_len);
+ pos += dev_name_len;
+ *pos++ = '\0';
+
+ A_MEMCPY(pos, (A_UINT8 *)&supp_config_methods, 2);
+ pos += 2;
+
+ A_MEMCPY(pos, (A_UINT8 *)&wps_config_method, 2);
+ pos += 2;
+
+ A_MEMCPY(pos, &dev_capab, 1);
+ pos++;
+
+ A_MEMCPY(pos, &group_capab, 1);
+ pos++;
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = (pos-buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+void ar6000_p2p_prov_disc_resp_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 *peer,
+ A_UINT16 config_methods)
+{
+ union iwreq_data wrqu;
+ A_UINT8 buf[100];
+ A_UINT8 *pos=buf;
+
+ A_MEMZERO(pos, sizeof(buf));
+ A_MEMCPY(pos, "P2PPROVDISCRESP", 15);
+ pos += 15;
+
+ A_MEMCPY(pos, peer, IEEE80211_ADDR_LEN);
+ pos += IEEE80211_ADDR_LEN;
+
+ A_MEMCPY(pos, (A_UINT8 *)&config_methods, 2);
+ pos += 2;
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = (pos-buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+void ar6000_p2pdev_event(AR_SOFTC_DEV_T *arPriv, const A_UINT8 *addr,
+ const A_UINT8 *dev_addr,
+ const A_UINT8 *pri_dev_type, const A_UINT8 *dev_name,
+ A_UINT8 dev_name_len, A_UINT16 config_methods, A_UINT8 dev_capab,
+ A_UINT8 grp_capab)
+{
+ union iwreq_data wrqu;
+ A_UINT8 buf[100];
+ A_UINT8 *pos=buf;
+
+ A_MEMZERO(pos, sizeof(buf));
+ A_MEMCPY(pos, "P2PDEVFOUND", 11);
+ pos += 11;
+
+ A_MEMCPY(pos, addr, IEEE80211_ADDR_LEN);
+ pos += IEEE80211_ADDR_LEN;
+
+ A_MEMCPY(pos, dev_addr, IEEE80211_ADDR_LEN);
+ pos += IEEE80211_ADDR_LEN;
+
+ /* Size of P2P Attributes hardcoded here. Can this be changed ?
+ */
+ A_MEMCPY(pos, pri_dev_type, 8);
+ pos += 8;
+
+ A_MEMCPY(pos, dev_name, dev_name_len);
+ pos += dev_name_len;
+ *pos++ = '\0';
+
+ A_MEMCPY(pos, (A_UINT8 *)&config_methods, 2);
+ pos += 2;
+
+ A_MEMCPY(pos, &dev_capab, 1);
+ pos++;
+
+ A_MEMCPY(pos, &grp_capab, 1);
+ pos++;
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = (pos-buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+
+ return;
+}
+
+void ar6000_p2pdev_lost_event(AR_SOFTC_DEV_T *arPriv, const A_UINT8 *dev_addr) {
+ union iwreq_data wrqu;
+ A_UINT8 buf[20];
+ A_UINT8 *pos=buf;
+
+ A_MEMZERO(pos, sizeof(buf));
+ A_MEMCPY(pos, "P2PDEVLOST", 10);
+ pos += 10;
+
+ A_MEMCPY(pos, dev_addr, IEEE80211_ADDR_LEN);
+ pos += IEEE80211_ADDR_LEN;
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = (pos-buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+void ar6000_p2p_sd_rx_event(AR_SOFTC_DEV_T *arPriv, WMI_P2P_SDPD_RX_EVENT *ev)
+{
+ union iwreq_data wrqu;
+ A_UINT8 *event_ptr;
+ A_UINT8 *pos;
+ A_UINT16 size;
+
+#define P2P_SD_REQ_RESP_STR_LEN 12
+ size = P2P_SD_REQ_RESP_STR_LEN
+ + sizeof(WMI_P2P_SDPD_RX_EVENT)
+ + ev->tlv_length;
+ event_ptr = A_MALLOC_NOWAIT(size);
+ pos = event_ptr;
+ A_MEMZERO(pos, size);
+ A_MEMCPY(pos, "P2PSDREQRESP", P2P_SD_REQ_RESP_STR_LEN);
+ pos += P2P_SD_REQ_RESP_STR_LEN;
+#undef P2P_SD_REQ_RESP_STR_LEN
+
+ /* Copy the event followed by TLV, parsing will be dobe in supplicant */
+ A_MEMCPY(pos, ev, sizeof(WMI_P2P_SDPD_RX_EVENT) + ev->tlv_length);
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = size;
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, event_ptr);
+
+ A_FREE(event_ptr);
+ return;
+}
+
+void p2p_go_neg_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 *res, A_UINT8 len)
+{
+ union iwreq_data wrqu;
+ A_UINT8 buf[100];
+
+ A_MEMZERO(&buf, sizeof(buf));
+ A_MEMCPY(buf, "P2PNEGCOMPLETE",14);
+ A_MEMCPY(&buf[14], res, len);
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = 14+len;
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+void p2p_go_neg_req_event(AR_SOFTC_DEV_T *arPriv, const A_UINT8 *sa, A_UINT16 dev_passwd_id)
+{
+ union iwreq_data wrqu;
+ A_UINT8 buf[100];
+ A_UINT8 *pos=buf;
+
+ A_MEMZERO(pos, sizeof(buf));
+ A_MEMCPY(pos, "P2PNEGREQEV", 11);
+ pos += 11;
+
+ A_MEMCPY(pos, sa, IEEE80211_ADDR_LEN);
+ pos += IEEE80211_ADDR_LEN;
+
+ A_MEMCPY(pos, (A_UINT8 *)&dev_passwd_id, 2);
+ pos += 2;
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = (pos-buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+
+void p2p_invite_sent_result_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 *res,
+ A_UINT8 len)
+{
+ union iwreq_data wrqu;
+ A_UINT8 buf[100];
+
+ A_MEMZERO(&buf, sizeof(buf));
+ A_MEMCPY(buf, "P2PINVITESENTRESULT", 19);
+ A_MEMCPY(&buf[19], res, len);
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = 19 + len;
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+void p2p_invite_rcvd_result_event(AR_SOFTC_DEV_T *arPriv,
+ A_UINT8 *res, A_UINT8 len)
+{
+ union iwreq_data wrqu;
+ A_UINT8 buf[100];
+
+ A_MEMZERO(&buf, sizeof(buf));
+ A_MEMCPY(buf, "P2PINVITERCVDRESULT", 19);
+ A_MEMCPY(&buf[19], res, len);
+
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = 19 + len;
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+#endif /* P2P */
+
+void ar6000_peer_event(
+ void *context,
+ A_UINT8 eventCode,
+ A_UINT8 *macAddr)
+{
+ A_UINT8 pos;
+
+ for (pos=0;pos<6;pos++)
+ printk("%02x: ",*(macAddr+pos));
+ printk("\n");
+}
+
+void ar6000_get_device_addr(AR_SOFTC_DEV_T *arPriv, A_UINT8 *addr)
+{
+ A_MEMCPY(addr, arPriv->arNetDev->dev_addr, IEEE80211_ADDR_LEN);
+ return;
+}
+
+#ifdef HTC_TEST_SEND_PKTS
+#define HTC_TEST_DUPLICATE 8
+static void DoHTCSendPktsTest(AR_SOFTC_T *ar, int MapNo, HTC_ENDPOINT_ID eid, struct sk_buff *dupskb)
+{
+ struct ar_cookie *cookie;
+ struct ar_cookie *cookieArray[HTC_TEST_DUPLICATE];
+ struct sk_buff *new_skb;
+ int i;
+ int pkts = 0;
+ HTC_PACKET_QUEUE pktQueue;
+ EPPING_HEADER *eppingHdr;
+
+ eppingHdr = A_NETBUF_DATA(dupskb);
+
+ if (eppingHdr->Cmd_h == EPPING_CMD_NO_ECHO) {
+ /* skip test if this is already a tx perf test */
+ return;
+ }
+
+ for (i = 0; i < HTC_TEST_DUPLICATE; i++,pkts++) {
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ cookie = ar6000_alloc_cookie(ar);
+ if (cookie != NULL) {
+ ar->arTxPending[eid]++;
+ ar->arTotalTxDataPending++;
+ }
+
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+
+ if (NULL == cookie) {
+ break;
+ }
+
+ new_skb = A_NETBUF_ALLOC(A_NETBUF_LEN(dupskb));
+
+ if (new_skb == NULL) {
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ ar6000_free_cookie(ar,cookie);
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ break;
+ }
+
+ A_NETBUF_PUT_DATA(new_skb, A_NETBUF_DATA(dupskb), A_NETBUF_LEN(dupskb));
+ cookie->arc_bp[0] = (A_UINT32)new_skb;
+ cookie->arc_bp[1] = MapNo;
+ SET_HTC_PACKET_INFO_TX(&cookie->HtcPkt,
+ cookie,
+ A_NETBUF_DATA(new_skb),
+ A_NETBUF_LEN(new_skb),
+ eid,
+ AR6K_DATA_PKT_TAG);
+
+ cookieArray[i] = cookie;
+
+ {
+ EPPING_HEADER *pHdr = (EPPING_HEADER *)A_NETBUF_DATA(new_skb);
+ pHdr->Cmd_h = EPPING_CMD_NO_ECHO; /* do not echo the packet */
+ }
+ }
+
+ if (pkts == 0) {
+ return;
+ }
+
+ INIT_HTC_PACKET_QUEUE(&pktQueue);
+
+ for (i = 0; i < pkts; i++) {
+ HTC_PACKET_ENQUEUE(&pktQueue,&cookieArray[i]->HtcPkt);
+ }
+
+ HTCSendPktsMultiple(ar->arHtcTarget, &pktQueue);
+
+}
+
+#endif
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+EXPORT_SYMBOL(setupbtdev);
+#endif
+
+NETWORK_TYPE ar6000_get_network_type(AR_SOFTC_DEV_T *arPriv)
+{
+ return (arPriv->arNetworkType);
+}
+
diff --git a/host/os/linux/ar6000_pm.c b/host/os/linux/ar6000_pm.c
new file mode 100644
index 0000000..6a3d73e
--- /dev/null
+++ b/host/os/linux/ar6000_pm.c
@@ -0,0 +1,1359 @@
+//
+//
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+//
+//
+//
+
+/*
+ * Implementation of system power management
+ */
+
+#include "ar6000_drv.h"
+#include <linux/inetdevice.h>
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15)
+#include <linux/platform_device.h>
+#endif
+#include "wlan_config.h"
+
+#ifdef CONFIG_HAS_WAKELOCK
+#include <linux/wakelock.h>
+#endif
+
+#ifdef CONFIG_PLAT_AMBARELLA
+#include <mach/board.h>
+#include <plat/sd.h>
+#endif
+
+#define WOW_ENABLE_MAX_INTERVAL 1
+#define WOW_SET_SCAN_PARAMS 1
+
+extern unsigned int wmitimeout;
+extern unsigned int num_device;
+#if WLAN_CONFIG_FIRST_SCAN_2G_ONLY
+extern unsigned int first_scan_2g_only;
+#endif
+extern unsigned int psm_info;
+#ifdef CONFIG_PM
+struct platform_device *g_pdev = NULL;
+
+#if PLAT_WOW_GPIO_PIN || PLAT_WLAN_CHIP_PWD_PIN
+#include <linux/gpio.h>
+#endif
+
+#if defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM9615)
+#include <linux/gpio.h>
+#include <linux/regulator/consumer.h>
+#endif
+
+#if PLAT_WOW_GPIO_PIN
+static int wow_irq;
+#endif /* PLAT_WOW_GPIO_PIN */
+
+#ifdef CONFIG_HAS_WAKELOCK
+struct wake_lock ar6k_suspend_wake_lock;
+struct wake_lock ar6k_wow_wake_lock;
+#endif
+#endif /* CONFIG_PM */
+
+#ifdef ANDROID_ENV
+extern void android_ar6k_check_wow_status(AR_SOFTC_T *ar, struct sk_buff *skb, A_BOOL isEvent);
+#endif
+#undef ATH_MODULE_NAME
+#define ATH_MODULE_NAME pm
+#define ATH_DEBUG_PM ATH_DEBUG_MAKE_MODULE_MASK(0)
+
+#ifdef DEBUG
+static ATH_DEBUG_MASK_DESCRIPTION pm_debug_desc[] = {
+ { ATH_DEBUG_PM , "System power management"},
+};
+
+ATH_DEBUG_INSTANTIATE_MODULE_VAR(pm,
+ "pm",
+ "System Power Management",
+ ATH_DEBUG_MASK_DEFAULTS | ATH_DEBUG_PM,
+ ATH_DEBUG_DESCRIPTION_COUNT(pm_debug_desc),
+ pm_debug_desc);
+
+#endif /* DEBUG */
+
+A_STATUS ar6000_exit_cut_power_state(AR_SOFTC_T *ar);
+
+#ifdef CONFIG_PM
+static void ar6k_send_asleep_event_to_app(AR_SOFTC_DEV_T *arPriv, A_BOOL asleep)
+{
+ char buf[128];
+ union iwreq_data wrqu;
+
+ snprintf(buf, sizeof(buf), "HOST_ASLEEP=%s", asleep ? "asleep" : "awake");
+ A_MEMZERO(&wrqu, sizeof(wrqu));
+ wrqu.data.length = strlen(buf);
+ wireless_send_event(arPriv->arNetDev, IWEVCUSTOM, &wrqu, buf);
+}
+
+static void ar6000_set_host_sleep_mode_callback(void *ptr)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)ptr;
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("%s: set host sleep mode cmd processed event arrived", __func__));
+ ar->sleep_mode_cmd_completed = TRUE;
+ wake_up(&(ar->sleep_mode_cmd_completed_event));
+}
+
+static void ar6000_wow_resume(AR_SOFTC_T *ar)
+{
+ HIF_DEVICE_POWER_CHANGE_TYPE config;
+ AR_SOFTC_DEV_T *arPriv;
+ AR_SOFTC_STA_T *arSta;
+ A_UINT8 i;
+
+ if (ar->arWowState!= WLAN_WOW_STATE_NONE) {
+ config = HIF_DEVICE_POWER_UP;
+ HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_POWER_STATE_CHANGE,
+ &config,
+ sizeof(HIF_DEVICE_POWER_CHANGE_TYPE));
+
+ }
+
+ for(i = 0; i < num_device; i++) {
+ arPriv = ar->arDev[i];
+ arSta = &arPriv->arSta;
+
+ /*
+ * Free all wlan_nodes (scanned APs that we detected previously)
+ * because during the time we were suspended, the device may have
+ * been moved to a new location and these APs scanned for before
+ * suspend may not be valid
+ */
+ wmi_free_allnodes(arPriv->arWmi);
+
+ if (ar->arWowState!= WLAN_WOW_STATE_NONE) {
+ A_UINT16 fg_start_period = (arSta->scParams.fg_start_period==0) ? 1 : arSta->scParams.fg_start_period;
+ A_UINT16 bg_period = (arSta->scParams.bg_period==0) ? 60 : arSta->scParams.bg_period;
+ WMI_SET_HOST_SLEEP_MODE_CMD hostSleepMode = {TRUE, FALSE};
+ ar->arWowState = WLAN_WOW_STATE_NONE;
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock_timeout(&ar6k_wow_wake_lock, 5);
+#endif
+ /*
+ * Clear the callback function. We do not need to wait while resuming.
+ */
+ wmi_set_host_sleep_mode_event_fn_ptr(arPriv->arWmi, NULL, NULL);
+ if (wmi_set_host_sleep_mode_cmd(arPriv->arWmi, &hostSleepMode)!=A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to setup restore host awake\n"));
+ }
+
+ if (arPriv->arNetworkType!=AP_NETWORK) {
+#if WOW_SET_SCAN_PARAMS
+ wmi_scanparams_cmd(arPriv->arWmi, fg_start_period,
+ arSta->scParams.fg_end_period,
+ bg_period,
+ arSta->scParams.minact_chdwell_time,
+ arSta->scParams.maxact_chdwell_time,
+ arSta->scParams.pas_chdwell_time,
+ arSta->scParams.shortScanRatio,
+ arSta->scParams.scanCtrlFlags,
+ arSta->scParams.max_dfsch_act_time,
+ arSta->scParams.maxact_scan_per_ssid);
+#else
+ (void)fg_start_period;
+ (void)bg_period;
+#endif
+
+
+#if WOW_ENABLE_MAX_INTERVAL /* we don't do it if the power consumption is already good enough. */
+ if (wmi_listeninterval_cmd(arPriv->arWmi, arSta->arListenIntervalT, arSta->arListenIntervalB) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to restore WoW listen interval %d\n", arSta->arListenIntervalT));
+ } else {
+ if (wmi_bmisstime_cmd(arPriv->arWmi, arSta->arBmissTimeT, arSta->arBmissTimeB) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to restore WoW bmiss %d\n", arSta->arBmissTimeT));
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("WoW does not invoked. skip resume"));
+ }
+#endif
+ }
+ ar6k_send_asleep_event_to_app(arPriv, FALSE);
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("Resume WoW successfully\n"));
+ ar->isHostAsleep = 0;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("WoW does not invoked. skip resume"));
+ }
+ }
+
+ ar->arWlanPowerState = WLAN_POWER_STATE_ON;
+}
+
+static void ar6000_wow_suspend(AR_SOFTC_T *ar)
+{
+ struct net_device *ndev;
+ AR_SOFTC_DEV_T *arPriv;
+ AR_SOFTC_STA_T *arSta;
+ A_INT32 i, j;
+ A_STATUS status;
+ A_UINT32 timeremaining;
+#define WOW_LIST_ID 1
+ /* Setup WoW for unicast & Arp request for our own IP
+ * disable background scan. Set listen interval into 1000 TUs
+ * Enable keepliave for 110 seconds
+ */
+ struct in_ifaddr **ifap = NULL;
+ struct in_ifaddr *ifa = NULL;
+ HIF_DEVICE_POWER_CHANGE_TYPE config;
+ struct in_device *in_dev;
+ WMI_ADD_WOW_PATTERN_CMD addWowCmd = { .filter = { 0 } };
+ WMI_DEL_WOW_PATTERN_CMD delWowCmd;
+ WMI_SET_HOST_SLEEP_MODE_CMD hostSleepMode = {FALSE, TRUE};
+ WMI_SET_WOW_MODE_CMD wowMode = { .enable_wow = TRUE,
+ .hostReqDelay = 500 };/*500 ms delay*/
+
+ if (ar->arWowState!= WLAN_WOW_STATE_NONE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("System already go into wow mode!\n"));
+ return;
+ }
+
+ ar6000_TxDataCleanup(ar); /* IMPORTANT, otherwise there will be 11mA after listen interval as 1000*/
+
+ for(j = 0; j< num_device; j++)
+ {
+ arPriv = ar->arDev[j];
+ arSta = &arPriv->arSta;
+ ndev = arPriv->arNetDev;
+ /* clear up our WoW pattern first */
+ for (i=0; i<WOW_MAX_FILTERS_PER_LIST; ++i) {
+ delWowCmd.filter_list_id = WOW_LIST_ID;
+ delWowCmd.filter_id = i;
+ wmi_del_wow_pattern_cmd(arPriv->arWmi, &delWowCmd);
+ }
+
+ if (arPriv->arNetworkType == AP_NETWORK) {
+ /* setup all unicast IP packet pattern for WoW */
+#if WLAN_CONFIG_SIMPLE_WOW_AP_MODE
+ /* IP packets except boradcast */
+ A_UINT8 allData[] = { 0x08 }; /* Either IP 0x0800, ARP 0x0806 or EAPOL-like 0x8800 */
+ A_UINT8 allMask[] = { 0x7f };
+ A_MEMZERO(&addWowCmd, sizeof(addWowCmd));
+ addWowCmd.filter_list_id = WOW_LIST_ID;
+ addWowCmd.filter_size = sizeof(allMask);
+ addWowCmd.filter_offset = 20;
+ status = wmi_add_wow_pattern_cmd(ar->arWmi, &addWowCmd, allData, allMask, addWowCmd.filter_size);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to add WoW simple pattern for AP mode\n"));
+ }
+#else
+ /* Unicast IP, EAPOL-like and ARP packets */
+ A_UINT8 unicastData[] = {
+ 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
+ 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x08, };
+ A_UINT8 unicastMask[] = {
+ 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
+ 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x7f };
+ A_UINT8 discoverData[] = { 0xe0, 0x00, 0x00, 0xf8 };
+ A_UINT8 discoverMask[] = { 0xf0, 0x00, 0x00, 0xf8 };
+ A_UINT8 arpData[] = { 0x08, 0x06 };
+ A_UINT8 arpMask[] = { 0xff, 0xff };
+ A_UINT8 dhcpData[] = {
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
+ 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x08, 0x00,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x00, 0x00, 0x00, 0x43 /* port 67 */
+ };
+ A_UINT8 dhcpMask[] = {
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
+ 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0xff, 0xff,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x00, 0x00, 0xff, 0xff /* port 67 */
+ };
+ A_MEMZERO(&addWowCmd, sizeof(addWowCmd));
+ addWowCmd.filter_list_id = WOW_LIST_ID;
+ addWowCmd.filter_size = sizeof(unicastMask);
+ addWowCmd.filter_offset = 0;
+ status = wmi_add_wow_pattern_cmd(arPriv->arWmi, &addWowCmd, unicastData, unicastMask, addWowCmd.filter_size);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to add WoW unicast IP pattern for AP mode\n"));
+ }
+ /* setup all ARP packet pattern for WoW */
+ A_MEMZERO(&addWowCmd, sizeof(addWowCmd));
+ addWowCmd.filter_list_id = WOW_LIST_ID;
+ addWowCmd.filter_size = sizeof(arpMask);
+ addWowCmd.filter_offset = 20;
+ status = wmi_add_wow_pattern_cmd(arPriv->arWmi, &addWowCmd, arpData, arpMask, addWowCmd.filter_size);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to add WoW ARP pattern for AP mode\n"));
+ }
+ /* Setup multicast pattern for mDNS 224.0.0.251, SSDP 239.255.255.250 and LLMNR 224.0.0.252*/
+ A_MEMZERO(&addWowCmd, sizeof(addWowCmd));
+ addWowCmd.filter_list_id = WOW_LIST_ID;
+ addWowCmd.filter_size = sizeof(discoverMask);
+ addWowCmd.filter_offset = 38;
+ status = wmi_add_wow_pattern_cmd(arPriv->arWmi, &addWowCmd, discoverData, discoverMask, addWowCmd.filter_size);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to add mDNS/SSDP/LLMNR pattern for AP mode WoW\n"));
+ }
+ /* setup all DHCP broadcast packet pattern for WoW */
+ A_MEMZERO(&addWowCmd, sizeof(addWowCmd));
+ addWowCmd.filter_list_id = WOW_LIST_ID;
+ addWowCmd.filter_size = sizeof(dhcpMask);
+ addWowCmd.filter_offset = 0;
+ status = wmi_add_wow_pattern_cmd(arPriv->arWmi, &addWowCmd, dhcpData, dhcpMask, addWowCmd.filter_size);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to add WoW DHCP broadcast pattern for AP mode\n"));
+ }
+#endif /* WLAN_CONFIG_SIMPLE_WOW_AP_MODE */
+ } else {
+ /* station mode */
+ A_UINT8 macMask[] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
+ A_UINT16 wow_listen_interval = A_MAX_WOW_LISTEN_INTERVAL;
+#if WOW_ENABLE_MAX_INTERVAL /* we don't do it if the power consumption is already good enough. */
+ if (wmi_listeninterval_cmd(arPriv->arWmi, wow_listen_interval, 0) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to setup WoW listen interval %d\n", wow_listen_interval));
+ } else {
+ /*
+ * The default bmiss is 1500ms when listen interval is 100ms
+ * We set listen interval x 15 times as bmiss time here
+ */
+ A_UINT16 bmissTime = wow_listen_interval*15;
+ if (bmissTime > MAX_BMISS_TIME) {
+ bmissTime = MAX_BMISS_TIME;
+ }
+ if (wmi_bmisstime_cmd(arPriv->arWmi, bmissTime, 0) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to setup WoW bmiss %d\n", bmissTime));
+ }
+ }
+#else
+ (void)wow_listen_interval;
+#endif
+
+#if WOW_SET_SCAN_PARAMS
+ status = wmi_scanparams_cmd(arPriv->arWmi, 0xFFFF, 0, 0xFFFF, 0, 0, 0, 0, 0, 0, 0);
+#endif
+ /* setup unicast packet pattern for WoW */
+ if (ndev->dev_addr[1]) {
+ A_MEMZERO(&addWowCmd, sizeof(addWowCmd));
+ addWowCmd.filter_list_id = WOW_LIST_ID;
+ addWowCmd.filter_size = 6; /* MAC address */
+ addWowCmd.filter_offset = 0;
+ status = wmi_add_wow_pattern_cmd(arPriv->arWmi, &addWowCmd, ndev->dev_addr, macMask, addWowCmd.filter_size);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to add WoW pattern\n"));
+ }
+ }
+
+ /* Setup multicast pattern for mDNS 224.0.0.251, SSDP 239.255.255.250 and LLMNR 224.0.0.252*/
+ if ( ndev->flags & IFF_ALLMULTI ||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
+ (ndev->flags & IFF_MULTICAST && ndev->mc_count>0) )
+#else
+ (ndev->flags & IFF_MULTICAST && netdev_mc_count(ndev)>0) )
+#endif
+ {
+ A_UINT8 discoverData[] = { 0xe0, 0x00, 0x00, 0xf8 };
+ A_UINT8 discoverMask[] = { 0xf0, 0x00, 0x00, 0xf8 };
+ A_MEMZERO(&addWowCmd, sizeof(addWowCmd));
+ addWowCmd.filter_list_id = WOW_LIST_ID;
+ addWowCmd.filter_size = sizeof(discoverMask);
+ addWowCmd.filter_offset = 38;
+ status = wmi_add_wow_pattern_cmd(arPriv->arWmi, &addWowCmd, discoverData, discoverMask, addWowCmd.filter_size);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to add mDNS/SSDP/LLMNR pattern for WoW\n"));
+ }
+ }
+
+ ar6k_send_asleep_event_to_app(arPriv, TRUE);
+ }
+
+ ar->arWowState = WLAN_WOW_STATE_SUSPENDING;
+
+ /* setup ARP request for our own IP */
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15)
+ if ((in_dev = __in_dev_get_rtnl(ndev)) != NULL) {
+ for (ifap = &in_dev->ifa_list; (ifa = *ifap) != NULL; ifap = &ifa->ifa_next) {
+ if (!strcmp(ndev->name, ifa->ifa_label)) {
+ break; /* found */
+ }
+ }
+ }
+#endif
+
+ if (ifa && ifa->ifa_local) {
+ WMI_SET_IP_CMD ipCmd;
+ memset(&ipCmd, 0, sizeof(ipCmd));
+ ipCmd.ips[0] = ifa->ifa_local;
+ status = wmi_set_ip_cmd(arPriv->arWmi, &ipCmd);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to setup IP for ARP agent\n"));
+ }
+ }
+
+#ifndef ATH6K_CONFIG_OTA_MODE
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6K: %s: psm.info is %d (0: MAX_PERF_POWER, 1:REC_POWER)\n", __FUNCTION__, psm_info));
+ wmi_powermode_cmd_w_psminfo(arPriv->arWmi, psm_info, REC_POWER);
+#endif
+
+ status = wmi_set_wow_mode_cmd(arPriv->arWmi, &wowMode);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to enable wow mode\n"));
+ }
+ /*
+ * Set the callback function for processing of the last WMI command before suspending,
+ * so that we can wait for the HTC credit report to come in before proceeding.
+ */
+ ar->sleep_mode_cmd_completed = FALSE;
+ wmi_set_host_sleep_mode_event_fn_ptr(arPriv->arWmi, ar6000_set_host_sleep_mode_callback, ar);
+ status = wmi_set_host_sleep_mode_cmd(arPriv->arWmi, &hostSleepMode);
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to set host asleep\n"));
+ }
+
+ /*
+ * Wait for the WMI_SET_HOST_SLEEP_MODE_CMD_PROCESSED_EVENTID to come in. This is
+ * guaranteed to happen either AFTER the credit report for the
+ * WMI_SET_HOST_SLEEP_MODE_CMD arrives, or simultaneously along with the event.
+ * This should never take longer than a few ms, so if 2 seconds have elapsed and
+ * we still do not get the event, there's a problem with the WLAN chip. Just continue,
+ * (the user will have to unload the driver manually). It's better than taking down
+ * the entire OS.
+ */
+ timeremaining = wait_event_interruptible_timeout(ar->sleep_mode_cmd_completed_event, (ar->sleep_mode_cmd_completed == TRUE), 2*HZ);
+ if (!timeremaining) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Expected a WMI_SET_HOST_SLEEP_MODE_CMD_PROCESSED event but it never arrived\n"));
+ }
+
+ if (ar->arTxPending[ar->arControlEp]) {
+ A_UINT32 timeleft = wait_event_interruptible_timeout(arPriv->arEvent,
+ ar->arTxPending[ar->arControlEp] == 0, wmitimeout * HZ);
+ if (!timeleft || signal_pending(current)) {
+ /* what can I do? wow resume at once */
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to setup WoW. Pending wmi control data %d\n", ar->arTxPending[ar->arControlEp]));
+ }
+ }
+ }
+
+ status = hifWaitForPendingRecv(ar->arHifDevice);
+
+ config = HIF_DEVICE_POWER_DOWN;
+ status = HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_POWER_STATE_CHANGE,
+ &config,
+ sizeof(HIF_DEVICE_POWER_CHANGE_TYPE));
+
+ ar->arWowState = WLAN_WOW_STATE_SUSPENDED;
+ ar->arWlanPowerState = WLAN_POWER_STATE_WOW;
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("Setup WoW successfully\n"));
+}
+
+A_STATUS ar6000_suspend_ev(void *context)
+{
+ A_STATUS status = A_OK;
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)context;
+ A_INT16 pmmode = ar->arSuspendConfig;
+ A_INT32 i;
+ A_BOOL needWow = FALSE;
+wow_not_connected:
+ switch (pmmode) {
+ case WLAN_SUSPEND_WOW:
+ for(i = 0; i< num_device; i++) {
+ if (ar->arDev[i]->arConnected) {
+ needWow = TRUE;
+ break;
+ }
+ }
+ if (ar->arWmiReady && ar->arWlanState==WLAN_ENABLED && needWow) {
+ ar6000_wow_suspend(ar);
+ status = A_EBUSY;
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM,("%s:Suspend for wow mode %d\n", __func__, ar->arWlanPowerState));
+ } else {
+ pmmode = ar->arWow2Config;
+ goto wow_not_connected;
+ }
+ break;
+ case WLAN_SUSPEND_CUT_PWR:
+ /* fall through */
+ case WLAN_SUSPEND_CUT_PWR_IF_BT_OFF:
+ /* fall through */
+ case WLAN_SUSPEND_DEEP_SLEEP:
+ /* fall through */
+ default:
+ status = ar6000_update_wlan_pwr_state(ar, WLAN_DISABLED, TRUE);
+ if (ar->arWlanPowerState==WLAN_POWER_STATE_ON ||
+ ar->arWlanPowerState==WLAN_POWER_STATE_WOW) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("Strange suspend state for not wow mode %d", ar->arWlanPowerState));
+ }
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM,("%s:Suspend for %d mode pwr %d status %d\n", __func__, pmmode, ar->arWlanPowerState, status));
+ if (ar->arWlanPowerState==WLAN_POWER_STATE_CUT_PWR) {
+ status = A_OK;
+ } else {
+ status = A_EBUSY; /* don't let mmc call sdio_init after resume */
+ }
+ break;
+ }
+
+ for(i = 0; i < num_device; i++) {
+ AR_SOFTC_DEV_T *arPriv = ar->arDev[i];
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ if (arSta->scan_triggered) {
+ ar6000_scanComplete_event(arPriv, A_OK);
+ }
+ }
+ return status;
+}
+
+A_STATUS ar6000_resume_ev(void *context)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)context;
+ A_UINT16 powerState = ar->arWlanPowerState;
+
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock(&ar6k_suspend_wake_lock);
+#endif
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("%s: enter previous state %d wowState %d\n", __func__, powerState, ar->arWowState));
+ switch (powerState) {
+ case WLAN_POWER_STATE_WOW:
+ ar6000_wow_resume(ar);
+ break;
+ case WLAN_POWER_STATE_CUT_PWR:
+ /* fall through */
+ case WLAN_POWER_STATE_DEEP_SLEEP:
+ ar6000_update_wlan_pwr_state(ar, WLAN_ENABLED, TRUE);
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM,("%s:Resume for %d mode pwr %d\n", __func__, powerState, ar->arWlanPowerState));
+ break;
+ case WLAN_POWER_STATE_ON:
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Strange SDIO bus power mode!!\n"));
+ break;
+ }
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_unlock(&ar6k_suspend_wake_lock);
+#endif
+ return A_OK;
+}
+
+void ar6000_check_wow_status(AR_SOFTC_T *ar, struct sk_buff *skb, A_BOOL isEvent)
+{
+ /* EV85521 */
+ if (in_interrupt()) {
+ if (ar->arWowState == WLAN_WOW_STATE_SUSPENDED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN, ("AR6K: %s called in interrupt context\n", __func__));
+ }
+ return;
+ }
+
+ if (ar->arWowState != WLAN_WOW_STATE_NONE) {
+ if (ar->arWowState==WLAN_WOW_STATE_SUSPENDING) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM,("\n%s: Received IRQ while we are wow suspending!!!\n\n", __func__));
+ return;
+ }
+ /* Wow resume from irq interrupt */
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("%s: WoW resume from irq thread status %d\n", __func__, ar->arWlanPowerState));
+ ar6000_wow_resume(ar);
+ } else {
+#ifdef ANDROID_ENV
+ android_ar6k_check_wow_status(ar, skb, isEvent);
+#endif
+ }
+}
+
+A_STATUS ar6000_power_change_ev(void *context, A_UINT32 config)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)context;
+ A_STATUS status = A_OK;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("%s: power change event callback %d \n", __func__, config));
+ switch (config) {
+ case HIF_DEVICE_POWER_UP:
+ ar6000_restart_endpoint(ar);
+#ifdef ANDROID_ENV
+ ar->arResumeDone = TRUE;
+ wake_up(&(ar->arDev[0]->arEvent));
+#endif /* ANDROID_ENV */
+ status = A_OK;
+ break;
+ case HIF_DEVICE_POWER_DOWN:
+ case HIF_DEVICE_POWER_CUT:
+ status = A_OK;
+ break;
+ }
+ return status;
+}
+
+#if PLAT_WOW_GPIO_PIN
+static irqreturn_t
+ar6000_wow_irq(int irq, void *dev_id)
+{
+ gpio_clear_detect_status(wow_irq);
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock_timeout(&ar6k_wow_wake_lock, 3*HZ);
+#else
+ /* TODO: What should I do if there is no wake lock?? */
+#endif
+ return IRQ_HANDLED;
+}
+#endif /* PLAT_WOW_GPIO_PIN */
+
+#if PLAT_WLAN_CHIP_PWD_PIN
+void plat_setup_power_stub(AR_SOFTC_T *ar, int on, int detect)
+{
+ A_BOOL chip_pwd_low_val;
+
+ if (on) {
+ chip_pwd_low_val = 1;
+ } else {
+ chip_pwd_low_val = 0;
+ }
+ ambarella_set_gpio_output(&ambarella_board_generic.wifi_power, chip_pwd_low_val);
+
+}
+#endif /* PLAT_WLAN_CHIP_PWD_PIN */
+
+#if defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM9615)
+
+struct wlan_regulator {
+ const char *vreg_name; /* Regulator Name */
+ int min_uV; /* Minimum voltage at which AR6003 can operate */
+ int max_uV; /* Maximum voltage at which AR6003 can operate */
+ int load_uA; /* Current which will be drawn from regulator (Worst case) */
+ int delay_mT; /* Time from this operation to next */
+ struct regulator *vreg; /* Regulator Handle */
+};
+
+
+static struct wlan_regulator regulator_table[] = {
+ {"wlan_vreg", 1710000, 1890000, 86000, 5, NULL}
+};
+
+static void msm9615_wifi_power_down(struct wlan_regulator *regulators, A_UINT32 size)
+{
+ int rc = 0;
+ int i;
+
+ if (!regulators) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("msm9615_wifi_power_down: NULL pointer passed!!!\n"));
+ return;
+ }
+
+ for (i = size - 1; i >= 0; i--) {
+
+ if (!regulators[i].vreg) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("msm9615_wifi_power_down: vreg is NULL!!!\n"));
+ continue;
+ }
+
+ rc = regulator_disable(regulators[i].vreg);
+
+ if (rc) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to disable regulator: %s, rc: %d\n",
+ regulators[i].vreg_name, rc));
+ }
+
+ rc = regulator_set_voltage(regulators[i].vreg, 0, regulators[i].max_uV);
+
+ if (rc) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to set regulator voltage: %s, rc: %d\n",
+ regulators[i].vreg_name, rc));
+ }
+
+ rc = regulator_set_optimum_mode(regulators[i].vreg, 0);
+
+ if (rc < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to set regulator optimum mode: %s, rc: %d\n",
+ regulators[i].vreg_name, rc));
+ }
+
+ regulator_put(regulators[i].vreg);
+ regulators[i].vreg = NULL;
+ }
+}
+
+static int msm9615_wifi_power_up(struct wlan_regulator *regulators, A_UINT32 size)
+{
+ int rc = 0;
+ int i = 0;
+
+ if (!g_pdev) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("msm9615_wifi_power_up: Platform device is NULL!!!\n"));
+ rc = -ENODEV;
+ goto fail;
+ }
+
+ if (!regulators) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("msm9615_wifi_power_up: NULL pointer passed!!!"));
+ rc = -EINVAL;
+ goto fail;
+ }
+
+ for (i = 0; i < size; i++) {
+
+ regulators[i].vreg = regulator_get(&g_pdev->dev, regulators[i].vreg_name);
+
+ if (!regulators[i].vreg || IS_ERR(regulators[i].vreg)) {
+ rc = PTR_ERR(regulators[i].vreg);
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to get regulator: %s, rc: %d\n",
+ regulators[i].vreg_name, rc));
+ regulators[i].vreg = NULL;
+ goto fail;
+ }
+
+ rc = regulator_set_voltage(regulators[i].vreg, regulators[i].min_uV, regulators[i].max_uV);
+
+ if (rc) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to set regulator voltage: %s, rc: %d\n",
+ regulators[i].vreg_name, rc));
+ goto fail;
+ }
+
+ rc = regulator_set_optimum_mode(regulators[i].vreg, regulators[i].load_uA);
+
+ if (rc < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to set regulator optimum mode: %s, rc: %d\n",
+ regulators[i].vreg_name, rc));
+ goto fail;
+ }
+
+ rc = regulator_enable(regulators[i].vreg);
+ if (rc) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Failed to enable regulator: %s, rc: %d\n",
+ regulators[i].vreg_name, rc));
+ goto fail;
+ }
+
+ A_MDELAY(regulators[i].delay_mT);
+ }
+
+ return rc;
+
+fail:
+ msm9615_wifi_power_down(regulators, i + 1);
+ return rc;
+}
+
+static struct gpio wifi_gpios[] = {
+ { MSM9615_WLAN_PM_ENABLE_PIN, GPIOF_OUT_INIT_LOW, "wlan_pm_enable" },
+ { MSM9615_WLAN_CHIP_PWD_PIN, GPIOF_OUT_INIT_LOW, "wlan_chip_pwd_l" },
+};
+
+int msm9615_wifi_power(AR_SOFTC_T *ar, int on)
+{
+ int rc = 0;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("msm9615_wifi_power: %s\n", on ? "on" : "off"));
+
+ do {
+ if (on) {
+ rc = msm9615_wifi_power_up(regulator_table, ARRAY_SIZE(regulator_table));
+
+ if (rc) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("msm9615_wifi_power: Power UP failed!!!\n"));
+ break;
+ }
+
+ rc = gpio_request_array(wifi_gpios, ARRAY_SIZE(wifi_gpios));
+
+ if (rc) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Cannot request GPIO!!!"));
+
+ msm9615_wifi_power_down(regulator_table, ARRAY_SIZE(regulator_table));
+ break;
+ }
+
+ gpio_set_value(MSM9615_WLAN_PM_ENABLE_PIN, 1);
+ A_MDELAY(100);
+ gpio_set_value(MSM9615_WLAN_CHIP_PWD_PIN, 1);
+ } else {
+
+ gpio_set_value(MSM9615_WLAN_CHIP_PWD_PIN, 0);
+ gpio_set_value(MSM9615_WLAN_PM_ENABLE_PIN, 0);
+
+ gpio_free_array(wifi_gpios, ARRAY_SIZE(wifi_gpios));
+
+ msm9615_wifi_power_down(regulator_table, ARRAY_SIZE(regulator_table));
+ }
+
+ } while (0);
+
+ return rc;
+}
+#endif /* defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM9615) */
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15)
+static int ar6000_pm_probe(struct platform_device *pdev)
+{
+
+ g_pdev = pdev;
+
+ plat_setup_power(NULL, 1, 1);
+ return 0;
+}
+
+static int ar6000_pm_remove(struct platform_device *pdev)
+{
+ plat_setup_power(NULL, 0, 1);
+ return 0;
+}
+
+static int ar6000_pm_suspend(struct platform_device *pdev, pm_message_t state)
+{
+ return 0;
+}
+
+static int ar6000_pm_resume(struct platform_device *pdev)
+{
+ int i;
+ extern struct net_device *ar6000_devices[MAX_AR6000];
+
+ for (i=0; ar6000_devices[i]; ++i) {
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ar6000_devices[i]);
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)arPriv->arSoftc;
+
+ if (ar && ar->arPlatPowerOff) {
+ A_BOOL wlanOff = ar->arWlanOff;
+ A_UINT16 powerState = ar->arWlanPowerState;
+ A_BOOL btOff = ar->arBTOff;
+
+ if (!wlanOff) {
+ if (powerState == WLAN_POWER_STATE_CUT_PWR) {
+ plat_setup_power(ar, 1, 0);
+ ar->arPlatPowerOff = FALSE;
+ }
+ }
+#ifdef CONFIG_PM
+ else if (wlanOff) {
+ A_BOOL allowCutPwr = ((!ar->arBTSharing) || btOff);
+ if ((powerState==WLAN_POWER_STATE_CUT_PWR) && (!allowCutPwr)) {
+ plat_setup_power(ar, 1, 0);
+ ar->arPlatPowerOff = FALSE;
+ }
+ }
+#endif /* CONFIG_PM */
+ }
+ }
+ return 0;
+}
+
+static struct platform_driver ar6000_pm_device = {
+ .probe = ar6000_pm_probe,
+ .remove = ar6000_pm_remove,
+ .suspend = ar6000_pm_suspend,
+ .resume = ar6000_pm_resume,
+ .driver = {
+ .name = "wlan_ar6000_pm_dev",
+ },
+};
+#endif
+#endif /* CONFIG_PM */
+
+A_STATUS
+ar6000_setup_cut_power_state(struct ar6_softc *ar, AR6000_WLAN_STATE state)
+{
+ A_STATUS status = A_OK;
+ HIF_DEVICE_POWER_CHANGE_TYPE config;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("%s: Cut power %d %d \n", __func__,state, ar->arWlanPowerState));
+#ifdef CONFIG_PM
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("Wlan OFF %d BT OFf %d \n", ar->arWlanOff, ar->arBTOff));
+#endif
+ do {
+ if (state == WLAN_ENABLED) {
+ /* Not in cut power state.. exit */
+ if (ar->arWlanPowerState != WLAN_POWER_STATE_CUT_PWR) {
+ break;
+ }
+
+ if (ar->arPlatPowerOff) {
+ plat_setup_power(ar, 1, 0);
+ ar->arPlatPowerOff = FALSE;
+ }
+
+ /* Change the state to ON */
+ ar->arWlanPowerState = WLAN_POWER_STATE_ON;
+
+#ifdef ANDROID_ENV
+ ar->arResumeDone = FALSE;
+#endif /* ANDROID_ENV */
+
+ /* Indicate POWER_UP to HIF */
+ config = HIF_DEVICE_POWER_UP;
+ status = HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_POWER_STATE_CHANGE,
+ &config,
+ sizeof(HIF_DEVICE_POWER_CHANGE_TYPE));
+
+ if (status == A_PENDING) {
+#ifdef ANDROID_ENV
+ /* Wait for resume done event */
+ A_UINT32 timeleft = wait_event_interruptible_timeout(ar->arDev[0]->arEvent,
+ (ar->arResumeDone == TRUE), wmitimeout * HZ);
+ if (!timeleft || signal_pending(current)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000 : Failed to get resume done event \n"));
+ status = A_ERROR;
+ break;
+ }
+#endif
+ status = A_OK;
+ } else if (status == A_OK) {
+ ar6000_restart_endpoint(ar);
+#ifdef ANDROID_ENV
+ ar->arResumeDone = TRUE;
+#endif /* ANDROID_ENV */
+ status = A_OK;
+ }
+ } else if (state == WLAN_DISABLED) {
+
+
+ /* Already in cut power state.. exit */
+ if (ar->arWlanPowerState == WLAN_POWER_STATE_CUT_PWR) {
+ break;
+ }
+ ar6000_stop_endpoint(ar, TRUE, FALSE);
+
+ config = HIF_DEVICE_POWER_CUT;
+ status = HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_POWER_STATE_CHANGE,
+ &config,
+ sizeof(HIF_DEVICE_POWER_CHANGE_TYPE));
+
+ plat_setup_power(ar, 0, 0);
+ ar->arPlatPowerOff = TRUE;
+
+ ar->arWlanPowerState = WLAN_POWER_STATE_CUT_PWR;
+ }
+ } while (0);
+
+ return status;
+}
+
+A_STATUS
+ar6000_setup_deep_sleep_state(struct ar6_softc *ar, AR6000_WLAN_STATE state)
+{
+ A_STATUS status = A_OK;
+
+ HIF_DEVICE_POWER_CHANGE_TYPE config;
+ AR_SOFTC_DEV_T *arPriv;
+ AR_SOFTC_STA_T *arSta;
+ A_UINT8 i;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("%s: Deep sleep %d %d \n", __func__,state, ar->arWlanPowerState));
+#ifdef CONFIG_PM
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("Wlan OFF %d BT OFf %d \n", ar->arWlanOff, ar->arBTOff));
+#endif
+ do {
+ WMI_SET_HOST_SLEEP_MODE_CMD hostSleepMode;
+
+ if (state == WLAN_ENABLED) {
+ A_UINT16 fg_start_period;
+
+ /* Not in deep sleep state.. exit */
+ if (ar->arWlanPowerState != WLAN_POWER_STATE_DEEP_SLEEP) {
+ if (ar->arWlanPowerState != WLAN_POWER_STATE_ON) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Strange state when we resume from deep sleep %d\n", ar->arWlanPowerState));
+ }
+ break;
+ }
+
+ /* Indicate POWER_UP to HIF */
+ config = HIF_DEVICE_POWER_UP;
+ status = HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_POWER_STATE_CHANGE,
+ &config,
+ sizeof(HIF_DEVICE_POWER_CHANGE_TYPE));
+
+ for(i = 0; i < num_device; i++)
+ {
+ arPriv = ar->arDev[i];
+ arSta = &arPriv->arSta;
+
+ /*
+ * Free all wlan_nodes (scanned APs that we detected previously)
+ * because during the time we were suspended, the device may have
+ * been moved to a new location and these APs scanned for before
+ * suspend may not be valid
+ */
+ wmi_free_allnodes(arPriv->arWmi);
+
+ fg_start_period = (arSta->scParams.fg_start_period==0) ? 1 : arSta->scParams.fg_start_period;
+ hostSleepMode.awake = TRUE;
+ hostSleepMode.asleep = FALSE;
+
+ /*
+ * Clear the callback function. We do not need to wait while resuming.
+ */
+ wmi_set_host_sleep_mode_event_fn_ptr(arPriv->arWmi, NULL, NULL);
+ if ((status=wmi_set_host_sleep_mode_cmd(arPriv->arWmi, &hostSleepMode)) != A_OK) {
+ break;
+ }
+
+ /* Change the state to ON */
+ ar->arWlanPowerState = WLAN_POWER_STATE_ON;
+
+ /* Enable foreground scanning */
+ if ((status=wmi_scanparams_cmd(arPriv->arWmi, fg_start_period,
+ arSta->scParams.fg_end_period,
+ arSta->scParams.bg_period,
+ arSta->scParams.minact_chdwell_time,
+ arSta->scParams.maxact_chdwell_time,
+ arSta->scParams.pas_chdwell_time,
+ arSta->scParams.shortScanRatio,
+ arSta->scParams.scanCtrlFlags,
+ arSta->scParams.max_dfsch_act_time,
+ arSta->scParams.maxact_scan_per_ssid)) != A_OK)
+ {
+ break;
+ }
+
+ if (arPriv->arSsidLen) {
+ if (ar6000_connect_to_ap(arPriv) != A_OK) {
+ /* no need to report error if connection failed */
+ break;
+ }
+ }
+ }
+ } else if (state == WLAN_DISABLED){
+#ifdef CONFIG_PM
+ A_UINT32 timeremaining;
+#endif
+ WMI_SET_WOW_MODE_CMD wowMode = { .enable_wow = FALSE };
+
+ /* Already in deep sleep state.. exit */
+ if (ar->arWlanPowerState != WLAN_POWER_STATE_ON) {
+ if (ar->arWlanPowerState != WLAN_POWER_STATE_DEEP_SLEEP) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Strange state when we suspend for deep sleep %d\n", ar->arWlanPowerState));
+ }
+ break;
+ }
+
+ for(i = 0; i < num_device; i++)
+ {
+ arPriv = ar->arDev[i];
+ arSta = &arPriv->arSta;
+ /* make sure we disable wow for deep sleep */
+ if ((status=wmi_set_wow_mode_cmd(arPriv->arWmi, &wowMode))!=A_OK) {
+ break;
+ }
+
+ /* Disconnect from the AP and disable foreground scanning */
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ if (arPriv->arConnected == TRUE || arSta->arConnectPending == TRUE) {
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ ar6000_disconnect(arPriv);
+ } else {
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ }
+
+ if ((status=wmi_scanparams_cmd(arPriv->arWmi, 0xFFFF, 0, 0, 0, 0, 0, 0, 0, 0, 0)) != A_OK) {
+ break;
+ }
+ ar6000_TxDataCleanup(ar);
+#ifndef ATH6K_CONFIG_OTA_MODE
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6K: %s: psm.info is %d (0: MAX_PERF_POWER, 1:REC_POWER)\n", __FUNCTION__, psm_info));
+ wmi_powermode_cmd_w_psminfo(arPriv->arWmi, psm_info, REC_POWER);
+#endif
+
+ hostSleepMode.awake = FALSE;
+ hostSleepMode.asleep = TRUE;
+
+#ifdef CONFIG_PM
+ /*
+ * Set the callback function for processing of the last WMI command before suspending,
+ * so that we can wait for the HTC credit report to come in before proceeding.
+ */
+ ar->sleep_mode_cmd_completed = FALSE;
+ wmi_set_host_sleep_mode_event_fn_ptr(arPriv->arWmi, ar6000_set_host_sleep_mode_callback, ar);
+ if ((status=wmi_set_host_sleep_mode_cmd(arPriv->arWmi, &hostSleepMode))!=A_OK) {
+ break;
+ }
+
+ /*
+ * Wait for the WMI_SET_HOST_SLEEP_MODE_CMD_PROCESSED_EVENTID to come in. This is
+ * guaranteed to happen either AFTER the credit report for the
+ * WMI_SET_HOST_SLEEP_MODE_CMD arrives, or simultaneously along with the event.
+ * This should never take longer than a few ms, so if 2 seconds have elapsed and
+ * we still do not get the event, there's a problem with the WLAN chip. Just continue,
+ * (the user will have to unload the driver manually). It's better than taking down
+ * the entire OS.
+ */
+ timeremaining = wait_event_interruptible_timeout(ar->sleep_mode_cmd_completed_event, (ar->sleep_mode_cmd_completed == TRUE), 2*HZ);
+ if (!timeremaining) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Expected a WMI_SET_HOST_SLEEP_MODE_CMD_PROCESSED event but it never arrived\n"));
+ }
+
+ if (ar->arTxPending[ar->arControlEp]) {
+ A_UINT32 timeleft = wait_event_interruptible_timeout(arPriv->arEvent,
+ ar->arTxPending[ar->arControlEp] == 0, wmitimeout * HZ);
+ if (!timeleft || signal_pending(current)) {
+ status = A_ERROR;
+ break;
+ }
+ }
+#endif
+ }
+ status = hifWaitForPendingRecv(ar->arHifDevice);
+
+ config = HIF_DEVICE_POWER_DOWN;
+ status = HIFConfigureDevice(ar->arHifDevice,
+ HIF_DEVICE_POWER_STATE_CHANGE,
+ &config,
+ sizeof(HIF_DEVICE_POWER_CHANGE_TYPE));
+
+ ar->arWlanPowerState = WLAN_POWER_STATE_DEEP_SLEEP;
+ }
+ } while (0);
+
+ if (status!=A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to enter/exit deep sleep %d\n", state));
+ }
+
+ return status;
+}
+
+A_STATUS
+ar6000_update_wlan_pwr_state(struct ar6_softc *ar, AR6000_WLAN_STATE state, A_BOOL pmEvent)
+{
+ A_STATUS status = A_OK;
+ A_UINT16 powerState, oldPowerState;
+ AR6000_WLAN_STATE oldstate = ar->arWlanState;
+ A_BOOL wlanOff = ar->arWlanOff;
+#ifdef CONFIG_PM
+ A_BOOL btOff = ar->arBTOff;
+#endif /* CONFIG_PM */
+ A_UINT8 i;
+ AR_SOFTC_DEV_T *arPriv;
+
+ if ((state!=WLAN_DISABLED && state!=WLAN_ENABLED)) {
+ return A_ERROR;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ return A_EBUSY;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return A_ERROR;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ return A_EBUSY;
+ }
+
+ ar->arWlanState = wlanOff ? WLAN_DISABLED : state;
+ oldPowerState = ar->arWlanPowerState;
+ if (state == WLAN_ENABLED) {
+ powerState = ar->arWlanPowerState;
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("WLAN PWR set to ENABLE^^\n"));
+ if (!wlanOff) {
+ if (powerState == WLAN_POWER_STATE_DEEP_SLEEP) {
+ status = ar6000_setup_deep_sleep_state(ar, WLAN_ENABLED);
+ } else if (powerState == WLAN_POWER_STATE_CUT_PWR) {
+ status = ar6000_setup_cut_power_state(ar, WLAN_ENABLED);
+ }
+ }
+#ifdef CONFIG_PM
+ else if (pmEvent && wlanOff) {
+ A_BOOL allowCutPwr = ((!ar->arBTSharing) || btOff);
+ if ((powerState==WLAN_POWER_STATE_CUT_PWR) && (!allowCutPwr)) {
+ /* Come out of cut power */
+ ar6000_setup_cut_power_state(ar, WLAN_ENABLED);
+ status = ar6000_setup_deep_sleep_state(ar, WLAN_DISABLED);
+ }
+ }
+#endif /* CONFIG_PM */
+ } else if (state == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("WLAN PWR set to DISABLED~\n"));
+ powerState = WLAN_POWER_STATE_DEEP_SLEEP;
+#ifdef CONFIG_PM
+ if (pmEvent) { /* disable due to suspend */
+ A_BOOL suspendCutPwr = (ar->arSuspendConfig == WLAN_SUSPEND_CUT_PWR ||
+ (ar->arSuspendConfig == WLAN_SUSPEND_WOW &&
+ ar->arWow2Config==WLAN_SUSPEND_CUT_PWR));
+ A_BOOL suspendCutIfBtOff = ((ar->arSuspendConfig ==
+ WLAN_SUSPEND_CUT_PWR_IF_BT_OFF ||
+ (ar->arSuspendConfig == WLAN_SUSPEND_WOW &&
+ ar->arWow2Config==WLAN_SUSPEND_CUT_PWR_IF_BT_OFF)) &&
+ (!ar->arBTSharing || btOff));
+ if ((suspendCutPwr) ||
+ (suspendCutIfBtOff) ||
+ (ar->arWlanPowerState==WLAN_POWER_STATE_CUT_PWR))
+ {
+ if (!wlanOff || ar->arWlanPowerState!=WLAN_POWER_STATE_DEEP_SLEEP) {
+ powerState = WLAN_POWER_STATE_CUT_PWR;
+ }
+ }
+ } else {
+ if ((wlanOff) &&
+ (ar->arWlanOffConfig == WLAN_OFF_CUT_PWR) &&
+ (!ar->arBTSharing || btOff))
+ {
+ /* For BT clock sharing designs, CUT_POWER depend on BT state */
+ powerState = WLAN_POWER_STATE_CUT_PWR;
+ }
+ }
+#endif /* CONFIG_PM */
+
+ if (powerState == WLAN_POWER_STATE_DEEP_SLEEP) {
+ if (ar->arWlanPowerState == WLAN_POWER_STATE_CUT_PWR) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("Load firmware before set to deep sleep\n"));
+ ar6000_setup_cut_power_state(ar, WLAN_ENABLED);
+ }
+ status = ar6000_setup_deep_sleep_state(ar, WLAN_DISABLED);
+ } else if (powerState == WLAN_POWER_STATE_CUT_PWR) {
+ status = ar6000_setup_cut_power_state(ar, WLAN_DISABLED);
+ }
+
+ }
+
+ if (status!=A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Fail to setup WLAN state %d\n", ar->arWlanState));
+ ar->arWlanState = oldstate;
+ } else if (status == A_OK) {
+ WMI_REPORT_SLEEP_STATE_EVENT wmiSleepEvent, *pSleepEvent = NULL;
+ if ((ar->arWlanPowerState == WLAN_POWER_STATE_ON) && (oldPowerState != WLAN_POWER_STATE_ON)) {
+ wmiSleepEvent.sleepState = WMI_REPORT_SLEEP_STATUS_IS_AWAKE;
+ pSleepEvent = &wmiSleepEvent;
+ } else if ((ar->arWlanPowerState != WLAN_POWER_STATE_ON) && (oldPowerState == WLAN_POWER_STATE_ON)) {
+ wmiSleepEvent.sleepState = WMI_REPORT_SLEEP_STATUS_IS_DEEP_SLEEP;
+ pSleepEvent = &wmiSleepEvent;
+ }
+ if (pSleepEvent) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("SENT WLAN Sleep Event %d\n", wmiSleepEvent.sleepState));
+ for(i = 0; i < num_device; i++)
+ {
+ arPriv = ar->arDev[i];
+ ar6000_send_event_to_app(arPriv, WMI_REPORT_SLEEP_STATE_EVENTID, (A_UINT8*)pSleepEvent,
+ sizeof(WMI_REPORT_SLEEP_STATE_EVENTID));
+ }
+ }
+ }
+ up(&ar->arSem);
+ return status;
+}
+
+A_STATUS
+ar6000_set_bt_hw_state(struct ar6_softc *ar, A_UINT32 enable)
+{
+#ifdef CONFIG_PM
+ A_BOOL off = (enable == 0);
+ A_STATUS status;
+ if (ar->arBTOff == off) {
+ return A_OK;
+ }
+ ar->arBTOff = off;
+ status = ar6000_update_wlan_pwr_state(ar, ar->arWlanOff ? WLAN_DISABLED : WLAN_ENABLED, FALSE);
+ return status;
+#else
+ return A_OK;
+#endif
+}
+
+A_STATUS
+ar6000_set_wlan_state(struct ar6_softc *ar, AR6000_WLAN_STATE state)
+{
+ A_INT32 i;
+ A_STATUS status;
+ A_BOOL off = (state == WLAN_DISABLED);
+ return A_OK;
+
+ if (ar->arWlanOff == off) {
+ return A_OK;
+ }
+
+#if WLAN_CONFIG_FIRST_SCAN_2G_ONLY
+ if(!off) {
+ first_scan_2g_only = 1;
+ AR_DEBUG_PRINTF(ATH_DEBUG_PM, ("AR6K: first_scan_2g_only = 1\n"));
+ }
+#endif
+
+ ar->arWlanOff = off;
+ status = ar6000_update_wlan_pwr_state(ar, state, FALSE);
+ for(i = 0; i < num_device; i++) {
+ AR_SOFTC_DEV_T *arPriv = ar->arDev[i];
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ if (arSta->scan_triggered) {
+ ar6000_scanComplete_event(arPriv, A_OK);
+ }
+ }
+ return status;
+}
+
+void ar6000_pm_init()
+{
+ A_REGISTER_MODULE_DEBUG_INFO(pm);
+#ifdef CONFIG_PM
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock_init(&ar6k_suspend_wake_lock, WAKE_LOCK_SUSPEND, "ar6k_suspend");
+ wake_lock_init(&ar6k_wow_wake_lock, WAKE_LOCK_SUSPEND, "ar6k_wow");
+#endif
+ /*
+ * Register ar6000_pm_device into system.
+ * We should also add platform_device into the first item of array
+ * of devices[] in file arch/xxx/mach-xxx/board-xxxx.c
+ */
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15)
+ if (platform_driver_register(&ar6000_pm_device)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ar6000: fail to register the power control driver.\n"));
+ }
+#endif
+
+#if PLAT_WOW_GPIO_PIN
+ wow_irq = gpio_to_irq(PLAT_WOW_GPIO_PIN);
+ if (wow_irq) {
+ int ret;
+ ret = request_irq(wow_irq, ar6000_wow_irq,
+ IRQF_SHARED | IRQF_TRIGGER_RISING,
+ "ar6000" "sdiowakeup", &wow_irq);
+ if (!ret) {
+ ret = enable_irq_wake(wow_irq);
+ if (ret < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Couldn't enable WoW IRQ as wakeup interrupt"));
+ }
+ }
+ }
+#endif /* PLAT_WOW_GPIO_PIN */
+#endif /* CONFIG_PM */
+}
+
+void ar6000_pm_exit()
+{
+#ifdef CONFIG_PM
+#if PLAT_WOW_GPIO_PIN
+ if (wow_irq) {
+ if (disable_irq_wake(wow_irq)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Couldn't disable hostwake IRQ wakeup mode\n"));
+ }
+ free_irq(wow_irq, &wow_irq);
+ wow_irq = 0;
+ }
+#endif /* PLAT_WOW_GPIO_PIN */
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15)
+ platform_driver_unregister(&ar6000_pm_device);
+#endif
+#ifdef CONFIG_HAS_WAKELOCK
+ wake_lock_destroy(&ar6k_suspend_wake_lock);
+ wake_lock_destroy(&ar6k_wow_wake_lock);
+#endif
+#endif /* CONFIG_PM */
+}
+
diff --git a/host/os/linux/ar6000_raw_if.c b/host/os/linux/ar6000_raw_if.c
new file mode 100644
index 0000000..39e5823
--- /dev/null
+++ b/host/os/linux/ar6000_raw_if.c
@@ -0,0 +1,465 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#include "ar6000_drv.h"
+
+#ifdef HTC_RAW_INTERFACE
+
+static void
+ar6000_htc_raw_read_cb(void *Context, HTC_PACKET *pPacket)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)Context;
+ raw_htc_buffer *busy;
+ HTC_RAW_STREAM_ID streamID;
+ AR_RAW_HTC_T *arRaw = ar->arRawHtc;
+
+ busy = (raw_htc_buffer *)pPacket->pPktContext;
+ A_ASSERT(busy != NULL);
+
+ if (pPacket->Status == A_ECANCELED) {
+ /*
+ * HTC provides A_ECANCELED status when it doesn't want to be refilled
+ * (probably due to a shutdown)
+ */
+ return;
+ }
+
+ streamID = arEndpoint2RawStreamID(ar,pPacket->Endpoint);
+ A_ASSERT(streamID != HTC_RAW_STREAM_NOT_MAPPED);
+ if(streamID == HTC_RAW_STREAM_NOT_MAPPED) {
+ return; /* in case panic_on_assert==0 */
+ }
+
+#ifdef CF
+ if (down_trylock(&arRaw->raw_htc_read_sem[streamID])) {
+#else
+ if (down_interruptible(&arRaw->raw_htc_read_sem[streamID])) {
+#endif /* CF */
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unable to down the semaphore\n"));
+ }
+
+ A_ASSERT((pPacket->Status != A_OK) ||
+ (pPacket->pBuffer == (busy->data + HTC_HEADER_LEN)));
+
+ busy->length = pPacket->ActualLength + HTC_HEADER_LEN;
+ busy->currPtr = HTC_HEADER_LEN;
+ arRaw->read_buffer_available[streamID] = TRUE;
+ //AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("raw read cb: 0x%X 0x%X \n", busy->currPtr,busy->length);
+ up(&arRaw->raw_htc_read_sem[streamID]);
+
+ /* Signal the waiting process */
+ AR_DEBUG_PRINTF(ATH_DEBUG_HTC_RAW,("Waking up the StreamID(%d) read process\n", streamID));
+ wake_up_interruptible(&arRaw->raw_htc_read_queue[streamID]);
+}
+
+static void
+ar6000_htc_raw_write_cb(void *Context, HTC_PACKET *pPacket)
+{
+ AR_SOFTC_T *ar = (AR_SOFTC_T *)Context;
+ raw_htc_buffer *free;
+ HTC_RAW_STREAM_ID streamID;
+ AR_RAW_HTC_T *arRaw = ar->arRawHtc;
+
+ free = (raw_htc_buffer *)pPacket->pPktContext;
+ A_ASSERT(free != NULL);
+
+ if (pPacket->Status == A_ECANCELED) {
+ /*
+ * HTC provides A_ECANCELED status when it doesn't want to be refilled
+ * (probably due to a shutdown)
+ */
+ return;
+ }
+
+ streamID = arEndpoint2RawStreamID(ar,pPacket->Endpoint);
+ A_ASSERT(streamID != HTC_RAW_STREAM_NOT_MAPPED);
+ if(streamID == HTC_RAW_STREAM_NOT_MAPPED) {
+ return; /* in case panic_on_assert==0 */
+ }
+#ifdef CF
+ if (down_trylock(&arRaw->raw_htc_write_sem[streamID])) {
+#else
+ if (down_interruptible(&arRaw->raw_htc_write_sem[streamID])) {
+#endif
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unable to down the semaphore\n"));
+ }
+
+ A_ASSERT(pPacket->pBuffer == (free->data + HTC_HEADER_LEN));
+
+ free->length = 0;
+ arRaw->write_buffer_available[streamID] = TRUE;
+ up(&arRaw->raw_htc_write_sem[streamID]);
+
+ /* Signal the waiting process */
+ AR_DEBUG_PRINTF(ATH_DEBUG_HTC_RAW,("Waking up the StreamID(%d) write process\n", streamID));
+ wake_up_interruptible(&arRaw->raw_htc_write_queue[streamID]);
+}
+
+/* connect to a service */
+static A_STATUS ar6000_connect_raw_service(AR_SOFTC_T *ar,
+ HTC_RAW_STREAM_ID StreamID)
+{
+ A_STATUS status;
+ HTC_SERVICE_CONNECT_RESP response;
+ A_UINT8 streamNo;
+ HTC_SERVICE_CONNECT_REQ connect;
+
+ do {
+
+ A_MEMZERO(&connect,sizeof(connect));
+ /* pass the stream ID as meta data to the RAW streams service */
+ streamNo = (A_UINT8)StreamID;
+ connect.pMetaData = &streamNo;
+ connect.MetaDataLength = sizeof(A_UINT8);
+ /* these fields are the same for all endpoints */
+ connect.EpCallbacks.pContext = ar;
+ connect.EpCallbacks.EpTxComplete = ar6000_htc_raw_write_cb;
+ connect.EpCallbacks.EpRecv = ar6000_htc_raw_read_cb;
+ /* simple interface, we don't need these optional callbacks */
+ connect.EpCallbacks.EpRecvRefill = NULL;
+ connect.EpCallbacks.EpSendFull = NULL;
+ connect.MaxSendQueueDepth = RAW_HTC_WRITE_BUFFERS_NUM;
+
+ /* connect to the raw streams service, we may be able to get 1 or more
+ * connections, depending on WHAT is running on the target */
+ connect.ServiceID = HTC_RAW_STREAMS_SVC;
+
+ A_MEMZERO(&response,sizeof(response));
+
+ /* try to connect to the raw stream, it is okay if this fails with
+ * status HTC_SERVICE_NO_MORE_EP */
+ status = HTCConnectService(ar->arHtcTarget,
+ &connect,
+ &response);
+
+ if (A_FAILED(status)) {
+ if (response.ConnectRespCode == HTC_SERVICE_NO_MORE_EP) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("HTC RAW , No more streams allowed \n"));
+ status = A_OK;
+ }
+ break;
+ }
+
+ /* set endpoint mapping for the RAW HTC streams */
+ arSetRawStream2EndpointIDMap(ar,StreamID,response.Endpoint);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HTC_RAW,("HTC RAW : stream ID: %d, endpoint: %d\n",
+ StreamID, arRawStream2EndpointID(ar,StreamID)));
+
+ } while (FALSE);
+
+ return status;
+}
+
+int ar6000_htc_raw_open(AR_SOFTC_T *ar)
+{
+ A_STATUS status;
+ int streamID, endPt, count2;
+ raw_htc_buffer *buffer;
+ HTC_SERVICE_ID servicepriority;
+ AR_RAW_HTC_T *arRaw = ar->arRawHtc;
+ if (!arRaw) {
+ arRaw = ar->arRawHtc = A_MALLOC(sizeof(AR_RAW_HTC_T));
+ if (arRaw) {
+ A_MEMZERO(arRaw, sizeof(AR_RAW_HTC_T));
+ }
+ }
+ A_ASSERT(ar->arHtcTarget != NULL);
+ if (!arRaw) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Faile to allocate memory for HTC RAW interface\n"));
+ return -ENOMEM;
+ }
+ /* wait for target */
+ status = HTCWaitTarget(ar->arHtcTarget);
+
+ if (A_FAILED(status)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("HTCWaitTarget failed (%d)\n", status));
+ return -ENODEV;
+ }
+
+ for (endPt = 0; endPt < ENDPOINT_MAX; endPt++) {
+ arRaw->arEp2RawMapping[endPt] = HTC_RAW_STREAM_NOT_MAPPED;
+ }
+
+ for (streamID = HTC_RAW_STREAM_0; streamID < HTC_RAW_STREAM_NUM_MAX; streamID++) {
+ /* Initialize the data structures */
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)
+ sema_init(&arRaw->raw_htc_read_sem[streamID], 1);
+ sema_init(&arRaw->raw_htc_write_sem[streamID], 1);
+#else
+ init_MUTEX(&arRaw->raw_htc_read_sem[streamID]);
+ init_MUTEX(&arRaw->raw_htc_write_sem[streamID]);
+#endif
+ init_waitqueue_head(&arRaw->raw_htc_read_queue[streamID]);
+ init_waitqueue_head(&arRaw->raw_htc_write_queue[streamID]);
+
+ /* try to connect to the raw service */
+ status = ar6000_connect_raw_service(ar,streamID);
+
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ if (arRawStream2EndpointID(ar,streamID) == 0) {
+ break;
+ }
+
+ for (count2 = 0; count2 < RAW_HTC_READ_BUFFERS_NUM; count2 ++) {
+ /* Initialize the receive buffers */
+ buffer = &arRaw->raw_htc_write_buffer[streamID][count2];
+ memset(buffer, 0, sizeof(raw_htc_buffer));
+ buffer = &arRaw->raw_htc_read_buffer[streamID][count2];
+ memset(buffer, 0, sizeof(raw_htc_buffer));
+
+ SET_HTC_PACKET_INFO_RX_REFILL(&buffer->HTCPacket,
+ buffer,
+ buffer->data,
+ HTC_RAW_BUFFER_SIZE,
+ arRawStream2EndpointID(ar,streamID));
+
+ /* Queue buffers to HTC for receive */
+ if ((status = HTCAddReceivePkt(ar->arHtcTarget, &buffer->HTCPacket)) != A_OK)
+ {
+ BMIInit();
+ return -EIO;
+ }
+ }
+
+ for (count2 = 0; count2 < RAW_HTC_WRITE_BUFFERS_NUM; count2 ++) {
+ /* Initialize the receive buffers */
+ buffer = &arRaw->raw_htc_write_buffer[streamID][count2];
+ memset(buffer, 0, sizeof(raw_htc_buffer));
+ }
+
+ arRaw->read_buffer_available[streamID] = FALSE;
+ arRaw->write_buffer_available[streamID] = TRUE;
+ }
+
+ if (A_FAILED(status)) {
+ return -EIO;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("HTC RAW, number of streams the target supports: %d \n", streamID));
+
+ servicepriority = HTC_RAW_STREAMS_SVC; /* only 1 */
+
+ /* set callbacks and priority list */
+ HTCSetCreditDistribution(ar->arHtcTarget,
+ ar,
+ NULL, /* use default */
+ NULL, /* use default */
+ &servicepriority,
+ 1);
+
+ /* Start the HTC component */
+ if ((status = HTCStart(ar->arHtcTarget)) != A_OK) {
+ BMIInit();
+ return -EIO;
+ }
+
+ (ar)->arRawIfInit = TRUE;
+
+ return 0;
+}
+
+int ar6000_htc_raw_close(AR_SOFTC_T *ar)
+{
+ A_PRINTF("ar6000_htc_raw_close called \n");
+ HTCStop(ar->arHtcTarget);
+
+ /* reset the device */
+ ar6000_reset_device(ar->arHifDevice, ar->arTargetType, TRUE, FALSE);
+ /* Initialize the BMI component */
+ BMIInit();
+
+ return 0;
+}
+
+raw_htc_buffer *
+get_filled_buffer(AR_SOFTC_T *ar, HTC_RAW_STREAM_ID StreamID)
+{
+ int count;
+ raw_htc_buffer *busy;
+ AR_RAW_HTC_T *arRaw = ar->arRawHtc;
+
+ /* Check for data */
+ for (count = 0; count < RAW_HTC_READ_BUFFERS_NUM; count ++) {
+ busy = &arRaw->raw_htc_read_buffer[StreamID][count];
+ if (busy->length) {
+ break;
+ }
+ }
+ if (busy->length) {
+ arRaw->read_buffer_available[StreamID] = TRUE;
+ } else {
+ arRaw->read_buffer_available[StreamID] = FALSE;
+ }
+
+ return busy;
+}
+
+ssize_t ar6000_htc_raw_read(AR_SOFTC_T *ar, HTC_RAW_STREAM_ID StreamID,
+ char __user *buffer, size_t length)
+{
+ int readPtr;
+ raw_htc_buffer *busy;
+ AR_RAW_HTC_T *arRaw = ar->arRawHtc;
+
+ if (arRawStream2EndpointID(ar,StreamID) == 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("StreamID(%d) not connected! \n", StreamID));
+ return -EFAULT;
+ }
+
+ if (down_interruptible(&arRaw->raw_htc_read_sem[StreamID])) {
+ return -ERESTARTSYS;
+ }
+
+ busy = get_filled_buffer(ar,StreamID);
+ while (!arRaw->read_buffer_available[StreamID]) {
+ up(&arRaw->raw_htc_read_sem[StreamID]);
+
+ /* Wait for the data */
+ AR_DEBUG_PRINTF(ATH_DEBUG_HTC_RAW,("Sleeping StreamID(%d) read process\n", StreamID));
+ if (wait_event_interruptible(arRaw->raw_htc_read_queue[StreamID],
+ arRaw->read_buffer_available[StreamID]))
+ {
+ return -EINTR;
+ }
+ if (down_interruptible(&arRaw->raw_htc_read_sem[StreamID])) {
+ return -ERESTARTSYS;
+ }
+ busy = get_filled_buffer(ar,StreamID);
+ }
+
+ /* Read the data */
+ readPtr = busy->currPtr;
+ if (length > busy->length - HTC_HEADER_LEN) {
+ length = busy->length - HTC_HEADER_LEN;
+ }
+ if (copy_to_user(buffer, &busy->data[readPtr], length)) {
+ up(&arRaw->raw_htc_read_sem[StreamID]);
+ return -EFAULT;
+ }
+
+ busy->currPtr += length;
+
+ if (busy->currPtr == busy->length)
+ {
+ busy->currPtr = 0;
+ busy->length = 0;
+ HTC_PACKET_RESET_RX(&busy->HTCPacket);
+ //AR_DEBUG_PRINTF(ATH_DEBUG_HTC_RAW,("raw read ioctl: ep for packet:%d \n", busy->HTCPacket.Endpoint));
+ HTCAddReceivePkt(ar->arHtcTarget, &busy->HTCPacket);
+ }
+ arRaw->read_buffer_available[StreamID] = FALSE;
+ up(&arRaw->raw_htc_read_sem[StreamID]);
+
+ return length;
+}
+
+static raw_htc_buffer *
+get_free_buffer(AR_SOFTC_T *ar, HTC_ENDPOINT_ID StreamID)
+{
+ int count;
+ raw_htc_buffer *free;
+ AR_RAW_HTC_T *arRaw = ar->arRawHtc;
+
+ free = NULL;
+ for (count = 0; count < RAW_HTC_WRITE_BUFFERS_NUM; count ++) {
+ free = &arRaw->raw_htc_write_buffer[StreamID][count];
+ if (free->length == 0) {
+ break;
+ }
+ }
+ if (!free->length) {
+ arRaw->write_buffer_available[StreamID] = TRUE;
+ } else {
+ arRaw->write_buffer_available[StreamID] = FALSE;
+ }
+
+ return free;
+}
+
+ssize_t ar6000_htc_raw_write(AR_SOFTC_T *ar, HTC_RAW_STREAM_ID StreamID,
+ char __user *buffer, size_t length)
+{
+ int writePtr;
+ raw_htc_buffer *free;
+ AR_RAW_HTC_T *arRaw = ar->arRawHtc;
+ if (arRawStream2EndpointID(ar,StreamID) == 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("StreamID(%d) not connected! \n", StreamID));
+ return -EFAULT;
+ }
+
+ if (down_interruptible(&arRaw->raw_htc_write_sem[StreamID])) {
+ return -ERESTARTSYS;
+ }
+
+ /* Search for a free buffer */
+ free = get_free_buffer(ar,StreamID);
+
+ /* Check if there is space to write else wait */
+ while (!arRaw->write_buffer_available[StreamID]) {
+ up(&arRaw->raw_htc_write_sem[StreamID]);
+
+ /* Wait for buffer to become free */
+ AR_DEBUG_PRINTF(ATH_DEBUG_HTC_RAW,("Sleeping StreamID(%d) write process\n", StreamID));
+ if (wait_event_interruptible(arRaw->raw_htc_write_queue[StreamID],
+ arRaw->write_buffer_available[StreamID]))
+ {
+ return -EINTR;
+ }
+ if (down_interruptible(&arRaw->raw_htc_write_sem[StreamID])) {
+ return -ERESTARTSYS;
+ }
+ free = get_free_buffer(ar,StreamID);
+ }
+
+ /* Send the data */
+ writePtr = HTC_HEADER_LEN;
+ if (length > (HTC_RAW_BUFFER_SIZE - HTC_HEADER_LEN)) {
+ length = HTC_RAW_BUFFER_SIZE - HTC_HEADER_LEN;
+ }
+
+ if (copy_from_user(&free->data[writePtr], buffer, length)) {
+ up(&arRaw->raw_htc_read_sem[StreamID]);
+ return -EFAULT;
+ }
+
+ free->length = length;
+
+ SET_HTC_PACKET_INFO_TX(&free->HTCPacket,
+ free,
+ &free->data[writePtr],
+ length,
+ arRawStream2EndpointID(ar,StreamID),
+ AR6K_DATA_PKT_TAG);
+
+ HTCSendPkt(ar->arHtcTarget,&free->HTCPacket);
+
+ arRaw->write_buffer_available[StreamID] = FALSE;
+ up(&arRaw->raw_htc_write_sem[StreamID]);
+
+ return length;
+}
+#endif /* HTC_RAW_INTERFACE */
diff --git a/host/os/linux/ar6k_mem_debug.c b/host/os/linux/ar6k_mem_debug.c
new file mode 100644
index 0000000..cb7cd30
--- /dev/null
+++ b/host/os/linux/ar6k_mem_debug.c
@@ -0,0 +1,246 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+//
+#include "ar6000_drv.h"
+
+#define malloc(size) kmalloc((size), GFP_ATOMIC)
+#define free(ptr) kfree((ptr))
+
+typedef struct MemInfo {
+ void *ptr;
+ const char *caller;
+ int lineno;
+ size_t size;
+} MemInfo;
+
+
+
+typedef unsigned long hash_key;
+
+typedef struct HashItem {
+ hash_key Key;
+ struct HashItem * Next;
+} HashItem;
+
+typedef struct a_hash {
+ HashItem **Buckets;
+ size_t len;
+ int (*cmpKeyFunc)(const hash_key a, const hash_key b);
+ unsigned long (*hashFunc)(const hash_key key);
+ HashItem* (*mkNodeFunc)(hash_key key);
+} a_hash;
+
+static a_hash* gMem;
+
+static int cmpMemInfo(const hash_key a, const hash_key b)
+{
+ return((const MemInfo*)a)->ptr - ((const MemInfo*)b)->ptr;
+}
+
+static unsigned long hashMemInfo(const hash_key key)
+{
+ return(unsigned long)((const MemInfo*)key)->ptr;
+}
+
+static HashItem* mkMemInfoItem(hash_key key)
+{
+ HashItem* item;
+ item = malloc(sizeof(HashItem)+ sizeof(MemInfo));
+ item->Key = (hash_key)(item+1);
+ memcpy((void*)item->Key, (void*)key, sizeof(MemInfo));
+ return item;
+}
+
+static void rmItem(HashItem* item, void* data)
+{ /* private function, don't use !! */
+ free(item);
+}
+
+HashItem* a_hash_add(a_hash *hash, const hash_key Key)
+{
+ int hashIndex = hash->hashFunc(Key) % hash->len;
+ HashItem* item = hash->mkNodeFunc(Key);
+ item->Next = hash->Buckets[hashIndex];
+ hash->Buckets[hashIndex] = item;
+ return item;
+}
+
+void a_hash_iterate(a_hash* hash, void (*func)(HashItem*, void*), void* data)
+{
+ size_t i;
+ HashItem *p, *next;
+ for (i=0; i<hash->len; ++i) {
+ p = hash->Buckets[i];
+ while (p) {
+ next = p->Next;
+ func(p, data);
+ p = next;
+ }
+ }
+}
+
+void a_hash_clear(a_hash* hash)
+{
+ a_hash_iterate(hash, rmItem, NULL);
+ memset(hash->Buckets, 0, hash->len * sizeof(HashItem*));
+}
+
+void a_hash_destroy(a_hash* hash)
+{
+ a_hash_clear(hash);
+ free(hash);
+}
+
+static HashItem** __a_hash_find(a_hash* hash, const hash_key Key)
+{
+ int hashIndex = hash->hashFunc(Key) % hash->len;
+ HashItem** result = &hash->Buckets[hashIndex];
+ while (*result) {
+ if (hash->cmpKeyFunc((*result)->Key, Key)==0)
+ return result;
+ else
+ result = &(*result)->Next;
+ }
+ return result;
+}
+
+HashItem* a_hash_find(a_hash* hash, const hash_key Key)
+{
+ return *__a_hash_find(hash, Key);
+}
+
+HashItem* a_hash_findNext(a_hash* hash, HashItem* item)
+{
+ hash_key Key = (item) ? item->Key : 0;
+ if (item)
+ item = item->Next;
+ while (item) {
+ if (hash->cmpKeyFunc(item->Key, Key) == 0)
+ return item;
+ else
+ item = item->Next;
+ }
+ return item;
+}
+
+void a_hash_erase(a_hash* hash, const hash_key Key)
+{
+ HashItem* p;
+ HashItem** prev = __a_hash_find(hash, Key);
+ p = *prev;
+ if (p) {
+ *prev = p->Next;
+ rmItem(p, NULL);
+ }
+}
+
+void __a_meminfo_add(void *ptr, size_t msize, const char *func, int lineno)
+{
+ MemInfo info;
+ info.ptr = ptr;
+ info.lineno = lineno;
+ info.caller = func;
+ info.size = msize;
+ if (!gMem) {
+ int len = 512;
+ size_t size = sizeof(HashItem*) * len;
+ gMem = (a_hash*)malloc(sizeof(a_hash)+size);
+ memset(gMem, 0, sizeof(a_hash)+size);
+ gMem->Buckets = (HashItem**)(gMem+1);
+ gMem->len = len;
+
+ gMem->mkNodeFunc = mkMemInfoItem;
+ gMem->cmpKeyFunc = cmpMemInfo;
+ gMem->hashFunc = hashMemInfo;
+ }
+
+ a_hash_add(gMem, (hash_key)&info);
+}
+
+void a_meminfo_del(void *ptr)
+{
+ MemInfo info;
+ info.ptr = ptr;
+ if (gMem) {
+ HashItem* p;
+ HashItem** prev = __a_hash_find(gMem, (unsigned long)&info);
+ p = *prev;
+ if (p) {
+ *prev = p->Next;
+ rmItem(p, NULL);
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Warning! memory ptr %p not found!", __func__, ptr));
+ }
+ }
+}
+
+void* a_mem_alloc(size_t msize, int type, const char *func, int lineno)
+{
+ void *ptr = kmalloc(msize, type);
+ __a_meminfo_add(ptr, msize, func, lineno);
+ return ptr;
+}
+
+void a_mem_free(void *ptr)
+{
+ a_meminfo_del(ptr);
+ kfree(ptr);
+}
+
+static void printMemInfo(HashItem *item, void*arg)
+{
+ MemInfo *info = (MemInfo*)item->Key;
+ int *total = (int*)arg;
+ *total += info->size;
+ A_PRINTF("%s line %d size %d ptr %p\n", info->caller, info->lineno, info->size, info->ptr);
+}
+
+void a_meminfo_report(int clear)
+{
+ int total = 0;
+ A_PRINTF("AR6K Memory Report\n");
+ if (gMem) {
+ a_hash_iterate(gMem, printMemInfo, &total);
+ if (clear) {
+ a_hash_destroy(gMem);
+ }
+ }
+ A_PRINTF("Total %d bytes\n", total);
+}
+
+A_BOOL a_meminfo_find(void *ptr)
+{
+ MemInfo info;
+ info.ptr = ptr;
+ if (gMem) {
+ HashItem* p;
+ HashItem** prev = __a_hash_find(gMem, (unsigned long)&info);
+ p = *prev;
+ if (p) {
+ return TRUE;
+ } else {
+ return FALSE;
+ }
+ }
+}
diff --git a/host/os/linux/ar6k_pal.c b/host/os/linux/ar6k_pal.c
new file mode 100644
index 0000000..179a2f0
--- /dev/null
+++ b/host/os/linux/ar6k_pal.c
@@ -0,0 +1,471 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+/* PAL Transport driver for AR6003 */
+
+#include "ar6000_drv.h"
+#include <net/bluetooth/bluetooth.h>
+#include <net/bluetooth/hci_core.h>
+#include <ar6k_pal.h>
+
+extern unsigned int setupbtdev;
+extern unsigned int loghci;
+
+#define bt_check_bit(val, bit) (val & bit)
+#define bt_set_bit(val, bit) (val |= bit)
+#define bt_clear_bit(val, bit) (val &= ~bit)
+
+/* export ATH_AR6K_DEBUG_HCI_PAL=yes in host/localmake.linux.inc
+ * to enable debug information */
+#ifdef HCIPAL_DEBUG
+#define PRIN_LOG(format, args...) printk(KERN_ALERT "%s:%d - %s Msg:" format "\n",__FUNCTION__, __LINE__, __FILE__, ## args)
+#else
+#define PRIN_LOG(format, args...)
+#endif
+
+
+/*** BT Stack Entrypoints *******/
+/***************************************
+ * bt_open - open a handle to the device
+ ***************************************/
+static int bt_open(struct hci_dev *hdev)
+{
+ PRIN_LOG("HCI PAL: bt_open - enter - x\n");
+ set_bit(HCI_RUNNING, &hdev->flags);
+ set_bit(HCI_UP, &hdev->flags);
+ set_bit(HCI_INIT, &hdev->flags);
+ return 0;
+}
+
+/***************************************
+ * bt_close - close handle to the device
+ ***************************************/
+static int bt_close(struct hci_dev *hdev)
+{
+ PRIN_LOG("HCI PAL: bt_close - enter\n");
+ clear_bit(HCI_RUNNING, &hdev->flags);
+ return 0;
+}
+
+/*****************************
+ * bt_ioctl - ioctl processing
+ *****************************/
+static int bt_ioctl(struct hci_dev *hdev, unsigned int cmd, unsigned long arg)
+{
+ PRIN_LOG("HCI PAL: bt_ioctl - enter\n");
+ return -ENOIOCTLCMD;
+}
+
+/**************************************
+ * bt_flush - flush outstanding packets
+ **************************************/
+static int bt_flush(struct hci_dev *hdev)
+{
+ PRIN_LOG("HCI PAL: bt_flush - enter\n");
+ return 0;
+}
+
+/***************
+ * bt_destruct
+ ***************/
+static void bt_destruct(struct hci_dev *hdev)
+{
+ PRIN_LOG("HCI PAL: bt_destruct - enter\n");
+ /* nothing to do here */
+}
+
+/****************************************************
+ * Invoked from bluetooth stack via hdev->send()
+ * to send the packet out via ar6k to PAL firmware.
+ *
+ * For HCI command packet wmi_send_hci_cmd() is invoked.
+ * wmi_send_hci_cmd adds WMI_CMD_HDR and sends the packet
+ * to PAL firmware.
+ *
+ * For HCI ACL data packet wmi_data_hdr_add is invoked
+ * to add WMI_DATA_HDR to the packet. ar6000_acl_data_tx
+ * is then invoked to send the packet to PAL firmware.
+ ******************************************************/
+static int btpal_send_frame(struct sk_buff *skb)
+{
+ struct hci_dev *hdev = (struct hci_dev *)skb->dev;
+ HCI_TRANSPORT_PACKET_TYPE type;
+ ar6k_hci_pal_info_t *pHciPalInfo;
+ A_STATUS status = A_OK;
+ struct sk_buff *txSkb = NULL;
+ AR_SOFTC_DEV_T *ar;
+
+ if (!hdev) {
+ PRIN_LOG("HCI PAL: btpal_send_frame - no device\n");
+ return -ENODEV;
+ }
+
+ if (!test_bit(HCI_RUNNING, &hdev->flags)) {
+ PRIN_LOG("HCI PAL: btpal_send_frame - not open\n");
+ return -EBUSY;
+ }
+
+ pHciPalInfo = (ar6k_hci_pal_info_t *)hdev->driver_data;
+ A_ASSERT(pHciPalInfo != NULL);
+ ar = pHciPalInfo->ar;
+
+ PRIN_LOG("+btpal_send_frame type: %d \n",bt_cb(skb)->pkt_type);
+ type = HCI_COMMAND_TYPE;
+
+ switch (bt_cb(skb)->pkt_type) {
+ case HCI_COMMAND_PKT:
+ type = HCI_COMMAND_TYPE;
+ hdev->stat.cmd_tx++;
+ break;
+
+ case HCI_ACLDATA_PKT:
+ type = HCI_ACL_TYPE;
+ hdev->stat.acl_tx++;
+ break;
+
+ case HCI_SCODATA_PKT:
+ /* we don't support SCO over the pal */
+ kfree_skb(skb);
+ return 0;
+ default:
+ A_ASSERT(FALSE);
+ kfree_skb(skb);
+ return 0;
+ }
+
+ if(loghci) {
+ A_PRINTF(">>> Send HCI %s packet len: %d\n",
+ (type == HCI_COMMAND_TYPE) ? "COMMAND" : "ACL",
+ skb->len);
+ if (type == HCI_COMMAND_TYPE) {
+ A_PRINTF("HCI Command: OGF:0x%X OCF:0x%X \r\n",
+ (HCI_GET_OP_CODE(skb->data)) >> 10,
+ (HCI_GET_OP_CODE(skb->data)) & 0x3FF);
+ }
+ DebugDumpBytes(skb->data,skb->len,"BT HCI SEND Packet Dump");
+ }
+
+ do {
+ if(type == HCI_COMMAND_TYPE)
+ {
+ PRIN_LOG("HCI command");
+
+ if (ar->arSoftc->arWmiReady == FALSE)
+ {
+ PRIN_LOG("WMI not ready ");
+ break;
+ }
+
+ if (wmi_send_hci_cmd(ar->arWmi, skb->data, skb->len) != A_OK)
+ {
+ PRIN_LOG("send hci cmd error");
+ break;
+ }
+ }
+ else if(type == HCI_ACL_TYPE)
+ {
+ void *osbuf;
+
+ PRIN_LOG("ACL data");
+ if (ar->arSoftc->arWmiReady == FALSE)
+ {
+ PRIN_LOG("WMI not ready");
+ break;
+ }
+
+ /* need to add WMI header so allocate a skb with more space */
+ txSkb = bt_skb_alloc(TX_PACKET_RSV_OFFSET + WMI_MAX_TX_META_SZ +
+ sizeof(WMI_DATA_HDR) + skb->len,
+ GFP_ATOMIC);
+
+ if (txSkb == NULL) {
+ status = A_NO_MEMORY;
+ PRIN_LOG("No memory");
+ break;
+ }
+
+ bt_cb(txSkb)->pkt_type = bt_cb(skb)->pkt_type;
+ txSkb->dev = (void *)pHciPalInfo->hdev;
+ skb_reserve(txSkb, TX_PACKET_RSV_OFFSET + WMI_MAX_TX_META_SZ + sizeof(WMI_DATA_HDR));
+ A_MEMCPY(txSkb->data, skb->data, skb->len);
+ skb_put(txSkb,skb->len);
+ /* Add WMI packet type */
+ osbuf = (void *)txSkb;
+
+ PRIN_LOG("\nAdd WMI header");
+ if (wmi_data_hdr_add(ar->arWmi, osbuf, DATA_MSGTYPE, 0, WMI_DATA_HDR_DATA_TYPE_ACL,0,NULL) != A_OK) {
+ PRIN_LOG("XIOCTL_ACL_DATA - wmi_data_hdr_add failed\n");
+ } else {
+ /* Send data buffer over HTC */
+ PRIN_LOG("acl data tx");
+ ar6000_acl_data_tx(osbuf, ar);
+ }
+ txSkb = NULL;
+ }
+ } while (FALSE);
+
+ if (txSkb != NULL) {
+ PRIN_LOG("Free skb");
+ kfree_skb(txSkb);
+ }
+ kfree_skb(skb);
+ return 0;
+}
+
+
+/***********************************************
+ * Unregister HCI device and free HCI device info
+ ***********************************************/
+static void bt_cleanup_hci_pal(ar6k_hci_pal_info_t *pHciPalInfo)
+{
+ int err;
+
+ if (bt_check_bit(pHciPalInfo->ulFlags, HCI_REGISTERED)) {
+ bt_clear_bit(pHciPalInfo->ulFlags, HCI_REGISTERED);
+ clear_bit(HCI_RUNNING, &pHciPalInfo->hdev->flags);
+ clear_bit(HCI_UP, &pHciPalInfo->hdev->flags);
+ clear_bit(HCI_INIT, &pHciPalInfo->hdev->flags);
+ A_ASSERT(pHciPalInfo->hdev != NULL);
+#ifdef CONFIG_BT
+ /* unregister */
+ PRIN_LOG("Unregister PAL device");
+ if ((err = hci_unregister_dev(pHciPalInfo->hdev)) < 0) {
+ PRIN_LOG("HCI PAL: failed to unregister with bluetooth %d\n",err);
+ }
+#else
+ (void)&err;
+#endif
+ }
+
+ if (pHciPalInfo->hdev != NULL) {
+ kfree(pHciPalInfo->hdev);
+ pHciPalInfo->hdev = NULL;
+ }
+}
+
+/*********************************************************
+ * Allocate HCI device and store in PAL private info structure.
+ *********************************************************/
+static A_STATUS bt_setup_hci_pal(ar6k_hci_pal_info_t *pHciPalInfo)
+{
+#ifdef CONFIG_BT
+ A_STATUS status = A_OK;
+ struct hci_dev *pHciDev = NULL;
+
+#if 0 //This condition is not required for PAL
+ if (!setupbtdev) {
+ return A_OK;
+ }
+#endif
+ do {
+ /* allocate a BT HCI struct for this device */
+ pHciDev = hci_alloc_dev();
+ if (NULL == pHciDev) {
+ PRIN_LOG("HCI PAL driver - failed to allocate BT HCI struct \n");
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ /* save the device, we'll register this later */
+ pHciPalInfo->hdev = pHciDev;
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 37)
+ SET_HCI_BUS_TYPE(pHciDev, HCI_VIRTUAL, HCI_80211);
+#else
+ SET_HCI_BUS_TYPE(pHciDev, HCI_VIRTUAL, HCI_AMP);
+#endif
+ pHciDev->driver_data = pHciPalInfo;
+ pHciDev->open = bt_open;
+ pHciDev->close = bt_close;
+ pHciDev->send = btpal_send_frame;
+ pHciDev->ioctl = bt_ioctl;
+ pHciDev->flush = bt_flush;
+ pHciDev->destruct = bt_destruct;
+ pHciDev->owner = THIS_MODULE;
+ /* driver is running in normal BT mode */
+ PRIN_LOG("Normal mode enabled");
+ bt_set_bit(pHciPalInfo->ulFlags, HCI_NORMAL_MODE);
+
+ } while (FALSE);
+
+ if (A_FAILED(status)) {
+ bt_cleanup_hci_pal(pHciPalInfo);
+ }
+ return status;
+#else
+ (void)&bt_open;
+ (void)&bt_close;
+ (void)&btpal_send_frame;
+ (void)&bt_ioctl;
+ (void)&bt_flush;
+ (void)&bt_destruct;
+ bt_cleanup_hci_pal(pHciPalInfo);
+ return A_ENOTSUP;
+#endif
+}
+
+/**********************************************
+ * Cleanup HCI device and free HCI PAL private info
+ *********************************************/
+void ar6k_cleanup_hci_pal(void *ar_p)
+{
+ AR_SOFTC_DEV_T *ar = (AR_SOFTC_DEV_T *)ar_p;
+ ar6k_hci_pal_info_t *pHciPalInfo = (ar6k_hci_pal_info_t *)ar->hcipal_info;
+
+ if (pHciPalInfo != NULL) {
+ bt_cleanup_hci_pal(pHciPalInfo);
+ A_FREE(pHciPalInfo);
+ ar->hcipal_info = NULL;
+ }
+}
+
+/****************************
+ * Register HCI device
+ ****************************/
+static A_BOOL ar6k_pal_transport_ready(void *pHciPal)
+{
+#ifdef CONFIG_BT
+ ar6k_hci_pal_info_t *pHciPalInfo = (ar6k_hci_pal_info_t *)pHciPal;
+
+ PRIN_LOG("HCI device transport ready");
+ if(pHciPalInfo == NULL)
+ return FALSE;
+
+ if (hci_register_dev(pHciPalInfo->hdev) < 0) {
+ PRIN_LOG("Can't register HCI device");
+ hci_free_dev(pHciPalInfo->hdev);
+ return FALSE;
+ }
+ PRIN_LOG("HCI device registered");
+ pHciPalInfo->ulFlags |= HCI_REGISTERED;
+ return TRUE;
+#else
+ return FALSE;
+#endif
+}
+
+/**************************************************
+ * Called from ar6k driver when command or ACL data
+ * packet is received. Pass the packet to bluetooth
+ * stack via hci_recv_frame.
+ **************************************************/
+A_BOOL ar6k_pal_recv_pkt(void *pHciPal, void *osbuf)
+{
+ struct sk_buff *skb = (struct sk_buff *)osbuf;
+ ar6k_hci_pal_info_t *pHciPalInfo;
+ A_BOOL success = FALSE;
+ A_UINT8 btType = 0;
+ pHciPalInfo = (ar6k_hci_pal_info_t *)pHciPal;
+
+ do {
+
+ /* if normal mode is not enabled pass on to the stack
+ * by returning failure */
+ if(!(pHciPalInfo->ulFlags & HCI_NORMAL_MODE))
+ {
+ PRIN_LOG("Normal mode not enabled");
+ break;
+ }
+
+ if (!test_bit(HCI_RUNNING, &pHciPalInfo->hdev->flags)) {
+ PRIN_LOG("HCI PAL: HCI - not running\n");
+ break;
+ }
+
+ if(*((short *)A_NETBUF_DATA(skb)) == WMI_ACL_DATA_EVENTID)
+ btType = HCI_ACLDATA_PKT;
+ else
+ btType = HCI_EVENT_PKT;
+ /* pull 4 bytes which contains WMI packet type */
+ A_NETBUF_PULL(skb, sizeof(int));
+ bt_cb(skb)->pkt_type = btType;
+ skb->dev = (void *)pHciPalInfo->hdev;
+
+ if(loghci) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ANY,("<<< Recv HCI %s packet len:%d \n",
+ (btType == HCI_EVENT_TYPE) ? "EVENT" : "ACL",
+ skb->len));
+ DebugDumpBytes(skb->data, skb->len,"BT HCI RECV Packet Dump");
+ }
+ /* pass the received event packet up the stack */
+#ifdef CONFIG_BT
+ if (hci_recv_frame(skb) != 0) {
+#else
+ if (1) {
+#endif
+ PRIN_LOG("HCI PAL: hci_recv_frame failed \n");
+ break;
+ } else {
+ PRIN_LOG("HCI PAL: Indicated RCV of type:%d, Length:%d \n",HCI_EVENT_PKT, skb->len);
+ }
+ PRIN_LOG("hci recv success");
+ success = TRUE;
+ }while(FALSE);
+ return success;
+}
+
+/**********************************************************
+ * HCI PAL init function called from ar6k when it is loaded..
+ * Allocates PAL private info, stores the same in ar6k private info.
+ * Registers a HCI device.
+ * Registers packet receive callback function with ar6k
+ **********************************************************/
+A_STATUS ar6k_setup_hci_pal(void *ar_p)
+{
+ A_STATUS status = A_OK;
+ ar6k_hci_pal_info_t *pHciPalInfo;
+ ar6k_pal_config_t ar6k_pal_config;
+ AR_SOFTC_DEV_T *ar = (AR_SOFTC_DEV_T *)ar_p;
+
+ do {
+
+ pHciPalInfo = (ar6k_hci_pal_info_t *)A_MALLOC(sizeof(ar6k_hci_pal_info_t));
+
+ if (NULL == pHciPalInfo) {
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ A_MEMZERO(pHciPalInfo, sizeof(ar6k_hci_pal_info_t));
+ ar->hcipal_info = pHciPalInfo;
+ pHciPalInfo->ar = ar;
+
+ status = bt_setup_hci_pal(pHciPalInfo);
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ if(bt_check_bit(pHciPalInfo->ulFlags, HCI_NORMAL_MODE))
+ PRIN_LOG("HCI PAL: running in normal mode... \n");
+ else
+ PRIN_LOG("HCI PAL: running in test mode... \n");
+
+ ar6k_pal_config.fpar6k_pal_recv_pkt = ar6k_pal_recv_pkt;
+ register_pal_cb(&ar6k_pal_config);
+ ar6k_pal_transport_ready(ar->hcipal_info);
+ } while (FALSE);
+
+ if (A_FAILED(status)) {
+ ar6k_cleanup_hci_pal(ar);
+ }
+ return status;
+}
diff --git a/host/os/linux/cfg80211.c b/host/os/linux/cfg80211.c
new file mode 100644
index 0000000..97f6979
--- /dev/null
+++ b/host/os/linux/cfg80211.c
@@ -0,0 +1,1638 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#include <linux/kernel.h>
+#include <linux/netdevice.h>
+#include <linux/wireless.h>
+#include <linux/ieee80211.h>
+#include <net/cfg80211.h>
+
+#include "ar6000_drv.h"
+
+
+extern unsigned int wmitimeout;
+extern int reconnect_flag;
+
+
+#define RATETAB_ENT(_rate, _rateid, _flags) { \
+ .bitrate = (_rate), \
+ .flags = (_flags), \
+ .hw_value = (_rateid), \
+}
+
+#define CHAN2G(_channel, _freq, _flags) { \
+ .band = IEEE80211_BAND_2GHZ, \
+ .hw_value = (_channel), \
+ .center_freq = (_freq), \
+ .flags = (_flags), \
+ .max_antenna_gain = 0, \
+ .max_power = 30, \
+}
+
+#define CHAN5G(_channel, _flags) { \
+ .band = IEEE80211_BAND_5GHZ, \
+ .hw_value = (_channel), \
+ .center_freq = 5000 + (5 * (_channel)), \
+ .flags = (_flags), \
+ .max_antenna_gain = 0, \
+ .max_power = 30, \
+}
+
+static struct
+ieee80211_rate ar6k_rates[] = {
+ RATETAB_ENT(10, 0x1, 0),
+ RATETAB_ENT(20, 0x2, 0),
+ RATETAB_ENT(55, 0x4, 0),
+ RATETAB_ENT(110, 0x8, 0),
+ RATETAB_ENT(60, 0x10, 0),
+ RATETAB_ENT(90, 0x20, 0),
+ RATETAB_ENT(120, 0x40, 0),
+ RATETAB_ENT(180, 0x80, 0),
+ RATETAB_ENT(240, 0x100, 0),
+ RATETAB_ENT(360, 0x200, 0),
+ RATETAB_ENT(480, 0x400, 0),
+ RATETAB_ENT(540, 0x800, 0),
+};
+
+#define ar6k_a_rates (ar6k_rates + 4)
+#define ar6k_a_rates_size 8
+#define ar6k_g_rates (ar6k_rates + 0)
+#define ar6k_g_rates_size 12
+
+static struct
+ieee80211_channel ar6k_2ghz_channels[] = {
+ CHAN2G(1, 2412, 0),
+ CHAN2G(2, 2417, 0),
+ CHAN2G(3, 2422, 0),
+ CHAN2G(4, 2427, 0),
+ CHAN2G(5, 2432, 0),
+ CHAN2G(6, 2437, 0),
+ CHAN2G(7, 2442, 0),
+ CHAN2G(8, 2447, 0),
+ CHAN2G(9, 2452, 0),
+ CHAN2G(10, 2457, 0),
+ CHAN2G(11, 2462, 0),
+ CHAN2G(12, 2467, 0),
+ CHAN2G(13, 2472, 0),
+ CHAN2G(14, 2484, 0),
+};
+
+static struct
+ieee80211_channel ar6k_5ghz_a_channels[] = {
+ CHAN5G(34, 0), CHAN5G(36, 0),
+ CHAN5G(38, 0), CHAN5G(40, 0),
+ CHAN5G(42, 0), CHAN5G(44, 0),
+ CHAN5G(46, 0), CHAN5G(48, 0),
+ CHAN5G(52, 0), CHAN5G(56, 0),
+ CHAN5G(60, 0), CHAN5G(64, 0),
+ CHAN5G(100, 0), CHAN5G(104, 0),
+ CHAN5G(108, 0), CHAN5G(112, 0),
+ CHAN5G(116, 0), CHAN5G(120, 0),
+ CHAN5G(124, 0), CHAN5G(128, 0),
+ CHAN5G(132, 0), CHAN5G(136, 0),
+ CHAN5G(140, 0), CHAN5G(149, 0),
+ CHAN5G(153, 0), CHAN5G(157, 0),
+ CHAN5G(161, 0), CHAN5G(165, 0),
+ CHAN5G(184, 0), CHAN5G(188, 0),
+ CHAN5G(192, 0), CHAN5G(196, 0),
+ CHAN5G(200, 0), CHAN5G(204, 0),
+ CHAN5G(208, 0), CHAN5G(212, 0),
+ CHAN5G(216, 0),
+};
+
+static struct
+ieee80211_supported_band ar6k_band_2ghz = {
+ .n_channels = ARRAY_SIZE(ar6k_2ghz_channels),
+ .channels = ar6k_2ghz_channels,
+ .n_bitrates = ar6k_g_rates_size,
+ .bitrates = ar6k_g_rates,
+};
+
+static struct
+ieee80211_supported_band ar6k_band_5ghz = {
+ .n_channels = ARRAY_SIZE(ar6k_5ghz_a_channels),
+ .channels = ar6k_5ghz_a_channels,
+ .n_bitrates = ar6k_a_rates_size,
+ .bitrates = ar6k_a_rates,
+};
+
+static int
+ar6k_set_wpa_version(AR_SOFTC_DEV_T *arPriv, enum nl80211_wpa_versions wpa_version)
+{
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: %u\n", __func__, wpa_version));
+
+ if (!wpa_version) {
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ } else if (wpa_version & NL80211_WPA_VERSION_1) {
+ arPriv->arAuthMode = WMI_WPA_AUTH;
+ } else if (wpa_version & NL80211_WPA_VERSION_2) {
+ arPriv->arAuthMode = WMI_WPA2_AUTH;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s: %u not spported\n", __func__, wpa_version));
+ return -ENOTSUPP;
+ }
+
+ return A_OK;
+}
+
+static int
+ar6k_set_auth_type(AR_SOFTC_DEV_T *arPriv, enum nl80211_auth_type auth_type)
+{
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: 0x%x\n", __func__, auth_type));
+
+ switch (auth_type) {
+ case NL80211_AUTHTYPE_OPEN_SYSTEM:
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ break;
+ case NL80211_AUTHTYPE_SHARED_KEY:
+ arPriv->arDot11AuthMode = SHARED_AUTH;
+ break;
+ case NL80211_AUTHTYPE_NETWORK_EAP:
+ arPriv->arDot11AuthMode = LEAP_AUTH;
+ break;
+ default:
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: 0x%x not spported\n", __func__, auth_type));
+ return -ENOTSUPP;
+ }
+
+ return A_OK;
+}
+
+static int
+ar6k_set_cipher(AR_SOFTC_DEV_T *arPriv, A_UINT32 cipher, A_BOOL ucast)
+{
+ A_UINT8 *ar_cipher = ucast ? &arPriv->arPairwiseCrypto :
+ &arPriv->arGroupCrypto;
+ A_UINT8 *ar_cipher_len = ucast ? &arPriv->arPairwiseCryptoLen :
+ &arPriv->arGroupCryptoLen;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: cipher 0x%x, ucast %u\n", __func__, cipher, ucast));
+
+ switch (cipher) {
+ case 0:
+ case IW_AUTH_CIPHER_NONE:
+ *ar_cipher = NONE_CRYPT;
+ *ar_cipher_len = 0;
+ break;
+ case WLAN_CIPHER_SUITE_WEP40:
+ *ar_cipher = WEP_CRYPT;
+ *ar_cipher_len = 5;
+ break;
+ case WLAN_CIPHER_SUITE_WEP104:
+ *ar_cipher = WEP_CRYPT;
+ *ar_cipher_len = 13;
+ break;
+ case WLAN_CIPHER_SUITE_TKIP:
+#ifdef CFG80211_WAPI_ENABLE
+ *ar_cipher = WAPI_CRYPT;
+#else
+ *ar_cipher = TKIP_CRYPT;
+#endif
+ *ar_cipher_len = 0;
+ break;
+ case WLAN_CIPHER_SUITE_CCMP:
+ *ar_cipher = AES_CRYPT;
+ *ar_cipher_len = 0;
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s: cipher 0x%x not supported\n", __func__, cipher));
+ return -ENOTSUPP;
+ }
+
+ return A_OK;
+}
+
+static void
+ar6k_set_key_mgmt(AR_SOFTC_DEV_T *arPriv, A_UINT32 key_mgmt)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: 0x%x\n", __func__, key_mgmt));
+
+ if (WLAN_AKM_SUITE_PSK == key_mgmt) {
+ if (WMI_WPA_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA_PSK_AUTH;
+ } else if (WMI_WPA2_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA2_PSK_AUTH;
+ }
+ } else if (WLAN_AKM_SUITE_8021X != key_mgmt) {
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ }
+}
+
+static int
+ar6k_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
+ struct cfg80211_connect_params *sme)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ A_STATUS status;
+#ifdef CFG80211_WAPI_ENABLE
+ const unsigned char wps_oui[] = { 0x00, 0x50, 0xf2, 0x04 };
+ const unsigned char wpa_oui[] = { 0x00, 0x50, 0xf2, 0x01 };
+ unsigned char *ie = sme->ie;
+#endif
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready yet\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->bIsDestroyProgress) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: destroy in progress\n", __func__));
+ return -EBUSY;
+ }
+
+ if(!sme->ssid_len || IEEE80211_MAX_SSID_LEN < sme->ssid_len) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: ssid invalid\n", __func__));
+ return -EINVAL;
+ }
+
+ if(arSta->arSkipScan == TRUE &&
+ ((sme->channel && sme->channel->center_freq == 0) ||
+ (sme->bssid && !sme->bssid[0] && !sme->bssid[1] && !sme->bssid[2] &&
+ !sme->bssid[3] && !sme->bssid[4] && !sme->bssid[5])))
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s:SkipScan: channel or bssid invalid\n", __func__));
+ return -EINVAL;
+ }
+
+ if(down_interruptible(&ar->arSem)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: busy, couldn't get access\n", __func__));
+ return -ERESTARTSYS;
+ }
+
+ if(ar->bIsDestroyProgress) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: busy, destroy in progress\n", __func__));
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ if(ar->arTxPending[wmi_get_control_ep(arPriv->arWmi)]) {
+ /*
+ * sleep until the command queue drains
+ */
+ wait_event_interruptible_timeout(arPriv->arEvent,
+ ar->arTxPending[wmi_get_control_ep(arPriv->arWmi)] == 0, wmitimeout * HZ);
+ if (signal_pending(current)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: cmd queue drain timeout\n", __func__));
+ up(&ar->arSem);
+ return -EINTR;
+ }
+ }
+ up(&ar->arSem);
+
+ if(down_interruptible(&ar->arSem)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: busy, couldn't get access\n", __func__));
+ return -ERESTARTSYS;
+ }
+
+ if(arPriv->arConnected == TRUE &&
+ arPriv->arSsidLen == sme->ssid_len &&
+ !A_MEMCMP(arPriv->arSsid, sme->ssid, arPriv->arSsidLen)) {
+ reconnect_flag = TRUE;
+ status = wmi_reconnect_cmd(arPriv->arWmi,
+ arSta->arReqBssid,
+ arPriv->arChannelHint);
+
+ if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: wmi_reconnect_cmd failed\n", __func__));
+ return -EIO;
+ }
+ return 0;
+ } else if(arPriv->arSsidLen == sme->ssid_len &&
+ !A_MEMCMP(arPriv->arSsid, sme->ssid, arPriv->arSsidLen)) {
+ ar6000_disconnect(arPriv);
+ }
+
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = sme->ssid_len;
+ A_MEMCPY(arPriv->arSsid, sme->ssid, sme->ssid_len);
+
+ if(sme->channel){
+ arPriv->arChannelHint = sme->channel->center_freq;
+ }
+
+ A_MEMZERO(arSta->arReqBssid, sizeof(arSta->arReqBssid));
+ if(sme->bssid){
+ if(A_MEMCMP(&sme->bssid, bcast_mac, AR6000_ETH_ADDR_LEN)) {
+ A_MEMCPY(arSta->arReqBssid, sme->bssid, sizeof(arSta->arReqBssid));
+ }
+ }
+
+ ar6k_set_wpa_version(arPriv, sme->crypto.wpa_versions);
+ ar6k_set_auth_type(arPriv, sme->auth_type);
+
+ if(sme->crypto.n_ciphers_pairwise) {
+ ar6k_set_cipher(arPriv, sme->crypto.ciphers_pairwise[0], true);
+ } else {
+ ar6k_set_cipher(arPriv, IW_AUTH_CIPHER_NONE, true);
+ }
+ ar6k_set_cipher(arPriv, sme->crypto.cipher_group, false);
+
+ if(sme->crypto.n_akm_suites) {
+ ar6k_set_key_mgmt(arPriv, sme->crypto.akm_suites[0]);
+ }
+
+ if((sme->key_len) &&
+ (WMI_NONE_AUTH == arPriv->arAuthMode) &&
+ (WEP_CRYPT == arPriv->arPairwiseCrypto)) {
+ struct ar_key *key = NULL;
+
+ if(sme->key_idx < WMI_MIN_KEY_INDEX || sme->key_idx > WMI_MAX_KEY_INDEX) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s: key index %d out of bounds\n", __func__, sme->key_idx));
+ up(&ar->arSem);
+ return -ENOENT;
+ }
+
+ key = &arPriv->keys[sme->key_idx];
+ key->key_len = sme->key_len;
+ A_MEMCPY(key->key, sme->key, key->key_len);
+ key->cipher = arPriv->arPairwiseCrypto;
+ arPriv->arDefTxKeyIndex = sme->key_idx;
+
+ wmi_addKey_cmd(arPriv->arWmi, sme->key_idx,
+ arPriv->arPairwiseCrypto,
+ GROUP_USAGE | TX_USAGE,
+ key->key_len,
+ NULL,
+ key->key, KEY_OP_INIT_VAL, NULL,
+ NO_SYNC_WMIFLAG);
+ }
+
+ if (!arSta->arUserBssFilter) {
+ if (wmi_bssfilter_cmd(arPriv->arWmi, ALL_BSS_FILTER, 0) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Couldn't set bss filtering\n", __func__));
+ up(&ar->arSem);
+ return -EIO;
+ }
+ }
+
+ arPriv->arNetworkType = arPriv->arNextMode;
+
+#ifdef CFG80211_WAPI_ENABLE
+/*the following codes for wps and wapi, but ONLY test wapi*/
+ if (ie[0] == WLAN_EID_VENDOR_SPECIFIC &&
+ memcmp(ie + 2, wps_oui, sizeof(wps_oui)) == 0) {
+ /* WPS IE detected, notify target */
+ A_PRINTF("WPS IE detected -- setting WPS flag\n");
+ arPriv->arSta.arConnectCtrlFlags |= CONNECT_WPS_FLAG;
+ arPriv->arAuthMode = 0;
+ } else {
+ if ((ie[0]==IEEE80211_ELEMID_RSN) ||
+ (ie[0]==IEEE80211_ELEMID_VENDOR &&
+ memcmp(&ie[2], wpa_oui, sizeof(wpa_oui))==0)) {
+ sme->ie_len = 0; /* Firmware will set for us. Clear the previous one */
+ }
+ /* for WAPI */
+ else if (ie[0]==IEEE80211_ELEMID_WAPI)
+ {
+ }
+ /************/
+ arPriv->arSta.arConnectCtrlFlags &= ~CONNECT_WPS_FLAG;
+ }
+ wmi_set_appie_cmd(arPriv->arWmi, WMI_FRAME_ASSOC_REQ, sme->ie_len, ie);
+/*********************************************************/
+#endif
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: Connect called with authmode %d dot11 auth %d"\
+ " PW crypto %d PW crypto Len %d GRP crypto %d"\
+ " GRP crypto Len %d channel hint %u\n",
+ __func__, arPriv->arAuthMode, arPriv->arDot11AuthMode,
+ arPriv->arPairwiseCrypto, arPriv->arPairwiseCryptoLen,
+ arPriv->arGroupCrypto, arPriv->arGroupCryptoLen, arPriv->arChannelHint));
+ reconnect_flag = 0;
+ status = wmi_connect_cmd(arPriv->arWmi, arPriv->arNetworkType,
+ arPriv->arDot11AuthMode, arPriv->arAuthMode,
+ arPriv->arPairwiseCrypto, arPriv->arPairwiseCryptoLen,
+ arPriv->arGroupCrypto,arPriv->arGroupCryptoLen,
+ arPriv->arSsidLen, arPriv->arSsid,
+ arSta->arReqBssid, arPriv->arChannelHint,
+ arSta->arConnectCtrlFlags);
+
+ up(&ar->arSem);
+
+ if (A_EINVAL == status) {
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Invalid request\n", __func__));
+ return -ENOENT;
+ } else if (status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: wmi_connect_cmd failed\n", __func__));
+ return -EIO;
+ }
+
+ if ((!(arSta->arConnectCtrlFlags & CONNECT_DO_WPA_OFFLOAD)) &&
+ ((WMI_WPA_PSK_AUTH == arPriv->arAuthMode) || (WMI_WPA2_PSK_AUTH == arPriv->arAuthMode)))
+ {
+ A_TIMEOUT_MS(&arSta->disconnect_timer, A_DISCONNECT_TIMER_INTERVAL, 0);
+ }
+
+ arSta->arConnectCtrlFlags &= ~CONNECT_DO_WPA_OFFLOAD;
+ arSta->arConnectPending = TRUE;
+
+ return 0;
+}
+
+void
+ar6k_cfg80211_connect_event(AR_SOFTC_DEV_T *arPriv, A_UINT16 channel,
+ A_UINT8 *bssid, A_UINT16 listenInterval,
+ A_UINT16 beaconInterval,NETWORK_TYPE networkType,
+ A_UINT8 beaconIeLen, A_UINT8 assocReqLen,
+ A_UINT8 assocRespLen, A_UINT8 *assocInfo)
+{
+ A_UINT16 size = 0;
+ A_UINT16 capability = 0;
+ struct cfg80211_bss *bss = NULL;
+ struct ieee80211_mgmt *mgmt = NULL;
+ struct ieee80211_channel *ibss_channel = NULL;
+ s32 signal = 50 * 100;
+ A_UINT8 ie_buf_len = 0;
+ unsigned char ie_buf[256];
+ unsigned char *ptr_ie_buf = ie_buf;
+ unsigned char *ieeemgmtbuf = NULL;
+ A_UINT8 source_mac[ATH_MAC_LEN];
+
+ A_UINT8 assocReqIeOffset = sizeof(A_UINT16) + /* capinfo*/
+ sizeof(A_UINT16); /* listen interval */
+ A_UINT8 assocRespIeOffset = sizeof(A_UINT16) + /* capinfo*/
+ sizeof(A_UINT16) + /* status Code */
+ sizeof(A_UINT16); /* associd */
+ A_UINT8 *assocReqIe = assocInfo + beaconIeLen + assocReqIeOffset;
+ A_UINT8 *assocRespIe = assocInfo + beaconIeLen + assocReqLen + assocRespIeOffset;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ assocReqLen -= assocReqIeOffset;
+ assocRespLen -= assocRespIeOffset;
+
+ if((ADHOC_NETWORK & networkType)) {
+ if(NL80211_IFTYPE_ADHOC != arPriv->wdev->iftype) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: ath6k not in ibss mode\n", __func__));
+ return;
+ }
+ }
+
+ if((INFRA_NETWORK & networkType)) {
+ if(NL80211_IFTYPE_STATION != arPriv->wdev->iftype) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: ath6k not in station mode\n", __func__));
+ return;
+ }
+ }
+
+ /* Before informing the join/connect event, make sure that
+ * bss entry is present in scan list, if it not present
+ * construct and insert into scan list, otherwise that
+ * event will be dropped on the way by cfg80211, due to
+ * this keys will not be plumbed in case of WEP and
+ * application will not be aware of join/connect status. */
+ bss = cfg80211_get_bss(arPriv->wdev->wiphy, NULL, bssid,
+ arPriv->wdev->ssid, arPriv->wdev->ssid_len,
+ ((ADHOC_NETWORK & networkType) ? WLAN_CAPABILITY_IBSS : WLAN_CAPABILITY_ESS),
+ ((ADHOC_NETWORK & networkType) ? WLAN_CAPABILITY_IBSS : WLAN_CAPABILITY_ESS));
+
+ if(!bss) {
+ if (ADHOC_NETWORK & networkType) {
+ /* construct 802.11 mgmt beacon */
+ if(ptr_ie_buf) {
+ *ptr_ie_buf++ = WLAN_EID_SSID;
+ *ptr_ie_buf++ = arPriv->arSsidLen;
+ A_MEMCPY(ptr_ie_buf, arPriv->arSsid, arPriv->arSsidLen);
+ ptr_ie_buf +=arPriv->arSsidLen;
+
+ *ptr_ie_buf++ = WLAN_EID_IBSS_PARAMS;
+ *ptr_ie_buf++ = 2; /* length */
+ *ptr_ie_buf++ = 0; /* ATIM window */
+ *ptr_ie_buf++ = 0; /* ATIM window */
+
+ /* TODO: update ibss params and include supported rates,
+ * DS param set, extened support rates, wmm. */
+
+ ie_buf_len = ptr_ie_buf - ie_buf;
+ }
+
+ capability |= IEEE80211_CAPINFO_IBSS;
+ if(WEP_CRYPT == arPriv->arPairwiseCrypto) {
+ capability |= IEEE80211_CAPINFO_PRIVACY;
+ }
+ A_MEMCPY(source_mac, arPriv->arNetDev->dev_addr, ATH_MAC_LEN);
+ ptr_ie_buf = ie_buf;
+ } else {
+ capability = *(A_UINT16 *)(&assocInfo[beaconIeLen]);
+ A_MEMCPY(source_mac, bssid, ATH_MAC_LEN);
+ ptr_ie_buf = assocReqIe;
+ ie_buf_len = assocReqLen;
+ }
+
+ size = offsetof(struct ieee80211_mgmt, u)
+ + sizeof(mgmt->u.beacon)
+ + ie_buf_len;
+
+ ieeemgmtbuf = A_MALLOC_NOWAIT(size);
+ if(!ieeemgmtbuf) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s: ieeeMgmtbuf alloc error\n", __func__));
+ return;
+ }
+
+ A_MEMZERO(ieeemgmtbuf, size);
+ mgmt = (struct ieee80211_mgmt *)ieeemgmtbuf;
+ mgmt->frame_control = (IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_BEACON);
+ A_MEMCPY(mgmt->da, bcast_mac, ATH_MAC_LEN);
+ A_MEMCPY(mgmt->sa, source_mac, ATH_MAC_LEN);
+ A_MEMCPY(mgmt->bssid, bssid, ATH_MAC_LEN);
+ mgmt->u.beacon.beacon_int = beaconInterval;
+ mgmt->u.beacon.capab_info = capability;
+ A_MEMCPY(mgmt->u.beacon.variable, ptr_ie_buf, ie_buf_len);
+
+ ibss_channel = ieee80211_get_channel(arPriv->wdev->wiphy, (int)channel);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: inform bss with bssid %02x:%02x:%02x:%02x:%02x:%02x "\
+ "channel %d beaconInterval %d capability 0x%x\n",
+ __func__,
+ mgmt->bssid[0], mgmt->bssid[1], mgmt->bssid[2],
+ mgmt->bssid[3], mgmt->bssid[4], mgmt->bssid[5],
+ ibss_channel->hw_value, beaconInterval, capability));
+
+ bss = cfg80211_inform_bss_frame(arPriv->wdev->wiphy,
+ ibss_channel, mgmt,
+ le16_to_cpu(size),
+ signal, GFP_ATOMIC);
+ A_FREE(ieeemgmtbuf);
+ cfg80211_put_bss(bss);
+ }
+
+ if((ADHOC_NETWORK & networkType)) {
+ cfg80211_ibss_joined(arPriv->arNetDev, bssid, GFP_ATOMIC);
+ return;
+ }
+
+ if (FALSE == arPriv->arConnected) {
+ /* inform connect result to cfg80211 */
+ cfg80211_connect_result(arPriv->arNetDev, bssid,
+ assocReqIe, assocReqLen,
+ assocRespIe, assocRespLen,
+ WLAN_STATUS_SUCCESS, GFP_ATOMIC);
+ } else {
+ /* inform roam event to cfg80211 */
+ cfg80211_roamed(arPriv->arNetDev, bssid,
+ assocReqIe, assocReqLen,
+ assocRespIe, assocRespLen,
+ GFP_ATOMIC);
+ }
+}
+
+static int
+ar6k_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
+ A_UINT16 reason_code)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: reason=%u\n", __func__, reason_code));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->bIsDestroyProgress) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: busy, destroy in progress\n", __func__));
+ return -EBUSY;
+ }
+
+ if(down_interruptible(&ar->arSem)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: busy, couldn't get access\n", __func__));
+ return -ERESTARTSYS;
+ }
+
+ reconnect_flag = 0;
+ ar6000_disconnect(arPriv);
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+
+ if (arPriv->arSta.arSkipScan == FALSE) {
+ A_MEMZERO(arPriv->arSta.arReqBssid, sizeof(arPriv->arSta.arReqBssid));
+ }
+
+ up(&ar->arSem);
+
+ return 0;
+}
+
+void
+ar6k_cfg80211_disconnect_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 reason,
+ A_UINT8 *bssid, A_UINT8 assocRespLen,
+ A_UINT8 *assocInfo, A_UINT16 protocolReasonStatus)
+{
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: reason=%u\n", __func__, reason));
+
+ if((ADHOC_NETWORK & arPriv->arNetworkType)) {
+ if(NL80211_IFTYPE_ADHOC != arPriv->wdev->iftype) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: ath6k not in ibss mode\n", __func__));
+ return;
+ }
+ A_MEMZERO(bssid, ETH_ALEN);
+ cfg80211_ibss_joined(arPriv->arNetDev, bssid, GFP_ATOMIC);
+ return;
+ }
+
+ if((INFRA_NETWORK & arPriv->arNetworkType)) {
+ if(NL80211_IFTYPE_STATION != arPriv->wdev->iftype) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: ath6k not in station mode\n", __func__));
+ return;
+ }
+ }
+
+ if(FALSE == arPriv->arConnected) {
+ if(NO_NETWORK_AVAIL == reason) {
+ /* connect cmd failed */
+ cfg80211_connect_result(arPriv->arNetDev, bssid,
+ NULL, 0,
+ NULL, 0,
+ WLAN_STATUS_UNSPECIFIED_FAILURE,
+ GFP_ATOMIC);
+ }
+ } else {
+ /* connection loss due to disconnect cmd or low rssi */
+ cfg80211_disconnected(arPriv->arNetDev, reason, NULL, 0, GFP_ATOMIC);
+ }
+}
+
+void
+ar6k_cfg80211_scan_node(void *arg, bss_t *ni)
+{
+ struct wiphy *wiphy = (struct wiphy *)arg;
+ A_UINT16 size;
+ unsigned char *ieeemgmtbuf = NULL;
+ struct ieee80211_mgmt *mgmt;
+ struct ieee80211_channel *channel;
+ struct ieee80211_supported_band *band;
+ struct ieee80211_common_ie *cie;
+ s32 signal;
+ int freq;
+
+ cie = &ni->ni_cie;
+
+#define CHAN_IS_11A(x) (!((x >= 2412) && (x <= 2484)))
+ if(CHAN_IS_11A(cie->ie_chan)) {
+ /* 11a */
+ band = wiphy->bands[IEEE80211_BAND_5GHZ];
+ } else if((cie->ie_erp) || (cie->ie_xrates)) {
+ /* 11g */
+ band = wiphy->bands[IEEE80211_BAND_2GHZ];
+ } else {
+ /* 11b */
+ band = wiphy->bands[IEEE80211_BAND_2GHZ];
+ }
+
+ size = ni->ni_framelen + offsetof(struct ieee80211_mgmt, u);
+ ieeemgmtbuf = A_MALLOC_NOWAIT(size);
+ if(!ieeemgmtbuf)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: ieeeMgmtbuf alloc error\n", __func__));
+ return;
+ }
+
+ /* Note:
+ TODO: Update target to include 802.11 mac header while sending bss info.
+ Target removes 802.11 mac header while sending the bss info to host,
+ cfg80211 needs it, for time being just filling the da, sa and bssid fields alone.
+ */
+ mgmt = (struct ieee80211_mgmt *)ieeemgmtbuf;
+ A_MEMCPY(mgmt->da, bcast_mac, ATH_MAC_LEN);
+ A_MEMCPY(mgmt->sa, ni->ni_macaddr, ATH_MAC_LEN);
+ A_MEMCPY(mgmt->bssid, ni->ni_macaddr, ATH_MAC_LEN);
+ A_MEMCPY(ieeemgmtbuf + offsetof(struct ieee80211_mgmt, u),
+ ni->ni_buf, ni->ni_framelen);
+
+ freq = cie->ie_chan;
+ channel = ieee80211_get_channel(wiphy, freq);
+ signal = ni->ni_snr * 100;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: bssid %02x:%02x:%02x:%02x:%02x:%02x channel %d freq %d size %d\n",
+ __func__,
+ mgmt->bssid[0], mgmt->bssid[1], mgmt->bssid[2],
+ mgmt->bssid[3], mgmt->bssid[4], mgmt->bssid[5],
+ channel->hw_value, freq, size));
+ cfg80211_inform_bss_frame(wiphy, channel, mgmt,
+ le16_to_cpu(size),
+ signal, GFP_ATOMIC);
+
+ A_FREE (ieeemgmtbuf);
+}
+
+static int
+ar6k_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
+ struct cfg80211_scan_request *request)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ndev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ int ret = 0;
+ A_BOOL forceFgScan = FALSE;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if (!arPriv->arSta.arUserBssFilter) {
+ if (wmi_bssfilter_cmd(arPriv->arWmi,
+ (arPriv->arConnected ? ALL_BUT_BSS_FILTER : ALL_BSS_FILTER),
+ 0) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Couldn't set bss filtering\n", __func__));
+ return -EIO;
+ }
+ }
+
+ if(request->n_ssids &&
+ request->ssids[0].ssid_len) {
+ A_UINT8 i;
+
+ if(request->n_ssids > MAX_PROBED_SSID_INDEX) {
+ request->n_ssids = MAX_PROBED_SSID_INDEX;
+ }
+
+ for (i = 0; i < request->n_ssids; i++) {
+ wmi_probedSsid_cmd(arPriv->arWmi, i, SPECIFIC_SSID_FLAG,
+ request->ssids[i].ssid_len,
+ request->ssids[i].ssid);
+ }
+ }
+
+ if(arPriv->arConnected) {
+ forceFgScan = TRUE;
+ }
+
+ if(wmi_startscan_cmd(arPriv->arWmi, WMI_LONG_SCAN, forceFgScan, FALSE, \
+ 0, 0, 0, NULL) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: wmi_startscan_cmd failed\n", __func__));
+ ret = -EIO;
+ }
+
+ arPriv->scan_request = request;
+
+ return ret;
+}
+
+void
+ar6k_cfg80211_scanComplete_event(AR_SOFTC_DEV_T *arPriv, A_STATUS status)
+{
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: status %d\n", __func__, status));
+
+ if(arPriv->scan_request)
+ {
+ /* Translate data to cfg80211 mgmt format */
+ wmi_iterate_nodes(arPriv->arWmi, ar6k_cfg80211_scan_node, arPriv->wdev->wiphy);
+
+ cfg80211_scan_done(arPriv->scan_request,
+ (status & A_ECANCELED) ? true : false);
+
+ if(arPriv->scan_request->n_ssids &&
+ arPriv->scan_request->ssids[0].ssid_len) {
+ A_UINT8 i;
+
+ for (i = 0; i < arPriv->scan_request->n_ssids; i++) {
+ wmi_probedSsid_cmd(arPriv->arWmi, i, DISABLE_SSID_FLAG,
+ 0, NULL);
+ }
+ }
+ arPriv->scan_request = NULL;
+ }
+}
+
+static int
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)
+ar6k_cfg80211_add_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index, bool pairwise, const A_UINT8 *mac_addr,
+ struct key_params *params)
+#else
+ar6k_cfg80211_add_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index, const A_UINT8 *mac_addr,
+ struct key_params *params)
+#endif
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ndev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ struct ar_key *key = NULL;
+ A_UINT8 key_usage;
+ A_UINT8 key_type;
+ A_STATUS status = 0;
+#ifdef CFG80211_WAPI_ENABLE
+ A_UINT32 *PN;
+ A_INT32 i;
+ A_UINT8 wapiKeyRsc[16] = {0};
+ #define PN_INIT 0x5c365c36
+#endif
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s:\n", __func__));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(key_index < WMI_MIN_KEY_INDEX || key_index > WMI_MAX_KEY_INDEX) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: key index %d out of bounds\n", __func__, key_index));
+ return -ENOENT;
+ }
+
+ key = &arPriv->keys[key_index];
+ A_MEMZERO(key, sizeof(struct ar_key));
+
+ if(!mac_addr || is_broadcast_ether_addr(mac_addr)) {
+ key_usage = GROUP_USAGE;
+ } else {
+ key_usage = PAIRWISE_USAGE;
+ }
+
+ if(params) {
+ if(params->key_len > WLAN_MAX_KEY_LEN ||
+ params->seq_len > IW_ENCODE_SEQ_MAX_SIZE)
+ return -EINVAL;
+
+ key->key_len = params->key_len;
+ A_MEMCPY(key->key, params->key, key->key_len);
+ key->seq_len = params->seq_len;
+ A_MEMCPY(key->seq, params->seq, key->seq_len);
+ key->cipher = params->cipher;
+ }
+
+ switch (key->cipher) {
+ case WLAN_CIPHER_SUITE_WEP40:
+ case WLAN_CIPHER_SUITE_WEP104:
+ key_type = WEP_CRYPT;
+ break;
+
+ case WLAN_CIPHER_SUITE_TKIP:
+ key_type = TKIP_CRYPT;
+ break;
+
+ case WLAN_CIPHER_SUITE_CCMP:
+ key_type = AES_CRYPT;
+ break;
+
+ default:
+ return -ENOTSUPP;
+ }
+
+ if (((WMI_WPA_PSK_AUTH == arPriv->arAuthMode) || (WMI_WPA2_PSK_AUTH == arPriv->arAuthMode)) &&
+ (GROUP_USAGE & key_usage))
+ {
+ A_UNTIMEOUT(&arPriv->arSta.disconnect_timer);
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: index %d, key_len %d, key_type 0x%x,"\
+ " key_usage 0x%x, seq_len %d\n",
+ __func__, key_index, key->key_len, key_type,
+ key_usage, key->seq_len));
+ arPriv->arDefTxKeyIndex = key_index;
+
+#ifdef CFG80211_WAPI_ENABLE
+ key_type = WAPI_CRYPT;
+ key_usage = 0;
+ if (is_broadcast_ether_addr(mac_addr)) {
+ key_usage |= GROUP_USAGE;
+ PN = (A_UINT32 *)wapiKeyRsc;
+ for (i = 0; i < 4; i++) {
+ PN[i] = PN_INIT;
+ }
+ } else {
+ key_usage |= PAIRWISE_USAGE;
+ }
+ status = wmi_addKey_cmd(arPriv->arWmi, arPriv->arDefTxKeyIndex, key_type, key_usage,
+ key->key_len, wapiKeyRsc, key->key, KEY_OP_INIT_VAL,
+ (A_UINT8*)mac_addr, SYNC_BOTH_WMIFLAG);
+#else
+ status = wmi_addKey_cmd(arPriv->arWmi, arPriv->arDefTxKeyIndex, key_type, key_usage,
+ key->key_len, key->seq, key->key, KEY_OP_INIT_VAL,
+ (A_UINT8*)mac_addr, SYNC_BOTH_WMIFLAG);
+#endif
+
+
+ if(status != A_OK) {
+ return -EIO;
+ }
+
+ return 0;
+}
+
+static int
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)
+ar6k_cfg80211_del_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index, bool pairwise, const A_UINT8 *mac_addr)
+#else
+ar6k_cfg80211_del_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index, const A_UINT8 *mac_addr)
+#endif
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ndev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: index %d\n", __func__, key_index));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(key_index < WMI_MIN_KEY_INDEX || key_index > WMI_MAX_KEY_INDEX) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: key index %d out of bounds\n", __func__, key_index));
+ return -ENOENT;
+ }
+
+ if(!arPriv->keys[key_index].key_len) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: index %d is empty\n", __func__, key_index));
+ return 0;
+ }
+
+ arPriv->keys[key_index].key_len = 0;
+
+ return wmi_deleteKey_cmd(arPriv->arWmi, key_index);
+}
+
+
+static int
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)
+ar6k_cfg80211_get_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index, bool pairwise, const A_UINT8 *mac_addr,
+ void *cookie,
+ void (*callback)(void *cookie, struct key_params*))
+#else
+ar6k_cfg80211_get_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index, const A_UINT8 *mac_addr, void *cookie,
+ void (*callback)(void *cookie, struct key_params*))
+#endif
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ndev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ struct ar_key *key = NULL;
+ struct key_params params;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: index %d\n", __func__, key_index));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(key_index < WMI_MIN_KEY_INDEX || key_index > WMI_MAX_KEY_INDEX) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: key index %d out of bounds\n", __func__, key_index));
+ return -ENOENT;
+ }
+
+ key = &arPriv->keys[key_index];
+ A_MEMZERO(¶ms, sizeof(params));
+ params.cipher = key->cipher;
+ params.key_len = key->key_len;
+ params.seq_len = key->seq_len;
+ params.seq = key->seq;
+ params.key = key->key;
+
+ callback(cookie, ¶ms);
+
+ return key->key_len ? 0 : -ENOENT;
+}
+
+
+static int
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)
+ar6k_cfg80211_set_default_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index,bool unicast, bool multicast)
+#else
+ar6k_cfg80211_set_default_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index)
+#endif
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ndev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ struct ar_key *key = NULL;
+ A_STATUS status = A_OK;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: index %d\n", __func__, key_index));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(key_index < WMI_MIN_KEY_INDEX || key_index > WMI_MAX_KEY_INDEX) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: key index %d out of bounds\n",
+ __func__, key_index));
+ return -ENOENT;
+ }
+
+ if(!arPriv->keys[key_index].key_len) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: invalid key index %d\n",
+ __func__, key_index));
+ return -EINVAL;
+ }
+
+ arPriv->arDefTxKeyIndex = key_index;
+ key = &arPriv->keys[arPriv->arDefTxKeyIndex];
+#ifdef CFG80211_WAPI_ENABLE
+ /*if WAPI enable, we donot need to set it*/
+#else
+ status = wmi_addKey_cmd(arPriv->arWmi, arPriv->arDefTxKeyIndex,
+ arPriv->arPairwiseCrypto, GROUP_USAGE | TX_USAGE,
+ key->key_len, key->seq, key->key, KEY_OP_INIT_VAL,
+ NULL, SYNC_BOTH_WMIFLAG);
+ if (status != A_OK) {
+ return -EIO;
+ }
+#endif
+ return 0;
+}
+
+static int
+ar6k_cfg80211_set_default_mgmt_key(struct wiphy *wiphy, struct net_device *ndev,
+ A_UINT8 key_index)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ndev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: index %d\n", __func__, key_index));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: not supported\n", __func__));
+ return -ENOTSUPP;
+}
+
+void
+ar6k_cfg80211_tkip_micerr_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 keyid, A_BOOL ismcast)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,
+ ("%s: keyid %d, ismcast %d\n", __func__, keyid, ismcast));
+
+ cfg80211_michael_mic_failure(arPriv->arNetDev, arPriv->arBssid,
+ (ismcast ? NL80211_KEYTYPE_GROUP : NL80211_KEYTYPE_PAIRWISE),
+ keyid, NULL, GFP_KERNEL);
+}
+
+static int
+ar6k_cfg80211_set_wiphy_params(struct wiphy *wiphy, A_UINT32 changed)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)wiphy_priv(wiphy);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: changed 0x%x\n", __func__, changed));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if (changed & WIPHY_PARAM_RTS_THRESHOLD) {
+ if (wmi_set_rts_cmd(arPriv->arWmi,wiphy->rts_threshold) != A_OK){
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: wmi_set_rts_cmd failed\n", __func__));
+ return -EIO;
+ }
+ }
+
+ return 0;
+}
+
+static int
+ar6k_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
+ const A_UINT8 *peer,
+ const struct cfg80211_bitrate_mask *mask)
+{
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,34)
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_STATUS status;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: mask 0x%x\n", __func__, mask->fixed));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ status = wmi_set_fixrates_cmd(arPriv->arWmi, mask->fixed);
+
+ if(status == A_EINVAL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: invalid params\n", __func__));
+ return -EINVAL;
+ } else if(status != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: wmi_set_fixrates_cmd failed\n", __func__));
+ return -EIO;
+ }
+
+ return 0;
+#else
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Setting rates: Not supported\n"));
+ return -EIO;
+#endif
+}
+
+/* The type nl80211_tx_power_setting replaces the following data type from 2.6.36 onwards */
+static int
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)
+ar6k_cfg80211_set_txpower(struct wiphy *wiphy, enum nl80211_tx_power_setting type, int dbm)
+#else
+ar6k_cfg80211_set_txpower(struct wiphy *wiphy, enum tx_power_setting type, int dbm)
+#endif
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)wiphy_priv(wiphy);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UINT8 ar_dbm;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: type 0x%x, dbm %d\n", __func__, type, dbm));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ arPriv->arTxPwrSet = FALSE;
+ switch(type) {
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)
+ case NL80211_TX_POWER_AUTOMATIC:
+#else
+ case TX_POWER_AUTOMATIC:
+#endif
+ return 0;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37)
+ case NL80211_TX_POWER_LIMITED:
+#else
+ case TX_POWER_LIMITED:
+#endif
+ arPriv->arTxPwr = ar_dbm = dbm;
+ arPriv->arTxPwrSet = TRUE;
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: type 0x%x not supported\n", __func__, type));
+ return -EOPNOTSUPP;
+ }
+
+ wmi_set_txPwr_cmd(arPriv->arWmi, ar_dbm);
+
+ return 0;
+}
+
+static int
+ar6k_cfg80211_get_txpower(struct wiphy *wiphy, int *dbm)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)wiphy_priv(wiphy);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if((arPriv->arConnected == TRUE)) {
+ arPriv->arTxPwr = 0;
+
+ if(wmi_get_txPwr_cmd(arPriv->arWmi) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: wmi_get_txPwr_cmd failed\n", __func__));
+ return -EIO;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->arTxPwr != 0, 5 * HZ);
+
+ if(signal_pending(current)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Target did not respond\n", __func__));
+ return -EINTR;
+ }
+ }
+
+ *dbm = arPriv->arTxPwr;
+ return 0;
+}
+
+static int
+ar6k_cfg80211_set_power_mgmt(struct wiphy *wiphy,
+ struct net_device *dev,
+ bool pmgmt, int timeout)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_POWER_MODE_CMD pwrMode;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: pmgmt %d, timeout %d\n", __func__, pmgmt, timeout));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(!pmgmt) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: Max Perf\n", __func__));
+ pwrMode.powerMode = MAX_PERF_POWER;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: Rec Power\n", __func__));
+ pwrMode.powerMode = REC_POWER;
+ }
+
+ if(wmi_powermode_cmd(arPriv->arWmi, pwrMode.powerMode) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: wmi_powermode_cmd failed\n", __func__));
+ return -EIO;
+ }
+
+ return 0;
+}
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)
+struct net_device *
+ar6k_cfg80211_add_virtual_intf(struct wiphy *wiphy, char *name,
+ enum nl80211_iftype type, u32 *flags,
+ struct vif_params *params)
+#else
+static int
+ar6k_cfg80211_add_virtual_intf(struct wiphy *wiphy, char *name,
+ enum nl80211_iftype type, u32 *flags,
+ struct vif_params *params)
+#endif
+{
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: not supported\n", __func__));
+
+ /* Multiple virtual interface is not supported.
+ * The default interface supports STA and IBSS type
+ */
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,38)
+ return NULL;
+#else
+ return -EOPNOTSUPP;
+#endif
+}
+
+static int
+ar6k_cfg80211_del_virtual_intf(struct wiphy *wiphy, struct net_device *dev)
+{
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: not supported\n", __func__));
+
+ /* Multiple virtual interface is not supported.
+ * The default interface supports STA and IBSS type
+ */
+ return -EOPNOTSUPP;
+}
+
+static int
+ar6k_cfg80211_change_iface(struct wiphy *wiphy, struct net_device *ndev,
+ enum nl80211_iftype type, u32 *flags,
+ struct vif_params *params)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(ndev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ struct wireless_dev *wdev = arPriv->wdev;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: type %u\n", __func__, type));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ switch (type) {
+ case NL80211_IFTYPE_STATION:
+ arPriv->arNextMode = INFRA_NETWORK;
+ break;
+ case NL80211_IFTYPE_ADHOC:
+ arPriv->arNextMode = ADHOC_NETWORK;
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: type %u\n", __func__, type));
+ return -EOPNOTSUPP;
+ }
+
+ wdev->iftype = type;
+
+ return 0;
+}
+
+static int
+ar6k_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
+ struct cfg80211_ibss_params *ibss_param)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta;
+ A_STATUS status;
+
+ arSta = &arPriv->arSta;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ if(!ibss_param->ssid_len || IEEE80211_MAX_SSID_LEN < ibss_param->ssid_len) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: ssid invalid\n", __func__));
+ return -EINVAL;
+ }
+
+ arPriv->arSsidLen = ibss_param->ssid_len;
+ A_MEMCPY(arPriv->arSsid, ibss_param->ssid, arPriv->arSsidLen);
+
+ if(ibss_param->channel) {
+ arPriv->arChannelHint = ibss_param->channel->center_freq;
+ }
+
+ if(ibss_param->channel_fixed) {
+ /* TODO: channel_fixed: The channel should be fixed, do not search for
+ * IBSSs to join on other channels. Target firmware does not support this
+ * feature, needs to be updated.*/
+ }
+
+ A_MEMZERO(arSta->arReqBssid, sizeof(arSta->arReqBssid));
+ if(ibss_param->bssid) {
+ if(A_MEMCMP(&ibss_param->bssid, bcast_mac, AR6000_ETH_ADDR_LEN)) {
+ A_MEMCPY(arSta->arReqBssid, ibss_param->bssid, sizeof(arSta->arReqBssid));
+ }
+ }
+
+ ar6k_set_wpa_version(arPriv, 0);
+ ar6k_set_auth_type(arPriv, NL80211_AUTHTYPE_OPEN_SYSTEM);
+
+ if(ibss_param->privacy) {
+ ar6k_set_cipher(arPriv, WLAN_CIPHER_SUITE_WEP40, true);
+ ar6k_set_cipher(arPriv, WLAN_CIPHER_SUITE_WEP40, false);
+ } else {
+ ar6k_set_cipher(arPriv, IW_AUTH_CIPHER_NONE, true);
+ ar6k_set_cipher(arPriv, IW_AUTH_CIPHER_NONE, false);
+ }
+
+ arPriv->arNetworkType = arPriv->arNextMode;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: Connect called with authmode %d dot11 auth %d"\
+ " PW crypto %d PW crypto Len %d GRP crypto %d"\
+ " GRP crypto Len %d channel hint %u\n",
+ __func__, arPriv->arAuthMode, arPriv->arDot11AuthMode,
+ arPriv->arPairwiseCrypto, arPriv->arPairwiseCryptoLen,
+ arPriv->arGroupCrypto, arPriv->arGroupCryptoLen, arPriv->arChannelHint));
+
+ status = wmi_connect_cmd(arPriv->arWmi, arPriv->arNetworkType,
+ arPriv->arDot11AuthMode, arPriv->arAuthMode,
+ arPriv->arPairwiseCrypto, arPriv->arPairwiseCryptoLen,
+ arPriv->arGroupCrypto,arPriv->arGroupCryptoLen,
+ arPriv->arSsidLen, arPriv->arSsid,
+ arSta->arReqBssid, arPriv->arChannelHint,
+ arSta->arConnectCtrlFlags);
+ arSta->arConnectPending = TRUE;
+
+ return 0;
+}
+
+static int
+ar6k_cfg80211_leave_ibss(struct wiphy *wiphy, struct net_device *dev)
+{
+
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ if(ar->arWmiReady == FALSE) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready\n", __func__));
+ return -EIO;
+ }
+
+ if(ar->arWlanState == WLAN_DISABLED) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wlan disabled\n", __func__));
+ return -EIO;
+ }
+
+ ar6000_disconnect(arPriv);
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+
+ return 0;
+}
+
+
+static const
+A_UINT32 cipher_suites[] = {
+ WLAN_CIPHER_SUITE_WEP40,
+ WLAN_CIPHER_SUITE_WEP104,
+ WLAN_CIPHER_SUITE_TKIP,
+ WLAN_CIPHER_SUITE_CCMP,
+};
+
+static struct
+cfg80211_ops ar6k_cfg80211_ops = {
+ .change_virtual_intf = ar6k_cfg80211_change_iface,
+ .add_virtual_intf = ar6k_cfg80211_add_virtual_intf,
+ .del_virtual_intf = ar6k_cfg80211_del_virtual_intf,
+ .scan = ar6k_cfg80211_scan,
+ .connect = ar6k_cfg80211_connect,
+ .disconnect = ar6k_cfg80211_disconnect,
+ .add_key = ar6k_cfg80211_add_key,
+ .get_key = ar6k_cfg80211_get_key,
+ .del_key = ar6k_cfg80211_del_key,
+ .set_default_key = ar6k_cfg80211_set_default_key,
+ .set_default_mgmt_key = ar6k_cfg80211_set_default_mgmt_key,
+ .set_wiphy_params = ar6k_cfg80211_set_wiphy_params,
+ .set_bitrate_mask = ar6k_cfg80211_set_bitrate_mask,
+ .set_tx_power = ar6k_cfg80211_set_txpower,
+ .get_tx_power = ar6k_cfg80211_get_txpower,
+ .set_power_mgmt = ar6k_cfg80211_set_power_mgmt,
+ .join_ibss = ar6k_cfg80211_join_ibss,
+ .leave_ibss = ar6k_cfg80211_leave_ibss,
+};
+
+struct wireless_dev *
+ar6k_cfg80211_init(struct device *dev)
+{
+ int ret = 0;
+ struct wireless_dev *wdev;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ wdev = kzalloc(sizeof(struct wireless_dev), GFP_KERNEL);
+ if(!wdev) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s: Couldn't allocate wireless device\n", __func__));
+ return ERR_PTR(-ENOMEM);
+ }
+
+ /* create a new wiphy for use with cfg80211 */
+ wdev->wiphy = wiphy_new(&ar6k_cfg80211_ops, sizeof(AR_SOFTC_T));
+ if(!wdev->wiphy) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s: Couldn't allocate wiphy device\n", __func__));
+ kfree(wdev);
+ return ERR_PTR(-ENOMEM);
+ }
+
+ /* set device pointer for wiphy */
+ set_wiphy_dev(wdev->wiphy, dev);
+
+ wdev->wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION) |
+ BIT(NL80211_IFTYPE_ADHOC);
+ /* max num of ssids that can be probed during scanning */
+ wdev->wiphy->max_scan_ssids = MAX_PROBED_SSID_INDEX;
+ wdev->wiphy->bands[IEEE80211_BAND_2GHZ] = &ar6k_band_2ghz;
+ wdev->wiphy->bands[IEEE80211_BAND_5GHZ] = &ar6k_band_5ghz;
+ wdev->wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM;
+
+ wdev->wiphy->cipher_suites = cipher_suites;
+ wdev->wiphy->n_cipher_suites = ARRAY_SIZE(cipher_suites);
+
+ ret = wiphy_register(wdev->wiphy);
+ if(ret < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("%s: Couldn't register wiphy device\n", __func__));
+ wiphy_free(wdev->wiphy);
+ return ERR_PTR(ret);
+ }
+
+ return wdev;
+}
+
+void
+ar6k_cfg80211_deinit(AR_SOFTC_DEV_T *arPriv)
+{
+ struct wireless_dev *wdev = arPriv->wdev;
+
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
+
+ if(arPriv->scan_request) {
+ cfg80211_scan_done(arPriv->scan_request, true);
+ arPriv->scan_request = NULL;
+ }
+
+ if(!wdev)
+ return;
+
+ wiphy_unregister(wdev->wiphy);
+ wiphy_free(wdev->wiphy);
+ kfree(wdev);
+}
+
+
+
+
+
+
+
diff --git a/host/os/linux/eeprom.c b/host/os/linux/eeprom.c
new file mode 100644
index 0000000..fb086b4
--- /dev/null
+++ b/host/os/linux/eeprom.c
@@ -0,0 +1,572 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+
+#include "ar6000_drv.h"
+#include "htc.h"
+#include <linux/fs.h>
+
+#include "target_reg_table.h"
+#include "host_reg_table.h
+//
+// defines
+//
+
+#define MAX_FILENAME 1023
+#define EEPROM_WAIT_LIMIT 16
+
+#define EEPROM_SZ 768
+
+/* soft mac */
+#define ATH_MAC_LEN 6
+#define ATH_SOFT_MAC_TMP_BUF_LEN 64
+unsigned char mac_addr[ATH_MAC_LEN];
+unsigned char soft_mac_tmp_buf[ATH_SOFT_MAC_TMP_BUF_LEN];
+char *p_mac = NULL;
+/* soft mac */
+
+//
+// static variables
+//
+
+static A_UCHAR eeprom_data[EEPROM_SZ];
+static A_UINT32 sys_sleep_reg;
+static HIF_DEVICE *p_bmi_device;
+
+//
+// Functions
+//
+
+/* soft mac */
+static int
+wmic_ether_aton(const char *orig, A_UINT8 *eth)
+{
+ const char *bufp;
+ int i;
+
+ i = 0;
+ for(bufp = orig; *bufp != '\0'; ++bufp) {
+ unsigned int val;
+ unsigned char c = *bufp++;
+ if (c >= '0' && c <= '9') val = c - '0';
+ else if (c >= 'a' && c <= 'f') val = c - 'a' + 10;
+ else if (c >= 'A' && c <= 'F') val = c - 'A' + 10;
+ else {
+ printk("%s: MAC value is invalid\n", __FUNCTION__);
+ break;
+ }
+
+ val <<= 4;
+ c = *bufp++;
+ if (c >= '0' && c <= '9') val |= c - '0';
+ else if (c >= 'a' && c <= 'f') val |= c - 'a' + 10;
+ else if (c >= 'A' && c <= 'F') val |= c - 'A' + 10;
+ else {
+ printk("%s: MAC value is invalid\n", __FUNCTION__);
+ break;
+ }
+
+ eth[i] = (unsigned char) (val & 0377);
+ if(++i == ATH_MAC_LEN) {
+ /* That's it. Any trailing junk? */
+ if (*bufp != '\0') {
+ return 0;
+ }
+ return 1;
+ }
+ if (*bufp != ':')
+ break;
+ }
+ return 0;
+}
+
+static void
+update_mac(unsigned char* eeprom, int size, unsigned char* macaddr)
+{
+ int i;
+ A_UINT16* ptr = (A_UINT16*)(eeprom+4);
+ A_UINT16 checksum = 0;
+
+ memcpy(eeprom+10,macaddr,6);
+
+ *ptr = 0;
+ ptr = (A_UINT16*)eeprom;
+
+ for (i=0; i<size; i+=2) {
+ checksum ^= *ptr++;
+ }
+ checksum = ~checksum;
+
+ ptr = (A_UINT16*)(eeprom+4);
+ *ptr = checksum;
+ return;
+}
+/* soft mac */
+
+/* Read a Target register and return its value. */
+inline void
+BMI_read_reg(A_UINT32 address, A_UINT32 *pvalue)
+{
+ BMIReadSOCRegister(p_bmi_device, address, pvalue);
+}
+
+/* Write a value to a Target register. */
+inline void
+BMI_write_reg(A_UINT32 address, A_UINT32 value)
+{
+ BMIWriteSOCRegister(p_bmi_device, address, value);
+}
+
+/* Read Target memory word and return its value. */
+inline void
+BMI_read_mem(A_UINT32 address, A_UINT32 *pvalue)
+{
+ BMIReadMemory(p_bmi_device, address, (A_UCHAR*)(pvalue), 4);
+}
+
+/* Write a word to a Target memory. */
+inline void
+BMI_write_mem(A_UINT32 address, A_UINT8 *p_data, A_UINT32 sz)
+{
+ BMIWriteMemory(p_bmi_device, address, (A_UCHAR*)(p_data), sz);
+}
+
+/*
+ * Enable and configure the Target's Serial Interface
+ * so we can access the EEPROM.
+ */
+static void
+enable_SI(HIF_DEVICE *p_device)
+{
+ A_UINT32 regval;
+
+ printk("%s\n", __FUNCTION__);
+
+ p_bmi_device = p_device;
+
+ BMI_read_reg(RTC_WMAC_BASE_ADDRESS+WLAN_SYSTEM_SLEEP_OFFSET, &sys_sleep_reg);
+ BMI_write_reg(RTC_WMAC_BASE_ADDRESS+WLAN_SYSTEM_SLEEP_OFFSET, SYSTEM_SLEEP_DISABLE_SET(1)); //disable system sleep temporarily
+
+ BMI_read_reg(RTC_SOC_BASE_ADDRESS+CLOCK_CONTROL_OFFSET, ®val);
+ regval &= ~CLOCK_CONTROL_SI0_CLK_MASK;
+ BMI_write_reg(RTC_SOC_BASE_ADDRESS+CLOCK_CONTROL_OFFSET, regval);
+
+ BMI_read_reg(RTC_SOC_BASE_ADDRESS+RESET_CONTROL_OFFSET, ®val);
+ regval &= ~RESET_CONTROL_SI0_RST_MASK;
+ BMI_write_reg(RTC_SOC_BASE_ADDRESS+RESET_CONTROL_OFFSET, regval);
+
+
+ BMI_read_reg(GPIO_BASE_ADDRESS+GPIO_PIN0_OFFSET, ®val);
+ regval &= ~GPIO_PIN0_CONFIG_MASK;
+ BMI_write_reg(GPIO_BASE_ADDRESS+GPIO_PIN0_OFFSET, regval);
+
+ BMI_read_reg(GPIO_BASE_ADDRESS+GPIO_PIN1_OFFSET, ®val);
+ regval &= ~GPIO_PIN1_CONFIG_MASK;
+ BMI_write_reg(GPIO_BASE_ADDRESS+GPIO_PIN1_OFFSET, regval);
+
+ /* SI_CONFIG = 0x500a6; */
+ regval = SI_CONFIG_BIDIR_OD_DATA_SET(1) |
+ SI_CONFIG_I2C_SET(1) |
+ SI_CONFIG_POS_SAMPLE_SET(1) |
+ SI_CONFIG_INACTIVE_CLK_SET(1) |
+ SI_CONFIG_INACTIVE_DATA_SET(1) |
+ SI_CONFIG_DIVIDER_SET(6);
+ BMI_write_reg(SI_BASE_ADDRESS+SI_CONFIG_OFFSET, regval);
+
+}
+
+static void
+disable_SI(void)
+{
+ A_UINT32 regval;
+
+ printk("%s\n", __FUNCTION__);
+
+ BMI_write_reg(RTC_SOC_BASE_ADDRESS+RESET_CONTROL_OFFSET, RESET_CONTROL_SI0_RST_MASK);
+ BMI_read_reg(RTC_SOC_BASE_ADDRESS+CLOCK_CONTROL_OFFSET, ®val);
+ regval |= CLOCK_CONTROL_SI0_CLK_MASK;
+ BMI_write_reg(RTC_SOC_BASE_ADDRESS+CLOCK_CONTROL_OFFSET, regval);//Gate SI0 clock
+ BMI_write_reg(RTC_WMAC_BASE_ADDRESS+WLAN_SYSTEM_SLEEP_OFFSET, sys_sleep_reg); //restore system sleep setting
+}
+
+/*
+ * Tell the Target to start an 8-byte read from EEPROM,
+ * putting the results in Target RX_DATA registers.
+ */
+static void
+request_8byte_read(int offset)
+{
+ A_UINT32 regval;
+
+// printk("%s: request_8byte_read from offset 0x%x\n", __FUNCTION__, offset);
+
+
+ /* SI_TX_DATA0 = read from offset */
+ regval =(0xa1<<16)|
+ ((offset & 0xff)<<8) |
+ (0xa0 | ((offset & 0xff00)>>7));
+
+ BMI_write_reg(SI_BASE_ADDRESS+SI_TX_DATA0_OFFSET, regval);
+
+ regval = SI_CS_START_SET(1) |
+ SI_CS_RX_CNT_SET(8) |
+ SI_CS_TX_CNT_SET(3);
+ BMI_write_reg(SI_BASE_ADDRESS+SI_CS_OFFSET, regval);
+}
+
+/*
+ * Tell the Target to start a 4-byte write to EEPROM,
+ * writing values from Target TX_DATA registers.
+ */
+static void
+request_4byte_write(int offset, A_UINT32 data)
+{
+ A_UINT32 regval;
+
+ printk("%s: request_4byte_write (0x%x) to offset 0x%x\n", __FUNCTION__, data, offset);
+
+ /* SI_TX_DATA0 = write data to offset */
+ regval = ((data & 0xffff) <<16) |
+ ((offset & 0xff)<<8) |
+ (0xa0 | ((offset & 0xff00)>>7));
+ BMI_write_reg(SI_BASE_ADDRESS+SI_TX_DATA0_OFFSET, regval);
+
+ regval = data >> 16;
+ BMI_write_reg(SI_BASE_ADDRESS+SI_TX_DATA1_OFFSET, regval);
+
+ regval = SI_CS_START_SET(1) |
+ SI_CS_RX_CNT_SET(0) |
+ SI_CS_TX_CNT_SET(6);
+ BMI_write_reg(SI_BASE_ADDRESS+SI_CS_OFFSET, regval);
+}
+
+/*
+ * Check whether or not an EEPROM request that was started
+ * earlier has completed yet.
+ */
+static A_BOOL
+request_in_progress(void)
+{
+ A_UINT32 regval;
+
+ /* Wait for DONE_INT in SI_CS */
+ BMI_read_reg(SI_BASE_ADDRESS+SI_CS_OFFSET, ®val);
+
+// printk("%s: request in progress SI_CS=0x%x\n", __FUNCTION__, regval);
+ if (regval & SI_CS_DONE_ERR_MASK) {
+ printk("%s: EEPROM signaled ERROR (0x%x)\n", __FUNCTION__, regval);
+ }
+
+ return (!(regval & SI_CS_DONE_INT_MASK));
+}
+
+/*
+ * try to detect the type of EEPROM,16bit address or 8bit address
+ */
+
+static void eeprom_type_detect(void)
+{
+ A_UINT32 regval;
+ A_UINT8 i = 0;
+
+ request_8byte_read(0x100);
+ /* Wait for DONE_INT in SI_CS */
+ do{
+ BMI_read_reg(SI_BASE_ADDRESS+SI_CS_OFFSET, ®val);
+ if (regval & SI_CS_DONE_ERR_MASK) {
+ printk("%s: ERROR : address type was wrongly set\n", __FUNCTION__);
+ break;
+ }
+ if (i++ == EEPROM_WAIT_LIMIT) {
+ printk("%s: EEPROM not responding\n", __FUNCTION__);
+ }
+ } while(!(regval & SI_CS_DONE_INT_MASK));
+}
+
+/*
+ * Extract the results of a completed EEPROM Read request
+ * and return them to the caller.
+ */
+inline void
+read_8byte_results(A_UINT32 *data)
+{
+ /* Read SI_RX_DATA0 and SI_RX_DATA1 */
+ BMI_read_reg(SI_BASE_ADDRESS+SI_RX_DATA0_OFFSET, &data[0]);
+ BMI_read_reg(SI_BASE_ADDRESS+SI_RX_DATA1_OFFSET, &data[1]);
+}
+
+
+/*
+ * Wait for a previously started command to complete.
+ * Timeout if the command is takes "too long".
+ */
+static void
+wait_for_eeprom_completion(void)
+{
+ int i=0;
+
+ while (request_in_progress()) {
+ if (i++ == EEPROM_WAIT_LIMIT) {
+ printk("%s: EEPROM not responding\n", __FUNCTION__);
+ }
+ }
+}
+
+/*
+ * High-level function which starts an 8-byte read,
+ * waits for it to complete, and returns the result.
+ */
+static void
+fetch_8bytes(int offset, A_UINT32 *data)
+{
+ request_8byte_read(offset);
+ wait_for_eeprom_completion();
+ read_8byte_results(data);
+
+ /* Clear any pending intr */
+ BMI_write_reg(SI_BASE_ADDRESS+SI_CS_OFFSET, SI_CS_DONE_INT_MASK);
+}
+
+/*
+ * High-level function which starts a 4-byte write,
+ * and waits for it to complete.
+ */
+inline void
+commit_4bytes(int offset, A_UINT32 data)
+{
+ request_4byte_write(offset, data);
+ wait_for_eeprom_completion();
+}
+/* ATHENV */
+#ifdef ANDROID_ENV
+void eeprom_ar6000_transfer(HIF_DEVICE *device, char *fake_file, char *p_mac)
+{
+ A_UINT32 first_word;
+ A_UINT32 board_data_addr;
+ int i;
+
+ printk("%s: Enter\n", __FUNCTION__);
+
+ enable_SI(device);
+ eeprom_type_detect();
+
+ if (fake_file) {
+ /*
+ * Transfer from file to Target RAM.
+ * Fetch source data from file.
+ */
+ mm_segment_t oldfs;
+ struct file *filp;
+ struct inode *inode = NULL;
+ int length;
+
+ /* open file */
+ oldfs = get_fs();
+ set_fs(KERNEL_DS);
+ filp = filp_open(fake_file, O_RDONLY, S_IRUSR);
+
+ if (IS_ERR(filp)) {
+ printk("%s: file %s filp_open error\n", __FUNCTION__, fake_file);
+ set_fs(oldfs);
+ return;
+ }
+
+ if (!filp->f_op) {
+ printk("%s: File Operation Method Error\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+ inode = GET_INODE_FROM_FILEP(filep);
+ if (!inode) {
+ printk("%s: Get inode from filp failed\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+ printk("%s file offset opsition: %xh\n", __FUNCTION__, (unsigned)filp->f_pos);
+
+ /* file's size */
+ length = i_size_read(inode->i_mapping->host);
+ printk("%s: length=%d\n", __FUNCTION__, length);
+ if (length != EEPROM_SZ) {
+ printk("%s: The file's size is not as expected\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+ /* read data */
+ if (filp->f_op->read(filp, eeprom_data, length, &filp->f_pos) != length) {
+ printk("%s: file read error\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+ /* read data out successfully */
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ } else {
+ /*
+ * Read from EEPROM to file OR transfer from EEPROM to Target RAM.
+ * Fetch EEPROM_SZ Bytes of Board Data, 8 bytes at a time.
+ */
+
+ fetch_8bytes(0, (A_UINT32 *)(&eeprom_data[0]));
+
+ /* Check the first word of EEPROM for validity */
+ first_word = *((A_UINT32 *)eeprom_data);
+
+ if ((first_word == 0) || (first_word == 0xffffffff)) {
+ printk("Did not find EEPROM with valid Board Data.\n");
+ }
+
+ for (i=8; i<EEPROM_SZ; i+=8) {
+ fetch_8bytes(i, (A_UINT32 *)(&eeprom_data[i]));
+ }
+ }
+
+ /* soft mac */
+ if (p_mac) {
+
+ mm_segment_t oldfs;
+ struct file *filp;
+ struct inode *inode = NULL;
+ int length;
+
+ /* open file */
+ oldfs = get_fs();
+ set_fs(KERNEL_DS);
+ filp = filp_open(p_mac, O_RDONLY, S_IRUSR);
+
+ printk("%s try to open file %s\n", __FUNCTION__, p_mac);
+
+ if (IS_ERR(filp)) {
+ printk("%s: file %s filp_open error\n", __FUNCTION__, p_mac);
+ set_fs(oldfs);
+ return;
+ }
+
+ if (!filp->f_op) {
+ printk("%s: File Operation Method Error\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+ inode = GET_INODE_FROM_FILEP(filep);
+ if (!inode) {
+ printk("%s: Get inode from filp failed\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+ printk("%s file offset opsition: %xh\n", __FUNCTION__, (unsigned)filp->f_pos);
+
+ /* file's size */
+ length = i_size_read(inode->i_mapping->host);
+ printk("%s: length=%d\n", __FUNCTION__, length);
+ if (length > ATH_SOFT_MAC_TMP_BUF_LEN) {
+ printk("%s: MAC file's size is not as expected\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+ /* read data */
+ if (filp->f_op->read(filp, soft_mac_tmp_buf, length, &filp->f_pos) != length) {
+ printk("%s: file read error\n", __FUNCTION__);
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+ return;
+ }
+
+#if 0
+ /* the data we just read */
+ printk("%s: mac address from the file:\n", __FUNCTION__);
+ for (i = 0; i < length; i++)
+ printk("[%c(0x%x)],", soft_mac_tmp_buf[i], soft_mac_tmp_buf[i]);
+ printk("\n");
+#endif
+
+ /* read data out successfully */
+ filp_close(filp, NULL);
+ set_fs(oldfs);
+
+ /* convert mac address */
+ if (!wmic_ether_aton(soft_mac_tmp_buf, mac_addr)) {
+ printk("%s: convert mac value fail\n", __FUNCTION__);
+ return;
+ }
+
+#if 0
+ /* the converted mac address */
+ printk("%s: the converted mac value\n", __FUNCTION__);
+ for (i = 0; i < ATH_MAC_LEN; i++)
+ printk("[0x%x],", mac_addr[i]);
+ printk("\n");
+#endif
+ }
+ /* soft mac */
+
+ /* Determine where in Target RAM to write Board Data */
+ BMI_read_mem( AR6002_HOST_INTEREST_ITEM_ADDRESS(hi_board_data), &board_data_addr);
+ if (board_data_addr == 0) {
+ printk("hi_board_data is zero\n");
+ }
+
+ /* soft mac */
+#if 1
+ /* Update MAC address in RAM */
+ if (p_mac) {
+ update_mac(eeprom_data, EEPROM_SZ, mac_addr);
+ }
+#endif
+#if 0
+ /* mac address in eeprom array */
+ printk("%s: mac values in eeprom array\n", __FUNCTION__);
+ for (i = 10; i < 10 + 6; i++)
+ printk("[0x%x],", eeprom_data[i]);
+ printk("\n");
+#endif
+ /* soft mac */
+
+ /* Write EEPROM data to Target RAM */
+ BMI_write_mem(board_data_addr, ((A_UINT8 *)eeprom_data), EEPROM_SZ);
+
+ /* Record the fact that Board Data IS initialized */
+ {
+ A_UINT32 one = 1;
+ BMI_write_mem(AR6002_HOST_INTEREST_ITEM_ADDRESS(hi_board_data_initialized),
+ (A_UINT8 *)&one, sizeof(A_UINT32));
+ }
+
+ disable_SI();
+}
+#endif
+/* ATHENV */
+
diff --git a/host/os/linux/export_hci_transport.c b/host/os/linux/export_hci_transport.c
new file mode 100644
index 0000000..c44311b
--- /dev/null
+++ b/host/os/linux/export_hci_transport.c
@@ -0,0 +1,122 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// HCI bridge implementation
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#include <a_config.h>
+#include <athdefs.h>
+#include "a_types.h"
+#include "a_osapi.h"
+#include "htc_api.h"
+#include "a_drv.h"
+#include "hif.h"
+#include "common_drv.h"
+#include "a_debug.h"
+#include "hci_transport_api.h"
+
+
+HCI_TRANSPORT_HANDLE (*_HCI_TransportAttach)(void *HTCHandle, HCI_TRANSPORT_CONFIG_INFO *pInfo);
+void (*_HCI_TransportDetach)(HCI_TRANSPORT_HANDLE HciTrans);
+A_STATUS (*_HCI_TransportAddReceivePkts)(HCI_TRANSPORT_HANDLE HciTrans, HTC_PACKET_QUEUE *pQueue);
+A_STATUS (*_HCI_TransportSendPkt)(HCI_TRANSPORT_HANDLE HciTrans, HTC_PACKET *pPacket, A_BOOL Synchronous);
+void (*_HCI_TransportStop)(HCI_TRANSPORT_HANDLE HciTrans);
+A_STATUS (*_HCI_TransportStart)(HCI_TRANSPORT_HANDLE HciTrans);
+A_STATUS (*_HCI_TransportEnableDisableAsyncRecv)(HCI_TRANSPORT_HANDLE HciTrans, A_BOOL Enable);
+A_STATUS (*_HCI_TransportRecvHCIEventSync)(HCI_TRANSPORT_HANDLE HciTrans,
+ HTC_PACKET *pPacket,
+ int MaxPollMS);
+A_STATUS (*_HCI_TransportSetBaudRate)(HCI_TRANSPORT_HANDLE HciTrans, A_UINT32 Baud);
+A_STATUS (*_HCI_TransportEnablePowerMgmt)(HCI_TRANSPORT_HANDLE HciTrans, A_BOOL Enable);
+
+extern HCI_TRANSPORT_CALLBACKS ar6kHciTransCallbacks;
+
+A_STATUS ar6000_register_hci_transport(HCI_TRANSPORT_CALLBACKS *hciTransCallbacks)
+{
+ ar6kHciTransCallbacks = *hciTransCallbacks;
+
+ _HCI_TransportAttach = HCI_TransportAttach;
+ _HCI_TransportDetach = HCI_TransportDetach;
+ _HCI_TransportAddReceivePkts = HCI_TransportAddReceivePkts;
+ _HCI_TransportSendPkt = HCI_TransportSendPkt;
+ _HCI_TransportStop = HCI_TransportStop;
+ _HCI_TransportStart = HCI_TransportStart;
+ _HCI_TransportEnableDisableAsyncRecv = HCI_TransportEnableDisableAsyncRecv;
+ _HCI_TransportRecvHCIEventSync = HCI_TransportRecvHCIEventSync;
+ _HCI_TransportSetBaudRate = HCI_TransportSetBaudRate;
+ _HCI_TransportEnablePowerMgmt = HCI_TransportEnablePowerMgmt;
+
+ return A_OK;
+}
+
+A_STATUS
+ar6000_get_hif_dev(HIF_DEVICE *device, void *config)
+{
+ A_STATUS status;
+
+ status = HIFConfigureDevice(device,
+ HIF_DEVICE_GET_OS_DEVICE,
+ (HIF_DEVICE_OS_DEVICE_INFO *)config,
+ sizeof(HIF_DEVICE_OS_DEVICE_INFO));
+ return status;
+}
+
+A_STATUS ar6000_set_uart_config(HIF_DEVICE *hifDevice,
+ A_UINT32 scale,
+ A_UINT32 step)
+{
+ A_UINT32 regAddress;
+ A_UINT32 regVal;
+ A_STATUS status;
+
+ regAddress = WLAN_UART_BASE_ADDRESS | UART_CLKDIV_ADDRESS;
+ regVal = ((A_UINT32)scale << 16) | step;
+ /* change the HCI UART scale/step values through the diagnostic window */
+ status = ar6000_WriteRegDiag(hifDevice, ®Address, ®Val);
+
+ return status;
+}
+
+A_STATUS ar6000_get_core_clock_config(HIF_DEVICE *hifDevice, A_UINT32 *data)
+{
+ A_UINT32 regAddress;
+ A_STATUS status;
+
+ regAddress = WLAN_RTC_BASE_ADDRESS | WLAN_CPU_CLOCK_ADDRESS;
+ /* read CPU clock settings*/
+ status = ar6000_ReadRegDiag(hifDevice, ®Address, data);
+
+ return status;
+}
+
+EXPORT_SYMBOL(ar6000_register_hci_transport);
+EXPORT_SYMBOL(ar6000_get_hif_dev);
+EXPORT_SYMBOL(ar6000_set_uart_config);
+EXPORT_SYMBOL(ar6000_get_core_clock_config);
+EXPORT_SYMBOL(_HCI_TransportAttach);
+EXPORT_SYMBOL(_HCI_TransportDetach);
+EXPORT_SYMBOL(_HCI_TransportAddReceivePkts);
+EXPORT_SYMBOL(_HCI_TransportSendPkt);
+EXPORT_SYMBOL(_HCI_TransportStop);
+EXPORT_SYMBOL(_HCI_TransportStart);
+EXPORT_SYMBOL(_HCI_TransportEnableDisableAsyncRecv);
+EXPORT_SYMBOL(_HCI_TransportRecvHCIEventSync);
+EXPORT_SYMBOL(_HCI_TransportSetBaudRate);
+EXPORT_SYMBOL(_HCI_TransportEnablePowerMgmt);
diff --git a/host/os/linux/hci_bridge.c b/host/os/linux/hci_bridge.c
new file mode 100644
index 0000000..a81b383
--- /dev/null
+++ b/host/os/linux/hci_bridge.c
@@ -0,0 +1,1174 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// HCI bridge implementation
+//
+// Author(s): ="Atheros"
+//==============================================================================
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+#include <linux/etherdevice.h>
+#include <a_config.h>
+#include <athdefs.h>
+#include "a_types.h"
+#include "a_osapi.h"
+#include "htc_api.h"
+#include "wmi.h"
+#include "a_drv.h"
+#include "hif.h"
+#include "common_drv.h"
+#include "a_debug.h"
+#define ATH_DEBUG_HCI_BRIDGE ATH_DEBUG_MAKE_MODULE_MASK(6)
+#define ATH_DEBUG_HCI_RECV ATH_DEBUG_MAKE_MODULE_MASK(7)
+#define ATH_DEBUG_HCI_SEND ATH_DEBUG_MAKE_MODULE_MASK(8)
+#define ATH_DEBUG_HCI_DUMP ATH_DEBUG_MAKE_MODULE_MASK(9)
+#else
+#include "ar6000_drv.h"
+#endif /* EXPORT_HCI_BRIDGE_INTERFACE */
+
+#ifdef ATH_AR6K_ENABLE_GMBOX
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+#include "export_hci_transport.h"
+#else
+#include "hci_transport_api.h"
+#endif
+#include "epping_test.h"
+#include "gmboxif.h"
+#include "ar3kconfig.h"
+#include <net/bluetooth/bluetooth.h>
+#include <net/bluetooth/hci_core.h>
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,25)
+ /* only build on newer kernels which have BT configured */
+#if defined(CONFIG_BT_MODULE) || defined(CONFIG_BT)
+#define CONFIG_BLUEZ_HCI_BRIDGE
+#endif
+#endif
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+unsigned int ar3khcibaud = 0;
+unsigned int hciuartscale = 0;
+unsigned int hciuartstep = 0;
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+module_param(ar3khcibaud, int, 0644);
+module_param(hciuartscale, int, 0644);
+module_param(hciuartstep, int, 0644);
+#else
+
+#define __user
+/* for linux 2.4 and lower */
+MODULE_PARM(ar3khcibaud, "i");
+MODULE_PARM(hciuartscale, "i");
+MODULE_PARM(hciuartstep, "i");
+#endif
+#else
+extern unsigned int ar3khcibaud;
+extern unsigned int hciuartscale;
+extern unsigned int hciuartstep;
+#endif /* EXPORT_HCI_BRIDGE_INTERFACE */
+
+typedef struct {
+ void *pHCIDev; /* HCI bridge device */
+ HCI_TRANSPORT_PROPERTIES HCIProps; /* HCI bridge props */
+ struct hci_dev *pBtStackHCIDev; /* BT Stack HCI dev */
+ A_BOOL HciNormalMode; /* Actual HCI mode enabled (non-TEST)*/
+ A_BOOL HciRegistered; /* HCI device registered with stack */
+ HTC_PACKET_QUEUE HTCPacketStructHead;
+ A_UINT8 *pHTCStructAlloc;
+ spinlock_t BridgeLock;
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ HCI_TRANSPORT_MISC_HANDLES HCITransHdl;
+#else
+ AR_SOFTC_T *ar;
+#endif /* EXPORT_HCI_BRIDGE_INTERFACE */
+} AR6K_HCI_BRIDGE_INFO;
+
+#define MAX_ACL_RECV_BUFS 16
+#define MAX_EVT_RECV_BUFS 8
+#define MAX_HCI_WRITE_QUEUE_DEPTH 32
+#define MAX_ACL_RECV_LENGTH 1200
+#define MAX_EVT_RECV_LENGTH 257
+#define TX_PACKET_RSV_OFFSET 32
+#define NUM_HTC_PACKET_STRUCTS ((MAX_ACL_RECV_BUFS + MAX_EVT_RECV_BUFS + MAX_HCI_WRITE_QUEUE_DEPTH) * 2)
+
+#define HCI_GET_OP_CODE(p) (((A_UINT16)((p)[1])) << 8) | ((A_UINT16)((p)[0]))
+
+extern unsigned int setupbtdev;
+AR3K_CONFIG_INFO ar3kconfig;
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+AR6K_HCI_BRIDGE_INFO *g_pHcidevInfo;
+#endif
+
+static A_STATUS bt_setup_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo);
+static void bt_cleanup_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo);
+static A_STATUS bt_register_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo);
+static A_BOOL bt_indicate_recv(AR6K_HCI_BRIDGE_INFO *pHcidevInfo,
+ HCI_TRANSPORT_PACKET_TYPE Type,
+ struct sk_buff *skb);
+static struct sk_buff *bt_alloc_buffer(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, int Length);
+static void bt_free_buffer(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, struct sk_buff *skb);
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+A_STATUS ar6000_setup_hci(void *ar);
+void ar6000_cleanup_hci(void *ar);
+A_STATUS hci_test_send(void *ar, struct sk_buff *skb);
+#else
+A_STATUS ar6000_setup_hci(AR_SOFTC_T *ar);
+void ar6000_cleanup_hci(AR_SOFTC_T *ar);
+/* HCI bridge testing */
+A_STATUS hci_test_send(AR_SOFTC_T *ar, struct sk_buff *skb);
+#endif /* EXPORT_HCI_BRIDGE_INTERFACE */
+
+#define LOCK_BRIDGE(dev) spin_lock_bh(&(dev)->BridgeLock)
+#define UNLOCK_BRIDGE(dev) spin_unlock_bh(&(dev)->BridgeLock)
+
+static inline void FreeBtOsBuf(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, void *osbuf)
+{
+ if (pHcidevInfo->HciNormalMode) {
+ bt_free_buffer(pHcidevInfo, (struct sk_buff *)osbuf);
+ } else {
+ /* in test mode, these are just ordinary netbuf allocations */
+ A_NETBUF_FREE(osbuf);
+ }
+}
+
+static void FreeHTCStruct(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, HTC_PACKET *pPacket)
+{
+ LOCK_BRIDGE(pHcidevInfo);
+ HTC_PACKET_ENQUEUE(&pHcidevInfo->HTCPacketStructHead,pPacket);
+ UNLOCK_BRIDGE(pHcidevInfo);
+}
+
+static HTC_PACKET * AllocHTCStruct(AR6K_HCI_BRIDGE_INFO *pHcidevInfo)
+{
+ HTC_PACKET *pPacket = NULL;
+ LOCK_BRIDGE(pHcidevInfo);
+ pPacket = HTC_PACKET_DEQUEUE(&pHcidevInfo->HTCPacketStructHead);
+ UNLOCK_BRIDGE(pHcidevInfo);
+ return pPacket;
+}
+
+#define BLOCK_ROUND_UP_PWR2(x, align) (((int) (x) + ((align)-1)) & ~((align)-1))
+
+static void RefillRecvBuffers(AR6K_HCI_BRIDGE_INFO *pHcidevInfo,
+ HCI_TRANSPORT_PACKET_TYPE Type,
+ int NumBuffers)
+{
+ int length, i;
+ void *osBuf = NULL;
+ HTC_PACKET_QUEUE queue;
+ HTC_PACKET *pPacket;
+
+ INIT_HTC_PACKET_QUEUE(&queue);
+
+ if (Type == HCI_ACL_TYPE) {
+ if (pHcidevInfo->HciNormalMode) {
+ length = HCI_MAX_FRAME_SIZE;
+ } else {
+ length = MAX_ACL_RECV_LENGTH;
+ }
+ } else {
+ length = MAX_EVT_RECV_LENGTH;
+ }
+
+ /* add on transport head and tail room */
+ length += pHcidevInfo->HCIProps.HeadRoom + pHcidevInfo->HCIProps.TailRoom;
+ /* round up to the required I/O padding */
+ length = BLOCK_ROUND_UP_PWR2(length,pHcidevInfo->HCIProps.IOBlockPad);
+
+ for (i = 0; i < NumBuffers; i++) {
+
+ if (pHcidevInfo->HciNormalMode) {
+ osBuf = bt_alloc_buffer(pHcidevInfo,length);
+ } else {
+ osBuf = A_NETBUF_ALLOC(length);
+ }
+
+ if (NULL == osBuf) {
+ break;
+ }
+
+ pPacket = AllocHTCStruct(pHcidevInfo);
+ if (NULL == pPacket) {
+ FreeBtOsBuf(pHcidevInfo,osBuf);
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Failed to alloc HTC struct \n"));
+ break;
+ }
+
+ SET_HTC_PACKET_INFO_RX_REFILL(pPacket,osBuf,A_NETBUF_DATA(osBuf),length,Type);
+ /* add to queue */
+ HTC_PACKET_ENQUEUE(&queue,pPacket);
+ }
+
+ if (i > 0) {
+ HCI_TransportAddReceivePkts(pHcidevInfo->pHCIDev, &queue);
+ }
+}
+
+static A_STATUS ar6000_hci_transport_ready(HCI_TRANSPORT_HANDLE HCIHandle,
+ HCI_TRANSPORT_PROPERTIES *pProps,
+ void *pContext)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)pContext;
+ A_STATUS status;
+ AR_SOFTC_DEV_T *arDev = pHcidevInfo->ar->arDev[0];
+
+
+ pHcidevInfo->pHCIDev = HCIHandle;
+
+ A_MEMCPY(&pHcidevInfo->HCIProps,pProps,sizeof(*pProps));
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_BRIDGE,("HCI ready (hci:0x%lX, headroom:%d, tailroom:%d blockpad:%d) \n",
+ (unsigned long)HCIHandle,
+ pHcidevInfo->HCIProps.HeadRoom,
+ pHcidevInfo->HCIProps.TailRoom,
+ pHcidevInfo->HCIProps.IOBlockPad));
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ A_ASSERT((pProps->HeadRoom + pProps->TailRoom) <= (struct net_device *)(pHcidevInfo->HCITransHdl.netDevice)->hard_header_len);
+#else
+ A_ASSERT((pProps->HeadRoom + pProps->TailRoom) <= arDev->arNetDev->hard_header_len);
+#endif
+
+ /* provide buffers */
+ RefillRecvBuffers(pHcidevInfo, HCI_ACL_TYPE, MAX_ACL_RECV_BUFS);
+ RefillRecvBuffers(pHcidevInfo, HCI_EVENT_TYPE, MAX_EVT_RECV_BUFS);
+
+ do {
+ /* start transport */
+ status = HCI_TransportStart(pHcidevInfo->pHCIDev);
+
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ if (!pHcidevInfo->HciNormalMode) {
+ /* in test mode, no need to go any further */
+ break;
+ }
+
+ // The delay is required when AR6K is driving the BT reset line
+ // where time is needed after the BT chip is out of reset (HCI_TransportStart)
+ // and before the first HCI command is issued (AR3KConfigure)
+ // FIXME
+ // The delay should be configurable and be only applied when AR6K driving the BT
+ // reset line. This could be done by some module parameter or based on some HW config
+ // info. For now apply 100ms delay blindly
+ A_MDELAY(100);
+
+ A_MEMZERO(&ar3kconfig,sizeof(ar3kconfig));
+ ar3kconfig.pHCIDev = pHcidevInfo->pHCIDev;
+ ar3kconfig.pHCIProps = &pHcidevInfo->HCIProps;
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ ar3kconfig.pHIFDevice = (HIF_DEVICE *)(pHcidevInfo->HCITransHdl.hifDevice);
+#else
+ ar3kconfig.pHIFDevice = pHcidevInfo->ar->arHifDevice;
+#endif
+ ar3kconfig.pBtStackHCIDev = pHcidevInfo->pBtStackHCIDev;
+
+ if (ar3khcibaud != 0) {
+ /* user wants ar3k baud rate change */
+ ar3kconfig.Flags |= AR3K_CONFIG_FLAG_SET_AR3K_BAUD;
+ ar3kconfig.Flags |= AR3K_CONFIG_FLAG_AR3K_BAUD_CHANGE_DELAY;
+ ar3kconfig.AR3KBaudRate = ar3khcibaud;
+ }
+
+ if ((hciuartscale != 0) || (hciuartstep != 0)) {
+ /* user wants to tune HCI bridge UART scale/step values */
+ ar3kconfig.AR6KScale = (A_UINT16)hciuartscale;
+ ar3kconfig.AR6KStep = (A_UINT16)hciuartstep;
+ ar3kconfig.Flags |= AR3K_CONFIG_FLAG_SET_AR6K_SCALE_STEP;
+ }
+
+ /* configure the AR3K device */
+ memcpy(ar3kconfig.bdaddr,pHcidevInfo->ar->bdaddr,6);
+ status = AR3KConfigure(&ar3kconfig);
+ if (A_FAILED(status)) {
+ extern unsigned int setuphci;
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: Fail to configure AR3K. No device? Cleanup HCI\n"));
+ pHcidevInfo->ar->exitCallback = NULL;
+ ar6000_cleanup_hci(pHcidevInfo->ar);
+ setuphci = 0;
+ pHcidevInfo->ar->arBTSharing = 0;
+ break;
+ }
+
+ /* Make sure both AR6K and AR3K have power management enabled */
+ if (ar3kconfig.PwrMgmtEnabled) {
+ A_UINT32 address, hci_uart_pwr_mgmt_params;
+ /* Fetch the address of the hi_hci_uart_pwr_mgmt_params instance in the host interest area */
+ address = TARG_VTOP(pHcidevInfo->ar->arTargetType,
+ HOST_INTEREST_ITEM_ADDRESS(pHcidevInfo->ar->arTargetType, hi_hci_uart_pwr_mgmt_params));
+ status = ar6000_ReadRegDiag(pHcidevInfo->ar->arHifDevice, &address, &hci_uart_pwr_mgmt_params);
+ hci_uart_pwr_mgmt_params &= 0xFFFF;
+ /* wakeup timeout is [31:16] */
+ hci_uart_pwr_mgmt_params |= (ar3kconfig.WakeupTimeout << 16);
+ status |= ar6000_WriteRegDiag(pHcidevInfo->ar->arHifDevice, &address, &hci_uart_pwr_mgmt_params);
+ if (A_OK != status) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: failed to write hci_uart_pwr_mgmt_params!\n"));
+ }
+
+ /* Fetch the address of the hi_hci_uart_pwr_mgmt_params_ext instance in the host interest area */
+ address = TARG_VTOP(pHcidevInfo->ar->arTargetType,
+ HOST_INTEREST_ITEM_ADDRESS(pHcidevInfo->ar->arTargetType, hi_hci_uart_pwr_mgmt_params_ext));
+ status = ar6000_WriteRegDiag(pHcidevInfo->ar->arHifDevice, &address, &ar3kconfig.IdleTimeout);
+ if (A_OK != status) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: failed to write hci_uart_pwr_mgmt_params_ext!\n"));
+ }
+
+ status = HCI_TransportEnablePowerMgmt(pHcidevInfo->pHCIDev, TRUE);
+ if (A_FAILED(status)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: failed to enable TLPM for AR6K! \n"));
+ }
+ }
+
+ status = bt_register_hci(pHcidevInfo);
+
+ } while (FALSE);
+
+ return status;
+}
+
+static void ar6000_hci_transport_failure(void *pContext, A_STATUS Status)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)pContext;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: transport failure! \n"));
+
+ if (pHcidevInfo->HciNormalMode) {
+ /* TODO .. */
+ }
+}
+
+static void ar6000_hci_transport_removed(void *pContext)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)pContext;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_BRIDGE, ("HCI Bridge: transport removed. \n"));
+
+ A_ASSERT(pHcidevInfo->pHCIDev != NULL);
+
+ HCI_TransportDetach(pHcidevInfo->pHCIDev);
+ bt_cleanup_hci(pHcidevInfo);
+ pHcidevInfo->pHCIDev = NULL;
+}
+
+static void ar6000_hci_send_complete(void *pContext, HTC_PACKET *pPacket)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)pContext;
+ void *osbuf = pPacket->pPktContext;
+ A_ASSERT(osbuf != NULL);
+ A_ASSERT(pHcidevInfo != NULL);
+
+ if (A_FAILED(pPacket->Status)) {
+ if ((pPacket->Status != A_ECANCELED) && (pPacket->Status != A_NO_RESOURCE)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: Send Packet Failed: %d \n",pPacket->Status));
+ }
+ }
+
+ FreeHTCStruct(pHcidevInfo,pPacket);
+ FreeBtOsBuf(pHcidevInfo,osbuf);
+
+}
+
+static void ar6000_hci_pkt_recv(void *pContext, HTC_PACKET *pPacket)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)pContext;
+ struct sk_buff *skb;
+ AR_SOFTC_DEV_T *arDev = pHcidevInfo->ar->arDev[0];
+
+ A_ASSERT(pHcidevInfo != NULL);
+ skb = (struct sk_buff *)pPacket->pPktContext;
+ A_ASSERT(skb != NULL);
+
+ do {
+
+ if (A_FAILED(pPacket->Status)) {
+ break;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_RECV,
+ ("HCI Bridge, packet received type : %d len:%d \n",
+ HCI_GET_PACKET_TYPE(pPacket),pPacket->ActualLength));
+
+ /* set the actual buffer position in the os buffer, HTC recv buffers posted to HCI are set
+ * to fill the front of the buffer */
+ A_NETBUF_PUT(skb,pPacket->ActualLength + pHcidevInfo->HCIProps.HeadRoom);
+ A_NETBUF_PULL(skb,pHcidevInfo->HCIProps.HeadRoom);
+
+ if (AR_DEBUG_LVL_CHECK(ATH_DEBUG_HCI_DUMP)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ANY,("<<< Recv HCI %s packet len:%d \n",
+ (HCI_GET_PACKET_TYPE(pPacket) == HCI_EVENT_TYPE) ? "EVENT" : "ACL",
+ skb->len));
+ AR_DEBUG_PRINTBUF(skb->data, skb->len,"BT HCI RECV Packet Dump");
+ }
+
+ if (pHcidevInfo->HciNormalMode) {
+ /* indicate the packet */
+ if (bt_indicate_recv(pHcidevInfo,HCI_GET_PACKET_TYPE(pPacket),skb)) {
+ /* bt stack accepted the packet */
+ skb = NULL;
+ }
+ break;
+ }
+
+ /* for testing, indicate packet to the network stack */
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ skb->dev = (struct net_device *)(pHcidevInfo->HCITransHdl.netDevice);
+ if ((((struct net_device *)pHcidevInfo->HCITransHdl.netDevice)->flags & IFF_UP) == IFF_UP) {
+ skb->protocol = eth_type_trans(skb, (struct net_device *)(pHcidevInfo->HCITransHdl.netDevice));
+#else
+ skb->dev = arDev->arNetDev;
+ if ((arDev->arNetDev->flags & IFF_UP) == IFF_UP) {
+ skb->protocol = eth_type_trans(skb, arDev->arNetDev);
+#endif
+ A_NETIF_RX(skb);
+ skb = NULL;
+ }
+
+ } while (FALSE);
+
+ FreeHTCStruct(pHcidevInfo,pPacket);
+
+ if (skb != NULL) {
+ /* packet was not accepted, free it */
+ FreeBtOsBuf(pHcidevInfo,skb);
+ }
+
+}
+
+static void ar6000_hci_pkt_refill(void *pContext, HCI_TRANSPORT_PACKET_TYPE Type, int BuffersAvailable)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)pContext;
+ int refillCount;
+
+ if (Type == HCI_ACL_TYPE) {
+ refillCount = MAX_ACL_RECV_BUFS - BuffersAvailable;
+ } else {
+ refillCount = MAX_EVT_RECV_BUFS - BuffersAvailable;
+ }
+
+ if (refillCount > 0) {
+ RefillRecvBuffers(pHcidevInfo,Type,refillCount);
+ }
+
+}
+
+static HCI_SEND_FULL_ACTION ar6000_hci_pkt_send_full(void *pContext, HTC_PACKET *pPacket)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)pContext;
+ HCI_SEND_FULL_ACTION action = HCI_SEND_FULL_KEEP;
+
+ if (!pHcidevInfo->HciNormalMode) {
+ /* for epping testing, check packet tag, some epping packets are
+ * special and cannot be dropped */
+ if (HTC_GET_TAG_FROM_PKT(pPacket) == AR6K_DATA_PKT_TAG) {
+ action = HCI_SEND_FULL_DROP;
+ }
+ }
+
+ return action;
+}
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+A_STATUS ar6000_setup_hci(void *ar)
+#else
+A_STATUS ar6000_setup_hci(AR_SOFTC_T *ar)
+#endif
+{
+ HCI_TRANSPORT_CONFIG_INFO config;
+ A_STATUS status = A_OK;
+ int i;
+ HTC_PACKET *pPacket;
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo;
+
+
+ do {
+
+ pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)A_MALLOC(sizeof(AR6K_HCI_BRIDGE_INFO));
+
+ if (NULL == pHcidevInfo) {
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ A_MEMZERO(pHcidevInfo, sizeof(AR6K_HCI_BRIDGE_INFO));
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ g_pHcidevInfo = pHcidevInfo;
+ pHcidevInfo->HCITransHdl = *(HCI_TRANSPORT_MISC_HANDLES *)ar;
+#else
+ ar->hcidev_info = pHcidevInfo;
+ pHcidevInfo->ar = ar;
+#endif
+ spin_lock_init(&pHcidevInfo->BridgeLock);
+ INIT_HTC_PACKET_QUEUE(&pHcidevInfo->HTCPacketStructHead);
+
+ ar->exitCallback = AR3KConfigureExit;
+
+ status = bt_setup_hci(pHcidevInfo);
+ if (A_FAILED(status)) {
+ break;
+ }
+
+ if (pHcidevInfo->HciNormalMode) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_BRIDGE, ("HCI Bridge: running in normal mode... \n"));
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_BRIDGE, ("HCI Bridge: running in test mode... \n"));
+ }
+
+ pHcidevInfo->pHTCStructAlloc = (A_UINT8 *)A_MALLOC((sizeof(HTC_PACKET)) * NUM_HTC_PACKET_STRUCTS);
+
+ if (NULL == pHcidevInfo->pHTCStructAlloc) {
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ pPacket = (HTC_PACKET *)pHcidevInfo->pHTCStructAlloc;
+ for (i = 0; i < NUM_HTC_PACKET_STRUCTS; i++,pPacket++) {
+ FreeHTCStruct(pHcidevInfo,pPacket);
+ }
+
+ A_MEMZERO(&config,sizeof(HCI_TRANSPORT_CONFIG_INFO));
+ config.ACLRecvBufferWaterMark = MAX_ACL_RECV_BUFS / 2;
+ config.EventRecvBufferWaterMark = MAX_EVT_RECV_BUFS / 2;
+ config.MaxSendQueueDepth = MAX_HCI_WRITE_QUEUE_DEPTH;
+ config.pContext = pHcidevInfo;
+ config.TransportFailure = ar6000_hci_transport_failure;
+ config.TransportReady = ar6000_hci_transport_ready;
+ config.TransportRemoved = ar6000_hci_transport_removed;
+ config.pHCISendComplete = ar6000_hci_send_complete;
+ config.pHCIPktRecv = ar6000_hci_pkt_recv;
+ config.pHCIPktRecvRefill = ar6000_hci_pkt_refill;
+ config.pHCISendFull = ar6000_hci_pkt_send_full;
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ pHcidevInfo->pHCIDev = HCI_TransportAttach(pHcidevInfo->HCITransHdl.htcHandle, &config);
+#else
+ pHcidevInfo->pHCIDev = HCI_TransportAttach(ar->arHtcTarget, &config);
+#endif
+
+ if (NULL == pHcidevInfo->pHCIDev) {
+ status = A_ERROR;
+ }
+
+ } while (FALSE);
+
+ if (A_FAILED(status)) {
+ if (pHcidevInfo != NULL) {
+ if (NULL == pHcidevInfo->pHCIDev) {
+ /* GMBOX may not be present in older chips */
+ /* just return success */
+ status = A_OK;
+ }
+ }
+ ar6000_cleanup_hci(ar);
+ }
+
+ return status;
+}
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+void ar6000_cleanup_hci(void *ar)
+#else
+void ar6000_cleanup_hci(AR_SOFTC_T *ar)
+#endif
+{
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = g_pHcidevInfo;
+#else
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)ar->hcidev_info;
+#endif
+
+ if (pHcidevInfo != NULL) {
+ bt_cleanup_hci(pHcidevInfo);
+
+ if (pHcidevInfo->pHCIDev != NULL) {
+ HCI_TransportStop(pHcidevInfo->pHCIDev);
+ HCI_TransportDetach(pHcidevInfo->pHCIDev);
+ pHcidevInfo->pHCIDev = NULL;
+ }
+
+ if (pHcidevInfo->pHTCStructAlloc != NULL) {
+ A_FREE(pHcidevInfo->pHTCStructAlloc);
+ pHcidevInfo->pHTCStructAlloc = NULL;
+ }
+
+ A_FREE(pHcidevInfo);
+#ifndef EXPORT_HCI_BRIDGE_INTERFACE
+ ar->hcidev_info = NULL;
+ ar->exitCallback = NULL;
+#endif
+ }
+
+
+}
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+A_STATUS hci_test_send(void *ar, struct sk_buff *skb)
+#else
+A_STATUS hci_test_send(AR_SOFTC_T *ar, struct sk_buff *skb)
+#endif
+{
+ int status = A_OK;
+ int length;
+ EPPING_HEADER *pHeader;
+ HTC_PACKET *pPacket;
+ HTC_TX_TAG htc_tag = AR6K_DATA_PKT_TAG;
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = g_pHcidevInfo;
+#else
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)ar->hcidev_info;
+#endif
+
+ do {
+
+ if (NULL == pHcidevInfo) {
+ status = A_ERROR;
+ break;
+ }
+
+ if (NULL == pHcidevInfo->pHCIDev) {
+ status = A_ERROR;
+ break;
+ }
+
+ if (pHcidevInfo->HciNormalMode) {
+ /* this interface cannot run when normal WMI is running */
+ status = A_ERROR;
+ break;
+ }
+
+ pHeader = (EPPING_HEADER *)A_NETBUF_DATA(skb);
+
+ if (!IS_EPPING_PACKET(pHeader)) {
+ status = A_EINVAL;
+ break;
+ }
+
+ if (IS_EPING_PACKET_NO_DROP(pHeader)) {
+ htc_tag = AR6K_CONTROL_PKT_TAG;
+ }
+
+ length = sizeof(EPPING_HEADER) + pHeader->DataLength;
+
+ pPacket = AllocHTCStruct(pHcidevInfo);
+ if (NULL == pPacket) {
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ SET_HTC_PACKET_INFO_TX(pPacket,
+ skb,
+ A_NETBUF_DATA(skb),
+ length,
+ HCI_ACL_TYPE, /* send every thing out as ACL */
+ htc_tag);
+
+ HCI_TransportSendPkt(pHcidevInfo->pHCIDev,pPacket,FALSE);
+ pPacket = NULL;
+
+ } while (FALSE);
+
+ return status;
+}
+
+void ar6000_set_default_ar3kconfig(AR_SOFTC_T *ar, void *ar3kconfig)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)ar->hcidev_info;
+ AR3K_CONFIG_INFO *config = (AR3K_CONFIG_INFO *)ar3kconfig;
+
+ config->pHCIDev = pHcidevInfo->pHCIDev;
+ config->pHCIProps = &pHcidevInfo->HCIProps;
+ config->pHIFDevice = ar->arHifDevice;
+ config->pBtStackHCIDev = pHcidevInfo->pBtStackHCIDev;
+ config->Flags |= AR3K_CONFIG_FLAG_SET_AR3K_BAUD;
+ config->AR3KBaudRate = 115200;
+}
+
+#ifdef CONFIG_BLUEZ_HCI_BRIDGE
+/*** BT Stack Entrypoints *******/
+
+/*
+ * bt_open - open a handle to the device
+*/
+static int bt_open(struct hci_dev *hdev)
+{
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC, ("HCI Bridge: bt_open - enter - x\n"));
+ set_bit(HCI_RUNNING, &hdev->flags);
+ set_bit(HCI_UP, &hdev->flags);
+ set_bit(HCI_INIT, &hdev->flags);
+ return 0;
+}
+
+/*
+ * bt_close - close handle to the device
+*/
+static int bt_close(struct hci_dev *hdev)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC, ("HCI Bridge: bt_close - enter\n"));
+ clear_bit(HCI_RUNNING, &hdev->flags);
+ return 0;
+}
+
+/*
+ * bt_send_frame - send data frames
+*/
+static int bt_send_frame(struct sk_buff *skb)
+{
+ struct hci_dev *hdev = (struct hci_dev *)skb->dev;
+ HCI_TRANSPORT_PACKET_TYPE type;
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo;
+ HTC_PACKET *pPacket;
+ A_STATUS status = A_OK;
+ struct sk_buff *txSkb = NULL;
+
+ if (!hdev) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN, ("HCI Bridge: bt_send_frame - no device\n"));
+ return -ENODEV;
+ }
+
+ if (!test_bit(HCI_RUNNING, &hdev->flags)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC, ("HCI Bridge: bt_send_frame - not open\n"));
+ return -EBUSY;
+ }
+
+ pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)hdev->driver_data;
+ A_ASSERT(pHcidevInfo != NULL);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_SEND, ("+bt_send_frame type: %d \n",bt_cb(skb)->pkt_type));
+ type = HCI_COMMAND_TYPE;
+
+ switch (bt_cb(skb)->pkt_type) {
+ case HCI_COMMAND_PKT:
+ type = HCI_COMMAND_TYPE;
+ hdev->stat.cmd_tx++;
+ break;
+
+ case HCI_ACLDATA_PKT:
+ type = HCI_ACL_TYPE;
+ hdev->stat.acl_tx++;
+ break;
+
+ case HCI_SCODATA_PKT:
+ /* we don't support SCO over the bridge */
+ kfree_skb(skb);
+ return 0;
+ default:
+ A_ASSERT(FALSE);
+ kfree_skb(skb);
+ return 0;
+ }
+
+ if (AR_DEBUG_LVL_CHECK(ATH_DEBUG_HCI_DUMP)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ANY,(">>> Send HCI %s packet len: %d\n",
+ (type == HCI_COMMAND_TYPE) ? "COMMAND" : "ACL",
+ skb->len));
+ if (type == HCI_COMMAND_TYPE) {
+ A_UINT16 opcode = HCI_GET_OP_CODE(skb->data);
+ AR_DEBUG_PRINTF(ATH_DEBUG_ANY,(" HCI Command: OGF:0x%X OCF:0x%X \r\n",
+ opcode >> 10, opcode & 0x3FF));
+ }
+ AR_DEBUG_PRINTBUF(skb->data,skb->len,"BT HCI SEND Packet Dump");
+ }
+
+ do {
+
+ txSkb = bt_skb_alloc(TX_PACKET_RSV_OFFSET + pHcidevInfo->HCIProps.HeadRoom +
+ pHcidevInfo->HCIProps.TailRoom + skb->len,
+ GFP_ATOMIC);
+
+ if (txSkb == NULL) {
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ bt_cb(txSkb)->pkt_type = bt_cb(skb)->pkt_type;
+ txSkb->dev = (void *)pHcidevInfo->pBtStackHCIDev;
+ skb_reserve(txSkb, TX_PACKET_RSV_OFFSET + pHcidevInfo->HCIProps.HeadRoom);
+ A_MEMCPY(txSkb->data, skb->data, skb->len);
+ skb_put(txSkb,skb->len);
+
+ pPacket = AllocHTCStruct(pHcidevInfo);
+ if (NULL == pPacket) {
+ status = A_NO_MEMORY;
+ break;
+ }
+
+ /* HCI packet length here doesn't include the 1-byte transport header which
+ * will be handled by the HCI transport layer. Enough headroom has already
+ * been reserved above for the transport header
+ */
+ SET_HTC_PACKET_INFO_TX(pPacket,
+ txSkb,
+ txSkb->data,
+ txSkb->len,
+ type,
+ AR6K_CONTROL_PKT_TAG); /* HCI packets cannot be dropped */
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_SEND, ("HCI Bridge: bt_send_frame skb:0x%lX \n",(unsigned long)txSkb));
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_SEND, ("HCI Bridge: type:%d, Total Length:%d Bytes \n",
+ type, txSkb->len));
+
+ status = HCI_TransportSendPkt(pHcidevInfo->pHCIDev,pPacket,FALSE);
+ pPacket = NULL;
+ txSkb = NULL;
+
+ } while (FALSE);
+
+ if (txSkb != NULL) {
+ kfree_skb(txSkb);
+ }
+
+ kfree_skb(skb);
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_SEND, ("-bt_send_frame \n"));
+ return 0;
+}
+
+/*
+ * bt_ioctl - ioctl processing
+*/
+static int bt_ioctl(struct hci_dev *hdev, unsigned int cmd, unsigned long arg)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC, ("HCI Bridge: bt_ioctl - enter\n"));
+ return -ENOIOCTLCMD;
+}
+
+/*
+ * bt_flush - flush outstandingbpackets
+*/
+static int bt_flush(struct hci_dev *hdev)
+{
+ AR6K_HCI_BRIDGE_INFO *pHcidevInfo;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC, ("HCI Bridge: bt_flush - enter\n"));
+
+ pHcidevInfo = (AR6K_HCI_BRIDGE_INFO *)hdev->driver_data;
+
+ /* TODO??? */
+
+ return 0;
+}
+
+
+/*
+ * bt_destruct -
+*/
+static void bt_destruct(struct hci_dev *hdev)
+{
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC, ("HCI Bridge: bt_destruct - enter\n"));
+ /* nothing to do here */
+}
+
+static A_STATUS bt_setup_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo)
+{
+ A_STATUS status = A_OK;
+ struct hci_dev *pHciDev = NULL;
+ HIF_DEVICE_OS_DEVICE_INFO osDevInfo;
+
+ if (!setupbtdev) {
+ return A_OK;
+ }
+
+ do {
+
+ A_MEMZERO(&osDevInfo,sizeof(osDevInfo));
+ /* get the underlying OS device */
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+ status = ar6000_get_hif_dev((HIF_DEVICE *)(pHcidevInfo->HCITransHdl.hifDevice),
+ &osDevInfo);
+#else
+ status = HIFConfigureDevice(pHcidevInfo->ar->arHifDevice,
+ HIF_DEVICE_GET_OS_DEVICE,
+ &osDevInfo,
+ sizeof(osDevInfo));
+#endif
+
+ if (A_FAILED(status)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Failed to OS device info from HIF\n"));
+ break;
+ }
+
+ /* allocate a BT HCI struct for this device */
+ pHciDev = hci_alloc_dev();
+ if (NULL == pHciDev) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge - failed to allocate bt struct \n"));
+ status = A_NO_MEMORY;
+ break;
+ }
+ /* save the device, we'll register this later */
+ pHcidevInfo->pBtStackHCIDev = pHciDev;
+ SET_HCIDEV_DEV(pHciDev,osDevInfo.pOSDevice);
+ SET_HCI_BUS_TYPE(pHciDev, HCI_VIRTUAL, HCI_BREDR);
+ pHciDev->driver_data = pHcidevInfo;
+ pHciDev->open = bt_open;
+ pHciDev->close = bt_close;
+ pHciDev->send = bt_send_frame;
+ pHciDev->ioctl = bt_ioctl;
+ pHciDev->flush = bt_flush;
+ pHciDev->destruct = bt_destruct;
+ pHciDev->owner = THIS_MODULE;
+ /* driver is running in normal BT mode */
+ pHcidevInfo->HciNormalMode = TRUE;
+
+ } while (FALSE);
+
+ if (A_FAILED(status)) {
+ bt_cleanup_hci(pHcidevInfo);
+ }
+
+ return status;
+}
+
+static void bt_cleanup_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo)
+{
+ int err;
+
+ if (pHcidevInfo->HciRegistered) {
+ pHcidevInfo->HciRegistered = FALSE;
+ clear_bit(HCI_RUNNING, &pHcidevInfo->pBtStackHCIDev->flags);
+ clear_bit(HCI_UP, &pHcidevInfo->pBtStackHCIDev->flags);
+ clear_bit(HCI_INIT, &pHcidevInfo->pBtStackHCIDev->flags);
+ A_ASSERT(pHcidevInfo->pBtStackHCIDev != NULL);
+ /* unregister */
+ if ((err = hci_unregister_dev(pHcidevInfo->pBtStackHCIDev)) < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: failed to unregister with bluetooth %d\n",err));
+ }
+ }
+
+ if (pHcidevInfo->pBtStackHCIDev != NULL) {
+ kfree(pHcidevInfo->pBtStackHCIDev);
+ pHcidevInfo->pBtStackHCIDev = NULL;
+ }
+}
+
+static A_STATUS bt_register_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo)
+{
+ int err;
+ A_STATUS status = A_OK;
+
+ do {
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_BRIDGE, ("HCI Bridge: registering HCI... \n"));
+ A_ASSERT(pHcidevInfo->pBtStackHCIDev != NULL);
+ /* mark that we are registered */
+ pHcidevInfo->HciRegistered = TRUE;
+ if ((err = hci_register_dev(pHcidevInfo->pBtStackHCIDev)) < 0) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: failed to register with bluetooth %d\n",err));
+ pHcidevInfo->HciRegistered = FALSE;
+ status = A_ERROR;
+ break;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_BRIDGE, ("HCI Bridge: HCI registered \n"));
+
+ } while (FALSE);
+
+ return status;
+}
+
+static A_BOOL bt_indicate_recv(AR6K_HCI_BRIDGE_INFO *pHcidevInfo,
+ HCI_TRANSPORT_PACKET_TYPE Type,
+ struct sk_buff *skb)
+{
+ A_UINT8 btType;
+ int len;
+ A_BOOL success = FALSE;
+ BT_HCI_EVENT_HEADER *pEvent;
+
+ do {
+
+ if (!test_bit(HCI_RUNNING, &pHcidevInfo->pBtStackHCIDev->flags)) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN, ("HCI Bridge: bt_indicate_recv - not running\n"));
+ break;
+ }
+
+ switch (Type) {
+ case HCI_ACL_TYPE:
+ btType = HCI_ACLDATA_PKT;
+ break;
+ case HCI_EVENT_TYPE:
+ btType = HCI_EVENT_PKT;
+ break;
+ default:
+ btType = 0;
+ A_ASSERT(FALSE);
+ break;
+ }
+
+ if (0 == btType) {
+ break;
+ }
+
+ /* set the final type */
+ bt_cb(skb)->pkt_type = btType;
+ /* set dev */
+ skb->dev = (void *)pHcidevInfo->pBtStackHCIDev;
+ len = skb->len;
+
+ if (AR_DEBUG_LVL_CHECK(ATH_DEBUG_HCI_RECV)) {
+ if (bt_cb(skb)->pkt_type == HCI_EVENT_PKT) {
+ pEvent = (BT_HCI_EVENT_HEADER *)skb->data;
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_RECV, ("BT HCI EventCode: %d, len:%d \n",
+ pEvent->EventCode, pEvent->ParamLength));
+ }
+ }
+
+ /* pass receive packet up the stack */
+#ifdef CONFIG_BT
+ if (hci_recv_frame(skb) != 0) {
+#else
+ if (1) {
+#endif
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("HCI Bridge: hci_recv_frame failed \n"));
+ break;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_HCI_RECV,
+ ("HCI Bridge: Indicated RCV of type:%d, Length:%d \n",btType,len));
+ }
+
+ success = TRUE;
+
+ } while (FALSE);
+
+ return success;
+}
+
+static struct sk_buff* bt_alloc_buffer(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, int Length)
+{
+ struct sk_buff *skb;
+ /* in normal HCI mode we need to alloc from the bt core APIs */
+ skb = bt_skb_alloc(Length, GFP_ATOMIC);
+ if (NULL == skb) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Failed to alloc bt sk_buff \n"));
+ }
+ return skb;
+}
+
+static void bt_free_buffer(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, struct sk_buff *skb)
+{
+ kfree_skb(skb);
+}
+
+#else // { CONFIG_BLUEZ_HCI_BRIDGE
+
+ /* stubs when we only want to test the HCI bridging Interface without the HT stack */
+static A_STATUS bt_setup_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo)
+{
+ return A_OK;
+}
+static void bt_cleanup_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo)
+{
+
+}
+static A_STATUS bt_register_hci(AR6K_HCI_BRIDGE_INFO *pHcidevInfo)
+{
+ A_ASSERT(FALSE);
+ return A_ERROR;
+}
+
+static A_BOOL bt_indicate_recv(AR6K_HCI_BRIDGE_INFO *pHcidevInfo,
+ HCI_TRANSPORT_PACKET_TYPE Type,
+ struct sk_buff *skb)
+{
+ A_ASSERT(FALSE);
+ return FALSE;
+}
+
+static struct sk_buff* bt_alloc_buffer(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, int Length)
+{
+ A_ASSERT(FALSE);
+ return NULL;
+}
+static void bt_free_buffer(AR6K_HCI_BRIDGE_INFO *pHcidevInfo, struct sk_buff *skb)
+{
+ A_ASSERT(FALSE);
+}
+
+#endif // } CONFIG_BLUEZ_HCI_BRIDGE
+
+#else // { ATH_AR6K_ENABLE_GMBOX
+
+ /* stubs when GMBOX support is not needed */
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+A_STATUS ar6000_setup_hci(void *ar)
+#else
+A_STATUS ar6000_setup_hci(AR_SOFTC_T *ar)
+#endif
+{
+ return A_OK;
+}
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+void ar6000_cleanup_hci(void *ar)
+#else
+void ar6000_cleanup_hci(AR_SOFTC_T *ar)
+#endif
+{
+ return;
+}
+
+#ifndef EXPORT_HCI_BRIDGE_INTERFACE
+void ar6000_set_default_ar3kconfig(AR_SOFTC_T *ar, void *ar3kconfig)
+{
+ return;
+}
+#endif
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+int hci_test_send(void *ar, struct sk_buff *skb)
+#else
+int hci_test_send(AR_SOFTC_T *ar, struct sk_buff *skb)
+#endif
+{
+ return -EOPNOTSUPP;
+}
+
+#endif // } ATH_AR6K_ENABLE_GMBOX
+
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+static int __init
+hcibridge_init_module(void)
+{
+ A_STATUS status;
+ HCI_TRANSPORT_CALLBACKS hciTransCallbacks;
+
+ hciTransCallbacks.setupTransport = ar6000_setup_hci;
+ hciTransCallbacks.cleanupTransport = ar6000_cleanup_hci;
+
+ status = ar6000_register_hci_transport(&hciTransCallbacks);
+ if(status != A_OK)
+ return -ENODEV;
+
+ return 0;
+}
+
+static void __exit
+hcibridge_cleanup_module(void)
+{
+}
+
+module_init(hcibridge_init_module);
+module_exit(hcibridge_cleanup_module);
+MODULE_LICENSE("Dual BSD/GPL");
+#endif
diff --git a/host/os/linux/include/ar6000_drv.h b/host/os/linux/include/ar6000_drv.h
new file mode 100644
index 0000000..0996e5a
--- /dev/null
+++ b/host/os/linux/include/ar6000_drv.h
@@ -0,0 +1,1008 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _AR6000_H_
+#define _AR6000_H_
+
+#include <linux/version.h>
+
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,17)
+#include <linux/config.h>
+#elif LINUX_VERSION_CODE < KERNEL_VERSION(2,6,33)
+#include <linux/autoconf.h>
+#else
+#include <generated/autoconf.h>
+#endif
+#include <linux/init.h>
+#include <linux/kernel.h>
+#include <linux/sched.h>
+#include <linux/spinlock.h>
+#include <linux/skbuff.h>
+#include <linux/if_ether.h>
+#include <linux/netdevice.h>
+#include <linux/etherdevice.h>
+#include <net/iw_handler.h>
+#include <linux/if_arp.h>
+#include <linux/ip.h>
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,26)
+#include <asm/semaphore.h>
+#else
+#include <linux/semaphore.h>
+#endif
+#include <linux/wireless.h>
+#ifdef ATH6K_CONFIG_CFG80211
+#include <net/cfg80211.h>
+#endif /* ATH6K_CONFIG_CFG80211 */
+#include <linux/module.h>
+#include <asm/io.h>
+
+#include <a_config.h>
+#include <athdefs.h>
+#include "a_types.h"
+#include "a_osapi.h"
+#include "htc_api.h"
+#include "wmi.h"
+#include "a_drv.h"
+#include "bmi.h"
+#include <ieee80211.h>
+#include <ieee80211_ioctl.h>
+#include <wlan_api.h>
+#include <wmi_api.h>
+#include "gpio_api.h"
+#include "gpio.h"
+#include "pkt_log.h"
+#include "aggr_recv_api.h"
+#include <host_version.h>
+#include <linux/rtnetlink.h>
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,0)
+#include <asm/uaccess.h>
+#else
+#include <linux/init.h>
+#include <linux/moduleparam.h>
+#endif
+#include "ar6000_api.h"
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+#include <testcmd.h>
+#endif
+#include <linux/firmware.h>
+
+#include "targaddrs.h"
+#include "dbglog_api.h"
+#include "ar6000_diag.h"
+#include "common_drv.h"
+#include "roaming.h"
+#include "hci_transport_api.h"
+#define ATH_MODULE_NAME driver
+#include "a_debug.h"
+
+#define ATH_DEBUG_DBG_LOG ATH_DEBUG_MAKE_MODULE_MASK(0)
+#define ATH_DEBUG_WLAN_CONNECT ATH_DEBUG_MAKE_MODULE_MASK(1)
+#define ATH_DEBUG_WLAN_SCAN ATH_DEBUG_MAKE_MODULE_MASK(2)
+#define ATH_DEBUG_WLAN_TX ATH_DEBUG_MAKE_MODULE_MASK(3)
+#define ATH_DEBUG_WLAN_RX ATH_DEBUG_MAKE_MODULE_MASK(4)
+#define ATH_DEBUG_HTC_RAW ATH_DEBUG_MAKE_MODULE_MASK(5)
+#define ATH_DEBUG_HCI_BRIDGE ATH_DEBUG_MAKE_MODULE_MASK(6)
+#define ATH_DEBUG_HCI_RECV ATH_DEBUG_MAKE_MODULE_MASK(7)
+#define ATH_DEBUG_HCI_SEND ATH_DEBUG_MAKE_MODULE_MASK(8)
+#define ATH_DEBUG_HCI_DUMP ATH_DEBUG_MAKE_MODULE_MASK(9)
+
+#ifndef __dev_put
+#define __dev_put(dev) dev_put(dev)
+#endif
+
+
+
+#ifdef ATH6K_CONFIG_CFG80211
+#define NUM_SUBQUEUE 1
+#endif
+
+#ifdef USER_KEYS
+
+#define USER_SAVEDKEYS_STAT_INIT 0
+#define USER_SAVEDKEYS_STAT_RUN 1
+
+// TODO this needs to move into the AR_SOFTC struct
+struct USER_SAVEDKEYS {
+ struct ieee80211req_key ucast_ik;
+ struct ieee80211req_key bcast_ik;
+ CRYPTO_TYPE keyType;
+ A_BOOL keyOk;
+};
+#endif
+
+#define DBG_INFO 0x00000001
+#define DBG_ERROR 0x00000002
+#define DBG_WARNING 0x00000004
+#define DBG_SDIO 0x00000008
+#define DBG_HIF 0x00000010
+#define DBG_HTC 0x00000020
+#define DBG_WMI 0x00000040
+#define DBG_WMI2 0x00000080
+#define DBG_DRIVER 0x00000100
+
+#define DBG_DEFAULTS (DBG_ERROR|DBG_WARNING)
+
+
+A_STATUS ar6000_ReadRegDiag(HIF_DEVICE *hifDevice, A_UINT32 *address, A_UINT32 *data);
+A_STATUS ar6000_WriteRegDiag(HIF_DEVICE *hifDevice, A_UINT32 *address, A_UINT32 *data);
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define MAX_AR6000 1
+#define AR6000_MAX_RX_BUFFERS 16
+#define AR6000_BUFFER_SIZE 1664
+#define AR6000_MAX_AMSDU_RX_BUFFERS 4
+#define AR6000_AMSDU_REFILL_THRESHOLD 3
+#define AR6000_AMSDU_BUFFER_SIZE (WMI_MAX_AMSDU_RX_DATA_FRAME_LENGTH + 128)
+#define AR6000_MAX_RX_MESSAGE_SIZE (max(WMI_MAX_NORMAL_RX_DATA_FRAME_LENGTH,WMI_MAX_AMSDU_RX_DATA_FRAME_LENGTH))
+
+#define AR6000_TX_TIMEOUT 10
+#define AR6000_ETH_ADDR_LEN 6
+#define AR6000_MAX_ENDPOINTS 4
+#define MAX_NODE_NUM 15
+/* MAX_HI_COOKIE_NUM are reserved for high priority traffic */
+#define MAX_DEF_COOKIE_NUM 150
+#define MAX_HIGH_PRIORITY_COOKIE_NUM 15 /* 10% of MAX_COOKIE_NUM (for high priority traffic) */
+#define MAX_CONTROL_COOKIE_NUM WMM_NUM_AC*2 + 3 + 1 /* Number of cookies reserved for control packets ONLY */
+#define MAX_HI_COOKIE_NUM MAX_HIGH_PRIORITY_COOKIE_NUM + MAX_CONTROL_COOKIE_NUM
+ /* Number of cookies reserved for both
+ * high priority data + control packets
+ */
+#define MAX_COOKIE_NUM (MAX_DEF_COOKIE_NUM + MAX_HI_COOKIE_NUM)
+
+/*
+ * MAX_DEFAULT_PS_QUEUE_DEPTH is used to set the default queue depth for
+ * Power Save queue maintained for each station. This settings is used only for
+ * AP mode. This queue depth is also used for multicast PS queue.
+ * To disable this feature or have unlimited queue size pass 0 as module
+ * parameter.
+ */
+#define MAX_DEFAULT_PS_QUEUE_DEPTH 128
+
+/* MAX_DEFAULT_SEND_QUEUE_DEPTH is used to set the default queue depth for the
+ * WMM send queues. If a queue exceeds this depth htc will query back to the
+ * OS specific layer by calling EpSendFull(). This gives the OS layer the
+ * opportunity to drop the packet if desired. Therefore changing
+ * MAX_DEFAULT_SEND_QUEUE_DEPTH does not affect resource utilization but
+ * does impact the threshold used to identify if a packet should be
+ * dropped. */
+// #define MAX_DEFAULT_SEND_QUEUE_DEPTH (MAX_DEF_COOKIE_NUM / WMM_NUM_AC)
+
+// Host Queue depth has been increased during performace chariot endpoint runs. Host may not pump
+// as fast as host application expected, due to that panic/packet loss / chariot error happens
+// adjusting queue depth size resolve this issue
+#define MAX_DEFAULT_SEND_QUEUE_DEPTH 64
+
+#define AR6000_HB_CHALLENGE_RESP_FREQ_DEFAULT 1
+#define AR6000_HB_CHALLENGE_RESP_MISS_THRES_DEFAULT 1
+#define A_DISCONNECT_TIMER_INTERVAL 12 * 1000
+#define A_DEFAULT_LISTEN_INTERVAL 100
+#define A_DEFAULT_BMISS_TIME 1500
+#define A_MAX_WOW_LISTEN_INTERVAL 300
+#define A_MAX_WOW_BMISS_TIME 4500
+
+#define IS_5G_CHANNEL(channel) ((channel >= 5180 && channel <= 5825) ? TRUE : FALSE)
+
+enum {
+ DRV_HB_CHALLENGE = 0,
+ APP_HB_CHALLENGE
+};
+
+enum {
+ WLAN_INIT_MODE_NONE = 0,
+ WLAN_INIT_MODE_USR,
+ WLAN_INIT_MODE_UDEV,
+ WLAN_INIT_MODE_DRV
+};
+
+/* Suspend - configuration */
+enum {
+ WLAN_SUSPEND_CUT_PWR = 0,
+ WLAN_SUSPEND_DEEP_SLEEP,
+ WLAN_SUSPEND_WOW,
+ WLAN_SUSPEND_CUT_PWR_IF_BT_OFF
+};
+
+/* WiFi OFF - configuration */
+enum {
+ WLAN_OFF_CUT_PWR = 0,
+ WLAN_OFF_DEEP_SLEEP,
+};
+
+/* WLAN low power state */
+enum {
+ WLAN_POWER_STATE_ON = 0,
+ WLAN_POWER_STATE_CUT_PWR = 1,
+ WLAN_POWER_STATE_DEEP_SLEEP,
+ WLAN_POWER_STATE_WOW
+};
+
+/* WLAN WoW State */
+enum {
+ WLAN_WOW_STATE_NONE = 0,
+ WLAN_WOW_STATE_SUSPENDING,
+ WLAN_WOW_STATE_SUSPENDED
+};
+
+
+typedef enum _AR6K_BIN_FILE {
+ AR6K_OTP_FILE,
+ AR6K_FIRMWARE_FILE,
+ AR6K_PATCH_FILE,
+ AR6K_BOARD_DATA_FILE,
+} AR6K_BIN_FILE;
+
+#define REASON_DELBA_INIT 0
+#define REASON_TEAR_DOWN 1
+#define REASON_DELBA_TIMEOUT 2
+
+#define DELBA_TIMEOUT 2000
+
+#ifdef SETUPHCI_ENABLED
+#define SETUPHCI_DEFAULT 1
+#else
+#define SETUPHCI_DEFAULT 0
+#endif /* SETUPHCI_ENABLED */
+
+#ifdef SETUPHCIPAL_ENABLED
+#define SETUPHCIPAL_DEFAULT 1
+#else
+#define SETUPHCIPAL_DEFAULT 0
+#endif /* SETUPHCIPAL_ENABLED */
+
+#ifdef SETUPBTDEV_ENABLED
+#define SETUPBTDEV_DEFAULT 1
+#else
+#define SETUPBTDEV_DEFAULT 0
+#endif /* SETUPBTDEV_ENABLED */
+
+#ifdef BMIENABLE_SET
+#define BMIENABLE_DEFAULT 1
+#else
+#define BMIENABLE_DEFAULT 0
+#endif /* BMIENABLE_SET */
+
+#ifdef ENABLEUARTPRINT_SET
+#define ENABLEUARTPRINT_DEFAULT 1
+#else
+#define ENABLEUARTPRINT_DEFAULT 0
+#endif /* ENABLEARTPRINT_SET */
+
+#ifdef ATH6KL_CONFIG_HIF_VIRTUAL_SCATTER
+#define NOHIFSCATTERSUPPORT_DEFAULT 1
+#else /* ATH6KL_CONFIG_HIF_VIRTUAL_SCATTER */
+#define NOHIFSCATTERSUPPORT_DEFAULT 0
+#endif /* ATH6KL_CONFIG_HIF_VIRTUAL_SCATTER */
+
+#ifdef AR600x_BT_AR3001
+#define AR3KHCIBAUD_DEFAULT 3000000
+#define HCIUARTSCALE_DEFAULT 1
+#define HCIUARTSTEP_DEFAULT 8937
+#else
+#define AR3KHCIBAUD_DEFAULT 0
+#define HCIUARTSCALE_DEFAULT 0
+#define HCIUARTSTEP_DEFAULT 0
+#endif /* AR600x_BT_AR3001 */
+
+#ifdef INIT_MODE_DRV_ENABLED
+#define WLAN_INIT_MODE_DEFAULT WLAN_INIT_MODE_DRV
+#else
+#define WLAN_INIT_MODE_DEFAULT WLAN_INIT_MODE_USR
+#endif /* INIT_MODE_DRV_ENABLED */
+
+#define AR6K_DATASET_PATCH_ADDRESS(_param, _ver) do { \
+ if ((_ver) == AR6003_REV2_VERSION) { \
+ (_param) = AR6003_REV2_DATASET_PATCH_ADDRESS; \
+ } else if ((_ver) == AR6003_REV3_VERSION) { \
+ (_param) = AR6003_REV3_DATASET_PATCH_ADDRESS; \
+ } else { \
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown Version: %d\n", _ver)); \
+ A_ASSERT(0); \
+ } \
+} while (0)
+
+#define AR6K_APP_LOAD_ADDRESS(_param, _ver) do { \
+ if ((_ver) == AR6003_REV2_VERSION) { \
+ (_param) = AR6003_REV2_APP_LOAD_ADDRESS; \
+ } else if ((_ver) == AR6003_REV3_VERSION) { \
+ (_param) = AR6003_REV3_APP_LOAD_ADDRESS; \
+ } else { \
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown Version: %d\n", _ver)); \
+ A_ASSERT(0); \
+ } \
+} while (0)
+
+#define AR6K_APP_START_OVERRIDE_ADDRESS(_param, _ver) do { \
+ if ((_ver) == AR6003_REV2_VERSION) { \
+ (_param) = AR6003_REV2_APP_START_OVERRIDE; \
+ } else if ((_ver) == AR6003_REV3_VERSION) { \
+ (_param) = AR6003_REV3_APP_START_OVERRIDE; \
+ } else { \
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("Unknown Version: %d\n", _ver)); \
+ A_ASSERT(0); \
+ } \
+} while (0)
+
+#define AR6003_SUBVER_DEFAULT 1
+#define AR6003_SUBVER_ROUTER 2
+#define AR6003_SUBVER_MOBILE 3
+#define AR6003_SUBVER_TABLET 4
+
+/* AR6003 2.0 definitions */
+#define AR6003_REV2_VERSION 0x30000384
+#ifdef KERNEL_VERSION_ANDROID
+
+#define AR6003_REV2_OTP_FILE "ath6k/AR6003/hw2.0/otp.bin.z77"
+#define AR6003_REV2_FIRMWARE_FILE "ath6k/AR6003/hw2.0/athwlan.bin.z77"
+#define AR6003_REV2_TCMD_FIRMWARE_FILE "ath6k/AR6003/hw2.0/athtcmd_ram.bin"
+#define AR6003_REV2_TESTSCRIPT_FILE "ath6k/AR6003/hw2.0/testflow.bin"
+#define AR6003_REV2_UTF_FIRMWARE_FILE "ath6k/AR6003/hw2.0/utf.bin"
+#define AR6003_REV2_ART_FIRMWARE_FILE "ath6k/AR6003/hw2.0/device.bin"
+#define AR6003_REV2_PATCH_FILE "ath6k/AR6003/hw2.0/data.patch.hw2_0.bin"
+#define AR6003_REV2_EPPING_FIRMWARE_FILE "ath6k/AR6003/hw2.0/endpointping.bin"
+#ifdef AR600x_SD31_XXX
+#define AR6003_REV2_BOARD_DATA_FILE "ath6k/AR6003/hw2.0/bdata.SD31.bin"
+#elif defined(AR600x_SD32_XXX)
+#define AR6003_REV2_BOARD_DATA_FILE "ath6k/AR6003/hw2.0/bdata.SD32.bin"
+#elif defined(AR600x_WB31_XXX)
+#define AR6003_REV2_BOARD_DATA_FILE "ath6k/AR6003/hw2.0/bdata.WB31.bin"
+#else
+#define AR6003_REV2_BOARD_DATA_FILE "ath6k/AR6003/hw2.0/bdata.CUSTOM.bin"
+#endif /* Board Data File */
+#else /* KERNEL_VERSION_ANDROID*/
+
+#define AR6003_REV2_OTP_FILE "hw2.0/bin/otp.bin.z77"
+#define AR6003_REV2_FIRMWARE_FILE "hw2.0/bin/athwlan.bin.z77"
+#define AR6003_REV2_TCMD_FIRMWARE_FILE "hw2.0/bin/athtcmd_ram.bin"
+#define AR6003_REV2_TESTSCRIPT_FILE "hw2.0/bin/testflow.bin"
+#define AR6003_REV2_UTF_FIRMWARE_FILE "hw2.0/bin/utf.bin"
+#define AR6003_REV2_ART_FIRMWARE_FILE "hw2.0/bin/device.bin"
+#define AR6003_REV2_PATCH_FILE "hw2.0/bin/data.patch.hw2_0.bin"
+#define AR6003_REV2_EPPING_FIRMWARE_FILE "hw2.0/bin/endpointping.bin"
+#ifdef AR600x_SD31_XXX
+#define AR6003_REV2_BOARD_DATA_FILE "hw2.0/bin/bdata.SD31.bin"
+#elif defined(AR600x_SD32_XXX)
+#define AR6003_REV2_BOARD_DATA_FILE "hw2.0/bin/bdata.SD32.bin"
+#elif defined(AR600x_WB31_XXX)
+#define AR6003_REV2_BOARD_DATA_FILE "hw2.0/bin/bdata.WB31.bin"
+#else
+#define AR6003_REV2_BOARD_DATA_FILE "hw2.0/bin/bdata.CUSTOM.bin"
+#endif /* Board Data File */
+
+#endif /* KERNEL_VERSION_ANDROID*/
+
+
+/* AR6003 3.0 definitions */
+#define AR6003_REV3_VERSION 0x30000582
+#ifdef KERNEL_VERSION_ANDROID
+#define AR6003_REV3_OTP_FILE "ath6k/AR6003/hw2.1.1/otp.bin"
+#define AR6003_REV3_DEFAULT_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/athwlan.bin"
+#define AR6003_REV3_ROUTER_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/athwlan_router.bin"
+#define AR6003_REV3_MOBILE_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/athwlan_mobile.bin"
+#define AR6003_REV3_TABLET_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/athwlan_tablet.bin"
+#define AR6003_REV3_TCMD_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/athtcmd_ram.bin"
+#define AR6003_REV3_TESTSCRIPT_FILE "ath6k/AR6003/hw2.1.1/testflow.bin"
+#define AR6003_REV3_UTF_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/utf.bin"
+#define AR6003_REV3_ART_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/device.bin"
+#define AR6003_REV3_PATCH_FILE "ath6k/AR6003/hw2.1.1/data.patch.hw3_0.bin"
+#define AR6003_REV3_EPPING_FIRMWARE_FILE "ath6k/AR6003/hw2.1.1/endpointping.bin"
+#ifdef AR600x_SD31_XXX
+#define AR6003_REV3_BOARD_DATA_FILE "ath6k/AR6003/hw2.1.1/bdata.SD31.bin"
+#elif defined(AR600x_SD32_XXX)
+#define AR6003_REV3_BOARD_DATA_FILE "ath6k/AR6003/hw2.1.1/bdata.SD32.bin"
+#elif defined(AR600x_WB31_XXX)
+#define AR6003_REV3_BOARD_DATA_FILE "ath6k/AR6003/hw2.1.1/bdata.WB31.bin"
+#else
+#define AR6003_REV3_BOARD_DATA_FILE "ath6k/AR6003/hw2.1.1/bdata.CUSTOM.bin"
+#endif /* Board Data File */
+
+#else /* KERNEL_VERSION_ANDROID*/
+#define AR6003_REV3_OTP_FILE "hw2.1.1/bin/otp.bin"
+#define AR6003_REV3_DEFAULT_FIRMWARE_FILE "hw2.1.1/bin/athwlan.bin"
+#define AR6003_REV3_ROUTER_FIRMWARE_FILE "hw2.1.1/bin/athwlan_router.bin"
+#define AR6003_REV3_MOBILE_FIRMWARE_FILE "hw2.1.1/bin/athwlan_mobile.bin"
+#define AR6003_REV3_TABLET_FIRMWARE_FILE "hw2.1.1/bin/athwlan_tablet.bin"
+#define AR6003_REV3_TCMD_FIRMWARE_FILE "hw2.1.1/bin/athtcmd_ram.bin"
+#define AR6003_REV3_TESTSCRIPT_FILE "hw2.1.1/bin/testflow.bin"
+#define AR6003_REV3_UTF_FIRMWARE_FILE "hw2.1.1/bin/utf.bin"
+#define AR6003_REV3_ART_FIRMWARE_FILE "hw2.1.1/bin/device.bin"
+#define AR6003_REV3_PATCH_FILE "hw2.1.1/bin/data.patch.hw3_0.bin"
+#define AR6003_REV3_EPPING_FIRMWARE_FILE "hw2.1.1/bin/endpointping.bin"
+#ifdef AR600x_SD31_XXX
+#define AR6003_REV3_BOARD_DATA_FILE "hw2.1.1/bin/bdata.SD31.bin"
+#elif defined(AR600x_SD32_XXX)
+#define AR6003_REV3_BOARD_DATA_FILE "hw2.1.1/bin/bdata.SD32.bin"
+#elif defined(AR600x_WB31_XXX)
+#define AR6003_REV3_BOARD_DATA_FILE "hw2.1.1/bin/bdata.WB31.bin"
+#else
+#define AR6003_REV3_BOARD_DATA_FILE "hw2.1.1/bin/bdata.CUSTOM.bin"
+#endif /* Board */
+
+
+#endif /* KERNEL_VERSION_ANDROID*/
+
+/* AP-STA Concurrency */
+#define GET_CONN_AP_PRIV(_ar,_priv) do { \
+ int i; \
+ AR_SOFTC_DEV_T *tDev =NULL; \
+ for(i=0;i<_ar->arConfNumDev;i++) { \
+ tDev = _ar->arDev[i]; \
+ if((tDev->arNetworkType == AP_NETWORK) && \
+ (tDev->arConnected)) { \
+ _priv = tDev; \
+ break; \
+ } \
+ } \
+}while(0);
+
+/* Power states */
+enum {
+ WLAN_PWR_CTRL_UP = 0,
+ WLAN_PWR_CTRL_CUT_PWR,
+ WLAN_PWR_CTRL_DEEP_SLEEP,
+ WLAN_PWR_CTRL_WOW,
+ WLAN_PWR_CTRL_DEEP_SLEEP_DISABLED
+};
+
+/* HTC RAW streams */
+typedef enum _HTC_RAW_STREAM_ID {
+ HTC_RAW_STREAM_NOT_MAPPED = -1,
+ HTC_RAW_STREAM_0 = 0,
+ HTC_RAW_STREAM_1 = 1,
+ HTC_RAW_STREAM_2 = 2,
+ HTC_RAW_STREAM_3 = 3,
+ HTC_RAW_STREAM_NUM_MAX
+} HTC_RAW_STREAM_ID;
+
+#define RAW_HTC_READ_BUFFERS_NUM 4
+#define RAW_HTC_WRITE_BUFFERS_NUM 4
+
+#define HTC_RAW_BUFFER_SIZE 1664
+
+typedef struct {
+ int currPtr;
+ int length;
+ A_UINT8 _Pad1[A_CACHE_LINE_PAD];
+ unsigned char data[HTC_RAW_BUFFER_SIZE];
+ A_UINT8 _Pad2[A_CACHE_LINE_PAD];
+ HTC_PACKET HTCPacket;
+} raw_htc_buffer;
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+/*
+ * add TCMD_MODE besides wmi and bypasswmi
+ * in TCMD_MODE, only few TCMD releated wmi commands
+ * counld be hanlder
+ */
+enum {
+ AR6000_WMI_MODE = 0,
+ AR6000_BYPASS_MODE,
+ AR6000_TCMD_MODE,
+ AR6000_WLAN_MODE
+};
+#endif /* CONFIG_HOST_TCMD_SUPPORT */
+
+struct ar_wep_key {
+ A_UINT8 arKeyIndex;
+ A_UINT8 arKeyLen;
+ A_UINT8 arKey[64];
+} ;
+
+#ifdef ATH6K_CONFIG_CFG80211
+struct ar_key {
+ A_UINT8 key[WLAN_MAX_KEY_LEN];
+ A_UINT8 key_len;
+ A_UINT8 seq[IW_ENCODE_SEQ_MAX_SIZE];
+ A_UINT8 seq_len;
+ A_UINT32 cipher;
+};
+#endif /* ATH6K_CONFIG_CFG80211 */
+
+
+struct ar_node_mapping {
+ A_UINT8 macAddress[6];
+ A_UINT8 epId;
+ A_UINT8 txPending;
+};
+
+struct ar_cookie {
+ unsigned long arc_bp[2]; /* Must be first field */
+ HTC_PACKET HtcPkt; /* HTC packet wrapper */
+ struct ar_cookie *arc_list_next;
+};
+
+struct ar_hb_chlng_resp {
+ A_TIMER timer;
+ A_UINT32 frequency;
+ A_UINT32 seqNum;
+ A_BOOL outstanding;
+ A_UINT8 missCnt;
+ A_UINT8 missThres;
+};
+
+/* Per STA data, used in AP mode */
+/*TODO: All this should move to OS independent dir */
+
+#define STA_PWR_MGMT_MASK 0x1
+#define STA_PWR_MGMT_SHIFT 0x0
+#define STA_PWR_MGMT_AWAKE 0x0
+#define STA_PWR_MGMT_SLEEP 0x1
+
+#define STA_SET_PWR_SLEEP(sta) (sta->flags |= (STA_PWR_MGMT_MASK << STA_PWR_MGMT_SHIFT))
+#define STA_CLR_PWR_SLEEP(sta) (sta->flags &= ~(STA_PWR_MGMT_MASK << STA_PWR_MGMT_SHIFT))
+#define STA_IS_PWR_SLEEP(sta) ((sta->flags >> STA_PWR_MGMT_SHIFT) & STA_PWR_MGMT_MASK)
+
+#define STA_PS_POLLED_MASK 0x1
+#define STA_PS_POLLED_SHIFT 0x1
+
+#define STA_SET_PS_POLLED(sta) (sta->flags |= (STA_PS_POLLED_MASK << STA_PS_POLLED_SHIFT))
+#define STA_CLR_PS_POLLED(sta) (sta->flags &= ~(STA_PS_POLLED_MASK << STA_PS_POLLED_SHIFT))
+#define STA_IS_PS_POLLED(sta) (sta->flags & (STA_PS_POLLED_MASK << STA_PS_POLLED_SHIFT))
+
+#define STA_APSD_TRIGGER_MASK 0x1
+#define STA_APSD_TRIGGER_SHIFT 0x2
+#define STA_APSD_EOSP_MASK 0x1
+#define STA_APSD_EOSP_SHIFT 0x3
+
+#define STA_SET_APSD_TRIGGER(sta) (sta->flags |= (STA_APSD_TRIGGER_MASK << STA_APSD_TRIGGER_SHIFT))
+#define STA_CLR_APSD_TRIGGER(sta) (sta->flags &= ~(STA_APSD_TRIGGER_MASK << STA_APSD_TRIGGER_SHIFT))
+#define STA_IS_APSD_TRIGGER(sta) (sta->flags & (STA_APSD_TRIGGER_MASK << STA_APSD_TRIGGER_SHIFT))
+
+#define STA_SET_APSD_EOSP(sta) (sta->flags |= (STA_APSD_EOSP_MASK << STA_APSD_EOSP_SHIFT))
+#define STA_CLR_APSD_EOSP(sta) (sta->flags &= ~(STA_APSD_EOSP_MASK << STA_APSD_EOSP_SHIFT))
+#define STA_IS_APSD_EOSP(sta) (sta->flags & (STA_APSD_EOSP_MASK << STA_APSD_EOSP_SHIFT))
+
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+#define APTC_TRAFFIC_SAMPLING_INTERVAL 100 /* msec */
+#define APTC_UPPER_THROUGHPUT_THRESHOLD 3000 /* Kbps */
+#define APTC_LOWER_THROUGHPUT_THRESHOLD 2000 /* Kbps */
+
+
+typedef struct aptc_traffic_record {
+ A_BOOL timerScheduled;
+ struct timeval samplingTS;
+ unsigned long bytesReceived;
+ unsigned long bytesTransmitted;
+} APTC_TRAFFIC_RECORD;
+
+#endif /* ADAPTIVE_POWER_THROUGHPUT_CONTROL */
+
+typedef struct user_rssi_compensation_t {
+ A_UINT16 customerID;
+ union {
+ A_UINT16 a_enable;
+ A_UINT16 bg_enable;
+ A_UINT16 enable;
+ };
+ A_INT16 bg_param_a;
+ A_INT16 bg_param_b;
+ A_INT16 a_param_a;
+ A_INT16 a_param_b;
+ A_UINT32 reserved;
+} USER_RSSI_CPENSATION;
+
+
+
+typedef struct {
+ A_UINT16 flags;
+ A_UINT8 mac[ATH_MAC_LEN];
+ A_UINT8 aid;
+ A_UINT8 keymgmt;
+ A_UINT8 ucipher;
+ A_UINT8 auth;
+ A_UINT8 wmode;
+ A_UINT8 wpa_ie[IEEE80211_MAX_IE];
+ A_UINT8 apsd_info;
+ A_NETBUF_QUEUE_T psq; /* power save q */
+ A_NETBUF_QUEUE_T apsdq; /* APSD delivery enabled q */
+ A_MUTEX_T psqLock;
+ void *conn_aggr;
+ void *arPriv;
+ A_UINT8 HT_present;
+} conn_t;
+
+typedef struct ar6_raw_htc {
+ HTC_ENDPOINT_ID arRaw2EpMapping[HTC_RAW_STREAM_NUM_MAX];
+ HTC_RAW_STREAM_ID arEp2RawMapping[ENDPOINT_MAX];
+ struct semaphore raw_htc_read_sem[HTC_RAW_STREAM_NUM_MAX];
+ struct semaphore raw_htc_write_sem[HTC_RAW_STREAM_NUM_MAX];
+ wait_queue_head_t raw_htc_read_queue[HTC_RAW_STREAM_NUM_MAX];
+ wait_queue_head_t raw_htc_write_queue[HTC_RAW_STREAM_NUM_MAX];
+ raw_htc_buffer raw_htc_read_buffer[HTC_RAW_STREAM_NUM_MAX][RAW_HTC_READ_BUFFERS_NUM];
+ raw_htc_buffer raw_htc_write_buffer[HTC_RAW_STREAM_NUM_MAX][RAW_HTC_WRITE_BUFFERS_NUM];
+ A_BOOL write_buffer_available[HTC_RAW_STREAM_NUM_MAX];
+ A_BOOL read_buffer_available[HTC_RAW_STREAM_NUM_MAX];
+} AR_RAW_HTC_T;
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+typedef struct {
+ A_UINT16 len;
+ A_UINT8 ver;
+ A_UINT8 reserved;
+ A_UINT8 buf[TC_CMDS_SIZE_MAX];
+} AR_TCMD_RESP;
+#endif /* CONFIG_HOST_TCMD_SUPPORT */
+
+typedef struct ar6_softc {
+ spinlock_t arLock;
+ struct semaphore arSem;
+ A_BOOL arWmiReady;
+ int arTxPending[ENDPOINT_MAX];
+ int arTotalTxDataPending;
+ A_UINT8 arNumDataEndPts;
+ HTC_HANDLE arHtcTarget;
+ void *arHifDevice;
+ struct ar6000_version arVersion;
+ A_UINT32 arTargetType;
+ AR6000_WLAN_STATE arWlanState;
+ struct ar_cookie *arCookieList;
+ A_UINT32 arCookieCount;
+ A_UINT32 arControlCookieCount;
+ struct ar_hb_chlng_resp arHBChallengeResp;
+ HTC_ENDPOINT_ID arAc2EpMapping[WMM_NUM_AC];
+ A_BOOL arAcStreamActive[WMM_NUM_AC];
+ A_UINT8 arAcStreamPriMap[WMM_NUM_AC];
+ A_UINT8 arHiAcStreamActivePri;
+ A_UINT8 arEp2AcMapping[ENDPOINT_MAX];
+ HTC_ENDPOINT_ID arControlEp;
+#ifdef HTC_RAW_INTERFACE
+ AR_RAW_HTC_T *arRawHtc;
+#endif
+ A_BOOL arRawIfInit;
+ COMMON_CREDIT_STATE_INFO arCreditStateInfo;
+ A_BOOL arWMIControlEpFull;
+ A_BOOL dbgLogFetchInProgress;
+ A_UCHAR log_buffer[DBGLOG_HOST_LOG_BUFFER_SIZE];
+ A_UINT32 log_cnt;
+ A_UINT32 dbglog_init_done;
+ HTC_PACKET_QUEUE amsdu_rx_buffer_queue;
+ A_BOOL bIsDestroyProgress; /* flag to indicate ar6k destroy is in progress */
+ A_UINT8 rxMetaVersion;
+ A_INT32 (*exitCallback)(void *config); /* generic callback at AR6K exit */
+ HIF_DEVICE_OS_DEVICE_INFO osDevInfo;
+ A_UINT16 arWlanPowerState;
+ A_BOOL arPlatPowerOff;
+ USER_RSSI_CPENSATION rssi_compensation_param;
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+ A_UINT8 tcmdRxReport;
+ A_UINT32 tcmdRxTotalPkt;
+ A_INT32 tcmdRxRssi;
+ A_UINT32 tcmdPm;
+ A_UINT32 arTargetMode;
+ A_UINT32 tcmdRxcrcErrPkt;
+ A_UINT32 tcmdRxsecErrPkt;
+ A_UINT16 tcmdRateCnt[TCMD_MAX_RATES];
+ A_UINT16 tcmdRateCntShortGuard[TCMD_MAX_RATES];
+ AR_TCMD_RESP tcmdResp;
+#endif
+ A_BOOL arWlanOff;
+#ifdef CONFIG_PM
+ A_UINT16 arWowState;
+ A_BOOL arBTOff;
+ A_BOOL arBTSharing;
+ A_UINT16 arSuspendCutPwrConfig;
+ A_UINT16 arSuspendConfig;
+ A_UINT16 arWlanOffConfig;
+ A_UINT16 arWow2Config;
+#endif
+#ifndef EXPORT_HCI_BRIDGE_INTERFACE
+ void *hcidev_info;
+#endif
+ conn_t connTbl[NUM_CONN]; /* AP mode */
+ WMI_PER_STA_STAT arAPStats[NUM_CONN]; /* AP mode */
+ A_UINT8 inter_bss; /* enable/disable inter bss data forward */
+ A_UINT8 arAcsPolicy;
+ /* Concurrency */
+ A_UINT8 arConfNumDev;
+ A_UINT8 arHoldConnection;
+ A_TIMER ap_reconnect_timer;
+ A_UINT8 gNumSta;
+ struct ar6_softc_dev *arDev[NUM_DEV];
+ A_BOOL arResumeDone;
+ /* Bluetooth Address to be read from OTP */
+ A_UINT8 bdaddr[6];
+/* AP+ BTCOEX - Variables declared for Maintaining States */
+ A_TIMER delbaTimer;
+ A_BOOL IsdelbaTimerInitialized;
+ A_UINT8 delbaState;
+ A_UINT16 lteFreq;
+ A_UINT8 isHostAsleep;
+#ifdef CONFIG_PM
+ A_BOOL sleep_mode_cmd_completed;
+ wait_queue_head_t sleep_mode_cmd_completed_event;
+#endif
+} AR_SOFTC_T;
+
+typedef struct ar6_softc_ap {
+ WMI_AP_ACL g_acl; /* AP mode */
+ A_UINT8 sta_list_index; /* AP mode */
+ struct ieee80211req_key ap_mode_bkey; /* AP mode */
+ A_NETBUF_QUEUE_T mcastpsq; /* power save q for Mcast frames */
+ A_MUTEX_T mcastpsqLock;
+ A_BOOL DTIMExpired; /* flag to indicate DTIM expired */
+ A_UINT8 intra_bss; /* enable/disable intra bss data forward */
+ A_UINT8 ap_hidden_ssid;
+ A_UINT8 ap_country_code[3];
+ A_UINT8 ap_dtim_period;
+ A_UINT16 ap_beacon_interval;
+ A_UINT16 arRTS;
+ void *pDfs; /* Pointer to DFS state structure */
+ A_BOOL deKeySet;
+}AR_SOFTC_AP_T;
+
+typedef struct ar6_softc_sta {
+ A_BOOL arConnectPending;
+ A_UINT8 arReqBssid[ATH_MAC_LEN];
+ A_UINT16 arListenIntervalB;
+ A_UINT16 arListenIntervalT;
+ A_UINT16 arBmissTimeB;
+ A_UINT16 arBmissTimeT;
+ A_INT8 arRssi;
+ A_UINT8 arSkipScan;
+ A_UINT16 arBeaconInterval;
+ A_UINT8 arKeepaliveConfigured;
+ A_UINT8 arIbssPsEnable;
+ A_UINT32 arMgmtFilter;
+ struct ar_node_mapping arNodeMap[MAX_NODE_NUM];
+ A_UINT8 arNodeNum;
+ A_UINT8 arNexEpId;
+ A_UINT32 arConnectCtrlFlags;
+#ifdef USER_KEYS
+ A_INT32 user_savedkeys_stat;
+ A_UINT32 user_key_ctrl;
+ struct USER_SAVEDKEYS user_saved_keys;
+#endif
+ USER_RSSI_THOLD rssi_map[12];
+ A_TIMER disconnect_timer;
+ A_UINT8 arUserBssFilter;
+ A_INT8 arNumChannels;
+ A_UINT16 arChannelList[WMI_MAX_CHANNELS];
+ A_UINT8 scan_triggered;
+ WMI_SCAN_PARAMS_CMD scParams;
+ A_UINT8 scanSpecificSsid;
+ A_BOOL wpaOffloadEnabled;
+ A_BOOL disconnect_timer_inited;
+ A_UINT8 arHostDisconnect;
+}AR_SOFTC_STA_T;
+
+typedef struct ar6_softc_dev {
+ struct net_device *arNetDev; /* net_device pointer */
+ void *arWmi;
+ A_BOOL arWmiEnabled;
+ wait_queue_head_t arEvent;
+ spinlock_t arPrivLock;
+ A_INT8 arMaxRetries;
+ A_BOOL statsUpdatePending;
+ A_UINT8 arPhyCapability;
+ A_UINT16 arChannelHint;
+ A_UINT16 arBssChannel;
+ A_BOOL arConnected;
+ int arSsidLen;
+ u_char arSsid[WMI_MAX_SSID_LEN];
+ A_UINT8 arNextMode;
+ A_UINT8 arNetworkType;
+ A_UINT8 arNetworkSubType;
+ A_UINT8 arDot11AuthMode;
+ A_UINT8 arAuthMode;
+ A_UINT8 arPairwiseCrypto;
+ A_UINT8 arPairwiseCryptoLen;
+ A_UINT8 arGroupCrypto;
+ A_UINT8 arGroupCryptoLen;
+ A_UINT8 arDefTxKeyIndex;
+ struct ar_wep_key arWepKeyList[WMI_MAX_KEY_INDEX + 1];
+ A_UINT8 arBssid[ATH_MAC_LEN];
+ A_UINT8 arTxPwr;
+ A_BOOL arTxPwrSet;
+ A_INT32 arBitRate;
+ struct net_device_stats arNetStats;
+ struct iw_statistics arIwStats;
+ A_UINT32 arRateMask[WMI_MAX_RATE_MASK];
+ A_BOOL arNetQueueStopped;
+ A_UINT8 arDeviceIndex;
+ A_BOOL arWmmEnabled;
+ A_UINT32 arRegCode;
+ A_UINT16 ap_profile_flag; /* AP mode */
+ WMI_BTCOEX_CONFIG_EVENT arBtcoexConfig;
+ WMI_BTCOEX_STATS_EVENT arBtcoexStats;
+ WMI_GET_WAC_INFO wacInfo;
+#define AR_MCAST_FILTER_MAC_ADDR_SIZE 6
+ A_UINT8 mcast_filters[MAC_MAX_FILTERS_PER_LIST][AR_MCAST_FILTER_MAC_ADDR_SIZE];
+ A_UINT8 bdaddr[ATH_MAC_LEN];
+#ifdef ADAPTIVE_POWER_THROUGHPUT_CONTROL
+ APTC_TRAFFIC_RECORD aptcTR;
+#endif
+#ifdef ATH6K_CONFIG_CFG80211
+ struct wireless_dev *wdev;
+ struct cfg80211_scan_request *scan_request;
+ struct ar_key keys[WMI_MAX_KEY_INDEX + 1];
+#endif /* ATH6K_CONFIG_CFG80211 */
+ TARGET_STATS arTargetStats;
+ void *conn_aggr;
+ void *p2p_ctx;
+ AR_SOFTC_AP_T arAp;
+ AR_SOFTC_STA_T arSta;
+ AR_SOFTC_T *arSoftc;
+ A_BOOL arDoConnectOnResume;
+ A_UINT8 num_sta;
+ void *hcipal_info;
+ A_BOOL isBt30amp;
+ A_UINT8 phymode;
+ A_BOOL is_sta_roaming;
+ A_UINT8 PreAuthMode;
+ A_UINT8 PreAuthKeyMgmt;
+}AR_SOFTC_DEV_T;
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,0)
+/* Looks like we need this for 2.4 kernels */
+static inline void *ar6k_priv(struct net_device *dev)
+{
+ return(dev->priv);
+}
+#else
+#ifdef ATH6K_CONFIG_CFG80211
+static inline void *ar6k_priv(struct net_device *dev)
+{
+ return (wdev_priv(dev->ieee80211_ptr));
+}
+#else
+#define ar6k_priv netdev_priv
+#endif /* ATH6K_CONFIG_CFG80211 */
+#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(2,6,0) */
+
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,34)
+#define SET_HCI_BUS_TYPE(pHciDev, __bus, __type) do { \
+ (pHciDev)->type = (__bus); \
+} while(0)
+#else
+#define SET_HCI_BUS_TYPE(pHciDev, __bus, __type) do { \
+ (pHciDev)->bus = (__bus); \
+ (pHciDev)->dev_type = (__type); \
+} while(0)
+#endif
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,20)
+#define GET_INODE_FROM_FILEP(filp) \
+ (filp)->f_path.dentry->d_inode
+#else
+#define GET_INODE_FROM_FILEP(filp) \
+ (filp)->f_dentry->d_inode
+#endif
+
+#define arAc2EndpointID(ar,ac) (ar)->arAc2EpMapping[(ac)]
+#define arSetAc2EndpointIDMap(ar,ac,ep) \
+{ (ar)->arAc2EpMapping[(ac)] = (ep); \
+ (ar)->arEp2AcMapping[(ep)] = (ac); }
+#define arEndpoint2Ac(ar,ep) (ar)->arEp2AcMapping[(ep)]
+
+#define arRawIfEnabled(ar) (ar)->arRawIfInit
+#define arRawStream2EndpointID(ar,raw) (ar)->arRawHtc->arRaw2EpMapping[(raw)]
+#define arSetRawStream2EndpointIDMap(ar,raw,ep) \
+{ (ar)->arRawHtc->arRaw2EpMapping[(raw)] = (ep); \
+ (ar)->arRawHtc->arEp2RawMapping[(ep)] = (raw); }
+#define arEndpoint2RawStreamID(ar,ep) (ar)->arRawHtc->arEp2RawMapping[(ep)]
+
+struct ar_giwscan_param {
+ char *current_ev;
+ char *end_buf;
+ A_UINT32 bytes_needed;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27)
+ struct iw_request_info *info;
+#endif
+};
+
+#define AR6000_STAT_INC(ar, stat) (ar->arNetStats.stat++)
+
+#define AR6000_SPIN_LOCK(lock, param) do { \
+ if (irqs_disabled()) { \
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC,("IRQs disabled:AR6000_LOCK\n")); \
+ } \
+ spin_lock_bh(lock); \
+} while (0)
+
+#define AR6000_SPIN_UNLOCK(lock, param) do { \
+ if (irqs_disabled()) { \
+ AR_DEBUG_PRINTF(ATH_DEBUG_TRC,("IRQs disabled: AR6000_UNLOCK\n")); \
+ } \
+ spin_unlock_bh(lock); \
+} while (0)
+
+int ar6000_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
+int ar6000_ioctl_dispatcher(struct net_device *dev, struct ifreq *rq, int cmd);
+void ar6000_gpio_init(void);
+void ar6000_init_profile_info(AR_SOFTC_DEV_T *arPriv);
+void ar6000_install_static_wep_keys(AR_SOFTC_DEV_T *arPriv);
+int ar6000_init(struct net_device *dev);
+int ar6000_dbglog_get_debug_logs(AR_SOFTC_T *ar);
+void ar6000_TxDataCleanup(AR_SOFTC_T *ar);
+int ar6000_acl_data_tx(struct sk_buff *skb, AR_SOFTC_DEV_T *arPriv);
+void ar6000_restart_endpoint(AR_SOFTC_T *ar);
+void ar6000_stop_endpoint(AR_SOFTC_T *ar, A_BOOL keepprofile, A_BOOL getdbglogs);
+
+#ifdef HTC_RAW_INTERFACE
+
+#ifndef __user
+#define __user
+#endif
+
+int ar6000_htc_raw_open(AR_SOFTC_T *ar);
+int ar6000_htc_raw_close(AR_SOFTC_T *ar);
+ssize_t ar6000_htc_raw_read(AR_SOFTC_T *ar,
+ HTC_RAW_STREAM_ID StreamID,
+ char __user *buffer, size_t count);
+ssize_t ar6000_htc_raw_write(AR_SOFTC_T *ar,
+ HTC_RAW_STREAM_ID StreamID,
+ char __user *buffer, size_t count);
+
+#endif /* HTC_RAW_INTERFACE */
+
+/* AP mode */
+/*TODO: These routines should be moved to a file that is common across OS */
+conn_t *
+ieee80211_find_conn(AR_SOFTC_DEV_T *arPriv, A_UINT8 *node_addr);
+
+conn_t *
+ieee80211_find_conn_for_aid(AR_SOFTC_DEV_T *arPriv, A_UINT8 aid);
+
+A_UINT8
+remove_sta(AR_SOFTC_DEV_T *arPriv, A_UINT8 *mac, A_UINT16 reason);
+
+void
+ar6000_ap_cleanup(AR_SOFTC_DEV_T *arPriv);
+
+int
+ar6000_ap_set_num_sta(AR_SOFTC_T *ar, AR_SOFTC_DEV_T *arPriv, A_UINT8 num_sta);
+
+int
+ar6000_ap_handle_lte_freq(AR_SOFTC_T *ar, AR_SOFTC_DEV_T *arPriv, A_UINT16 lteFreq);
+
+void
+ar6000_send_delba (void *context, A_UINT8 reasonCode);
+/* HCI support */
+
+#ifndef EXPORT_HCI_BRIDGE_INTERFACE
+A_STATUS ar6000_setup_hci(AR_SOFTC_T *ar);
+void ar6000_cleanup_hci(AR_SOFTC_T *ar);
+void ar6000_set_default_ar3kconfig(AR_SOFTC_T *ar, void *ar3kconfig);
+
+/* HCI bridge testing */
+A_STATUS hci_test_send(AR_SOFTC_T *ar, struct sk_buff *skb);
+#endif
+void ar6000_init_mode_info(AR_SOFTC_DEV_T *arPriv);
+ATH_DEBUG_DECLARE_EXTERN(htc);
+ATH_DEBUG_DECLARE_EXTERN(wmi);
+ATH_DEBUG_DECLARE_EXTERN(bmi);
+ATH_DEBUG_DECLARE_EXTERN(hif);
+ATH_DEBUG_DECLARE_EXTERN(wlan);
+ATH_DEBUG_DECLARE_EXTERN(misc);
+
+extern A_UINT8 bcast_mac[];
+extern A_UINT8 null_mac[];
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _AR6000_H_ */
diff --git a/host/os/linux/include/ar6k_pal.h b/host/os/linux/include/ar6k_pal.h
new file mode 100644
index 0000000..98eb1db
--- /dev/null
+++ b/host/os/linux/include/ar6k_pal.h
@@ -0,0 +1,47 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+// The software source and binaries included in this development package are
+// licensed, not sold. You, or your company, received the package under one
+// or more license agreements. The rights granted to you are specifically
+// listed in these license agreement(s). All other rights remain with Atheros
+// Communications, Inc., its subsidiaries, or the respective owner including
+// those listed on the included copyright notices. Distribution of any
+// portion of this package must be in strict compliance with the license
+// agreement(s) terms.
+// </copyright>
+//
+// <summary>
+// PAL driver for AR6003
+// </summary>
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HCI_PAL_H_
+#define _HCI_PAL_H_
+#define HCI_GET_OP_CODE(p) (((A_UINT16)((p)[1])) << 8) | ((A_UINT16)((p)[0]))
+#define TX_PACKET_RSV_OFFSET 32
+/* pal specific config structure */
+typedef A_BOOL (*ar6k_pal_recv_pkt_t)(void *pHciPalInfo, void *skb);
+typedef struct ar6k_pal_config_s
+{
+ ar6k_pal_recv_pkt_t fpar6k_pal_recv_pkt;
+}ar6k_pal_config_t;
+
+/**********************************
+ * HCI PAL private info structure
+ *********************************/
+typedef struct ar6k_hci_pal_info_s{
+
+ unsigned long ulFlags;
+#define HCI_NORMAL_MODE (1)
+#define HCI_REGISTERED (1<<1)
+ struct hci_dev *hdev; /* BT Stack HCI dev */
+ AR_SOFTC_DEV_T *ar;
+
+}ar6k_hci_pal_info_t;
+
+void register_pal_cb(ar6k_pal_config_t *palConfig_p);
+#endif /* _HCI_PAL_H_ */
diff --git a/host/os/linux/include/ar6xapi_linux.h b/host/os/linux/include/ar6xapi_linux.h
new file mode 100644
index 0000000..8db0d64
--- /dev/null
+++ b/host/os/linux/include/ar6xapi_linux.h
@@ -0,0 +1,252 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _AR6XAPI_LINUX_H
+#define _AR6XAPI_LINUX_H
+
+#include <wmi.h>
+#ifdef ATH_SUPPORT_DFS
+#include <dfs_common.h>
+#endif
+#include <htc_packet.h>
+#include <athdrv_linux.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+struct ar6_softc;
+struct ar6_softc_dev;
+
+#ifdef ATH_SUPPORT_DFS
+void ar6000_dfs_attach_event(struct ar6_softc_dev *arPriv, WMI_DFS_HOST_ATTACH_EVENT *capinfo);
+void ar6000_dfs_init_event(struct ar6_softc_dev *arPriv, WMI_DFS_HOST_INIT_EVENT *info);
+void ar6000_dfs_reset_delaylines_event(struct ar6_softc_dev *arPriv);
+void ar6000_dfs_reset_radarq_event(struct ar6_softc_dev *arPriv);
+void ar6000_dfs_reset_ar_event(struct ar6_softc_dev *arPriv);
+void ar6000_dfs_reset_arq_event(struct ar6_softc_dev *arPriv);
+void ar6000_dfs_set_dur_multiplier_event(struct ar6_softc_dev *arPriv, A_UINT32 value);
+void ar6000_dfs_set_debuglevel_event(struct ar6_softc_dev *arPriv, A_UINT32 value);
+void ar6000_dfs_set_bangradar_event(struct ar6_softc_dev *arPriv, A_UINT32 value);
+A_STATUS ar6000_dfs_set_maxpulsedur_cmd(struct ar6_softc_dev *arPriv, A_UINT32 value);
+A_STATUS ar6000_dfs_radar_detected_cmd(struct ar6_softc_dev *arPriv, A_INT16 chan_index, A_INT8 bang_radar);
+A_STATUS ar6000_dfs_set_minrssithresh_cmd(struct ar6_softc_dev *arPriv, A_INT32 rssi);
+void ar6000_dfs_phyerr_event(struct ar6_softc_dev *arPriv, WMI_DFS_PHYERR_EVENT *info);
+#endif
+
+void ar6000_ready_event(void *devt, A_UINT8 *datap, A_UINT8 phyCap,
+ A_UINT32 sw_ver, A_UINT32 abi_ver);
+A_STATUS ar6000_control_tx(void *devt, void *osbuf, HTC_ENDPOINT_ID eid);
+void ar6000_connect_event(struct ar6_softc_dev *arPriv, WMI_CONNECT_EVENT *pEvt);
+void ar6000_disconnect_event(struct ar6_softc_dev *arPriv, A_UINT8 reason,
+ A_UINT8 *bssid, A_UINT8 assocRespLen,
+ A_UINT8 *assocInfo, A_UINT16 protocolReasonStatus);
+void ar6000_tkip_micerr_event(struct ar6_softc_dev *arPriv, A_UINT8 keyid,
+ A_BOOL ismcast);
+void ar6000_bitrate_rx(void *devt, A_INT32 rateKbps);
+void ar6000_channelList_rx(void *devt, A_INT8 numChan, A_UINT16 *chanList);
+void ar6000_regDomain_event(struct ar6_softc_dev *arPriv, A_UINT32 regCode);
+void ar6000_txPwr_rx(void *devt, A_UINT8 txPwr);
+void ar6000_keepalive_rx(void *devt, A_UINT8 configured);
+void ar6000_neighborReport_event(struct ar6_softc_dev *arPriv, int numAps,
+ WMI_NEIGHBOR_INFO *info);
+void ar6000_set_numdataendpts(struct ar6_softc_dev *arPriv, A_UINT32 num);
+void ar6000_scanComplete_event(struct ar6_softc_dev *arPriv, A_STATUS status);
+void ar6000_targetStats_event(struct ar6_softc_dev *arPriv, A_UINT8 *ptr, A_UINT32 len);
+void ar6000_rssiThreshold_event(struct ar6_softc_dev *arPriv,
+ WMI_RSSI_THRESHOLD_VAL newThreshold,
+ A_INT16 rssi);
+void ar6000_reportError_event(struct ar6_softc_dev *, WMI_TARGET_ERROR_VAL errorVal);
+void ar6000_cac_event(struct ar6_softc_dev *arPriv, A_UINT8 ac, A_UINT8 cac_indication,
+ A_UINT8 statusCode, A_UINT8 *tspecSuggestion);
+void ar6000_channel_change_event(struct ar6_softc_dev *arPriv, A_UINT16 oldChannel, A_UINT16 newChannel);
+void ar6000_hbChallengeResp_event(struct ar6_softc_dev *arPriv, A_UINT32 cookie, A_UINT32 source);
+void
+ar6000_roam_tbl_event(struct ar6_softc_dev *arPriv, WMI_TARGET_ROAM_TBL *pTbl);
+
+void
+ar6000_roam_data_event(struct ar6_softc_dev *arPriv, WMI_TARGET_ROAM_DATA *p);
+
+void
+ar6000_wow_list_event(struct ar6_softc_dev *ar, A_UINT8 num_filters,
+ WMI_GET_WOW_LIST_REPLY *wow_reply);
+
+void ar6000_pmkid_list_event(void *devt, A_UINT8 numPMKID,
+ WMI_PMKID *pmkidList, A_UINT8 *bssidList);
+
+void ar6000_gpio_intr_rx(struct ar6_softc_dev *arPriv, A_UINT32 intr_mask, A_UINT32 input_values);
+void ar6000_gpio_data_rx(struct ar6_softc_dev *arPriv, A_UINT32 reg_id, A_UINT32 value);
+void ar6000_gpio_ack_rx(struct ar6_softc_dev *arPriv);
+
+A_INT32 rssi_compensation_calc_tcmd(struct ar6_softc *ar, A_UINT32 freq, A_INT32 rssi, A_UINT32 totalPkt);
+A_INT16 rssi_compensation_calc(struct ar6_softc_dev *arPriv, A_INT16 rssi);
+A_INT16 rssi_compensation_reverse_calc(struct ar6_softc_dev *arPriv, A_INT16 rssi, A_BOOL Above);
+
+void ar6000_dbglog_init_done(struct ar6_softc_dev *arPriv);
+
+void ar6000_wacinfo_event(struct ar6_softc_dev *ar, A_UINT8 *ptr, A_UINT32 len);
+
+#ifdef SEND_EVENT_TO_APP
+void ar6000_send_event_to_app(struct ar6_softc_dev *arPriv, A_UINT16 eventId, A_UINT8 *datap, int len);
+void ar6000_send_generic_event_to_app(struct ar6_softc_dev *arPriv, A_UINT16 eventId, A_UINT8 *datap, int len);
+#endif
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+void ar6000_tcmd_rx_report_event(struct ar6_softc_dev *arPriv, A_UINT8 * results, int len);
+#endif
+
+void ar6000_tx_retry_err_event(void *devt);
+
+void ar6000_snrThresholdEvent_rx(void *devt,
+ WMI_SNR_THRESHOLD_VAL newThreshold,
+ A_UINT8 snr);
+
+void ar6000_lqThresholdEvent_rx(void *devt, WMI_LQ_THRESHOLD_VAL range, A_UINT8 lqVal);
+
+
+void ar6000_ratemask_rx(void *devt, A_UINT32 *ratemask);
+
+A_STATUS ar6000_get_driver_cfg(struct net_device *dev,
+ A_UINT16 cfgParam,
+ void *result);
+void ar6000_bssInfo_event_rx(struct ar6_softc_dev *arPriv, A_UINT8 *data, int len);
+A_STATUS ar6000_ap_mode_probe_rx(struct ar6_softc_dev *arPriv, A_UINT8 *data, int len);
+
+void ar6000_dbglog_event(struct ar6_softc_dev *arPriv, A_UINT32 dropped,
+ A_INT8 *buffer, A_UINT32 length);
+
+int ar6000_dbglog_get_debug_logs(struct ar6_softc *ar);
+
+void ar6000_peer_event(void *devt, A_UINT8 eventCode, A_UINT8 *bssid);
+
+void ar6000_indicate_tx_activity(void *devt, A_UINT8 trafficClass, A_BOOL Active);
+HTC_ENDPOINT_ID ar6000_ac2_endpoint_id ( void * devt, A_UINT8 ac);
+A_UINT8 ar6000_endpoint_id2_ac (void * devt, HTC_ENDPOINT_ID ep );
+
+void ar6000_btcoex_config_event(struct ar6_softc_dev *arPriv, A_UINT8 *ptr, A_UINT32 len);
+
+void ar6000_btcoex_stats_event(struct ar6_softc_dev *arPriv, A_UINT8 *ptr, A_UINT32 len) ;
+
+void ar6000_dset_open_req(void *devt,
+ A_UINT32 id,
+ A_UINT32 targ_handle,
+ A_UINT32 targ_reply_fn,
+ A_UINT32 targ_reply_arg);
+void ar6000_dset_close(void *devt, A_UINT32 access_cookie);
+void ar6000_dset_data_req(void *devt,
+ A_UINT32 access_cookie,
+ A_UINT32 offset,
+ A_UINT32 length,
+ A_UINT32 targ_buf,
+ A_UINT32 targ_reply_fn,
+ A_UINT32 targ_reply_arg);
+
+
+#if defined(CONFIG_TARGET_PROFILE_SUPPORT)
+void prof_count_rx(unsigned int addr, unsigned int count);
+#endif
+
+A_UINT32 ar6000_getnodeAge (void);
+
+A_UINT32 ar6000_getclkfreq (void);
+
+int ar6000_ap_mode_profile_commit(struct ar6_softc_dev *arPriv);
+
+A_STATUS ar6000_check_connect_request(struct ar6_softc_dev *arPriv, A_UINT8 check_pending_status);
+
+struct ieee80211req_wpaie;
+A_STATUS
+ar6000_ap_mode_get_wpa_ie(struct ar6_softc_dev *arPriv, struct ieee80211req_wpaie *wpaie);
+
+A_STATUS is_iwioctl_allowed(A_UINT8 mode, A_UINT16 cmd);
+
+A_STATUS is_xioctl_allowed(A_UINT8 mode, A_UINT8 submode, int cmd);
+
+void ar6000_pspoll_event(struct ar6_softc_dev *arPriv,A_UINT8 aid);
+
+void ar6000_dtimexpiry_event(struct ar6_softc_dev *arPriv);
+
+void ar6000_aggr_rcv_addba_req_evt(struct ar6_softc_dev *arPriv, WMI_ADDBA_REQ_EVENT *cmd);
+void ar6000_aggr_rcv_addba_resp_evt(struct ar6_softc_dev *arPriv, WMI_ADDBA_RESP_EVENT *cmd);
+void ar6000_aggr_rcv_delba_req_evt(struct ar6_softc_dev *arPriv, WMI_DELBA_EVENT *cmd);
+void ar6000_hci_event_rcv_evt(struct ar6_softc_dev *arPriv, WMI_HCI_EVENT *cmd);
+
+#ifdef WAPI_ENABLE
+int ap_set_wapi_key(struct ar6_softc_dev *arPriv, void *ik);
+void ap_wapi_rekey_event(struct ar6_softc_dev *arPriv, A_UINT8 type, A_UINT8 *mac);
+#endif
+
+#ifdef P2P
+void ar6000_p2pdev_event(struct ar6_softc_dev *arPriv, const A_UINT8 *addr,
+ const A_UINT8 *dev_addr,
+ const A_UINT8 *pri_dev_type, const A_UINT8 *dev_name,
+ A_UINT8 dev_name_len, A_UINT16 config_methods,
+ A_UINT8 dev_capab, A_UINT8 grp_capab);
+void p2p_go_neg_event(struct ar6_softc_dev *arPriv, A_UINT8 *res, A_UINT8 len);
+void p2p_go_neg_req_event(struct ar6_softc_dev *arPriv, const A_UINT8 *sa, A_UINT16 dev_passwd_id);
+void p2p_invite_sent_result_event(struct ar6_softc_dev *arPriv, A_UINT8 *res,
+ A_UINT8 len);
+void p2p_invite_rcvd_result_event(struct ar6_softc_dev *arPriv, A_UINT8 *res,
+ A_UINT8 len);
+void ar6000_p2p_prov_disc_req_event(struct ar6_softc_dev *arPriv,
+ const A_UINT8 *peer, A_UINT16 wps_config_method,
+ const A_UINT8 *dev_addr, const A_UINT8 *pri_dev_type,
+ const A_UINT8 *dev_name, A_UINT8 dev_name_len,
+ A_UINT16 supp_config_methods, A_UINT8 dev_capab, A_UINT8 group_capab);
+void ar6000_p2p_prov_disc_resp_event(struct ar6_softc_dev *arPriv,
+ A_UINT8 *peer, A_UINT16 config_methods);
+void *get_p2p_ctx(struct ar6_softc_dev *arPriv);
+void *get_wmi_ctx(struct ar6_softc_dev *arPriv);
+NETWORK_SUBTYPE get_network_subtype(struct ar6_softc_dev *arPriv);
+void ar6000_p2p_sd_rx_event(struct ar6_softc_dev *arPriv, WMI_P2P_SDPD_RX_EVENT *ev);
+void ar6000_p2pdev_lost_event(struct ar6_softc_dev *arPriv, const A_UINT8 *dev_addr);
+#endif
+
+A_STATUS ar6000_connect_to_ap(struct ar6_softc_dev *arPriv);
+A_STATUS ar6000_disconnect(struct ar6_softc_dev *arPriv);
+A_STATUS ar6000_update_wlan_pwr_state(struct ar6_softc *ar, AR6000_WLAN_STATE state, A_BOOL suspending);
+
+A_STATUS ar6000_set_wlan_state(struct ar6_softc *ar, AR6000_WLAN_STATE state);
+A_STATUS ar6000_set_bt_hw_state(struct ar6_softc *ar, A_UINT32 state);
+
+#ifdef CONFIG_PM
+A_STATUS ar6000_suspend_ev(void *context);
+A_STATUS ar6000_resume_ev(void *context);
+A_STATUS ar6000_power_change_ev(void *context, A_UINT32 config);
+void ar6000_check_wow_status(struct ar6_softc *ar, struct sk_buff *skb, A_BOOL isEvent);
+#endif
+
+void ar6000_pm_init(void);
+void ar6000_pm_exit(void);
+
+void ar6000_indicate_proberesp(struct ar6_softc_dev *arPriv , A_UINT8* pData , A_UINT16 len ,A_UINT8* bssid);
+void ar6000_indicate_beacon(struct ar6_softc_dev *arPriv , A_UINT8* pData , A_UINT16 len ,A_UINT8* bssid);
+void ar6000_assoc_req_report_event (void *context, A_UINT8 status, A_UINT8 rspType, A_UINT8* pData, int len);
+void ar6000_get_device_addr(struct ar6_softc_dev *arPriv, A_UINT8 *addr);
+NETWORK_TYPE ar6000_get_network_type(struct ar6_softc_dev *arPriv);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff --git a/host/os/linux/include/athdrv_linux.h b/host/os/linux/include/athdrv_linux.h
new file mode 100644
index 0000000..8ece7c7
--- /dev/null
+++ b/host/os/linux/include/athdrv_linux.h
@@ -0,0 +1,1482 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _ATHDRV_LINUX_H
+#define _ATHDRV_LINUX_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+/*
+ * There are two types of ioctl's here: Standard ioctls and
+ * eXtended ioctls. All extended ioctls (XIOCTL) are multiplexed
+ * off of the single ioctl command, AR6000_IOCTL_EXTENDED. The
+ * arguments for every XIOCTL starts with a 32-bit command word
+ * that is used to select which extended ioctl is in use. After
+ * the command word are command-specific arguments.
+ */
+
+/* Linux standard Wireless Extensions, private ioctl interfaces */
+#define IEEE80211_IOCTL_SETPARAM (SIOCIWFIRSTPRIV+0)
+#define IEEE80211_IOCTL_SETKEY (SIOCIWFIRSTPRIV+1)
+#define IEEE80211_IOCTL_DELKEY (SIOCIWFIRSTPRIV+2)
+#define IEEE80211_IOCTL_SETMLME (SIOCIWFIRSTPRIV+3)
+#define IEEE80211_IOCTL_ADDPMKID (SIOCIWFIRSTPRIV+4)
+#define IEEE80211_IOCTL_SETOPTIE (SIOCIWFIRSTPRIV+5)
+//#define IEEE80211_IOCTL_GETPARAM (SIOCIWFIRSTPRIV+6)
+//#define IEEE80211_IOCTL_SETWMMPARAMS (SIOCIWFIRSTPRIV+7)
+//#define IEEE80211_IOCTL_GETWMMPARAMS (SIOCIWFIRSTPRIV+8)
+//#define IEEE80211_IOCTL_GETOPTIE (SIOCIWFIRSTPRIV+9)
+//#define IEEE80211_IOCTL_SETAUTHALG (SIOCIWFIRSTPRIV+10)
+#define IEEE80211_IOCTL_LASTONE (SIOCIWFIRSTPRIV+10)
+
+
+
+/* ====WMI Ioctls==== */
+/*
+ *
+ * Many ioctls simply provide WMI services to application code:
+ * an application makes such an ioctl call with a set of arguments
+ * that are packaged into the corresponding WMI message, and sent
+ * to the Target.
+ */
+
+#define AR6000_IOCTL_WMI_GETREV (SIOCIWFIRSTPRIV+11)
+/*
+ * arguments:
+ * ar6000_version *revision
+ */
+
+#define AR6000_IOCTL_WMI_SETPWR (SIOCIWFIRSTPRIV+12)
+/*
+ * arguments:
+ * WMI_POWER_MODE_CMD pwrModeCmd (see include/wmi.h)
+ * uses: WMI_SET_POWER_MODE_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SETSCAN (SIOCIWFIRSTPRIV+13)
+/*
+ * arguments:
+ * WMI_SCAN_PARAMS_CMD scanParams (see include/wmi.h)
+ * uses: WMI_SET_SCAN_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SETLISTENINT (SIOCIWFIRSTPRIV+14)
+/*
+ * arguments:
+ * UINT32 listenInterval
+ * uses: WMI_SET_LISTEN_INT_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SETBSSFILTER (SIOCIWFIRSTPRIV+15)
+/*
+ * arguments:
+ * WMI_BSS_FILTER filter (see include/wmi.h)
+ * uses: WMI_SET_BSS_FILTER_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_CHANNELPARAMS (SIOCIWFIRSTPRIV+16)
+/*
+ * arguments:
+ * WMI_CHANNEL_PARAMS_CMD chParams
+ * uses: WMI_SET_CHANNEL_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_PROBEDSSID (SIOCIWFIRSTPRIV+17)
+/*
+ * arguments:
+ * WMI_PROBED_SSID_CMD probedSsids (see include/wmi.h)
+ * uses: WMI_SETPROBED_SSID_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_PMPARAMS (SIOCIWFIRSTPRIV+18)
+/*
+ * arguments:
+ * WMI_POWER_PARAMS_CMD powerParams (see include/wmi.h)
+ * uses: WMI_SET_POWER_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_BADAP (SIOCIWFIRSTPRIV+19)
+/*
+ * arguments:
+ * WMI_ADD_BAD_AP_CMD badAPs (see include/wmi.h)
+ * uses: WMI_ADD_BAD_AP_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_GET_QOS_QUEUE (SIOCIWFIRSTPRIV+20)
+/*
+ * arguments:
+ * ar6000_queuereq queueRequest (see below)
+ */
+
+#define AR6000_IOCTL_WMI_CREATE_QOS (SIOCIWFIRSTPRIV+21)
+/*
+ * arguments:
+ * WMI_CREATE_PSTREAM createPstreamCmd (see include/wmi.h)
+ * uses: WMI_CREATE_PSTREAM_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_DELETE_QOS (SIOCIWFIRSTPRIV+22)
+/*
+ * arguments:
+ * WMI_DELETE_PSTREAM_CMD deletePstreamCmd (see include/wmi.h)
+ * uses: WMI_DELETE_PSTREAM_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_SNRTHRESHOLD (SIOCIWFIRSTPRIV+23)
+/*
+ * arguments:
+ * WMI_SNR_THRESHOLD_PARAMS_CMD thresholdParams (see include/wmi.h)
+ * uses: WMI_SNR_THRESHOLD_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_ERROR_REPORT_BITMASK (SIOCIWFIRSTPRIV+24)
+/*
+ * arguments:
+ * WMI_TARGET_ERROR_REPORT_BITMASK errorReportBitMask (see include/wmi.h)
+ * uses: WMI_TARGET_ERROR_REPORT_BITMASK_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_GET_TARGET_STATS (SIOCIWFIRSTPRIV+25)
+/*
+ * arguments:
+ * TARGET_STATS *targetStats (see below)
+ * uses: WMI_GET_STATISTICS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_ASSOC_INFO (SIOCIWFIRSTPRIV+26)
+/*
+ * arguments:
+ * WMI_SET_ASSOC_INFO_CMD setAssocInfoCmd
+ * uses: WMI_SET_ASSOC_INFO_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_ACCESS_PARAMS (SIOCIWFIRSTPRIV+27)
+/*
+ * arguments:
+ * WMI_SET_ACCESS_PARAMS_CMD setAccessParams (see include/wmi.h)
+ * uses: WMI_SET_ACCESS_PARAMS_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_BMISS_TIME (SIOCIWFIRSTPRIV+28)
+/*
+ * arguments:
+ * UINT32 beaconMissTime
+ * uses: WMI_SET_BMISS_TIME_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_DISC_TIMEOUT (SIOCIWFIRSTPRIV+29)
+/*
+ * arguments:
+ * WMI_DISC_TIMEOUT_CMD disconnectTimeoutCmd (see include/wmi.h)
+ * uses: WMI_SET_DISC_TIMEOUT_CMDID
+ */
+
+#define AR6000_IOCTL_WMI_SET_IBSS_PM_CAPS (SIOCIWFIRSTPRIV+30)
+/*
+ * arguments:
+ * WMI_IBSS_PM_CAPS_CMD ibssPowerMgmtCapsCmd
+ * uses: WMI_SET_IBSS_PM_CAPS_CMDID
+ */
+
+/*
+ * There is a very small space available for driver-private
+ * wireless ioctls. In order to circumvent this limitation,
+ * we multiplex a bunch of ioctls (XIOCTLs) on top of a
+ * single AR6000_IOCTL_EXTENDED ioctl.
+ */
+#define AR6000_IOCTL_EXTENDED (SIOCIWFIRSTPRIV+31)
+
+typedef enum {
+ AR6000_XIOCTL_BMI_DONE = 1,
+ AR6000_XIOCTL_BMI_READ_MEMORY,
+ AR6000_XIOCTL_BMI_WRITE_MEMORY,
+ AR6000_XIOCTL_BMI_EXECUTE,
+ AR6000_XIOCTL_BMI_SET_APP_START,
+ AR6000_XIOCTL_BMI_READ_SOC_REGISTER,
+ AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER,
+ AR6000_XIOCTL_BMI_TEST,
+ AR6000_XIOCTL_UNUSED9,
+ AR6000_XIOCTL_UNUSED10, /* 10 */
+ AR6000_XIOCTL_UNUSED11,
+ AR6000_XIOCTL_FORCE_TARGET_RESET,
+ AR6000_XIOCTL_HTC_RAW_OPEN,
+ AR6000_XIOCTL_HTC_RAW_CLOSE,
+ AR6000_XIOCTL_HTC_RAW_READ,
+ AR6000_XIOCTL_HTC_RAW_WRITE,
+ AR6000_XIOCTL_CHECK_TARGET_READY,
+ AR6000_XIOCTL_GPIO_OUTPUT_SET,
+ AR6000_XIOCTL_GPIO_INPUT_GET,
+ AR6000_XIOCTL_GPIO_REGISTER_SET, /* 20 */
+ AR6000_XIOCTL_GPIO_REGISTER_GET,
+ AR6000_XIOCTL_GPIO_INTR_ACK,
+ AR6000_XIOCTL_GPIO_INTR_WAIT,
+ AR6000_XIOCTL_SET_ADHOC_BSSID,
+ AR6000_XIOCTL_UNUSED25,
+ AR6000_XIOCTL_UNUSED26,
+ AR6000_XIOCTL_SET_BEACON_INTVAL,
+ IEEE80211_IOCTL_SETAUTHALG,
+ AR6000_XIOCTL_SET_VOICE_PKT_SIZE,
+ AR6000_XIOCTL_SET_MAX_SP, /* 30 */
+ AR6000_XIOCTL_WMI_GET_ROAM_TBL,
+ AR6000_XIOCTL_WMI_SET_ROAM_CTRL,
+ AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS,
+ AR6000_XIOCTRL_WMI_GET_POWER_MODE,
+ AR6000_XIOCTRL_WMI_SET_WLAN_STATE,
+ AR6000_XIOCTL_WMI_GET_ROAM_DATA,
+ AR6000_XIOCTL_WMI_SETRETRYLIMITS,
+ AR6000_XIOCTL_TCMD_CONT_TX,
+ AR6000_XIOCTL_TCMD_CONT_RX,
+ AR6000_XIOCTL_TCMD_PM, /* 40 */
+ AR6000_XIOCTL_WMI_STARTSCAN,
+ AR6000_XIOCTL_WMI_SETFIXRATES,
+ AR6000_XIOCTL_WMI_GETFIXRATES,
+ AR6000_XIOCTL_WMI_SET_RSSITHRESHOLD,
+ AR6000_XIOCTL_WMI_CLR_RSSISNR,
+ AR6000_XIOCTL_WMI_SET_LQTHRESHOLD,
+ AR6000_XIOCTL_WMI_SET_RTS,
+ AR6000_XIOCTL_WMI_SET_LPREAMBLE,
+ AR6000_XIOCTL_WMI_SET_AUTHMODE,
+ AR6000_XIOCTL_WMI_SET_REASSOCMODE, /* 50 */
+ AR6000_XIOCTL_WMI_SET_WMM,
+ AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS,
+ AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP,
+ AR6000_XIOCTL_WMI_GET_RD,
+ AR6000_XIOCTL_DIAG_READ,
+ AR6000_XIOCTL_DIAG_WRITE,
+ AR6000_XIOCTL_WMI_SET_TXOP,
+ AR6000_XIOCTL_USER_SETKEYS,
+ AR6000_XIOCTL_WMI_SET_KEEPALIVE,
+ AR6000_XIOCTL_WMI_GET_KEEPALIVE, /* 60 */
+ AR6000_XIOCTL_BMI_ROMPATCH_INSTALL,
+ AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL,
+ AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE,
+ AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE,
+ AR6000_XIOCTL_WMI_SET_APPIE,
+ AR6000_XIOCTL_WMI_SET_MGMT_FRM_RX_FILTER,
+ AR6000_XIOCTL_DBGLOG_CFG_MODULE,
+ AR6000_XIOCTL_DBGLOG_GET_DEBUG_LOGS,
+ AR6000_XIOCTL_WMI_SET_WSC_STATUS = 70, /* 70 */
+ AR6000_XIOCTL_WMI_SET_BT_STATUS,
+ AR6000_XIOCTL_WMI_SET_BT_PARAMS,
+ AR6000_XIOCTL_WMI_SET_HOST_SLEEP_MODE,
+ AR6000_XIOCTL_WMI_SET_WOW_MODE,
+ AR6000_XIOCTL_WMI_GET_WOW_LIST,
+ AR6000_XIOCTL_WMI_ADD_WOW_PATTERN,
+ AR6000_XIOCTL_WMI_DEL_WOW_PATTERN,
+ AR6000_XIOCTL_TARGET_INFO,
+ AR6000_XIOCTL_DUMP_HTC_CREDIT_STATE,
+ AR6000_XIOCTL_TRAFFIC_ACTIVITY_CHANGE, /* 80 */
+ AR6000_XIOCTL_WMI_SET_CONNECT_CTRL_FLAGS,
+ AR6000_XIOCTL_WMI_SET_AKMP_PARAMS,
+ AR6000_XIOCTL_WMI_GET_PMKID_LIST,
+ AR6000_XIOCTL_WMI_SET_PMKID_LIST,
+ AR6000_XIOCTL_WMI_SET_PARAMS,
+ AR6000_XIOCTL_WMI_SET_MCAST_FILTER,
+ AR6000_XIOCTL_WMI_DEL_MCAST_FILTER,
+ AR6000_XIOCTL_UNUSED90 = 90, /* 90 */
+ AR6000_XIOCTL_BMI_LZ_STREAM_START,
+ AR6000_XIOCTL_BMI_LZ_DATA,
+ AR6000_XIOCTL_PROF_CFG,
+ AR6000_XIOCTL_PROF_ADDR_SET,
+ AR6000_XIOCTL_PROF_START,
+ AR6000_XIOCTL_PROF_STOP,
+ AR6000_XIOCTL_PROF_COUNT_GET,
+ AR6000_XIOCTL_WMI_ABORT_SCAN,
+ AR6000_XIOCTL_AP_GET_STA_LIST,
+ AR6000_XIOCTL_AP_HIDDEN_SSID, /* 100 */
+ AR6000_XIOCTL_AP_SET_NUM_STA,
+ AR6000_XIOCTL_AP_SET_ACL_MAC,
+ AR6000_XIOCTL_AP_GET_ACL_LIST,
+ AR6000_XIOCTL_AP_COMMIT_CONFIG,
+ IEEE80211_IOCTL_GETWPAIE,
+ AR6000_XIOCTL_AP_CONN_INACT_TIME,
+ AR6000_XIOCTL_AP_PROT_SCAN_TIME,
+ AR6000_XIOCTL_AP_SET_COUNTRY,
+ AR6000_XIOCTL_AP_SET_DTIM,
+ AR6000_XIOCTL_WMI_TARGET_EVENT_REPORT, /* 110 */
+ AR6000_XIOCTL_SET_IP,
+ AR6000_XIOCTL_AP_SET_ACL_POLICY,
+ AR6000_XIOCTL_AP_CTRL_BSS_COMM,
+ AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO,
+ AR6000_XIOCTL_MODULE_DEBUG_SET_MASK,
+ AR6000_XIOCTL_MODULE_DEBUG_GET_MASK,
+ AR6000_XIOCTL_DUMP_RCV_AGGR_STATS,
+ AR6000_XIOCTL_SET_HT_CAP,
+ AR6000_XIOCTL_SET_HT_OP,
+ AR6000_XIOCTL_AP_GET_STAT, /* 120 */
+ AR6000_XIOCTL_SET_TX_SELECT_RATES,
+ AR6000_XIOCTL_SETUP_AGGR,
+ AR6000_XIOCTL_ALLOW_AGGR,
+ AR6000_XIOCTL_AP_GET_HIDDEN_SSID,
+ AR6000_XIOCTL_AP_GET_COUNTRY,
+ AR6000_XIOCTL_AP_GET_WMODE,
+ AR6000_XIOCTL_AP_GET_DTIM,
+ AR6000_XIOCTL_AP_GET_BINTVL,
+ AR6000_XIOCTL_AP_GET_RTS,
+ AR6000_XIOCTL_DELE_AGGR, /* 130 */
+ AR6000_XIOCTL_FETCH_TARGET_REGS,
+ AR6000_XIOCTL_HCI_CMD,
+ AR6000_XIOCTL_ACL_DATA,
+ AR6000_XIOCTL_WLAN_CONN_PRECEDENCE,
+ AR6000_XIOCTL_AP_SET_11BG_RATESET,
+ AR6000_XIOCTL_WMI_SET_AP_PS,
+ AR6000_XIOCTL_WMI_MCAST_FILTER,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_FE_ANT,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_COLOCATED_BT_DEV,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG, /* 140 */
+ AR6000_XIOCTL_WMI_SET_BTCOEX_SCO_CONFIG,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_A2DP_CONFIG,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_ACLCOEX_CONFIG,
+ AR6000_XIOCTL_WMI_SET_BTCOEX_DEBUG,
+ AR6000_XIOCTL_WMI_SET_BT_OPERATING_STATUS,
+ AR6000_XIOCTL_WMI_GET_BTCOEX_CONFIG,
+ AR6000_XIOCTL_WMI_GET_BTCOEX_STATS,
+ AR6000_XIOCTL_WMI_SET_QOS_SUPP,
+ AR6000_XIOCTL_AP_SET_DFS,
+ AR6000_XIOCTL_WMI_P2P_DISCOVER, /* 150 */
+ AR6000_XIOCTL_WMI_P2P_STOP_FIND,
+ AR6000_XIOCTL_WMI_P2P_CANCEL,
+ AR6000_XIOCTL_WMI_P2P_LISTEN,
+ AR6000_XIOCTL_WMI_P2P_GO_NEG,
+ AR6000_XIOCTL_WMI_P2P_AUTH_GO_NEG,
+ AR6000_XIOCTL_WMI_P2P_REJECT,
+ AR6000_XIOCTL_WMI_P2P_CONFIG,
+ AR6000_XIOCTL_WMI_WPS_CONFIG,
+ AR6000_XIOCTL_WMI_P2P_FINDNODE,
+ AR6000_XIOCTL_WMI_P2P_GRP_INIT, /* 160 */
+ AR6000_XIOCTL_WMI_P2P_GRP_FORMATION_DONE,
+ AR6000_XIOCTL_WMI_P2P_INVITE,
+ AR6000_XIOCTL_WMI_P2P_PROV_DISC,
+ AR6000_XIOCTL_WMI_P2P_SET,
+ AR6000_XIOCTL_WMI_P2P_PEER,
+ AR6000_XIOCTL_WMI_P2P_FLUSH,
+ AR6000_XIOCTL_WMI_GET_GO_PARAMS,
+ AR6000_XIOCTL_P2P_AUTH_INVITE,
+ AR6000_XIOCTL_WMI_P2P_GET_IF_ADDR,
+ AR6000_XIOCTL_WMI_P2P_GET_DEV_ADDR, /* 170 */
+ AR6000_XIOCTL_WMI_P2P_SDPD_TX_CMD,
+ AR6000_XIOTCL_WMI_P2P_SD_CANCEL_REQUEST,
+ AR6000_XIOCTL_SET_BT_HW_POWER_STATE,
+ AR6000_XIOCTL_GET_BT_HW_POWER_STATE,
+ AR6000_XIOCTL_GET_WLAN_SLEEP_STATE,
+ AR6000_XIOCTL_WMI_SET_TX_SGI_PARAM,
+ AR6000_XIOCTL_WMI_ENABLE_WAC_PARAM,
+ AR6000_XIOCTL_WAC_SCAN_REPLY,
+ AR6000_XIOCTL_WMI_WAC_CTRL_REQ,
+ AR6000_XIOCTL_WMI_SET_WPA_OFFLOAD_STATE, /* 180 */
+ AR6000_XIOCTL_WMI_SET_PASSPHRASE,
+ AR6000_XIOCTL_BMI_NVRAM_PROCESS,
+ AR6000_XIOCTL_WMI_SET_DIVERSITY_PARAM,
+ AR6000_XIOCTL_WMI_FORCE_ASSERT,
+ AR6000_XIOCTL_WMI_ENABLE_PKTLOG,
+ AR6000_XIOCTL_WMI_DISABLE_PKTLOG,
+ AR6000_XIOCTL_WMI_GET_PKTLOG,
+ AR6000_XIOCTL_AP_ACS_POLICY,
+ AR6000_XIOCTL_TCMD_CMDS,
+ AR6000_XIOCTL_WMI_SET_EXCESS_TX_RETRY_THRES, /* 190 */
+ AR6000_XIOCTL_AP_GET_NUM_STA,
+ AR6000_XIOCTL_SUSPEND_DRIVER,
+ AR6000_XIOCTL_RESUME_DRIVER,
+ AR6000_XIOCTL_GET_SUBMODE,
+ AR6000_XIOCTL_WMI_AP_SET_APSD,
+ AR6000_XIOCTL_TCMD_SETREG,
+ AR6000_XIOCTL_GET_HT_CAP,
+ AR6000_XIOCTL_WMI_GET_P2P_IE,
+ AR6000_XIOCTL_WMI_P2P_GET_OWN_INFO,
+ AR6000_XIOCTL_WMI_LTE_FREQ, /* 200 */
+ AR6000_XIOCTL_WMI_AP_IDLE_CLOSE_TIME,
+ AR6000_XIOCTL_WMI_SEND_FRAME,
+ AR6000_XIOCTL_WMI_GET_WMM,
+} XTND_IOCLTS;
+
+
+
+///* ====BMI Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_BMI_DONE 1
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_DONE)
+// * uses: BMI_DONE
+// */
+//
+//#define AR6000_XIOCTL_BMI_READ_MEMORY 2
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_READ_MEMORY)
+// * UINT32 address
+// * UINT32 length
+// * }
+// * char results[length]
+// * }
+// * uses: BMI_READ_MEMORY
+// */
+//
+//#define AR6000_XIOCTL_BMI_WRITE_MEMORY 3
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_WRITE_MEMORY)
+// * UINT32 address
+// * UINT32 length
+// * char data[length]
+// * uses: BMI_WRITE_MEMORY
+// */
+//
+//#define AR6000_XIOCTL_BMI_EXECUTE 4
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_EXECUTE)
+// * UINT32 TargetAddress
+// * UINT32 parameter
+// * uses: BMI_EXECUTE
+// */
+//
+//#define AR6000_XIOCTL_BMI_SET_APP_START 5
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_SET_APP_START)
+// * UINT32 TargetAddress
+// * uses: BMI_SET_APP_START
+// */
+//
+//#define AR6000_XIOCTL_BMI_READ_SOC_REGISTER 6
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_READ_SOC_REGISTER)
+// * UINT32 TargetAddress, 32-bit aligned
+// * }
+// * UINT32 result
+// * }
+// * uses: BMI_READ_SOC_REGISTER
+// */
+//
+//#define AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER 7
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER)
+// * UINT32 TargetAddress, 32-bit aligned
+// * UINT32 newValue
+// * }
+// * uses: BMI_WRITE_SOC_REGISTER
+// */
+//
+//#define AR6000_XIOCTL_BMI_TEST 8
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_TEST)
+// * UINT32 address
+// * UINT32 length
+// * UINT32 count
+// */
+//
+//
+//
+///* Historical Host-side DataSet support */
+//#define AR6000_XIOCTL_UNUSED9 9
+//#define AR6000_XIOCTL_UNUSED10 10
+//#define AR6000_XIOCTL_UNUSED11 11
+//
+///* ====Misc Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_FORCE_TARGET_RESET 12
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_FORCE_TARGET_RESET)
+// */
+//
+//
+//#ifdef HTC_RAW_INTERFACE
+///* HTC Raw Interface Ioctls */
+//#define AR6000_XIOCTL_HTC_RAW_OPEN 13
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_OPEN)
+// */
+//
+//#define AR6000_XIOCTL_HTC_RAW_CLOSE 14
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_CLOSE)
+// */
+//
+//#define AR6000_XIOCTL_HTC_RAW_READ 15
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_READ)
+// * UINT32 mailboxID
+// * UINT32 length
+// * }
+// * results[length]
+// * }
+// */
+//
+//#define AR6000_XIOCTL_HTC_RAW_WRITE 16
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_HTC_RAW_WRITE)
+// * UINT32 mailboxID
+// * UINT32 length
+// * char buffer[length]
+// */
+//#endif /* HTC_RAW_INTERFACE */
+//
+//#define AR6000_XIOCTL_CHECK_TARGET_READY 17
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_CHECK_TARGET_READY)
+// */
+//
+//
+//
+///* ====GPIO (General Purpose I/O) Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_GPIO_OUTPUT_SET 18
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_OUTPUT_SET)
+// * ar6000_gpio_output_set_cmd_s (see below)
+// * uses: WMIX_GPIO_OUTPUT_SET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_INPUT_GET 19
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_INPUT_GET)
+// * uses: WMIX_GPIO_INPUT_GET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_REGISTER_SET 20
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_REGISTER_SET)
+// * ar6000_gpio_register_cmd_s (see below)
+// * uses: WMIX_GPIO_REGISTER_SET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_REGISTER_GET 21
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_REGISTER_GET)
+// * ar6000_gpio_register_cmd_s (see below)
+// * uses: WMIX_GPIO_REGISTER_GET_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_INTR_ACK 22
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_INTR_ACK)
+// * ar6000_cpio_intr_ack_cmd_s (see below)
+// * uses: WMIX_GPIO_INTR_ACK_CMDID
+// */
+//
+//#define AR6000_XIOCTL_GPIO_INTR_WAIT 23
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_GPIO_INTR_WAIT)
+// */
+//
+//
+//
+///* ====more wireless commands==== */
+//
+//#define AR6000_XIOCTL_SET_ADHOC_BSSID 24
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_ADHOC_BSSID)
+// * WMI_SET_ADHOC_BSSID_CMD setAdHocBssidCmd (see include/wmi.h)
+// */
+//
+//#define AR6000_XIOCTL_SET_OPT_MODE 25
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_OPT_MODE)
+// * WMI_SET_OPT_MODE_CMD setOptModeCmd (see include/wmi.h)
+// * uses: WMI_SET_OPT_MODE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_OPT_SEND_FRAME 26
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_OPT_SEND_FRAME)
+// * WMI_OPT_TX_FRAME_CMD optTxFrameCmd (see include/wmi.h)
+// * uses: WMI_OPT_TX_FRAME_CMDID
+// */
+//
+//#define AR6000_XIOCTL_SET_BEACON_INTVAL 27
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_BEACON_INTVAL)
+// * WMI_BEACON_INT_CMD beaconIntCmd (see include/wmi.h)
+// * uses: WMI_SET_BEACON_INT_CMDID
+// */
+//
+//
+//#define IEEE80211_IOCTL_SETAUTHALG 28
+//
+//
+//#define AR6000_XIOCTL_SET_VOICE_PKT_SIZE 29
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_VOICE_PKT_SIZE)
+// * WMI_SET_VOICE_PKT_SIZE_CMD setVoicePktSizeCmd (see include/wmi.h)
+// * uses: WMI_SET_VOICE_PKT_SIZE_CMDID
+// */
+//
+//
+//#define AR6000_XIOCTL_SET_MAX_SP 30
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_SET_MAX_SP)
+// * WMI_SET_MAX_SP_LEN_CMD maxSPLen(see include/wmi.h)
+// * uses: WMI_SET_MAX_SP_LEN_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_ROAM_TBL 31
+//
+//#define AR6000_XIOCTL_WMI_SET_ROAM_CTRL 32
+//
+//#define AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS 33
+//
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS)
+// * WMI_SET_POWERSAVE_TIMERS_CMD powerSaveTimers(see include/wmi.h)
+// * WMI_SET_POWERSAVE_TIMERS_CMDID
+// */
+//
+//#define AR6000_XIOCTRL_WMI_GET_POWER_MODE 34
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTRL_WMI_GET_POWER_MODE)
+// */
+//
+//#define AR6000_XIOCTRL_WMI_SET_WLAN_STATE 35
+
+typedef enum {
+ WLAN_DISABLED,
+ WLAN_ENABLED
+} AR6000_WLAN_STATE;
+
+///*
+// * arguments:
+// * enable/disable
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_ROAM_DATA 36
+//
+//#define AR6000_XIOCTL_WMI_SETRETRYLIMITS 37
+///*
+// * arguments:
+// * WMI_SET_RETRY_LIMITS_CMD ibssSetRetryLimitsCmd
+// * uses: WMI_SET_RETRY_LIMITS_CMDID
+// */
+//
+//#ifdef CONFIG_HOST_TCMD_SUPPORT
+///* ====extended commands for radio test ==== */
+//
+//#define AR6000_XIOCTL_TCMD_CONT_TX 38
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_CONT_TX)
+// * WMI_TCMD_CONT_TX_CMD contTxCmd (see include/wmi.h)
+// * uses: WMI_TCMD_CONT_TX_CMDID
+// */
+//
+//#define AR6000_XIOCTL_TCMD_CONT_RX 39
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_CONT_RX)
+// * WMI_TCMD_CONT_RX_CMD rxCmd (see include/wmi.h)
+// * uses: WMI_TCMD_CONT_RX_CMDID
+// */
+//
+//#define AR6000_XIOCTL_TCMD_PM 40
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_PM)
+// * WMI_TCMD_PM_CMD pmCmd (see include/wmi.h)
+// * uses: WMI_TCMD_PM_CMDID
+// */
+//
+//#endif /* CONFIG_HOST_TCMD_SUPPORT */
+//
+//#define AR6000_XIOCTL_WMI_STARTSCAN 41
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_STARTSCAN)
+// * UINT8 scanType
+// * UINT8 scanConnected
+// * A_BOOL forceFgScan
+// * uses: WMI_START_SCAN_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SETFIXRATES 42
+//
+//#define AR6000_XIOCTL_WMI_GETFIXRATES 43
+//
+//
+//#define AR6000_XIOCTL_WMI_SET_RSSITHRESHOLD 44
+///*
+// * arguments:
+// * WMI_RSSI_THRESHOLD_PARAMS_CMD thresholdParams (see include/wmi.h)
+// * uses: WMI_RSSI_THRESHOLD_PARAMS_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_CLR_RSSISNR 45
+///*
+// * arguments:
+// * WMI_CLR_RSSISNR_CMD thresholdParams (see include/wmi.h)
+// * uses: WMI_CLR_RSSISNR_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_LQTHRESHOLD 46
+///*
+// * arguments:
+// * WMI_LQ_THRESHOLD_PARAMS_CMD thresholdParams (see include/wmi.h)
+// * uses: WMI_LQ_THRESHOLD_PARAMS_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_RTS 47
+///*
+// * arguments:
+// * WMI_SET_RTS_MODE_CMD (see include/wmi.h)
+// * uses: WMI_SET_RTS_MODE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_LPREAMBLE 48
+//
+//#define AR6000_XIOCTL_WMI_SET_AUTHMODE 49
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_AUTHMODE)
+// * UINT8 mode
+// * uses: WMI_SET_RECONNECT_AUTH_MODE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_REASSOCMODE 50
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_WMM)
+// * UINT8 mode
+// * uses: WMI_SET_WMM_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_WMM 51
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS)
+// * UINT32 frequency
+// * UINT8 threshold
+// */
+//#define AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS 52
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP)
+// * UINT32 cookie
+// */
+//#define AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP 53
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_GET_RD)
+// * UINT32 regDomain
+// */
+//#define AR6000_XIOCTL_WMI_GET_RD 54
+//
+//#define AR6000_XIOCTL_DIAG_READ 55
+//
+//#define AR6000_XIOCTL_DIAG_WRITE 56
+//
+///*
+// * arguments cmd (AR6000_XIOCTL_SET_TXOP)
+// * WMI_TXOP_CFG txopEnable
+// */
+//#define AR6000_XIOCTL_WMI_SET_TXOP 57
+//
+//#ifdef USER_KEYS
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_USER_SETKEYS)
+// * UINT32 keyOpCtrl
+// * uses AR6000_USER_SETKEYS_INFO
+// */
+//#define AR6000_XIOCTL_USER_SETKEYS 58
+//#endif /* USER_KEYS */
+//
+//#define AR6000_XIOCTL_WMI_SET_KEEPALIVE 59
+///*
+// * arguments:
+// * UINT8 cmd (AR6000_XIOCTL_WMI_SET_KEEPALIVE)
+// * UINT8 keepaliveInterval
+// * uses: WMI_SET_KEEPALIVE_CMDID
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_KEEPALIVE 60
+///*
+// * arguments:
+// * UINT8 cmd (AR6000_XIOCTL_WMI_GET_KEEPALIVE)
+// * UINT8 keepaliveInterval
+// * A_BOOL configured
+// * uses: WMI_GET_KEEPALIVE_CMDID
+// */
+//
+///* ====ROM Patching Extended Ioctls==== */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_INSTALL 61
+///*
+// * arguments:
+// * union {
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_INSTALL)
+// * UINT32 ROM Address
+// * UINT32 RAM Address
+// * UINT32 number of bytes
+// * UINT32 activate? (0 or 1)
+// * }
+// * A_UINT32 resulting rompatch ID
+// * }
+// * uses: BMI_ROMPATCH_INSTALL
+// */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL 62
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL)
+// * UINT32 rompatch ID
+// * }
+// * uses: BMI_ROMPATCH_UNINSTALL
+// */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE 63
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE)
+// * UINT32 rompatch count
+// * UINT32 rompatch IDs[rompatch count]
+// * }
+// * uses: BMI_ROMPATCH_ACTIVATE
+// */
+//
+//#define AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE 64
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE)
+// * UINT32 rompatch count
+// * UINT32 rompatch IDs[rompatch count]
+// * }
+// * uses: BMI_ROMPATCH_DEACTIVATE
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_APPIE 65
+///*
+// * arguments:
+// * struct {
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_APPIE)
+// * UINT32 app_frmtype;
+// * UINT32 app_buflen;
+// * UINT8 app_buf[];
+// * }
+// */
+//#define AR6000_XIOCTL_WMI_SET_MGMT_FRM_RX_FILTER 66
+///*
+// * arguments:
+// * A_UINT32 filter_type;
+// */
+//
+//#define AR6000_XIOCTL_DBGLOG_CFG_MODULE 67
+//
+//#define AR6000_XIOCTL_DBGLOG_GET_DEBUG_LOGS 68
+//
+//#define AR6000_XIOCTL_WMI_SET_WSC_STATUS 70
+///*
+// * arguments:
+// * A_UINT32 wsc_status;
+// * (WSC_REG_INACTIVE or WSC_REG_ACTIVE)
+// */
+//
+///*
+// * arguments:
+// * struct {
+// * A_UINT8 streamType;
+// * A_UINT8 status;
+// * }
+// * uses: WMI_SET_BT_STATUS_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_BT_STATUS 71
+//
+///*
+// * arguments:
+// * struct {
+// * A_UINT8 paramType;
+// * union {
+// * A_UINT8 noSCOPkts;
+// * BT_PARAMS_A2DP a2dpParams;
+// * BT_COEX_REGS regs;
+// * };
+// * }
+// * uses: WMI_SET_BT_PARAM_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_BT_PARAMS 72
+//
+//#define AR6000_XIOCTL_WMI_SET_HOST_SLEEP_MODE 73
+//#define AR6000_XIOCTL_WMI_SET_WOW_MODE 74
+//#define AR6000_XIOCTL_WMI_GET_WOW_LIST 75
+//#define AR6000_XIOCTL_WMI_ADD_WOW_PATTERN 76
+//#define AR6000_XIOCTL_WMI_DEL_WOW_PATTERN 77
+//
+//
+//
+//#define AR6000_XIOCTL_TARGET_INFO 78
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TARGET_INFO)
+// * A_UINT32 TargetVersion (returned)
+// * A_UINT32 TargetType (returned)
+// * (See also bmi_msg.h target_ver and target_type)
+// */
+//
+//#define AR6000_XIOCTL_DUMP_HTC_CREDIT_STATE 79
+///*
+// * arguments:
+// * none
+// */
+//
+//#define AR6000_XIOCTL_TRAFFIC_ACTIVITY_CHANGE 80
+///*
+// * This ioctl is used to emulate traffic activity
+// * timeouts. Activity/inactivity will trigger the driver
+// * to re-balance credits.
+// *
+// * arguments:
+// * ar6000_traffic_activity_change
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_CONNECT_CTRL_FLAGS 81
+///*
+// * This ioctl is used to set the connect control flags
+// *
+// * arguments:
+// * A_UINT32 connectCtrlFlags
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_AKMP_PARAMS 82
+///*
+// * This IOCTL sets any Authentication,Key Management and Protection
+// * related parameters. This is used along with the information set in
+// * Connect Command.
+// * Currently this enables Multiple PMKIDs to an AP.
+// *
+// * arguments:
+// * struct {
+// * A_UINT32 akmpInfo;
+// * }
+// * uses: WMI_SET_AKMP_PARAMS_CMD
+// */
+//
+//#define AR6000_XIOCTL_WMI_GET_PMKID_LIST 83
+//
+//#define AR6000_XIOCTL_WMI_SET_PMKID_LIST 84
+///*
+// * This IOCTL is used to set a list of PMKIDs. This list of
+// * PMKIDs is used in the [Re]AssocReq Frame. This list is used
+// * only if the MultiPMKID option is enabled via the
+// * AR6000_XIOCTL_WMI_SET_AKMP_PARAMS IOCTL.
+// *
+// * arguments:
+// * struct {
+// * A_UINT32 numPMKID;
+// * WMI_PMKID pmkidList[WMI_MAX_PMKID_CACHE];
+// * }
+// * uses: WMI_SET_PMKIDLIST_CMD
+// */
+//
+//#define AR6000_XIOCTL_WMI_SET_PARAMS 85
+//#define AR6000_XIOCTL_WMI_SET_MCAST_FILTER 86
+//#define AR6000_XIOCTL_WMI_DEL_MCAST_FILTER 87
+//
+//
+///* Historical DSETPATCH support for INI patches */
+//#define AR6000_XIOCTL_UNUSED90 90
+//
+//
+///* Support LZ-compressed firmware download */
+//#define AR6000_XIOCTL_BMI_LZ_STREAM_START 91
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_LZ_STREAM_START)
+// * UINT32 address
+// * uses: BMI_LZ_STREAM_START
+// */
+//
+//#define AR6000_XIOCTL_BMI_LZ_DATA 92
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_LZ_DATA)
+// * UINT32 length
+// * char data[length]
+// * uses: BMI_LZ_DATA
+// */
+//
+//#define AR6000_XIOCTL_PROF_CFG 93
+///*
+// * arguments:
+// * A_UINT32 period
+// * A_UINT32 nbins
+// */
+//
+//#define AR6000_XIOCTL_PROF_ADDR_SET 94
+///*
+// * arguments:
+// * A_UINT32 Target address
+// */
+//
+//#define AR6000_XIOCTL_PROF_START 95
+//
+//#define AR6000_XIOCTL_PROF_STOP 96
+//
+//#define AR6000_XIOCTL_PROF_COUNT_GET 97
+//
+//#define AR6000_XIOCTL_WMI_ABORT_SCAN 98
+//
+///*
+// * AP mode
+// */
+//#define AR6000_XIOCTL_AP_GET_STA_LIST 99
+//
+//#define AR6000_XIOCTL_AP_HIDDEN_SSID 100
+//
+//#define AR6000_XIOCTL_AP_SET_NUM_STA 101
+//
+//#define AR6000_XIOCTL_AP_SET_ACL_MAC 102
+//
+//#define AR6000_XIOCTL_AP_GET_ACL_LIST 103
+//
+//#define AR6000_XIOCTL_AP_COMMIT_CONFIG 104
+//
+//#define IEEE80211_IOCTL_GETWPAIE 105
+//
+//#define AR6000_XIOCTL_AP_CONN_INACT_TIME 106
+//
+//#define AR6000_XIOCTL_AP_PROT_SCAN_TIME 107
+//
+//#define AR6000_XIOCTL_AP_SET_COUNTRY 108
+//
+//#define AR6000_XIOCTL_AP_SET_DTIM 109
+//
+//
+//
+//
+//#define AR6000_XIOCTL_WMI_TARGET_EVENT_REPORT 110
+//
+//#define AR6000_XIOCTL_SET_IP 111
+//
+//#define AR6000_XIOCTL_AP_SET_ACL_POLICY 112
+//
+//#define AR6000_XIOCTL_AP_CTRL_BSS_COMM 113
+//
+//#define AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO 114
+//
+//#define AR6000_XIOCTL_MODULE_DEBUG_SET_MASK 115
+//
+//#define AR6000_XIOCTL_MODULE_DEBUG_GET_MASK 116
+//
+//#define AR6000_XIOCTL_DUMP_RCV_AGGR_STATS 117
+//
+//#define AR6000_XIOCTL_SET_HT_CAP 118
+//
+//#define AR6000_XIOCTL_SET_HT_OP 119
+//
+//#define AR6000_XIOCTL_AP_GET_STAT 120
+//
+//#define AR6000_XIOCTL_SET_TX_SELECT_RATES 121
+//
+//#define AR6000_XIOCTL_SETUP_AGGR 122
+//
+//#define AR6000_XIOCTL_ALLOW_AGGR 123
+//
+//#define AR6000_XIOCTL_AP_GET_HIDDEN_SSID 124
+//
+//#define AR6000_XIOCTL_AP_GET_COUNTRY 125
+//
+//#define AR6000_XIOCTL_AP_GET_WMODE 126
+//
+//#define AR6000_XIOCTL_AP_GET_DTIM 127
+//
+//#define AR6000_XIOCTL_AP_GET_BINTVL 128
+//
+//#define AR6000_XIOCTL_AP_GET_RTS 129
+//
+//#define AR6000_XIOCTL_DELE_AGGR 130
+//
+//#define AR6000_XIOCTL_FETCH_TARGET_REGS 131
+//
+//#define AR6000_XIOCTL_HCI_CMD 132
+//
+//#define AR6000_XIOCTL_ACL_DATA 133
+//
+//#define AR6000_XIOCTL_WLAN_CONN_PRECEDENCE 134
+//
+//#define AR6000_XIOCTL_AP_SET_11BG_RATESET 135
+//
+//#define AR6000_XIOCTL_WMI_SET_AP_PS 136
+//
+//#define AR6000_XIOCTL_WMI_MCAST_FILTER 137
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_FE_ANT 138
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_COLOCATED_BT_DEV 139
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG 140
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_SCO_CONFIG 141
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_A2DP_CONFIG 142
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_ACLCOEX_CONFIG 143
+//
+//#define AR6000_XIOCTL_WMI_SET_BTCOEX_DEBUG 144
+//
+//#define AR6000_XIOCTL_WMI_SET_BT_OPERATING_STATUS 145
+//
+//#define AR6000_XIOCTL_WMI_GET_BTCOEX_CONFIG 146
+//
+//#define AR6000_XIOCTL_WMI_GET_BTCOEX_STATS 147
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_WMI_SET_QOS_SUPP)
+// * UINT8 mode
+// * uses: WMI_SET_QOS_SUPP_CMDID
+// */
+//#define AR6000_XIOCTL_WMI_SET_QOS_SUPP 148
+//
+//#define AR6000_XIOCTL_AP_SET_DFS 149
+//
+//#ifdef P2P
+//#define AR6000_XIOCTL_WMI_P2P_DISCOVER 150
+//#define AR6000_XIOCTL_WMI_P2P_LISTEN 151
+//#define AR6000_XIOCTL_WMI_P2P_GO_NEG 152
+//#define AR6000_XIOCTL_WMI_P2P_CONFIG 153
+//#define AR6000_XIOCTL_WMI_WPS_CONFIG 154
+//#define AR6000_XIOCTL_WMI_P2P_FINDNODE 155
+//#endif
+//#define AR6000_XIOCTL_SET_BT_HW_POWER_STATE 156
+//#define AR6000_XIOCTL_GET_BT_HW_POWER_STATE 157
+//#define AR6000_XIOCTL_GET_WLAN_SLEEP_STATE 158
+//#define AR6000_XIOCTL_WMI_SET_TX_SGI_PARAM 159
+///*
+// * arguments:
+// * WMI_AP_PS_CMD apPsCmd
+// * uses: WMI_AP_PS_CMDID
+// */
+//
+//
+//// WAC
+//#define AR6000_XIOCTL_WMI_ENABLE_WAC_PARAM 160
+//
+//#define AR6000_XIOCTL_WAC_SCAN_REPLY 161
+//
+//#define AR6000_XIOCTL_WMI_WAC_CTRL_REQ 162
+//
+//#define AR6000_XIOCTL_WMI_SET_WPA_OFFLOAD_STATE 163
+//
+//#define AR6000_XIOCTL_WMI_SET_PASSPHRASE 164
+//
+//#define AR6000_XIOCTL_BMI_NVRAM_PROCESS 165
+//
+//#define AR6000_XIOCTL_AP_ACS_POLICY 166
+//
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_BMI_NVRAM_PROCESS)
+// * UINT8 name[BMI_NVRAM_SEG_NAME_SZ]
+// * uses: BMI_NVRAM_PROCESS
+// */
+//
+//
+//#ifdef CONFIG_HOST_TCMD_SUPPORT
+///* ====additional extended commands for radio test ==== */
+//
+//#define AR6000_XIOCTL_TCMD_CMDS 167
+///*
+// * arguments:
+// * UINT32 cmd (AR6000_XIOCTL_TCMD_CMDS)
+// * WMI_TCMD_CMDS_CMD cmdsCmd (see include/wmi.h)
+// * uses: WMI_TCMD_CMDS_CMDID
+// */
+//
+//#endif //ifdef CONFIG_HOST_TCMD_SUPPORT
+//
+//#define AR6000_XIOCTL_WMI_SET_DIVERSITY_PARAM 168
+//
+//#define AR6000_XIOCTL_WMI_FORCE_ASSERT 169
+//
+//#define AR6000_XIOCTL_WMI_SET_EXCESS_TX_RETRY_THRES 170
+//
+//#define AR6000_XIOCTL_AP_GET_NUM_STA 171
+//
+//#define AR6000_XIOCTL_SUSPEND_DRIVER 172
+//
+//#define AR6000_XIOCTL_RESUME_DRIVER 173
+
+/* used by AR6000_IOCTL_WMI_GETREV */
+struct ar6000_version {
+ A_UINT32 host_ver;
+ A_UINT32 target_ver;
+ A_UINT32 wlan_ver;
+ A_UINT32 abi_ver;
+ A_UINT32 targetconf_ver;
+};
+
+/* used by AR6000_IOCTL_WMI_GET_QOS_QUEUE */
+struct ar6000_queuereq {
+ A_UINT8 trafficClass;
+ A_UINT16 activeTsids;
+};
+
+/* used by AR6000_IOCTL_WMI_GET_TARGET_STATS */
+typedef struct targetStats_t {
+ A_UINT64 tx_packets;
+ A_UINT64 tx_bytes;
+ A_UINT64 tx_unicast_pkts;
+ A_UINT64 tx_unicast_bytes;
+ A_UINT64 tx_multicast_pkts;
+ A_UINT64 tx_multicast_bytes;
+ A_UINT64 tx_broadcast_pkts;
+ A_UINT64 tx_broadcast_bytes;
+ A_UINT64 tx_rts_success_cnt;
+ A_UINT64 tx_packet_per_ac[4];
+
+ A_UINT64 tx_errors;
+ A_UINT64 tx_failed_cnt;
+ A_UINT64 tx_retry_cnt;
+ A_UINT64 tx_mult_retry_cnt;
+ A_UINT64 tx_rts_fail_cnt;
+
+ A_UINT64 rx_packets;
+ A_UINT64 rx_bytes;
+ A_UINT64 rx_unicast_pkts;
+ A_UINT64 rx_unicast_bytes;
+ A_UINT64 rx_multicast_pkts;
+ A_UINT64 rx_multicast_bytes;
+ A_UINT64 rx_broadcast_pkts;
+ A_UINT64 rx_broadcast_bytes;
+ A_UINT64 rx_fragment_pkt;
+
+ A_UINT64 rx_errors;
+ A_UINT64 rx_crcerr;
+ A_UINT64 rx_key_cache_miss;
+ A_UINT64 rx_decrypt_err;
+ A_UINT64 rx_duplicate_frames;
+
+ A_UINT64 tkip_local_mic_failure;
+ A_UINT64 tkip_counter_measures_invoked;
+ A_UINT64 tkip_replays;
+ A_UINT64 tkip_format_errors;
+ A_UINT64 ccmp_format_errors;
+ A_UINT64 ccmp_replays;
+
+ A_UINT64 power_save_failure_cnt;
+
+ A_UINT64 cs_bmiss_cnt;
+ A_UINT64 cs_lowRssi_cnt;
+ A_UINT64 cs_connect_cnt;
+ A_UINT64 cs_disconnect_cnt;
+
+ A_INT32 tx_unicast_rate;
+ A_INT32 rx_unicast_rate;
+
+ A_UINT32 lq_val;
+
+ A_UINT32 wow_num_pkts_dropped;
+ A_UINT16 wow_num_events_discarded;
+
+ A_INT16 noise_floor_calibation;
+ A_INT16 cs_rssi;
+ A_INT16 cs_aveBeacon_rssi;
+ A_UINT8 cs_aveBeacon_snr;
+ A_UINT8 cs_lastRoam_msec;
+ A_UINT8 cs_snr;
+
+ A_UINT8 wow_num_host_pkt_wakeups;
+ A_UINT8 wow_num_host_event_wakeups;
+
+ A_UINT32 arp_received;
+ A_UINT32 arp_matched;
+ A_UINT32 arp_replied;
+}TARGET_STATS;
+
+typedef struct targetStats_cmd_t {
+ TARGET_STATS targetStats;
+ int clearStats;
+} TARGET_STATS_CMD;
+
+/* used by AR6000_XIOCTL_USER_SETKEYS */
+
+/*
+ * Setting this bit to 1 doesnot initialize the RSC on the firmware
+ */
+#define AR6000_XIOCTL_USER_SETKEYS_RSC_CTRL 1
+#define AR6000_USER_SETKEYS_RSC_UNCHANGED 0x00000002
+
+typedef struct {
+ A_UINT32 keyOpCtrl; /* Bit Map of Key Mgmt Ctrl Flags */
+} AR6000_USER_SETKEYS_INFO;
+
+
+/* used by AR6000_XIOCTL_GPIO_OUTPUT_SET */
+struct ar6000_gpio_output_set_cmd_s {
+ A_UINT32 set_mask;
+ A_UINT32 clear_mask;
+ A_UINT32 enable_mask;
+ A_UINT32 disable_mask;
+};
+
+/*
+ * used by AR6000_XIOCTL_GPIO_REGISTER_GET and AR6000_XIOCTL_GPIO_REGISTER_SET
+ */
+struct ar6000_gpio_register_cmd_s {
+ A_UINT32 gpioreg_id;
+ A_UINT32 value;
+};
+
+/* used by AR6000_XIOCTL_GPIO_INTR_ACK */
+struct ar6000_gpio_intr_ack_cmd_s {
+ A_UINT32 ack_mask;
+};
+
+/* used by AR6000_XIOCTL_GPIO_INTR_WAIT */
+struct ar6000_gpio_intr_wait_cmd_s {
+ A_UINT32 intr_mask;
+ A_UINT32 input_values;
+};
+
+/* used by the AR6000_XIOCTL_DBGLOG_CFG_MODULE */
+typedef struct ar6000_dbglog_module_config_s {
+ A_UINT32 valid;
+ A_UINT16 mmask;
+ A_UINT16 tsr;
+ A_BOOL rep;
+ A_UINT16 size;
+} DBGLOG_MODULE_CONFIG;
+
+typedef struct user_rssi_thold_t {
+ A_INT16 tag;
+ A_INT16 rssi;
+} USER_RSSI_THOLD;
+
+typedef struct user_rssi_params_t {
+ A_UINT8 weight;
+ A_UINT32 pollTime;
+ USER_RSSI_THOLD tholds[12];
+} USER_RSSI_PARAMS;
+
+typedef struct ar6000_get_btcoex_config_cmd_t{
+ A_UINT32 btProfileType;
+ A_UINT32 linkId;
+ }AR6000_GET_BTCOEX_CONFIG_CMD;
+
+typedef struct ar6000_btcoex_config_t {
+ AR6000_GET_BTCOEX_CONFIG_CMD configCmd;
+ A_UINT32 * configEvent;
+} AR6000_BTCOEX_CONFIG;
+
+typedef struct ar6000_btcoex_stats_t {
+ A_UINT32 * statsEvent;
+ }AR6000_BTCOEX_STATS;
+/*
+ * Host driver may have some config parameters. Typically, these
+ * config params are one time config parameters. These could
+ * correspond to any of the underlying modules. Host driver exposes
+ * an api for the underlying modules to get this config.
+ */
+#define AR6000_DRIVER_CFG_BASE 0x8000
+
+/* Should driver perform wlan node caching? */
+#define AR6000_DRIVER_CFG_GET_WLANNODECACHING 0x8001
+/*Should we log raw WMI msgs */
+#define AR6000_DRIVER_CFG_LOG_RAW_WMI_MSGS 0x8002
+
+/* used by AR6000_XIOCTL_DIAG_READ & AR6000_XIOCTL_DIAG_WRITE */
+struct ar6000_diag_window_cmd_s {
+ unsigned int addr;
+ unsigned int value;
+};
+
+
+struct ar6000_traffic_activity_change {
+ A_UINT32 StreamID; /* stream ID to indicate activity change */
+ A_UINT32 Active; /* active (1) or inactive (0) */
+};
+
+/* Used with AR6000_XIOCTL_PROF_COUNT_GET */
+struct prof_count_s {
+ A_UINT32 addr; /* bin start address */
+ A_UINT32 count; /* hit count */
+};
+
+
+/* used by AR6000_XIOCTL_MODULE_DEBUG_SET_MASK */
+/* AR6000_XIOCTL_MODULE_DEBUG_GET_MASK */
+/* AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO */
+struct drv_debug_module_s {
+ A_CHAR modulename[128]; /* name of module */
+ A_UINT32 mask; /* new mask to set .. or .. current mask */
+};
+
+/* used by AR6000_XIOCTL_P2P_AUTH_INVITE */
+#define ATH_MAC_LEN 6
+typedef PREPACK struct {
+ A_UINT32 auth;
+ A_UINT8 peer_addr[ATH_MAC_LEN];
+}POSTPACK P2P_AUTH_INVITE_CMD;
+
+/* All HCI related rx events are sent up to the host app
+ * via a wmi event id. It can contain ACL data or HCI event,
+ * based on which it will be de-multiplexed.
+ */
+typedef enum {
+ PAL_HCI_EVENT = 0,
+ PAL_HCI_RX_DATA,
+} WMI_PAL_EVENT_INFO;
+
+
+#ifdef __cplusplus
+}
+#endif
+#endif
diff --git a/host/os/linux/include/athendpack_linux.h b/host/os/linux/include/athendpack_linux.h
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/host/os/linux/include/athendpack_linux.h
diff --git a/host/os/linux/include/athstartpack_linux.h b/host/os/linux/include/athstartpack_linux.h
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/host/os/linux/include/athstartpack_linux.h
diff --git a/host/os/linux/include/athtypes_linux.h b/host/os/linux/include/athtypes_linux.h
new file mode 100644
index 0000000..b008fef
--- /dev/null
+++ b/host/os/linux/include/athtypes_linux.h
@@ -0,0 +1,53 @@
+//------------------------------------------------------------------------------
+//
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _ATHTYPES_LINUX_H_
+#define _ATHTYPES_LINUX_H_
+
+#ifdef __KERNEL__
+#include <linux/types.h>
+#else
+#include <sys/types.h>
+#endif
+
+typedef int8_t A_INT8;
+typedef int16_t A_INT16;
+typedef int32_t A_INT32;
+typedef int64_t A_INT64;
+
+typedef u_int8_t A_UINT8;
+typedef u_int16_t A_UINT16;
+typedef u_int32_t A_UINT32;
+typedef u_int64_t A_UINT64;
+
+typedef int A_BOOL;
+typedef char A_CHAR;
+typedef unsigned char A_UCHAR;
+typedef unsigned long A_ATH_TIMER;
+
+#endif /* _ATHTYPES_LINUX_H_ */
+
diff --git a/host/os/linux/include/cfg80211.h b/host/os/linux/include/cfg80211.h
new file mode 100644
index 0000000..eeab404
--- /dev/null
+++ b/host/os/linux/include/cfg80211.h
@@ -0,0 +1,50 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _AR6K_CFG80211_H_
+#define _AR6K_CFG80211_H_
+
+struct wireless_dev *ar6k_cfg80211_init(struct device *dev);
+void ar6k_cfg80211_deinit(AR_SOFTC_DEV_T *arPriv);
+
+void ar6k_cfg80211_scanComplete_event(AR_SOFTC_DEV_T *arPriv, A_STATUS status);
+
+void ar6k_cfg80211_connect_event(AR_SOFTC_DEV_T *arPriv, A_UINT16 channel,
+ A_UINT8 *bssid, A_UINT16 listenInterval,
+ A_UINT16 beaconInterval,NETWORK_TYPE networkType,
+ A_UINT8 beaconIeLen, A_UINT8 assocReqLen,
+ A_UINT8 assocRespLen, A_UINT8 *assocInfo);
+
+void ar6k_cfg80211_disconnect_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 reason,
+ A_UINT8 *bssid, A_UINT8 assocRespLen,
+ A_UINT8 *assocInfo, A_UINT16 protocolReasonStatus);
+
+void ar6k_cfg80211_tkip_micerr_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 keyid, A_BOOL ismcast);
+
+#endif /* _AR6K_CFG80211_H_ */
+
+
+
+
+
+
diff --git a/host/os/linux/include/config_linux.h b/host/os/linux/include/config_linux.h
new file mode 100644
index 0000000..872f31e
--- /dev/null
+++ b/host/os/linux/include/config_linux.h
@@ -0,0 +1,71 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _CONFIG_LINUX_H_
+#define _CONFIG_LINUX_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include <linux/version.h>
+
+/*
+ * Host-side GPIO support is optional.
+ * If run-time access to GPIO pins is not required, then
+ * this should be changed to #undef.
+ */
+#define CONFIG_HOST_GPIO_SUPPORT
+
+/*
+ * Host side Test Command support
+ * Note: when HCI SDIO is enabled, a low stack IRQ or statck overflow is
+ * hit on FC10. So with HCI SDIO, minimize the stack allocation by
+ * mutually exclude TCMD_SUPPORT, which allocates large buffers
+ * in AR_TCMD_RESP in AR_SOFTC_T
+ *
+ */
+#ifndef HCI_TRANSPORT_SDIO
+#define CONFIG_HOST_TCMD_SUPPORT
+#endif
+
+/* Host-side support for Target-side profiling */
+#undef CONFIG_TARGET_PROFILE_SUPPORT
+/*DIX OFFLOAD SUPPORT*/
+/*#define DIX_RX_OFFLOAD*/
+/*#define DIX_TX_OFFLOAD*/
+
+/* IP/TCP checksum offload */
+/* Checksum offload is currently not supported for 64 bit platforms */
+#ifndef __LP64__
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,25)
+#define CONFIG_CHECKSUM_OFFLOAD
+#endif
+#endif /* __LP64__ */
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
+
diff --git a/host/os/linux/include/debug_linux.h b/host/os/linux/include/debug_linux.h
new file mode 100644
index 0000000..c9ee7f2
--- /dev/null
+++ b/host/os/linux/include/debug_linux.h
@@ -0,0 +1,51 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _DEBUG_LINUX_H_
+#define _DEBUG_LINUX_H_
+
+ /* macro to remove parens */
+#define ATH_PRINTX_ARG(arg...) arg
+
+#ifdef DEBUG
+ /* NOTE: the AR_DEBUG_PRINTF macro is defined here to handle special handling of variable arg macros
+ * which may be compiler dependent. */
+#define AR_DEBUG_PRINTF(mask, args) do { \
+ if (GET_ATH_MODULE_DEBUG_VAR_MASK(ATH_MODULE_NAME) & (mask)) { \
+ A_LOGGER(mask, ATH_MODULE_NAME, ATH_PRINTX_ARG args); \
+ } \
+} while (0)
+#else
+ /* on non-debug builds, keep in error and warning messages in the driver, all other
+ * message tracing will get compiled out */
+#define AR_DEBUG_PRINTF(mask, args) \
+ if ((mask) & (ATH_DEBUG_ERR | ATH_DEBUG_WARN)) { A_PRINTF(ATH_PRINTX_ARG args); }
+
+#endif
+
+ /* compile specific macro to get the function name string */
+#define _A_FUNCNAME_ __func__
+
+
+#endif /* _DEBUG_LINUX_H_ */
+
diff --git a/host/os/linux/include/export_hci_transport.h b/host/os/linux/include/export_hci_transport.h
new file mode 100644
index 0000000..c150680
--- /dev/null
+++ b/host/os/linux/include/export_hci_transport.h
@@ -0,0 +1,76 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2009-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// HCI bridge implementation
+//
+// Author(s): ="Atheros"
+//==============================================================================
+
+#include "hci_transport_api.h"
+#include "common_drv.h"
+
+extern HCI_TRANSPORT_HANDLE (*_HCI_TransportAttach)(void *HTCHandle, HCI_TRANSPORT_CONFIG_INFO *pInfo);
+extern void (*_HCI_TransportDetach)(HCI_TRANSPORT_HANDLE HciTrans);
+extern A_STATUS (*_HCI_TransportAddReceivePkts)(HCI_TRANSPORT_HANDLE HciTrans, HTC_PACKET_QUEUE *pQueue);
+extern A_STATUS (*_HCI_TransportSendPkt)(HCI_TRANSPORT_HANDLE HciTrans, HTC_PACKET *pPacket, A_BOOL Synchronous);
+extern void (*_HCI_TransportStop)(HCI_TRANSPORT_HANDLE HciTrans);
+extern A_STATUS (*_HCI_TransportStart)(HCI_TRANSPORT_HANDLE HciTrans);
+extern A_STATUS (*_HCI_TransportEnableDisableAsyncRecv)(HCI_TRANSPORT_HANDLE HciTrans, A_BOOL Enable);
+extern A_STATUS (*_HCI_TransportRecvHCIEventSync)(HCI_TRANSPORT_HANDLE HciTrans,
+ HTC_PACKET *pPacket,
+ int MaxPollMS);
+extern A_STATUS (*_HCI_TransportSetBaudRate)(HCI_TRANSPORT_HANDLE HciTrans, A_UINT32 Baud);
+extern A_STATUS (*_HCI_TransportEnablePowerMgmt)(HCI_TRANSPORT_HANDLE HciTrans, A_BOOL Enable);
+
+
+#define HCI_TransportAttach(HTCHandle, pInfo) \
+ _HCI_TransportAttach((HTCHandle), (pInfo))
+#define HCI_TransportDetach(HciTrans) \
+ _HCI_TransportDetach(HciTrans)
+#define HCI_TransportAddReceivePkts(HciTrans, pQueue) \
+ _HCI_TransportAddReceivePkts((HciTrans), (pQueue))
+#define HCI_TransportSendPkt(HciTrans, pPacket, Synchronous) \
+ _HCI_TransportSendPkt((HciTrans), (pPacket), (Synchronous))
+#define HCI_TransportStop(HciTrans) \
+ _HCI_TransportStop((HciTrans))
+#define HCI_TransportStart(HciTrans) \
+ _HCI_TransportStart((HciTrans))
+#define HCI_TransportEnableDisableAsyncRecv(HciTrans, Enable) \
+ _HCI_TransportEnableDisableAsyncRecv((HciTrans), (Enable))
+#define HCI_TransportRecvHCIEventSync(HciTrans, pPacket, MaxPollMS) \
+ _HCI_TransportRecvHCIEventSync((HciTrans), (pPacket), (MaxPollMS))
+#define HCI_TransportSetBaudRate(HciTrans, Baud) \
+ _HCI_TransportSetBaudRate((HciTrans), (Baud))
+#define HCI_TransportEnablePowerMgmt(HciTrans, Enable) \
+ _HCI_TransportEnablePowerMgmt((HciTrans), (Enable))
+
+
+extern A_STATUS ar6000_register_hci_transport(HCI_TRANSPORT_CALLBACKS *hciTransCallbacks);
+
+extern A_STATUS ar6000_get_hif_dev(HIF_DEVICE *device, void *config);
+
+extern A_STATUS ar6000_set_uart_config(HIF_DEVICE *hifDevice, A_UINT32 scale, A_UINT32 step);
+
+/* get core clock register settings
+ * data: 0 - 40/44MHz
+ * 1 - 80/88MHz
+ * where (5G band/2.4G band)
+ * assume 2.4G band for now
+ */
+extern A_STATUS ar6000_get_core_clock_config(HIF_DEVICE *hifDevice, A_UINT32 *data);
diff --git a/host/os/linux/include/ieee80211_ioctl.h b/host/os/linux/include/ieee80211_ioctl.h
new file mode 100644
index 0000000..7144412
--- /dev/null
+++ b/host/os/linux/include/ieee80211_ioctl.h
@@ -0,0 +1,181 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _IEEE80211_IOCTL_H_
+#define _IEEE80211_IOCTL_H_
+
+#include <linux/version.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+ * Extracted from the MADWIFI net80211/ieee80211_ioctl.h
+ */
+
+/*
+ * WPA/RSN get/set key request. Specify the key/cipher
+ * type and whether the key is to be used for sending and/or
+ * receiving. The key index should be set only when working
+ * with global keys (use IEEE80211_KEYIX_NONE for ``no index'').
+ * Otherwise a unicast/pairwise key is specified by the bssid
+ * (on a station) or mac address (on an ap). They key length
+ * must include any MIC key data; otherwise it should be no
+ more than IEEE80211_KEYBUF_SIZE.
+ */
+struct ieee80211req_key {
+ u_int8_t ik_type; /* key/cipher type */
+ u_int8_t ik_pad;
+ u_int16_t ik_keyix; /* key index */
+ u_int8_t ik_keylen; /* key length in bytes */
+ u_int8_t ik_flags;
+#define IEEE80211_KEY_XMIT 0x01
+#define IEEE80211_KEY_RECV 0x02
+#define IEEE80211_KEY_DEFAULT 0x80 /* default xmit key */
+ u_int8_t ik_macaddr[IEEE80211_ADDR_LEN];
+ u_int64_t ik_keyrsc; /* key receive sequence counter */
+ u_int64_t ik_keytsc; /* key transmit sequence counter */
+ u_int8_t ik_keydata[IEEE80211_KEYBUF_SIZE+IEEE80211_MICBUF_SIZE];
+};
+/*
+ * Delete a key either by index or address. Set the index
+ * to IEEE80211_KEYIX_NONE when deleting a unicast key.
+ */
+struct ieee80211req_del_key {
+ u_int8_t idk_keyix; /* key index */
+ u_int8_t idk_macaddr[IEEE80211_ADDR_LEN];
+};
+/*
+ * MLME state manipulation request. IEEE80211_MLME_ASSOC
+ * only makes sense when operating as a station. The other
+ * requests can be used when operating as a station or an
+ * ap (to effect a station).
+ */
+struct ieee80211req_mlme {
+ u_int8_t im_op; /* operation to perform */
+#define IEEE80211_MLME_ASSOC 1 /* associate station */
+#define IEEE80211_MLME_DISASSOC 2 /* disassociate station */
+#define IEEE80211_MLME_DEAUTH 3 /* deauthenticate station */
+#define IEEE80211_MLME_AUTHORIZE 4 /* authorize station */
+#define IEEE80211_MLME_UNAUTHORIZE 5 /* unauthorize station */
+ u_int16_t im_reason; /* 802.11 reason code */
+ u_int8_t im_macaddr[IEEE80211_ADDR_LEN];
+};
+
+struct ieee80211req_addpmkid {
+ u_int8_t pi_bssid[IEEE80211_ADDR_LEN];
+ u_int8_t pi_enable;
+ u_int8_t pi_pmkid[16];
+};
+
+#define AUTH_ALG_OPEN_SYSTEM 0x01
+#define AUTH_ALG_SHARED_KEY 0x02
+#define AUTH_ALG_LEAP 0x04
+
+struct ieee80211req_authalg {
+ u_int8_t auth_alg;
+};
+
+/*
+ * Request to add an IE to a Management Frame
+ */
+enum{
+ IEEE80211_APPIE_FRAME_BEACON = 0,
+ IEEE80211_APPIE_FRAME_PROBE_REQ = 1,
+ IEEE80211_APPIE_FRAME_PROBE_RESP = 2,
+ IEEE80211_APPIE_FRAME_ASSOC_REQ = 3,
+ IEEE80211_APPIE_FRAME_ASSOC_RESP = 4,
+ IEEE80211_APPIE_NUM_OF_FRAME = 5
+};
+
+/*
+ * The Maximum length of the IE that can be added to a Management frame
+ */
+#define IEEE80211_APPIE_FRAME_MAX_LEN 200
+
+struct ieee80211req_getset_appiebuf {
+ u_int32_t app_frmtype; /* management frame type for which buffer is added */
+ u_int32_t app_buflen; /*application supplied buffer length */
+ u_int8_t app_buf[];
+};
+
+/*
+ * The following definitions are used by an application to set filter
+ * for receiving management frames
+ */
+enum {
+ IEEE80211_FILTER_TYPE_BEACON = 0x1,
+ IEEE80211_FILTER_TYPE_PROBE_REQ = 0x2,
+ IEEE80211_FILTER_TYPE_PROBE_RESP = 0x4,
+ IEEE80211_FILTER_TYPE_ASSOC_REQ = 0x8,
+ IEEE80211_FILTER_TYPE_ASSOC_RESP = 0x10,
+ IEEE80211_FILTER_TYPE_AUTH = 0x20,
+ IEEE80211_FILTER_TYPE_DEAUTH = 0x40,
+ IEEE80211_FILTER_TYPE_DISASSOC = 0x80,
+ IEEE80211_FILTER_TYPE_ALL = 0xFF /* used to check the valid filter bits */
+};
+
+struct ieee80211req_set_filter {
+ u_int32_t app_filterype; /* management frame filter type */
+};
+
+enum {
+ IEEE80211_PARAM_AUTHMODE = 3, /* Authentication Mode */
+ IEEE80211_PARAM_MCASTCIPHER = 5,
+ IEEE80211_PARAM_MCASTKEYLEN = 6, /* multicast key length */
+ IEEE80211_PARAM_UCASTCIPHER = 8,
+ IEEE80211_PARAM_UCASTKEYLEN = 9, /* unicast key length */
+ IEEE80211_PARAM_WPA = 10, /* WPA mode (0,1,2) */
+ IEEE80211_PARAM_ROAMING = 12, /* roaming mode */
+ IEEE80211_PARAM_PRIVACY = 13, /* privacy invoked */
+ IEEE80211_PARAM_COUNTERMEASURES = 14, /* WPA/TKIP countermeasures */
+ IEEE80211_PARAM_DROPUNENCRYPTED = 15, /* discard unencrypted frames */
+ IEEE80211_PARAM_WAPI = 16, /* WAPI policy from wapid */
+};
+
+/*
+ * Values for IEEE80211_PARAM_WPA
+ */
+#define WPA_MODE_WPA1 1
+#define WPA_MODE_WPA2 2
+#define WPA_MODE_AUTO 3
+#define WPA_MODE_NONE 4
+
+struct ieee80211req_wpaie {
+ u_int8_t wpa_macaddr[IEEE80211_ADDR_LEN];
+ u_int8_t wpa_ie[IEEE80211_MAX_IE];
+ u_int8_t rsn_ie[IEEE80211_MAX_IE];
+};
+
+#ifndef IW_ENCODE_ALG_PMK
+#define IW_ENCODE_ALG_PMK 4
+#endif
+#ifndef IW_ENCODE_ALG_KRK
+#define IW_ENCODE_ALG_KRK 6
+#endif
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _IEEE80211_IOCTL_H_ */
diff --git a/host/os/linux/include/osapi_linux.h b/host/os/linux/include/osapi_linux.h
new file mode 100644
index 0000000..bd42ad7
--- /dev/null
+++ b/host/os/linux/include/osapi_linux.h
@@ -0,0 +1,446 @@
+//------------------------------------------------------------------------------
+// This file contains the definitions of the basic atheros data types.
+// It is used to map the data types in atheros files to a platform specific
+// type.
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _OSAPI_LINUX_H_
+#define _OSAPI_LINUX_H_
+
+#ifdef __KERNEL__
+
+#include <linux/version.h>
+#include <linux/types.h>
+#include <linux/kernel.h>
+#include <linux/string.h>
+#include <linux/skbuff.h>
+#include <linux/netdevice.h>
+#include <linux/device.h>
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24)
+#include <linux/ethtool.h>
+#endif
+/*************************************/
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)
+#include <linux/jiffies.h>
+#endif
+#include <linux/semaphore.h>
+#include <linux/sched.h>
+
+#include <linux/timer.h>
+#include <linux/delay.h>
+#include <linux/wait.h>
+#ifdef KERNEL_2_4
+#include <asm/arch/irq.h>
+#include <asm/irq.h>
+#endif
+
+#include <linux/cache.h>
+
+#ifdef __GNUC__
+#define __ATTRIB_PACK __attribute__ ((packed))
+#define __ATTRIB_PRINTF __attribute__ ((format (printf, 1, 2)))
+#define __ATTRIB_NORETURN __attribute__ ((noreturn))
+#ifndef INLINE
+#define INLINE __inline__
+#endif
+#else /* Not GCC */
+#define __ATTRIB_PACK
+#define __ATTRIB_PRINTF
+#define __ATTRIB_NORETURN
+#ifndef INLINE
+#define INLINE __inline
+#endif
+#endif /* End __GNUC__ */
+
+#define PREPACK
+#define POSTPACK __ATTRIB_PACK
+
+/*
+ * Endianes macros
+ */
+#define A_BE2CPU8(x) ntohb(x)
+#define A_BE2CPU16(x) ntohs(x)
+#define A_BE2CPU32(x) ntohl(x)
+
+#define A_LE2CPU8(x) (x)
+#define A_LE2CPU16(x) (x)
+#define A_LE2CPU32(x) (x)
+
+#define A_CPU2BE8(x) htonb(x)
+#define A_CPU2BE16(x) htons(x)
+#define A_CPU2BE32(x) htonl(x)
+
+#define A_MEMCPY(dst, src, len) memcpy((A_UINT8 *)(dst), (src), (len))
+#define A_MEMZERO(addr, len) memset(addr, 0, len)
+#define A_MEMCMP(addr1, addr2, len) memcmp((addr1), (addr2), (len))
+
+#ifdef AR6K_ALLOC_DEBUG
+#define a_meminfo_add(p, s) __a_meminfo_add(p, s, __func__, __LINE)
+void __a_meminfo_add(void *ptr, size_t msize, const char *func, int lineno);
+void a_meminfo_del(void *ptr);
+void* a_mem_alloc(size_t msize, int type, const char *func, int lineno);
+void a_mem_free(void *ptr);
+void a_meminfo_report(int clear);
+A_BOOL a_meminfo_find(void *ptr);
+#define A_MALLOC(size) a_mem_alloc((size), GFP_KERNEL, __func__, __LINE__)
+#define A_MALLOC_NOWAIT(size) a_mem_alloc((size), GFP_ATOMIC, __func__, __LINE__)
+#define A_FREE(addr) a_mem_free(addr)
+#define A_FREE_NOWAIT(addr) a_mem_free(addr)
+#define A_NETIF_RX(skb) do { a_meminfo_del(skb); netif_rx(skb); } while (0)
+#define A_NETIF_RX_NI(skb) do { a_meminfo_del(skb); netif_rx_ni(skb); } while (0)
+#define A_MEM_HELPER_INIT(void)
+#define A_MEM_HELPER_DESTROY(void)
+#else
+#define a_meminfo_report(_c)
+#define A_MALLOC(size) kmalloc((size), GFP_KERNEL)
+#define A_MALLOC_NOWAIT(size) kmalloc((size), GFP_ATOMIC)
+#define A_FREE(addr) kfree(addr);addr=NULL;
+#define A_FREE_NOWAIT(addr) kfree(addr);addr=NULL;
+#define A_NETIF_RX(skb) netif_rx(skb)
+#define A_NETIF_RX_NI(skb) netif_rx_ni(skb)
+#endif
+
+#if defined(ANDROID_ENV) && defined(CONFIG_ANDROID_LOGGER)
+extern unsigned int enablelogcat;
+extern int android_logger_lv(void* module, int mask);
+enum logidx { LOG_MAIN_IDX = 0 };
+extern int logger_write(const enum logidx idx,
+ const unsigned char prio,
+ const char __kernel * const tag,
+ const char __kernel * const fmt,
+ ...);
+#define A_ANDROID_PRINTF(mask, module, tags, args...) do { \
+ if (enablelogcat) \
+ logger_write(LOG_MAIN_IDX, android_logger_lv(module, mask), tags, args); \
+ else \
+ printk(KERN_ALERT args); \
+} while (0)
+#ifdef DEBUG
+#define A_LOGGER_MODULE_NAME(x) #x
+#define A_LOGGER(mask, mod, args...) \
+ A_ANDROID_PRINTF(mask, &GET_ATH_MODULE_DEBUG_VAR_NAME(mod), "ar6k_" A_LOGGER_MODULE_NAME(mod), args);
+#endif
+#define A_PRINTF(args...) A_ANDROID_PRINTF(ATH_DEBUG_INFO, NULL, "ar6k_driver", args)
+#else
+#define A_LOGGER(mask, mod, args...) printk(KERN_ALERT args)
+#define A_PRINTF(args...) printk(KERN_ALERT args)
+#endif /* ANDROID */
+#define A_PRINTF_LOG(args...) printk(args)
+#define A_SPRINTF(buf, args...) sprintf (buf, args)
+
+/* Mutual Exclusion */
+typedef spinlock_t A_MUTEX_T;
+#define A_MUTEX_INIT(mutex) spin_lock_init(mutex)
+#define A_MUTEX_LOCK(mutex) spin_lock_bh(mutex)
+#define A_MUTEX_UNLOCK(mutex) spin_unlock_bh(mutex)
+#define A_IS_MUTEX_VALID(mutex) TRUE /* okay to return true, since A_MUTEX_DELETE does nothing */
+#define A_MUTEX_DELETE(mutex) /* spin locks are not kernel resources so nothing to free.. */
+
+/* Get current time in ms adding a constant offset (in ms) */
+#define A_GET_MS(offset) \
+ (((jiffies / HZ) * 1000) + (offset))
+
+/*
+ * Timer Functions
+ */
+#define A_MDELAY(msecs) mdelay(msecs)
+typedef struct timer_list A_TIMER;
+
+#define A_INIT_TIMER(pTimer, pFunction, pArg) do { \
+ init_timer(pTimer); \
+ (pTimer)->function = (pFunction); \
+ (pTimer)->data = (unsigned long)(pArg); \
+} while (0)
+
+/*
+ * Start a Timer that elapses after 'periodMSec' milli-seconds
+ * Support is provided for a one-shot timer. The 'repeatFlag' is
+ * ignored.
+ */
+#define A_TIMEOUT_MS(pTimer, periodMSec, repeatFlag) do { \
+ if (repeatFlag) { \
+ printk("\n" __FILE__ ":%d: Timer Repeat requested\n",__LINE__); \
+ panic("Timer Repeat"); \
+ } \
+ mod_timer((pTimer), jiffies + HZ * (periodMSec) / 1000); \
+} while (0)
+
+/*
+ * Cancel the Timer.
+ */
+#define A_UNTIMEOUT(pTimer) do { \
+ del_timer((pTimer)); \
+} while (0)
+
+#define A_DELETE_TIMER(pTimer) do { \
+} while (0)
+
+/*
+ * Wait Queue related functions
+ */
+typedef wait_queue_head_t A_WAITQUEUE_HEAD;
+#define A_INIT_WAITQUEUE_HEAD(head) init_waitqueue_head(head)
+#ifndef wait_event_interruptible_timeout
+#define __wait_event_interruptible_timeout(wq, condition, ret) \
+do { \
+ wait_queue_t __wait; \
+ init_waitqueue_entry(&__wait, current); \
+ \
+ add_wait_queue(&wq, &__wait); \
+ for (;;) { \
+ set_current_state(TASK_INTERRUPTIBLE); \
+ if (condition) \
+ break; \
+ if (!signal_pending(current)) { \
+ ret = schedule_timeout(ret); \
+ if (!ret) \
+ break; \
+ continue; \
+ } \
+ ret = -ERESTARTSYS; \
+ break; \
+ } \
+ current->state = TASK_RUNNING; \
+ remove_wait_queue(&wq, &__wait); \
+} while (0)
+
+#define wait_event_interruptible_timeout(wq, condition, timeout) \
+({ \
+ long __ret = timeout; \
+ if (!(condition)) \
+ __wait_event_interruptible_timeout(wq, condition, __ret); \
+ __ret; \
+})
+#endif /* wait_event_interruptible_timeout */
+
+#define A_WAIT_EVENT_INTERRUPTIBLE_TIMEOUT(head, condition, timeout) do { \
+ wait_event_interruptible_timeout(head, condition, timeout); \
+} while (0)
+
+#define A_WAKE_UP(head) wake_up(head)
+
+#ifdef DEBUG
+extern unsigned int panic_on_assert;
+#define A_ASSERT(expr) \
+ if (!(expr)) { \
+ printk(KERN_ALERT"Debug Assert Caught, File %s, Line: %d, Test:%s \n",__FILE__, __LINE__,#expr); \
+ if (panic_on_assert) panic(#expr); \
+ }
+#else
+#define A_ASSERT(expr)
+#endif /* DEBUG */
+
+#ifdef ANDROID_ENV
+struct firmware;
+int android_request_firmware(const struct firmware **firmware_p, const char *filename,
+ struct device *device);
+void android_release_firmware(const struct firmware *firmware);
+#define A_REQUEST_FIRMWARE(_ppf, _pfile, _dev) android_request_firmware(_ppf, _pfile, _dev)
+#define A_RELEASE_FIRMWARE(_pf) android_release_firmware(_pf)
+#else
+struct firmware;
+int android_request_firmware(const struct firmware **firmware_p, const char *filename,
+ struct device *device);
+void android_release_firmware(const struct firmware *firmware);
+#define A_REQUEST_FIRMWARE(_ppf, _pfile, _dev) android_request_firmware(_ppf, _pfile, _dev)
+#define A_RELEASE_FIRMWARE(_pf) android_release_firmware(_pf)
+
+//#define A_REQUEST_FIRMWARE(_ppf, _pfile, _dev) request_firmware(_ppf, _pfile, _dev)
+//#define A_RELEASE_FIRMWARE(_pf) release_firmware(_pf)
+#endif
+
+/*
+ * Initialization of the network buffer subsystem
+ */
+#define A_NETBUF_INIT()
+
+/*
+ * Network buffer queue support
+ */
+typedef struct sk_buff_head A_NETBUF_QUEUE_T;
+
+#define A_NETBUF_QUEUE_INIT(q) \
+ a_netbuf_queue_init(q)
+
+#define A_NETBUF_ENQUEUE(q, pkt) \
+ a_netbuf_enqueue((q), (pkt))
+#define A_NETBUF_PREQUEUE(q, pkt) \
+ a_netbuf_prequeue((q), (pkt))
+#define A_NETBUF_DEQUEUE(q) \
+ (a_netbuf_dequeue(q))
+#define A_NETBUF_QUEUE_SIZE(q) \
+ a_netbuf_queue_size(q)
+#define A_NETBUF_QUEUE_EMPTY(q) \
+ a_netbuf_queue_empty(q)
+
+/*
+ * Network buffer support
+ */
+#ifdef AR6K_ALLOC_DEBUG
+#define A_NETBUF_ALLOC(size) \
+ a_netbuf_alloc(size, __func__, __LINE__)
+#define A_NETBUF_ALLOC_RAW(size) \
+ a_netbuf_alloc_raw(size, __func__, __LINE__)
+#define A_NETBUF_CHECK(bufPtr) \
+ a_netbuf_check(bufPtr, __func__, __LINE__)
+#else
+#define A_NETBUF_ALLOC(size) \
+ a_netbuf_alloc(size)
+#define A_NETBUF_ALLOC_RAW(size) \
+ a_netbuf_alloc_raw(size)
+#endif /* AR6K_ALLOC_DEBUG */
+#define A_NETBUF_FREE(bufPtr) \
+ a_netbuf_free(bufPtr)
+#define A_NETBUF_DATA(bufPtr) \
+ a_netbuf_to_data(bufPtr)
+#define A_NETBUF_LEN(bufPtr) \
+ a_netbuf_to_len(bufPtr)
+#define A_NETBUF_PUSH(bufPtr, len) \
+ a_netbuf_push(bufPtr, len)
+#define A_NETBUF_PUT(bufPtr, len) \
+ a_netbuf_put(bufPtr, len)
+#define A_NETBUF_TRIM(bufPtr,len) \
+ a_netbuf_trim(bufPtr, len)
+#define A_NETBUF_PULL(bufPtr, len) \
+ a_netbuf_pull(bufPtr, len)
+#define A_NETBUF_HEADROOM(bufPtr)\
+ a_netbuf_headroom(bufPtr)
+#define A_NETBUF_SETLEN(bufPtr,len) \
+ a_netbuf_setlen(bufPtr, len)
+
+/* Add data to end of a buffer */
+#define A_NETBUF_PUT_DATA(bufPtr, srcPtr, len) \
+ a_netbuf_put_data(bufPtr, srcPtr, len)
+
+/* Add data to start of the buffer */
+#define A_NETBUF_PUSH_DATA(bufPtr, srcPtr, len) \
+ a_netbuf_push_data(bufPtr, srcPtr, len)
+
+/* Remove data at start of the buffer */
+#define A_NETBUF_PULL_DATA(bufPtr, dstPtr, len) \
+ a_netbuf_pull_data(bufPtr, dstPtr, len)
+
+/* Remove data from the end of the buffer */
+#define A_NETBUF_TRIM_DATA(bufPtr, dstPtr, len) \
+ a_netbuf_trim_data(bufPtr, dstPtr, len)
+
+/* View data as "size" contiguous bytes of type "t" */
+#define A_NETBUF_VIEW_DATA(bufPtr, t, size) \
+ (t )( ((struct skbuf *)(bufPtr))->data)
+
+/* return the beginning of the headroom for the buffer */
+#define A_NETBUF_HEAD(bufPtr) \
+ ((((struct sk_buff *)(bufPtr))->head))
+
+/*
+ * OS specific network buffer access routines
+ */
+#ifdef AR6K_ALLOC_DEBUG
+void *a_netbuf_alloc(int size, const char *func, int lineno);
+void *a_netbuf_alloc_raw(int size, const char *func, int lineno);
+void a_netbuf_check(void *bufPtr, const char *func, int lineno);
+#else
+void *a_netbuf_alloc(int size);
+void *a_netbuf_alloc_raw(int size);
+#endif
+void a_netbuf_free(void *bufPtr);
+void *a_netbuf_to_data(void *bufPtr);
+A_UINT32 a_netbuf_to_len(void *bufPtr);
+A_STATUS a_netbuf_push(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_push_data(void *bufPtr, char *srcPtr, A_INT32 len);
+A_STATUS a_netbuf_put(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_put_data(void *bufPtr, char *srcPtr, A_INT32 len);
+A_STATUS a_netbuf_pull(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_pull_data(void *bufPtr, char *dstPtr, A_INT32 len);
+A_STATUS a_netbuf_trim(void *bufPtr, A_INT32 len);
+A_STATUS a_netbuf_trim_data(void *bufPtr, char *dstPtr, A_INT32 len);
+A_STATUS a_netbuf_setlen(void *bufPtr, A_INT32 len);
+A_INT32 a_netbuf_headroom(void *bufPtr);
+void a_netbuf_enqueue(A_NETBUF_QUEUE_T *q, void *pkt);
+void a_netbuf_prequeue(A_NETBUF_QUEUE_T *q, void *pkt);
+void *a_netbuf_dequeue(A_NETBUF_QUEUE_T *q);
+int a_netbuf_queue_size(A_NETBUF_QUEUE_T *q);
+int a_netbuf_queue_empty(A_NETBUF_QUEUE_T *q);
+int a_netbuf_queue_empty(A_NETBUF_QUEUE_T *q);
+void a_netbuf_queue_init(A_NETBUF_QUEUE_T *q);
+
+/*
+ * Kernel v.s User space functions
+ */
+A_UINT32 a_copy_to_user(void *to, const void *from, A_UINT32 n);
+A_UINT32 a_copy_from_user(void *to, const void *from, A_UINT32 n);
+
+/* In linux, WLAN Rx and Tx run in different contexts, so no need to check
+ * for any commands/data queued for WLAN */
+#define A_CHECK_DRV_TX()
+
+#define A_GET_CACHE_LINE_BYTES() L1_CACHE_BYTES
+
+#define A_CACHE_LINE_PAD 128
+
+static inline void *A_ALIGN_TO_CACHE_LINE(void *ptr) {
+ return (void *)L1_CACHE_ALIGN((unsigned long)ptr);
+}
+
+#else /* __KERNEL__ */
+
+#ifdef __GNUC__
+#define __ATTRIB_PACK __attribute__ ((packed))
+#define __ATTRIB_PRINTF __attribute__ ((format (printf, 1, 2)))
+#define __ATTRIB_NORETURN __attribute__ ((noreturn))
+#ifndef INLINE
+#define INLINE __inline__
+#endif
+#else /* Not GCC */
+#define __ATTRIB_PACK
+#define __ATTRIB_PRINTF
+#define __ATTRIB_NORETURN
+#ifndef INLINE
+#define INLINE __inline
+#endif
+#endif /* End __GNUC__ */
+
+#define PREPACK
+#define POSTPACK __ATTRIB_PACK
+
+#define A_MEMCPY(dst, src, len) memcpy((dst), (src), (len))
+#define A_MEMZERO(addr, len) memset((addr), 0, (len))
+#define A_MEMCMP(addr1, addr2, len) memcmp((addr1), (addr2), (len))
+#define A_MALLOC(size) malloc(size)
+#define A_FREE(addr) free(addr)
+
+#ifdef ANDROID
+#ifndef err
+#include <errno.h>
+#define err(_s, args...) do { \
+ fprintf(stderr, "%s: line %d ", __FILE__, __LINE__); \
+ fprintf(stderr, args); fprintf(stderr, ": %d\n", errno); \
+ exit(_s); } while (0)
+#endif
+#else
+#include <err.h>
+#endif
+
+#endif /* __KERNEL__ */
+
+#endif /* _OSAPI_LINUX_H_ */
diff --git a/host/os/linux/include/wlan_config.h b/host/os/linux/include/wlan_config.h
new file mode 100644
index 0000000..e357131
--- /dev/null
+++ b/host/os/linux/include/wlan_config.h
@@ -0,0 +1,179 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Corporation. All rights reserved.
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//------------------------------------------------------------------------------
+//==============================================================================
+// This file contains the tunable configuration items for the WLAN module
+//
+// Author(s): ="Atheros"
+//==============================================================================
+#ifndef _HOST_WLAN_CONFIG_H_
+#define _HOST_WLAN_CONFIG_H_
+
+/* Include definitions here that can be used to tune the WLAN module behavior.
+ * Different customers can tune the behavior as per their needs, here.
+ */
+
+/* This configuration item when defined will consider the barker preamble
+ * mentioned in the ERP IE of the beacons from the AP to determine the short
+ * preamble support sent in the (Re)Assoc request frames.
+ */
+#define WLAN_CONFIG_DONOT_IGNORE_BARKER_IN_ERP 0
+
+/* This config item when defined will not send the power module state transition
+ * failure events that happen during scan, to the host.
+ */
+#define WLAN_CONFIG_IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN 0
+
+/* This config item disables sending a DisAssoc frame prior to sending a
+ * DeAuth frame.
+ */
+#define WLAN_CONFIG_NO_DISASSOC_UPON_DEAUTH 0
+
+/*
+ * This configuration item enable/disable keepalive support.
+ * Keepalive support: In the absence of any data traffic to AP, null
+ * frames will be sent to the AP at periodic interval, to keep the association
+ * active. This configuration item defines the periodic interval.
+ * Use value of zero to disable keepalive support
+ * Default: 60 seconds
+ */
+#define WLAN_CONFIG_KEEP_ALIVE_INTERVAL 60
+
+/*
+ * This configuration item sets the value of disconnect timeout
+ * Firmware delays sending the disconnec event to the host for this
+ * timeout after is gets disconnected from the current AP.
+ * If the firmware successly roams within the disconnect timeout
+ * it sends a new connect event
+ */
+#ifdef ANDROID_ENV
+#define WLAN_CONFIG_DISCONNECT_TIMEOUT 3
+#else
+#define WLAN_CONFIG_DISCONNECT_TIMEOUT 10
+#endif /* ANDROID_ENV */
+
+/*
+ * This configuration item enable BT clock sharing support
+ * 1 - Enable
+ * 0 - Disable (Default)
+ */
+#define WLAN_CONFIG_BT_SHARING 0
+
+/*
+ * This configuration item sets WIFI OFF policy
+ * 0 - CUT_POWER
+ * 1 - DEEP_SLEEP (Default)
+ */
+#define WLAN_CONFIG_WLAN_OFF 1
+
+/*
+ * This configuration item disables 11n support.
+ * 0 - Enable
+ * 1 - Disable
+ */
+#define WLAN_CONFIG_DISABLE_11N 0
+
+/*
+ * This configuration item sets suspend policy
+ * 0 - CUT_POWER (Default)
+ * 1 - DEEP_SLEEP
+ * 2 - WoW
+ * 3 - CUT_POWER if BT OFF (clock sharing designs only)
+ */
+#define WLAN_CONFIG_PM_SUSPEND 0
+
+/*
+ * This configuration item sets suspend policy to use if PM_SUSPEND is
+ * set to WoW and device is not connected at the time of suspend
+ * 0 - CUT_POWER (Default)
+ * 1 - DEEP_SLEEP
+ * 2 - WoW
+ * 3 - CUT_POWER if BT OFF (clock sharing designs only)
+ */
+#define WLAN_CONFIG_PM_WOW2 1
+
+/*
+ * Define GPIO number for WoW in your platform other than zero
+ * Wake lock will be called when GPIO asserted.
+ */
+#define PLAT_WOW_GPIO_PIN 0
+
+/*
+ * This configuration item for the WOW patterns in AP mode
+ * 0 - Wake up host only if any unicast IP, EAPOL-like and ARP, broadcast dhcp and ARP packets. (default)
+ * 1 - Wake up host if any unicast/broadcast/multicast packets
+ */
+#define WLAN_CONFIG_SIMPLE_WOW_AP_MODE 0
+
+/*
+ * set to 1 to let STA do 2.4GHz band scan on 1st scan after
+ * either insmod or wmiconfig --wlan enable
+ *
+ * set to 0 to disable this feature
+ */
+#define WLAN_CONFIG_FIRST_SCAN_2G_ONLY 0
+
+/*
+ * 1: to disable sending ps-poll in TIM interrupt
+ * 0: to send one ps-poll (the default)
+ *
+ */
+#define WLAN_CONFIG_PSPOLL_NUM 0
+
+/*
+ * 0: to use the default (NORMAL_DTIM)
+ * 1: to use IGNORE_DTIM
+ * 2: to use NORMAL_DTIM
+ * 3: to use STICK_DTIM
+ * 4: to use AUTO_DTIM
+ */
+#define WLAN_CONFIG_DTIM_POLICY 0
+
+
+/*
+ * Define the GPIO number for WLAN CHIP_PWD PIN other than zero
+ * Only use when you define plat_setup_power as plat_setup_power_stub
+ */
+
+#define PLAT_WLAN_CHIP_PWD_PIN 1
+
+/*
+ * Platform specific function to power ON/OFF AR6000 with CHIP_PWD PIN
+ * and enable/disable SDIO card detection
+ *
+ * Either implement wlan CHIP_PWD PIN and power GPIO control into
+ * plat_setup_power_stub(..) place holder in ar6000_pm.c
+ * or redefine plat_setup_power(..) into your export funciton.
+ */
+
+#if PLAT_WLAN_CHIP_PWD_PIN
+extern void plat_setup_power_stub(struct ar6_softc *ar, int on, int detect);
+#define plat_setup_power(ar, on, detect) plat_setup_power_stub(ar, on, detect)
+#elif defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM7X27) && defined(CONFIG_MSM_SOC_REV_A)
+extern void msm7x27a_wifi_power(bool on);
+#define plat_setup_power(ar, on, detect) msm7x27a_wifi_power(on)
+#elif defined(CONFIG_MMC_MSM) && defined(CONFIG_ARCH_MSM9615)
+#define MSM9615_WLAN_CHIP_PWD_PIN 21
+#define MSM9615_WLAN_PM_ENABLE_PIN 2
+extern int msm9615_wifi_power(AR_SOFTC_T *ar, int on);
+#define plat_setup_power(ar, on, detect) msm9615_wifi_power(ar, on)
+#else
+#define plat_setup_power(ar, on, detect) /* define as your function */
+#endif
+
+#endif /* _HOST_WLAN_CONFIG_H_ */
diff --git a/host/os/linux/include/wmi_filter_linux.h b/host/os/linux/include/wmi_filter_linux.h
new file mode 100644
index 0000000..dc81b83
--- /dev/null
+++ b/host/os/linux/include/wmi_filter_linux.h
@@ -0,0 +1,351 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#ifndef _WMI_FILTER_LINUX_H_
+#define _WMI_FILTER_LINUX_H_
+
+/*
+ * sioctl_filter - Standard ioctl
+ * pioctl_filter - Priv ioctl
+ * xioctl_filter - eXtended ioctl
+ *
+ * ---- Possible values for the WMI filter ---------------
+ * (0) - Block this cmd always (or) not implemented
+ * (INFRA_NETWORK) - Allow this cmd only in STA mode
+ * (ADHOC_NETWORK) - Allow this cmd only in IBSS mode
+ * (AP_NETWORK) - Allow this cmd only in AP mode
+ * (INFRA_NETWORK | ADHOC_NETWORK) - Block this cmd in AP mode
+ * (ADHOC_NETWORK | AP_NETWORK) - Block this cmd in STA mode
+ * (INFRA_NETWORK | AP_NETWORK) - Block this cmd in IBSS mode
+ * (INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK)- allow only when mode is set
+ * (0xFF) - Allow this cmd always irrespective of mode
+ */
+
+A_UINT8 sioctl_filter[] = {
+(AP_NETWORK), /* SIOCSIWCOMMIT 0x8B00 */
+(0xFF), /* SIOCGIWNAME 0x8B01 */
+(0), /* SIOCSIWNWID 0x8B02 */
+(0), /* SIOCGIWNWID 0x8B03 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCSIWFREQ 0x8B04 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCGIWFREQ 0x8B05 */
+(0xFF), /* SIOCSIWMODE 0x8B06 */
+(0xFF), /* SIOCGIWMODE 0x8B07 */
+(0), /* SIOCSIWSENS 0x8B08 */
+(0), /* SIOCGIWSENS 0x8B09 */
+(0), /* SIOCSIWRANGE 0x8B0A */
+(0xFF), /* SIOCGIWRANGE 0x8B0B */
+(0), /* SIOCSIWPRIV 0x8B0C */
+(0), /* SIOCGIWPRIV 0x8B0D */
+(0), /* SIOCSIWSTATS 0x8B0E */
+(0), /* SIOCGIWSTATS 0x8B0F */
+(0), /* SIOCSIWSPY 0x8B10 */
+(0), /* SIOCGIWSPY 0x8B11 */
+(0), /* SIOCSIWTHRSPY 0x8B12 */
+(0), /* SIOCGIWTHRSPY 0x8B13 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCSIWAP 0x8B14 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCGIWAP 0x8B15 */
+#if (WIRELESS_EXT >= 18)
+(INFRA_NETWORK | ADHOC_NETWORK), /* SIOCSIWMLME 0X8B16 */
+#else
+(0), /* Dummy 0 */
+#endif /* WIRELESS_EXT */
+(0), /* SIOCGIWAPLIST 0x8B17 */
+(INFRA_NETWORK | ADHOC_NETWORK), /* SIOCSIWSCAN 0x8B18 */
+(INFRA_NETWORK | ADHOC_NETWORK), /* SIOCGIWSCAN 0x8B19 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCSIWESSID 0x8B1A */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCGIWESSID 0x8B1B */
+(0), /* SIOCSIWNICKN 0x8B1C */
+(0), /* SIOCGIWNICKN 0x8B1D */
+(0), /* Dummy 0 */
+(0), /* Dummy 0 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCSIWRATE 0x8B20 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCGIWRATE 0x8B21 */
+(0), /* SIOCSIWRTS 0x8B22 */
+(0), /* SIOCGIWRTS 0x8B23 */
+(0), /* SIOCSIWFRAG 0x8B24 */
+(0), /* SIOCGIWFRAG 0x8B25 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCSIWTXPOW 0x8B26 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCGIWTXPOW 0x8B27 */
+(INFRA_NETWORK | ADHOC_NETWORK), /* SIOCSIWRETRY 0x8B28 */
+(INFRA_NETWORK | ADHOC_NETWORK), /* SIOCGIWRETRY 0x8B29 */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCSIWENCODE 0x8B2A */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCGIWENCODE 0x8B2B */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCSIWPOWER 0x8B2C */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* SIOCGIWPOWER 0x8B2D */
+};
+
+
+
+A_UINT8 pioctl_filter[] = {
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* IEEE80211_IOCTL_SETPARAM (SIOCIWFIRSTPRIV+0) */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* IEEE80211_IOCTL_SETKEY (SIOCIWFIRSTPRIV+1) */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* IEEE80211_IOCTL_DELKEY (SIOCIWFIRSTPRIV+2) */
+(AP_NETWORK), /* IEEE80211_IOCTL_SETMLME (SIOCIWFIRSTPRIV+3) */
+(INFRA_NETWORK), /* IEEE80211_IOCTL_ADDPMKID (SIOCIWFIRSTPRIV+4) */
+(0), /* IEEE80211_IOCTL_SETOPTIE (SIOCIWFIRSTPRIV+5) */
+(0), /* (SIOCIWFIRSTPRIV+6) */
+(0), /* (SIOCIWFIRSTPRIV+7) */
+(0), /* (SIOCIWFIRSTPRIV+8) */
+(0), /* (SIOCIWFIRSTPRIV+9) */
+(0), /* IEEE80211_IOCTL_LASTONE (SIOCIWFIRSTPRIV+10) */
+(0xFF), /* AR6000_IOCTL_WMI_GETREV (SIOCIWFIRSTPRIV+11) */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_IOCTL_WMI_SETPWR (SIOCIWFIRSTPRIV+12) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SETSCAN (SIOCIWFIRSTPRIV+13) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SETLISTENINT (SIOCIWFIRSTPRIV+14) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SETBSSFILTER (SIOCIWFIRSTPRIV+15) */
+(INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_IOCTL_WMI_SET_CHANNELPARAMS (SIOCIWFIRSTPRIV+16) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_PROBEDSSID (SIOCIWFIRSTPRIV+17) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_PMPARAMS (SIOCIWFIRSTPRIV+18) */
+(INFRA_NETWORK), /* AR6000_IOCTL_WMI_SET_BADAP (SIOCIWFIRSTPRIV+19) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_GET_QOS_QUEUE (SIOCIWFIRSTPRIV+20) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_CREATE_QOS (SIOCIWFIRSTPRIV+21) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_DELETE_QOS (SIOCIWFIRSTPRIV+22) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_SNRTHRESHOLD (SIOCIWFIRSTPRIV+23) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_ERROR_REPORT_BITMASK (SIOCIWFIRSTPRIV+24)*/
+(0xFF), /* AR6000_IOCTL_WMI_GET_TARGET_STATS (SIOCIWFIRSTPRIV+25) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_ASSOC_INFO (SIOCIWFIRSTPRIV+26) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_ACCESS_PARAMS (SIOCIWFIRSTPRIV+27) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_BMISS_TIME (SIOCIWFIRSTPRIV+28) */
+(INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_DISC_TIMEOUT (SIOCIWFIRSTPRIV+29) */
+(ADHOC_NETWORK), /* AR6000_IOCTL_WMI_SET_IBSS_PM_CAPS (SIOCIWFIRSTPRIV+30) */
+};
+
+/* Submode for the sake of filtering XIOCTLs are broadly set to 2 types.
+ * P2P Submode & Non-P2P submode. IOCLT cmds can be marked to be valid only in
+ * P2P Submode or Non-P2P submode or both. The bits- b5,b6,b7 are used to encode
+ * this information in the IOCTL filters. The LSBits b0-b4 are used to encode
+ * the mode information.
+ */
+#define XIOCTL_FILTER_P2P_SUBMODE 0x20
+#define XIOCTL_FILTER_NONP2P_SUBMODE 0x40
+#define XIOCTL_FILTER_SUBMODE_DONTCARE \
+ (XIOCTL_FILTER_P2P_SUBMODE | XIOCTL_FILTER_NONP2P_SUBMODE)
+
+A_UINT8 xioctl_filter[] = {
+(0xFF), /* Dummy 0 */
+(0xFF), /* AR6000_XIOCTL_BMI_DONE 1 */
+(0xFF), /* AR6000_XIOCTL_BMI_READ_MEMORY 2 */
+(0xFF), /* AR6000_XIOCTL_BMI_WRITE_MEMORY 3 */
+(0xFF), /* AR6000_XIOCTL_BMI_EXECUTE 4 */
+(0xFF), /* AR6000_XIOCTL_BMI_SET_APP_START 5 */
+(0xFF), /* AR6000_XIOCTL_BMI_READ_SOC_REGISTER 6 */
+(0xFF), /* AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER 7 */
+(0xFF), /* AR6000_XIOCTL_BMI_TEST 8 */
+(0xFF), /* AR6000_XIOCTL_UNUSED9 9 */
+(0xFF), /* AR6000_XIOCTL_UNUSED10 10 */
+(0xFF), /* AR6000_XIOCTL_UNUSED11 11 */
+(0xFF), /* AR6000_XIOCTL_FORCE_TARGET_RESET 12 */
+(0xFF), /* AR6000_XIOCTL_HTC_RAW_OPEN 13 */
+(0xFF), /* AR6000_XIOCTL_HTC_RAW_CLOSE 14 */
+(0xFF), /* AR6000_XIOCTL_HTC_RAW_READ 15 */
+(0xFF), /* AR6000_XIOCTL_HTC_RAW_WRITE 16 */
+(0xFF), /* AR6000_XIOCTL_CHECK_TARGET_READY 17 */
+(0xFF), /* AR6000_XIOCTL_GPIO_OUTPUT_SET 18 */
+(0xFF), /* AR6000_XIOCTL_GPIO_INPUT_GET 19 */
+(0xFF), /* AR6000_XIOCTL_GPIO_REGISTER_SET 20 */
+(0xFF), /* AR6000_XIOCTL_GPIO_REGISTER_GET 21 */
+(0xFF), /* AR6000_XIOCTL_GPIO_INTR_ACK 22 */
+(0xFF), /* AR6000_XIOCTL_GPIO_INTR_WAIT 23 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_SET_ADHOC_BSSID 24 */
+(0x00), /*AR6000_XIOCTL_UNUSED 25 */
+(0x00), /*AR6000_XIOCTL_UNUSED 26 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_SET_BEACON_INTVAL 27 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* IEEE80211_IOCTL_SETAUTHALG 28 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_SET_VOICE_PKT_SIZE 29 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_SET_MAX_SP 30 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_GET_ROAM_TBL 31 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_ROAM_CTRL 32 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS 33 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTRL_WMI_GET_POWER_MODE 34 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTRL_WMI_SET_WLAN_STATE 35 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_GET_ROAM_DATA 36 */
+(0xFF), /* AR6000_XIOCTL_WMI_SETRETRYLIMITS 37 */
+(0xFF), /* AR6000_XIOCTL_TCMD_CONT_TX 38 */
+(0xFF), /* AR6000_XIOCTL_TCMD_CONT_RX 39 */
+(0xFF), /* AR6000_XIOCTL_TCMD_PM 40 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_STARTSCAN 41 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SETFIXRATES 42 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GETFIXRATES 43 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_RSSITHRESHOLD 44 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_CLR_RSSISNR 45 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_LQTHRESHOLD 46 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_RTS 47 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_LPREAMBLE 48 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_AUTHMODE 49 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_REASSOCMODE 50 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_WMM 51 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS 52 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP 53 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GET_RD 54 */
+(0xFF), /* AR6000_XIOCTL_DIAG_READ 55 */
+(0xFF), /* AR6000_XIOCTL_DIAG_WRITE 56 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_TXOP 57 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK), /* AR6000_XIOCTL_USER_SETKEYS 58 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK), /* AR6000_XIOCTL_WMI_SET_KEEPALIVE 59 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK), /* AR6000_XIOCTL_WMI_GET_KEEPALIVE 60 */
+(0xFF), /* AR6000_XIOCTL_BMI_ROMPATCH_INSTALL 61 */
+(0xFF), /* AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL 62 */
+(0xFF), /* AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE 63 */
+(0xFF), /* AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE 64 */
+(0xFF), /* AR6000_XIOCTL_WMI_SET_APPIE 65 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | 0x1F), /* AR6000_XIOCTL_WMI_SET_MGMT_FRM_RX_FILTER 66 */
+(0xFF), /* AR6000_XIOCTL_DBGLOG_CFG_MODULE 67 */
+(0xFF), /* AR6000_XIOCTL_DBGLOG_GET_DEBUG_LOGS 68 */
+(0xFF), /* Dummy 69 */
+(0xFF), /* AR6000_XIOCTL_WMI_SET_WSC_STATUS 70 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_BT_STATUS 71 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_BT_PARAMS 72 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_HOST_SLEEP_MODE 73 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_WOW_MODE 74 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GET_WOW_LIST 75 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_ADD_WOW_PATTERN 76 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_DEL_WOW_PATTERN 77 */
+(0xFF), /* AR6000_XIOCTL_TARGET_INFO 78 */
+(0xFF), /* AR6000_XIOCTL_DUMP_HTC_CREDIT_STATE 79 */
+(0xFF), /* AR6000_XIOCTL_TRAFFIC_ACTIVITY_CHANGE 80 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_CONNECT_CTRL_FLAGS 81 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_AKMP_PARAMS 82 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_GET_PMKID_LIST 83 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_PMKID_LIST 84 */
+(0xFF), /* Dummy 85 */
+(0xFF), /* Dummy 86 */
+(0xFF), /* Dummy 87 */
+(0xFF), /* Dummy 88 */
+(0xFF), /* Dummy 89 */
+(0xFF), /* AR6000_XIOCTL_UNUSED90 90 */
+(0xFF), /* AR6000_XIOCTL_BMI_LZ_STREAM_START 91 */
+(0xFF), /* AR6000_XIOCTL_BMI_LZ_DATA 92 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_PROF_CFG 93 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_PROF_ADDR_SET 94 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_PROF_START 95 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_PROF_STOP 96 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_PROF_COUNT_GET 97 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_ABORT_SCAN 98 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_STA_LIST 99 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | AP_NETWORK), /* AR6000_XIOCTL_AP_HIDDEN_SSID 100 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_SET_NUM_STA 101 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_SET_ACL_MAC 102 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_ACL_LIST 103 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_COMMIT_CONFIG 104 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* IEEE80211_IOCTL_GETWPAIE 105 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_CONN_INACT_TIME 106 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_PROT_SCAN_TIME 107 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_COUNTRY 108 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_SET_DTIM 109 */
+(0xFF), /* AR6000_XIOCTL_WMI_TARGET_EVENT_REPORT 110 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_SET_IP 111 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_SET_ACL_POLICY 112 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_CTRL_BSS_COMM 113 */
+(0xFF), /* AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO 114 */
+(0xFF), /* AR6000_XIOCTL_MODULE_DEBUG_SET_MASK 115 */
+(0xFF), /* AR6000_XIOCTL_MODULE_DEBUG_GET_MASK 116 */
+(0xFF), /* AR6000_XIOCTL_DUMP_RCV_AGGR_STATS 117 */
+(0xFF), /* AR6000_XIOCTL_SET_HT_CAP 118 */
+(0xFF), /* AR6000_XIOCTL_SET_HT_OP 119 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_STAT 120 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | 0x1F), /* AR6000_XIOCTL_SET_TX_SELECT_RATES 121 */
+(0xFF), /* AR6000_XIOCTL_SETUP_AGGR 122 */
+(0xFF), /* AR6000_XIOCTL_ALLOW_AGGR 123 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_HIDDEN_SSID 124 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_COUNTRY 125 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_WMODE 126 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_DTIM 127 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_AP_GET_BINTVL 128 */
+(0xFF), /* AR6000_XIOCTL_AP_GET_RTS 129 */
+(0xFF), /* AR6000_XIOCTL_DELE_AGGR 130 */
+(0xFF), /* AR6000_XIOCTL_FETCH_TARGET_REGS 131 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | 0x1F), /* AR6000_XIOCTL_HCI_CMD 132 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | 0x1F), /* AR6000_XIOCTL_ACL_DATA 133 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | 0x1F), /* AR6000_XIOCTL_WLAN_CONN_PRECEDENCE 134 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | AP_NETWORK), /* AR6000_XIOCTL_AP_SET_11BG_RATESET 135 */
+(0xFF),
+(0xFF),
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BTCOEX_FE_ANT 138 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BTCOEX_COLOCATED_BT_DEV 139 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG 140 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BTCOEX_SCO_CONFIG 141 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BTCOEX_A2DP_CONFIG 142 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BTCOEX_ACLCOEX_CONFIG 143 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BTCOEX_DEBUG 144 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_SET_BT_OPERATING_STATUS 145 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GET_BTCOEX_CONFIG 146 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GET_BTCOEX_GET_STATS 147 */
+(0xFF), /* AR6000_XIOCTL_WMI_SET_QOS_SUPP 148 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_SET_DFS 149 */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* P2P CMDS BEGIN AR6000_XIOCTL_WMI_P2P_DISCOVER 150 */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_STOP_FIND */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_CANCEL */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_LISTEN */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_GO_NEG */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_AUTH_GO_NEG */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_REJECT */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_CONFIG */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_WPS_CONFIG */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_FINDNODE */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_GRP_INIT 160 */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_GRP_FORMATION_DONE */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_INVITE */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_PROV_DISC */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_SET */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_PEER */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_FLUSH */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GET_GO_PARAMS */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_P2P_AUTH_INVITE */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_GET_IF_ADDR */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_GET_DEV_ADDR 170 */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_P2P_SDPD_TX_CMD */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOTCL_WMI_P2P_SD_CANCEL_REQUEST */
+(0xFF), /* AR6000_XIOCTL_SET_BT_HW_POWER_STATE 173 */
+(0xFF), /* AR6000_XIOCTL_GET_BT_HW_POWER_STATE 174 */
+(0xFF), /* AR6000_XIOCTL_GET_WLAN_SLEEP_STATE 175 */
+(0xFF), /* AR6000_XIOCTL_WMI_SET_TX_SGI_PARAM 176 */
+(0xFF), /* R6000_XIOCTL_WMI_ENABLE_WAC_PARAM 177 */
+(0xFF), /* AR6000_XIOCTL_WAC_SCAN_REPLY 178 */
+(0xFF), /* AR6000_XIOCTL_WMI_WAC_CTRL_REQ 179 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_WPA_OFFLOAD_STATE 180 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_PASSPHRASE 181 */
+(0xFF), /* AR6000_XIOCTL_BMI_NVRAM_PROCESS 182 */
+(0xFF), /* AR6000_XIOCTL_WMI_SET_DIVERSITY_PARAM 183 */
+(0xFF), /* AR6000_XIOCTL_WMI_FORCE_ASSERT 184 */
+(0xFF), /* AR6000_XIOCTL_WMI_ENABLE_PKTLOG 185 */
+(0xFF), /* AR6000_XIOCTL_WMI_DISABLE_PKTLOG 186 */
+(0xFF), /* AR6000_XIOCTL_WMI_GET_PKTLOG 187 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | AP_NETWORK), /* AR6000_XIOCTL_AP_ACS_DISABLE_HI_CHANNELS 188 */
+(0xFF), /* AR6000_XIOCTL_TCMD_CMDS 189 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK), /* AR6000_XIOCTL_WMI_SET_EXCESS_TX_RETRY_THRES 190 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_AP_GET_NUM_STA 191 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | 0x1F), /* AR6000_XIOCTL_SUSPEND_DRIVER 192 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | 0x1F), /* AR6000_XIOCTL_RESUME_DRIVER 193 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_GET_SUBMODE 194 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | AP_NETWORK), /* AR6000_XIOCTL_WMI_AP_APSD 195 */
+(0xFF), /* AR6000_XIOCTL_TCMD_SETREG 196 */
+(0xFF), /* AR6000_XIOCTL_GET_HT_CAP 197 */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GET_P2P_IE 198 */
+(XIOCTL_FILTER_P2P_SUBMODE | INFRA_NETWORK | AP_NETWORK), /*AR6000_XIOCTL_WMI_P2P_GET_OWN_INFO 199 */
+(0xFF), /* AR6000_XIOCTL_WMI_LTE_FREQ 200 */
+(0xFF), /* AR6000_XIOCTL_WMI_IDLE_CLOSE_TIME 201 */
+(XIOCTL_FILTER_SUBMODE_DONTCARE | INFRA_NETWORK), /* AR6000_XIOCTL_WMI_SEND_FRAME 202 */
+(XIOCTL_FILTER_NONP2P_SUBMODE | INFRA_NETWORK | ADHOC_NETWORK | AP_NETWORK), /* AR6000_XIOCTL_WMI_GET_WMM 203 */
+};
+
+#endif /*_WMI_FILTER_LINUX_H_*/
diff --git a/host/os/linux/ioctl.c b/host/os/linux/ioctl.c
new file mode 100644
index 0000000..f8db5c4
--- /dev/null
+++ b/host/os/linux/ioctl.c
@@ -0,0 +1,5951 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#include "ar6000_drv.h"
+#include "a_drv_api.h"
+#include "ieee80211_ioctl.h"
+#include "ar6kap_common.h"
+#include "targaddrs.h"
+#include "wlan_config.h"
+
+#ifdef BTCOEX
+#include "a_hci.h"
+#endif
+
+#ifdef WAC
+#include "wac_defs.h"
+#endif
+
+#ifdef P2P
+#include "p2p_api.h"
+#endif /* P2P */
+
+extern int enablerssicompensation;
+A_UINT32 tcmdRxFreq;
+extern unsigned int wmitimeout;
+extern int tspecCompliance;
+extern int bmienable;
+extern int bypasswmi;
+#ifdef BTCOEX
+extern int loghci;
+#endif
+static int
+ar6000_ioctl_get_roam_tbl(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if(wmi_get_roam_tbl_cmd(arPriv->arWmi) != A_OK) {
+ return -EIO;
+ }
+
+ return 0;
+}
+
+static int
+ar6000_ioctl_get_roam_data(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ /* currently assume only roam times are required */
+ if(wmi_get_roam_data_cmd(arPriv->arWmi, ROAM_DATA_TIME) != A_OK) {
+ return -EIO;
+ }
+
+
+ return 0;
+}
+
+static int
+ar6000_ioctl_set_roam_ctrl(struct net_device *dev, char *userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_ROAM_CTRL_CMD cmd;
+ A_UINT8 size = sizeof(cmd);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, size)) {
+ return -EFAULT;
+ }
+
+ if (cmd.roamCtrlType == WMI_SET_HOST_BIAS) {
+ if (cmd.info.bssBiasInfo.numBss > 1) {
+ size += (cmd.info.bssBiasInfo.numBss - 1) * sizeof(WMI_BSS_BIAS);
+ }
+ }
+
+ if (copy_from_user(&cmd, userdata, size)) {
+ return -EFAULT;
+ }
+
+ if(wmi_set_roam_ctrl_cmd(arPriv->arWmi, &cmd, size) != A_OK) {
+ return -EIO;
+ }
+
+ return 0;
+}
+
+static int
+ar6000_ioctl_set_powersave_timers(struct net_device *dev, char *userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_POWERSAVE_TIMERS_POLICY_CMD cmd;
+ A_UINT8 size = sizeof(cmd);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, size)) {
+ return -EFAULT;
+ }
+
+ if (copy_from_user(&cmd, userdata, size)) {
+ return -EFAULT;
+ }
+
+ if(wmi_set_powersave_timers_cmd(arPriv->arWmi, &cmd, size) != A_OK) {
+ return -EIO;
+ }
+
+ return 0;
+}
+
+static int
+ar6000_ioctl_set_qos_supp(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_QOS_SUPP_CMD cmd;
+ A_STATUS ret;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, (char *)((unsigned int*)rq->ifr_data + 1),
+ sizeof(cmd)))
+ {
+ return -EFAULT;
+ }
+
+ ret = wmi_set_qos_supp_cmd(arPriv->arWmi, cmd.status);
+
+ switch (ret) {
+ case A_OK:
+ return 0;
+ case A_EBUSY :
+ return -EBUSY;
+ case A_NO_MEMORY:
+ return -ENOMEM;
+ case A_EINVAL:
+ default:
+ return -EFAULT;
+ }
+}
+
+static int
+ar6000_ioctl_get_wmm(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_to_user(rq->ifr_data, &arPriv->arWmmEnabled, sizeof(A_BOOL)))
+ return -EFAULT;
+ return 0;
+}
+
+static int
+ar6000_ioctl_set_wmm(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_WMM_CMD cmd;
+ A_STATUS ret;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, (char *)((unsigned int*)rq->ifr_data + 1),
+ sizeof(cmd)))
+ {
+ return -EFAULT;
+ }
+
+ if (cmd.status == WMI_WMM_ENABLED) {
+ arPriv->arWmmEnabled = TRUE;
+ } else {
+ arPriv->arWmmEnabled = FALSE;
+ }
+
+ ret = wmi_set_wmm_cmd(arPriv->arWmi, cmd.status);
+
+ switch (ret) {
+ case A_OK:
+ return 0;
+ case A_EBUSY :
+ return -EBUSY;
+ case A_NO_MEMORY:
+ return -ENOMEM;
+ case A_EINVAL:
+ default:
+ return -EFAULT;
+ }
+}
+
+static int
+ar6000_ioctl_set_txop(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_WMM_TXOP_CMD cmd;
+ A_STATUS ret;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, (char *)((unsigned int*)rq->ifr_data + 1),
+ sizeof(cmd)))
+ {
+ return -EFAULT;
+ }
+
+ ret = wmi_set_wmm_txop(arPriv->arWmi, cmd.txopEnable);
+
+ switch (ret) {
+ case A_OK:
+ return 0;
+ case A_EBUSY :
+ return -EBUSY;
+ case A_NO_MEMORY:
+ return -ENOMEM;
+ case A_EINVAL:
+ default:
+ return -EFAULT;
+ }
+}
+
+static int
+ar6000_ioctl_get_rd(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ A_STATUS ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if(copy_to_user((char *)((unsigned int*)rq->ifr_data + 1),
+ &arPriv->arRegCode, sizeof(arPriv->arRegCode)))
+ ret = -EFAULT;
+
+ return ret;
+}
+
+static int
+ar6000_ioctl_set_country(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_AP_SET_COUNTRY_CMD cmd;
+ A_STATUS ret;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, (char *)((unsigned int*)rq->ifr_data + 1),
+ sizeof(cmd)))
+ {
+ return -EFAULT;
+ }
+
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+
+ ret = wmi_set_country(arPriv->arWmi, cmd.countryCode);
+ A_MEMCPY(arPriv->arAp.ap_country_code, cmd.countryCode, 3);
+
+ switch (ret) {
+ case A_OK:
+ return 0;
+ case A_EBUSY :
+ return -EBUSY;
+ case A_NO_MEMORY:
+ return -ENOMEM;
+ case A_EINVAL:
+ default:
+ return -EFAULT;
+ }
+}
+
+
+/* Get power mode command */
+static int
+ar6000_ioctl_get_power_mode(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_POWER_MODE_CMD power_mode;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ power_mode.powerMode = wmi_get_power_mode_cmd(arPriv->arWmi);
+ if (copy_to_user(rq->ifr_data, &power_mode, sizeof(WMI_POWER_MODE_CMD))) {
+ ret = -EFAULT;
+ }
+
+ return ret;
+}
+
+
+static int
+ar6000_ioctl_set_channelParams(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_CHANNEL_PARAMS_CMD cmd, *cmdp;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if( (arPriv->arNextMode == AP_NETWORK) && (cmd.numChannels || cmd.scanParam) ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ERROR: Only wmode is allowed in AP mode\n"));
+ return -EIO;
+ }
+
+ if (cmd.numChannels > 1) {
+ cmdp = A_MALLOC(130);
+ if (copy_from_user(cmdp, rq->ifr_data,
+ sizeof (*cmdp) +
+ ((cmd.numChannels - 1) * sizeof(A_UINT16))))
+ {
+ A_FREE(cmdp);
+ return -EFAULT;
+ }
+ } else {
+ cmdp = &cmd;
+ }
+
+ if ((arPriv->arPhyCapability == WMI_11NG_CAPABILITY) &&
+ ((cmdp->phyMode == WMI_11A_MODE) || (cmdp->phyMode == WMI_11AG_MODE)))
+ {
+ ret = -EINVAL;
+ }
+
+ if (!ret &&
+ (wmi_set_channelParams_cmd(arPriv->arWmi, cmdp->scanParam, cmdp->phyMode,
+ cmdp->numChannels, cmdp->channelList)
+ != A_OK))
+ {
+ ret = -EIO;
+ }
+
+ if (!ret)
+ arPriv->phymode = cmdp->phyMode;
+
+ if (cmd.numChannels > 1) {
+ A_FREE(cmdp);
+ }
+
+ /* Set the profile change flag to allow a commit cmd */
+ if (!ret)
+ arPriv->ap_profile_flag = 1;
+
+ return ret;
+}
+
+
+static int
+ar6000_ioctl_set_snr_threshold(struct net_device *dev, struct ifreq *rq)
+{
+
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SNR_THRESHOLD_PARAMS_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if( wmi_set_snr_threshold_params(arPriv->arWmi, &cmd) != A_OK ) {
+ ret = -EIO;
+ }
+
+ return ret;
+}
+
+static int
+ar6000_ioctl_set_rssi_threshold(struct net_device *dev, struct ifreq *rq)
+{
+#define SWAP_THOLD(thold1, thold2) do { \
+ USER_RSSI_THOLD tmpThold; \
+ tmpThold.tag = thold1.tag; \
+ tmpThold.rssi = thold1.rssi; \
+ thold1.tag = thold2.tag; \
+ thold1.rssi = thold2.rssi; \
+ thold2.tag = tmpThold.tag; \
+ thold2.rssi = tmpThold.rssi; \
+} while (0)
+
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_RSSI_THRESHOLD_PARAMS_CMD cmd;
+ USER_RSSI_PARAMS rssiParams;
+ A_INT32 i, j;
+ int ret = 0;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user((char *)&rssiParams, (char *)((unsigned int *)rq->ifr_data + 1), sizeof(USER_RSSI_PARAMS))) {
+ return -EFAULT;
+ }
+ cmd.weight = rssiParams.weight;
+ cmd.pollTime = rssiParams.pollTime;
+
+ A_MEMCPY(arSta->rssi_map, &rssiParams.tholds, sizeof(arSta->rssi_map));
+ /*
+ * only 6 elements, so use bubble sorting, in ascending order
+ */
+ for (i = 5; i > 0; i--) {
+ for (j = 0; j < i; j++) { /* above tholds */
+ if (arSta->rssi_map[j+1].rssi < arSta->rssi_map[j].rssi) {
+ SWAP_THOLD(arSta->rssi_map[j+1], arSta->rssi_map[j]);
+ } else if (arSta->rssi_map[j+1].rssi == arSta->rssi_map[j].rssi) {
+ return EFAULT;
+ }
+ }
+ }
+ for (i = 11; i > 6; i--) {
+ for (j = 6; j < i; j++) { /* below tholds */
+ if (arSta->rssi_map[j+1].rssi < arSta->rssi_map[j].rssi) {
+ SWAP_THOLD(arSta->rssi_map[j+1], arSta->rssi_map[j]);
+ } else if (arSta->rssi_map[j+1].rssi == arSta->rssi_map[j].rssi) {
+ return EFAULT;
+ }
+ }
+ }
+
+#ifdef DEBUG
+ for (i = 0; i < 12; i++) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("thold[%d].tag: %d, thold[%d].rssi: %d \n",
+ i, arSta->rssi_map[i].tag, i, arSta->rssi_map[i].rssi));
+ }
+#endif
+
+ if (enablerssicompensation) {
+ for (i = 0; i < 6; i++)
+ arSta->rssi_map[i].rssi = rssi_compensation_reverse_calc(arPriv, arSta->rssi_map[i].rssi, TRUE);
+ for (i = 6; i < 12; i++)
+ arSta->rssi_map[i].rssi = rssi_compensation_reverse_calc(arPriv, arSta->rssi_map[i].rssi, FALSE);
+ }
+
+ cmd.thresholdAbove1_Val = arSta->rssi_map[0].rssi;
+ cmd.thresholdAbove2_Val = arSta->rssi_map[1].rssi;
+ cmd.thresholdAbove3_Val = arSta->rssi_map[2].rssi;
+ cmd.thresholdAbove4_Val = arSta->rssi_map[3].rssi;
+ cmd.thresholdAbove5_Val = arSta->rssi_map[4].rssi;
+ cmd.thresholdAbove6_Val = arSta->rssi_map[5].rssi;
+ cmd.thresholdBelow1_Val = arSta->rssi_map[6].rssi;
+ cmd.thresholdBelow2_Val = arSta->rssi_map[7].rssi;
+ cmd.thresholdBelow3_Val = arSta->rssi_map[8].rssi;
+ cmd.thresholdBelow4_Val = arSta->rssi_map[9].rssi;
+ cmd.thresholdBelow5_Val = arSta->rssi_map[10].rssi;
+ cmd.thresholdBelow6_Val = arSta->rssi_map[11].rssi;
+
+ if( wmi_set_rssi_threshold_params(arPriv->arWmi, &cmd) != A_OK ) {
+ ret = -EIO;
+ }
+
+ return ret;
+}
+
+static int
+ar6000_ioctl_set_lq_threshold(struct net_device *dev, struct ifreq *rq)
+{
+
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_LQ_THRESHOLD_PARAMS_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, (char *)((unsigned int *)rq->ifr_data + 1), sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if( wmi_set_lq_threshold_params(arPriv->arWmi, &cmd) != A_OK ) {
+ ret = -EIO;
+ }
+
+ return ret;
+}
+
+
+static int
+ar6000_ioctl_set_probedSsid(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_PROBED_SSID_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_probedSsid_cmd(arPriv->arWmi, cmd.entryIndex, cmd.flag, cmd.ssidLength,
+ cmd.ssid) != A_OK)
+ {
+ ret = -EIO;
+ }
+
+ return ret;
+}
+
+static int
+ar6000_ioctl_set_badAp(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_ADD_BAD_AP_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (cmd.badApIndex > WMI_MAX_BAD_AP_INDEX) {
+ return -EIO;
+ }
+
+ if (A_MEMCMP(cmd.bssid, null_mac, AR6000_ETH_ADDR_LEN) == 0) {
+ /*
+ * This is a delete badAP.
+ */
+ if (wmi_deleteBadAp_cmd(arPriv->arWmi, cmd.badApIndex) != A_OK) {
+ ret = -EIO;
+ }
+ } else {
+ if (wmi_addBadAp_cmd(arPriv->arWmi, cmd.badApIndex, cmd.bssid) != A_OK) {
+ ret = -EIO;
+ }
+ }
+
+ return ret;
+}
+
+static int
+ar6000_ioctl_create_qos(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_CREATE_PSTREAM_CMD cmd;
+ A_STATUS ret;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ ret = wmi_verify_tspec_params(&cmd, tspecCompliance);
+ if (ret == A_OK)
+ ret = wmi_create_pstream_cmd(arPriv->arWmi, &cmd);
+
+ switch (ret) {
+ case A_OK:
+ return 0;
+ case A_EBUSY :
+ return -EBUSY;
+ case A_NO_MEMORY:
+ return -ENOMEM;
+ case A_EINVAL:
+ default:
+ return -EFAULT;
+ }
+}
+
+static int
+ar6000_ioctl_delete_qos(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_DELETE_PSTREAM_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ ret = wmi_delete_pstream_cmd(arPriv->arWmi, cmd.trafficClass, cmd.tsid);
+
+ switch (ret) {
+ case A_OK:
+ return 0;
+ case A_EBUSY :
+ return -EBUSY;
+ case A_NO_MEMORY:
+ return -ENOMEM;
+ case A_EINVAL:
+ default:
+ return -EFAULT;
+ }
+}
+
+static int
+ar6000_ioctl_get_qos_queue(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ struct ar6000_queuereq qreq;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if( copy_from_user(&qreq, rq->ifr_data,
+ sizeof(struct ar6000_queuereq)))
+ return -EFAULT;
+
+ qreq.activeTsids = wmi_get_mapped_qos_queue(arPriv->arWmi, qreq.trafficClass);
+
+ if (copy_to_user(rq->ifr_data, &qreq,
+ sizeof(struct ar6000_queuereq)))
+ {
+ ret = -EFAULT;
+ }
+
+ return ret;
+}
+
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+static A_STATUS
+ar6000_ioctl_tcmd_cmd_resp(struct net_device *dev, struct ifreq *rq, A_UINT8 *data, A_UINT32 len)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UINT8 buf[4+TC_CMDS_SIZE_MAX];
+ int ret = 0;
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ ar->tcmdRxReport = 0;
+ if (wmi_test_cmd(arPriv->arWmi, data, len) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, ar->tcmdRxReport != 0, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ *(A_UINT16*)&(buf[0]) = ar->tcmdResp.len;
+ buf[2] = ar->tcmdResp.ver;
+ A_MEMCPY((buf+4), ar->tcmdResp.buf, sizeof(ar->tcmdResp.buf));
+
+ if (!ret && copy_to_user(rq->ifr_data, buf, sizeof(buf))) {
+ ret = -EFAULT;
+ }
+
+ up(&ar->arSem);
+
+ return ret;
+}
+
+static A_STATUS
+ar6000_ioctl_tcmd_get_rx_report(struct net_device *dev,
+ struct ifreq *rq, A_UINT8 *data, A_UINT32 len)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UINT32 buf[4+TCMD_MAX_RATES];
+ int ret = 0;
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ ar->tcmdRxReport = 0;
+ if (wmi_test_cmd(arPriv->arWmi, data, len) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, ar->tcmdRxReport != 0, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ buf[0] = ar->tcmdRxTotalPkt;
+ buf[1] = ar->tcmdRxRssi;
+ buf[2] = ar->tcmdRxcrcErrPkt;
+ buf[3] = ar->tcmdRxsecErrPkt;
+ A_MEMCPY(((A_UCHAR *)buf)+(4*sizeof(A_UINT32)), ar->tcmdRateCnt, sizeof(ar->tcmdRateCnt));
+ A_MEMCPY(((A_UCHAR *)buf)+(4*sizeof(A_UINT32))+(TCMD_MAX_RATES *sizeof(A_UINT16)), ar->tcmdRateCntShortGuard, sizeof(ar->tcmdRateCntShortGuard));
+
+ if (!ret && copy_to_user(rq->ifr_data, buf, sizeof(buf))) {
+ ret = -EFAULT;
+ }
+
+ up(&ar->arSem);
+
+ return ret;
+}
+
+void
+ar6000_tcmd_rx_report_event(AR_SOFTC_DEV_T *arPriv, A_UINT8 * results, int len)
+{
+
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ TCMD_CONT_RX * rx_rep = (TCMD_CONT_RX *)results;
+
+ if (TC_CMD_RESP == rx_rep->act) {
+ TC_CMDS *tCmd = (TC_CMDS *)results;
+ ar->tcmdResp.len = tCmd->hdr.u.parm.length;
+ ar->tcmdResp.ver = tCmd->hdr.u.parm.version;
+ A_MEMZERO(ar->tcmdResp.buf, sizeof(ar->tcmdResp.buf));
+ A_MEMCPY(ar->tcmdResp.buf, tCmd->buf, sizeof(ar->tcmdResp.buf));
+ ar->tcmdRxReport = 1;
+ }
+ else { /*(rx_rep->act == TCMD_CONT_RX_REPORT) */
+ if (enablerssicompensation) {
+ rx_rep->u.report.rssiInDBm = rssi_compensation_calc_tcmd(ar, tcmdRxFreq, rx_rep->u.report.rssiInDBm,rx_rep->u.report.totalPkt);
+ }
+
+
+ ar->tcmdRxTotalPkt = rx_rep->u.report.totalPkt;
+ ar->tcmdRxRssi = rx_rep->u.report.rssiInDBm;
+ ar->tcmdRxcrcErrPkt = rx_rep->u.report.crcErrPkt;
+ ar->tcmdRxsecErrPkt = rx_rep->u.report.secErrPkt;
+ ar->tcmdRxReport = 1;
+ A_MEMZERO(ar->tcmdRateCnt, sizeof(ar->tcmdRateCnt));
+ A_MEMZERO(ar->tcmdRateCntShortGuard, sizeof(ar->tcmdRateCntShortGuard));
+ A_MEMCPY(ar->tcmdRateCnt, rx_rep->u.report.rateCnt, sizeof(ar->tcmdRateCnt));
+ A_MEMCPY(ar->tcmdRateCntShortGuard, rx_rep->u.report.rateCntShortGuard, sizeof(ar->tcmdRateCntShortGuard));
+ }
+
+ wake_up(&arPriv->arEvent);
+}
+#endif /* CONFIG_HOST_TCMD_SUPPORT*/
+
+static int
+ar6000_ioctl_set_error_report_bitmask(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_TARGET_ERROR_REPORT_BITMASK cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ ret = wmi_set_error_report_bitmask(arPriv->arWmi, cmd.bitmask);
+
+ return (ret==0 ? ret : -EINVAL);
+}
+
+static int
+ar6000_clear_target_stats(struct net_device *dev)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ TARGET_STATS *pStats = &arPriv->arTargetStats;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ A_MEMZERO(pStats, sizeof(TARGET_STATS));
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ return ret;
+}
+
+static int
+ar6000_ioctl_get_target_stats(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ TARGET_STATS_CMD *pcmd;
+ TARGET_STATS *pStats = &arPriv->arTargetStats;
+ int ret = 0;
+
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+ pcmd = (TARGET_STATS_CMD *) A_MALLOC(sizeof(TARGET_STATS_CMD));
+
+ if (pcmd == NULL) {
+ return -ENOMEM;
+ }
+ if (copy_from_user(pcmd, rq->ifr_data, sizeof(*pcmd))) {
+ A_FREE(pcmd);
+ return -EFAULT;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ A_FREE(pcmd);
+ return -ERESTARTSYS;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ A_FREE(pcmd);
+ return -EBUSY;
+ }
+
+ arPriv->statsUpdatePending = TRUE;
+
+ if(wmi_get_stats_cmd(arPriv->arWmi) != A_OK) {
+ up(&ar->arSem);
+ A_FREE(pcmd);
+ return -EIO;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->statsUpdatePending == FALSE, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ if (!ret && copy_to_user(rq->ifr_data, pStats, sizeof(*pStats))) {
+ ret = -EFAULT;
+ }
+
+ if (pcmd->clearStats == 1) {
+ ret = ar6000_clear_target_stats(dev);
+ }
+
+ up(&ar->arSem);
+
+ a_meminfo_report(FALSE);
+ A_FREE(pcmd);
+
+ return ret;
+}
+
+static int
+ar6000_ioctl_get_ap_stats(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ A_UINT32 action; /* Allocating only the desired space on the frame. Declaring is as a WMI_AP_MODE_STAT variable results in exceeding the compiler imposed limit on the maximum frame size */
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_PER_STA_STAT *pStats = ar->arAPStats;
+ WMI_AP_MODE_STAT *pret_stat;
+ A_UINT8 i, j=0;
+
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&action, (char *)((unsigned int*)rq->ifr_data + 1),
+ sizeof(A_UINT32)))
+ {
+ return -EFAULT;
+ }
+ if (action == AP_CLEAR_STATS) {
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ for(i = 0; i < NUM_CONN; i++) {
+ if(ar->connTbl[i].arPriv == arPriv) {
+ pStats[i].tx_bytes = 0;
+ pStats[i].tx_pkts = 0;
+ pStats[i].tx_error = 0;
+ pStats[i].tx_discard = 0;
+ pStats[i].rx_bytes = 0;
+ pStats[i].rx_pkts = 0;
+ pStats[i].rx_error = 0;
+ pStats[i].rx_discard = 0;
+ }
+ }
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ return ret;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ arPriv->statsUpdatePending = TRUE;
+
+ if(wmi_get_stats_cmd(arPriv->arWmi) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->statsUpdatePending == FALSE, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ pret_stat = (WMI_AP_MODE_STAT *) A_MALLOC(sizeof(WMI_AP_MODE_STAT));
+ if (pret_stat == NULL) {
+ return -ENOMEM;
+ }
+ A_MEMZERO(pret_stat, sizeof(*pret_stat));
+ for(i = 0; i < NUM_CONN; i++) {
+ if(ar->connTbl[i].arPriv == arPriv) {
+ pret_stat->sta[j].aid = pStats[i].aid;
+ pret_stat->sta[j].tx_bytes = pStats[i].tx_bytes;
+ pret_stat->sta[j].tx_pkts = pStats[i].tx_pkts;
+ pret_stat->sta[j].tx_error = pStats[i].tx_error;
+ pret_stat->sta[j].tx_discard = pStats[i].tx_discard;
+ pret_stat->sta[j].rx_bytes = pStats[i].rx_bytes;
+ pret_stat->sta[j].rx_pkts = pStats[i].rx_pkts;
+ pret_stat->sta[j].rx_error = pStats[i].rx_error;
+ pret_stat->sta[j].rx_discard = pStats[i].rx_discard;
+ j++;
+ }
+ }
+
+ if (!ret && copy_to_user(rq->ifr_data, pret_stat, sizeof(*pret_stat))) {
+ ret = -EFAULT;
+ }
+
+ up(&ar->arSem);
+ A_FREE(pret_stat);
+ return ret;
+}
+
+static int
+ar6000_ioctl_set_access_params(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_ACCESS_PARAMS_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_access_params_cmd(arPriv->arWmi, cmd.ac, cmd.txop, cmd.eCWmin, cmd.eCWmax,
+ cmd.aifsn) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return (ret);
+}
+
+static int
+ar6000_ioctl_set_disconnect_timeout(struct net_device *dev, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_DISC_TIMEOUT_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, rq->ifr_data, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_disctimeout_cmd(arPriv->arWmi, cmd.disconnectTimeout) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return (ret);
+}
+
+static int
+ar6000_xioctl_set_voice_pkt_size(struct net_device *dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_VOICE_PKT_SIZE_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_voice_pkt_size_cmd(arPriv->arWmi, cmd.voicePktSize) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+
+ return (ret);
+}
+
+static int
+ar6000_xioctl_set_max_sp_len(struct net_device *dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_MAX_SP_LEN_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_max_sp_len_cmd(arPriv->arWmi, cmd.maxSPLen) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return (ret);
+}
+
+#ifdef BTCOEX
+static int
+ar6000_xioctl_set_bt_status_cmd(struct net_device *dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BT_STATUS_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_bt_status_cmd(arPriv->arWmi, cmd.streamType, cmd.status) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return (ret);
+}
+
+static int
+ar6000_xioctl_set_bt_params_cmd(struct net_device *dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BT_PARAMS_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_bt_params_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return (ret);
+}
+
+static int
+ar6000_xioctl_set_btcoex_fe_ant_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_FE_ANT_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_btcoex_fe_ant_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return(ret);
+}
+
+static int
+ar6000_xioctl_set_btcoex_colocated_bt_dev_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_btcoex_colocated_bt_dev_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return(ret);
+}
+
+static int
+ar6000_xioctl_set_btcoex_btinquiry_page_config_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_btcoex_btinquiry_page_config_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return(ret);
+}
+
+static int
+ar6000_xioctl_set_btcoex_sco_config_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_SCO_CONFIG_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_btcoex_sco_config_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return(ret);
+}
+
+static int
+ar6000_xioctl_set_btcoex_a2dp_config_cmd(struct net_device * dev,
+ char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_A2DP_CONFIG_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_btcoex_a2dp_config_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return(ret);
+}
+
+static int
+ar6000_xioctl_set_btcoex_aclcoex_config_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_btcoex_aclcoex_config_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return(ret);
+}
+
+static int
+ar60000_xioctl_set_btcoex_debug_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_DEBUG_CMD cmd;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_btcoex_debug_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ return(ret);
+}
+
+static int
+ar6000_xioctl_set_btcoex_bt_operating_status_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD cmd;
+ int ret = 0;
+ A_UINT32 btProfileType;
+ A_UINT32 btOperatingStatus;
+
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ btProfileType = cmd.btProfileType;
+ btOperatingStatus = cmd.btOperatingStatus;
+
+ if (BT_STREAM_SCAN != btProfileType &&
+ BT_STATUS_ON == btOperatingStatus &&
+ arPriv->arNetworkType == AP_NETWORK)
+ {
+ switch (ar->delbaState)
+ {
+ case REASON_DELBA_INIT:
+ ar6000_send_delba (ar, REASON_TEAR_DOWN);
+ ar->delbaState = REASON_TEAR_DOWN;
+ break;
+ case REASON_TEAR_DOWN:
+ break;
+ case REASON_DELBA_TIMEOUT:
+ //
+ // Uninitialize timer, and keep the state as TEAR_DOWN for rearm the timer
+ //
+ ar->IsdelbaTimerInitialized = FALSE;
+ A_UNTIMEOUT (&ar->delbaTimer);
+ ar->delbaState = REASON_TEAR_DOWN;
+ break;
+ }
+
+ }
+
+ if (wmi_set_btcoex_bt_operating_status_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+
+ if (BT_STREAM_SCAN != btProfileType &&
+ BT_STATUS_OFF == btOperatingStatus &&
+ arPriv->arNetworkType == AP_NETWORK)
+ {
+ switch (ar->delbaState)
+ {
+ case REASON_DELBA_INIT:
+ break;
+ case REASON_TEAR_DOWN:
+ ar->delbaState = REASON_DELBA_TIMEOUT;
+
+ // Initiate A_TIMER
+ ar->IsdelbaTimerInitialized = TRUE;
+ A_TIMEOUT_MS (&ar->delbaTimer, DELBA_TIMEOUT, 0);
+ break;
+
+ case REASON_DELBA_TIMEOUT:
+ break;
+ }
+ }
+
+ return(ret);
+}
+
+static int
+ar6000_xioctl_get_btcoex_config_cmd(struct net_device * dev, char * userdata,
+ struct ifreq *rq)
+{
+
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR6000_BTCOEX_CONFIG btcoexConfig;
+ WMI_BTCOEX_CONFIG_EVENT *pbtcoexConfigEv = &arPriv->arBtcoexConfig;
+
+ int ret = 0;
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+ if (copy_from_user(&btcoexConfig.configCmd, userdata, sizeof(AR6000_BTCOEX_CONFIG))) {
+ return -EFAULT;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (wmi_get_btcoex_config_cmd(arPriv->arWmi, (WMI_GET_BTCOEX_CONFIG_CMD *)&btcoexConfig.configCmd) != A_OK)
+ {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ arPriv->statsUpdatePending = TRUE;
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->statsUpdatePending == FALSE, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ if (!ret && copy_to_user(btcoexConfig.configEvent, pbtcoexConfigEv, sizeof(WMI_BTCOEX_CONFIG_EVENT))) {
+ ret = -EFAULT;
+ }
+ up(&ar->arSem);
+ return ret;
+}
+
+static int
+ar6000_xioctl_get_btcoex_stats_cmd(struct net_device * dev, char * userdata, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR6000_BTCOEX_STATS btcoexStats;
+ WMI_BTCOEX_STATS_EVENT *pbtcoexStats = &arPriv->arBtcoexStats;
+ int ret = 0;
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (copy_from_user(&btcoexStats.statsEvent, userdata, sizeof(AR6000_BTCOEX_CONFIG))) {
+ return -EFAULT;
+ }
+
+ if (wmi_get_btcoex_stats_cmd(arPriv->arWmi) != A_OK)
+ {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ arPriv->statsUpdatePending = TRUE;
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->statsUpdatePending == FALSE, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ if (!ret && copy_to_user(btcoexStats.statsEvent, pbtcoexStats, sizeof(WMI_BTCOEX_STATS_EVENT))) {
+ ret = -EFAULT;
+ }
+
+
+ up(&ar->arSem);
+
+ return(ret);
+}
+#endif
+
+static int
+ar6000_xioctl_set_excess_tx_retry_thres_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_SET_EXCESS_TX_RETRY_THRES_CMD cmd;
+ int ret = 0;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_excess_tx_retry_thres_cmd(arPriv->arWmi, &cmd) != A_OK)
+ {
+ ret = -EINVAL;
+ }
+ return(ret);
+}
+
+#ifdef WAC
+static int
+ar6000_xioctl_wac_ctrl_req_get_cmd(struct net_device * dev, char * userdata, struct ifreq *rq)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_WAC_CTRL_REQ_CMD cmd;
+ int ret = 0;
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(WMI_WAC_CTRL_REQ_CMD))) {
+ return -EFAULT;
+ }
+
+ if (wmi_wac_ctrl_req_cmd(arPriv->arWmi, &cmd) != A_OK)
+ {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ arPriv->statsUpdatePending = TRUE;
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->statsUpdatePending == FALSE, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ if (!ret && copy_to_user(rq->ifr_data, &arPriv->wacInfo, sizeof(WMI_GET_WAC_INFO))) {
+ ret = -EFAULT;
+ }
+
+ up(&ar->arSem);
+
+ return(ret);
+}
+#endif
+
+static int
+ar6000_xioctl_set_passphrase_cmd(struct net_device * dev, char * userdata)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ WMI_SET_PASSPHRASE_CMD cmd;
+ int ret = 0;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ return -EFAULT;
+ }
+
+ if (wmi_set_passphrase_cmd(arPriv->arWmi, &cmd) == A_OK)
+ {
+ /* enable WPA offload */
+ arSta->arConnectCtrlFlags |= CONNECT_DO_WPA_OFFLOAD;
+ ret = 0;
+ } else {
+ ret = -EINVAL;
+ }
+ return(ret);
+}
+
+#ifdef CONFIG_HOST_GPIO_SUPPORT
+struct ar6000_gpio_intr_wait_cmd_s gpio_intr_results;
+/* gpio_reg_results and gpio_data_available are protected by arSem */
+static struct ar6000_gpio_register_cmd_s gpio_reg_results;
+static A_BOOL gpio_data_available; /* Requested GPIO data available */
+static A_BOOL gpio_intr_available; /* GPIO interrupt info available */
+static A_BOOL gpio_ack_received; /* GPIO ack was received */
+
+/* Host-side initialization for General Purpose I/O support */
+void ar6000_gpio_init(void)
+{
+ gpio_intr_available = FALSE;
+ gpio_data_available = FALSE;
+ gpio_ack_received = FALSE;
+}
+
+/*
+ * Called when a GPIO interrupt is received from the Target.
+ * intr_values shows which GPIO pins have interrupted.
+ * input_values shows a recent value of GPIO pins.
+ */
+void
+ar6000_gpio_intr_rx(AR_SOFTC_DEV_T *arPriv, A_UINT32 intr_mask, A_UINT32 input_values)
+{
+ gpio_intr_results.intr_mask = intr_mask;
+ gpio_intr_results.input_values = input_values;
+ *((volatile A_BOOL *)&gpio_intr_available) = TRUE;
+ wake_up(&arPriv->arEvent);
+}
+
+/*
+ * This is called when a response is received from the Target
+ * for a previous or ar6000_gpio_input_get or ar6000_gpio_register_get
+ * call.
+ */
+void
+ar6000_gpio_data_rx(AR_SOFTC_DEV_T *arPriv, A_UINT32 reg_id, A_UINT32 value)
+{
+ gpio_reg_results.gpioreg_id = reg_id;
+ gpio_reg_results.value = value;
+ *((volatile A_BOOL *)&gpio_data_available) = TRUE;
+ wake_up(&arPriv->arEvent);
+}
+
+/*
+ * This is called when an acknowledgement is received from the Target
+ * for a previous or ar6000_gpio_output_set or ar6000_gpio_register_set
+ * call.
+ */
+void
+ar6000_gpio_ack_rx(AR_SOFTC_DEV_T *arPriv)
+{
+ gpio_ack_received = TRUE;
+ wake_up(&arPriv->arEvent);
+}
+
+A_STATUS
+ar6000_gpio_output_set(struct net_device *dev,
+ A_UINT32 set_mask,
+ A_UINT32 clear_mask,
+ A_UINT32 enable_mask,
+ A_UINT32 disable_mask)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ gpio_ack_received = FALSE;
+ return wmi_gpio_output_set(arPriv->arWmi,
+ set_mask, clear_mask, enable_mask, disable_mask);
+}
+
+static A_STATUS
+ar6000_gpio_input_get(struct net_device *dev)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ *((volatile A_BOOL *)&gpio_data_available) = FALSE;
+ return wmi_gpio_input_get(arPriv->arWmi);
+}
+
+static A_STATUS
+ar6000_gpio_register_set(struct net_device *dev,
+ A_UINT32 gpioreg_id,
+ A_UINT32 value)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ gpio_ack_received = FALSE;
+ return wmi_gpio_register_set(arPriv->arWmi, gpioreg_id, value);
+}
+
+static A_STATUS
+ar6000_gpio_register_get(struct net_device *dev,
+ A_UINT32 gpioreg_id)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ *((volatile A_BOOL *)&gpio_data_available) = FALSE;
+ return wmi_gpio_register_get(arPriv->arWmi, gpioreg_id);
+}
+
+static A_STATUS
+ar6000_gpio_intr_ack(struct net_device *dev,
+ A_UINT32 ack_mask)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ gpio_intr_available = FALSE;
+ return wmi_gpio_intr_ack(arPriv->arWmi, ack_mask);
+}
+#endif /* CONFIG_HOST_GPIO_SUPPORT */
+
+#if defined(CONFIG_TARGET_PROFILE_SUPPORT)
+static struct prof_count_s prof_count_results;
+static A_BOOL prof_count_available; /* Requested GPIO data available */
+
+static A_STATUS
+prof_count_get(struct net_device *dev)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+
+ *((volatile A_BOOL *)&prof_count_available) = FALSE;
+ return wmi_prof_count_get_cmd(arPriv->arWmi);
+}
+
+/*
+ * This is called when a response is received from the Target
+ * for a previous prof_count_get call.
+ */
+void
+prof_count_rx(A_UINT32 addr, A_UINT32 count)
+{
+ prof_count_results.addr = addr;
+ prof_count_results.count = count;
+ *((volatile A_BOOL *)&prof_count_available) = TRUE;
+ wake_up(&arEvent);
+}
+#endif /* CONFIG_TARGET_PROFILE_SUPPORT */
+
+#ifdef BTCOEX
+static A_STATUS
+ar6000_create_acl_data_osbuf(struct net_device *dev, A_UINT8 *userdata, void **p_osbuf)
+{
+ void *osbuf = NULL;
+ A_UINT8 tmp_space[8];
+ HCI_ACL_DATA_PKT *acl;
+ A_UINT8 hdr_size, *datap=NULL;
+ A_STATUS ret = A_OK;
+
+ /* ACL is in data path. There is a need to create pool
+ * mechanism for allocating and freeing NETBUFs - ToDo later.
+ */
+
+ *p_osbuf = NULL;
+ acl = (HCI_ACL_DATA_PKT *)tmp_space;
+ hdr_size = sizeof(acl->hdl_and_flags) + sizeof(acl->data_len);
+
+ do {
+ if (a_copy_from_user(acl, userdata, hdr_size)) {
+ ret = A_EFAULT;
+ break;
+ }
+
+ osbuf = A_NETBUF_ALLOC(hdr_size + acl->data_len);
+ if (osbuf == NULL) {
+ ret = A_NO_MEMORY;
+ break;
+ }
+ A_NETBUF_PUT(osbuf, hdr_size + acl->data_len);
+ datap = (A_UINT8 *)A_NETBUF_DATA(osbuf);
+
+ /* Real copy to osbuf */
+ acl = (HCI_ACL_DATA_PKT *)(datap);
+ A_MEMCPY(acl, tmp_space, hdr_size);
+ if (a_copy_from_user(acl->data, userdata + hdr_size, acl->data_len)) {
+ ret = A_EFAULT;
+ break;
+ }
+ } while(FALSE);
+
+ if (ret == A_OK) {
+ *p_osbuf = osbuf;
+ } else {
+ A_NETBUF_FREE(osbuf);
+ }
+ return ret;
+}
+#endif
+
+int
+ar6000_ioctl_ap_setparam(AR_SOFTC_DEV_T *arPriv, int param, int value)
+{
+ int ret=0;
+
+ switch(param) {
+ case IEEE80211_PARAM_WPA:
+ switch (value) {
+ case WPA_MODE_WPA1:
+ arPriv->arAuthMode = WMI_WPA_AUTH;
+ break;
+ case WPA_MODE_WPA2:
+ arPriv->arAuthMode = WMI_WPA2_AUTH;
+ break;
+ case WPA_MODE_AUTO:
+ arPriv->arAuthMode = WMI_WPA_AUTH | WMI_WPA2_AUTH;
+ break;
+ case WPA_MODE_NONE:
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ break;
+ }
+ break;
+ case IEEE80211_PARAM_AUTHMODE:
+ if(value == IEEE80211_AUTH_WPA_PSK) {
+ if (WMI_WPA_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA_PSK_AUTH;
+ } else if (WMI_WPA2_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA2_PSK_AUTH;
+ } else if ((WMI_WPA_AUTH | WMI_WPA2_AUTH) == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA_PSK_AUTH | WMI_WPA2_PSK_AUTH;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Error - Setting PSK "\
+ "mode when WPA param was set to %d\n",
+ arPriv->arAuthMode));
+ ret = -EIO;
+ }
+ }
+ break;
+ case IEEE80211_PARAM_UCASTCIPHER:
+ arPriv->arPairwiseCrypto = 0;
+ if(value & (1<<IEEE80211_CIPHER_AES_CCM)) {
+ arPriv->arPairwiseCrypto |= AES_CRYPT;
+ }
+ if(value & (1<<IEEE80211_CIPHER_TKIP)) {
+ arPriv->arPairwiseCrypto |= TKIP_CRYPT;
+ }
+ if(!arPriv->arPairwiseCrypto) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,
+ ("Error - Invalid cipher in WPA \n"));
+ ret = -EIO;
+ }
+ break;
+ case IEEE80211_PARAM_PRIVACY:
+ if(value == 0) {
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+ }
+ break;
+#ifdef WAPI_ENABLE
+ case IEEE80211_PARAM_WAPI:
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("WAPI Policy: %d\n", value));
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ if(value & 0x1) {
+ arPriv->arPairwiseCrypto = WAPI_CRYPT;
+ arPriv->arGroupCrypto = WAPI_CRYPT;
+ } else {
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ }
+ break;
+#endif
+ }
+ return ret;
+}
+
+int
+ar6000_ioctl_setparam(AR_SOFTC_DEV_T *arPriv, int param, int value)
+{
+ A_BOOL profChanged = FALSE;
+ int ret=0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if(arPriv->arNextMode == AP_NETWORK) {
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ switch (param) {
+ case IEEE80211_PARAM_WPA:
+ case IEEE80211_PARAM_AUTHMODE:
+ case IEEE80211_PARAM_UCASTCIPHER:
+ case IEEE80211_PARAM_PRIVACY:
+ case IEEE80211_PARAM_WAPI:
+ ret = ar6000_ioctl_ap_setparam(arPriv, param, value);
+ return ret;
+ }
+ }
+
+ switch (param) {
+ case IEEE80211_PARAM_WPA:
+ switch (value) {
+ case WPA_MODE_WPA1:
+ arPriv->arAuthMode = WMI_WPA_AUTH;
+ profChanged = TRUE;
+ break;
+ case WPA_MODE_WPA2:
+ arPriv->arAuthMode = WMI_WPA2_AUTH;
+ profChanged = TRUE;
+ break;
+ case WPA_MODE_NONE:
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ profChanged = TRUE;
+ break;
+ }
+ break;
+ case IEEE80211_PARAM_AUTHMODE:
+ switch(value) {
+ case IEEE80211_AUTH_WPA_PSK:
+ if (WMI_WPA_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA_PSK_AUTH;
+ profChanged = TRUE;
+ } else if (WMI_WPA2_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA2_PSK_AUTH;
+ profChanged = TRUE;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Error - Setting PSK "\
+ "mode when WPA param was set to %d\n",
+ arPriv->arAuthMode));
+ ret = -EIO;
+ }
+ break;
+ case IEEE80211_AUTH_WPA_CCKM:
+ if (WMI_WPA2_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA2_AUTH_CCKM;
+ } else {
+ arPriv->arAuthMode = WMI_WPA_AUTH_CCKM;
+ }
+ break;
+ default:
+ break;
+ }
+ break;
+ case IEEE80211_PARAM_UCASTCIPHER:
+ switch (value) {
+ case IEEE80211_CIPHER_AES_CCM:
+ arPriv->arPairwiseCrypto = AES_CRYPT;
+ profChanged = TRUE;
+ break;
+ case IEEE80211_CIPHER_TKIP:
+ arPriv->arPairwiseCrypto = TKIP_CRYPT;
+ profChanged = TRUE;
+ break;
+ case IEEE80211_CIPHER_WEP:
+ arPriv->arPairwiseCrypto = WEP_CRYPT;
+ profChanged = TRUE;
+ break;
+ case IEEE80211_CIPHER_NONE:
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ profChanged = TRUE;
+ break;
+ }
+ break;
+ case IEEE80211_PARAM_UCASTKEYLEN:
+ if (!IEEE80211_IS_VALID_WEP_CIPHER_LEN(value)) {
+ ret = -EIO;
+ } else {
+ arPriv->arPairwiseCryptoLen = value;
+ }
+ break;
+ case IEEE80211_PARAM_MCASTCIPHER:
+ switch (value) {
+ case IEEE80211_CIPHER_AES_CCM:
+ arPriv->arGroupCrypto = AES_CRYPT;
+ profChanged = TRUE;
+ break;
+ case IEEE80211_CIPHER_TKIP:
+ arPriv->arGroupCrypto = TKIP_CRYPT;
+ profChanged = TRUE;
+ break;
+ case IEEE80211_CIPHER_WEP:
+ arPriv->arGroupCrypto = WEP_CRYPT;
+ profChanged = TRUE;
+ break;
+ case IEEE80211_CIPHER_NONE:
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ profChanged = TRUE;
+ break;
+ }
+ break;
+ case IEEE80211_PARAM_MCASTKEYLEN:
+ if (!IEEE80211_IS_VALID_WEP_CIPHER_LEN(value)) {
+ ret = -EIO;
+ } else {
+ arPriv->arGroupCryptoLen = value;
+ }
+ break;
+ case IEEE80211_PARAM_COUNTERMEASURES:
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+ wmi_set_tkip_countermeasures_cmd(arPriv->arWmi, value);
+ break;
+ default:
+ break;
+ }
+ if ((arPriv->arNextMode != AP_NETWORK) && (profChanged == TRUE)) {
+ /*
+ * profile has changed. Erase ssid to signal change
+ */
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ }
+
+ return ret;
+}
+
+int
+ar6000_sendkey(AR_SOFTC_DEV_T *arPriv, struct ieee80211req_key *ik, KEY_USAGE keyUsage)
+{
+ A_STATUS status;
+ CRYPTO_TYPE keyType = NONE_CRYPT;
+
+ switch (ik->ik_type) {
+ case IEEE80211_CIPHER_WEP:
+ keyType = WEP_CRYPT;
+ break;
+ case IEEE80211_CIPHER_TKIP:
+ keyType = TKIP_CRYPT;
+ break;
+ case IEEE80211_CIPHER_AES_CCM:
+ keyType = AES_CRYPT;
+ break;
+ default:
+ break;
+ }
+
+ if (IEEE80211_CIPHER_CCKM_KRK != ik->ik_type) {
+ if (NONE_CRYPT == keyType) {
+ return A_ERROR;
+ }
+
+ if ((WEP_CRYPT == keyType)&&(!arPriv->arConnected)) {
+ int index = ik->ik_keyix;
+
+ if (!IEEE80211_IS_VALID_WEP_CIPHER_LEN(ik->ik_keylen)) {
+ return A_ERROR;
+ }
+
+ A_MEMZERO(arPriv->arWepKeyList[index].arKey,
+ sizeof(arPriv->arWepKeyList[index].arKey));
+ A_MEMCPY(arPriv->arWepKeyList[index].arKey, ik->ik_keydata, ik->ik_keylen);
+ arPriv->arWepKeyList[index].arKeyLen = ik->ik_keylen;
+
+ if(ik->ik_flags & IEEE80211_KEY_DEFAULT){
+ arPriv->arDefTxKeyIndex = index;
+ }
+
+ return A_OK;
+ }
+
+ status = wmi_addKey_cmd(arPriv->arWmi, ik->ik_keyix, keyType, keyUsage,
+ ik->ik_keylen, (A_UINT8 *)&ik->ik_keyrsc,
+ ik->ik_keydata, KEY_OP_INIT_VAL, ik->ik_macaddr,
+ SYNC_BOTH_WMIFLAG);
+
+ } else {
+ status = wmi_add_krk_cmd(arPriv->arWmi, ik->ik_keydata);
+ }
+
+ return status;
+}
+
+int
+ar6000_ioctl_setkey(AR_SOFTC_DEV_T *arPriv, struct ieee80211req_key *ik)
+{
+ KEY_USAGE keyUsage;
+ A_STATUS status;
+ CRYPTO_TYPE keyType = NONE_CRYPT;
+
+ if ( (0 == memcmp(ik->ik_macaddr, null_mac, IEEE80211_ADDR_LEN)) ||
+ (0 == memcmp(ik->ik_macaddr, bcast_mac, IEEE80211_ADDR_LEN)) ) {
+ keyUsage = GROUP_USAGE;
+ } else {
+ keyUsage = PAIRWISE_USAGE;
+ }
+
+ if(arPriv->arNextMode == AP_NETWORK) {
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+
+ if (keyUsage == GROUP_USAGE) {
+ A_MEMCPY(&arAp->ap_mode_bkey, ik, sizeof(struct ieee80211req_key));
+ }
+
+#ifdef WAPI_ENABLE
+ if(arPriv->arPairwiseCrypto == WAPI_CRYPT) {
+ return ap_set_wapi_key(arPriv, ik);
+ }
+#endif
+
+ status = ar6000_sendkey(arPriv, ik, keyUsage);
+
+ } else {
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+
+ #ifdef USER_KEYS
+ arSta->user_saved_keys.keyOk = FALSE;
+ arSta->user_saved_keys.keyType = keyType;
+ if (keyUsage == GROUP_USAGE) {
+ A_MEMCPY(&arSta->user_saved_keys.bcast_ik, ik,
+ sizeof(struct ieee80211req_key));
+ } else {
+ A_MEMCPY(&arSta->user_saved_keys.ucast_ik, ik,
+ sizeof(struct ieee80211req_key));
+ }
+ #endif
+
+ if (((WMI_WPA_PSK_AUTH == arPriv->arAuthMode) ||
+ (WMI_WPA2_PSK_AUTH == arPriv->arAuthMode)) &&
+ (GROUP_USAGE & keyUsage))
+ {
+ A_UNTIMEOUT(&arSta->disconnect_timer);
+ }
+
+ status = ar6000_sendkey(arPriv, ik, keyUsage);
+
+ #ifdef USER_KEYS
+ if (status == A_OK) {
+ arSta->user_saved_keys.keyOk = TRUE;
+ }
+ #endif
+ }
+
+ if (status != A_OK) {
+ return -EIO;
+ }
+
+ return 0;
+}
+int ar6000_xioctl_add_wowptn(AR_SOFTC_DEV_T *arPriv, char *userdata)
+{
+#define WOW_PATTERN_SIZE 64
+#define WOW_MASK_SIZE 64
+ WMI_ADD_WOW_PATTERN_CMD cmd;
+ AR_SOFTC_T *ar=arPriv->arSoftc;
+ int ret = 0;
+ A_UINT8 *pmask_data;
+ A_UINT8 *ppattern_data;
+ pmask_data = (A_UINT8 *) A_MALLOC(WOW_MASK_SIZE * sizeof(A_UINT8));
+ if (pmask_data == NULL) {
+ return -ENOMEM;
+ }
+ ppattern_data = (A_UINT8 *) A_MALLOC(WOW_PATTERN_SIZE * sizeof(A_UINT8));
+ if (ppattern_data == NULL) {
+ A_FREE(pmask_data);
+ return -ENOMEM;
+ }
+ A_MEMZERO(pmask_data, WOW_MASK_SIZE * sizeof(A_UINT8));
+ A_MEMZERO(ppattern_data, WOW_PATTERN_SIZE * sizeof(A_UINT8));
+
+ do {
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ break;
+ }
+ if(copy_from_user(&cmd, userdata,
+ sizeof(WMI_ADD_WOW_PATTERN_CMD)))
+ {
+ ret = -EFAULT;
+ break;
+ }
+ if (copy_from_user(ppattern_data,
+ userdata + 3,
+ cmd.filter_size))
+ {
+ ret = -EFAULT;
+ break;
+ }
+ if (copy_from_user(pmask_data,
+ (userdata + 3 + cmd.filter_size),
+ cmd.filter_size))
+ {
+ ret = -EFAULT;
+ break;
+ }
+ if (wmi_add_wow_pattern_cmd(arPriv->arWmi,
+ &cmd, ppattern_data, pmask_data,
+ cmd.filter_size) != A_OK)
+ {
+ ret = -EIO;
+ }
+ } while(FALSE);
+ A_FREE(pmask_data);
+ A_FREE(ppattern_data);
+ return ret;
+#undef WOW_PATTERN_SIZE
+#undef WOW_MASK_SIZE
+}
+
+int ar6000_xioctl_dump_htccredit(AR_SOFTC_DEV_T *arPriv)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ int ret = 0;
+ if (ar->arHtcTarget != NULL) {
+#ifdef ATH_DEBUG_MODULE
+ HTCDumpCreditStates(ar->arHtcTarget);
+#endif /* ATH_DEBUG_MODULE */
+#ifdef HTC_EP_STAT_PROFILING
+ {
+ HTC_ENDPOINT_STATS *pstats;
+ int i;
+ pstats = (HTC_ENDPOINT_STATS *) A_MALLOC(sizeof(HTC_ENDPOINT_STATS));
+ if (pstats == NULL) {
+ return -ENOMEM;
+ }
+
+ for (i = 0; i < 5; i++) {
+ if (HTCGetEndpointStatistics(ar->arHtcTarget,
+ i,
+ HTC_EP_STAT_SAMPLE_AND_CLEAR,
+ pstats)) {
+ A_PRINTF(KERN_ALERT"------- Profiling Endpoint : %d \n", i);
+ A_PRINTF(KERN_ALERT"TxCreditLowIndications : %d \n", pstats->TxCreditLowIndications);
+ A_PRINTF(KERN_ALERT"TxIssued : %d \n", pstats->TxIssued);
+ A_PRINTF(KERN_ALERT"TxDropped: %d \n", pstats->TxDropped);
+ A_PRINTF(KERN_ALERT"TxPacketsBundled : %d \n", pstats->TxPacketsBundled);
+ A_PRINTF(KERN_ALERT"TxBundles : %d \n", pstats->TxBundles);
+ A_PRINTF(KERN_ALERT"TxCreditRpts : %d \n", pstats->TxCreditRpts);
+ A_PRINTF(KERN_ALERT"TxCreditsRptsFromRx : %d \n", pstats->TxCreditRptsFromRx);
+ A_PRINTF(KERN_ALERT"TxCreditsRptsFromOther : %d \n", pstats->TxCreditRptsFromOther);
+ A_PRINTF(KERN_ALERT"TxCreditsRptsFromEp0 : %d \n", pstats->TxCreditRptsFromEp0);
+ A_PRINTF(KERN_ALERT"TxCreditsFromRx : %d \n", pstats->TxCreditsFromRx);
+ A_PRINTF(KERN_ALERT"TxCreditsFromOther : %d \n", pstats->TxCreditsFromOther);
+ A_PRINTF(KERN_ALERT"TxCreditsFromEp0 : %d \n", pstats->TxCreditsFromEp0);
+ A_PRINTF(KERN_ALERT"TxCreditsConsummed : %d \n", pstats->TxCreditsConsummed);
+ A_PRINTF(KERN_ALERT"TxCreditsReturned : %d \n", pstats->TxCreditsReturned);
+ A_PRINTF(KERN_ALERT"RxReceived : %d \n", pstats->RxReceived);
+ A_PRINTF(KERN_ALERT"RxPacketsBundled : %d \n", pstats->RxPacketsBundled);
+ A_PRINTF(KERN_ALERT"RxLookAheads : %d \n", pstats->RxLookAheads);
+ A_PRINTF(KERN_ALERT"RxBundleLookAheads : %d \n", pstats->RxBundleLookAheads);
+ A_PRINTF(KERN_ALERT"RxBundleIndFromHdr : %d \n", pstats->RxBundleIndFromHdr);
+ A_PRINTF(KERN_ALERT"RxAllocThreshHit : %d \n", pstats->RxAllocThreshHit);
+ A_PRINTF(KERN_ALERT"RxAllocThreshBytes : %d \n", pstats->RxAllocThreshBytes);
+ A_PRINTF(KERN_ALERT"---- \n");
+ }
+ }
+ A_FREE(pstats);
+
+ }
+#endif
+ }
+ return ret;
+}
+
+int ar6000_ioctl_get_wpaie(AR_SOFTC_DEV_T *arPriv, char *userdata)
+{
+ struct ieee80211req_wpaie *pwpaie;
+ int ret = 0;
+ AR_SOFTC_T *ar=arPriv->arSoftc;
+
+ pwpaie = (struct ieee80211req_wpaie *) A_MALLOC(sizeof(struct ieee80211req_wpaie));
+ if (pwpaie == NULL) {
+ return -ENOMEM;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(pwpaie, userdata, sizeof(*pwpaie))) {
+ ret = -EFAULT;
+ } else if (ar6000_ap_mode_get_wpa_ie(arPriv, pwpaie)) {
+ ret = -EFAULT;
+ } else if(copy_to_user(userdata, pwpaie, sizeof(*pwpaie))) {
+ ret = -EFAULT;
+ }
+ A_FREE(pwpaie);
+ return ret;
+
+}
+
+#ifdef BTCOEX
+int ar6000_xioctl_hci_cmd(AR_SOFTC_DEV_T *arPriv, char *userdata)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ char tmp_buf[512];
+ A_INT8 i;
+ WMI_HCI_CMD *cmd = (WMI_HCI_CMD *)tmp_buf;
+ A_UINT8 size;
+ int ret = 0;
+
+ size = sizeof(cmd->cmd_buf_sz);
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(cmd, userdata, size)) {
+ ret = -EFAULT;
+ } else if(copy_from_user(cmd->buf, userdata + size, cmd->cmd_buf_sz)) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_send_hci_cmd(arPriv->arWmi, cmd->buf, cmd->cmd_buf_sz) != A_OK) {
+ ret = -EIO;
+ } else if(loghci) {
+ A_PRINTF_LOG("HCI Command To PAL --> \n");
+ for(i = 0; i < cmd->cmd_buf_sz; i++) {
+ A_PRINTF_LOG("0x%02x ",cmd->buf[i]);
+ if((i % 10) == 0) {
+ A_PRINTF_LOG("\n");
+ }
+ }
+ A_PRINTF_LOG("\n");
+ A_PRINTF_LOG("==================================\n");
+ }
+ }
+ return ret;
+}
+#endif
+
+int ar6000_xioctl_fetch_targ_regs(AR_SOFTC_DEV_T *arPriv, struct ifreq *rq, HIF_DEVICE *hifDevice)
+{
+ int ret = 0;
+ AR_SOFTC_T *ar=arPriv->arSoftc;
+ A_UINT32 targregs[AR6003_FETCH_TARG_REGS_COUNT];
+
+ if (ar->arTargetType == TARGET_TYPE_AR6003) {
+ ar6k_FetchTargetRegs(hifDevice, targregs);
+ if (copy_to_user((A_UINT32 *)rq->ifr_data, &targregs, sizeof(targregs)))
+ {
+ ret = -EFAULT;
+ }
+ } else {
+ ret = -EOPNOTSUPP;
+ }
+ return ret;
+
+}
+
+#ifdef P2P
+int ar6000_xioctl_wmi_p2p_peer(AR_SOFTC_DEV_T *arPriv, char *userdata, struct ifreq *rq)
+{
+ A_UINT8 buf[12];
+ const A_UINT8 zero_mac[] = {0,0,0,0,0,0};
+
+ A_UINT8 peer_info_buf[900];
+ A_UINT32 peer_info_buf_used;
+
+ int first_element;
+ int ret = 0;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(buf, userdata, 12)) {
+ ret = -EFAULT;
+ } else {
+ /*
+ * Check the "next" value set in driver_ar6003.c of the supplicant.
+ * This determines whether we have a "P2P_PEER FIRST" (if = 1) or
+ * "P2P_PEER NEXT-<addr>" (if = 2) command, or just a plain p2p_peer <addr>
+ * command (if = 0)
+ */
+ if (buf[6] != 0) {
+ if (buf[6] == 1) {
+ first_element = 1;
+ } else {
+ first_element = 0;
+ }
+ peer_info_buf_used = p2p_get_next_addr(A_WMI_GET_P2P_CTX(arPriv),
+ buf, peer_info_buf,
+ sizeof(peer_info_buf),
+ first_element);
+ if (peer_info_buf_used == 0) {
+ ret = -ENODEV;
+ }
+ *((A_UINT32 *)rq->ifr_data) = peer_info_buf_used;
+ if(copy_to_user(((A_UINT32 *)(rq->ifr_data)+1),
+ peer_info_buf, peer_info_buf_used)) {
+ ret = -EFAULT;
+ }
+ } else {
+ if (p2p_peer(A_WMI_GET_P2P_CTX(arPriv),
+ buf, *(buf+6)) == A_OK) {
+ peer_info_buf_used = p2p_get_peer_info( A_WMI_GET_P2P_CTX(arPriv), buf,
+ peer_info_buf,
+ sizeof(peer_info_buf));
+ *((A_UINT32 *)rq->ifr_data) = peer_info_buf_used;
+ if(copy_to_user(((A_UINT32 *)(rq->ifr_data)+1),
+ peer_info_buf, peer_info_buf_used)) {
+ ret = -EFAULT;
+ }
+ } else {
+ if(copy_to_user((A_UINT16 *)rq->ifr_data,
+ zero_mac, IEEE80211_ADDR_LEN)) {
+ ret = -EFAULT;
+ }
+ }
+ }
+ }
+
+ return ret;
+}
+
+int ar6000_xioctl_wmi_p2p_provdisc(AR_SOFTC_DEV_T *arPriv, char *userdata)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UINT8 peer[IEEE80211_ADDR_LEN];
+ A_UINT16 wps_method;
+ A_UINT8 buf[8];
+ int ret = 0;
+
+ A_MEMZERO(peer, IEEE80211_ADDR_LEN);
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(buf, userdata, 8)) {
+ ret = -EFAULT;
+ } else {
+ A_MEMCPY(peer, buf, IEEE80211_ADDR_LEN);
+ wps_method = (*(A_UINT16 *)(&buf[6]));
+
+ if (p2p_prov_disc_req(A_WMI_GET_P2P_CTX(arPriv),
+ peer, wps_method) != A_OK) {
+ ret = -EFAULT;
+ }
+ }
+ return ret;
+}
+
+int ar6000_xioctl_wmi_p2p_set(AR_SOFTC_DEV_T *arPriv, char *userdata)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ int ret = 0;
+ WMI_P2P_SET_CMD set_p2p_config;
+ A_MEMZERO(&set_p2p_config, sizeof(WMI_P2P_SET_CMD));
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&set_p2p_config, userdata,
+ sizeof(WMI_P2P_SET_CMD))) {
+ ret = -EFAULT;
+ } else {
+ if (set_p2p_config.config_id == WMI_P2P_CONFID_CROSS_CONNECT) {
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv),
+ P2P_GROUP_CAPAB_CROSS_CONN,
+ set_p2p_config.val.cross_conn.flag);
+ } else if(set_p2p_config.config_id == WMI_P2P_CONFID_CONCURRENT_MODE) {
+ p2p_set_device_capability(A_WMI_GET_P2P_CTX(arPriv),
+ P2P_DEV_CAPAB_CONCURRENT_OPER,
+ set_p2p_config.val.concurrent_mode.flag);
+ }
+
+ wmi_p2p_set_cmd(arPriv->arWmi, &set_p2p_config);
+ }
+ return ret;
+
+}
+
+int ar6000_xioctl_wmi_p2p_sdpdtx(AR_SOFTC_DEV_T *arPriv, char *userdata, struct ifreq *rq)
+{
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_P2P_SDPD_TX_CMD *psdpd_tx_cmd;
+ A_UINT32 qid = 0;
+ int ret = 0;
+ psdpd_tx_cmd = (WMI_P2P_SDPD_TX_CMD *) A_MALLOC(sizeof(WMI_P2P_SDPD_TX_CMD));
+ if (psdpd_tx_cmd == NULL) {
+ return -ENOMEM;
+ }
+ A_MEMZERO(psdpd_tx_cmd, sizeof(WMI_P2P_SDPD_TX_CMD));
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(psdpd_tx_cmd, userdata,
+ sizeof(WMI_P2P_SDPD_TX_CMD))) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_sdpd_tx_cmd(A_WMI_GET_P2P_CTX(arPriv),
+ psdpd_tx_cmd, &qid) !=
+ A_OK) {
+ ret = -EFAULT;
+ } else {
+ if(copy_to_user((A_UINT8 *)rq->ifr_data,
+ (void *)&qid, sizeof(A_UINT32))) {
+ ret = -EFAULT;
+ }
+ }
+ }
+ A_FREE(psdpd_tx_cmd);
+ return ret;
+}
+
+#endif /* P2P */
+
+int ar6000_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+ HIF_DEVICE *hifDevice = ar->arHifDevice;
+ int ret = 0, param;
+ unsigned int address = 0;
+ unsigned int length = 0;
+ unsigned char *buffer;
+ char *userdata;
+
+ /*
+ * ioctl operations may have to wait for the Target, so we cannot hold rtnl.
+ * Prevent the device from disappearing under us and release the lock during
+ * the ioctl operation.
+ */
+ dev_hold(dev);
+ rtnl_unlock();
+
+ if (cmd == AR6000_IOCTL_EXTENDED) {
+ /*
+ * This allows for many more wireless ioctls than would otherwise
+ * be available. Applications embed the actual ioctl command in
+ * the first word of the parameter block, and use the command
+ * AR6000_IOCTL_EXTENDED_CMD on the ioctl call.
+ */
+ get_user(cmd, (int *)rq->ifr_data);
+ userdata = (char *)(((unsigned int *)rq->ifr_data)+1);
+ if(is_xioctl_allowed(arPriv->arNextMode,
+ arPriv->arNetworkSubType, cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("xioctl: cmd=%d not allowed in this mode\n",cmd));
+ ret = -EOPNOTSUPP;
+ goto ioctl_done;
+ }
+ } else {
+ A_STATUS ret = is_iwioctl_allowed(arPriv->arNextMode, cmd);
+ if(ret == A_ENOTSUP) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("iwioctl: cmd=0x%x not allowed in this mode\n", cmd));
+ ret = -EOPNOTSUPP;
+ goto ioctl_done;
+ } else if (ret == A_ERROR) {
+ /* It is not our ioctl (out of range ioctl) */
+ ret = -EOPNOTSUPP;
+ goto ioctl_done;
+ }
+ userdata = (char *)rq->ifr_data;
+ }
+
+ if ((ar->arWlanState == WLAN_DISABLED) &&
+ ((cmd != AR6000_XIOCTRL_WMI_SET_WLAN_STATE) &&
+ (cmd != AR6000_XIOCTL_GET_WLAN_SLEEP_STATE) &&
+ (cmd != AR6000_XIOCTL_DIAG_READ) &&
+ (cmd != AR6000_XIOCTL_DIAG_WRITE) &&
+ (cmd != AR6000_XIOCTL_SET_BT_HW_POWER_STATE) &&
+ (cmd != AR6000_XIOCTL_GET_BT_HW_POWER_STATE) &&
+ (cmd != AR6000_IOCTL_WMI_GETREV) &&
+ (cmd != AR6000_XIOCTL_RESUME_DRIVER)))
+ {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+
+
+ ret = 0;
+ switch(cmd)
+ {
+ case IEEE80211_IOCTL_SETPARAM:
+ {
+ int param, value;
+ int *ptr = (int *)rq->ifr_ifru.ifru_newname;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else {
+ param = *ptr++;
+ value = *ptr;
+ ret = ar6000_ioctl_setparam(arPriv,param,value);
+ }
+ break;
+ }
+ case IEEE80211_IOCTL_SETKEY:
+ {
+ struct ieee80211req_key keydata;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&keydata, userdata,
+ sizeof(struct ieee80211req_key))) {
+ ret = -EFAULT;
+ } else {
+ ar6000_ioctl_setkey(arPriv, &keydata);
+ }
+ break;
+ }
+ case IEEE80211_IOCTL_DELKEY:
+ case IEEE80211_IOCTL_SETOPTIE:
+ {
+ //ret = -EIO;
+ break;
+ }
+ case IEEE80211_IOCTL_SETMLME:
+ {
+ struct ieee80211req_mlme mlme;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&mlme, userdata,
+ sizeof(struct ieee80211req_mlme))) {
+ ret = -EFAULT;
+ } else {
+ switch (mlme.im_op) {
+ case IEEE80211_MLME_AUTHORIZE:
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("setmlme AUTHORIZE %02X:%02X\n",
+ mlme.im_macaddr[4], mlme.im_macaddr[5]));
+ break;
+ case IEEE80211_MLME_UNAUTHORIZE:
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("setmlme UNAUTHORIZE %02X:%02X\n",
+ mlme.im_macaddr[4], mlme.im_macaddr[5]));
+ break;
+ case IEEE80211_MLME_DEAUTH:
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("setmlme DEAUTH %02X:%02X\n",
+ mlme.im_macaddr[4], mlme.im_macaddr[5]));
+ //remove_sta(ar, mlme.im_macaddr);
+ break;
+ case IEEE80211_MLME_DISASSOC:
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("setmlme DISASSOC %02X:%02X\n",
+ mlme.im_macaddr[4], mlme.im_macaddr[5]));
+ //remove_sta(ar, mlme.im_macaddr);
+ break;
+ default:
+ ret = 0;
+ goto ioctl_done;
+ }
+
+ wmi_ap_set_mlme(arPriv->arWmi, mlme.im_op, mlme.im_macaddr,
+ mlme.im_reason);
+ }
+ break;
+ }
+ case IEEE80211_IOCTL_ADDPMKID:
+ {
+ struct ieee80211req_addpmkid req;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&req, userdata, sizeof(struct ieee80211req_addpmkid))) {
+ ret = -EFAULT;
+ } else {
+ A_STATUS status;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("Add pmkid for %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x en=%d\n",
+ req.pi_bssid[0], req.pi_bssid[1], req.pi_bssid[2],
+ req.pi_bssid[3], req.pi_bssid[4], req.pi_bssid[5],
+ req.pi_enable));
+
+ status = wmi_setPmkid_cmd(arPriv->arWmi, req.pi_bssid, req.pi_pmkid,
+ req.pi_enable);
+
+ if (status != A_OK) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ }
+ break;
+ }
+#ifdef CONFIG_HOST_TCMD_SUPPORT
+ case AR6000_XIOCTL_TCMD_CONT_TX:
+ {
+ TCMD_CONT_TX txCmd;
+
+ if ((ar->tcmdPm == TCMD_PM_SLEEP) ||
+ (ar->tcmdPm == TCMD_PM_DEEPSLEEP))
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Can NOT send tx tcmd when target is asleep! \n"));
+ ret = -EOPNOTSUPP;
+ goto ioctl_done;
+ }
+
+ if(copy_from_user(&txCmd, userdata, sizeof(TCMD_CONT_TX))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ } else {
+ wmi_test_cmd(arPriv->arWmi,(A_UINT8 *)&txCmd, sizeof(TCMD_CONT_TX));
+ }
+ }
+ break;
+ case AR6000_XIOCTL_TCMD_CONT_RX:
+ {
+ TCMD_CONT_RX rxCmd;
+
+ if ((ar->tcmdPm == TCMD_PM_SLEEP) ||
+ (ar->tcmdPm == TCMD_PM_DEEPSLEEP))
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Can NOT send rx tcmd when target is asleep! \n"));
+ ret = -EOPNOTSUPP;
+ goto ioctl_done;
+ }
+ if(copy_from_user(&rxCmd, userdata, sizeof(TCMD_CONT_RX))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+
+ switch(rxCmd.act)
+ {
+ case TCMD_CONT_RX_PROMIS:
+ case TCMD_CONT_RX_FILTER:
+ case TCMD_CONT_RX_SETMAC:
+ case TCMD_CONT_RX_SET_ANT_SWITCH_TABLE:
+ wmi_test_cmd(arPriv->arWmi,(A_UINT8 *)&rxCmd,
+ sizeof(TCMD_CONT_RX));
+ tcmdRxFreq = rxCmd.u.para.freq;
+ break;
+ case TCMD_CONT_RX_REPORT:
+ ar6000_ioctl_tcmd_get_rx_report(dev, rq,
+ (A_UINT8 *)&rxCmd, sizeof(TCMD_CONT_RX));
+ break;
+ default:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("Unknown Cont Rx mode: %d\n",rxCmd.act));
+ ret = -EINVAL;
+ goto ioctl_done;
+ }
+ }
+ break;
+ case AR6000_XIOCTL_TCMD_PM:
+ {
+ TCMD_PM pmCmd;
+
+ if(copy_from_user(&pmCmd, userdata, sizeof(TCMD_PM))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+ ar->tcmdPm = pmCmd.mode;
+ wmi_test_cmd(arPriv->arWmi, (A_UINT8*)&pmCmd, sizeof(TCMD_PM));
+ }
+ break;
+
+ case AR6000_XIOCTL_TCMD_CMDS:
+ {
+ TC_CMDS cmdsCmd;
+ if(copy_from_user(&cmdsCmd, userdata, sizeof(TC_CMDS))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+ ar6000_ioctl_tcmd_cmd_resp(dev, rq, (A_UINT8 *)&cmdsCmd, sizeof(TC_CMDS));
+#if 0
+ wmi_test_cmd(arPriv->arWmi, (A_UINT8*)&cmdsCmd, sizeof(TC_CMDS));
+#endif
+ }
+ break;
+
+ case AR6000_XIOCTL_TCMD_SETREG:
+ {
+ TCMD_SET_REG setRegCmd;
+
+ if(copy_from_user(&setRegCmd, userdata, sizeof(TCMD_SET_REG))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+ wmi_test_cmd(arPriv->arWmi, (A_UINT8*)&setRegCmd, sizeof(TCMD_SET_REG));
+ }
+ break;
+#endif /* CONFIG_HOST_TCMD_SUPPORT */
+
+ case AR6000_XIOCTL_BMI_DONE:
+ if(bmienable)
+ {
+ rtnl_lock(); /* ar6000_init expects to be called holding rtnl lock */
+ ret = ar6000_init(dev);
+ rtnl_unlock();
+ }
+ else
+ {
+ ret = BMIDone(hifDevice);
+ }
+ break;
+
+ case AR6000_XIOCTL_BMI_READ_MEMORY:
+ get_user(address, (unsigned int *)userdata);
+ get_user(length, (unsigned int *)userdata + 1);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Read Memory (address: 0x%x, length: %d)\n",
+ address, length));
+ if ((buffer = (unsigned char *)A_MALLOC(length)) != NULL) {
+ A_MEMZERO(buffer, length);
+ ret = BMIReadMemory(hifDevice, address, buffer, length);
+ if (copy_to_user(rq->ifr_data, buffer, length)) {
+ ret = -EFAULT;
+ }
+ A_FREE(buffer);
+ } else {
+ ret = -ENOMEM;
+ }
+ break;
+
+ case AR6000_XIOCTL_BMI_WRITE_MEMORY:
+ get_user(address, (unsigned int *)userdata);
+ get_user(length, (unsigned int *)userdata + 1);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Write Memory (address: 0x%x, length: %d)\n",
+ address, length));
+ if ((buffer = (unsigned char *)A_MALLOC(length)) != NULL) {
+ A_MEMZERO(buffer, length);
+ if (copy_from_user(buffer, &userdata[sizeof(address) +
+ sizeof(length)], length))
+ {
+ ret = -EFAULT;
+ } else {
+ ret = BMIWriteMemory(hifDevice, address, buffer, length);
+ }
+ A_FREE(buffer);
+ } else {
+ ret = -ENOMEM;
+ }
+ break;
+
+ case AR6000_XIOCTL_BMI_TEST:
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("No longer supported\n"));
+ ret = -EOPNOTSUPP;
+ break;
+
+ case AR6000_XIOCTL_BMI_EXECUTE:
+ get_user(address, (unsigned int *)userdata);
+ get_user(param, (unsigned int *)userdata + 1);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Execute (address: 0x%x, param: %d)\n",
+ address, param));
+ ret = BMIExecute(hifDevice, address, (A_UINT32*)¶m);
+ put_user(param, (unsigned int *)rq->ifr_data); /* return value */
+ break;
+
+ case AR6000_XIOCTL_BMI_SET_APP_START:
+ get_user(address, (unsigned int *)userdata);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Set App Start (address: 0x%x)\n", address));
+ ret = BMISetAppStart(hifDevice, address);
+ break;
+
+ case AR6000_XIOCTL_BMI_READ_SOC_REGISTER:
+ get_user(address, (unsigned int *)userdata);
+ ret = BMIReadSOCRegister(hifDevice, address, (A_UINT32*)¶m);
+ put_user(param, (unsigned int *)rq->ifr_data); /* return value */
+ break;
+
+ case AR6000_XIOCTL_BMI_WRITE_SOC_REGISTER:
+ get_user(address, (unsigned int *)userdata);
+ get_user(param, (unsigned int *)userdata + 1);
+ ret = BMIWriteSOCRegister(hifDevice, address, param);
+ break;
+
+#ifdef HTC_RAW_INTERFACE
+ case AR6000_XIOCTL_HTC_RAW_OPEN:
+ ret = A_OK;
+ if (!arRawIfEnabled(ar)) {
+ /* make sure block size is set in case the target was reset since last
+ * BMI phase (i.e. flashup downloads) */
+ ret = ar6000_set_htc_params(ar->arHifDevice,
+ ar->arTargetType,
+ 0, /* use default yield */
+ 0 /* use default number of HTC ctrl buffers */
+ );
+ if (A_FAILED(ret)) {
+ break;
+ }
+ /* Terminate the BMI phase */
+ ret = BMIDone(hifDevice);
+ if (ret == A_OK) {
+ ret = ar6000_htc_raw_open(ar);
+ }
+ }
+ break;
+
+ case AR6000_XIOCTL_HTC_RAW_CLOSE:
+ if (arRawIfEnabled(ar)) {
+ ret = ar6000_htc_raw_close(ar);
+ arRawIfEnabled(ar) = FALSE;
+ } else {
+ ret = A_ERROR;
+ }
+ break;
+
+ case AR6000_XIOCTL_HTC_RAW_READ:
+ if (arRawIfEnabled(ar)) {
+ unsigned int streamID;
+ get_user(streamID, (unsigned int *)userdata);
+ get_user(length, (unsigned int *)userdata + 1);
+ buffer = (unsigned char*)rq->ifr_data + sizeof(length);
+ ret = ar6000_htc_raw_read(ar, (HTC_RAW_STREAM_ID)streamID,
+ (char*)buffer, length);
+ put_user(ret, (unsigned int *)rq->ifr_data);
+ } else {
+ ret = A_ERROR;
+ }
+ break;
+
+ case AR6000_XIOCTL_HTC_RAW_WRITE:
+ if (arRawIfEnabled(ar)) {
+ unsigned int streamID;
+ get_user(streamID, (unsigned int *)userdata);
+ get_user(length, (unsigned int *)userdata + 1);
+ buffer = (unsigned char*)userdata + sizeof(streamID) + sizeof(length);
+ ret = ar6000_htc_raw_write(ar, (HTC_RAW_STREAM_ID)streamID,
+ (char*)buffer, length);
+ put_user(ret, (unsigned int *)rq->ifr_data);
+ } else {
+ ret = A_ERROR;
+ }
+ break;
+#endif /* HTC_RAW_INTERFACE */
+
+ case AR6000_XIOCTL_BMI_LZ_STREAM_START:
+ get_user(address, (unsigned int *)userdata);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Start Compressed Stream (address: 0x%x)\n", address));
+ ret = BMILZStreamStart(hifDevice, address);
+ break;
+
+ case AR6000_XIOCTL_BMI_LZ_DATA:
+ get_user(length, (unsigned int *)userdata);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Send Compressed Data (length: %d)\n", length));
+ if ((buffer = (unsigned char *)A_MALLOC(length)) != NULL) {
+ A_MEMZERO(buffer, length);
+ if (copy_from_user(buffer, &userdata[sizeof(length)], length))
+ {
+ ret = -EFAULT;
+ } else {
+ ret = BMILZData(hifDevice, buffer, length);
+ }
+ A_FREE(buffer);
+ } else {
+ ret = -ENOMEM;
+ }
+ break;
+
+#if defined(CONFIG_TARGET_PROFILE_SUPPORT)
+ /*
+ * Optional support for Target-side profiling.
+ * Not needed in production.
+ */
+
+ /* Configure Target-side profiling */
+ case AR6000_XIOCTL_PROF_CFG:
+ {
+ A_UINT32 period;
+ A_UINT32 nbins;
+ get_user(period, (unsigned int *)userdata);
+ get_user(nbins, (unsigned int *)userdata + 1);
+
+ if (wmi_prof_cfg_cmd(arPriv->arWmi, period, nbins) != A_OK) {
+ ret = -EIO;
+ }
+
+ break;
+ }
+
+ /* Start a profiling bucket/bin at the specified address */
+ case AR6000_XIOCTL_PROF_ADDR_SET:
+ {
+ A_UINT32 addr;
+ get_user(addr, (unsigned int *)userdata);
+
+ if (wmi_prof_addr_set_cmd(arPriv->arWmi, addr) != A_OK) {
+ ret = -EIO;
+ }
+
+ break;
+ }
+
+ /* START Target-side profiling */
+ case AR6000_XIOCTL_PROF_START:
+ wmi_prof_start_cmd(arPriv->arWmi);
+ break;
+
+ /* STOP Target-side profiling */
+ case AR6000_XIOCTL_PROF_STOP:
+ wmi_prof_stop_cmd(arPriv->arWmi);
+ break;
+ case AR6000_XIOCTL_PROF_COUNT_GET:
+ {
+ if (ar->bIsDestroyProgress) {
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+
+ prof_count_available = FALSE;
+ ret = prof_count_get(dev);
+ if (ret != A_OK) {
+ up(&ar->arSem);
+ ret = -EIO;
+ goto ioctl_done;
+ }
+
+ /* Wait for Target to respond. */
+ wait_event_interruptible(arPriv->arEvent, prof_count_available);
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ } else {
+ if (copy_to_user(userdata, &prof_count_results,
+ sizeof(prof_count_results)))
+ {
+ ret = -EFAULT;
+ }
+ }
+ up(&ar->arSem);
+ break;
+ }
+#endif /* CONFIG_TARGET_PROFILE_SUPPORT */
+
+ case AR6000_IOCTL_WMI_GETREV:
+ {
+ if (copy_to_user(rq->ifr_data, &ar->arVersion,
+ sizeof(ar->arVersion)))
+ {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SETPWR:
+ {
+ WMI_POWER_MODE_CMD pwrModeCmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&pwrModeCmd, userdata,
+ sizeof(pwrModeCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_powermode_cmd(arPriv->arWmi, pwrModeCmd.powerMode)
+ != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_IBSS_PM_CAPS:
+ {
+ WMI_IBSS_PM_CAPS_CMD ibssPmCaps;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&ibssPmCaps, userdata,
+ sizeof(ibssPmCaps)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_ibsspmcaps_cmd(arPriv->arWmi, ibssPmCaps.power_saving, ibssPmCaps.ttl,
+ ibssPmCaps.atim_windows, ibssPmCaps.timeout_value) != A_OK)
+ {
+ ret = -EIO;
+ }
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ arPriv->arSta.arIbssPsEnable = ibssPmCaps.power_saving;
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_AP_PS:
+ {
+ WMI_AP_PS_CMD apPsCmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&apPsCmd, userdata,
+ sizeof(apPsCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_apps_cmd(arPriv->arWmi, apPsCmd.psType, apPsCmd.idle_time,
+ apPsCmd.ps_period, apPsCmd.sleep_period) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_PMPARAMS:
+ {
+ WMI_POWER_PARAMS_CMD pmParams;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&pmParams, userdata,
+ sizeof(pmParams)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_pmparams_cmd(arPriv->arWmi, pmParams.idle_period,
+ pmParams.pspoll_number,
+ pmParams.dtim_policy,
+ pmParams.tx_wakeup_policy,
+ pmParams.num_tx_to_wakeup,
+#if WLAN_CONFIG_IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN
+ IGNORE_POWER_SAVE_FAIL_EVENT_DURING_SCAN
+#else
+ SEND_POWER_SAVE_FAIL_EVENT_ALWAYS
+#endif
+ ) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SETSCAN:
+ {
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&arSta->scParams, userdata,
+ sizeof(arSta->scParams)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (CAN_SCAN_IN_CONNECT(arSta->scParams.scanCtrlFlags)) {
+ arSta->arSkipScan = FALSE;
+ } else {
+ arSta->arSkipScan = TRUE;
+ }
+
+ if (wmi_scanparams_cmd(arPriv->arWmi, arSta->scParams.fg_start_period,
+ arSta->scParams.fg_end_period,
+ arSta->scParams.bg_period,
+ arSta->scParams.minact_chdwell_time,
+ arSta->scParams.maxact_chdwell_time,
+ arSta->scParams.pas_chdwell_time,
+ arSta->scParams.shortScanRatio,
+ arSta->scParams.scanCtrlFlags,
+ arSta->scParams.max_dfsch_act_time,
+ arSta->scParams.maxact_scan_per_ssid) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SETLISTENINT:
+ {
+ WMI_LISTEN_INT_CMD listenCmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&listenCmd, userdata,
+ sizeof(listenCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_listeninterval_cmd(arPriv->arWmi, listenCmd.listenInterval, listenCmd.numBeacons) != A_OK) {
+ ret = -EIO;
+ } else {
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ arSta->arListenIntervalT = listenCmd.listenInterval;
+ arSta->arListenIntervalB = listenCmd.numBeacons;
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ }
+
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_BMISS_TIME:
+ {
+ WMI_BMISS_TIME_CMD bmissCmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&bmissCmd, userdata,
+ sizeof(bmissCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_bmisstime_cmd(arPriv->arWmi, bmissCmd.bmissTime, bmissCmd.numBeacons) != A_OK) {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SETBSSFILTER:
+ {
+ WMI_BSS_FILTER_CMD filt;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&filt, userdata,
+ sizeof(filt)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_bssfilter_cmd(arPriv->arWmi, filt.bssFilter, filt.ieMask)
+ != A_OK) {
+ ret = -EIO;
+ } else {
+ arSta->arUserBssFilter = filt.bssFilter;
+ }
+ }
+ break;
+ }
+
+ case AR6000_IOCTL_WMI_SET_SNRTHRESHOLD:
+ {
+ ret = ar6000_ioctl_set_snr_threshold(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_RSSITHRESHOLD:
+ {
+ ret = ar6000_ioctl_set_rssi_threshold(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_CLR_RSSISNR:
+ {
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ }
+ ret = wmi_clr_rssi_snr(arPriv->arWmi);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_LQTHRESHOLD:
+ {
+ ret = ar6000_ioctl_set_lq_threshold(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_LPREAMBLE:
+ {
+ WMI_SET_LPREAMBLE_CMD setLpreambleCmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setLpreambleCmd, userdata,
+ sizeof(setLpreambleCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_lpreamble_cmd(arPriv->arWmi, setLpreambleCmd.status,
+#if WLAN_CONFIG_DONOT_IGNORE_BARKER_IN_ERP
+ WMI_DONOT_IGNORE_BARKER_IN_ERP
+#else
+ WMI_IGNORE_BARKER_IN_ERP
+#endif
+ ) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_RTS:
+ {
+ WMI_SET_RTS_CMD rtsCmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&rtsCmd, userdata,
+ sizeof(rtsCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if(arPriv->arNetworkType == AP_NETWORK) {
+ arAp->arRTS = rtsCmd.threshold;
+ }
+ if (wmi_set_rts_cmd(arPriv->arWmi, rtsCmd.threshold)
+ != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_WMM:
+ {
+ ret = ar6000_ioctl_get_wmm(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_WMM:
+ {
+ ret = ar6000_ioctl_set_wmm(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_QOS_SUPP:
+ {
+ ret = ar6000_ioctl_set_qos_supp(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_TXOP:
+ {
+ ret = ar6000_ioctl_set_txop(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_RD:
+ {
+ ret = ar6000_ioctl_get_rd(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_CHANNELPARAMS:
+ {
+ ret = ar6000_ioctl_set_channelParams(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_PROBEDSSID:
+ {
+ ret = ar6000_ioctl_set_probedSsid(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_BADAP:
+ {
+ ret = ar6000_ioctl_set_badAp(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_CREATE_QOS:
+ {
+ ret = ar6000_ioctl_create_qos(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_DELETE_QOS:
+ {
+ ret = ar6000_ioctl_delete_qos(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_GET_QOS_QUEUE:
+ {
+ ret = ar6000_ioctl_get_qos_queue(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_GET_TARGET_STATS:
+ {
+ ret = ar6000_ioctl_get_target_stats(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_ERROR_REPORT_BITMASK:
+ {
+ ret = ar6000_ioctl_set_error_report_bitmask(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_ASSOC_INFO:
+ {
+ WMI_SET_ASSOC_INFO_CMD cmd;
+ A_UINT8 assocInfo[WMI_MAX_ASSOC_INFO_LEN];
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else {
+ get_user(cmd.ieType, userdata);
+ if (cmd.ieType >= WMI_MAX_ASSOC_INFO_TYPE) {
+ ret = -EIO;
+ } else {
+ get_user(cmd.bufferSize, userdata + 1);
+ if (cmd.bufferSize > WMI_MAX_ASSOC_INFO_LEN) {
+ ret = -EFAULT;
+ break;
+ }
+ if (copy_from_user(assocInfo, userdata + 2,
+ cmd.bufferSize))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_associnfo_cmd(arPriv->arWmi, cmd.ieType,
+ cmd.bufferSize,
+ assocInfo) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ }
+ }
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_ACCESS_PARAMS:
+ {
+ ret = ar6000_ioctl_set_access_params(dev, rq);
+ break;
+ }
+ case AR6000_IOCTL_WMI_SET_DISC_TIMEOUT:
+ {
+ ret = ar6000_ioctl_set_disconnect_timeout(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_FORCE_TARGET_RESET:
+ {
+ if (ar->arHtcTarget)
+ {
+// HTCForceReset(htcTarget);
+ }
+ else
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WARN,("ar6000_ioctl cannot attempt reset.\n"));
+ }
+ break;
+ }
+ case AR6000_XIOCTL_TARGET_INFO:
+ case AR6000_XIOCTL_CHECK_TARGET_READY: /* backwards compatibility */
+ {
+ /* If we made it to here, then the Target exists and is ready. */
+
+ if (cmd == AR6000_XIOCTL_TARGET_INFO) {
+ if (copy_to_user((A_UINT32 *)rq->ifr_data, &ar->arVersion.target_ver,
+ sizeof(ar->arVersion.target_ver)))
+ {
+ ret = -EFAULT;
+ }
+ if (copy_to_user(((A_UINT32 *)rq->ifr_data)+1, &ar->arTargetType,
+ sizeof(ar->arTargetType)))
+ {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_HB_CHALLENGE_RESP_PARAMS:
+ {
+ WMI_SET_HB_CHALLENGE_RESP_PARAMS_CMD hbparam;
+
+ if (copy_from_user(&hbparam, userdata, sizeof(hbparam)))
+ {
+ ret = -EFAULT;
+ } else {
+ AR6000_SPIN_LOCK(&ar->arLock, 0);
+ /* Start a cyclic timer with the parameters provided. */
+ if (hbparam.frequency) {
+ ar->arHBChallengeResp.frequency = hbparam.frequency;
+ }
+ if (hbparam.threshold) {
+ ar->arHBChallengeResp.missThres = hbparam.threshold;
+ }
+
+ /* Delete the pending timer and start a new one */
+ if (timer_pending(&ar->arHBChallengeResp.timer)) {
+ A_UNTIMEOUT(&ar->arHBChallengeResp.timer);
+ }
+ A_TIMEOUT_MS(&ar->arHBChallengeResp.timer, ar->arHBChallengeResp.frequency * 1000, 0);
+ AR6000_SPIN_UNLOCK(&ar->arLock, 0);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_HB_CHALLENGE_RESP:
+ {
+ A_UINT32 cookie;
+
+ if (copy_from_user(&cookie, userdata, sizeof(cookie))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+
+ /* Send the challenge on the control channel */
+ if (wmi_get_challenge_resp_cmd(arPriv->arWmi, cookie, APP_HB_CHALLENGE) != A_OK) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ break;
+ }
+#ifdef USER_KEYS
+ case AR6000_XIOCTL_USER_SETKEYS:
+ {
+
+ arSta->user_savedkeys_stat = USER_SAVEDKEYS_STAT_RUN;
+
+ if (copy_from_user(&arSta->user_key_ctrl, userdata,
+ sizeof(arSta->user_key_ctrl)))
+ {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("ar6000 USER set key %x\n", arSta->user_key_ctrl));
+ break;
+ }
+#endif /* USER_KEYS */
+
+#ifdef CONFIG_HOST_GPIO_SUPPORT
+ case AR6000_XIOCTL_GPIO_OUTPUT_SET:
+ {
+ struct ar6000_gpio_output_set_cmd_s gpio_output_set_cmd;
+
+ if (ar->bIsDestroyProgress) {
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+
+ if (copy_from_user(&gpio_output_set_cmd, userdata,
+ sizeof(gpio_output_set_cmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ ret = ar6000_gpio_output_set(dev,
+ gpio_output_set_cmd.set_mask,
+ gpio_output_set_cmd.clear_mask,
+ gpio_output_set_cmd.enable_mask,
+ gpio_output_set_cmd.disable_mask);
+ if (ret != A_OK) {
+ ret = EIO;
+ }
+ }
+ up(&ar->arSem);
+ break;
+ }
+ case AR6000_XIOCTL_GPIO_INPUT_GET:
+ {
+ if (ar->bIsDestroyProgress) {
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+
+ ret = ar6000_gpio_input_get(dev);
+ if (ret != A_OK) {
+ up(&ar->arSem);
+ ret = -EIO;
+ goto ioctl_done;
+ }
+
+ /* Wait for Target to respond. */
+ wait_event_interruptible(arPriv->arEvent, gpio_data_available);
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ } else {
+ A_ASSERT(gpio_reg_results.gpioreg_id == GPIO_ID_NONE);
+
+ if (copy_to_user(userdata, &gpio_reg_results.value,
+ sizeof(gpio_reg_results.value)))
+ {
+ ret = -EFAULT;
+ }
+ }
+ up(&ar->arSem);
+ break;
+ }
+ case AR6000_XIOCTL_GPIO_REGISTER_SET:
+ {
+ struct ar6000_gpio_register_cmd_s gpio_register_cmd;
+
+ if (ar->bIsDestroyProgress) {
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+
+ if (copy_from_user(&gpio_register_cmd, userdata,
+ sizeof(gpio_register_cmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ ret = ar6000_gpio_register_set(dev,
+ gpio_register_cmd.gpioreg_id,
+ gpio_register_cmd.value);
+ if (ret != A_OK) {
+ ret = EIO;
+ }
+
+ /* Wait for acknowledgement from Target */
+ wait_event_interruptible(arPriv->arEvent, gpio_ack_received);
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+ }
+ up(&ar->arSem);
+ break;
+ }
+ case AR6000_XIOCTL_GPIO_REGISTER_GET:
+ {
+ struct ar6000_gpio_register_cmd_s gpio_register_cmd;
+
+ if (ar->bIsDestroyProgress) {
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+
+ if (copy_from_user(&gpio_register_cmd, userdata,
+ sizeof(gpio_register_cmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ ret = ar6000_gpio_register_get(dev, gpio_register_cmd.gpioreg_id);
+ if (ret != A_OK) {
+ up(&ar->arSem);
+ ret = -EIO;
+ goto ioctl_done;
+ }
+
+ /* Wait for Target to respond. */
+ wait_event_interruptible(arPriv->arEvent, gpio_data_available);
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ } else {
+ A_ASSERT(gpio_register_cmd.gpioreg_id == gpio_reg_results.gpioreg_id);
+ if (copy_to_user(userdata, &gpio_reg_results,
+ sizeof(gpio_reg_results)))
+ {
+ ret = -EFAULT;
+ }
+ }
+ }
+ up(&ar->arSem);
+ break;
+ }
+ case AR6000_XIOCTL_GPIO_INTR_ACK:
+ {
+ struct ar6000_gpio_intr_ack_cmd_s gpio_intr_ack_cmd;
+
+ if (ar->bIsDestroyProgress) {
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+
+ if (copy_from_user(&gpio_intr_ack_cmd, userdata,
+ sizeof(gpio_intr_ack_cmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ ret = ar6000_gpio_intr_ack(dev, gpio_intr_ack_cmd.ack_mask);
+ if (ret != A_OK) {
+ ret = EIO;
+ }
+ }
+ up(&ar->arSem);
+ break;
+ }
+ case AR6000_XIOCTL_GPIO_INTR_WAIT:
+ {
+ /* Wait for Target to report an interrupt. */
+ wait_event_interruptible(arPriv->arEvent, gpio_intr_available);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ } else {
+ if (copy_to_user(userdata, &gpio_intr_results,
+ sizeof(gpio_intr_results)))
+ {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+#endif /* CONFIG_HOST_GPIO_SUPPORT */
+
+ case AR6000_XIOCTL_DBGLOG_CFG_MODULE:
+ {
+ struct ar6000_dbglog_module_config_s config;
+
+ if (copy_from_user(&config, userdata, sizeof(config))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+
+ /* Send the challenge on the control channel */
+ if (wmi_config_debug_module_cmd(arPriv->arWmi, config.mmask,
+ config.tsr, config.rep,
+ config.size, config.valid) != A_OK)
+ {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_DBGLOG_GET_DEBUG_LOGS:
+ {
+ /* Send the challenge on the control channel */
+ if (ar6000_dbglog_get_debug_logs(ar) != A_OK)
+ {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_SET_ADHOC_BSSID:
+ {
+ WMI_SET_ADHOC_BSSID_CMD adhocBssid;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&adhocBssid, userdata,
+ sizeof(adhocBssid)))
+ {
+ ret = -EFAULT;
+ } else if (A_MEMCMP(adhocBssid.bssid, bcast_mac,
+ AR6000_ETH_ADDR_LEN) == 0)
+ {
+ ret = -EFAULT;
+ } else {
+
+ A_MEMCPY(arSta->arReqBssid, adhocBssid.bssid, sizeof(arSta->arReqBssid));
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_SETRETRYLIMITS:
+ {
+ WMI_SET_RETRY_LIMITS_CMD setRetryParams;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setRetryParams, userdata,
+ sizeof(setRetryParams)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_retry_limits_cmd(arPriv->arWmi, setRetryParams.frameType,
+ setRetryParams.trafficClass,
+ setRetryParams.maxRetries,
+ setRetryParams.enableNotify) != A_OK)
+ {
+ ret = -EIO;
+ }
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ arPriv->arMaxRetries = setRetryParams.maxRetries;
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_SET_BEACON_INTVAL:
+ {
+ WMI_BEACON_INT_CMD bIntvlCmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&bIntvlCmd, userdata,
+ sizeof(bIntvlCmd)))
+ {
+ ret = -EFAULT;
+ } else if (wmi_set_adhoc_bconIntvl_cmd(arPriv->arWmi, bIntvlCmd.beaconInterval)
+ != A_OK)
+ {
+ ret = -EIO;
+ }
+ if(ret == 0) {
+ arAp->ap_beacon_interval = bIntvlCmd.beaconInterval;
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ }
+ break;
+ }
+ case IEEE80211_IOCTL_SETAUTHALG:
+ {
+ struct ieee80211req_authalg req;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&req, userdata,
+ sizeof(struct ieee80211req_authalg)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (req.auth_alg & AUTH_ALG_OPEN_SYSTEM) {
+ arPriv->arDot11AuthMode |= OPEN_AUTH;
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ }
+ if (req.auth_alg & AUTH_ALG_SHARED_KEY) {
+ arPriv->arDot11AuthMode |= SHARED_AUTH;
+ arPriv->arPairwiseCrypto = WEP_CRYPT;
+ arPriv->arGroupCrypto = WEP_CRYPT;
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ }
+ if (req.auth_alg == AUTH_ALG_LEAP) {
+ arPriv->arDot11AuthMode = LEAP_AUTH;
+ }
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_SET_VOICE_PKT_SIZE:
+ ret = ar6000_xioctl_set_voice_pkt_size(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_SET_MAX_SP:
+ ret = ar6000_xioctl_set_max_sp_len(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_GET_ROAM_TBL:
+ ret = ar6000_ioctl_get_roam_tbl(dev, rq);
+ break;
+ case AR6000_XIOCTL_WMI_SET_ROAM_CTRL:
+ ret = ar6000_ioctl_set_roam_ctrl(dev, userdata);
+ break;
+ case AR6000_XIOCTRL_WMI_SET_POWERSAVE_TIMERS:
+ ret = ar6000_ioctl_set_powersave_timers(dev, userdata);
+ break;
+ case AR6000_XIOCTRL_WMI_GET_POWER_MODE:
+ ret = ar6000_ioctl_get_power_mode(dev, rq);
+ break;
+
+ case AR6000_XIOCTRL_WMI_SET_WLAN_STATE:
+ {
+ AR6000_WLAN_STATE state;
+ get_user(state, (unsigned int *)userdata);
+ if (ar6000_set_wlan_state(ar, state)!=A_OK) {
+ ret = -EIO;
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_GET_ROAM_DATA:
+ ret = ar6000_ioctl_get_roam_data(dev, rq);
+ break;
+
+#ifdef BTCOEX
+ case AR6000_XIOCTL_WMI_SET_BT_STATUS:
+ ret = ar6000_xioctl_set_bt_status_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BT_PARAMS:
+ ret = ar6000_xioctl_set_bt_params_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BTCOEX_FE_ANT:
+ ret = ar6000_xioctl_set_btcoex_fe_ant_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BTCOEX_COLOCATED_BT_DEV:
+ ret = ar6000_xioctl_set_btcoex_colocated_bt_dev_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG:
+ ret = ar6000_xioctl_set_btcoex_btinquiry_page_config_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BTCOEX_SCO_CONFIG:
+ ret = ar6000_xioctl_set_btcoex_sco_config_cmd( dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BTCOEX_A2DP_CONFIG:
+ ret = ar6000_xioctl_set_btcoex_a2dp_config_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BTCOEX_ACLCOEX_CONFIG:
+ ret = ar6000_xioctl_set_btcoex_aclcoex_config_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BTCOEX_DEBUG:
+ ret = ar60000_xioctl_set_btcoex_debug_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_SET_BT_OPERATING_STATUS:
+ ret = ar6000_xioctl_set_btcoex_bt_operating_status_cmd(dev, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_GET_BTCOEX_CONFIG:
+ ret = ar6000_xioctl_get_btcoex_config_cmd(dev, userdata, rq);
+ break;
+
+ case AR6000_XIOCTL_WMI_GET_BTCOEX_STATS:
+ ret = ar6000_xioctl_get_btcoex_stats_cmd(dev, userdata, rq);
+ break;
+#endif
+ case AR6000_XIOCTL_WMI_STARTSCAN:
+ {
+ WMI_START_SCAN_CMD setStartScanCmd, *cmdp;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setStartScanCmd, userdata,
+ sizeof(setStartScanCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (setStartScanCmd.numChannels > 1) {
+ cmdp = A_MALLOC(130);
+ if (copy_from_user(cmdp, userdata,
+ sizeof (*cmdp) +
+ ((setStartScanCmd.numChannels - 1) *
+ sizeof(A_UINT16))))
+ {
+ A_FREE(cmdp);
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+ } else {
+ cmdp = &setStartScanCmd;
+ }
+
+ if (wmi_startscan_cmd(arPriv->arWmi, cmdp->scanType,
+ cmdp->forceFgScan,
+ cmdp->isLegacy,
+ cmdp->homeDwellTime,
+ cmdp->forceScanInterval,
+ cmdp->numChannels,
+ cmdp->channelList) != A_OK)
+ {
+ ret = -EIO;
+ }
+ if (setStartScanCmd.numChannels > 1) {
+ A_FREE(cmdp);
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SETFIXRATES:
+ {
+ WMI_FIX_RATES_CMD setFixRatesCmd;
+ A_STATUS returnStatus;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setFixRatesCmd, userdata,
+ sizeof(setFixRatesCmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ returnStatus = wmi_set_fixrates_cmd(arPriv->arWmi, setFixRatesCmd.fixRateMask);
+ if (returnStatus == A_EINVAL) {
+ ret = -EINVAL;
+ } else if(returnStatus != A_OK) {
+ ret = -EIO;
+ } else {
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ }
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_GETFIXRATES:
+ {
+ WMI_FIX_RATES_CMD getFixRatesCmd;
+ int ret = 0;
+
+ if (ar->bIsDestroyProgress) {
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ /* Used copy_from_user/copy_to_user to access user space data */
+ if (copy_from_user(&getFixRatesCmd, userdata, sizeof(getFixRatesCmd))) {
+ ret = -EFAULT;
+ } else {
+ arPriv->arRateMask[0] = 0xFFFFFFFF;
+ arPriv->arRateMask[1] = 0xFFFFFFFF;
+
+ if (wmi_get_ratemask_cmd(arPriv->arWmi) != A_OK) {
+ up(&ar->arSem);
+ ret = -EIO;
+ goto ioctl_done;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, (arPriv->arRateMask[0] != 0xFFFFFFFF) &&
+ (arPriv->arRateMask[1] != 0xFFFFFFFF), wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ if (!ret) {
+ getFixRatesCmd.fixRateMask[0] = arPriv->arRateMask[0];
+ getFixRatesCmd.fixRateMask[1] = arPriv->arRateMask[1];
+ }
+
+ if(copy_to_user(userdata, &getFixRatesCmd, sizeof(getFixRatesCmd))) {
+ ret = -EFAULT;
+ }
+
+ up(&ar->arSem);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_AUTHMODE:
+ {
+ WMI_SET_AUTH_MODE_CMD setAuthMode;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setAuthMode, userdata,
+ sizeof(setAuthMode))) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_authmode_cmd(arPriv->arWmi, setAuthMode.mode) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_REASSOCMODE:
+ {
+ WMI_SET_REASSOC_MODE_CMD setReassocMode;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setReassocMode, userdata,
+ sizeof(setReassocMode))) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_reassocmode_cmd(arPriv->arWmi, setReassocMode.mode) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_DIAG_READ:
+ {
+ A_UINT32 addr, data;
+ get_user(addr, (unsigned int *)userdata);
+ addr = TARG_VTOP(ar->arTargetType, addr);
+ if (ar6000_ReadRegDiag(ar->arHifDevice, &addr, &data) != A_OK) {
+ ret = -EIO;
+ }
+ put_user(data, (unsigned int *)userdata + 1);
+ break;
+ }
+ case AR6000_XIOCTL_DIAG_WRITE:
+ {
+ A_UINT32 addr, data;
+ get_user(addr, (unsigned int *)userdata);
+ get_user(data, (unsigned int *)userdata + 1);
+ addr = TARG_VTOP(ar->arTargetType, addr);
+ if (ar6000_WriteRegDiag(ar->arHifDevice, &addr, &data) != A_OK) {
+ ret = -EIO;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_KEEPALIVE:
+ {
+ WMI_SET_KEEPALIVE_CMD setKeepAlive;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ } else if (copy_from_user(&setKeepAlive, userdata,
+ sizeof(setKeepAlive))){
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_keepalive_cmd(arPriv->arWmi, setKeepAlive.keepaliveInterval) != A_OK) {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_PARAMS:
+ {
+ WMI_SET_PARAMS_CMD cmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ } else if (copy_from_user(&cmd, userdata,
+ sizeof(cmd))){
+ ret = -EFAULT;
+ } else if (copy_from_user(&cmd, userdata,
+ sizeof(cmd) + cmd.length))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_params_cmd(arPriv->arWmi, cmd.opcode, cmd.length, cmd.buffer) != A_OK) {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_MCAST_FILTER:
+ {
+ WMI_SET_MCAST_FILTER_CMD cmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ } else if (copy_from_user(&cmd, userdata,
+ sizeof(cmd))){
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_mcast_filter_cmd(arPriv->arWmi, &cmd.multicast_mac[0]) != A_OK) {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_DEL_MCAST_FILTER:
+ {
+ WMI_SET_MCAST_FILTER_CMD cmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ } else if (copy_from_user(&cmd, userdata,
+ sizeof(cmd))){
+ ret = -EFAULT;
+ } else {
+ if (wmi_del_mcast_filter_cmd(arPriv->arWmi, &cmd.multicast_mac[0]) != A_OK) {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_MCAST_FILTER:
+ {
+ WMI_MCAST_FILTER_CMD cmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ } else if (copy_from_user(&cmd, userdata,
+ sizeof(cmd))){
+ ret = -EFAULT;
+ } else {
+ if (wmi_mcast_filter_cmd(arPriv->arWmi, cmd.enable) != A_OK) {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_KEEPALIVE:
+ {
+ WMI_GET_KEEPALIVE_CMD getKeepAlive;
+ int ret = 0;
+ if (ar->bIsDestroyProgress) {
+ ret =-EBUSY;
+ goto ioctl_done;
+ }
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ if (down_interruptible(&ar->arSem)) {
+ ret = -ERESTARTSYS;
+ goto ioctl_done;
+ }
+ if (ar->bIsDestroyProgress) {
+ up(&ar->arSem);
+ ret = -EBUSY;
+ goto ioctl_done;
+ }
+ if (copy_from_user(&getKeepAlive, userdata,sizeof(getKeepAlive))) {
+ ret = -EFAULT;
+ } else {
+ getKeepAlive.keepaliveInterval = wmi_get_keepalive_cmd(arPriv->arWmi);
+ arSta->arKeepaliveConfigured = 0xFF;
+ if (wmi_get_keepalive_configured(arPriv->arWmi) != A_OK){
+ up(&ar->arSem);
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ wait_event_interruptible_timeout(arPriv->arEvent, arSta->arKeepaliveConfigured != 0xFF, wmitimeout * HZ);
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+
+ if (!ret) {
+ getKeepAlive.configured = arSta->arKeepaliveConfigured;
+ }
+ if (copy_to_user(userdata, &getKeepAlive, sizeof(getKeepAlive))) {
+ ret = -EFAULT;
+ }
+ }
+ up(&ar->arSem);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_APPIE:
+ {
+ WMI_SET_APPIE_CMD appIEcmd;
+ A_UINT8 appIeInfo[IEEE80211_APPIE_FRAME_MAX_LEN];
+ A_UINT32 fType,ieLen;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ get_user(fType, (A_UINT32 *)userdata);
+ appIEcmd.mgmtFrmType = fType;
+ if (appIEcmd.mgmtFrmType >= IEEE80211_APPIE_NUM_OF_FRAME) {
+ ret = -EIO;
+ } else {
+ get_user(ieLen, (A_UINT32 *)(userdata + 4));
+ appIEcmd.ieLen = ieLen;
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("WPSIE: Type-%d, Len-%d\n",appIEcmd.mgmtFrmType, appIEcmd.ieLen));
+ if (appIEcmd.ieLen > IEEE80211_APPIE_FRAME_MAX_LEN) {
+ ret = -EIO;
+ break;
+ }
+ if (copy_from_user(appIeInfo, userdata + 8, appIEcmd.ieLen)) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_appie_cmd(arPriv->arWmi, appIEcmd.mgmtFrmType,
+ appIEcmd.ieLen, appIeInfo) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_MGMT_FRM_RX_FILTER:
+ {
+ WMI_BSS_FILTER_CMD cmd;
+ A_UINT32 filterType;
+
+ if (copy_from_user(&filterType, userdata, sizeof(A_UINT32)))
+ {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+ if (filterType & (IEEE80211_FILTER_TYPE_BEACON |
+ IEEE80211_FILTER_TYPE_PROBE_RESP))
+ {
+ cmd.bssFilter = ALL_BSS_FILTER;
+ } else {
+ cmd.bssFilter = NONE_BSS_FILTER;
+ }
+ if (wmi_bssfilter_cmd(arPriv->arWmi, cmd.bssFilter, 0) != A_OK) {
+ ret = -EIO;
+ } else {
+ arSta->arUserBssFilter = cmd.bssFilter;
+ }
+
+ AR6000_SPIN_LOCK(&arPriv->arPrivLock, 0);
+ arSta->arMgmtFilter = filterType;
+ AR6000_SPIN_UNLOCK(&arPriv->arPrivLock, 0);
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_WSC_STATUS:
+ {
+ A_UINT32 wsc_status;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ } else if (copy_from_user(&wsc_status, userdata, sizeof(A_UINT32))) {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+ if (wmi_set_wsc_status_cmd(arPriv->arWmi, wsc_status) != A_OK) {
+ ret = -EIO;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_BMI_ROMPATCH_INSTALL:
+ {
+ A_UINT32 ROM_addr;
+ A_UINT32 RAM_addr;
+ A_UINT32 nbytes;
+ A_UINT32 do_activate;
+ A_UINT32 rompatch_id;
+
+ get_user(ROM_addr, (A_UINT32 *)userdata);
+ get_user(RAM_addr, (A_UINT32 *)userdata + 1);
+ get_user(nbytes, (A_UINT32 *)userdata + 2);
+ get_user(do_activate, (A_UINT32 *)userdata + 3);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Install rompatch from ROM: 0x%x to RAM: 0x%x length: %d\n",
+ ROM_addr, RAM_addr, nbytes));
+ ret = BMIrompatchInstall(hifDevice, ROM_addr, RAM_addr,
+ nbytes, do_activate, &rompatch_id);
+ if (ret == A_OK) {
+ put_user(rompatch_id, (unsigned int *)rq->ifr_data); /* return value */
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_BMI_ROMPATCH_UNINSTALL:
+ {
+ A_UINT32 rompatch_id;
+
+ get_user(rompatch_id, (A_UINT32 *)userdata);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("UNinstall rompatch_id %d\n", rompatch_id));
+ ret = BMIrompatchUninstall(hifDevice, rompatch_id);
+ break;
+ }
+
+ case AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE:
+ case AR6000_XIOCTL_BMI_ROMPATCH_DEACTIVATE:
+ {
+ A_UINT32 rompatch_count;
+
+ get_user(rompatch_count, (A_UINT32 *)userdata);
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Change rompatch activation count=%d\n", rompatch_count));
+ length = sizeof(A_UINT32) * rompatch_count;
+ if ((buffer = (unsigned char *)A_MALLOC(length)) != NULL) {
+ A_MEMZERO(buffer, length);
+ if (copy_from_user(buffer, &userdata[sizeof(rompatch_count)], length))
+ {
+ ret = -EFAULT;
+ } else {
+ if (cmd == AR6000_XIOCTL_BMI_ROMPATCH_ACTIVATE) {
+ ret = BMIrompatchActivate(hifDevice, rompatch_count, (A_UINT32 *)buffer);
+ } else {
+ ret = BMIrompatchDeactivate(hifDevice, rompatch_count, (A_UINT32 *)buffer);
+ }
+ }
+ A_FREE(buffer);
+ } else {
+ ret = -ENOMEM;
+ }
+
+ break;
+ }
+ case AR6000_XIOCTL_SET_IP:
+ {
+ WMI_SET_IP_CMD setIP;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setIP, userdata,
+ sizeof(setIP))) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_ip_cmd(arPriv->arWmi,
+ &setIP) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_SET_HOST_SLEEP_MODE:
+ {
+ WMI_SET_HOST_SLEEP_MODE_CMD setHostSleepMode;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setHostSleepMode, userdata,
+ sizeof(setHostSleepMode))) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_host_sleep_mode_cmd(arPriv->arWmi,
+ &setHostSleepMode) != A_OK)
+ {
+ ret = -EIO;
+ } else {
+ if (setHostSleepMode.asleep) {
+ ar->isHostAsleep = 1;
+ } else {
+ ar->isHostAsleep = 0;
+ }
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_WOW_MODE:
+ {
+ WMI_SET_WOW_MODE_CMD setWowMode;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&setWowMode, userdata,
+ sizeof(setWowMode))) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_wow_mode_cmd(arPriv->arWmi,
+ &setWowMode) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_WOW_LIST:
+ {
+ WMI_GET_WOW_LIST_CMD getWowList;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&getWowList, userdata,
+ sizeof(getWowList))) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_get_wow_list_cmd(arPriv->arWmi,
+ &getWowList) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_ADD_WOW_PATTERN:
+ ret = ar6000_xioctl_add_wowptn(arPriv, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_DEL_WOW_PATTERN:
+ {
+ WMI_DEL_WOW_PATTERN_CMD delWowPattern;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&delWowPattern, userdata,
+ sizeof(delWowPattern))) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_del_wow_pattern_cmd(arPriv->arWmi,
+ &delWowPattern) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_DUMP_HTC_CREDIT_STATE:
+ ret = ar6000_xioctl_dump_htccredit(arPriv);
+ break;
+
+ case AR6000_XIOCTL_TRAFFIC_ACTIVITY_CHANGE:
+ if (ar->arHtcTarget != NULL) {
+ struct ar6000_traffic_activity_change data;
+
+ if (copy_from_user(&data, userdata, sizeof(data)))
+ {
+ ret = -EFAULT;
+ goto ioctl_done;
+ }
+ /* note, this is used for testing (mbox ping testing), indicate activity
+ * change using the stream ID as the traffic class */
+ ar6000_indicate_tx_activity(arPriv,
+ (A_UINT8)data.StreamID,
+ data.Active ? TRUE : FALSE);
+ }
+ break;
+ case AR6000_XIOCTL_WMI_SET_CONNECT_CTRL_FLAGS:
+ {
+ A_UINT32 connectCtrlFlags;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&connectCtrlFlags, userdata,
+ sizeof(connectCtrlFlags)))
+ {
+ ret = -EFAULT;
+ } else {
+ arSta->arConnectCtrlFlags = connectCtrlFlags;
+ }
+ }
+ break;
+ case AR6000_XIOCTL_WMI_SET_AKMP_PARAMS:
+ {
+ WMI_SET_AKMP_PARAMS_CMD akmpParams;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&akmpParams, userdata,
+ sizeof(WMI_SET_AKMP_PARAMS_CMD)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_set_akmp_params_cmd(arPriv->arWmi, &akmpParams) != A_OK) {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_SET_PMKID_LIST:
+ {
+ WMI_SET_PMKID_LIST_CMD pmkidInfo;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ break;
+ }
+ if (copy_from_user(&pmkidInfo.numPMKID, userdata,
+ sizeof(pmkidInfo.numPMKID))) {
+ ret = -EFAULT;
+ break;
+ }
+ if (copy_from_user(&pmkidInfo.pmkidList,
+ userdata + sizeof(pmkidInfo.numPMKID),
+ pmkidInfo.numPMKID * sizeof(WMI_PMKID)))
+ {
+ ret = -EFAULT;
+ break;
+ }
+ if (wmi_set_pmkid_list_cmd(arPriv->arWmi, &pmkidInfo) != A_OK) {
+ ret = -EIO;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_PMKID_LIST:
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (wmi_get_pmkid_list_cmd(arPriv->arWmi) != A_OK) {
+ ret = -EIO;
+ }
+ break;
+ case AR6000_XIOCTL_WMI_ABORT_SCAN:
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ }
+ ret = wmi_abort_scan_cmd(arPriv->arWmi);
+ break;
+ case AR6000_XIOCTL_AP_HIDDEN_SSID:
+ {
+ A_UINT8 hidden_ssid;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&hidden_ssid, userdata, sizeof(hidden_ssid))) {
+ ret = -EFAULT;
+ } else {
+ wmi_ap_set_hidden_ssid(arPriv->arWmi, hidden_ssid);
+ arAp->ap_hidden_ssid = hidden_ssid;
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_STA_LIST:
+ {
+ WMI_SET_HT_CAP_CMD htCap;
+
+ htCap.band = A_BAND_24GHZ;
+ if(arPriv->phymode == WMI_11A_MODE) {
+ htCap.band = A_BAND_5GHZ;
+ }
+ wmi_get_ht_cap_cmd(arPriv->arWmi, &htCap);
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else {
+ A_UINT8 i, j=0;
+ ap_get_sta_t temp;
+ A_MEMZERO(&temp, sizeof(temp));
+ for(i=0;i<NUM_CONN;i++) {
+ if(ar->connTbl[i].arPriv == arPriv) {
+ A_MEMCPY(temp.sta[j].mac, ar->connTbl[i].mac, ATH_MAC_LEN);
+ temp.sta[j].aid = ar->connTbl[i].aid;
+ temp.sta[j].keymgmt = ar->connTbl[i].keymgmt;
+ temp.sta[j].ucipher = ar->connTbl[i].ucipher;
+ temp.sta[j].auth = ar->connTbl[i].auth;
+ temp.sta[j].wmode = ar->connTbl[i].wmode;
+ if(htCap.enable == 2) {
+ /* Set MSB to indicate 11n-only mode */
+ temp.sta[j].wmode |= 0x80;
+ }
+ j++;
+ }
+ }
+ if(copy_to_user((ap_get_sta_t *)rq->ifr_data, &temp, sizeof(temp))) {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_SET_NUM_STA:
+ {
+ A_UINT8 num_sta;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&num_sta, userdata, sizeof(num_sta))) {
+ ret = -EFAULT;
+ } else {
+ ret = ar6000_ap_set_num_sta(ar, arPriv, num_sta);
+ printk("ar6000_ap_set_num_sta %d ret %d \n",num_sta,ret);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_SET_DFS:
+ {
+#ifdef ATH_SUPPORT_DFS
+ A_UINT8 enable;
+ if (copy_from_user(&enable, userdata, sizeof(enable))) {
+ ret = -EFAULT;
+ } else {
+ wmi_ap_set_dfs(arPriv->arWmi, enable);
+ }
+#else
+ ret = -EIO;
+#endif
+ break;
+ }
+
+ case AR6000_XIOCTL_AP_SET_ACL_POLICY:
+ {
+ A_UINT8 policy;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&policy, userdata, sizeof(policy))) {
+ ret = -EFAULT;
+ } else {
+ if(!(policy & AP_ACL_RETAIN_LIST_MASK)) {
+ /* clear ACL list */
+ memset(&arAp->g_acl,0,sizeof(WMI_AP_ACL));
+ }
+ arAp->g_acl.policy = policy;
+ wmi_ap_set_acl_policy(arPriv->arWmi, policy);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_SET_ACL_MAC:
+ {
+ WMI_AP_ACL_MAC_CMD acl;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&acl, userdata, sizeof(acl))) {
+ ret = -EFAULT;
+ } else {
+ if(acl_add_del_mac(&arAp->g_acl, &acl)) {
+ wmi_ap_acl_mac_list(arPriv->arWmi, &acl);
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("ACL list error\n"));
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_ACL_LIST:
+ {
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if(copy_to_user((WMI_AP_ACL *)rq->ifr_data, &arAp->g_acl,
+ sizeof(WMI_AP_ACL))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_COMMIT_CONFIG:
+ {
+ A_STATUS status = ar6000_check_connect_request(arPriv, TRUE);
+ if( A_OK == status ) {
+ ret = ar6000_ap_mode_profile_commit(arPriv);
+ } else if (A_ERROR == status){
+ ret = -EINVAL;
+ }
+ else {
+ ret = 0;
+ }
+ break;
+ }
+ case IEEE80211_IOCTL_GETWPAIE:
+ ret = ar6000_ioctl_get_wpaie(arPriv, userdata);
+ break;
+
+ case AR6000_XIOCTL_AP_CONN_INACT_TIME:
+ {
+ A_UINT32 period;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&period, userdata, sizeof(period))) {
+ ret = -EFAULT;
+ } else {
+ wmi_ap_conn_inact_time(arPriv->arWmi, period);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_PROT_SCAN_TIME:
+ {
+ WMI_AP_PROT_SCAN_TIME_CMD bgscan;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&bgscan, userdata, sizeof(bgscan))) {
+ ret = -EFAULT;
+ } else {
+ wmi_ap_bgscan_time(arPriv->arWmi, bgscan.period_min, bgscan.dwell_ms);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_SET_COUNTRY:
+ {
+ ret = ar6000_ioctl_set_country(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_AP_SET_DTIM:
+ {
+ WMI_AP_SET_DTIM_CMD d;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&d, userdata, sizeof(d))) {
+ ret = -EFAULT;
+ } else {
+ if(d.dtim > 0 && d.dtim < 11) {
+ arAp->ap_dtim_period = d.dtim;
+ wmi_ap_set_dtim(arPriv->arWmi, d.dtim);
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("DTIM out of range. Valid range is [1-10]\n"));
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_TARGET_EVENT_REPORT:
+ {
+ WMI_SET_TARGET_EVENT_REPORT_CMD evtCfgCmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ }
+ if (copy_from_user(&evtCfgCmd, userdata,
+ sizeof(evtCfgCmd))) {
+ ret = -EFAULT;
+ break;
+ }
+ ret = wmi_set_target_event_report_cmd(arPriv->arWmi, &evtCfgCmd);
+ break;
+ }
+ case AR6000_XIOCTL_AP_CTRL_BSS_COMM:
+ {
+ A_UINT8 intra=0;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&intra, userdata, sizeof(intra))) {
+ ret = -EFAULT;
+ } else {
+ if(intra & 0x80) { /* interbss */
+ ar->inter_bss = ( (intra & 0xF) ? 1 : 0 );
+ } else {
+ arAp->intra_bss = ( intra ? 1 : 0 );
+ }
+ }
+#ifdef P2P
+ /* If P2P is enabled on this device, also indicate intra_bss setting to the firmware
+ * so that it can be reflected in the Group Capability bit of the p2p-go.
+ */
+ {
+ NETWORK_SUBTYPE networkSubType = arPriv->arNetworkSubType;
+
+ if (networkSubType == SUBTYPE_P2PDEV ||
+ networkSubType == SUBTYPE_P2PCLIENT ||
+ networkSubType == SUBTYPE_P2PGO) {
+
+ WMI_P2P_SET_CMD set_p2p_config;
+ A_MEMZERO(&set_p2p_config, sizeof(WMI_P2P_SET_CMD));
+
+ set_p2p_config.config_id = WMI_P2P_CONFID_INTRA_BSS;
+ set_p2p_config.val.intra_bss.flag = intra;
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv), P2P_GROUP_CAPAB_INTRA_BSS_DIST, intra);
+ wmi_p2p_set_cmd(arPriv->arWmi, &set_p2p_config);
+ }
+ }
+#endif /* P2P */
+ break;
+ }
+ case AR6000_XIOCTL_DUMP_MODULE_DEBUG_INFO:
+ {
+ struct drv_debug_module_s moduleinfo;
+
+ if (copy_from_user(&moduleinfo, userdata, sizeof(moduleinfo))) {
+ ret = -EFAULT;
+ break;
+ }
+
+ a_dump_module_debug_info_by_name(moduleinfo.modulename);
+ ret = 0;
+ break;
+ }
+ case AR6000_XIOCTL_MODULE_DEBUG_SET_MASK:
+ {
+ struct drv_debug_module_s moduleinfo;
+
+ if (copy_from_user(&moduleinfo, userdata, sizeof(moduleinfo))) {
+ ret = -EFAULT;
+ break;
+ }
+
+ if (A_FAILED(a_set_module_mask(moduleinfo.modulename, moduleinfo.mask))) {
+ ret = -EFAULT;
+ }
+
+ break;
+ }
+ case AR6000_XIOCTL_MODULE_DEBUG_GET_MASK:
+ {
+ struct drv_debug_module_s moduleinfo;
+
+ if (copy_from_user(&moduleinfo, userdata, sizeof(moduleinfo))) {
+ ret = -EFAULT;
+ break;
+ }
+
+ if (A_FAILED(a_get_module_mask(moduleinfo.modulename, &moduleinfo.mask))) {
+ ret = -EFAULT;
+ break;
+ }
+
+ if (copy_to_user(userdata, &moduleinfo, sizeof(moduleinfo))) {
+ ret = -EFAULT;
+ break;
+ }
+
+ break;
+ }
+#ifdef ATH_AR6K_11N_SUPPORT
+ case AR6000_XIOCTL_DUMP_RCV_AGGR_STATS:
+ {
+ PACKET_LOG *copy_of_pkt_log;
+
+ aggr_dump_stats(ar->connTbl[0].conn_aggr, ©_of_pkt_log);
+ if (copy_to_user(rq->ifr_data, copy_of_pkt_log, sizeof(PACKET_LOG))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_SETUP_AGGR:
+ {
+ WMI_ADDBA_REQ_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ ret = -EFAULT;
+ } else {
+ wmi_setup_aggr_cmd(arPriv->arWmi, cmd.tid);
+ }
+ }
+ break;
+
+ case AR6000_XIOCTL_DELE_AGGR:
+ {
+ WMI_DELBA_REQ_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ ret = -EFAULT;
+ } else {
+ wmi_delete_aggr_cmd(arPriv->arWmi, cmd.tid, cmd.is_sender_initiator);
+ }
+ }
+ break;
+
+ case AR6000_XIOCTL_ALLOW_AGGR:
+ {
+ WMI_ALLOW_AGGR_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ ret = -EFAULT;
+ } else {
+ wmi_allow_aggr_cmd(arPriv->arWmi, cmd.tx_allow_aggr, cmd.rx_allow_aggr);
+ }
+ }
+ break;
+
+ case AR6000_XIOCTL_SET_HT_CAP:
+ {
+ WMI_SET_HT_CAP_CMD htCap;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&htCap, userdata, sizeof(htCap))) {
+ ret = -EFAULT;
+ } else if (wmi_set_ht_cap_cmd(arPriv->arWmi, &htCap) != A_OK) {
+ ret = -EIO;
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_GET_HT_CAP:
+ {
+ WMI_SET_HT_CAP_CMD htCap;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&htCap, userdata, sizeof(htCap))) {
+ ret = -EFAULT;
+ } else if (wmi_get_ht_cap_cmd(arPriv->arWmi, &htCap) != A_OK) {
+ ret = -EIO;
+ } else if(copy_to_user((WMI_SET_HT_CAP_CMD *)rq->ifr_data,
+ &htCap, sizeof(htCap))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_SET_HT_OP:
+ {
+ WMI_SET_HT_OP_CMD htOp;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&htOp, userdata,
+ sizeof(htOp))){
+ ret = -EFAULT;
+ } else {
+
+ if (wmi_set_ht_op_cmd(arPriv->arWmi, htOp.sta_chan_width) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+#endif
+
+#ifdef BTCOEX
+ case AR6000_XIOCTL_ACL_DATA:
+ {
+ void *osbuf = NULL;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (ar6000_create_acl_data_osbuf(dev, (A_UINT8*)userdata, &osbuf) != A_OK) {
+ ret = -EIO;
+ } else {
+ if (wmi_data_hdr_add(arPriv->arWmi, osbuf, DATA_MSGTYPE, 0, WMI_DATA_HDR_DATA_TYPE_ACL,0,NULL) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("XIOCTL_ACL_DATA - wmi_data_hdr_add failed\n"));
+ } else {
+ /* Send data buffer over HTC */
+ ar6000_acl_data_tx(osbuf, arPriv);
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_HCI_CMD:
+ ret = ar6000_xioctl_hci_cmd(arPriv, userdata);
+ break;
+
+ case AR6000_XIOCTL_WLAN_CONN_PRECEDENCE:
+ {
+ WMI_SET_BT_WLAN_CONN_PRECEDENCE cmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd))) {
+ ret = -EFAULT;
+ } else {
+ if (cmd.precedence == BT_WLAN_CONN_PRECDENCE_WLAN ||
+ cmd.precedence == BT_WLAN_CONN_PRECDENCE_PAL) {
+ if ( wmi_set_wlan_conn_precedence_cmd(arPriv->arWmi, cmd.precedence) != A_OK) {
+ ret = -EIO;
+ }
+ } else {
+ ret = -EINVAL;
+ }
+ }
+ break;
+ }
+#endif
+ case AR6000_XIOCTL_AP_GET_STAT:
+ {
+ ret = ar6000_ioctl_get_ap_stats(dev, rq);
+ break;
+ }
+ case AR6000_XIOCTL_SET_TX_SELECT_RATES:
+ {
+ WMI_SET_TX_SELECT_RATES_CMD masks;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&masks, userdata,
+ sizeof(masks))) {
+ ret = -EFAULT;
+ } else {
+
+ if (wmi_set_tx_select_rates_cmd(arPriv->arWmi, masks.rateMasks) != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_HIDDEN_SSID:
+ {
+ WMI_AP_HIDDEN_SSID_CMD ssid;
+ ssid.hidden_ssid = arAp->ap_hidden_ssid;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if(copy_to_user((WMI_AP_HIDDEN_SSID_CMD *)rq->ifr_data,
+ &ssid, sizeof(WMI_AP_HIDDEN_SSID_CMD))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_COUNTRY:
+ {
+ WMI_AP_SET_COUNTRY_CMD cty;
+ A_MEMCPY(cty.countryCode, arAp->ap_country_code, 3);
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if(copy_to_user((WMI_AP_SET_COUNTRY_CMD *)rq->ifr_data,
+ &cty, sizeof(WMI_AP_SET_COUNTRY_CMD))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_WMODE:
+ {
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if(copy_to_user((A_UINT8 *)rq->ifr_data,
+ &arPriv->phymode, sizeof(A_UINT8))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_DTIM:
+ {
+ WMI_AP_SET_DTIM_CMD dtim;
+ dtim.dtim = arAp->ap_dtim_period;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if(copy_to_user((WMI_AP_SET_DTIM_CMD *)rq->ifr_data,
+ &dtim, sizeof(WMI_AP_SET_DTIM_CMD))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_BINTVL:
+ {
+ WMI_BEACON_INT_CMD bi;
+ bi.beaconInterval = arAp->ap_beacon_interval;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if(copy_to_user((WMI_BEACON_INT_CMD *)rq->ifr_data,
+ &bi, sizeof(WMI_BEACON_INT_CMD))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_RTS:
+ {
+ WMI_SET_RTS_CMD rts;
+ rts.threshold = arAp->arRTS;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if(copy_to_user((WMI_SET_RTS_CMD *)rq->ifr_data,
+ &rts, sizeof(WMI_SET_RTS_CMD))) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_FETCH_TARGET_REGS:
+ ret = ar6000_xioctl_fetch_targ_regs(arPriv, rq, hifDevice);
+ break;
+
+ case AR6000_XIOCTL_AP_SET_11BG_RATESET:
+ {
+ WMI_AP_SET_11BG_RATESET_CMD rate;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&rate, userdata, sizeof(rate))) {
+ ret = -EFAULT;
+ } else {
+ wmi_ap_set_rateset(arPriv->arWmi, rate.rateset);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_GET_WLAN_SLEEP_STATE:
+ {
+ WMI_REPORT_SLEEP_STATE_EVENT wmiSleepEvent ;
+
+ if (ar->arWlanState == WLAN_ENABLED) {
+ wmiSleepEvent.sleepState = WMI_REPORT_SLEEP_STATUS_IS_AWAKE;
+ } else {
+ wmiSleepEvent.sleepState = WMI_REPORT_SLEEP_STATUS_IS_DEEP_SLEEP;
+ }
+ rq->ifr_ifru.ifru_ivalue = ar->arWlanState; /* return value */
+ ar6000_send_event_to_app(arPriv, WMI_REPORT_SLEEP_STATE_EVENTID, (A_UINT8*)&wmiSleepEvent,
+ sizeof(WMI_REPORT_SLEEP_STATE_EVENTID));
+ break;
+ }
+#ifdef P2P
+ case AR6000_XIOCTL_WMI_P2P_DISCOVER:
+ {
+ WMI_BSS_FILTER_CMD filt;
+
+ /*Issue the WMI_FIND CMD*/
+ WMI_P2P_FIND_CMD find_param;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ break;
+ }
+ A_MEMZERO(&filt, sizeof(WMI_BSS_FILTER_CMD));
+ /*Set BSS filter to ALL*/
+ filt.bssFilter = ALL_BSS_FILTER;
+
+ if (wmi_bssfilter_cmd(arPriv->arWmi, filt.bssFilter, filt.ieMask)
+ != A_OK) {
+ ret = -EIO;
+ } else {
+ arSta->arUserBssFilter = filt.bssFilter;
+ if (copy_from_user(&find_param, userdata, sizeof(WMI_P2P_FIND_CMD))) {
+ ret = -EFAULT;
+ } else {
+ p2p_clear_peers_reported_flag(A_WMI_GET_P2P_CTX(arPriv));
+ wmi_p2p_discover(arPriv->arWmi, &find_param);
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_STOP_FIND:
+ {
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else {
+ wmi_p2p_stop_find(arPriv->arWmi);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_CANCEL:
+ {
+ wmi_p2p_cancel(arPriv->arWmi);
+ p2p_clear_group_peer(A_WMI_GET_P2P_CTX(arPriv));
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_LISTEN:
+ {
+ A_UINT32 timeout;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&timeout, userdata, sizeof(timeout))) {
+ ret = -EFAULT;
+ } else {
+ wmi_p2p_listen(arPriv->arWmi, timeout);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_GO_NEG:
+ {
+ /*Issue the WMI_GO_NEG CMD*/
+ WMI_P2P_GO_NEG_START_CMD go_param;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&go_param, userdata, sizeof(WMI_P2P_GO_NEG_START_CMD))) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_go_neg_start(A_WMI_GET_P2P_CTX(arPriv), &go_param)
+ != A_OK) {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_AUTH_GO_NEG:
+ {
+ WMI_P2P_GO_NEG_START_CMD go_neg_auth_param;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&go_neg_auth_param, userdata, sizeof(WMI_P2P_GO_NEG_START_CMD))) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_auth_go_neg(A_WMI_GET_P2P_CTX(arPriv),
+ &go_neg_auth_param) != A_OK) {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_REJECT:
+ {
+ A_UINT8 p2p_reject_peer[IEEE80211_ADDR_LEN];
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(p2p_reject_peer, userdata,
+ IEEE80211_ADDR_LEN)) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_peer_reject(A_WMI_GET_P2P_CTX(arPriv),
+ p2p_reject_peer) != A_OK) {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_CONFIG:
+ {
+ WMI_P2P_SET_CONFIG_CMD set_p2p_config;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&set_p2p_config, userdata, sizeof(WMI_P2P_SET_CONFIG_CMD))) {
+ ret = -EFAULT;
+ } else {
+ wmi_p2p_set_config(arPriv->arWmi, &set_p2p_config);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_WPS_CONFIG:
+ {
+ WMI_WPS_SET_CONFIG_CMD set_wps_config;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&set_wps_config, userdata, sizeof(WMI_WPS_SET_CONFIG_CMD))) {
+ ret = -EFAULT;
+ } else {
+ wmi_wps_set_config(arPriv->arWmi, &set_wps_config);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_FINDNODE:
+ {
+ A_UINT8 macaddr[AR6000_ETH_ADDR_LEN];
+ bss_t *ni;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(macaddr, userdata,AR6000_ETH_ADDR_LEN)) {
+ ret = -EFAULT;
+ } else {
+ ni = wmi_find_node(arPriv->arWmi, macaddr);
+ if (ni) {
+ if(copy_to_user((A_UINT16 *)rq->ifr_data,
+ &ni->ni_cie.ie_chan, sizeof(A_UINT16))) {
+ ret = -EFAULT;
+ }
+ }
+ else {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_GRP_INIT:
+ {
+ WMI_P2P_GRP_INIT_CMD p2p_grp_init_cmd;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&p2p_grp_init_cmd, userdata,
+ sizeof(WMI_P2P_GRP_INIT_CMD))) {
+ ret = -EFAULT;
+ } else {
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv), P2P_GROUP_CAPAB_GROUP_FORMATION,
+ p2p_grp_init_cmd.group_formation);
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv), P2P_GROUP_CAPAB_PERSISTENT_GROUP,
+ p2p_grp_init_cmd.persistent_group);
+ wmi_p2p_grp_init_cmd(arPriv->arWmi, &p2p_grp_init_cmd);
+
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_GRP_FORMATION_DONE:
+ {
+ WMI_P2P_GRP_FORMATION_DONE_CMD p2p_grp_done_cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&p2p_grp_done_cmd, userdata,
+ sizeof(WMI_P2P_GRP_FORMATION_DONE_CMD))) {
+ ret = -EFAULT;
+ } else {
+ p2p_set_group_capability(A_WMI_GET_P2P_CTX(arPriv), P2P_GROUP_CAPAB_GROUP_FORMATION,
+ 0);
+ wmi_p2p_grp_done_cmd(arPriv->arWmi, &p2p_grp_done_cmd);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_INVITE:
+ {
+ WMI_P2P_INVITE_CMD p2p_invite_param;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&p2p_invite_param, userdata,
+ sizeof(WMI_P2P_INVITE_CMD))) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_invite_cmd(A_WMI_GET_P2P_CTX(arPriv), &p2p_invite_param)
+ != A_OK) {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_PROV_DISC:
+ ret = ar6000_xioctl_wmi_p2p_provdisc(arPriv, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_P2P_GET_IF_ADDR:
+ {
+ A_UINT8 buf[12];
+ const A_UINT8 zero_mac[] = {0,0,0,0,0,0};
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(buf, userdata, 12)) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_get_ifaddr(A_WMI_GET_P2P_CTX(arPriv),
+ buf) == A_OK) {
+ if(copy_to_user((A_UINT8 *)rq->ifr_data,
+ buf+6, IEEE80211_ADDR_LEN)) {
+ ret = -EFAULT;
+ }
+ } else {
+ if(copy_to_user((A_UINT8 *)rq->ifr_data,
+ zero_mac, IEEE80211_ADDR_LEN)) {
+ ret = -EFAULT;
+ }
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_GET_DEV_ADDR:
+ {
+ A_UINT8 buf[12];
+ const A_UINT8 zero_mac[] = {0,0,0,0,0,0};
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(buf, userdata, 12)) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_get_devaddr(A_WMI_GET_P2P_CTX(arPriv),
+ buf) == A_OK) {
+ if(copy_to_user((A_UINT8 *)rq->ifr_data,
+ buf+6, IEEE80211_ADDR_LEN)) {
+ ret = -EFAULT;
+ }
+ } else {
+ if(copy_to_user((A_UINT8 *)rq->ifr_data,
+ zero_mac, IEEE80211_ADDR_LEN)) {
+ ret = -EFAULT;
+ }
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_SET:
+ ret = ar6000_xioctl_wmi_p2p_set(arPriv, userdata);
+ break;
+
+ case AR6000_XIOCTL_WMI_P2P_PEER:
+ ret = ar6000_xioctl_wmi_p2p_peer(arPriv, userdata, rq);
+ break;
+
+ case AR6000_XIOCTL_WMI_P2P_FLUSH:
+ {
+ p2p_free_all_devices(A_WMI_GET_P2P_CTX(arPriv));
+ p2p_free_all_sd_queries(A_WMI_GET_P2P_CTX(arPriv));
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_GO_PARAMS:
+ {
+ A_UINT8 go_dev_addr[AR6000_ETH_ADDR_LEN];
+ struct {
+ A_UINT16 oper_freq;
+ A_UINT8 ssid[WMI_MAX_SSID_LEN];
+ A_UINT8 ssid_len;
+ } go_params;
+
+ A_MEMZERO(&go_params, sizeof(go_params));
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(go_dev_addr,
+ userdata, AR6000_ETH_ADDR_LEN)) {
+ ret = -EFAULT;
+ } else {
+ if (wmi_p2p_get_go_params(A_WMI_GET_P2P_CTX(arPriv),
+ go_dev_addr, &go_params.oper_freq, go_params.ssid,
+ &go_params.ssid_len) == A_OK) {
+ if(copy_to_user((A_UINT16 *)rq->ifr_data,
+ &go_params, sizeof(go_params))) {
+ ret = -EFAULT;
+ }
+ } else {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_P2P_AUTH_INVITE:
+ {
+ P2P_AUTH_INVITE_CMD auth_invite_cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&auth_invite_cmd, userdata,sizeof(P2P_AUTH_INVITE_CMD))) {
+ ret = -EFAULT;
+ } else {
+ if (p2p_auth_invite(A_WMI_GET_P2P_CTX(arPriv),
+ auth_invite_cmd.auth,
+ (A_UINT8 *)&(auth_invite_cmd.peer_addr)) != A_OK) {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_SDPD_TX_CMD:
+ ret = ar6000_xioctl_wmi_p2p_sdpdtx(arPriv, userdata, rq);
+ break;
+
+ case AR6000_XIOTCL_WMI_P2P_SD_CANCEL_REQUEST:
+ {
+ A_UINT32 qid;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&qid, userdata, sizeof(qid))) {
+ ret = -EFAULT;
+ } else if (p2p_sd_cancel_request(A_WMI_GET_P2P_CTX(arPriv),qid) !=
+ A_OK) {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_GET_P2P_IE:
+ {
+ A_UINT8 buf[12];
+ const A_UINT8 zero_mac[] = {0,0,0,0,0,0};
+ A_UINT8 * p2p_buf = NULL;
+ A_UINT8 p2p_buf_len = 0;
+
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(buf, userdata, 12)) {
+ ret = -EFAULT;
+ } else {
+
+ if (p2p_peer(A_WMI_GET_P2P_CTX(arPriv),
+ buf, *(buf+6)) == A_OK) {
+
+ p2p_get_device_p2p_buf(A_WMI_GET_P2P_CTX(arPriv),buf, &p2p_buf, &p2p_buf_len);
+
+ if(p2p_buf) {
+ *((A_UINT8 *)rq->ifr_data) = p2p_buf_len;
+
+ if(copy_to_user(((A_UINT8 *)(rq->ifr_data)+1),
+ p2p_buf, p2p_buf_len)) {
+ ret = -EFAULT;
+ }
+ }
+ } else {
+ if(copy_to_user((A_UINT16 *)rq->ifr_data,
+ zero_mac, IEEE80211_ADDR_LEN)) {
+ ret = -EFAULT;
+ }
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_P2P_GET_OWN_INFO:
+ {
+ A_UINT8 buf[200];
+ A_UINT8 buf_len = 0;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else {
+ buf_len = p2p_get_own_info(A_WMI_GET_P2P_CTX(arPriv),buf, sizeof(buf));
+ *((A_UINT8 *)rq->ifr_data) = buf_len;
+ if(copy_to_user(((A_UINT8 *)(rq->ifr_data)+1),
+ buf, buf_len)) {
+ ret = -EFAULT;
+ }
+
+ }
+ break;
+ }
+#endif /* P2P */
+
+#ifdef CONFIG_PM
+ case AR6000_XIOCTL_SET_BT_HW_POWER_STATE:
+ {
+ unsigned int state;
+ get_user(state, (unsigned int *)userdata);
+ if (ar6000_set_bt_hw_state(ar, state)!=A_OK) {
+ ret = -EIO;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_GET_BT_HW_POWER_STATE:
+ rq->ifr_ifru.ifru_ivalue = !ar->arBTOff; /* return value */
+ break;
+#endif
+
+ case AR6000_XIOCTL_WMI_SET_TX_SGI_PARAM:
+ {
+ WMI_SET_TX_SGI_PARAM_CMD SGICmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&SGICmd, userdata,
+ sizeof(SGICmd))){
+ ret = -EFAULT;
+ } else{
+ if (wmi_SGI_cmd(arPriv->arWmi, SGICmd.sgiMask, SGICmd.sgiPERThreshold) != A_OK) {
+ ret = -EIO;
+ }
+
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_SET_PASSPHRASE:
+ {
+ ret = ar6000_xioctl_set_passphrase_cmd(dev, userdata);
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_SET_EXCESS_TX_RETRY_THRES:
+ {
+ ret = ar6000_xioctl_set_excess_tx_retry_thres_cmd(dev, userdata);
+ break;
+ }
+#ifdef WAC
+ case AR6000_XIOCTL_WMI_ENABLE_WAC_PARAM:
+ {
+ WMI_WAC_ENABLE_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if ( cmd.enable & 0x80 ) {
+ cmd.enable &= ~0x80;
+ ar6000_send_generic_event_to_app(arPriv, WMI_ENABLE_WAC_CMDID,
+ (A_UINT8*)&cmd, sizeof(WMI_WAC_ENABLE_CMD));
+ }
+ else {
+ if (wmi_wac_enable_cmd(arPriv->arWmi, &cmd)
+ != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WAC_SCAN_REPLY:
+ {
+ WMI_WAC_SCAN_REPLY_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if (wmi_wac_scan_reply_cmd(arPriv->arWmi, cmd.cmdid)
+ != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_WAC_CTRL_REQ:
+ {
+ WMI_WAC_CTRL_REQ_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd)))
+ {
+ ret = -EFAULT;
+ } else {
+ if ( WAC_SET == cmd.req ) {
+ if (wmi_wac_ctrl_req_cmd(arPriv->arWmi, &cmd)
+ != A_OK)
+ {
+ ret = -EIO;
+ }
+ }
+ else if ( WAC_GET == cmd.req ) {
+ ret = ar6000_xioctl_wac_ctrl_req_get_cmd(dev, userdata, rq);
+ }
+ }
+ break;
+ }
+#endif
+ case AR6000_XIOCTL_WMI_SET_WPA_OFFLOAD_STATE:
+ {
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27)
+ A_UINT8 wpaOffloadState = 0;
+
+ if (copy_from_user(&wpaOffloadState, userdata, sizeof(A_UINT8))) {
+ ret = -EFAULT;
+ } else {
+ arSta->wpaOffloadEnabled = (wpaOffloadState) ? TRUE : FALSE;
+ }
+#else
+ ret = -EOPNOTSUPP;
+#endif /* LINUX_VERSION_CODE >= 2.6.27 */
+ break;
+ }
+ case AR6000_XIOCTL_BMI_NVRAM_PROCESS:
+ {
+ A_UCHAR seg_name[BMI_NVRAM_SEG_NAME_SZ+1];
+ A_UINT32 rv = 0;
+
+ if (copy_from_user(seg_name, userdata, sizeof(seg_name))) {
+ ret = -EFAULT;
+ break;
+ }
+
+ seg_name[BMI_NVRAM_SEG_NAME_SZ] = '\0';
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("Process NVRAM segment: %s\n", seg_name));
+
+ if (BMInvramProcess(hifDevice, seg_name, &rv) != A_OK) {
+ ret = -EIO;
+ }
+ put_user(rv, (unsigned int *)rq->ifr_data); /* return value */
+
+ break;
+ }
+
+ case AR6000_XIOCTL_AP_ACS_POLICY:
+ {
+ A_UINT32 acs;
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&acs, userdata, sizeof(acs))) {
+ ret = -EFAULT;
+ } else {
+ ar->arAcsPolicy = acs;
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_FORCE_ASSERT:
+ {
+ if (wmi_force_target_assert(arPriv->arWmi) != A_OK)
+ {
+ ret = -EIO;
+ }
+ break;
+ }
+
+ case AR6000_XIOCTL_WMI_SET_DIVERSITY_PARAM:
+ {
+ WMI_DIV_PARAMS_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(cmd)))
+ {
+ ret = -EFAULT;
+ } else
+ {
+ if (wmi_set_div_param_cmd(arPriv->arWmi, cmd.divIdleTime, cmd.antRssiThresh, cmd.divEnable, cmd.active_treshold_rate)
+ != A_OK)
+ {
+ ret = -EIO;
+ }
+
+ }
+ break;
+ }
+ case AR6000_XIOCTL_AP_GET_NUM_STA:
+ {
+ A_UINT8 num_sta, ret_num_sta;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&num_sta, userdata, sizeof(num_sta))) {
+ ret = -EFAULT;
+ } else {
+ if(num_sta & 0x80) {
+ ret_num_sta = ar->gNumSta;
+ } else {
+ ret_num_sta = arPriv->num_sta;
+ }
+ if(copy_to_user((A_UINT8 *)rq->ifr_data,
+ &ret_num_sta, sizeof(A_UINT8))) {
+ ret = -EFAULT;
+ }
+ }
+ break;
+ }
+#ifdef CONFIG_PM
+ case AR6000_XIOCTL_SUSPEND_DRIVER:
+ {
+ ar6000_suspend_ev(ar);
+ break;
+ }
+ case AR6000_XIOCTL_RESUME_DRIVER:
+ {
+ ar6000_resume_ev(ar);
+ break;
+ }
+#endif
+ case AR6000_XIOCTL_GET_SUBMODE:
+ {
+ if (copy_to_user((A_UINT8 *)rq->ifr_data, &arPriv->arNetworkSubType,
+ sizeof(A_UINT8)))
+ {
+ ret = -EFAULT;
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_AP_SET_APSD:
+ {
+ WMI_AP_SET_APSD_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(WMI_AP_SET_APSD_CMD))) {
+ ret = -EFAULT;
+ } else {
+ if(wmi_ap_set_apsd(arPriv->arWmi, cmd.enable) != A_OK) {
+ ret = -EIO;
+ } else {
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ }
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_LTE_FREQ:
+ {
+ WMI_LTE_FREQ_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(WMI_LTE_FREQ_CMD))) {
+ ret = -EFAULT;
+ } else {
+ ar6000_ap_handle_lte_freq(ar, arPriv, cmd.freq);
+ }
+ break;
+ }
+ case AR6000_XIOCTL_WMI_AP_IDLE_CLOSE_TIME:
+ {
+ WMI_AP_IDLE_CLOSE_TIME_CMD cmd;
+
+ if (ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ } else if (copy_from_user(&cmd, userdata, sizeof(WMI_AP_IDLE_CLOSE_TIME_CMD))) {
+ ret = -EFAULT;
+ } else {
+ wmi_ap_set_idle_close_time(arPriv->arWmi, cmd.time_val_sec);
+ }
+ break;
+ }
+#ifdef HS20_ENABLE
+ case AR6000_XIOCTL_WMI_SEND_FRAME:
+ {
+ A_UINT8 appIeInfo[IEEE80211_APPIE_FRAME_MAX_LEN];
+ A_UINT16 ieLen;
+
+ if(ar->arWmiReady == FALSE) {
+ ret = -EIO;
+ goto ioctl_done;
+ }
+ get_user(ieLen, (A_UINT16 *)(userdata));
+ ieLen += 8;
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("HS20IE: Len-%d\n", ieLen));
+ if (ieLen > IEEE80211_APPIE_FRAME_MAX_LEN) {
+ ret = -EIO;
+ break;
+ }
+ if (copy_from_user(appIeInfo, userdata, ieLen)) {
+ ret = -EFAULT;
+ }
+
+ if (wmi_send_action_frame_cmd(arPriv->arWmi,
+ ieLen, appIeInfo) != A_OK) {
+ ret = -EIO;
+ }
+ break;
+ }
+#endif
+ default:
+ ret = -EOPNOTSUPP;
+ }
+
+ioctl_done:
+ rtnl_lock(); /* restore rtnl state */
+ dev_put(dev);
+
+ return ret;
+}
+
+A_UINT8 mac_cmp_wild(A_UINT8 *mac, A_UINT8 *new_mac, A_UINT8 wild, A_UINT8 new_wild)
+{
+ A_UINT8 i;
+
+ for(i=0;i<ATH_MAC_LEN;i++) {
+ if((wild & 1<<i) && (new_wild & 1<<i)) continue;
+ if(mac[i] != new_mac[i]) return 1;
+ }
+ if((A_MEMCMP(new_mac, null_mac, 6)==0) && new_wild &&
+ (wild != new_wild)) {
+ return 1;
+ }
+
+ return 0;
+}
+
+A_UINT8 acl_add_del_mac(WMI_AP_ACL *a, WMI_AP_ACL_MAC_CMD *acl)
+{
+ A_INT8 already_avail=-1, free_slot=-1, i;
+
+ /* To check whether this mac is already there in our list */
+ for(i=AP_ACL_SIZE-1;i>=0;i--)
+ {
+ if(mac_cmp_wild(a->acl_mac[i], acl->mac, a->wildcard[i],
+ acl->wildcard)==0)
+ already_avail = i;
+
+ if(!((1 << i) & a->index))
+ free_slot = i;
+ }
+
+ if(acl->action == ADD_MAC_ADDR)
+ {
+ /* Dont add mac if it is already available */
+ if((already_avail >= 0) || (free_slot == -1))
+ return 0;
+
+ A_MEMCPY(a->acl_mac[free_slot], acl->mac, ATH_MAC_LEN);
+ a->index = a->index | (1 << free_slot);
+ acl->index = free_slot;
+ a->wildcard[free_slot] = acl->wildcard;
+ return 1;
+ }
+ else if(acl->action == DEL_MAC_ADDR)
+ {
+ if(acl->index >= AP_ACL_SIZE)
+ return 0;
+
+ if(!(a->index & (1 << acl->index)))
+ return 0;
+
+ A_MEMZERO(a->acl_mac[acl->index],ATH_MAC_LEN);
+ a->index = a->index & ~(1 << acl->index);
+ a->wildcard[acl->index] = 0;
+ return 1;
+ }
+
+ return 0;
+}
+
+void
+ar6000_send_delba (void *context, A_UINT8 reasonCode)
+{
+ AR_SOFTC_T *ar= (AR_SOFTC_T *)context;
+ AR_SOFTC_DEV_T *arTempPriv = NULL;
+ A_UINT8 i=0;
+
+ if (ar == NULL) {
+ return;
+ }
+
+ for(i=0;i<ar->arConfNumDev;i++){
+ arTempPriv = ar->arDev[i];
+ if(AP_NETWORK == arTempPriv->arNetworkType) {
+ break;
+ }
+ }
+
+ if (REASON_TEAR_DOWN == reasonCode)
+ {
+ wmi_allow_aggr_cmd (arTempPriv->arWmi, 0xFF, 0);
+ }
+
+ if (REASON_DELBA_TIMEOUT == reasonCode)
+ {
+ wmi_allow_aggr_cmd (arTempPriv->arWmi, 0xFF, 0xFF);
+ }
+
+ for (i = 0; i < NUM_CONN; i++)
+ {
+ if (NULL != ar->connTbl[i].conn_aggr && arTempPriv == ar->connTbl[i].arPriv
+ && ar->connTbl[i].HT_present)
+ {
+ aggr_delba_request (ar->connTbl[i].conn_aggr, (struct wmi_t *)arTempPriv->arWmi, ar->connTbl[i].aid, reasonCode);
+ }
+ }
+
+}
+
diff --git a/host/os/linux/netbuf.c b/host/os/linux/netbuf.c
new file mode 100644
index 0000000..963b99e
--- /dev/null
+++ b/host/os/linux/netbuf.c
@@ -0,0 +1,272 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+#include <linux/kernel.h>
+#include <linux/skbuff.h>
+#include <a_config.h>
+#include "athdefs.h"
+#include "a_types.h"
+#include "a_osapi.h"
+#include "htc_packet.h"
+
+#define AR6000_DATA_OFFSET 64
+
+void a_netbuf_enqueue(A_NETBUF_QUEUE_T *q, void *pkt)
+{
+ skb_queue_tail((struct sk_buff_head *) q, (struct sk_buff *) pkt);
+}
+
+void a_netbuf_prequeue(A_NETBUF_QUEUE_T *q, void *pkt)
+{
+ skb_queue_head((struct sk_buff_head *) q, (struct sk_buff *) pkt);
+}
+
+void *a_netbuf_dequeue(A_NETBUF_QUEUE_T *q)
+{
+ return((void *) skb_dequeue((struct sk_buff_head *) q));
+}
+
+int a_netbuf_queue_size(A_NETBUF_QUEUE_T *q)
+{
+ return(skb_queue_len((struct sk_buff_head *) q));
+}
+
+int a_netbuf_queue_empty(A_NETBUF_QUEUE_T *q)
+{
+ return(skb_queue_empty((struct sk_buff_head *) q));
+}
+
+void a_netbuf_queue_init(A_NETBUF_QUEUE_T *q)
+{
+ skb_queue_head_init((struct sk_buff_head *) q);
+}
+
+#ifdef AR6K_ALLOC_DEBUG
+void *
+a_netbuf_alloc(int size, const char *func, int lineno)
+#else
+void *
+a_netbuf_alloc(int size)
+#endif
+{
+ struct sk_buff *skb;
+ size += 2 * (A_GET_CACHE_LINE_BYTES()); /* add some cacheline space at front and back of buffer */
+ skb = dev_alloc_skb(AR6000_DATA_OFFSET + sizeof(HTC_PACKET) + size);
+ if (skb) {
+ skb_reserve(skb, AR6000_DATA_OFFSET + sizeof(HTC_PACKET) + A_GET_CACHE_LINE_BYTES());
+#ifdef AR6K_ALLOC_DEBUG
+ __a_meminfo_add(skb, size, func, lineno);
+#endif
+ }
+ return ((void *)skb);
+}
+
+/*
+ * Allocate an SKB w.o. any encapsulation requirement.
+ */
+#ifdef AR6K_ALLOC_DEBUG
+void *
+a_netbuf_alloc_raw(int size, const char *func, int lineno)
+#else
+void *
+a_netbuf_alloc_raw(int size)
+#endif
+{
+ struct sk_buff *skb;
+
+ skb = dev_alloc_skb(size);
+#ifdef AR6K_ALLOC_DEBUG
+ __a_meminfo_add(skb, size, func, lineno);
+#endif
+ return ((void *)skb);
+}
+
+void
+a_netbuf_free(void *bufPtr)
+{
+ struct sk_buff *skb = (struct sk_buff *)bufPtr;
+#ifdef AR6K_ALLOC_DEBUG
+ a_meminfo_del(bufPtr);
+#endif
+ dev_kfree_skb(skb);
+}
+
+A_UINT32
+a_netbuf_to_len(void *bufPtr)
+{
+ return (((struct sk_buff *)bufPtr)->len);
+}
+
+void *
+a_netbuf_to_data(void *bufPtr)
+{
+ return (((struct sk_buff *)bufPtr)->data);
+}
+
+/*
+ * Add len # of bytes to the beginning of the network buffer
+ * pointed to by bufPtr
+ */
+A_STATUS
+a_netbuf_push(void *bufPtr, A_INT32 len)
+{
+ skb_push((struct sk_buff *)bufPtr, len);
+
+ return A_OK;
+}
+
+/*
+ * Add len # of bytes to the beginning of the network buffer
+ * pointed to by bufPtr and also fill with data
+ */
+A_STATUS
+a_netbuf_push_data(void *bufPtr, char *srcPtr, A_INT32 len)
+{
+ skb_push((struct sk_buff *) bufPtr, len);
+ A_MEMCPY(((struct sk_buff *)bufPtr)->data, srcPtr, len);
+
+ return A_OK;
+}
+
+/*
+ * Add len # of bytes to the end of the network buffer
+ * pointed to by bufPtr
+ */
+A_STATUS
+a_netbuf_put(void *bufPtr, A_INT32 len)
+{
+ skb_put((struct sk_buff *)bufPtr, len);
+
+ return A_OK;
+}
+
+/*
+ * Add len # of bytes to the end of the network buffer
+ * pointed to by bufPtr and also fill with data
+ */
+A_STATUS
+a_netbuf_put_data(void *bufPtr, char *srcPtr, A_INT32 len)
+{
+ char *start = (char*)(((struct sk_buff *)bufPtr)->data +
+ ((struct sk_buff *)bufPtr)->len);
+ skb_put((struct sk_buff *)bufPtr, len);
+ A_MEMCPY(start, srcPtr, len);
+
+ return A_OK;
+}
+
+
+/*
+ * Trim the network buffer pointed to by bufPtr to len # of bytes
+ */
+A_STATUS
+a_netbuf_setlen(void *bufPtr, A_INT32 len)
+{
+ skb_trim((struct sk_buff *)bufPtr, len);
+
+ return A_OK;
+}
+
+/*
+ * Chop of len # of bytes from the end of the buffer.
+ */
+A_STATUS
+a_netbuf_trim(void *bufPtr, A_INT32 len)
+{
+ skb_trim((struct sk_buff *)bufPtr, ((struct sk_buff *)bufPtr)->len - len);
+
+ return A_OK;
+}
+
+/*
+ * Chop of len # of bytes from the end of the buffer and return the data.
+ */
+A_STATUS
+a_netbuf_trim_data(void *bufPtr, char *dstPtr, A_INT32 len)
+{
+ char *start = (char*)(((struct sk_buff *)bufPtr)->data +
+ (((struct sk_buff *)bufPtr)->len - len));
+
+ A_MEMCPY(dstPtr, start, len);
+ skb_trim((struct sk_buff *)bufPtr, ((struct sk_buff *)bufPtr)->len - len);
+
+ return A_OK;
+}
+
+
+/*
+ * Returns the number of bytes available to a a_netbuf_push()
+ */
+A_INT32
+a_netbuf_headroom(void *bufPtr)
+{
+ return (skb_headroom((struct sk_buff *)bufPtr));
+}
+
+/*
+ * Removes specified number of bytes from the beginning of the buffer
+ */
+A_STATUS
+a_netbuf_pull(void *bufPtr, A_INT32 len)
+{
+ skb_pull((struct sk_buff *)bufPtr, len);
+
+ return A_OK;
+}
+
+/*
+ * Removes specified number of bytes from the beginning of the buffer
+ * and return the data
+ */
+A_STATUS
+a_netbuf_pull_data(void *bufPtr, char *dstPtr, A_INT32 len)
+{
+ A_MEMCPY(dstPtr, ((struct sk_buff *)bufPtr)->data, len);
+ skb_pull((struct sk_buff *)bufPtr, len);
+
+ return A_OK;
+}
+
+
+#ifdef AR6K_ALLOC_DEBUG
+void a_netbuf_check(void *bufPtr, const char *func, int lineno)
+{
+ struct sk_buff *skb = (struct sk_buff *)bufPtr;
+ A_UINT32 len;
+ A_BOOL found = FALSE;
+ found = a_meminfo_find(skb);
+
+ if (found == FALSE)
+ {
+ len = A_NETBUF_LEN(skb);
+ __a_meminfo_add(skb, len, func, lineno);
+ }
+}
+#endif
+
+#ifdef EXPORT_HCI_BRIDGE_INTERFACE
+EXPORT_SYMBOL(a_netbuf_to_data);
+EXPORT_SYMBOL(a_netbuf_put);
+EXPORT_SYMBOL(a_netbuf_pull);
+EXPORT_SYMBOL(a_netbuf_alloc);
+EXPORT_SYMBOL(a_netbuf_free);
+#endif
diff --git a/host/os/linux/wireless_ext.c b/host/os/linux/wireless_ext.c
new file mode 100644
index 0000000..571ec02
--- /dev/null
+++ b/host/os/linux/wireless_ext.c
@@ -0,0 +1,3389 @@
+//------------------------------------------------------------------------------
+// Copyright (c) 2004-2010 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+// Author(s): ="Atheros"
+//------------------------------------------------------------------------------
+
+#include "ar6000_drv.h"
+#include "wlan_config.h"
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27)
+#define IWE_STREAM_ADD_EVENT(p1, p2, p3, p4, p5) \
+ iwe_stream_add_event((p1), (p2), (p3), (p4), (p5))
+#else
+#define IWE_STREAM_ADD_EVENT(p1, p2, p3, p4, p5) \
+ iwe_stream_add_event((p2), (p3), (p4), (p5))
+#endif
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27)
+#define IWE_STREAM_ADD_POINT(p1, p2, p3, p4, p5) \
+ iwe_stream_add_point((p1), (p2), (p3), (p4), (p5))
+#else
+#define IWE_STREAM_ADD_POINT(p1, p2, p3, p4, p5) \
+ iwe_stream_add_point((p2), (p3), (p4), (p5))
+#endif
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27)
+#define IWE_STREAM_ADD_VALUE(p1, p2, p3, p4, p5, p6) \
+ iwe_stream_add_value((p1), (p2), (p3), (p4), (p5), (p6))
+#else
+#define IWE_STREAM_ADD_VALUE(p1, p2, p3, p4, p5, p6) \
+ iwe_stream_add_value((p2), (p3), (p4), (p5), (p6))
+#endif
+
+static void ar6000_set_quality(struct iw_quality *iq, A_INT8 rssi);
+extern unsigned int wmitimeout;
+#if WLAN_CONFIG_FIRST_SCAN_2G_ONLY
+extern unsigned int first_scan_2g_only;
+#endif
+extern unsigned int psm_info;
+
+#if WIRELESS_EXT > 14
+/*
+ * Encode a WPA or RSN information element as a custom
+ * element using the hostap format.
+ */
+static u_int
+encode_ie(void *buf, size_t bufsize,
+ const u_int8_t *ie, size_t ielen,
+ const char *leader, size_t leader_len)
+{
+ u_int8_t *p;
+ int i;
+
+ if (bufsize < leader_len)
+ return 0;
+ p = buf;
+ memcpy(p, leader, leader_len);
+ bufsize -= leader_len;
+ p += leader_len;
+ for (i = 0; i < ielen && bufsize > 2; i++)
+ {
+ p += snprintf((char*)p, bufsize, "%02x", ie[i]);
+ bufsize -= 2;
+ }
+ return (i == ielen ? p - (u_int8_t *)buf : 0);
+}
+#endif /* WIRELESS_EXT > 14 */
+
+static A_UINT8
+get_bss_phy_capability(bss_t *bss)
+{
+ A_UINT8 capability = 0;
+ struct ieee80211_common_ie *cie = &bss->ni_cie;
+#define CHAN_IS_11A(x) (!((x >= 2412) && (x <= 2484)))
+ if (CHAN_IS_11A(cie->ie_chan)) {
+ if (cie->ie_htcap) {
+ capability = WMI_11NA_CAPABILITY;
+ } else {
+ capability = WMI_11A_CAPABILITY;
+ }
+ } else if ((cie->ie_erp) || (cie->ie_xrates)) {
+ if (cie->ie_htcap) {
+ capability = WMI_11NG_CAPABILITY;
+ } else {
+ capability = WMI_11G_CAPABILITY;
+ }
+ }
+ return capability;
+}
+
+void
+ar6000_scan_node(void *arg, bss_t *ni)
+{
+ struct iw_event iwe;
+#if WIRELESS_EXT > 14
+ char buf[256];
+#endif
+ struct ar_giwscan_param *param;
+ A_CHAR *current_ev;
+ A_CHAR *end_buf;
+ struct ieee80211_common_ie *cie;
+ A_CHAR *current_val;
+ A_INT32 j;
+ A_UINT32 rate_len, data_len = 0;
+
+ /* Node table now contains entries from P2P Action frames and Probe Request also. Return
+ * if the frame type is an action frame/ Probe request.
+ */
+ if ((ni->ni_frametype == ACTION_MGMT_FTYPE) || (ni->ni_frametype == PROBEREQ_FTYPE) || (ni->ni_buf == NULL)) {
+ return;
+ }
+
+ param = (struct ar_giwscan_param *)arg;
+
+ current_ev = param->current_ev;
+ end_buf = param->end_buf;
+
+ cie = &ni->ni_cie;
+ if (cie == NULL) {
+ return;
+ }
+
+ if ((end_buf - current_ev) > IW_EV_ADDR_LEN)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = SIOCGIWAP;
+ iwe.u.ap_addr.sa_family = ARPHRD_ETHER;
+ A_MEMCPY(iwe.u.ap_addr.sa_data, ni->ni_macaddr, 6);
+ current_ev = IWE_STREAM_ADD_EVENT(param->info, current_ev, end_buf,
+ &iwe, IW_EV_ADDR_LEN);
+ }
+ param->bytes_needed += IW_EV_ADDR_LEN;
+
+ /* EV92904 cie->ie_ssid can be NULL */
+ if (cie->ie_ssid) {
+ data_len = cie->ie_ssid[1] + IW_EV_POINT_LEN;
+ } else {
+ data_len = IW_EV_POINT_LEN;
+ }
+
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = SIOCGIWESSID;
+ iwe.u.data.flags = 1;
+ if (cie->ie_ssid) {
+ iwe.u.data.length = cie->ie_ssid[1];
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev, end_buf,
+ &iwe, (char*)&cie->ie_ssid[2]);
+ } else {
+ iwe.u.data.length = 0;
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev, end_buf,
+ &iwe, (char*)"");
+ }
+ }
+ param->bytes_needed += data_len;
+
+ if (cie->ie_capInfo & (IEEE80211_CAPINFO_ESS|IEEE80211_CAPINFO_IBSS)) {
+ if ((end_buf - current_ev) > IW_EV_UINT_LEN)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = SIOCGIWMODE;
+ iwe.u.mode = cie->ie_capInfo & IEEE80211_CAPINFO_ESS ?
+ IW_MODE_MASTER : IW_MODE_ADHOC;
+ current_ev = IWE_STREAM_ADD_EVENT(param->info, current_ev, end_buf,
+ &iwe, IW_EV_UINT_LEN);
+ }
+ param->bytes_needed += IW_EV_UINT_LEN;
+ }
+
+ if ((end_buf - current_ev) > IW_EV_FREQ_LEN)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = SIOCGIWFREQ;
+ iwe.u.freq.m = cie->ie_chan * 100000;
+ iwe.u.freq.e = 1;
+ current_ev = IWE_STREAM_ADD_EVENT(param->info, current_ev, end_buf,
+ &iwe, IW_EV_FREQ_LEN);
+ }
+ param->bytes_needed += IW_EV_FREQ_LEN;
+
+ if ((end_buf - current_ev) > IW_EV_QUAL_LEN)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVQUAL;
+ ar6000_set_quality(&iwe.u.qual, ni->ni_snr);
+ current_ev = IWE_STREAM_ADD_EVENT(param->info, current_ev, end_buf,
+ &iwe, IW_EV_QUAL_LEN);
+ }
+ param->bytes_needed += IW_EV_QUAL_LEN;
+
+ if ((end_buf - current_ev) > IW_EV_POINT_LEN)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = SIOCGIWENCODE;
+ if (cie->ie_capInfo & IEEE80211_CAPINFO_PRIVACY) {
+ iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY;
+ } else {
+ iwe.u.data.flags = IW_ENCODE_DISABLED;
+ }
+ iwe.u.data.length = 0;
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev, end_buf,
+ &iwe, "");
+ }
+ param->bytes_needed += IW_EV_POINT_LEN;
+
+ /* supported bit rate */
+ if ((cie->ie_rates != NULL) || (cie->ie_xrates != NULL)) {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = SIOCGIWRATE;
+ iwe.u.bitrate.fixed = 0;
+ iwe.u.bitrate.disabled = 0;
+ iwe.u.bitrate.value = 0;
+ current_val = current_ev + IW_EV_LCP_LEN;
+ param->bytes_needed += IW_EV_LCP_LEN;
+
+ if (cie->ie_rates != NULL) {
+ rate_len = cie->ie_rates[1];
+ data_len = (rate_len * (IW_EV_PARAM_LEN - IW_EV_LCP_LEN));
+ if ((end_buf - current_ev) > data_len)
+ {
+ for (j = 0; j < rate_len; j++) {
+ unsigned char val;
+ val = cie->ie_rates[2 + j];
+ iwe.u.bitrate.value =
+ (val >= 0x80)? ((val - 0x80) * 500000): (val * 500000);
+ current_val = IWE_STREAM_ADD_VALUE(param->info, current_ev,
+ current_val, end_buf,
+ &iwe, IW_EV_PARAM_LEN);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+
+ if (cie->ie_xrates != NULL) {
+ rate_len = cie->ie_xrates[1];
+ data_len = (rate_len * (IW_EV_PARAM_LEN - IW_EV_LCP_LEN));
+ if ((end_buf - current_ev) > data_len)
+ {
+ for (j = 0; j < rate_len; j++) {
+ unsigned char val;
+ val = cie->ie_xrates[2 + j];
+ iwe.u.bitrate.value =
+ (val >= 0x80)? ((val - 0x80) * 500000): (val * 500000);
+ current_val = IWE_STREAM_ADD_VALUE(param->info, current_ev,
+ current_val, end_buf,
+ &iwe, IW_EV_PARAM_LEN);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+ /* remove fixed header if no rates were added */
+ if ((current_val - current_ev) > IW_EV_LCP_LEN)
+ current_ev = current_val;
+ }
+
+#if WIRELESS_EXT >= 18
+ /* IE */
+ if (cie->ie_wpa != NULL) {
+ data_len = cie->ie_wpa[1] + 2 + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVGENIE;
+ iwe.u.data.length = cie->ie_wpa[1] + 2;
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev, end_buf,
+ &iwe, (char*)cie->ie_wpa);
+ }
+ param->bytes_needed += data_len;
+ }
+
+ if (cie->ie_rsn != NULL && cie->ie_rsn[0] == IEEE80211_ELEMID_RSN) {
+ data_len = cie->ie_rsn[1] + 2 + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVGENIE;
+ iwe.u.data.length = cie->ie_rsn[1] + 2;
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev, end_buf,
+ &iwe, (char*)cie->ie_rsn);
+ }
+ param->bytes_needed += data_len;
+ }
+
+#endif /* WIRELESS_EXT >= 18 */
+
+ if ((end_buf - current_ev) > IW_EV_CHAR_LEN)
+ {
+ /* protocol */
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = SIOCGIWNAME;
+ switch (get_bss_phy_capability(ni)) {
+ case WMI_11A_CAPABILITY:
+ snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11a");
+ break;
+ case WMI_11G_CAPABILITY:
+ snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11g");
+ break;
+ case WMI_11NA_CAPABILITY:
+ snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11na");
+ break;
+ case WMI_11NG_CAPABILITY:
+ snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11ng");
+ break;
+ default:
+ snprintf(iwe.u.name, IFNAMSIZ, "IEEE 802.11b");
+ break;
+ }
+ current_ev = IWE_STREAM_ADD_EVENT(param->info, current_ev, end_buf,
+ &iwe, IW_EV_CHAR_LEN);
+ }
+ param->bytes_needed += IW_EV_CHAR_LEN;
+
+#if WIRELESS_EXT > 14
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = snprintf(buf, sizeof(buf), "bcn_int=%d", cie->ie_beaconInt);
+ data_len = iwe.u.data.length + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev, end_buf,
+ &iwe, buf);
+ }
+ param->bytes_needed += data_len;
+
+#if WIRELESS_EXT < 18
+ if (cie->ie_wpa != NULL) {
+ static const char wpa_leader[] = "wpa_ie=";
+ data_len = (sizeof(wpa_leader) - 1) + ((cie->ie_wpa[1]+2) * 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = encode_ie(buf, sizeof(buf), cie->ie_wpa,
+ cie->ie_wpa[1]+2,
+ wpa_leader, sizeof(wpa_leader)-1);
+
+ if (iwe.u.data.length != 0) {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev,
+ end_buf, &iwe, buf);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+
+ if (cie->ie_rsn != NULL && cie->ie_rsn[0] == IEEE80211_ELEMID_RSN) {
+ static const char rsn_leader[] = "rsn_ie=";
+ data_len = (sizeof(rsn_leader) - 1) + ((cie->ie_rsn[1]+2) * 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = encode_ie(buf, sizeof(buf), cie->ie_rsn,
+ cie->ie_rsn[1]+2,
+ rsn_leader, sizeof(rsn_leader)-1);
+
+ if (iwe.u.data.length != 0) {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev,
+ end_buf, &iwe, buf);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+#endif /* WIRELESS_EXT < 18 */
+
+ if (cie->ie_wmm != NULL) {
+ static const char wmm_leader[] = "wmm_ie=";
+ data_len = (sizeof(wmm_leader) - 1) + ((cie->ie_wmm[1]+2) * 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = encode_ie(buf, sizeof(buf), cie->ie_wmm,
+ cie->ie_wmm[1]+2,
+ wmm_leader, sizeof(wmm_leader)-1);
+ if (iwe.u.data.length != 0) {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev,
+ end_buf, &iwe, buf);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+
+ if (cie->ie_ath != NULL) {
+ static const char ath_leader[] = "ath_ie=";
+ data_len = (sizeof(ath_leader) - 1) + ((cie->ie_ath[1]+2) * 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = encode_ie(buf, sizeof(buf), cie->ie_ath,
+ cie->ie_ath[1]+2,
+ ath_leader, sizeof(ath_leader)-1);
+ if (iwe.u.data.length != 0) {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev,
+ end_buf, &iwe, buf);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+
+#ifdef WAPI_ENABLE
+ if (cie->ie_wapi != NULL) {
+ static const char wapi_leader[] = "wapi_ie=";
+ data_len = (sizeof(wapi_leader) - 1) + ((cie->ie_wapi[1] + 2) * 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len) {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = encode_ie(buf, sizeof(buf), cie->ie_wapi,
+ cie->ie_wapi[1] + 2,
+ wapi_leader, sizeof(wapi_leader) - 1);
+ if (iwe.u.data.length != 0) {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev,
+ end_buf, &iwe, buf);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+#endif /* WAPI_ENABLE */
+
+#ifdef HS20_ENABLE
+ if (cie->ie_hs20 != NULL) {
+ static const char hs20_leader[] = "hs20_ie=";
+ data_len = (sizeof(hs20_leader) - 1) + ((cie->ie_hs20[1] + 2) * 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len) {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = encode_ie(buf, sizeof(buf), cie->ie_hs20,
+ cie->ie_hs20[1] + 2,
+ hs20_leader, sizeof(hs20_leader) - 1);
+ if (iwe.u.data.length != 0) {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev,
+ end_buf, &iwe, buf);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+ if (cie->ie_extcap != NULL) {
+ static const char extcap_leader[] = "extcap_ie=";
+ data_len = (sizeof(extcap_leader) - 1) + ((cie->ie_extcap[1] + 2) * 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len) {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVCUSTOM;
+ iwe.u.data.length = encode_ie(buf, sizeof(buf), cie->ie_extcap,
+ cie->ie_extcap[1] + 2,
+ extcap_leader, sizeof(extcap_leader) - 1);
+ if (iwe.u.data.length != 0) {
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev,
+ end_buf, &iwe, buf);
+ }
+ }
+ param->bytes_needed += data_len;
+ }
+#endif
+#endif /* WIRELESS_EXT > 14 */
+
+#if WIRELESS_EXT >= 18
+ if (cie->ie_wsc != NULL) {
+ data_len = (cie->ie_wsc[1] + 2) + IW_EV_POINT_LEN;
+ if ((end_buf - current_ev) > data_len)
+ {
+ A_MEMZERO(&iwe, sizeof(iwe));
+ iwe.cmd = IWEVGENIE;
+ iwe.u.data.length = cie->ie_wsc[1] + 2;
+ current_ev = IWE_STREAM_ADD_POINT(param->info, current_ev, end_buf,
+ &iwe, (char*)cie->ie_wsc);
+ }
+ param->bytes_needed += data_len;
+ }
+#endif /* WIRELESS_EXT >= 18 */
+
+ param->current_ev = current_ev;
+}
+
+int
+ar6000_ioctl_giwscan(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ struct ar_giwscan_param param;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ param.current_ev = extra;
+ param.end_buf = extra + data->length;
+ param.bytes_needed = 0;
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27)
+ param.info = info;
+#endif
+
+wmi_scan_report_lock(arPriv->arWmi);
+
+ /* Translate data to WE format */
+ wmi_iterate_nodes(arPriv->arWmi, ar6000_scan_node, ¶m);
+
+wmi_scan_report_unlock(arPriv->arWmi);
+
+ /* check if bytes needed is greater than bytes consumed */
+ if (data->length == 65535) {
+ param.bytes_needed = param.current_ev - extra;
+ } else {
+ if (param.bytes_needed > data->length)
+ {
+ /* Request one byte more than needed, because when "data->length" equals bytes_needed,
+ it is not possible to add the last event data as all iwe_stream_add_xxxxx() functions
+ checks whether (cur_ptr + ev_len) < end_ptr, due to this one more retry would happen*/
+ data->length = param.bytes_needed + 1;
+
+ up(&ar->arSem);
+ return -E2BIG;
+ }
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+extern int reconnect_flag;
+/* SIOCSIWESSID */
+static int
+ar6000_ioctl_siwessid(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *ssid)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_DEV_T *arTempPriv = NULL;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ A_STATUS status;
+ A_UINT8 i=0;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+
+#if defined(WIRELESS_EXT)
+ if (WIRELESS_EXT > 20) {
+ data->length += 1;
+ }
+#endif
+ /* Handling AP-STA Concurrency */
+ if((ar->arConfNumDev > 1)) {
+ if ((data->flags) &&
+ (arPriv->arNetworkType == INFRA_NETWORK) &&
+ ((arPriv->arSsidLen != (data->length - 1)) ||
+ (A_MEMCMP(arPriv->arSsid, ssid, arPriv->arSsidLen) != 0))){
+ for(i=0;i<ar->arConfNumDev;i++) {
+ arTempPriv = ar->arDev[i];
+ if((AP_NETWORK == arTempPriv->arNetworkType) &&
+ (arTempPriv->arConnected) &&
+ (arTempPriv->arNetworkSubType != SUBTYPE_NONE)) {
+ ar6000_disconnect(arPriv);
+ /*Disconnect AP only in P2P mode*/
+ }
+ }
+ }
+ }
+ /*
+ * iwconfig passes a null terminated string with length including this
+ * so we need to account for this
+ */
+ if (data->flags && (!data->length || (data->length == 1) ||
+ ((data->length - 1) > sizeof(arPriv->arSsid))))
+ {
+ /*
+ * ssid is invalid
+ */
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+
+ if (arPriv->arNetworkType == AP_NETWORK) {
+ if(!data->flags) {
+ /* stop AP */
+ ar6000_disconnect(arPriv);
+ if(arPriv->arNetworkSubType == SUBTYPE_P2PGO) {
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->arConnected == FALSE, wmitimeout * HZ);
+ if (signal_pending(current)) {
+ return -EINTR;
+ }
+ }
+
+ } else if(A_MEMCMP(arPriv->arSsid,ssid,32) != 0) {
+ /* SSID change for AP network - Will take effect on commit */
+ arPriv->arSsidLen = data->length - 1;
+ A_MEMZERO(arPriv->arSsid, WMI_MAX_SSID_LEN);
+ A_MEMCPY(arPriv->arSsid, ssid, arPriv->arSsidLen);
+ }
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ arPriv->arConnected = FALSE;
+ up(&ar->arSem);
+ return 0;
+ }
+
+ /* Added for bug 25178, return an IOCTL error instead of target returning
+ Illegal parameter error when either the BSSID or channel is missing
+ and we cannot scan during connect.
+ */
+ if (data->flags) {
+ if (arSta->arSkipScan == TRUE &&
+ (arPriv->arChannelHint == 0 ||
+ (!arSta->arReqBssid[0] && !arSta->arReqBssid[1] && !arSta->arReqBssid[2] &&
+ !arSta->arReqBssid[3] && !arSta->arReqBssid[4] && !arSta->arReqBssid[5])))
+ {
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ }
+
+
+ if (ar->arTxPending[wmi_get_control_ep(arPriv->arWmi)]) {
+ /*
+ * sleep until the command queue drains
+ */
+ wait_event_interruptible_timeout(arPriv->arEvent,
+ ar->arTxPending[wmi_get_control_ep(arPriv->arWmi)] == 0, wmitimeout * HZ);
+ if (signal_pending(current)) {
+ up(&ar->arSem);
+ return -EINTR;
+ }
+ }
+
+
+ if (!data->flags) {
+#ifdef ATH6K_CONFIG_CFG80211
+ if (arPriv->arConnected) {
+#endif /* ATH6K_CONFIG_CFG80211 */
+ ar6000_init_mode_info(arPriv);
+#ifdef ATH6K_CONFIG_CFG80211
+ }
+#endif /* ATH6K_CONFIG_CFG80211 */
+ }
+
+ if (((arPriv->arSsidLen) ||
+ ((arPriv->arSsidLen == 0) && (arPriv->arConnected || arSta->arConnectPending)) ||
+ (!data->flags)))
+ {
+ if ((!data->flags) ||
+ (A_MEMCMP(arPriv->arSsid, ssid, arPriv->arSsidLen) != 0) ||
+ (arPriv->arSsidLen != (data->length - 1)))
+ {
+ /*
+ * SSID set previously or essid off has been issued.
+ *
+ * Disconnect Command is issued in two cases after wmi is ready
+ * (1) ssid is different from the previous setting
+ * (2) essid off has been issued
+ *
+ */
+ if (ar->arWmiReady == TRUE) {
+ reconnect_flag = 0;
+ status = wmi_setPmkid_cmd(arPriv->arWmi, arPriv->arBssid, NULL, 0);
+ if(data->length) {
+ /*AR6000 intiated disconnect due to profile change*/
+ arPriv->arSta.arHostDisconnect = 1;
+ }
+ ar6000_disconnect(arPriv);
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+ if (arSta->arSkipScan == FALSE) {
+ A_MEMZERO(arSta->arReqBssid, sizeof(arSta->arReqBssid));
+ }
+ if (!data->flags) {
+ up(&ar->arSem);
+ return 0;
+ }
+ } else {
+ up(&ar->arSem);
+ return -EIO;
+ }
+ }
+ else
+ {
+ /*
+ * SSID is same, so we assume profile hasn't changed.
+ * If the interface is up and wmi is ready, we issue
+ * a reconnect cmd. Issue a reconnect only we are already
+ * connected.
+ */
+ if((arPriv->arConnected == TRUE) && (ar->arWmiReady == TRUE))
+ {
+ reconnect_flag = TRUE;
+ status = wmi_reconnect_cmd(arPriv->arWmi,arSta->arReqBssid,
+ arPriv->arChannelHint);
+ up(&ar->arSem);
+ if (status != A_OK) {
+ return -EIO;
+ }
+ return 0;
+ }
+ else{
+ /*
+ * Dont return if connect is pending.
+ */
+ if(!(arSta->arConnectPending)) {
+ up(&ar->arSem);
+ return 0;
+ }
+ }
+ }
+ }
+
+ arPriv->arSsidLen = data->length - 1;
+ A_MEMCPY(arPriv->arSsid, ssid, arPriv->arSsidLen);
+
+ if (ar6000_connect_to_ap(arPriv)!= A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }else{
+ up(&ar->arSem);
+ }
+ return 0;
+}
+
+/* SIOCGIWESSID */
+static int
+ar6000_ioctl_giwessid(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *essid)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (!arPriv->arSsidLen) {
+ return -EINVAL;
+ }
+
+ data->flags = 1;
+ data->length = arPriv->arSsidLen;
+ A_MEMCPY(essid, arPriv->arSsid, arPriv->arSsidLen);
+
+ return 0;
+}
+
+
+void ar6000_install_static_wep_keys(AR_SOFTC_DEV_T *arPriv)
+{
+ A_UINT8 index;
+ A_UINT8 keyUsage;
+ AR_SOFTC_AP_T *ap = &arPriv->arAp;
+
+ for (index = WMI_MIN_KEY_INDEX; index <= WMI_MAX_KEY_INDEX; index++) {
+ if (arPriv->arWepKeyList[index].arKeyLen) {
+ keyUsage = GROUP_USAGE;
+ if (index == arPriv->arDefTxKeyIndex) {
+ keyUsage |= TX_USAGE;
+ }
+ wmi_addKey_cmd(arPriv->arWmi,
+ index,
+ WEP_CRYPT,
+ keyUsage,
+ arPriv->arWepKeyList[index].arKeyLen,
+ NULL,
+ arPriv->arWepKeyList[index].arKey, KEY_OP_INIT_VAL, NULL,
+ NO_SYNC_WMIFLAG);
+ }
+ }
+ ap->deKeySet = FALSE;
+}
+
+/*
+ * SIOCSIWRATE
+ */
+int
+ar6000_ioctl_siwrate(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *rrq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ A_UINT32 kbps;
+ A_INT8 rate_idx;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ if (rrq->fixed) {
+ kbps = rrq->value / 1000; /* rrq->value is in bps */
+ } else {
+ kbps = -1; /* -1 indicates auto rate */
+ }
+ if(kbps != -1 && wmi_validate_bitrate(arPriv->arWmi, kbps, &rate_idx) != A_OK)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("BitRate is not Valid %d\n", kbps));
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ arPriv->arBitRate = kbps;
+ if(ar->arWmiReady == TRUE)
+ {
+ if (wmi_set_bitrate_cmd(arPriv->arWmi, kbps, -1, -1) != A_OK) {
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCGIWRATE
+ */
+int
+ar6000_ioctl_giwrate(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *rrq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ int ret = 0;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if ((arPriv->arNextMode != AP_NETWORK && !arPriv->arConnected) || ar->arWmiReady == FALSE) {
+ rrq->value = 1000 * 1000;
+ return 0;
+ }
+
+ if (arPriv->arBitRate!=-1 && arPriv->arBitRate!=0xFFFF) {
+ rrq->fixed = TRUE;
+ rrq->value = arPriv->arBitRate * 1000;
+ return 0;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ arPriv->arBitRate = 0xFFFF;
+ if (wmi_get_bitrate_cmd(arPriv->arWmi) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->arBitRate != 0xFFFF, wmitimeout * HZ);
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+ /* If the interface is down or wmi is not ready or the target is not
+ connected - return the value stored in the device structure */
+ if (!ret) {
+ if (arPriv->arBitRate == -1) {
+ rrq->fixed = TRUE;
+ rrq->value = 0;
+ } else {
+ rrq->fixed = FALSE;
+ rrq->value = arPriv->arBitRate * 1000;
+ }
+ arPriv->arBitRate = -1; /* clean it up for next query */
+ }
+
+ up(&ar->arSem);
+
+ return ret;
+}
+
+/*
+ * SIOCSIWTXPOW
+ */
+static int
+ar6000_ioctl_siwtxpow(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *rrq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ A_UINT8 dbM;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ if (rrq->disabled) {
+ up(&ar->arSem);
+ return -EOPNOTSUPP;
+ }
+
+ if (rrq->fixed) {
+ if (rrq->flags != IW_TXPOW_DBM) {
+ up(&ar->arSem);
+ return -EOPNOTSUPP;
+ }
+ arPriv->arTxPwr= dbM = rrq->value;
+ arPriv->arTxPwrSet = TRUE;
+ } else {
+ arPriv->arTxPwr = dbM = 0;
+ arPriv->arTxPwrSet = FALSE;
+ }
+ if(ar->arWmiReady == TRUE)
+ {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_TX,("Set tx pwr cmd %d dbM\n", dbM));
+ wmi_set_txPwr_cmd(arPriv->arWmi, dbM);
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCGIWTXPOW
+ */
+int
+ar6000_ioctl_giwtxpow(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *rrq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ int ret = 0;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ if((ar->arWmiReady == TRUE) && (arPriv->arConnected == TRUE))
+ {
+ arPriv->arTxPwr = 0;
+
+ if (wmi_get_txPwr_cmd(arPriv->arWmi) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arPriv->arTxPwr != 0, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ ret = -EINTR;
+ }
+ }
+ /* If the interace is down or wmi is not ready or target is not connected
+ then return value stored in the device structure */
+
+ if (!ret) {
+ if (arPriv->arTxPwrSet == TRUE) {
+ rrq->fixed = TRUE;
+ }
+ rrq->value = arPriv->arTxPwr;
+ rrq->flags = IW_TXPOW_DBM;
+ //
+ // IWLIST need this flag to get TxPower
+ //
+ rrq->disabled = 0;
+ }
+
+ up(&ar->arSem);
+
+ return ret;
+}
+
+/*
+ * SIOCSIWRETRY
+ * since iwconfig only provides us with one max retry value, we use it
+ * to apply to data frames of the BE traffic class.
+ */
+static int
+ar6000_ioctl_siwretry(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *rrq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ if (rrq->disabled) {
+ up(&ar->arSem);
+ return -EOPNOTSUPP;
+ }
+
+ if ((rrq->flags & IW_RETRY_TYPE) != IW_RETRY_LIMIT) {
+ up(&ar->arSem);
+ return -EOPNOTSUPP;
+ }
+
+ if ( !(rrq->value >= WMI_MIN_RETRIES) || !(rrq->value <= WMI_MAX_RETRIES)) {
+ up(&ar->arSem);
+ return - EINVAL;
+ }
+ if(ar->arWmiReady == TRUE)
+ {
+ if (wmi_set_retry_limits_cmd(arPriv->arWmi, DATA_FRAMETYPE, WMM_AC_BE,
+ rrq->value, 0) != A_OK){
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ }
+ arPriv->arMaxRetries = rrq->value;
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCGIWRETRY
+ */
+static int
+ar6000_ioctl_giwretry(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *rrq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ rrq->disabled = 0;
+ switch (rrq->flags & IW_RETRY_TYPE) {
+ case IW_RETRY_LIFETIME:
+ return -EOPNOTSUPP;
+ break;
+ case IW_RETRY_LIMIT:
+ rrq->flags = IW_RETRY_LIMIT;
+ switch (rrq->flags & IW_RETRY_MODIFIER) {
+ case IW_RETRY_MIN:
+ rrq->flags |= IW_RETRY_MIN;
+ rrq->value = WMI_MIN_RETRIES;
+ break;
+ case IW_RETRY_MAX:
+ rrq->flags |= IW_RETRY_MAX;
+ rrq->value = arPriv->arMaxRetries;
+ break;
+ }
+ break;
+ }
+ return 0;
+}
+
+/*
+ * SIOCSIWENCODE
+ */
+static int
+ar6000_ioctl_siwencode(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *erq, char *keybuf)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_AP_T *ap = &arPriv->arAp;
+
+ int index;
+ A_INT32 auth = 0;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if(arPriv->arNextMode != AP_NETWORK) {
+ /*
+ * Static WEP Keys should be configured before setting the SSID
+ */
+ if (arPriv->arSsid[0] && erq->length) {
+ return -EIO;
+ }
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ index = erq->flags & IW_ENCODE_INDEX;
+
+ if (index && (((index - 1) < WMI_MIN_KEY_INDEX) ||
+ ((index - 1) > WMI_MAX_KEY_INDEX)))
+ {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ if (erq->flags & IW_ENCODE_DISABLED) {
+ /*
+ * Encryption disabled
+ */
+ if (index) {
+ /*
+ * If key index was specified then clear the specified key
+ */
+ index--;
+ A_MEMZERO(arPriv->arWepKeyList[index].arKey,
+ sizeof(arPriv->arWepKeyList[index].arKey));
+ arPriv->arWepKeyList[index].arKeyLen = 0;
+ }
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ } else {
+ /*
+ * Enabling WEP encryption
+ */
+ if (index) {
+ index--; /* keyindex is off base 1 in iwconfig */
+ }
+
+ if (erq->flags & IW_ENCODE_OPEN) {
+ auth |= OPEN_AUTH;
+ }
+ if (erq->flags & IW_ENCODE_RESTRICTED) {
+ auth |= SHARED_AUTH;
+ }
+
+ if (!auth) {
+ auth = OPEN_AUTH;
+ }
+
+ if (!ap->deKeySet) {
+ arPriv->arDefTxKeyIndex = index;
+ }
+
+ if (erq->length) {
+ if (!IEEE80211_IS_VALID_WEP_CIPHER_LEN(erq->length)) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ A_MEMZERO(arPriv->arWepKeyList[index].arKey,
+ sizeof(arPriv->arWepKeyList[index].arKey));
+ A_MEMCPY(arPriv->arWepKeyList[index].arKey, keybuf, erq->length);
+ arPriv->arWepKeyList[index].arKeyLen = erq->length;
+ arPriv->arDot11AuthMode = auth;
+ } else {
+ if (arPriv->arWepKeyList[index].arKeyLen == 0) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+ arPriv->arDefTxKeyIndex = index;
+
+ if(arPriv->arSsidLen && arPriv->arWepKeyList[index].arKeyLen) {
+ wmi_addKey_cmd(arPriv->arWmi,
+ index,
+ WEP_CRYPT,
+ GROUP_USAGE | TX_USAGE,
+ arPriv->arWepKeyList[index].arKeyLen,
+ NULL,
+ arPriv->arWepKeyList[index].arKey, KEY_OP_INIT_VAL, NULL,
+ NO_SYNC_WMIFLAG);
+ }
+ ap->deKeySet = TRUE;
+ }
+
+ arPriv->arPairwiseCrypto = WEP_CRYPT;
+ arPriv->arGroupCrypto = WEP_CRYPT;
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ }
+
+ if(arPriv->arNextMode != AP_NETWORK) {
+ /*
+ * profile has changed. Erase ssid to signal change
+ */
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+ }
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ up(&ar->arSem);
+ return 0;
+}
+
+static int
+ar6000_ioctl_giwencode(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *erq, char *key)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ A_UINT8 keyIndex;
+ struct ar_wep_key *wk;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+
+ if (arPriv->arPairwiseCrypto == NONE_CRYPT) {
+ erq->length = 0;
+ erq->flags = IW_ENCODE_DISABLED;
+ } else {
+ if (arPriv->arPairwiseCrypto == WEP_CRYPT) {
+ /* get the keyIndex */
+ keyIndex = erq->flags & IW_ENCODE_INDEX;
+ if (0 == keyIndex) {
+ keyIndex = arPriv->arDefTxKeyIndex;
+ } else if ((keyIndex - 1 < WMI_MIN_KEY_INDEX) ||
+ (keyIndex - 1 > WMI_MAX_KEY_INDEX))
+ {
+ keyIndex = WMI_MIN_KEY_INDEX;
+ } else {
+ keyIndex--;
+ }
+ erq->flags = keyIndex + 1;
+ erq->flags &= ~IW_ENCODE_DISABLED;
+ wk = &arPriv->arWepKeyList[keyIndex];
+ if (erq->length > wk->arKeyLen) {
+ erq->length = wk->arKeyLen;
+ }
+ if (wk->arKeyLen) {
+ A_MEMCPY(key, wk->arKey, erq->length);
+ }
+ } else {
+ erq->flags &= ~IW_ENCODE_DISABLED;
+ if (arPriv->arSta.user_saved_keys.keyOk) {
+ erq->length = arPriv->arSta.user_saved_keys.ucast_ik.ik_keylen;
+ if (erq->length) {
+ A_MEMCPY(key, arPriv->arSta.user_saved_keys.ucast_ik.ik_keydata, erq->length);
+ }
+ } else {
+ erq->length = 1; // not really printing any key but let iwconfig know enc is on
+ }
+ }
+
+ if (arPriv->arDot11AuthMode & OPEN_AUTH) {
+ erq->flags |= IW_ENCODE_OPEN;
+ }
+ if (arPriv->arDot11AuthMode & SHARED_AUTH) {
+ erq->flags |= IW_ENCODE_RESTRICTED;
+ }
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+#if WIRELESS_EXT >= 18
+static bool is_wpa_ie(const u8 *pos)
+{
+ return pos[0] == IEEE80211_ELEMID_VENDOR && pos[1] >= 4 &&
+ pos[2] == 0x00 && pos[3] == 0x50 &&
+ pos[4] == 0xf2 && pos[5] == 0x01;
+}
+
+static bool is_rsn_ie(const u8 *pos)
+{
+ return pos[0] == IEEE80211_ELEMID_RSN;
+}
+
+static bool is_wps_ie(const u8 *pos)
+{
+ return (pos[0] == IEEE80211_ELEMID_VENDOR &&
+ pos[1] >= 4 &&
+ pos[2] == 0x00 && pos[3] == 0x50 && pos[4] == 0xf2 &&
+ pos[5] == 0x04);
+}
+/*
+ * SIOCSIWGENIE
+ */
+static int
+ar6000_ioctl_siwgenie(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *erq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_UCHAR *ie = extra;
+ A_UINT16 ieLen = erq->length;
+ const A_UCHAR *pos;
+ A_UCHAR *buf = NULL;
+ int len = 0;
+
+ if (ar->arWmiReady == FALSE || ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+ if (ieLen > IEEE80211_APPIE_FRAME_MAX_LEN) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ arPriv->arSta.arConnectCtrlFlags &= ~CONNECT_WPS_FLAG;
+
+ if (ie && ieLen) {
+ buf = kmalloc(ieLen, GFP_KERNEL);
+ if (buf == NULL){
+ up(&ar->arSem);
+ return -ENOMEM;
+ }
+ pos = ie;
+
+ while (pos + 1 < ie + ieLen) {
+ if (pos + 2 + pos[1] > ie + ieLen)
+ break;
+ if (!(is_wpa_ie(pos) || is_rsn_ie(pos))) {
+ memcpy(buf + len, pos, 2 + pos[1]);
+ len += 2 + pos[1];
+ }
+
+ if (is_wps_ie(pos)){
+ /* WPS IE detected, notify target */
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("WPS IE detected -- setting WPS flag\n"));
+ arPriv->arSta.arConnectCtrlFlags |= CONNECT_WPS_FLAG;
+ }
+
+ pos += 2 + pos[1];
+ }
+ }
+
+ wmi_set_appie_cmd(arPriv->arWmi, WMI_FRAME_ASSOC_REQ, len, buf);
+ kfree(buf);
+ up(&ar->arSem);
+ return 0;
+}
+
+
+
+/*
+ * SIOCGIWGENIE
+ */
+static int
+ar6000_ioctl_giwgenie(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *erq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+ erq->length = 0;
+ erq->flags = 0;
+
+ return 0;
+}
+
+/*
+ * SIOCSIWAUTH
+ */
+static int
+ar6000_ioctl_siwauth(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *data, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+
+ A_BOOL profChanged;
+ A_UINT16 param;
+ A_INT32 ret;
+ A_INT32 value;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ param = data->flags & IW_AUTH_INDEX;
+ value = data->value;
+ profChanged = TRUE;
+ ret = 0;
+
+ switch (param) {
+ case IW_AUTH_WPA_VERSION:
+ if (value & IW_AUTH_WPA_VERSION_DISABLED) {
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ } else if (value & IW_AUTH_WPA_VERSION_WPA) {
+ arPriv->arAuthMode = WMI_WPA_AUTH;
+ } else if (value & IW_AUTH_WPA_VERSION_WPA2) {
+ arPriv->arAuthMode = WMI_WPA2_AUTH;
+ } else {
+ ret = -1;
+ profChanged = FALSE;
+ }
+ if(!ret) {
+ if(arPriv->PreAuthMode == arPriv->arAuthMode) {
+ profChanged = FALSE;
+ }
+ arPriv->PreAuthMode = arPriv->arAuthMode;
+ }
+ break;
+ case IW_AUTH_CIPHER_PAIRWISE:
+ if (value & IW_AUTH_CIPHER_NONE) {
+ if(arPriv->arPairwiseCrypto == NONE_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+ } else if (value & IW_AUTH_CIPHER_WEP40) {
+ if(arPriv->arPairwiseCrypto == WEP_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arPairwiseCrypto = WEP_CRYPT;
+ arPriv->arPairwiseCryptoLen = 5;
+ } else if (value & IW_AUTH_CIPHER_TKIP) {
+ if(arPriv->arPairwiseCrypto == TKIP_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arPairwiseCrypto = TKIP_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+ } else if (value & IW_AUTH_CIPHER_CCMP) {
+ if(arPriv->arPairwiseCrypto == AES_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arPairwiseCrypto = AES_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+ } else if (value & IW_AUTH_CIPHER_WEP104) {
+ if(arPriv->arPairwiseCrypto == WEP_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arPairwiseCrypto = WEP_CRYPT;
+ arPriv->arPairwiseCryptoLen = 13;
+#ifdef WAPI_ENABLE
+ } else if (value & IW_AUTH_CIPHER_SMS4) {
+ if(arPriv->arPairwiseCrypto == WAPI_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arPairwiseCrypto = WAPI_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+#endif
+ } else {
+ ret = -1;
+ profChanged = FALSE;
+ }
+ break;
+ case IW_AUTH_CIPHER_GROUP:
+ if (value & IW_AUTH_CIPHER_NONE) {
+ if(arPriv->arGroupCrypto == NONE_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+ } else if (value & IW_AUTH_CIPHER_WEP40) {
+ if(arPriv->arGroupCrypto == WEP_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arGroupCrypto = WEP_CRYPT;
+ arPriv->arGroupCryptoLen = 5;
+ } else if (value & IW_AUTH_CIPHER_TKIP) {
+ if(arPriv->arGroupCrypto == TKIP_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arGroupCrypto = TKIP_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+ } else if (value & IW_AUTH_CIPHER_CCMP) {
+ if(arPriv->arGroupCrypto == AES_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arGroupCrypto = AES_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+ } else if (value & IW_AUTH_CIPHER_WEP104) {
+ if(arPriv->arGroupCrypto == WEP_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arGroupCrypto = WEP_CRYPT;
+ arPriv->arGroupCryptoLen = 13;
+#ifdef WAPI_ENABLE
+ } else if (value & IW_AUTH_CIPHER_SMS4) {
+ if(arPriv->arGroupCrypto == WAPI_CRYPT) {
+ profChanged = FALSE;
+ }
+ arPriv->arGroupCrypto = WAPI_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+#endif
+ } else {
+ ret = -1;
+ profChanged = FALSE;
+ }
+ break;
+ case IW_AUTH_KEY_MGMT:
+ if (value & IW_AUTH_KEY_MGMT_PSK) {
+ if (WMI_WPA_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA_PSK_AUTH;
+ } else if (WMI_WPA2_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA2_PSK_AUTH;
+ } else {
+ ret = -1;
+ }
+#define IW_AUTH_KEY_MGMT_CCKM 8
+ } else if (value & IW_AUTH_KEY_MGMT_CCKM) {
+ if (WMI_WPA_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA_AUTH_CCKM;
+ } else if (WMI_WPA2_AUTH == arPriv->arAuthMode) {
+ arPriv->arAuthMode = WMI_WPA2_AUTH_CCKM;
+ } else {
+ ret = -1;
+ }
+ } else if (!(value & IW_AUTH_KEY_MGMT_802_1X)) {
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ }
+ if(!ret) {
+ if(arPriv->PreAuthKeyMgmt == arPriv->arAuthMode) {
+ profChanged = FALSE;
+ }
+ arPriv->PreAuthKeyMgmt = arPriv->arAuthMode;
+ }
+ break;
+ case IW_AUTH_TKIP_COUNTERMEASURES:
+ wmi_set_tkip_countermeasures_cmd(arPriv->arWmi, value);
+ profChanged = FALSE;
+ break;
+ case IW_AUTH_DROP_UNENCRYPTED:
+ profChanged = FALSE;
+ break;
+ case IW_AUTH_80211_AUTH_ALG:
+ if (value & IW_AUTH_ALG_OPEN_SYSTEM) {
+ if((arPriv->arDot11AuthMode & OPEN_AUTH)) {
+ profChanged = FALSE;
+ }
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ }
+ if (value & IW_AUTH_ALG_SHARED_KEY) {
+ if((arPriv->arDot11AuthMode & SHARED_AUTH)) {
+ profChanged = FALSE;
+ }
+ arPriv->arDot11AuthMode = SHARED_AUTH;
+ }
+ if (value & IW_AUTH_ALG_LEAP) {
+ if((arPriv->arDot11AuthMode & LEAP_AUTH)) {
+ profChanged = FALSE;
+ }
+ arPriv->arDot11AuthMode = LEAP_AUTH;
+ }
+ if((value & (IW_AUTH_ALG_OPEN_SYSTEM | IW_AUTH_ALG_SHARED_KEY |IW_AUTH_ALG_LEAP))==0){
+ ret = -1;
+ profChanged = FALSE;
+ }
+ break;
+ case IW_AUTH_WPA_ENABLED:
+ profChanged = FALSE;
+ if (!value) {
+ arPriv->arAuthMode = WMI_NONE_AUTH;
+ /* when the supplicant is stopped, it calls this
+ * handler with value=0. The followings need to be
+ * reset if the STA were to connect again
+ * without security
+ */
+ arPriv->arDot11AuthMode = OPEN_AUTH;
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+ }
+ break;
+ case IW_AUTH_RX_UNENCRYPTED_EAPOL:
+ profChanged = FALSE;
+ break;
+ case IW_AUTH_ROAMING_CONTROL:
+ profChanged = FALSE;
+ break;
+ case IW_AUTH_PRIVACY_INVOKED:
+ profChanged = FALSE;
+ if (!value) {
+ arPriv->arPairwiseCrypto = NONE_CRYPT;
+ arPriv->arPairwiseCryptoLen = 0;
+ arPriv->arGroupCrypto = NONE_CRYPT;
+ arPriv->arGroupCryptoLen = 0;
+ }
+ break;
+ default:
+ ret = -1;
+ profChanged = FALSE;
+ break;
+ }
+
+ if (profChanged == TRUE) {
+ /*
+ * profile has changed. Erase ssid to signal change
+ */
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+ }
+
+ up(&ar->arSem);
+ return ret;
+}
+
+
+/*
+ * SIOCGIWAUTH
+ */
+static int
+ar6000_ioctl_giwauth(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *data, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ A_UINT16 param;
+ A_INT32 ret;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ param = data->flags & IW_AUTH_INDEX;
+ ret = 0;
+ data->value = 0;
+
+
+ switch (param) {
+ case IW_AUTH_WPA_VERSION:
+ if (arPriv->arAuthMode == WMI_NONE_AUTH) {
+ data->value |= IW_AUTH_WPA_VERSION_DISABLED;
+ } else if (arPriv->arAuthMode == WMI_WPA_AUTH) {
+ data->value |= IW_AUTH_WPA_VERSION_WPA;
+ } else if (arPriv->arAuthMode == WMI_WPA2_AUTH) {
+ data->value |= IW_AUTH_WPA_VERSION_WPA2;
+ } else {
+ ret = -1;
+ }
+ break;
+ case IW_AUTH_CIPHER_PAIRWISE:
+ if (arPriv->arPairwiseCrypto == NONE_CRYPT) {
+ data->value |= IW_AUTH_CIPHER_NONE;
+ } else if (arPriv->arPairwiseCrypto == WEP_CRYPT) {
+ if (arPriv->arPairwiseCryptoLen == 13) {
+ data->value |= IW_AUTH_CIPHER_WEP104;
+ } else {
+ data->value |= IW_AUTH_CIPHER_WEP40;
+ }
+ } else if (arPriv->arPairwiseCrypto == TKIP_CRYPT) {
+ data->value |= IW_AUTH_CIPHER_TKIP;
+ } else if (arPriv->arPairwiseCrypto == AES_CRYPT) {
+ data->value |= IW_AUTH_CIPHER_CCMP;
+ } else {
+ ret = -1;
+ }
+ break;
+ case IW_AUTH_CIPHER_GROUP:
+ if (arPriv->arGroupCrypto == NONE_CRYPT) {
+ data->value |= IW_AUTH_CIPHER_NONE;
+ } else if (arPriv->arGroupCrypto == WEP_CRYPT) {
+ if (arPriv->arGroupCryptoLen == 13) {
+ data->value |= IW_AUTH_CIPHER_WEP104;
+ } else {
+ data->value |= IW_AUTH_CIPHER_WEP40;
+ }
+ } else if (arPriv->arGroupCrypto == TKIP_CRYPT) {
+ data->value |= IW_AUTH_CIPHER_TKIP;
+ } else if (arPriv->arGroupCrypto == AES_CRYPT) {
+ data->value |= IW_AUTH_CIPHER_CCMP;
+ } else {
+ ret = -1;
+ }
+ break;
+ case IW_AUTH_KEY_MGMT:
+ if ((arPriv->arAuthMode == WMI_WPA_PSK_AUTH) ||
+ (arPriv->arAuthMode == WMI_WPA2_PSK_AUTH)) {
+ data->value |= IW_AUTH_KEY_MGMT_PSK;
+ } else if ((arPriv->arAuthMode == WMI_WPA_AUTH) ||
+ (arPriv->arAuthMode == WMI_WPA2_AUTH)) {
+ data->value |= IW_AUTH_KEY_MGMT_802_1X;
+ }
+ break;
+ case IW_AUTH_TKIP_COUNTERMEASURES:
+ // TODO. Save countermeassure enable/disable
+ data->value = 0;
+ break;
+ case IW_AUTH_DROP_UNENCRYPTED:
+ break;
+ case IW_AUTH_80211_AUTH_ALG:
+ if (arPriv->arDot11AuthMode == OPEN_AUTH) {
+ data->value |= IW_AUTH_ALG_OPEN_SYSTEM;
+ } else if (arPriv->arDot11AuthMode == SHARED_AUTH) {
+ data->value |= IW_AUTH_ALG_SHARED_KEY;
+ } else if (arPriv->arDot11AuthMode == LEAP_AUTH) {
+ data->value |= IW_AUTH_ALG_LEAP;
+ } else {
+ ret = -1;
+ }
+ break;
+ case IW_AUTH_WPA_ENABLED:
+ if (arPriv->arAuthMode == WMI_NONE_AUTH) {
+ data->value = 0;
+ } else {
+ data->value = 1;
+ }
+ break;
+ case IW_AUTH_RX_UNENCRYPTED_EAPOL:
+ break;
+ case IW_AUTH_ROAMING_CONTROL:
+ break;
+ case IW_AUTH_PRIVACY_INVOKED:
+ if (arPriv->arPairwiseCrypto == NONE_CRYPT) {
+ data->value = 0;
+ } else {
+ data->value = 1;
+ }
+ break;
+ default:
+ ret = -1;
+ break;
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCSIWPMKSA
+ */
+static int
+ar6000_ioctl_siwpmksa(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_INT32 ret;
+ A_STATUS status;
+ struct iw_pmksa *pmksa;
+
+ pmksa = (struct iw_pmksa *)extra;
+
+ if (ar->arWmiReady == FALSE || ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ ret = 0;
+ status = A_OK;
+
+ switch (pmksa->cmd) {
+ case IW_PMKSA_ADD:
+ status = wmi_setPmkid_cmd(arPriv->arWmi, (A_UINT8*)pmksa->bssid.sa_data, pmksa->pmkid, TRUE);
+ break;
+ case IW_PMKSA_REMOVE:
+ status = wmi_setPmkid_cmd(arPriv->arWmi, (A_UINT8*)pmksa->bssid.sa_data, pmksa->pmkid, FALSE);
+ break;
+ case IW_PMKSA_FLUSH:
+ if (arPriv->arConnected == TRUE) {
+ status = wmi_setPmkid_cmd(arPriv->arWmi, arPriv->arBssid, NULL, 0);
+ }
+ break;
+ default:
+ ret=-1;
+ break;
+ }
+ if (status != A_OK) {
+ ret = -1;
+ }
+
+ up(&ar->arSem);
+ return ret;
+}
+
+#ifdef WAPI_ENABLE
+
+#define PN_INIT 0x5c365c36
+
+static int ar6000_set_wapi_key(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *erq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ struct iw_encode_ext *ext = (struct iw_encode_ext *)extra;
+ KEY_USAGE keyUsage = 0;
+ A_INT32 keyLen;
+ A_UINT8 *keyData;
+ A_INT32 index;
+ A_UINT32 *PN;
+ A_INT32 i;
+ A_STATUS status;
+ A_UINT8 wapiKeyRsc[16];
+ CRYPTO_TYPE keyType = WAPI_CRYPT;
+ const A_UINT8 broadcastMac[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+ index = erq->flags & IW_ENCODE_INDEX;
+ if (index && (((index - 1) < WMI_MIN_KEY_INDEX) ||
+ ((index - 1) > WMI_MAX_KEY_INDEX))) {
+ return -EIO;
+ }
+
+ index--;
+ if (index < 0 || index > 4) {
+ return -EIO;
+ }
+ keyData = (A_UINT8 *)(ext + 1);
+ keyLen = erq->length - sizeof(struct iw_encode_ext);
+ A_MEMCPY(wapiKeyRsc, ext->tx_seq, sizeof(wapiKeyRsc));
+
+ if (A_MEMCMP(ext->addr.sa_data, broadcastMac, sizeof(broadcastMac)) == 0) {
+ keyUsage |= GROUP_USAGE;
+ PN = (A_UINT32 *)wapiKeyRsc;
+ for (i = 0; i < 4; i++) {
+ PN[i] = PN_INIT;
+ }
+ } else {
+ keyUsage |= PAIRWISE_USAGE;
+ }
+ status = wmi_addKey_cmd(arPriv->arWmi,
+ index,
+ keyType,
+ keyUsage,
+ keyLen,
+ wapiKeyRsc,
+ keyData,
+ KEY_OP_INIT_WAPIPN,
+ NULL,
+ SYNC_BEFORE_WMIFLAG);
+ if (A_OK != status) {
+ return -EIO;
+ }
+ return 0;
+}
+
+#endif
+
+/*
+ * SIOCSIWENCODEEXT
+ */
+static int
+ar6000_ioctl_siwencodeext(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *erq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_INT32 index;
+ struct iw_encode_ext *ext;
+ KEY_USAGE keyUsage;
+ A_INT32 keyLen;
+ A_UINT8 *keyData;
+ A_UINT8 keyRsc[8];
+ A_STATUS status;
+ CRYPTO_TYPE keyType;
+ A_UINT32 returnValue = -EIO;
+#ifdef USER_KEYS
+ struct ieee80211req_key ik;
+#endif /* USER_KEYS */
+ AR_SOFTC_AP_T *arAp = &arPriv->arAp;
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+#ifdef USER_KEYS
+ arPriv->arSta.user_saved_keys.keyOk = FALSE;
+#endif /* USER_KEYS */
+
+ index = erq->flags & IW_ENCODE_INDEX;
+
+ if (index && (((index - 1) < WMI_MIN_KEY_INDEX) ||
+ ((index - 1) > WMI_MAX_KEY_INDEX)))
+ {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ ext = (struct iw_encode_ext *)extra;
+ if (erq->flags & IW_ENCODE_DISABLED) {
+ /*
+ * Encryption disabled
+ */
+ if (index) {
+ /*
+ * If key index was specified then clear the specified key
+ */
+ index--;
+ A_MEMZERO(arPriv->arWepKeyList[index].arKey,
+ sizeof(arPriv->arWepKeyList[index].arKey));
+ arPriv->arWepKeyList[index].arKeyLen = 0;
+ }
+ } else {
+ /*
+ * Enabling WEP encryption
+ */
+ if (index) {
+ index--; /* keyindex is off base 1 in iwconfig */
+ }
+
+ keyUsage = 0;
+ keyLen = erq->length - sizeof(struct iw_encode_ext);
+
+ if (ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY) {
+ keyUsage = TX_USAGE;
+ arPriv->arDefTxKeyIndex = index;
+ // Just setting the key index
+ if (keyLen == 0) {
+ up(&ar->arSem);
+ return 0;
+ }
+ }
+
+ if (keyLen <= 0) {
+ if (ext->alg == IW_ENCODE_ALG_KRK) {
+ wmi_delete_krk_cmd(arPriv->arWmi);
+ }
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ /* key follows iw_encode_ext */
+ keyData = (A_UINT8 *)(ext + 1);
+
+ switch (ext->alg) {
+ case IW_ENCODE_ALG_WEP:
+ keyType = WEP_CRYPT;
+#ifdef USER_KEYS
+ ik.ik_type = IEEE80211_CIPHER_WEP;
+#endif /* USER_KEYS */
+ if(arPriv->arNextMode == AP_NETWORK) {
+ arAp->ap_mode_bkey.ik_type = IEEE80211_CIPHER_WEP;
+ }
+ if (!IEEE80211_IS_VALID_WEP_CIPHER_LEN(keyLen)) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ /* Check whether it is static wep. */
+ if (!arPriv->arConnected) {
+ A_MEMZERO(arPriv->arWepKeyList[index].arKey,
+ sizeof(arPriv->arWepKeyList[index].arKey));
+ A_MEMCPY(arPriv->arWepKeyList[index].arKey, keyData, keyLen);
+ arPriv->arWepKeyList[index].arKeyLen = keyLen;
+
+ up(&ar->arSem);
+ return 0;
+ }
+ break;
+ case IW_ENCODE_ALG_TKIP:
+ keyType = TKIP_CRYPT;
+#ifdef USER_KEYS
+ ik.ik_type = IEEE80211_CIPHER_TKIP;
+#endif /* USER_KEYS */
+ if(arPriv->arNextMode == AP_NETWORK) {
+ arAp->ap_mode_bkey.ik_type = IEEE80211_CIPHER_TKIP;
+ }
+ break;
+ case IW_ENCODE_ALG_CCMP:
+ keyType = AES_CRYPT;
+#ifdef USER_KEYS
+ ik.ik_type = IEEE80211_CIPHER_AES_CCM;
+#endif /* USER_KEYS */
+ if(arPriv->arNextMode == AP_NETWORK) {
+ arAp->ap_mode_bkey.ik_type = IEEE80211_CIPHER_AES_CCM;
+ }
+ break;
+#ifdef WAPI_ENABLE
+ case IW_ENCODE_ALG_SM4:
+ {
+ returnValue = ar6000_set_wapi_key(dev, info, erq, extra);
+ up(&ar->arSem);
+ return returnValue;
+ }
+#endif
+ case IW_ENCODE_ALG_PMK:
+ arPriv->arSta.arConnectCtrlFlags |= CONNECT_DO_WPA_OFFLOAD;
+ returnValue = wmi_set_pmk_cmd(arPriv->arWmi, keyData);
+ up(&ar->arSem);
+ return returnValue;
+ case IW_ENCODE_ALG_KRK:
+ returnValue = wmi_add_krk_cmd(arPriv->arWmi, keyData);
+ up(&ar->arSem);
+ return returnValue;
+ default:
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+
+ if (ext->ext_flags & IW_ENCODE_EXT_GROUP_KEY) {
+ keyUsage |= GROUP_USAGE;
+ if(arPriv->arNextMode == AP_NETWORK) {
+ keyUsage &= ~TX_USAGE;
+ arAp->ap_mode_bkey.ik_keyix = index;
+ arAp->ap_mode_bkey.ik_keylen = keyLen;
+ memcpy(arAp->ap_mode_bkey.ik_keydata, keyData, keyLen);
+ memcpy(&arAp->ap_mode_bkey.ik_keyrsc, keyRsc, sizeof(keyRsc));
+ memcpy(arAp->ap_mode_bkey.ik_macaddr, ext->addr.sa_data, ETH_ALEN);
+ }
+ } else {
+ keyUsage |= PAIRWISE_USAGE;
+ }
+
+ if (ext->ext_flags & IW_ENCODE_EXT_RX_SEQ_VALID) {
+ A_MEMCPY(keyRsc, ext->rx_seq, sizeof(keyRsc));
+ } else {
+ A_MEMZERO(keyRsc, sizeof(keyRsc));
+ }
+
+ if (((WMI_WPA_PSK_AUTH == arPriv->arAuthMode) || (WMI_WPA2_PSK_AUTH == arPriv->arAuthMode)) &&
+ (GROUP_USAGE & keyUsage))
+ {
+ A_UNTIMEOUT(&arPriv->arSta.disconnect_timer);
+ }
+
+ status = wmi_addKey_cmd(arPriv->arWmi, index, keyType, keyUsage,
+ keyLen, keyRsc,
+ keyData, KEY_OP_INIT_VAL,
+ (A_UINT8*)ext->addr.sa_data,
+ SYNC_BOTH_WMIFLAG);
+ if (status != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+#ifdef USER_KEYS
+ ik.ik_keyix = index;
+ ik.ik_keylen = keyLen;
+ memcpy(ik.ik_keydata, keyData, keyLen);
+ memcpy(&ik.ik_keyrsc, keyRsc, sizeof(keyRsc));
+ memcpy(ik.ik_macaddr, ext->addr.sa_data, ETH_ALEN);
+ if (ext->ext_flags & IW_ENCODE_EXT_GROUP_KEY) {
+ memcpy(&arPriv->arSta.user_saved_keys.bcast_ik, &ik,
+ sizeof(struct ieee80211req_key));
+ } else {
+ memcpy(&arPriv->arSta.user_saved_keys.ucast_ik, &ik,
+ sizeof(struct ieee80211req_key));
+ }
+ arPriv->arSta.user_saved_keys.keyOk = TRUE;
+#endif /* USER_KEYS */
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCGIWENCODEEXT
+ */
+static int
+ar6000_ioctl_giwencodeext(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *erq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (arPriv->arPairwiseCrypto == NONE_CRYPT) {
+ erq->length = 0;
+ erq->flags = IW_ENCODE_DISABLED;
+ } else {
+ erq->length = 0;
+ }
+
+ return 0;
+}
+#endif // WIRELESS_EXT >= 18
+
+#if WIRELESS_EXT > 20
+static int ar6000_ioctl_siwpower(struct net_device *dev,
+ struct iw_request_info *info,
+ union iwreq_data *wrqu, char *extra)
+{
+#ifndef ATH6K_CONFIG_OTA_MODE
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_POWER_MODE power_mode;
+
+ if(psm_info == 1 || psm_info == 0)
+ {
+ return 0;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ if (wrqu->power.disabled)
+ power_mode = MAX_PERF_POWER;
+ else
+ power_mode = REC_POWER;
+
+ if (wmi_powermode_cmd(arPriv->arWmi, power_mode) < 0)
+ {
+ up(&ar->arSem);
+ return -EIO;
+ }
+#endif
+ up(&ar->arSem);
+ return 0;
+}
+
+static int ar6000_ioctl_giwpower(struct net_device *dev,
+ struct iw_request_info *info,
+ union iwreq_data *wrqu, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ WMI_POWER_MODE power_mode;
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ power_mode = wmi_get_power_mode_cmd(arPriv->arWmi);
+
+ if (power_mode == MAX_PERF_POWER)
+ wrqu->power.disabled = 1;
+ else
+ wrqu->power.disabled = 0;
+
+ up(&ar->arSem);
+ return 0;
+}
+#endif // WIRELESS_EXT > 20
+
+/*
+ * SIOCGIWNAME
+ */
+int
+ar6000_ioctl_giwname(struct net_device *dev,
+ struct iw_request_info *info,
+ char *name, char *extra)
+{
+ A_UINT8 capability;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ capability = arPriv->arPhyCapability;
+ if(arPriv->arNetworkType == INFRA_NETWORK && arPriv->arConnected) {
+ bss_t *bss;
+ wmi_scan_report_lock(arPriv->arWmi);
+ bss = wmi_find_node(arPriv->arWmi, arPriv->arBssid);
+ if (bss) {
+ capability = get_bss_phy_capability(bss);
+ wmi_node_return(arPriv->arWmi, bss);
+ }
+ wmi_scan_report_unlock(arPriv->arWmi);
+ }
+ switch (capability) {
+ case (WMI_11A_CAPABILITY):
+ if (strlcpy(name, "AR6000 802.11a", IFNAMSIZ) >= IFNAMSIZ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("strlcpy: AR6000 802.11a\n"));
+ return -1;
+ }
+ break;
+ case (WMI_11G_CAPABILITY):
+ if (strlcpy(name, "AR6000 802.11g", IFNAMSIZ) >= IFNAMSIZ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("strlcpy: AR6000 802.11g\n"));
+ return -1;
+ }
+ break;
+ case (WMI_11AG_CAPABILITY):
+ if (strlcpy(name, "AR6000 802.11ag", IFNAMSIZ) >= IFNAMSIZ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("strlcpy: AR6000 802.11ag\n"));
+ return -1;
+ }
+ break;
+ case (WMI_11NA_CAPABILITY):
+ if (strlcpy(name, "AR6000 802.11na", IFNAMSIZ) >= IFNAMSIZ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("strlcpy: AR6000 802.11na\n"));
+ return -1;
+ }
+ break;
+ case (WMI_11NG_CAPABILITY):
+ if (strlcpy(name, "AR6000 802.11ng", IFNAMSIZ) >= IFNAMSIZ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("strlcpy: AR6000 802.11ng\n"));
+ return -1;
+ }
+ break;
+ case (WMI_11NAG_CAPABILITY):
+ if (strlcpy(name, "AR6K 802.11nag", IFNAMSIZ) >= IFNAMSIZ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("strlcpy: AR6000 802.11nag\n"));
+ return -1;
+ }
+ break;
+ default:
+ if (strlcpy(name, "AR6000 802.11b", IFNAMSIZ) >= IFNAMSIZ) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("strlcpy: AR6003 802.11b\n"));
+ return -1;
+ }
+ break;
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCSIWFREQ
+ */
+int
+ar6000_ioctl_siwfreq(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_freq *freq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ /*
+ * We support limiting the channels via wmiconfig.
+ *
+ * We use this command to configure the channel hint for the connect cmd
+ * so it is possible the target will end up connecting to a different
+ * channel.
+ */
+ if (freq->e > 1) {
+ up(&ar->arSem);
+ return -EINVAL;
+ } else if (freq->e == 1) {
+ if ((arPriv->arPhyCapability == WMI_11NG_CAPABILITY) && (((freq->m / 100000) >= 5180) && ((freq->m / 100000) <= 5825))) {
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ arPriv->arChannelHint = freq->m / 100000;
+ } else if(freq->m > 0) {
+ if ((arPriv->arPhyCapability == WMI_11NG_CAPABILITY) && ((wlan_ieee2freq(freq->m) >=5180) && (wlan_ieee2freq(freq->m) <= 5825))) {
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ arPriv->arChannelHint = wlan_ieee2freq(freq->m);
+ } else {
+ /* Auto Channel Selection */
+ arPriv->arChannelHint = 0;
+ }
+
+ if(ar->lteFreq && arPriv->arChannelHint && arPriv->arNetworkType == AP_NETWORK) {
+ A_PRINTF("LTE coex enabled. Ignore channel set to %d\n", arPriv->arChannelHint);
+ arPriv->arChannelHint = 0;
+ } else {
+ arPriv->ap_profile_flag = 1; /* There is a change in profile */
+ A_PRINTF("channel hint set to %d\n", arPriv->arChannelHint);
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCGIWFREQ
+ */
+int
+ar6000_ioctl_giwfreq(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_freq *freq, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ if (arPriv->arNetworkType == AP_NETWORK) {
+ if(arPriv->arChannelHint) {
+ freq->m = arPriv->arChannelHint * 100000;
+ } else if(arPriv->arBssChannel) {
+ freq->m = arPriv->arBssChannel * 100000;
+ } else {
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ } else {
+ if (arPriv->arConnected != TRUE) {
+ up(&ar->arSem);
+ return -EINVAL;
+ } else {
+ freq->m = arPriv->arBssChannel * 100000;
+ }
+ }
+
+ freq->e = 1;
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCSIWMODE
+ */
+int
+ar6000_ioctl_siwmode(struct net_device *dev,
+ struct iw_request_info *info,
+ __u32 *mode, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+#if 0
+ /*
+ * clear SSID during mode switch in connected state
+ */
+ if(!(arPriv->arNetworkType == (((*mode) == IW_MODE_INFRA) ? INFRA_NETWORK : ADHOC_NETWORK))
+ && (arPriv->arConnected == TRUE) ){
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+ }
+#endif
+
+ switch (*mode) {
+ case IW_MODE_INFRA:
+ arPriv->arNextMode = INFRA_NETWORK;
+ break;
+ case IW_MODE_ADHOC:
+ arPriv->arNextMode = ADHOC_NETWORK;
+ break;
+ case IW_MODE_MASTER:
+ arPriv->arNextMode = AP_NETWORK;
+ break;
+ default:
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+
+ if (arPriv->arNetworkType != arPriv->arNextMode) {
+ ar6000_init_mode_info(arPriv);
+ }
+
+ /* Update the arNetworkType */
+ arPriv->arNetworkType = arPriv->arNextMode;
+
+ up(&ar->arSem);
+ return 0;
+}
+
+/*
+ * SIOCGIWMODE
+ */
+int
+ar6000_ioctl_giwmode(struct net_device *dev,
+ struct iw_request_info *info,
+ __u32 *mode, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ switch (arPriv->arNetworkType) {
+ case INFRA_NETWORK:
+ *mode = IW_MODE_INFRA;
+ break;
+ case ADHOC_NETWORK:
+ *mode = IW_MODE_ADHOC;
+ break;
+ case AP_NETWORK:
+ *mode = IW_MODE_MASTER;
+ break;
+ default:
+ return -EIO;
+ }
+ return 0;
+}
+
+/*
+ * SIOCSIWSENS
+ */
+int
+ar6000_ioctl_siwsens(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *sens, char *extra)
+{
+ return 0;
+}
+
+/*
+ * SIOCGIWSENS
+ */
+int
+ar6000_ioctl_giwsens(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_param *sens, char *extra)
+{
+ sens->value = 0;
+ sens->fixed = 1;
+
+ return 0;
+}
+
+/*
+ * SIOCGIWRANGE
+ */
+int
+ar6000_ioctl_giwrange(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ struct iw_range *range = (struct iw_range *) extra;
+ int i, j, ret = 0;
+ const A_INT32 rateTable[] = {
+ 1000, 2000, 5500, 11000,
+ 6000, 9000, 12000, 18000, 24000, 36000, 48000, 54000,
+ 6500, 13000, 19500, 26000, 39000, 52000, 58500, 65000 };
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWmiReady == FALSE || ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ arSta->arNumChannels = -1;
+ A_MEMZERO(arSta->arChannelList, sizeof (arSta->arChannelList));
+
+ if (wmi_get_channelList_cmd(arPriv->arWmi) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ wait_event_interruptible_timeout(arPriv->arEvent, arSta->arNumChannels != -1, wmitimeout * HZ);
+
+ if (signal_pending(current)) {
+ up(&ar->arSem);
+ return -EINTR;
+ }
+
+ data->length = sizeof(struct iw_range);
+ A_MEMZERO(range, sizeof(struct iw_range));
+
+ range->enc_capa |= IW_ENC_CAPA_WPA | IW_ENC_CAPA_WPA2;
+ range->enc_capa |= IW_ENC_CAPA_CIPHER_TKIP|IW_ENC_CAPA_CIPHER_CCMP;
+ /* Event capability (kernel + driver) */
+ range->event_capa[0] = (IW_EVENT_CAPA_K_0 |
+ IW_EVENT_CAPA_MASK(SIOCGIWAP) |
+ IW_EVENT_CAPA_MASK(SIOCGIWSCAN));
+ range->event_capa[1] = IW_EVENT_CAPA_K_1;
+ range->event_capa[4] = (IW_EVENT_CAPA_MASK(IWEVCUSTOM) |
+ IW_EVENT_CAPA_MASK(IWEVREGISTERED) |
+ IW_EVENT_CAPA_MASK(IWEVEXPIRED) |
+#if WIRELESS_EXT >= 18
+ IW_EVENT_CAPA_MASK(IWEVPMKIDCAND) |
+ IW_EVENT_CAPA_MASK(IWEVASSOCRESPIE) |
+ IW_EVENT_CAPA_MASK(IWEVASSOCREQIE) |
+ IW_EVENT_CAPA_MASK(IWEVGENIE) |
+#endif
+ 0);
+
+ range->scan_capa = IW_SCAN_CAPA_ESSID | IW_SCAN_CAPA_CHANNEL;
+
+ range->txpower_capa = 0;
+
+ range->min_pmp = 1 * 1024;
+ range->max_pmp = 65535 * 1024;
+ range->min_pmt = 1 * 1024;
+ range->max_pmt = 1000 * 1024;
+ range->pmp_flags = IW_POWER_PERIOD;
+ range->pmt_flags = IW_POWER_TIMEOUT;
+ range->pm_capa = 0;
+
+ range->we_version_compiled = WIRELESS_EXT;
+ range->we_version_source = 13;
+
+ range->retry_capa = IW_RETRY_LIMIT;
+ range->retry_flags = IW_RETRY_LIMIT;
+ range->min_retry = 0;
+ range->max_retry = 255;
+
+ range->num_frequency = range->num_channels = arSta->arNumChannels;
+ for (i = 0; i < arSta->arNumChannels; i++) {
+ range->freq[i].i = wlan_freq2ieee(arSta->arChannelList[i]);
+ range->freq[i].m = arSta->arChannelList[i] * 100000;
+ range->freq[i].e = 1;
+ /*
+ * Linux supports max of 32 channels, bail out once you
+ * reach the max.
+ */
+ if (i == IW_MAX_FREQUENCIES) {
+ break;
+ }
+ }
+
+ /* Max quality is max field value minus noise floor */
+ range->max_qual.qual = 0xff - 161;
+
+ /*
+ * In order to use dBm measurements, 'level' must be lower
+ * than any possible measurement (see iw_print_stats() in
+ * wireless tools). It's unclear how this is meant to be
+ * done, but setting zero in these values forces dBm and
+ * the actual numbers are not used.
+ */
+ range->max_qual.level = 0;
+ range->max_qual.noise = 0;
+
+ range->sensitivity = 3;
+
+ range->max_encoding_tokens = 4;
+ /* XXX query driver to find out supported key sizes */
+ range->num_encoding_sizes = 3;
+ range->encoding_size[0] = 5; /* 40-bit */
+ range->encoding_size[1] = 13; /* 104-bit */
+ range->encoding_size[2] = 16; /* 128-bit */
+
+ for (i=0, j=0; i<sizeof(rateTable)/sizeof(rateTable[0]) && j<IW_MAX_BITRATES; ++i) {
+ A_INT8 rateIdx;
+ if (wmi_validate_bitrate(arPriv->arWmi, rateTable[i], &rateIdx)==A_OK) {
+ range->bitrate[j] = wmi_get_rate(i) * 1000;
+ ++j;
+ }
+ }
+ range->num_bitrates = j;
+
+ /* estimated maximum TCP throughput values (bps) */
+ range->throughput = 22000000;
+
+ range->min_rts = 0;
+ range->max_rts = 2347;
+ range->min_frag = 256;
+ range->max_frag = 2346;
+
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,27)
+ if (arSta->wpaOffloadEnabled) {
+ range->enc_capa |= IW_ENC_CAPA_4WAY_HANDSHAKE;
+ }
+#endif /* LINUX_VERSION_CODE >= 2.6.27 */
+
+ up(&ar->arSem);
+
+ return ret;
+}
+
+/*
+ * SIOCSIWPRIV
+ *
+ */
+int
+ar6000_ioctl_siwpriv(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+ int ret = -EOPNOTSUPP;
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+#ifdef ANDROID_ENV
+ extern int android_ioctl_siwpriv(struct net_device *, struct iw_request_info *, struct iw_point *, char*);
+ char cmd[5];
+ if (data->pointer) {
+ if (copy_from_user(cmd, data->pointer, sizeof(cmd)))
+ return -EIO;
+ }
+#endif
+
+ if (!ar ||
+ ( (!ar->arWmiReady || (ar->arWlanState != WLAN_ENABLED))
+#ifdef ANDROID_ENV
+ && (!data->pointer || strncasecmp(cmd, "START", 5)!=0)
+#endif
+ )
+ ) {
+ return -EIO;
+ }
+
+#ifdef ANDROID_ENV
+ ret = android_ioctl_siwpriv(dev, info, data, extra);
+ if (ret!=-EOPNOTSUPP) {
+ return ret;
+ }
+#endif
+ return ret;
+}
+
+/*
+ * SIOCSIWAP
+ * This ioctl is used to set the desired bssid for the connect command.
+ */
+int
+ar6000_ioctl_siwap(struct net_device *dev,
+ struct iw_request_info *info,
+ struct sockaddr *ap_addr, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (ap_addr->sa_family != ARPHRD_ETHER) {
+ return -EIO;
+ }
+
+ if (A_MEMCMP(&ap_addr->sa_data, bcast_mac, AR6000_ETH_ADDR_LEN) == 0) {
+ A_MEMZERO(arSta->arReqBssid, sizeof(arSta->arReqBssid));
+ } else {
+ A_MEMCPY(arSta->arReqBssid, &ap_addr->sa_data, sizeof(arSta->arReqBssid));
+ }
+
+ return 0;
+}
+
+/*
+ * SIOCGIWAP
+ */
+int
+ar6000_ioctl_giwap(struct net_device *dev,
+ struct iw_request_info *info,
+ struct sockaddr *ap_addr, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (arPriv->arNetworkType == AP_NETWORK) {
+ A_MEMCPY(&ap_addr->sa_data, dev->dev_addr, ATH_MAC_LEN);
+ ap_addr->sa_family = ARPHRD_ETHER;
+ return 0;
+ }
+
+ if (arPriv->arConnected != TRUE) {
+ return -EINVAL;
+ }
+
+ A_MEMCPY(&ap_addr->sa_data, arPriv->arBssid, sizeof(arPriv->arBssid));
+ ap_addr->sa_family = ARPHRD_ETHER;
+
+ return 0;
+}
+
+#if (WIRELESS_EXT >= 18)
+/*
+ * SIOCSIWMLME
+ */
+int
+ar6000_ioctl_siwmlme(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->bIsDestroyProgress) {
+ return -EBUSY;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+
+ if (data->pointer && data->length == sizeof(struct iw_mlme)) {
+
+ A_UINT8 arNetworkType;
+ struct iw_mlme mlme;
+
+ if (copy_from_user(&mlme, data->pointer, sizeof(struct iw_mlme))) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+
+ switch (mlme.cmd) {
+
+ case IW_MLME_DEAUTH:
+ /* fall through */
+ case IW_MLME_DISASSOC:
+ if ((arPriv->arConnected != TRUE) ||
+ (memcmp(arPriv->arBssid, mlme.addr.sa_data, 6) != 0)) {
+
+ up(&ar->arSem);
+ return -EINVAL;
+ }
+ wmi_setPmkid_cmd(arPriv->arWmi, arPriv->arBssid, NULL, 0);
+ arNetworkType = arPriv->arNetworkType;
+ ar6000_init_profile_info(arPriv);
+ arPriv->arNetworkType = arNetworkType;
+ reconnect_flag = 0;
+ ar6000_disconnect(arPriv);
+ A_MEMZERO(arPriv->arSsid, sizeof(arPriv->arSsid));
+ arPriv->arSsidLen = 0;
+ if (arSta->arSkipScan == FALSE) {
+ A_MEMZERO(arSta->arReqBssid, sizeof(arSta->arReqBssid));
+ }
+ break;
+
+ case IW_MLME_AUTH:
+ /* fall through */
+ case IW_MLME_ASSOC:
+ /* fall through */
+ default:
+ up(&ar->arSem);
+ return -EOPNOTSUPP;
+ }
+ }
+
+ up(&ar->arSem);
+ return 0;
+}
+#endif /* WIRELESS_EXT >= 18 */
+
+/*
+ * SIOCGIWAPLIST
+ */
+int
+ar6000_ioctl_iwaplist(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+ return -EIO; /* for now */
+}
+
+#if WLAN_CONFIG_FIRST_SCAN_2G_ONLY
+static A_UINT16 channelList2G[] = {
+ 2412, 2417, 2422, 2427, 2432, 2437, 2442,
+ 2447, 2452, 2457, 2462, 2467, 2472, 2484
+};
+#endif
+
+/*
+ * SIOCSIWSCAN
+ */
+int
+ar6000_ioctl_siwscan(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+#define ACT_DWELLTIME_DEFAULT 105
+#define HOME_TXDRAIN_TIME 100
+#define SCAN_INT HOME_TXDRAIN_TIME + ACT_DWELLTIME_DEFAULT
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ AR_SOFTC_STA_T *arSta = &arPriv->arSta;
+ int ret = 0;
+ struct iw_scan_req *req = (struct iw_scan_req *) extra;
+ A_INT8 numChan = 0;
+ A_UINT16 channelList[IW_MAX_FREQUENCIES], *pChannelList = NULL;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+
+ if (data->length < sizeof(struct iw_scan_req)) {
+ req = NULL;
+ }
+
+ /* If scan is issued in the middle of ongoing scan or connect,
+ dont issue another one */
+ if ( arSta->scan_triggered > 0 ) {
+ ++arSta->scan_triggered;
+ if (arSta->scan_triggered < 5) {
+ up(&ar->arSem);
+ return 0;
+ } else {
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_SCAN,("Scan request is triggered over 5 times. Not scan complete event\n"));
+ }
+ }
+
+ if (!arSta->arUserBssFilter) {
+ if (wmi_bssfilter_cmd(arPriv->arWmi, ALL_BSS_FILTER, 0) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+ }
+
+ if (arPriv->arConnected) {
+ if (wmi_get_stats_cmd(arPriv->arWmi) != A_OK) {
+ up(&ar->arSem);
+ return -EIO;
+ }
+ }
+
+#if WIRELESS_EXT >= 18
+ if ( req && (data->flags & IW_SCAN_THIS_ESSID) == IW_SCAN_THIS_ESSID ) {
+ if (wmi_probedSsid_cmd(arPriv->arWmi, 0,
+ SPECIFIC_SSID_FLAG, req->essid_len, req->essid) == A_OK) {
+ if (!arSta->scanSpecificSsid) {
+ arSta->scanSpecificSsid = 1;
+ }
+ }
+ } else {
+ A_UINT8 idx;
+ for (idx=0; idx<arSta->scanSpecificSsid; ++idx) {
+ /* index 0 always reserves for broadcast SSID*/
+ A_UINT8 flag = (idx==0) ? ANY_SSID_FLAG : DISABLE_SSID_FLAG;
+ wmi_probedSsid_cmd(arPriv->arWmi, idx, flag, 0, NULL);
+ }
+ arSta->scanSpecificSsid = 0;
+ }
+
+ if ( req && (data->flags & IW_SCAN_THIS_FREQ) == IW_SCAN_THIS_FREQ && req->num_channels>0) {
+ A_UINT8 i;
+ for (i=0; i<req->num_channels; ++i) {
+ struct iw_freq *freq = &req->channel_list[i];
+ A_UINT16 *dst = &channelList[numChan];
+ if (freq->e == 1) {
+ /* freq->m == (Freq HZ value) divided by (10 ^ freq->e) */
+ *dst = freq->m / 100000;
+ ++numChan;
+ } else if (freq->e < 1 && freq->m) {
+ /* It is a channel number if freq->e == 0 */
+ *dst = wlan_ieee2freq(freq->m);
+ ++numChan;
+ }
+ }
+ if (numChan > 0) {
+ pChannelList = channelList;
+ }
+ }
+#endif /* WIRELESS_EXT >= 18 */
+
+#if WLAN_CONFIG_FIRST_SCAN_2G_ONLY
+ /*
+ * EV93646: Required to reduce connection time to an AP
+ * To reduce connection time after turn on, scan only 2.4G band for the first scan
+ */
+ if (first_scan_2g_only && pChannelList == NULL) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_INFO,("AR6K: scan 2.4GHz band only\n"));
+
+ pChannelList = channelList2G;
+ numChan = ARRAY_SIZE(channelList2G);
+ first_scan_2g_only = 0;
+ }
+#endif
+
+ if (wmi_startscan_cmd(arPriv->arWmi, WMI_LONG_SCAN, FALSE, FALSE, \
+ 0, 0, numChan, pChannelList) != A_OK) {
+
+ ret = -EIO;
+ }
+ if (ret == 0) {
+ arSta->scan_triggered = 1;
+ }
+
+ up(&ar->arSem);
+ return ret;
+#undef ACT_DWELLTIME_DEFAULT
+#undef HOME_TXDRAIN_TIME
+#undef SCAN_INT
+}
+
+
+/*
+ * Units are in db above the noise floor. That means the
+ * rssi values reported in the tx/rx descriptors in the
+ * driver are the SNR expressed in db.
+ *
+ * If you assume that the noise floor is -95, which is an
+ * excellent assumption 99.5 % of the time, then you can
+ * derive the absolute signal level (i.e. -95 + rssi).
+ * There are some other slight factors to take into account
+ * depending on whether the rssi measurement is from 11b,
+ * 11g, or 11a. These differences are at most 2db and
+ * can be documented.
+ *
+ * NB: various calculations are based on the orinoco/wavelan
+ * drivers for compatibility
+ */
+static void
+ar6000_set_quality(struct iw_quality *iq, A_INT8 rssi)
+{
+ if (rssi < 0) {
+ iq->qual = 0;
+ } else {
+ iq->qual = rssi;
+ }
+
+ /* NB: max is 94 because noise is hardcoded to 161 */
+ if (iq->qual > 94)
+ iq->qual = 94;
+
+ iq->noise = 161; /* -95dBm */
+ iq->level = iq->noise + iq->qual;
+ iq->updated = 7;
+}
+
+
+int
+ar6000_ioctl_siwcommit(struct net_device *dev,
+ struct iw_request_info *info,
+ struct iw_point *data, char *extra)
+{
+
+ AR_SOFTC_DEV_T *arPriv = (AR_SOFTC_DEV_T *)ar6k_priv(dev);
+ AR_SOFTC_T *ar = arPriv->arSoftc;
+ A_STATUS status = A_OK;
+ int ret = 0;
+
+ if (is_iwioctl_allowed(arPriv->arNextMode, info->cmd) != A_OK) {
+ AR_DEBUG_PRINTF(ATH_DEBUG_ERR,("wext_ioctl: cmd=0x%x not allowed in this mode\n", info->cmd));
+ return -EOPNOTSUPP;
+ }
+
+ if (ar->arWmiReady == FALSE) {
+ return -EIO;
+ }
+
+ if (ar->arWlanState == WLAN_DISABLED) {
+ return -EIO;
+ }
+
+ if (down_interruptible(&ar->arSem)) {
+ return -ERESTARTSYS;
+ }
+
+ if (ar->bIsDestroyProgress || ar->arWlanState == WLAN_DISABLED) {
+ up(&ar->arSem);
+ return -EBUSY;
+ }
+
+ AR_DEBUG_PRINTF(ATH_DEBUG_WLAN_CONNECT,("AP: SSID %s freq %d authmode %d dot11 auth %d"\
+ " PW crypto %d GRP crypto %d\n",
+ arPriv->arSsid, arPriv->arChannelHint,
+ arPriv->arAuthMode, arPriv->arDot11AuthMode,
+ arPriv->arPairwiseCrypto, arPriv->arGroupCrypto));
+
+ /* Stop getting pkts from upper stack */
+ netif_stop_queue(arPriv->arNetDev);
+ /* Flush the Tx queues */
+ ar6000_TxDataCleanup(ar);
+ /* Start getting pkts from upper stack */
+ netif_wake_queue(arPriv->arNetDev);
+
+ status = ar6000_check_connect_request(arPriv, TRUE);
+ if(A_OK == status)
+ ret = ar6000_ap_mode_profile_commit(arPriv);
+ else if(A_ERROR == status)
+ ret = -EINVAL;
+
+ up(&ar->arSem);
+ return ret;
+}
+
+#define W_PROTO(_x) wait_ ## _x
+#define WAIT_HANDLER_IMPL(_x, type) \
+int wait_ ## _x (struct net_device *dev, struct iw_request_info *info, type wrqu, char *extra) {\
+ int ret; \
+ dev_hold(dev); \
+ ret = _x(dev, info, wrqu, extra); \
+ dev_put(dev); \
+ return ret;\
+}
+
+WAIT_HANDLER_IMPL(ar6000_ioctl_siwessid, struct iw_point *)
+WAIT_HANDLER_IMPL(ar6000_ioctl_giwrate, struct iw_param *)
+WAIT_HANDLER_IMPL(ar6000_ioctl_giwtxpow, struct iw_param *)
+WAIT_HANDLER_IMPL(ar6000_ioctl_giwrange, struct iw_point*)
+
+/* Structures to export the Wireless Handlers */
+static const iw_handler ath_handlers[] = {
+ (iw_handler) ar6000_ioctl_siwcommit, /* SIOCSIWCOMMIT */
+ (iw_handler) ar6000_ioctl_giwname, /* SIOCGIWNAME */
+ (iw_handler) NULL, /* SIOCSIWNWID */
+ (iw_handler) NULL, /* SIOCGIWNWID */
+ (iw_handler) ar6000_ioctl_siwfreq, /* SIOCSIWFREQ */
+ (iw_handler) ar6000_ioctl_giwfreq, /* SIOCGIWFREQ */
+ (iw_handler) ar6000_ioctl_siwmode, /* SIOCSIWMODE */
+ (iw_handler) ar6000_ioctl_giwmode, /* SIOCGIWMODE */
+ (iw_handler) ar6000_ioctl_siwsens, /* SIOCSIWSENS */
+ (iw_handler) ar6000_ioctl_giwsens, /* SIOCGIWSENS */
+ (iw_handler) NULL /* not _used */, /* SIOCSIWRANGE */
+ (iw_handler) W_PROTO(ar6000_ioctl_giwrange),/* SIOCGIWRANGE */
+ (iw_handler) ar6000_ioctl_siwpriv, /* SIOCSIWPRIV */
+ (iw_handler) NULL /* kernel code */, /* SIOCGIWPRIV */
+ (iw_handler) NULL /* not used */, /* SIOCSIWSTATS */
+ (iw_handler) NULL /* kernel code */, /* SIOCGIWSTATS */
+ (iw_handler) NULL, /* SIOCSIWSPY */
+ (iw_handler) NULL, /* SIOCGIWSPY */
+ (iw_handler) NULL, /* SIOCSIWTHRSPY */
+ (iw_handler) NULL, /* SIOCGIWTHRSPY */
+ (iw_handler) ar6000_ioctl_siwap, /* SIOCSIWAP */
+ (iw_handler) ar6000_ioctl_giwap, /* SIOCGIWAP */
+#if (WIRELESS_EXT >= 18)
+ (iw_handler) ar6000_ioctl_siwmlme, /* SIOCSIWMLME */
+#else
+ (iw_handler) NULL, /* -- hole -- */
+#endif /* WIRELESS_EXT >= 18 */
+ (iw_handler) ar6000_ioctl_iwaplist, /* SIOCGIWAPLIST */
+ (iw_handler) ar6000_ioctl_siwscan, /* SIOCSIWSCAN */
+ (iw_handler) ar6000_ioctl_giwscan, /* SIOCGIWSCAN */
+ (iw_handler) W_PROTO(ar6000_ioctl_siwessid),/* SIOCSIWESSID */
+ (iw_handler) ar6000_ioctl_giwessid, /* SIOCGIWESSID */
+ (iw_handler) NULL, /* SIOCSIWNICKN */
+ (iw_handler) NULL, /* SIOCGIWNICKN */
+ (iw_handler) NULL, /* -- hole -- */
+ (iw_handler) NULL, /* -- hole -- */
+ (iw_handler) ar6000_ioctl_siwrate, /* SIOCSIWRATE */
+ (iw_handler) W_PROTO(ar6000_ioctl_giwrate), /* SIOCGIWRATE */
+ (iw_handler) NULL, /* SIOCSIWRTS */
+ (iw_handler) NULL, /* SIOCGIWRTS */
+ (iw_handler) NULL, /* SIOCSIWFRAG */
+ (iw_handler) NULL, /* SIOCGIWFRAG */
+ (iw_handler) ar6000_ioctl_siwtxpow, /* SIOCSIWTXPOW */
+ (iw_handler) W_PROTO(ar6000_ioctl_giwtxpow),/* SIOCGIWTXPOW */
+ (iw_handler) ar6000_ioctl_siwretry, /* SIOCSIWRETRY */
+ (iw_handler) ar6000_ioctl_giwretry, /* SIOCGIWRETRY */
+ (iw_handler) ar6000_ioctl_siwencode, /* SIOCSIWENCODE */
+ (iw_handler) ar6000_ioctl_giwencode, /* SIOCGIWENCODE */
+#if WIRELESS_EXT > 20
+ (iw_handler) ar6000_ioctl_siwpower, /* SIOCSIWPOWER */
+ (iw_handler) ar6000_ioctl_giwpower, /* SIOCGIWPOWER */
+#endif // WIRELESS_EXT > 20
+#if WIRELESS_EXT >= 18
+ (iw_handler) NULL, /* -- hole -- */
+ (iw_handler) NULL, /* -- hole -- */
+ (iw_handler) ar6000_ioctl_siwgenie, /* SIOCSIWGENIE */
+ (iw_handler) ar6000_ioctl_giwgenie, /* SIOCGIWGENIE */
+ (iw_handler) ar6000_ioctl_siwauth, /* SIOCSIWAUTH */
+ (iw_handler) ar6000_ioctl_giwauth, /* SIOCGIWAUTH */
+ (iw_handler) ar6000_ioctl_siwencodeext, /* SIOCSIWENCODEEXT */
+ (iw_handler) ar6000_ioctl_giwencodeext, /* SIOCGIWENCODEEXT */
+ (iw_handler) ar6000_ioctl_siwpmksa, /* SIOCSIWPMKSA */
+#endif // WIRELESS_EXT >= 18
+};
+
+struct iw_handler_def ath_iw_handler_def = {
+ .standard = (iw_handler *)ath_handlers,
+ .num_standard = ARRAY_SIZE(ath_handlers),
+ .private = NULL,
+ .num_private = 0,
+};
diff --git a/host/tools/dbgParser/COPYING b/host/tools/dbgParser/COPYING
new file mode 100644
index 0000000..ee0d2e3
--- /dev/null
+++ b/host/tools/dbgParser/COPYING
@@ -0,0 +1,14 @@
+Copyright (c) 2006 Atheros Communications Inc.
+All rights reserved.
+
+Permission to use, copy, modify, and/or distribute this software for any
+purpose with or without fee is hereby granted, provided that the above
+copyright notice and this permission notice appear in all copies.
+
+THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
diff --git a/host/tools/dbgParser/Makefile b/host/tools/dbgParser/Makefile
new file mode 100644
index 0000000..944600e
--- /dev/null
+++ b/host/tools/dbgParser/Makefile
@@ -0,0 +1,17 @@
+CC := $(ATH_CROSS_COMPILE_TYPE)gcc
+KERNEL_SRC :=$(ATH_LINUXPATH)
+
+PREFIX ?= /usr
+SBINDIR ?= $(PREFIX)/sbin
+INSTALL ?= install
+
+override CFLAGS += -Wall -I./ -I../../include -I../../../include -I../../wlan/include -I../../os/linux/include
+
+dbgParser: dbgFormatter.c dbgParser.c
+ $(CC) $(CFLAGS) -o $@ $^ $(LDLIBS)
+
+install: dbgParser
+ install -m 755 dbgParser $(DESTDIR)$(SBINDIR)
+
+clean:
+ rm -f dbgParser
diff --git a/host/tools/dbgParser/dbgFormatter.c b/host/tools/dbgParser/dbgFormatter.c
new file mode 100644
index 0000000..36794ac
--- /dev/null
+++ b/host/tools/dbgParser/dbgFormatter.c
@@ -0,0 +1,1827 @@
+//
+// Copyright (c) 2006 Atheros Communications Inc.
+// All rights reserved.
+//
+//
+//
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+//
+//
+
+/* This tool parses the recevent logs stored in the binary format
+ by the wince athsrc */
+#define WAPI_ENABLE
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+#include <time.h>
+#include <a_config.h>
+#include <a_osapi.h>
+#include <a_types.h>
+#include <athdefs.h>
+#include <ieee80211.h>
+#include <wmi.h>
+#include <athdrv_linux.h>
+#include <dbglog_api.h>
+#include <dbglog_id.h>
+
+#include "dbg_cmd_evt.h"
+
+typedef int (*DbgCmdFormatter)(char *output, size_t len, const A_UINT8 *);
+typedef int (*DbgLogFormatter)(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer);
+
+struct dbglog_desc {
+ A_INT32 oid;
+ const char *desc;
+ DbgLogFormatter formatter;
+};
+
+struct module_desc {
+ int module;
+ const char *name;
+ struct dbglog_desc *descs;
+ size_t len;
+ int bsearch;
+};
+
+struct wmi_id_desc {
+ A_INT32 oid;
+ const char *desc;
+ DbgCmdFormatter formatter;
+ size_t cmdSize;
+};
+
+#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0]))
+#define CASE_STR_CONST(_s, _n, _val) case _n: (_val) = #_s; break
+#define CASE_STR(_x, _val) case _x: (_val) = #_x; break
+#define CASE_DEF_STR(_val) default: (_val) = "Unknown"; break
+#define BIT_STR(_b, _l, _r, _s, _c, _v) if (((_v) & (_c)) == (_c)) (_r) += snprintf((_b)+(_r), (_l)-(_r), _s)
+
+#define DBG_DESC(_x) { _x, #_x, NULL }
+#define DBG_DESC_FMT(_x) { _x, #_x, _x ## _fmt }
+
+#define WM_ID_DESC(_x) { _x, #_x, NULL, 0 }
+#define WM_ID_DESC_FMT(_x, s) { _x, #_x, _x ## _fmt, s }
+
+#define MODULE_DESC(_x, _d) { DBGLOG_MODULEID_ ## _x, #_x, _d, ARRAY_SIZE(_d),0}
+
+extern A_CHAR dbglog_id_tag[DBGLOG_MODULEID_NUM_MAX][DBGLOG_DBGID_NUM_MAX][DBGLOG_DBGID_DEFINITION_LEN_MAX];
+static int check_ids;
+
+static const char *pmmode2text(A_INT32 mode)
+{
+ const char *pm;
+ switch (mode) {
+ case 1: pm = "sleep"; break;
+ case 2: pm = "awake"; break;
+ case 3: pm = "fake_sleep"; break;
+ default: pm = "unknown"; break;
+ }
+ return pm;
+}
+
+#if 0
+static const char *module2text(A_INT32 moduleid)
+{
+ const char *msg;
+ switch (moduleid) {
+ CASE_STR_CONST(INF, DBGLOG_MODULEID_INF, msg);
+ CASE_STR_CONST(WMI, DBGLOG_MODULEID_WMI, msg);
+ CASE_STR_CONST(MISC, DBGLOG_MODULEID_MISC, msg);
+ CASE_STR_CONST(PM, DBGLOG_MODULEID_PM, msg);
+ CASE_STR_CONST(MGMTBUF, DBGLOG_MODULEID_TXRX_MGMTBUF, msg);
+ CASE_STR_CONST(TXBUF, DBGLOG_MODULEID_TXRX_TXBUF, msg);
+ CASE_STR_CONST(RXBUF, DBGLOG_MODULEID_TXRX_RXBUF, msg);
+ CASE_STR_CONST(WOW, DBGLOG_MODULEID_WOW, msg);
+ CASE_STR_CONST(WHAL, DBGLOG_MODULEID_WHAL, msg);
+ CASE_STR_CONST(DC, DBGLOG_MODULEID_DC, msg);
+ CASE_STR_CONST(CO, DBGLOG_MODULEID_CO, msg);
+ CASE_STR_CONST(RO, DBGLOG_MODULEID_RO, msg);
+ CASE_STR_CONST(CM, DBGLOG_MODULEID_CM, msg);
+ CASE_STR_CONST(MGMT, DBGLOG_MODULEID_MGMT, msg);
+ CASE_STR_CONST(TMR, DBGLOG_MODULEID_TMR, msg);
+ CASE_STR_CONST(BTCOEX, DBGLOG_MODULEID_BTCOEX, msg);
+ CASE_DEF_STR(msg);
+ }
+ return msg;
+}
+#endif
+
+static const char *pmmodule2text(A_INT32 moduleid)
+{
+ const char *msg;
+ switch (moduleid) {
+ CASE_STR_CONST(CSERV, 1, msg);
+ CASE_STR_CONST(MLME , 2, msg);
+ CASE_STR_CONST(TXRX , 3, msg);
+ CASE_STR_CONST(PM , 4, msg);
+ CASE_STR_CONST(BT_COEX, 5, msg);
+ CASE_STR_CONST(CO , 6, msg);
+ CASE_STR_CONST(DC , 7, msg);
+ CASE_STR_CONST(RO , 8, msg);
+ CASE_STR_CONST(CM , 9, msg);
+ CASE_STR_CONST(RRM , 10, msg);
+ CASE_STR_CONST(AP , 11, msg);
+ CASE_STR_CONST(KEYMGMT, 12, msg);
+ CASE_STR_CONST(CCX , 13, msg);
+ CASE_STR_CONST(MISC , 14, msg);
+ CASE_STR_CONST(DFS , 15, msg);
+ CASE_STR_CONST(TIMER , 16, msg);
+ CASE_DEF_STR(msg);
+ }
+ return msg;
+}
+
+static const char *status2text(A_STATUS status)
+{
+ const char *msg;
+ switch (status) {
+ CASE_STR(A_ERROR, msg);
+ CASE_STR(A_OK, msg); /* success */
+ /* Following values start at 1 */
+ CASE_STR(A_DEVICE_NOT_FOUND, msg); /* not able to find PCI device */
+ CASE_STR(A_NO_MEMORY, msg); /* not able to allocate memory, msg); not available */
+ CASE_STR(A_MEMORY_NOT_AVAIL, msg); /* memory region is not free for mapping */
+ CASE_STR(A_NO_FREE_DESC, msg); /* no free descriptors available */
+ CASE_STR(A_BAD_ADDRESS, msg); /* address does not match descriptor */
+ CASE_STR(A_WIN_DRIVER_ERROR, msg); /* used in NT_HW version, msg); if problem at init */
+ CASE_STR(A_REGS_NOT_MAPPED, msg); /* registers not correctly mapped */
+ CASE_STR(A_EPERM, msg); /* Not superuser */
+ CASE_STR(A_EACCES, msg); /* Access denied */
+ CASE_STR(A_ENOENT, msg); /* No such entry, msg); search failed, msg); etc. */
+ CASE_STR(A_EEXIST, msg); /* The object already exists (can't create) */
+ CASE_STR(A_EFAULT, msg); /* Bad address fault */
+ CASE_STR(A_EBUSY, msg); /* Object is busy */
+ CASE_STR(A_EINVAL, msg); /* Invalid parameter */
+ CASE_STR(A_EMSGSIZE, msg); /* Inappropriate message buffer length */
+ CASE_STR(A_ECANCELED, msg); /* Operation canceled */
+ CASE_STR(A_ENOTSUP, msg); /* Operation not supported */
+ CASE_STR(A_ECOMM, msg); /* Communication error on send */
+ CASE_STR(A_EPROTO, msg); /* Protocol error */
+ CASE_STR(A_ENODEV, msg); /* No such device */
+ CASE_STR(A_EDEVNOTUP, msg); /* device is not UP */
+ CASE_STR(A_NO_RESOURCE, msg); /* No resources for requested operation */
+ CASE_STR(A_HARDWARE, msg); /* Hardware failure */
+ CASE_STR(A_PENDING, msg); /* Asynchronous routine; will send up results la
+ter (typically in callback) */
+ CASE_STR(A_EBADCHANNEL, msg); /* The channel cannot be used */
+ CASE_STR(A_DECRYPT_ERROR, msg); /* Decryption error */
+ CASE_STR(A_PHY_ERROR, msg); /* RX PHY error */
+ CASE_STR(A_CONSUMED, msg); /* Object was consumed */
+ CASE_DEF_STR(msg);
+ }
+ return msg;
+}
+
+static const char *btStatus2text(A_INT32 status)
+{
+ const char *btState;
+ switch (status) {
+ CASE_STR_CONST(BT_UNDEF, 1, btState);
+ CASE_STR_CONST(BT_ON, 2, btState);
+ CASE_STR_CONST(BT_OFF, 3, btState);
+ CASE_STR_CONST(BT_IGNORE, 4, btState);
+ CASE_DEF_STR(btState);
+ }
+ return btState;
+}
+
+static int cipher2text(char *buf, size_t len, A_UINT8 cipher)
+{
+ int ret = 0;
+ BIT_STR(buf, len, ret, "none ", NONE_CRYPT, cipher);
+ BIT_STR(buf, len, ret, "wep ", WEP_CRYPT, cipher);
+ BIT_STR(buf, len, ret, "tkip ", TKIP_CRYPT, cipher);
+ BIT_STR(buf, len, ret, "aes ", AES_CRYPT, cipher);
+ buf[(ret>0) ? --ret : ret] = 0;
+ return ret;
+}
+
+static const char* enable2text(A_INT32 enable)
+{
+ return enable ? "ENABLE" : "DISABLE";
+}
+
+static const char* txrxstatus2text(A_INT32 status)
+{
+ const char *txstatus;
+ switch (status) {
+ CASE_STR_CONST(TXRX_ERROR, -1, txstatus);
+ CASE_STR_CONST(TXRX_OK , 0, txstatus);
+ CASE_STR_CONST(TXRX_FAILED , 1, txstatus);
+ CASE_STR_CONST(TXRX_Q_IS_EMPTY , 2, txstatus);
+ CASE_STR_CONST(TXRX_Q_NOT_DRAINED , 3, txstatus);
+ CASE_STR_CONST(TXRX_Q_DRAINED_ALL , 4, txstatus);
+ CASE_STR_CONST(TXRX_Q_DRAIN_PENDING , 5, txstatus);
+ CASE_STR_CONST(TXRX_IS_MGMT_PKT , 6, txstatus);
+ CASE_STR_CONST(TXRX_IS_DATA_PKT , 7, txstatus);
+ CASE_STR_CONST(TXRX_SAVED_AS_FRAG , 8, txstatus);
+ CASE_STR_CONST(TXRX_Q_IS_PAUSED , 9, txstatus);
+ CASE_STR_CONST(TXRX_RX_SEND_TO_HOST , 10, txstatus);
+ CASE_STR_CONST(TXRX_ERROR_PKT_DRAINED , 11, txstatus);
+ CASE_STR_CONST(TXRX_EOL_EXPIRED , 12, txstatus);
+ CASE_STR_CONST(TXRX_PS_FILTERED , 13, txstatus);
+ CASE_STR_CONST(TXRX_RX_SEND_TO_TX , 14, txstatus);
+ CASE_DEF_STR(txstatus);
+ }
+ return txstatus;
+}
+
+static int rxfilter2text(char *buf, size_t blen, A_INT32 rxfilter)
+{
+ int ret = 0;
+ BIT_STR(buf, blen, ret, "UCAST " , 0x00000001, rxfilter);
+ BIT_STR(buf, blen, ret, "MCAST " , 0x00000002, rxfilter);
+ BIT_STR(buf, blen, ret, "BCAST " , 0x00000004, rxfilter);
+ BIT_STR(buf, blen, ret, "CONTROL " , 0x00000008, rxfilter);
+ BIT_STR(buf, blen, ret, "BEACON " , 0x00000010, rxfilter);
+ BIT_STR(buf, blen, ret, "PROM " , 0x00000020, rxfilter);
+ BIT_STR(buf, blen, ret, "PROBEREQ ", 0x00000080, rxfilter);
+ BIT_STR(buf, blen, ret, "MYBEACON ", 0x00000200, rxfilter);
+ BIT_STR(buf, blen, ret, "COMP_BAR ", 0x00000400, rxfilter);
+ BIT_STR(buf, blen, ret, "COMP_BA " , 0x00000800, rxfilter);
+ BIT_STR(buf, blen, ret, "UNCOMP_BA_BAR " , 0x00001000, rxfilter);
+ BIT_STR(buf, blen, ret, "PS_POLL " , 0x00004000, rxfilter);
+ BIT_STR(buf, blen, ret, "MCAST_BCAST_ALL " , 0x00008000, rxfilter);
+ BIT_STR(buf, blen, ret, "FROM_TO_DS " , 0x00020000, rxfilter);
+ buf[(ret>0) ? --ret : ret] = 0;
+ return ret;
+}
+
+static int btState2text(char *buf, size_t blen, A_INT32 btState)
+{
+ int bret = 0;
+ BIT_STR(buf, blen, bret, "SCO ", (1<<1), btState);
+ BIT_STR(buf, blen, bret, "A2DP ", (1<<2), btState);
+ BIT_STR(buf, blen, bret, "SCAN ", (1<<3), btState);
+ BIT_STR(buf, blen, bret, "ESCO ", (1<<4), btState);
+ buf[(bret>0) ? --bret : bret] = 0;
+ return bret;
+}
+
+static int btcoexFlags2text(char *buf, size_t blen, A_INT32 btCoexFlags)
+{
+ int bret = 0;
+ BIT_STR(buf, blen, bret, "SCO_ON ", 0x0001, btCoexFlags);
+ BIT_STR(buf, blen, bret, "A2DP_ON ", 0x0002, btCoexFlags);
+ BIT_STR(buf, blen, bret, "ACL_ON ", 0x0004, btCoexFlags);
+ BIT_STR(buf, blen, bret, "INQUIRY_ON ", 0x0008, btCoexFlags);
+ BIT_STR(buf, blen, bret, "VOIP ", 0x0010, btCoexFlags);
+ BIT_STR(buf, blen, bret, "RXDATA_PENDING ", 0x0020, btCoexFlags);
+ BIT_STR(buf, blen, bret, "SLEEP_PENDING ", 0x0040, btCoexFlags);
+ BIT_STR(buf, blen, bret, "FAKESLEEP_ON ", 0x0080, btCoexFlags);
+ BIT_STR(buf, blen, bret, "ADD_BA_PENDING ", 0x0100, btCoexFlags);
+ BIT_STR(buf, blen, bret, "WAKEUP_TIM_INTR ", 0x0200, btCoexFlags);
+ BIT_STR(buf, blen, bret, "OPT_MODE ", 0x0400, btCoexFlags);
+ BIT_STR(buf, blen, bret, "FIRST_BMISS ", 0x0800, btCoexFlags);
+ BIT_STR(buf, blen, bret, "BEACON_PROTECION_ON ", 0x1000, btCoexFlags);
+ BIT_STR(buf, blen, bret, "WAIT_FOR_NULL_COMP ", 0x4000, btCoexFlags);
+ BIT_STR(buf, blen, bret, "PROTECT_POST_INQUIRY ", 0x8000, btCoexFlags);
+ BIT_STR(buf, blen, bret, "DUAL_ANT_ACTIVE ", 0x10000, btCoexFlags);
+ BIT_STR(buf, blen, bret, "DUAL_ANT_WAKEUP_TIM ", 0x20000, btCoexFlags);
+ BIT_STR(buf, blen, bret, "STOMP_FOR_DTIM_RECV ", 0x40000, btCoexFlags);
+ BIT_STR(buf, blen, bret, "ENABLE_COEX_ON_BCN_RECV ", 0x80000, btCoexFlags);
+ buf[(bret>0) ? --bret : bret] = 0;
+ return bret;
+}
+
+static int WMI_SET_MCAST_FILTER_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_SET_MCAST_FILTER_CMD *cmd = (WMI_SET_MCAST_FILTER_CMD*)cmdbuf;
+ return snprintf(output, len, "%02X:%02X:%02X:%02X:%02X:%02X",
+ cmd->multicast_mac[0], cmd->multicast_mac[1], cmd->multicast_mac[2],
+ cmd->multicast_mac[3], cmd->multicast_mac[4], cmd->multicast_mac[5]);
+}
+
+static int WMI_DEL_MCAST_FILTER_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ return WMI_SET_MCAST_FILTER_CMDID_fmt(output, len, cmdbuf);
+}
+
+static int WMI_MCAST_FILTER_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_MCAST_FILTER_CMD *cmd = (WMI_MCAST_FILTER_CMD*)cmdbuf;
+ return snprintf(output, len, "%s", enable2text(cmd->enable));
+}
+
+static int WMI_START_SCAN_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ int i;
+ int ret = 0;
+ WMI_START_SCAN_CMD *cmd = (WMI_START_SCAN_CMD*)cmdbuf;
+ const char *scanType = (cmd->scanType == WMI_SHORT_SCAN) ? "short" : "long";
+ if (cmd->forceFgScan) {
+ ret += snprintf(output+ret, len-ret, "forceFg ");
+ }
+ ret += snprintf(output+ret, len-ret, "hmdwell %u ", cmd->homeDwellTime);
+ ret += snprintf(output+ret, len-ret, "fscanint %u ", cmd->forceScanInterval);
+ ret += snprintf(output+ret, len-ret, "%s ", scanType);
+ for (i=0; i<cmd->numChannels; ++i) {
+ ret += snprintf(output+ret, len-ret, "%d ", cmd->channelList[i]);
+ }
+ return ret;
+}
+
+static int WMI_CONNECT_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_CONNECT_CMD *cmd = (WMI_CONNECT_CMD*)cmdbuf;
+ char ssid[33];
+ char pairwise[128], group[128];
+ const char *dot11Auth, *authMode;
+ memcpy(ssid, cmd->ssid, 32);
+ ssid[cmd->ssidLength] = 0;
+ cipher2text(pairwise, sizeof(pairwise), cmd->pairwiseCryptoType);
+ cipher2text(group, sizeof(group), cmd->groupCryptoType);
+
+ switch (cmd->dot11AuthMode) {
+ CASE_STR(OPEN_AUTH, dot11Auth);
+ CASE_STR(SHARED_AUTH, dot11Auth);
+ CASE_STR(LEAP_AUTH, dot11Auth);
+ CASE_DEF_STR(dot11Auth);
+ }
+
+ switch (cmd->authMode) {
+ CASE_STR(WMI_NONE_AUTH, authMode);
+ CASE_STR(WMI_WPA_AUTH, authMode);
+ CASE_STR(WMI_WPA2_AUTH, authMode);
+ CASE_STR(WMI_WPA_PSK_AUTH, authMode);
+ CASE_STR(WMI_WPA2_PSK_AUTH, authMode);
+ CASE_STR(WMI_WPA_AUTH_CCKM, authMode);
+ CASE_STR(WMI_WPA2_AUTH_CCKM, authMode);
+ CASE_DEF_STR(authMode);
+ }
+ return snprintf(output, len, "'%s' ch %d %s %s uni:%s grp:%s %02X:%02X:%02X:%02X:%02X:%02X ctrl 0x%x",
+ ssid, cmd->channel,
+ dot11Auth, authMode, pairwise, group,
+ cmd->bssid[0], cmd->bssid[1], cmd->bssid[2],
+ cmd->bssid[3], cmd->bssid[4], cmd->bssid[5],
+ cmd->ctrl_flags);
+}
+
+static int WMI_SET_BTCOEX_FE_ANT_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_SET_BTCOEX_FE_ANT_CMD *cmd = (WMI_SET_BTCOEX_FE_ANT_CMD*)cmdbuf;
+ const char *fe;
+ switch (cmd->btcoexFeAntType) {
+ CASE_STR(WMI_BTCOEX_NOT_ENABLED, fe);
+ CASE_STR(WMI_BTCOEX_FE_ANT_SINGLE, fe);
+ CASE_STR(WMI_BTCOEX_FE_ANT_DUAL, fe);
+ CASE_STR(WMI_BTCOEX_FE_ANT_DUAL_HIGH_ISO, fe);
+ CASE_DEF_STR(fe);
+ }
+ return snprintf(output, len, "%s", fe);
+}
+
+static int WMI_SET_BTCOEX_SCO_CONFIG_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_SET_BTCOEX_SCO_CONFIG_CMD *cmd = (WMI_SET_BTCOEX_SCO_CONFIG_CMD*)cmdbuf;
+ char scoFlags[512];
+ int blen = sizeof(scoFlags);
+ int bret = 0;
+ BIT_STR(scoFlags, blen, bret, "OPT ", (1<<0), cmd->scoConfig.scoFlags);
+ BIT_STR(scoFlags, blen, bret, "EDR ", (1<<1), cmd->scoConfig.scoFlags);
+ BIT_STR(scoFlags, blen, bret, "MASTER ", (1<<2), cmd->scoConfig.scoFlags);
+ BIT_STR(scoFlags, blen, bret, "FRM ", (1<<3), cmd->scoConfig.scoFlags);
+ scoFlags[(bret>0) ? --bret : bret] = 0;
+
+ return snprintf(output, len, "%d/%d slots [%s] ps %u-%u-%u opt %u-%u-%u-%u-%u-%u scan %u/%u",
+ cmd->scoConfig.scoSlots, cmd->scoConfig.scoIdleSlots, scoFlags,
+
+ cmd->scoPspollConfig.scoCyclesForceTrigger,
+ cmd->scoPspollConfig.scoDataResponseTimeout,
+ cmd->scoPspollConfig.scoPsPollLatencyFraction,
+
+ cmd->scoOptModeConfig.scoStompCntIn100ms,
+ cmd->scoOptModeConfig.scoContStompMax,
+ cmd->scoOptModeConfig.scoMinlowRateMbps,
+ cmd->scoOptModeConfig.scoLowRateCnt,
+ cmd->scoOptModeConfig.scoHighPktRatio,
+ cmd->scoOptModeConfig.scoMaxAggrSize,
+
+ cmd->scoWlanScanConfig.scanInterval,
+ cmd->scoWlanScanConfig.maxScanStompCnt);
+}
+
+static int WMI_SET_BTCOEX_A2DP_CONFIG_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ return 0;
+}
+
+static int WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ return 0;
+}
+
+static int WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD *cmd = (WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD*)cmdbuf;
+ return snprintf(output, len, "pspoll every %u inquiry duration %u",
+ cmd->btInquiryDataFetchFrequency,
+ cmd->protectBmissDurPostBtInquiry);
+}
+
+static int WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD *cmd = (WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD*)cmdbuf;
+ const char *profile;
+ const char *op = (cmd->btOperatingStatus==1) ? "START" : "STOP";
+ switch (cmd->btProfileType) {
+ CASE_STR_CONST(SCO, 1, profile);
+ CASE_STR_CONST(A2DP, 2, profile);
+ CASE_STR_CONST(Inquiry, 3, profile);
+ CASE_STR_CONST(ACL, 4, profile);
+ CASE_DEF_STR(profile);
+ }
+ return snprintf(output, len, "%s %s", profile, op);
+}
+
+static int WMI_SET_LISTEN_INT_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_LISTEN_INT_CMD *cmd = (WMI_LISTEN_INT_CMD*)cmdbuf;
+ return snprintf(output, len, "interval %d numBeacons %d", cmd->listenInterval, cmd->numBeacons);
+}
+
+static int WMI_SET_BSS_FILTER_CMDID_fmt(char *output, size_t len, const A_UINT8 *cmdbuf)
+{
+ WMI_BSS_FILTER_CMD *cmd = (WMI_BSS_FILTER_CMD*)cmdbuf;
+ const char *filter;
+ switch (cmd->bssFilter) {
+ CASE_STR(NONE_BSS_FILTER, filter);
+ CASE_STR(ALL_BSS_FILTER, filter);
+ CASE_STR(PROFILE_FILTER, filter);
+ CASE_STR(ALL_BUT_PROFILE_FILTER, filter);
+ CASE_STR(CURRENT_BSS_FILTER, filter);
+ CASE_STR(ALL_BUT_BSS_FILTER, filter);
+ CASE_STR(PROBED_SSID_FILTER, filter);
+ CASE_STR(LAST_BSS_FILTER, filter);
+ CASE_DEF_STR(filter);
+ }
+ return snprintf(output, len, "[%s]", filter);
+}
+
+static int CO_CHANGE_CHANNEL_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 freq = buffer[1];
+ A_INT32 duration = buffer[2];
+ return snprintf(output, len, "freq %d duration %d", freq, duration);
+}
+
+static int CO_CHANGE_STATE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 stateLog = (numargs==1) ? buffer[1] : buffer[2];
+ int op = stateLog & 0xff;
+ const char *opstr = op ? "set" : "clr";
+ int opState = (stateLog >> 8) & 0xff;
+ int oldState = stateLog >> 16;
+ int newState = (op) ? (oldState | opState) : (oldState & ~(opState));
+ char state[256];
+ size_t blen = sizeof(state);
+ int ret = 0;
+ BIT_STR(state, blen, ret, "DRAIN_IN_PROGRESS ", 0x01, newState);
+ BIT_STR(state, blen, ret, "FAKE_SLEEP_ENABLE_IN_PROGRESS ", 0x02, newState);
+ BIT_STR(state, blen, ret, "FAKE_SLEEP_ENABLED ", 0x04, newState);
+ BIT_STR(state, blen, ret, "TXQ_PAUSED ", 0x08, newState);
+ BIT_STR(state, blen, ret, "CHANNEL_CHANGE_IN_PROGRESS ", 0x10, newState);
+ state[(ret>0) ? --ret : ret] = 0;
+
+ ret = 0;
+ if (numargs==2) {
+ ret = snprintf(output+ret, len-ret, "dev %d ", buffer[1]);
+ }
+ ret += snprintf(output+ret, len-ret, "0x%x %s 0x%x->0x%x [%s]",
+ oldState, opstr, opState, newState, state);
+ return ret;
+}
+
+static int TXRX_MGMTBUF_WLAN_RESET_ON_ERROR_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ if (numargs==1) {
+ char buf[512];
+ A_INT32 rxfilter = buffer[1];
+ rxfilter2text(buf, sizeof(buf),rxfilter);
+ return snprintf(output, len, "rxfilter:[%s]", buf);
+ } else if (numargs==2) {
+ return snprintf(output, len, "rstCnt %d caller %p",
+ buffer[1], (void*)buffer[2]);
+ } else {
+ return 0;
+ }
+}
+static int TXRX_MGMTBUF_WAIT_FOR_TXQ_DRAIN_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *mid;
+ switch (buffer[2]) {
+ CASE_STR_CONST(CO, 0x001, mid);
+ CASE_STR_CONST(PM, 0x002, mid);
+ CASE_STR_CONST(BTCOEX, 0x004, mid);
+ CASE_DEF_STR(mid);
+ }
+ return snprintf(output, len, "wait drain %d ms %s ", buffer[1], mid);
+}
+
+static int TXRX_MGMTBUF_REAPED_BUF_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *txstatus = txrxstatus2text(buffer[2]);
+ return snprintf(output, len, "mgt %p %s", (void*)buffer[1], txstatus);
+}
+
+static int TXRX_MGMTBUF_DRAINQ_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 hwq = buffer[1];
+ A_INT32 depth = buffer[2];
+ return snprintf(output, len, "hwq 0x%x depth 0x%x", hwq, depth);
+}
+
+static int DC_RECEIVED_ANY_BEACON_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ if (numargs==1) {
+ A_INT32 addr3 = buffer[1];
+ return snprintf(output, len, "addr3 ??:??:%02X:%02X:%02X:%02X",
+ (addr3 & 0xff), ((addr3>>8)&0xff), ((addr3>>16)&0xff), ((addr3>>24)&0xff));
+ } else if (numargs==2) {
+ A_UINT64 tsf;
+ A_UINT8 ie_tstamp[8];
+ ie_tstamp[4] = buffer[1] & 0xff;
+ ie_tstamp[5] = (buffer[1]>>8) & 0xff;
+ ie_tstamp[6] = (buffer[1]>>16) & 0xff;
+ ie_tstamp[7] = (buffer[1]>>24) & 0xff;
+ ie_tstamp[0] = buffer[2] & 0xff;
+ ie_tstamp[1] = (buffer[2]>>8) & 0xff;
+ ie_tstamp[2] = (buffer[2]>>16) & 0xff;
+ ie_tstamp[3] = (buffer[2]>>24) & 0xff;
+ A_MEMCPY((A_UINT8 *)&tsf, ie_tstamp, sizeof(ie_tstamp));
+ return snprintf(output, len, "ie_tsf %llu", tsf);
+ }
+ return 0;
+}
+
+static int DC_SET_POWER_MODE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *pm = pmmode2text(buffer[1]);
+ return snprintf(output, len, "%s caller %p", pm, (void*)buffer[2]);
+}
+
+static int DC_SSID_PROBE_CB_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *txstatus = txrxstatus2text(buffer[1]);
+ return snprintf(output, len, "%s", txstatus);
+}
+
+static int DC_SEARCH_OPPORTUNITY_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *opt;
+ switch (buffer[1]) {
+ CASE_STR_CONST(SCAN_IN_PROGRESS, 1, opt);
+ CASE_STR_CONST(NOT_SCAN_IN_PROGRESS, 0, opt);
+ CASE_DEF_STR(opt);
+ }
+ return snprintf(output, len, "%s", opt);
+}
+
+static int DC_SEND_NEXT_SSID_PROBE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *flags;
+ switch (buffer[2]) {
+ CASE_STR(DISABLE_SSID_FLAG, flags);
+ CASE_STR(SPECIFIC_SSID_FLAG, flags);
+ CASE_STR(ANY_SSID_FLAG, flags);
+ CASE_DEF_STR(flags);
+ }
+ return snprintf(output, len, "idx %d %s", buffer[1], flags);
+}
+
+static int DC_SCAN_CHAN_FINISH_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_UINT16 freq = buffer[1] & 0xffff;
+ A_UINT16 status = (buffer[1] >> 16) & 0xffff;
+ A_INT32 rxfilter = buffer[2];
+ char rxfilterMsg[1024];
+ rxfilter2text(rxfilterMsg, sizeof(rxfilterMsg), rxfilter);
+ return snprintf(output, len, "freq %d status %s(%d), %s",
+ freq, status2text(status), status, rxfilterMsg);
+}
+
+static int DC_SCAN_CHAN_START_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 rxfilter = buffer[2];
+ char rxfilterMsg[1024];
+ A_UINT16 freq;
+ A_UINT16 attrib;
+ const char *probed;
+ rxfilter2text(rxfilterMsg, sizeof(rxfilterMsg), rxfilter);
+ freq = buffer[1] & 0xffff;
+ attrib = (buffer[1] >> 16) & 0xffff;
+ probed = ((attrib & (0x0100|0x10))==(0x0100|0x10)) && !(attrib & 0x0800) ? "allow" : "not allow";
+
+ return snprintf(output, len, "freq %d attrib %d probed %s %s",
+ freq, attrib, probed, rxfilterMsg);
+}
+
+static int DC_START_SEARCH_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ if (numargs==1) {
+ return snprintf(output, len, "devid %d", buffer[1]);
+ } else {
+ A_INT32 stype = buffer[1];
+ int ret = 0;
+ char buf[1024];
+ size_t blen = sizeof(buf);
+ if (stype == 0) {
+ BIT_STR(buf, blen, ret, "RESET " , 0, stype);
+ }
+ BIT_STR(buf, blen, ret, "ALL " , (0x01|0x02|0x04|0x08), stype);
+ if (((0x01|0x02|0x04|0x08)& stype)!=(0x01|0x02|0x04|0x08)) {
+ BIT_STR(buf, blen, ret, "POPULAR " , (0x02 | 0x04 | 0x08), stype);
+ if (((0x02|0x04|0x08)& stype)!=(0x02|0x04|0x08)) {
+ BIT_STR(buf, blen, ret, "SSIDS " , (0x04 | 0x08), stype);
+ if (((0x04|0x08)& stype)!=(0x04|0x08)) {
+ BIT_STR(buf, blen, ret, "PROF_MASK " , (0x08), stype);
+ }
+ }
+ }
+
+ BIT_STR(buf, blen, ret, "MULTI_CHANNEL " , 0x000100, stype);
+ BIT_STR(buf, blen, ret, "DETERMINISTIC " , 0x000200, stype);
+ BIT_STR(buf, blen, ret, "PROFILE_MATCH_TERMINATED " , 0x000400, stype);
+ BIT_STR(buf, blen, ret, "HOME_CHANNEL_SKIP " , 0x000800, stype);
+ BIT_STR(buf, blen, ret, "CHANNEL_LIST_CONTINUE " , 0x001000, stype);
+ BIT_STR(buf, blen, ret, "CURRENT_SSID_SKIP " , 0x002000, stype);
+ BIT_STR(buf, blen, ret, "ACTIVE_PROBE_DISABLE " , 0x004000, stype);
+ BIT_STR(buf, blen, ret, "CHANNEL_HINT_ONLY " , 0x008000, stype);
+ BIT_STR(buf, blen, ret, "ACTIVE_CHANNELS_ONLY " , 0x010000, stype);
+ BIT_STR(buf, blen, ret, "UNUSED1 " , 0x020000, stype);
+ BIT_STR(buf, blen, ret, "PERIODIC " , 0x040000, stype);
+ BIT_STR(buf, blen, ret, "FIXED_DURATION " , 0x080000, stype);
+ BIT_STR(buf, blen, ret, "AP_ASSISTED " , 0x100000, stype);
+ buf[(ret>0) ? --ret : ret] = 0;
+ return snprintf(output, len, "%s cb 0x%x", buf, buffer[2]);
+ }
+}
+
+static int PM_CHAN_OP_REQ_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *start = (buffer[1]==1) ? "start" : "stop";
+ A_INT32 chanOpReq = buffer[2];
+ return snprintf(output, len, "%s chan OpReq %d", start, chanOpReq);
+}
+
+static int PM_SET_ALL_BEACON_POLICY_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *policyMsg;
+ A_UINT16 policy = buffer[1];
+ A_UINT32 cnt = buffer[2];
+ switch (policy) {
+ CASE_STR_CONST(disallow, 1, policyMsg);
+ CASE_STR_CONST(allow, 2, policyMsg);
+ CASE_DEF_STR(policyMsg);
+ }
+ return snprintf(output, len, "%s beacons filterCnt %d", policyMsg, cnt);
+}
+
+static int PM_SET_MY_BEACON_POLICY_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *policyMsg;
+ A_UINT16 policy = buffer[1] & 0xff;
+ A_UINT32 bMiss = (buffer[1] >> 8);
+ A_UINT32 myBeaconCnt = buffer[2];
+ switch (policy) {
+ CASE_STR_CONST(disallow, 1, policyMsg);
+ CASE_STR_CONST(allow, 2, policyMsg);
+ CASE_DEF_STR(policyMsg);
+ }
+ return snprintf(output, len, "bmiss %d %s during sleep filterCnt %d", bMiss, policyMsg, myBeaconCnt);
+}
+
+
+static int PM_SET_STATE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT16 pmStateWakeupCount = (buffer[1] >> 16) & 0xffff;
+ A_INT16 pmState = buffer[1] & 0xffff;
+ A_INT16 pmAwakeCount = (buffer[2] >> 16) & 0xffff;
+ A_INT8 pmSleepCount = (buffer[2] >> 8) & 0xff;
+ A_INT8 pmOldState = buffer[2] & 0xff;
+ return snprintf(output, len, "StateWakeupCnt %d AwakeCnt %d, SleepCnt %d, %s to %s",
+ pmStateWakeupCount, pmAwakeCount, pmSleepCount,
+ pmmode2text(pmOldState), pmmode2text(pmState));
+}
+
+static int PM_SET_POWERMODE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_UINT16 wcnt = buffer[1] >> 16;
+ A_UINT16 fakeSleep = buffer[1] & 0xffff;
+ A_UINT16 oldPowerMode = buffer[2] >> 16;
+ A_UINT8 powerMode = (buffer[2] >> 8) & 0xff;
+ A_UINT8 moduleId = buffer[2] & 0xff;
+ return snprintf(output, len, "wakeCnt %d fakeSleep %d %s(%d)=>%s(%d) %s(%d)",
+ wcnt, fakeSleep, pmmode2text(oldPowerMode), oldPowerMode, pmmode2text(powerMode), powerMode, pmmodule2text(moduleId), moduleId);
+}
+
+static int PM_FAKE_SLEEP_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT16 enable = (buffer[1] >> 16) & 0xffff;
+ const char *state = enable2text(enable);
+ A_INT8 pmFakeSleepCount = (buffer[1] >> 8) & 0xff;
+ A_INT8 fakeSleepEnable = (buffer[1] & 0xff);
+ A_INT16 forceAwake = (buffer[2] >> 16) & 0xffff;
+ A_INT8 dontWaitForDrain = (buffer[2] >> 8) & 0xff;
+ A_INT8 module = buffer[2] & 0xff;
+ return snprintf(output, len, "%s cnt %d hasCnt %d forceAwake %d dontWaitDrain %d %s(%d)",
+ state, pmFakeSleepCount, fakeSleepEnable, forceAwake, dontWaitForDrain, pmmodule2text(module), module);
+}
+
+static int BTCOEX_DBG_pmwakeupcnt_flags(char *output, size_t len, A_INT32 pmWakeupCnt, A_INT32 btCoexFlags)
+{
+ int ret = 0;
+ ret += snprintf(output+ret, len-ret, "coexPmWakeupCnt %d", pmWakeupCnt);
+ if (btCoexFlags!=-1) {
+ char buf[512];
+ btcoexFlags2text(buf, sizeof(buf), btCoexFlags);
+ ret += snprintf(output+ret, len-ret, " coex [%s]", buf);
+ }
+ return ret;
+}
+
+static int BTCOEX_ACL_COEX_STATUS_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 btStatus = (buffer[1] >> 16) & 0xffff;
+ A_INT32 redoAggr = buffer[1] & 0xffff;
+ return snprintf(output, len, "%s redoAggr %d", btStatus2text(btStatus), redoAggr);
+}
+
+static int BTCOEX_DBG_PM_SLEEP_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 pmWakeupCnt = buffer[1];
+ A_INT32 btCoexFlags = buffer[2];
+ return BTCOEX_DBG_pmwakeupcnt_flags(output,len,pmWakeupCnt,btCoexFlags);
+}
+
+static int BTCOEX_PSPOLL_QUEUED_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT16 isEolEnabled = (buffer[1] >> 16) & 0xffff;
+ A_INT8 bSendAtLowestRate = (buffer[1] >>8) & 0xff;
+ A_INT8 isPmSleep = (buffer[1]) & 0xff;
+ return snprintf(output, len, "Eol:%s LowestRate:%s PmSleep:%s",
+ enable2text(isEolEnabled), enable2text(bSendAtLowestRate),
+ enable2text(isPmSleep));
+}
+
+static int BTCOEX_PSPOLL_COMPLETE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ return snprintf(output, len, "%s", txrxstatus2text(buffer[1]));
+}
+
+static int BTCOEX_DBG_PM_AWAKE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ return BTCOEX_DBG_PM_SLEEP_fmt(output,len,numargs,buffer);
+}
+
+static int BTCOEX_DBG_GO_TO_SLEEP_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ return BTCOEX_DBG_pmwakeupcnt_flags(output,len,buffer[1],-1);
+}
+
+static int BTCOEX_WAKEUP_ON_DATA_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ return BTCOEX_DBG_pmwakeupcnt_flags(output,len,buffer[2], buffer[1]);
+}
+
+static int BTCOEX_TIM_NOTIFICATION_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ int ret = 0;
+ A_INT32 btCoexFlags = buffer[1];
+ A_INT32 btStatus = (buffer[2]>>16) & 0xffff;
+ A_INT32 pmWakeupCnt = (buffer[2] & 0xffff);
+ ret = BTCOEX_DBG_pmwakeupcnt_flags(output,len, pmWakeupCnt, btCoexFlags);
+ ret += snprintf(output+ret, len-ret, " %s", btStatus2text(btStatus));
+ return ret;
+}
+
+static int BTCOEX_DBG_ALLOW_SCAN_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ char buf[512];
+ A_INT32 retStatus = buffer[2];
+ A_INT32 btState = buffer[1];
+ btState2text(buf, sizeof(buf), btState);
+ return snprintf(output, len, "state: [%s] allow:%d", buf, retStatus);
+}
+
+static int BTCOEX_DBG_SCAN_REQUEST_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ char buf[512];
+ A_INT32 scanReqEnabled = buffer[2];
+ A_INT32 btState = buffer[1];
+ btState2text(buf, sizeof(buf), btState);
+ return snprintf(output, len, "state: [%s] scanReqEnabled:%d", buf, scanReqEnabled);
+}
+
+static int BTCOEX_DBG_SET_WLAN_STATE_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 btCoexFlags = buffer[2];
+ char buf[512];
+ const char *wlanState;
+ switch (buffer[1]) {
+ CASE_STR_CONST(IDLE , 1, wlanState);
+ CASE_STR_CONST(CONNECTED , 2, wlanState);
+ CASE_STR_CONST(SCAN_START , 3, wlanState);
+ CASE_STR_CONST(CONNECT_START ,4, wlanState);
+ CASE_STR_CONST(SCAN_END , 5, wlanState);
+ CASE_STR_CONST(APMODE_STA_CONNECTED , 6, wlanState);
+ CASE_STR_CONST(APMODE_IDLE , 7, wlanState);
+ CASE_STR_CONST(APMODE_SWITCH , 8, wlanState);
+ CASE_STR_CONST(APMODE_TEARDOWN , 9, wlanState);
+ CASE_DEF_STR(wlanState);
+ }
+ btcoexFlags2text(buf, sizeof(buf), btCoexFlags);
+ return snprintf(output, len, "wlan %s coex [%s]", wlanState, buf);
+}
+
+static int BTCOEX_DBG_BT_INQUIRY_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *btState = btStatus2text(buffer[1]);
+ A_INT32 btCoexFlags = buffer[2];
+ char buf[512];
+ btcoexFlags2text(buf, sizeof(buf), btCoexFlags);
+ return snprintf(output, len, "%s coex [%s]", btState, buf);
+}
+
+static int BTCOEX_SET_WEIGHTS_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *weights;
+ switch (buffer[1]) {
+ CASE_STR_CONST(ALL_BT_TRAFFIC,1,weights);
+ CASE_STR_CONST(ONLY_HIGH_PRI_BT_TRAFFIC,2,weights);
+ CASE_STR_CONST(STOMP_ALL_BT_TRAFFIC,3,weights);
+ CASE_STR_CONST(ONLY_A2DP_TRAFFIC,4,weights);
+ CASE_STR_CONST(ONLY_HIGH_PRIO_AND_A2DP,5,weights);
+ CASE_STR_CONST(A2DP_STOMPED,6,weights);
+ CASE_STR_CONST(ALL_BT_TRAFFIC_WTX,7,weights);
+ CASE_STR_CONST(ALL_BT_TRAFFIC_WTX_HIGHISO_TXRX,8,weights);
+ CASE_STR_CONST(HIGH_PRI_TRAFFIC_WTX,9,weights);
+ CASE_STR_CONST(HIGH_PRI_TRAFFIC_WTX_HIGHISO_TXRX,0xa,weights);
+ CASE_STR_CONST(MCI_TEST,0xb,weights);
+ CASE_DEF_STR(weights);
+ }
+
+ return snprintf(output, len, "%s val 0x%x", weights, buffer[2]);
+}
+
+static int BTCOEX_PM_FAKE_SLEEP_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *enable = enable2text(buffer[1]);
+ A_STATUS status = buffer[2];
+ return snprintf(output, len, "%s -> %s", enable, status2text(status));
+}
+
+static const struct wmi_id_desc evt_desc[] = {
+ WM_ID_DESC(WMI_READY_EVENTID),
+ WM_ID_DESC(WMI_CONNECT_EVENTID),
+ WM_ID_DESC(WMI_DISCONNECT_EVENTID),
+ WM_ID_DESC(WMI_BSSINFO_EVENTID),
+ WM_ID_DESC(WMI_CMDERROR_EVENTID),
+ WM_ID_DESC(WMI_REGDOMAIN_EVENTID),
+ WM_ID_DESC(WMI_PSTREAM_TIMEOUT_EVENTID),
+ WM_ID_DESC(WMI_NEIGHBOR_REPORT_EVENTID),
+ WM_ID_DESC(WMI_TKIP_MICERR_EVENTID),
+ WM_ID_DESC(WMI_SCAN_COMPLETE_EVENTID), /* 0x100a */
+ WM_ID_DESC(WMI_REPORT_STATISTICS_EVENTID),
+ WM_ID_DESC(WMI_RSSI_THRESHOLD_EVENTID),
+ WM_ID_DESC(WMI_ERROR_REPORT_EVENTID),
+ WM_ID_DESC(WMI_OPT_RX_FRAME_EVENTID),
+ WM_ID_DESC(WMI_REPORT_ROAM_TBL_EVENTID),
+ WM_ID_DESC(WMI_EXTENSION_EVENTID),
+ WM_ID_DESC(WMI_CAC_EVENTID),
+ WM_ID_DESC(WMI_SNR_THRESHOLD_EVENTID),
+ WM_ID_DESC(WMI_LQ_THRESHOLD_EVENTID),
+ WM_ID_DESC(WMI_TX_RETRY_ERR_EVENTID), /* 0x1014 */
+ WM_ID_DESC(WMI_REPORT_ROAM_DATA_EVENTID),
+ WM_ID_DESC(WMI_TEST_EVENTID),
+ WM_ID_DESC(WMI_APLIST_EVENTID),
+ WM_ID_DESC(WMI_GET_WOW_LIST_EVENTID),
+ WM_ID_DESC(WMI_GET_PMKID_LIST_EVENTID),
+ WM_ID_DESC(WMI_CHANNEL_CHANGE_EVENTID),
+ WM_ID_DESC(WMI_PEER_NODE_EVENTID),
+ WM_ID_DESC(WMI_PSPOLL_EVENTID),
+ WM_ID_DESC(WMI_DTIMEXPIRY_EVENTID),
+ WM_ID_DESC(WMI_WLAN_VERSION_EVENTID),
+ WM_ID_DESC(WMI_SET_PARAMS_REPLY_EVENTID),
+ WM_ID_DESC(WMI_ADDBA_REQ_EVENTID), /*0x1020 */
+ WM_ID_DESC(WMI_ADDBA_RESP_EVENTID),
+ WM_ID_DESC(WMI_DELBA_REQ_EVENTID),
+ WM_ID_DESC(WMI_TX_COMPLETE_EVENTID),
+ WM_ID_DESC(WMI_HCI_EVENT_EVENTID),
+ WM_ID_DESC(WMI_ACL_DATA_EVENTID),
+ WM_ID_DESC(WMI_REPORT_SLEEP_STATE_EVENTID),
+
+ WM_ID_DESC(WMI_WAPI_REKEY_EVENTID),
+
+ WM_ID_DESC(WMI_REPORT_BTCOEX_STATS_EVENTID),
+ WM_ID_DESC(WMI_REPORT_BTCOEX_CONFIG_EVENTID),
+ WM_ID_DESC(WMI_GET_PMK_EVENTID),
+
+ /* DFS Events */
+ WM_ID_DESC(WMI_DFS_HOST_ATTACH_EVENTID),
+ WM_ID_DESC(WMI_DFS_HOST_INIT_EVENTID),
+ WM_ID_DESC(WMI_DFS_RESET_DELAYLINES_EVENTID),
+ WM_ID_DESC(WMI_DFS_RESET_RADARQ_EVENTID),
+ WM_ID_DESC(WMI_DFS_RESET_AR_EVENTID),
+ WM_ID_DESC(WMI_DFS_RESET_ARQ_EVENTID), /*0x1030*/
+ WM_ID_DESC(WMI_DFS_SET_DUR_MULTIPLIER_EVENTID),
+ WM_ID_DESC(WMI_DFS_SET_BANGRADAR_EVENTID),
+ WM_ID_DESC(WMI_DFS_SET_DEBUGLEVEL_EVENTID),
+ WM_ID_DESC(WMI_DFS_PHYERR_EVENTID),
+ /* CCX Evants */
+ WM_ID_DESC(WMI_CCX_RM_STATUS_EVENTID),
+
+ /* P2P Events */
+ WM_ID_DESC(WMI_P2P_GO_NEG_RESULT_EVENTID),
+
+ WM_ID_DESC(WMI_WAC_SCAN_DONE_EVENTID),
+ WM_ID_DESC(WMI_WAC_REPORT_BSS_EVENTID),
+ WM_ID_DESC(WMI_WAC_START_WPS_EVENTID),
+ WM_ID_DESC(WMI_WAC_CTRL_REQ_REPLY_EVENTID),
+
+ /*RFKILL Events*/
+ WM_ID_DESC(WMI_RFKILL_STATE_CHANGE_EVENTID),
+ WM_ID_DESC(WMI_RFKILL_GET_MODE_CMD_EVENTID),
+
+ /* More P2P Events */
+ WM_ID_DESC(WMI_P2P_GO_NEG_REQ_EVENTID),
+ WM_ID_DESC(WMI_P2P_INVITE_REQ_EVENTID),
+ WM_ID_DESC(WMI_P2P_INVITE_RCVD_RESULT_EVENTID),
+ WM_ID_DESC(WMI_P2P_INVITE_SENT_RESULT_EVENTID), /*1040*/
+ WM_ID_DESC(WMI_P2P_PROV_DISC_RESP_EVENTID),
+ WM_ID_DESC(WMI_P2P_PROV_DISC_REQ_EVENTID),
+ WM_ID_DESC(WMI_P2P_START_SDPD_EVENTID),
+ WM_ID_DESC(WMI_P2P_SDPD_RX_EVENTID),
+
+ /* Special event to notify host that cmd is processed and credit report is returned */
+ WM_ID_DESC(WMI_SET_HOST_SLEEP_MODE_CMD_PROCESSED_EVENTID),
+};
+
+static const struct wmi_id_desc cmds_desc[] = {
+ WM_ID_DESC_FMT(WMI_CONNECT_CMDID, sizeof(WMI_CONNECT_CMD)),
+ WM_ID_DESC(WMI_RECONNECT_CMDID),
+ WM_ID_DESC(WMI_DISCONNECT_CMDID),
+ WM_ID_DESC(WMI_SYNCHRONIZE_CMDID),
+ WM_ID_DESC(WMI_CREATE_PSTREAM_CMDID),
+ WM_ID_DESC(WMI_DELETE_PSTREAM_CMDID),
+ WM_ID_DESC_FMT(WMI_START_SCAN_CMDID, sizeof(WMI_START_SCAN_CMD)),
+ WM_ID_DESC(WMI_SET_SCAN_PARAMS_CMDID),
+ WM_ID_DESC_FMT(WMI_SET_BSS_FILTER_CMDID, sizeof(WMI_BSS_FILTER_CMD)),
+ WM_ID_DESC(WMI_SET_PROBED_SSID_CMDID), /* 10 */
+ WM_ID_DESC_FMT(WMI_SET_LISTEN_INT_CMDID, sizeof(WMI_LISTEN_INT_CMD)),
+ WM_ID_DESC(WMI_SET_BMISS_TIME_CMDID),
+ WM_ID_DESC(WMI_SET_DISC_TIMEOUT_CMDID),
+ WM_ID_DESC(WMI_GET_CHANNEL_LIST_CMDID),
+ WM_ID_DESC(WMI_SET_BEACON_INT_CMDID),
+ WM_ID_DESC(WMI_GET_STATISTICS_CMDID),
+ WM_ID_DESC(WMI_SET_CHANNEL_PARAMS_CMDID),
+ WM_ID_DESC(WMI_SET_POWER_MODE_CMDID),
+ WM_ID_DESC(WMI_SET_IBSS_PM_CAPS_CMDID),
+ WM_ID_DESC(WMI_SET_POWER_PARAMS_CMDID), /* 20 */
+ WM_ID_DESC(WMI_SET_POWERSAVE_TIMERS_POLICY_CMDID),
+ WM_ID_DESC(WMI_ADD_CIPHER_KEY_CMDID),
+ WM_ID_DESC(WMI_DELETE_CIPHER_KEY_CMDID),
+ WM_ID_DESC(WMI_ADD_KRK_CMDID),
+ WM_ID_DESC(WMI_DELETE_KRK_CMDID),
+ WM_ID_DESC(WMI_SET_PMKID_CMDID),
+ WM_ID_DESC(WMI_SET_TX_PWR_CMDID),
+ WM_ID_DESC(WMI_GET_TX_PWR_CMDID),
+ WM_ID_DESC(WMI_SET_ASSOC_INFO_CMDID),
+ WM_ID_DESC(WMI_ADD_BAD_AP_CMDID), /* 30 */
+ WM_ID_DESC(WMI_DELETE_BAD_AP_CMDID),
+ WM_ID_DESC(WMI_SET_TKIP_COUNTERMEASURES_CMDID),
+ WM_ID_DESC(WMI_RSSI_THRESHOLD_PARAMS_CMDID),
+ WM_ID_DESC(WMI_TARGET_ERROR_REPORT_BITMASK_CMDID),
+ WM_ID_DESC(WMI_SET_ACCESS_PARAMS_CMDID),
+ WM_ID_DESC(WMI_SET_RETRY_LIMITS_CMDID),
+ WM_ID_DESC(WMI_RESERVED1),
+ WM_ID_DESC(WMI_RESERVED2),
+ WM_ID_DESC(WMI_SET_VOICE_PKT_SIZE_CMDID),
+ WM_ID_DESC(WMI_SET_MAX_SP_LEN_CMDID), /* 40 */
+ WM_ID_DESC(WMI_SET_ROAM_CTRL_CMDID),
+ WM_ID_DESC(WMI_GET_ROAM_TBL_CMDID),
+ WM_ID_DESC(WMI_GET_ROAM_DATA_CMDID),
+ WM_ID_DESC(WMI_ENABLE_RM_CMDID),
+ WM_ID_DESC(WMI_SET_MAX_OFFHOME_DURATION_CMDID),
+ WM_ID_DESC(WMI_EXTENSION_CMDID), /* Non-wireless extensions */
+ WM_ID_DESC(WMI_SNR_THRESHOLD_PARAMS_CMDID),
+ WM_ID_DESC(WMI_LQ_THRESHOLD_PARAMS_CMDID),
+ WM_ID_DESC(WMI_SET_LPREAMBLE_CMDID),
+ WM_ID_DESC(WMI_SET_RTS_CMDID), /* 50 */
+ WM_ID_DESC(WMI_CLR_RSSI_SNR_CMDID),
+ WM_ID_DESC(WMI_SET_FIXRATES_CMDID),
+ WM_ID_DESC(WMI_GET_FIXRATES_CMDID),
+ WM_ID_DESC(WMI_SET_AUTH_MODE_CMDID),
+ WM_ID_DESC(WMI_SET_REASSOC_MODE_CMDID),
+ WM_ID_DESC(WMI_SET_WMM_CMDID),
+ WM_ID_DESC(WMI_SET_WMM_TXOP_CMDID),
+ WM_ID_DESC(WMI_TEST_CMDID),
+ /* COEX AR6002 only*/
+ WM_ID_DESC(WMI_SET_BT_STATUS_CMDID),
+ WM_ID_DESC(WMI_SET_BT_PARAMS_CMDID), /* 60 */
+
+ WM_ID_DESC(WMI_SET_KEEPALIVE_CMDID),
+ WM_ID_DESC(WMI_GET_KEEPALIVE_CMDID),
+ WM_ID_DESC(WMI_SET_APPIE_CMDID),
+ WM_ID_DESC(WMI_GET_APPIE_CMDID),
+ WM_ID_DESC(WMI_SET_WSC_STATUS_CMDID),
+
+ /* Wake on Wireless */
+ WM_ID_DESC(WMI_SET_HOST_SLEEP_MODE_CMDID),
+ WM_ID_DESC(WMI_SET_WOW_MODE_CMDID),
+ WM_ID_DESC(WMI_GET_WOW_LIST_CMDID),
+ WM_ID_DESC(WMI_ADD_WOW_PATTERN_CMDID),
+ WM_ID_DESC(WMI_DEL_WOW_PATTERN_CMDID), /* 70 */
+
+ WM_ID_DESC(WMI_SET_FRAMERATES_CMDID),
+ WM_ID_DESC(WMI_SET_AP_PS_CMDID),
+ WM_ID_DESC(WMI_SET_QOS_SUPP_CMDID),
+};
+
+static const struct wmi_id_desc cmdxs_desc[] = {
+ WM_ID_DESC(WMI_SET_BITRATE_CMDID),
+ WM_ID_DESC(WMI_GET_BITRATE_CMDID),
+ WM_ID_DESC(WMI_SET_WHALPARAM_CMDID),
+
+
+ /*Should add the new command to the tail for compatible with
+ * etna.
+ */
+ WM_ID_DESC(WMI_SET_MAC_ADDRESS_CMDID),
+ WM_ID_DESC(WMI_SET_AKMP_PARAMS_CMDID),
+ WM_ID_DESC(WMI_SET_PMKID_LIST_CMDID),
+ WM_ID_DESC(WMI_GET_PMKID_LIST_CMDID),
+ WM_ID_DESC(WMI_ABORT_SCAN_CMDID),
+ WM_ID_DESC(WMI_SET_TARGET_EVENT_REPORT_CMDID),
+
+ /* Unused */
+ WM_ID_DESC(WMI_UNUSED1),
+ WM_ID_DESC(WMI_UNUSED2),
+
+ /*
+ * AP mode commands
+ */
+ WM_ID_DESC(WMI_AP_HIDDEN_SSID_CMDID),
+ WM_ID_DESC(WMI_AP_SET_NUM_STA_CMDID),
+ WM_ID_DESC(WMI_AP_ACL_POLICY_CMDID),
+ WM_ID_DESC(WMI_AP_ACL_MAC_LIST_CMDID),
+ WM_ID_DESC(WMI_AP_CONFIG_COMMIT_CMDID),
+ WM_ID_DESC(WMI_AP_SET_MLME_CMDID),
+ WM_ID_DESC(WMI_AP_SET_PVB_CMDID),
+ WM_ID_DESC(WMI_AP_CONN_INACT_CMDID),
+ WM_ID_DESC(WMI_AP_PROT_SCAN_TIME_CMDID),
+ WM_ID_DESC(WMI_AP_SET_COUNTRY_CMDID),
+ WM_ID_DESC(WMI_AP_SET_DTIM_CMDID),
+ WM_ID_DESC(WMI_AP_MODE_STAT_CMDID),
+
+ WM_ID_DESC(WMI_SET_IP_CMDID),
+ WM_ID_DESC(WMI_SET_PARAMS_CMDID),
+ WM_ID_DESC_FMT(WMI_SET_MCAST_FILTER_CMDID, sizeof(WMI_SET_MCAST_FILTER_CMD)),
+ WM_ID_DESC_FMT(WMI_DEL_MCAST_FILTER_CMDID, sizeof(WMI_SET_MCAST_FILTER_CMD)),
+
+ WM_ID_DESC(WMI_ALLOW_AGGR_CMDID),
+ WM_ID_DESC(WMI_ADDBA_REQ_CMDID),
+ WM_ID_DESC(WMI_DELBA_REQ_CMDID),
+ WM_ID_DESC(WMI_SET_HT_CAP_CMDID),
+ WM_ID_DESC(WMI_SET_HT_OP_CMDID),
+ WM_ID_DESC(WMI_SET_TX_SELECT_RATES_CMDID),
+ WM_ID_DESC(WMI_SET_TX_SGI_PARAM_CMDID),
+ WM_ID_DESC(WMI_SET_RATE_POLICY_CMDID),
+
+ WM_ID_DESC(WMI_HCI_CMD_CMDID),
+ WM_ID_DESC(WMI_RX_FRAME_FORMAT_CMDID),
+ WM_ID_DESC(WMI_SET_THIN_MODE_CMDID),
+ WM_ID_DESC(WMI_SET_BT_WLAN_CONN_PRECEDENCE_CMDID),
+
+ WM_ID_DESC(WMI_AP_SET_11BG_RATESET_CMDID),
+ WM_ID_DESC(WMI_SET_PMK_CMDID),
+ WM_ID_DESC_FMT(WMI_MCAST_FILTER_CMDID, sizeof(WMI_MCAST_FILTER_CMD)),
+ /* COEX CMDID AR6003*/
+ WM_ID_DESC_FMT(WMI_SET_BTCOEX_FE_ANT_CMDID, sizeof(WMI_SET_BTCOEX_FE_ANT_CMD)),
+ WM_ID_DESC(WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID),
+ WM_ID_DESC_FMT(WMI_SET_BTCOEX_SCO_CONFIG_CMDID, sizeof(WMI_SET_BTCOEX_SCO_CONFIG_CMD)),
+ WM_ID_DESC_FMT(WMI_SET_BTCOEX_A2DP_CONFIG_CMDID, sizeof(WMI_SET_BTCOEX_A2DP_CONFIG_CMD)),
+ WM_ID_DESC_FMT(WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMDID, sizeof(WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMD)),
+ WM_ID_DESC_FMT(WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMDID, sizeof(WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMD)),
+ WM_ID_DESC(WMI_SET_BTCOEX_DEBUG_CMDID),
+ WM_ID_DESC_FMT(WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID, sizeof(WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMD)),
+ WM_ID_DESC(WMI_GET_BTCOEX_STATS_CMDID),
+ WM_ID_DESC(WMI_GET_BTCOEX_CONFIG_CMDID),
+
+ WM_ID_DESC(WMI_SET_DFS_ENABLE_CMDID), /* F034 */
+ WM_ID_DESC(WMI_SET_DFS_MINRSSITHRESH_CMDID),
+ WM_ID_DESC(WMI_SET_DFS_MAXPULSEDUR_CMDID),
+ WM_ID_DESC(WMI_DFS_RADAR_DETECTED_CMDID),
+
+ /* P2P CMDS */
+ WM_ID_DESC(WMI_P2P_SET_CONFIG_CMDID), /* F038 */
+ WM_ID_DESC(WMI_WPS_SET_CONFIG_CMDID),
+ WM_ID_DESC(WMI_SET_REQ_DEV_ATTR_CMDID),
+ WM_ID_DESC(WMI_P2P_FIND_CMDID),
+ WM_ID_DESC(WMI_P2P_STOP_FIND_CMDID),
+ WM_ID_DESC(WMI_P2P_GO_NEG_START_CMDID),
+ WM_ID_DESC(WMI_P2P_LISTEN_CMDID),
+
+ WM_ID_DESC(WMI_CONFIG_TX_MAC_RULES_CMDID),
+ WM_ID_DESC(WMI_SET_PROMISCUOUS_MODE_CMDID),/* F040 */
+ WM_ID_DESC(WMI_RX_FRAME_FILTER_CMDID),
+ WM_ID_DESC(WMI_SET_CHANNEL_CMDID),
+
+ /* WAC commands */
+ WM_ID_DESC(WMI_ENABLE_WAC_CMDID),
+ WM_ID_DESC(WMI_WAC_SCAN_REPLY_CMDID),
+ WM_ID_DESC(WMI_WAC_CTRL_REQ_CMDID),
+ WM_ID_DESC(WMI_SET_DIV_PARAMS_CMDID),
+
+ WM_ID_DESC(WMI_GET_PMK_CMDID),
+ WM_ID_DESC(WMI_SET_PASSPHRASE_CMDID),
+ WM_ID_DESC(WMI_SEND_ASSOC_RES_CMDID),
+ WM_ID_DESC(WMI_SET_ASSOC_REQ_RELAY_CMDID),
+ WM_ID_DESC(WMI_GET_RFKILL_MODE_CMDID),
+ WM_ID_DESC(WMI_SET_RFKILL_MODE_CMDID),
+
+ /* ACS command, consists of sub-commands */
+ WM_ID_DESC(WMI_ACS_CTRL_CMDID),
+
+ /* Ultra low power store / recall commands */
+ WM_ID_DESC(WMI_STORERECALL_CONFIGURE_CMDID),
+ WM_ID_DESC(WMI_STORERECALL_RECALL_CMDID),
+ WM_ID_DESC(WMI_STORERECALL_HOST_READY_CMDID),
+ WM_ID_DESC(WMI_FORCE_TARGET_ASSERT_CMDID),
+ WM_ID_DESC(WMI_SET_EXCESS_TX_RETRY_THRES_CMDID),
+
+ WM_ID_DESC(WMI_P2P_GO_NEG_REQ_RSP_CMDID), /* F053 */
+ WM_ID_DESC(WMI_P2P_GRP_INIT_CMDID),
+ WM_ID_DESC(WMI_P2P_GRP_FORMATION_DONE_CMDID),
+ WM_ID_DESC(WMI_P2P_INVITE_CMDID),
+ WM_ID_DESC(WMI_P2P_INVITE_REQ_RSP_CMDID),
+ WM_ID_DESC(WMI_P2P_PROV_DISC_REQ_CMDID),
+ WM_ID_DESC(WMI_P2P_SET_CMDID),
+
+ WM_ID_DESC(WMI_AP_SET_APSD_CMDID), /* F05A */
+ WM_ID_DESC(WMI_AP_APSD_BUFFERED_TRAFFIC_CMDID),
+
+ WM_ID_DESC(WMI_P2P_SDPD_TX_CMDID), /* F05C */
+ WM_ID_DESC(WMI_P2P_STOP_SDPD_CMDID),
+ WM_ID_DESC(WMI_P2P_CANCEL_CMDID),
+};
+
+static int dbg_wmi_cmd_params_pos, dbg_wmi_cmd_params_cmdid;
+static A_UINT8 *dbg_wmi_cmd_params_buf;
+
+static int WMI_EVENT_SEND_XTND_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ const char *txt;
+ A_INT32 evt = buffer[1];
+ switch (evt) {
+ CASE_STR(WMIX_DSETOPENREQ_EVENTID, txt);
+ CASE_STR(WMIX_DSETCLOSE_EVENTID, txt);
+ CASE_STR(WMIX_DSETDATAREQ_EVENTID, txt);
+ CASE_STR(WMIX_GPIO_INTR_EVENTID, txt);
+ CASE_STR(WMIX_GPIO_DATA_EVENTID, txt);
+ CASE_STR(WMIX_GPIO_ACK_EVENTID, txt);
+ CASE_STR(WMIX_HB_CHALLENGE_RESP_EVENTID, txt);
+ CASE_STR(WMIX_DBGLOG_EVENTID, txt);
+ CASE_STR(WMIX_PROF_COUNT_EVENTID, txt);
+ CASE_DEF_STR(txt);
+ }
+ return snprintf(output, len, "%s", txt);
+}
+
+static int WMI_EVENT_SEND_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 idx = buffer[1];
+ A_INT32 sidx;
+ if (idx>=(A_INT32)WMI_READY_EVENTID &&
+ idx<(A_INT32)(WMI_READY_EVENTID+ARRAY_SIZE(evt_desc))) {
+ sidx = idx - WMI_READY_EVENTID;
+ return snprintf(output, len, "%s", evt_desc[sidx].desc);
+ } else if (idx>=(A_INT32)WMI_SET_BITRATE_CMDID &&
+ idx<(A_INT32)(WMI_SET_BITRATE_CMDID+ARRAY_SIZE(cmdxs_desc))) {
+ sidx = idx - WMI_SET_BITRATE_CMDID;
+ return snprintf(output, len, "%s", cmdxs_desc[sidx].desc);
+ }
+ return 0;
+}
+
+
+static int WMI_CMD_RX_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 idx = buffer[1];
+ A_INT32 length = buffer[2];
+ A_INT32 sidx;
+ if (idx>=(A_INT32)WMI_CONNECT_CMDID &&
+ idx<(A_INT32)(WMI_CONNECT_CMDID+ARRAY_SIZE(cmds_desc))) {
+ sidx = idx-WMI_CONNECT_CMDID;
+ return snprintf(output, len, "%s, len %d",
+ cmds_desc[sidx].desc, length);
+ } else if (idx>=(A_INT32)WMI_SET_BITRATE_CMDID &&
+ idx<(A_INT32)(WMI_SET_BITRATE_CMDID+ARRAY_SIZE(cmdxs_desc))) {
+ sidx = idx - WMI_SET_BITRATE_CMDID;
+ return snprintf(output, len, "%s, len %d",
+ cmdxs_desc[sidx].desc, length);
+ }
+ return 0;
+}
+
+static int WMI_CMD_PARAMS_DUMP_START_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ A_INT32 paramslen = buffer[2];
+ paramslen += (sizeof(A_INT32) * 2); /* adding pad */
+ dbg_wmi_cmd_params_pos = 0;
+ dbg_wmi_cmd_params_cmdid = buffer[1];
+ dbg_wmi_cmd_params_buf = (paramslen>0) ? malloc(paramslen) : NULL;
+ return 0;
+}
+
+static int WMI_CMD_PARAMS_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ if (dbg_wmi_cmd_params_buf == NULL) {
+ /* partial debug log where there is no START. Skip it*/
+ return 0;
+ }
+ memcpy(&dbg_wmi_cmd_params_buf[dbg_wmi_cmd_params_pos], &buffer[1], sizeof(A_INT32));
+ memcpy(&dbg_wmi_cmd_params_buf[dbg_wmi_cmd_params_pos+4], &buffer[2], sizeof(A_INT32));
+ dbg_wmi_cmd_params_pos += (sizeof(A_INT32) * 2);
+ return 0;
+}
+
+static int WMI_CMD_PARAMS_DUMP_END_fmt(char *output, size_t len, A_UINT32 numargs, A_INT32 *buffer)
+{
+ int ret = 0;
+ A_INT32 idx = dbg_wmi_cmd_params_cmdid;
+ DbgCmdFormatter cmdFormatter = NULL;
+ size_t cmdSize;
+ if (dbg_wmi_cmd_params_buf == NULL) {
+ /* partial debug log where there is no START. Skip it*/
+ return 0;
+ }
+ if (idx>=(A_INT32)WMI_CONNECT_CMDID &&
+ idx<(A_INT32)(WMI_CONNECT_CMDID+ARRAY_SIZE(cmds_desc)) ) {
+ cmdFormatter = cmds_desc[idx-WMI_CONNECT_CMDID].formatter;
+ cmdSize = cmds_desc[idx-WMI_CONNECT_CMDID].cmdSize;
+ } else if (idx>=(A_INT32)WMI_SET_BITRATE_CMDID &&
+ idx<(A_INT32)(WMI_SET_BITRATE_CMDID+ARRAY_SIZE(cmdxs_desc))) {
+ cmdFormatter = cmdxs_desc[idx-WMI_SET_BITRATE_CMDID].formatter;
+ cmdSize = cmdxs_desc[idx-WMI_SET_BITRATE_CMDID].cmdSize;
+ }
+ if (cmdFormatter) {
+ ret += snprintf(output+ret, len-ret, " ");
+ if (dbg_wmi_cmd_params_pos>=cmdSize) {
+ ret += cmdFormatter(output+ret, len-ret, dbg_wmi_cmd_params_buf);
+ } else {
+ ret += snprintf(output+ret, len-ret, "malformed cmd. size too small %d < %d",
+ dbg_wmi_cmd_params_pos, cmdSize);
+ }
+ }
+ dbg_wmi_cmd_params_pos = 0;
+ dbg_wmi_cmd_params_cmdid = 0;
+ free(dbg_wmi_cmd_params_buf);
+ dbg_wmi_cmd_params_buf = NULL;
+ return ret;
+}
+
+static struct dbglog_desc wmi_desc[] = {
+ DBG_DESC(0),
+ DBG_DESC(WMI_CMD_RX_XTND_PKT_TOO_SHORT),
+ DBG_DESC(WMI_EXTENDED_CMD_NOT_HANDLED),
+ DBG_DESC(WMI_CMD_RX_PKT_TOO_SHORT),
+ DBG_DESC(WMI_CALLING_WMI_EXTENSION_FN),
+ DBG_DESC(WMI_CMD_NOT_HANDLED),
+ DBG_DESC(WMI_IN_SYNC),
+ DBG_DESC(WMI_TARGET_WMI_SYNC_CMD),
+ DBG_DESC(WMI_SET_SNR_THRESHOLD_PARAMS),
+ DBG_DESC(WMI_SET_RSSI_THRESHOLD_PARAMS),
+ DBG_DESC(WMI_SET_LQ_TRESHOLD_PARAMS),
+ DBG_DESC(WMI_TARGET_CREATE_PSTREAM_CMD),
+ DBG_DESC(WMI_WI_DTM_INUSE),
+ DBG_DESC(WMI_TARGET_DELETE_PSTREAM_CMD),
+ DBG_DESC(WMI_TARGET_IMPLICIT_DELETE_PSTREAM_CMD),
+ DBG_DESC(WMI_TARGET_GET_BIT_RATE_CMD),
+ DBG_DESC(WMI_GET_RATE_MASK_CMD_FIX_RATE_MASK_IS),
+ DBG_DESC(WMI_TARGET_GET_AVAILABLE_CHANNELS_CMD),
+ DBG_DESC(WMI_TARGET_GET_TX_PWR_CMD),
+ DBG_DESC(WMI_FREE_EVBUF_WMIBUF),
+ DBG_DESC(WMI_FREE_EVBUF_DATABUF),
+ DBG_DESC(WMI_FREE_EVBUF_BADFLAG),
+ DBG_DESC(WMI_HTC_RX_ERROR_DATA_PACKET),
+ DBG_DESC(WMI_HTC_RX_SYNC_PAUSING_FOR_MBOX),
+ DBG_DESC(WMI_INCORRECT_WMI_DATA_HDR_DROPPING_PKT),
+ DBG_DESC(WMI_SENDING_READY_EVENT),
+ DBG_DESC(WMI_SETPOWER_MDOE_TO_MAXPERF),
+ DBG_DESC(WMI_SETPOWER_MDOE_TO_REC),
+ DBG_DESC(WMI_BSSINFO_EVENT_FROM),
+ DBG_DESC(WMI_TARGET_GET_STATS_CMD),
+ DBG_DESC(WMI_SENDING_SCAN_COMPLETE_EVENT),
+ DBG_DESC(WMI_SENDING_RSSI_INDB_THRESHOLD_EVENT),
+ DBG_DESC(WMI_SENDING_RSSI_INDBM_THRESHOLD_EVENT),
+ DBG_DESC(WMI_SENDING_LINK_QUALITY_THRESHOLD_EVENT),
+ DBG_DESC(WMI_SENDING_ERROR_REPORT_EVENT),
+ DBG_DESC(WMI_SENDING_CAC_EVENT),
+ DBG_DESC(WMI_TARGET_GET_ROAM_TABLE_CMD),
+ DBG_DESC(WMI_TARGET_GET_ROAM_DATA_CMD),
+ DBG_DESC(WMI_SENDING_GPIO_INTR_EVENT),
+ DBG_DESC(WMI_SENDING_GPIO_ACK_EVENT),
+ DBG_DESC(WMI_SENDING_GPIO_DATA_EVENT),
+ DBG_DESC_FMT(WMI_CMD_RX),
+ DBG_DESC(WMI_CMD_RX_XTND),
+ DBG_DESC_FMT(WMI_EVENT_SEND),
+ DBG_DESC_FMT(WMI_EVENT_SEND_XTND),
+ DBG_DESC_FMT(WMI_CMD_PARAMS_DUMP_START),
+ DBG_DESC_FMT(WMI_CMD_PARAMS_DUMP_END),
+ DBG_DESC_FMT(WMI_CMD_PARAMS),
+};
+
+static struct dbglog_desc co_desc[] = {
+ DBG_DESC(0),
+ DBG_DESC(CO_INIT),
+ DBG_DESC(CO_ACQUIRE_LOCK),
+ DBG_DESC(CO_START_OP1),
+ DBG_DESC(CO_START_OP2),
+ DBG_DESC(CO_DRAIN_TX_COMPLETE_CB),
+ DBG_DESC(CO_CHANGE_CHANNEL_CB),
+ DBG_DESC(CO_RETURN_TO_HOME_CHANNEL),
+ DBG_DESC(CO_FINISH_OP_TIMEOUT),
+ DBG_DESC(CO_OP_END),
+ DBG_DESC(CO_CANCEL_OP),
+ DBG_DESC_FMT(CO_CHANGE_CHANNEL),
+ DBG_DESC(CO_RELEASE_LOCK),
+ DBG_DESC_FMT(CO_CHANGE_STATE),
+};
+
+static struct dbglog_desc mgmtbuf_desc[] = {
+ DBG_DESC(0),
+ DBG_DESC(TXRX_MGMTBUF_ALLOCATE_BUF),
+ DBG_DESC(TXRX_MGMTBUF_ALLOCATE_SM_BUF),
+ DBG_DESC(TXRX_MGMTBUF_ALLOCATE_RMBUF),
+ DBG_DESC(TXRX_MGMTBUF_GET_BUF),
+ DBG_DESC(TXRX_MGMTBUF_GET_SM_BUF),
+ DBG_DESC(TXRX_MGMTBUF_QUEUE_BUF_TO_TXQ),
+ DBG_DESC_FMT(TXRX_MGMTBUF_REAPED_BUF),
+ DBG_DESC(TXRX_MGMTBUF_REAPED_SM_BUF),
+ DBG_DESC_FMT(TXRX_MGMTBUF_WAIT_FOR_TXQ_DRAIN),
+ DBG_DESC(TXRX_MGMTBUF_WAIT_FOR_TXQ_SFQ_DRAIN),
+ DBG_DESC(TXRX_MGMTBUF_ENQUEUE_INTO_DATA_SFQ),
+ DBG_DESC(TXRX_MGMTBUF_DEQUEUE_FROM_DATA_SFQ),
+ DBG_DESC(TXRX_MGMTBUF_PAUSE_DATA_TXQ),
+ DBG_DESC(TXRX_MGMTBUF_RESUME_DATA_TXQ),
+ DBG_DESC(TXRX_MGMTBUF_WAIT_FORTXQ_DRAIN_TIMEOUT),
+ DBG_DESC_FMT(TXRX_MGMTBUF_DRAINQ),
+ DBG_DESC(TXRX_MGMTBUF_INDICATE_Q_DRAINED),
+ DBG_DESC(TXRX_MGMTBUF_ENQUEUE_INTO_HW_SFQ),
+ DBG_DESC(TXRX_MGMTBUF_DEQUEUE_FROM_HW_SFQ),
+ DBG_DESC(TXRX_MGMTBUF_PAUSE_HW_TXQ),
+ DBG_DESC(TXRX_MGMTBUF_RESUME_HW_TXQ),
+ DBG_DESC(TXRX_MGMTBUF_TEAR_DOWN_BA),
+ DBG_DESC(TXRX_MGMTBUF_PROCESS_ADDBA_REQ),
+ DBG_DESC(TXRX_MGMTBUF_PROCESS_DELBA),
+ DBG_DESC(TXRX_MGMTBUF_PERFORM_BA),
+ DBG_DESC_FMT(TXRX_MGMTBUF_WLAN_RESET_ON_ERROR),
+};
+
+static struct dbglog_desc dc_desc[] = {
+ DBG_DESC(0),
+ DBG_DESC_FMT(DC_SCAN_CHAN_START),
+ DBG_DESC_FMT(DC_SCAN_CHAN_FINISH),
+ DBG_DESC(DC_BEACON_RECEIVE7),
+ DBG_DESC_FMT(DC_SSID_PROBE_CB),
+ DBG_DESC_FMT(DC_SEND_NEXT_SSID_PROBE),
+ DBG_DESC_FMT(DC_START_SEARCH),
+ DBG_DESC(DC_CANCEL_SEARCH_CB),
+ DBG_DESC(DC_STOP_SEARCH),
+ DBG_DESC(DC_END_SEARCH),
+ DBG_DESC(DC_MIN_CHDWELL_TIMEOUT),
+ DBG_DESC(DC_START_SEARCH_CANCELED),
+ DBG_DESC_FMT(DC_SET_POWER_MODE),
+ DBG_DESC(DC_INIT),
+ DBG_DESC_FMT(DC_SEARCH_OPPORTUNITY),
+ DBG_DESC_FMT(DC_RECEIVED_ANY_BEACON),
+ DBG_DESC(DC_RECEIVED_MY_BEACON),
+ DBG_DESC(DC_PROFILE_IS_ADHOC_BUT_BSS_IS_INFRA),
+ DBG_DESC(DC_PS_ENABLED_BUT_ATHEROS_IE_ABSENT),
+ DBG_DESC(DC_BSS_ADHOC_CHANNEL_NOT_ALLOWED),
+ DBG_DESC(DC_SET_BEACON_UPDATE),
+ DBG_DESC(DC_BEACON_UPDATE_COMPLETE),
+ DBG_DESC(DC_END_SEARCH_BEACON_UPDATE_COMP_CB),
+ DBG_DESC(DC_BSSINFO_EVENT_DROPPED),
+ DBG_DESC(DC_IEEEPS_ENABLED_BUT_ATIM_ABSENT),
+};
+
+static struct dbglog_desc btcoex_desc[] = {
+ DBG_DESC(0),
+ DBG_DESC(BTCOEX_STATUS_CMD),
+ DBG_DESC(BTCOEX_PARAMS_CMD),
+ DBG_DESC(BTCOEX_ANT_CONFIG),
+ DBG_DESC(BTCOEX_COLOCATED_BT_DEVICE),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_SCO_ON),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_SCO_OFF),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_A2DP_ON),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_A2DP_OFF),
+ DBG_DESC(BTCOEX_A2DP_PROTECT_ON),
+ DBG_DESC(BTCOEX_A2DP_PROTECT_OFF),
+ DBG_DESC(BTCOEX_SCO_PROTECT_ON),
+ DBG_DESC(BTCOEX_SCO_PROTECT_OFF),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_DETECTOR_START),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_DETECTOR_STOP),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_TOGGLE),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_TOGGLE_RSSI_LRCNT),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_RSSI_THRESH),
+ DBG_DESC(BTCOEX_CLOSE_RANGE_LOW_RATE_THRESH),
+ DBG_DESC(BTCOEX_PTA_PRI_INTR_HANDLER),
+ DBG_DESC_FMT(BTCOEX_PSPOLL_QUEUED),
+ DBG_DESC_FMT(BTCOEX_PSPOLL_COMPLETE),
+ DBG_DESC_FMT(BTCOEX_DBG_PM_AWAKE),
+ DBG_DESC_FMT(BTCOEX_DBG_PM_SLEEP),
+ DBG_DESC(BTCOEX_DBG_SCO_COEX_ON),
+ DBG_DESC(BTCOEX_SCO_DATARECEIVE),
+ DBG_DESC(BTCOEX_INTR_INIT),
+ DBG_DESC(BTCOEX_PTA_PRI_DIFF),
+ DBG_DESC_FMT(BTCOEX_TIM_NOTIFICATION),
+ DBG_DESC(BTCOEX_SCO_WAKEUP_ON_DATA),
+ DBG_DESC(BTCOEX_SCO_SLEEP),
+ DBG_DESC_FMT(BTCOEX_SET_WEIGHTS),
+ DBG_DESC(BTCOEX_SCO_DATARECEIVE_LATENCY_VAL),
+ DBG_DESC(BTCOEX_SCO_MEASURE_TIME_DIFF),
+ DBG_DESC(BTCOEX_SET_EOL_VAL),
+ DBG_DESC(BTCOEX_OPT_DETECT_HANDLER),
+ DBG_DESC(BTCOEX_SCO_TOGGLE_STATE),
+ DBG_DESC(BTCOEX_SCO_STOMP),
+ DBG_DESC(BTCOEX_NULL_COMP_CALLBACK),
+ DBG_DESC(BTCOEX_RX_INCOMING),
+ DBG_DESC(BTCOEX_RX_INCOMING_CTL),
+ DBG_DESC(BTCOEX_RX_INCOMING_MGMT),
+ DBG_DESC(BTCOEX_RX_INCOMING_DATA),
+ DBG_DESC(BTCOEX_RTS_RECEPTION),
+ DBG_DESC(BTCOEX_FRAME_PRI_LOW_RATE_THRES),
+ DBG_DESC_FMT(BTCOEX_PM_FAKE_SLEEP),
+ DBG_DESC_FMT(BTCOEX_ACL_COEX_STATUS),
+ DBG_DESC(BTCOEX_ACL_COEX_DETECTION),
+ DBG_DESC(BTCOEX_A2DP_COEX_STATUS),
+ DBG_DESC(BTCOEX_SCO_STATUS),
+ DBG_DESC_FMT(BTCOEX_WAKEUP_ON_DATA),
+ DBG_DESC(BTCOEX_DATARECEIVE),
+ DBG_DESC(0),
+ DBG_DESC(BTCOEX_GET_MAX_AGGR_SIZE),
+ DBG_DESC(BTCOEX_MAX_AGGR_AVAIL_TIME),
+ DBG_DESC(BTCOEX_DBG_WBTIMER_INTR),
+ DBG_DESC(0),
+ DBG_DESC(BTCOEX_DBG_SCO_SYNC),
+ DBG_DESC(0),
+ DBG_DESC(BTCOEX_UPLINK_QUEUED_RATE),
+ DBG_DESC(BTCOEX_DBG_UPLINK_ENABLE_EOL),
+ DBG_DESC(BTCOEX_UPLINK_FRAME_DURATION),
+ DBG_DESC(BTCOEX_UPLINK_SET_EOL),
+ DBG_DESC(BTCOEX_DBG_EOL_EXPIRED),
+ DBG_DESC(BTCOEX_DBG_DATA_COMPLETE),
+ DBG_DESC(BTCOEX_UPLINK_QUEUED_TIMESTAMP),
+ DBG_DESC(BTCOEX_DBG_DATA_COMPLETE_TIME),
+ DBG_DESC(BTCOEX_DBG_A2DP_ROLE_IS_SLAVE),
+ DBG_DESC(BTCOEX_DBG_A2DP_ROLE_IS_MASTER),
+ DBG_DESC(BTCOEX_DBG_UPLINK_SEQ_NUM),
+ DBG_DESC(BTCOEX_UPLINK_AGGR_SEQ),
+ DBG_DESC(BTCOEX_DBG_TX_COMP_SEQ_NO),
+ DBG_DESC(BTCOEX_DBG_MAX_AGGR_PAUSE_STATE),
+ DBG_DESC(BTCOEX_DBG_ACL_TRAFFIC),
+ DBG_DESC(BTCOEX_CURR_AGGR_PROP),
+ DBG_DESC(BTCOEX_DBG_SCO_GET_PER_TIME_DIFF),
+ DBG_DESC(BTCOEX_PSPOLL_PROCESS),
+ DBG_DESC(BTCOEX_RETURN_FROM_MAC),
+ DBG_DESC(BTCOEX_FREED_REQUEUED_CNT),
+ DBG_DESC(BTCOEX_DBG_TOGGLE_LOW_RATES),
+ DBG_DESC(BTCOEX_MAC_GOES_TO_SLEEP),
+ DBG_DESC(BTCOEX_DBG_A2DP_NO_SYNC),
+ DBG_DESC(BTCOEX_RETURN_FROM_MAC_HOLD_Q_INFO),
+ DBG_DESC(BTCOEX_RETURN_FROM_MAC_AC),
+ DBG_DESC(BTCOEX_DBG_DTIM_RECV),
+ DBG_DESC(0),
+ DBG_DESC(BTCOEX_IS_PRE_UPDATE),
+ DBG_DESC(BTCOEX_ENQUEUED_BIT_MAP),
+ DBG_DESC(BTCOEX_TX_COMPLETE_FIRST_DESC_STATS),
+ DBG_DESC(BTCOEX_UPLINK_DESC),
+ DBG_DESC(BTCOEX_SCO_GET_PER_FIRST_FRM_TIMESTAMP),
+ DBG_DESC(0), DBG_DESC(0), DBG_DESC(0),
+ DBG_DESC(BTCOEX_DBG_RECV_ACK),
+ DBG_DESC(BTCOEX_DBG_ADDBA_INDICATION),
+ DBG_DESC(BTCOEX_TX_COMPLETE_EOL_FAILED),
+ DBG_DESC(BTCOEX_DBG_A2DP_USAGE_COMPLETE),
+ DBG_DESC(BTCOEX_DBG_A2DP_STOMP_FOR_BCN_HANDLER),
+ DBG_DESC(BTCOEX_DBG_A2DP_SYNC_INTR),
+ DBG_DESC(BTCOEX_DBG_A2DP_STOMP_FOR_BCN_RECEPTION),
+ DBG_DESC(BTCOEX_FORM_AGGR_CURR_AGGR),
+ DBG_DESC(BTCOEX_DBG_TOGGLE_A2DP_BURST_CNT),
+ DBG_DESC(BTCOEX_DBG_BT_TRAFFIC),
+ DBG_DESC(BTCOEX_DBG_STOMP_BT_TRAFFIC),
+ DBG_DESC(BTCOEX_RECV_NULL),
+ DBG_DESC(BTCOEX_DBG_A2DP_MASTER_BT_END),
+ DBG_DESC(BTCOEX_DBG_A2DP_BT_START),
+ DBG_DESC(BTCOEX_DBG_A2DP_SLAVE_BT_END),
+ DBG_DESC(BTCOEX_DBG_A2DP_STOMP_BT),
+ DBG_DESC_FMT(BTCOEX_DBG_GO_TO_SLEEP),
+ DBG_DESC(BTCOEX_DBG_A2DP_PKT),
+ DBG_DESC(BTCOEX_DBG_A2DP_PSPOLL_DATA_RECV),
+ DBG_DESC(BTCOEX_DBG_A2DP_NULL),
+ DBG_DESC(BTCOEX_DBG_UPLINK_DATA),
+ DBG_DESC(BTCOEX_DBG_A2DP_STOMP_LOW_PRIO_NULL),
+ DBG_DESC(BTCOEX_DBG_ADD_BA_RESP_TIMEOUT),
+ DBG_DESC(BTCOEX_DBG_TXQ_STATE),
+ DBG_DESC_FMT(BTCOEX_DBG_ALLOW_SCAN),
+ DBG_DESC_FMT(BTCOEX_DBG_SCAN_REQUEST),
+ DBG_DESC(0), DBG_DESC(0), DBG_DESC(0), DBG_DESC(0), DBG_DESC(0), DBG_DESC(0), DBG_DESC(0),
+ DBG_DESC(BTCOEX_A2DP_SLEEP),
+ DBG_DESC(BTCOEX_DBG_DATA_ACTIV_TIMEOUT),
+ DBG_DESC(BTCOEX_DBG_SWITCH_TO_PSPOLL_ON_MODE),
+ DBG_DESC(BTCOEX_DBG_SWITCH_TO_PSPOLL_OFF_MODE),
+ DBG_DESC(BTCOEX_DATARECEIVE_AGGR),
+ DBG_DESC(BTCOEX_DBG_DATA_RECV_SLEEPING_PENDING),
+ DBG_DESC(BTCOEX_DBG_DATARESP_TIMEOUT),
+ DBG_DESC(BTCOEX_BDG_BMISS),
+ DBG_DESC(BTCOEX_DBG_DATA_RECV_WAKEUP_TIM),
+ DBG_DESC(BTCOEX_DBG_SECOND_BMISS),
+ DBG_DESC(0),
+ DBG_DESC_FMT(BTCOEX_DBG_SET_WLAN_STATE),
+ DBG_DESC(BTCOEX_BDG_FIRST_BMISS),
+ DBG_DESC(BTCOEX_DBG_A2DP_CHAN_OP),
+ DBG_DESC(BTCOEX_DBG_A2DP_INTR),
+ DBG_DESC_FMT(BTCOEX_DBG_BT_INQUIRY),
+ DBG_DESC(BTCOEX_DBG_BT_INQUIRY_DATA_FETCH),
+ DBG_DESC(BTCOEX_DBG_POST_INQUIRY_FINISH),
+ DBG_DESC(BTCOEX_DBG_SCO_OPT_MODE_TIMER_HANDLER),
+ DBG_DESC(BTCOEX_DBG_NULL_FRAME_SLEEP),
+ DBG_DESC(BTCOEX_DBG_NULL_FRAME_AWAKE),
+ DBG_DESC(0), DBG_DESC(0), DBG_DESC(0), DBG_DESC(0),
+ DBG_DESC(BTCOEX_DBG_SET_AGGR_SIZE),
+ DBG_DESC(BTCOEX_DBG_TEAR_BA_TIMEOUT),
+ DBG_DESC(BTCOEX_DBG_MGMT_FRAME_SEQ_NO),
+ DBG_DESC(BTCOEX_DBG_SCO_STOMP_HIGH_PRI),
+ DBG_DESC(BTCOEX_DBG_COLOCATED_BT_DEV),
+ DBG_DESC(BTCOEX_DBG_FE_ANT_TYPE),
+ DBG_DESC(BTCOEX_DBG_BT_INQUIRY_CMD),
+ DBG_DESC(BTCOEX_DBG_SCO_CONFIG),
+ DBG_DESC(BTCOEX_DBG_SCO_PSPOLL_CONFIG),
+ DBG_DESC(BTCOEX_DBG_SCO_OPTMODE_CONFIG),
+ DBG_DESC(BTCOEX_DBG_A2DP_CONFIG),
+ DBG_DESC(BTCOEX_DBG_A2DP_PSPOLL_CONFIG),
+ DBG_DESC(BTCOEX_DBG_A2DP_OPTMODE_CONFIG),
+ DBG_DESC(BTCOEX_DBG_ACLCOEX_CONFIG),
+ DBG_DESC(BTCOEX_DBG_ACLCOEX_PSPOLL_CONFIG),
+ DBG_DESC(BTCOEX_DBG_ACLCOEX_OPTMODE_CONFIG),
+ DBG_DESC(BTCOEX_DBG_DEBUG_CMD),
+ DBG_DESC(BTCOEX_DBG_SET_BT_OPERATING_STATUS),
+ DBG_DESC(BTCOEX_DBG_GET_CONFIG),
+ DBG_DESC(BTCOEX_DBG_GET_STATS),
+ DBG_DESC(BTCOEX_DBG_BT_OPERATING_STATUS),
+ DBG_DESC(BTCOEX_DBG_PERFORM_RECONNECT),
+ DBG_DESC(0),
+ DBG_DESC(BTCOEX_DBG_ACL_WLAN_MED),
+ DBG_DESC(BTCOEX_DBG_ACL_BT_MED),
+ DBG_DESC(BTCOEX_DBG_WLAN_CONNECT),
+ DBG_DESC(BTCOEX_DBG_A2DP_DUAL_START),
+ DBG_DESC(BTCOEX_DBG_PMAWAKE_NOTIFY),
+ DBG_DESC(BTCOEX_DBG_BEACON_SCAN_ENABLE),
+ DBG_DESC(BTCOEX_DBG_BEACON_SCAN_DISABLE),
+ DBG_DESC(BTCOEX_DBG_RX_NOTIFY),
+ DBG_DESC(BTCOEX_SCO_GET_PER_SECOND_FRM_TIMESTAMP),
+ DBG_DESC(BTCOEX_DBG_TXQ_DETAILS),
+ DBG_DESC(BTCOEX_DBG_SCO_STOMP_LOW_PRI),
+ DBG_DESC(BTCOEX_DBG_A2DP_FORCE_SCAN),
+ DBG_DESC(BTCOEX_DBG_DTIM_STOMP_COMP),
+ DBG_DESC(BTCOEX_ACL_PRESENCE_TIMER),
+ DBG_DESC(BTCOEX_DBG_QUEUE_SELF_CTS),
+ DBG_DESC(BTCOEX_DBG_SELF_CTS_COMP),
+ DBG_DESC(BTCOEX_DBG_APMODE_WAIT_FOR_CTS_COMP_FAILED),
+ DBG_DESC(BTCOEX_DBG_APMODE_A2DP_MED_TO_BT),
+ DBG_DESC(BTCOEX_DBG_APMODE_SET_BTSTATE),
+ DBG_DESC(BTCOEX_DBG_APMODE_A2DP_STATUS),
+ DBG_DESC(BTCOEX_DBG_APMODE_SCO_CTS_HANDLER),
+ DBG_DESC(BTCOEX_DBG_APMODE_SCO_STATUS),
+ DBG_DESC(BTCOEX_DBG_APMODE_TXQ_DRAINED),
+ DBG_DESC(BTCOEX_DBG_APMODE_SCO_ARM_TIMER),
+ DBG_DESC(BTCOEX_DBG_APMODE_SWITCH_MED_TO_WLAN),
+ DBG_DESC(BTCOEX_APMODE_BCN_TX_HANDLER),
+ DBG_DESC(BTCOEX_APMODE_BCN_TX),
+ DBG_DESC(BTCOEX_APMODE_SCO_RTS_HANDLER),
+};
+
+static struct dbglog_desc pm_desc[] = {
+ DBG_DESC(0),
+ DBG_DESC(PM_INIT),
+ DBG_DESC(PM_ENABLE),
+ DBG_DESC_FMT(PM_SET_STATE),
+ DBG_DESC_FMT(PM_SET_POWERMODE),
+ DBG_DESC(PM_CONN_NOTIFY),
+ DBG_DESC(PM_REF_COUNT_NEGATIVE),
+ DBG_DESC(PM_INFRA_STA_APSD_ENABLE),
+ DBG_DESC(PM_INFRA_STA_UPDATE_APSD_STATE),
+ DBG_DESC_FMT(PM_CHAN_OP_REQ),
+ DBG_DESC_FMT(PM_SET_MY_BEACON_POLICY),
+ DBG_DESC_FMT(PM_SET_ALL_BEACON_POLICY),
+ DBG_DESC(PM_INFRA_STA_SET_PM_PARAMS1),
+ DBG_DESC(PM_INFRA_STA_SET_PM_PARAMS2),
+ DBG_DESC(PM_ADHOC_SET_PM_CAPS_FAIL),
+ DBG_DESC(PM_ADHOC_UNKNOWN_IBSS_ATTRIB_ID),
+ DBG_DESC(PM_ADHOC_SET_PM_PARAMS),
+ DBG_DESC(0),
+ DBG_DESC(PM_ADHOC_STATE1),
+ DBG_DESC(PM_ADHOC_STATE2),
+ DBG_DESC(PM_ADHOC_CONN_MAP),
+ DBG_DESC_FMT(PM_FAKE_SLEEP),
+ DBG_DESC(PM_AP_STATE1),
+ DBG_DESC(PM_AP_SET_PM_PARAMS),
+ DBG_DESC(PM_P2P_STATE1),
+};
+
+static struct dbglog_desc dummy_desc[] = {
+ DBG_DESC(0),
+};
+
+static struct module_desc modules[] = {
+ MODULE_DESC(INF, dummy_desc),
+ MODULE_DESC(WMI, wmi_desc),
+ MODULE_DESC(MISC, dummy_desc),
+ MODULE_DESC(PM, pm_desc),
+ MODULE_DESC(TXRX_MGMTBUF, mgmtbuf_desc),
+ MODULE_DESC(TXRX_TXBUF, dummy_desc),
+ MODULE_DESC(TXRX_RXBUF, dummy_desc),
+ MODULE_DESC(WOW, dummy_desc),
+ MODULE_DESC(WHAL, dummy_desc),
+ MODULE_DESC(DC, dc_desc),
+ MODULE_DESC(CO, co_desc),
+ MODULE_DESC(RO, dummy_desc),
+ MODULE_DESC(CM, dummy_desc),
+ MODULE_DESC(MGMT, dummy_desc),
+ MODULE_DESC(TMR, dummy_desc),
+ MODULE_DESC(BTCOEX, btcoex_desc),
+};
+
+static int compOid(const void *a, const void *b)
+{
+ return *(A_INT32*)a - *(A_INT32*)b;
+}
+
+static void do_check_ids(void)
+{
+ size_t m, d, td;
+ for (m = 0; m < DBGLOG_MODULEID_NUM_MAX; ++m) {
+ size_t mlen;
+ struct dbglog_desc *dlog;
+ if (m >= ARRAY_SIZE(modules)) {
+ printf("module id %d does not matched\n", m);
+ break;
+ }
+ dlog = modules[m].descs;
+ mlen = modules[m].len;
+ d=td=1;
+ while (dlog && (d<mlen||dbglog_id_tag[m][td][0]!='\0')) {
+ if (d>=mlen) {
+ if (dlog != dummy_desc) {
+ printf("m %s dbgid %s(%d) is larger than max internal table %d host/firmware mismatch?\n",
+ modules[m].name, dbglog_id_tag[m][td], td, mlen);
+ }
+ break;
+ }
+
+ if (dbglog_id_tag[m][td][0]=='\0' && dlog[d].oid!=0) {
+ for (;td < DBGLOG_DBGID_NUM_MAX && dbglog_id_tag[m][td][0]=='\0'; ++td);
+ }
+ if (strcmp(dbglog_id_tag[m][td], dlog[d].desc)!=0 && dlog[d].oid!=0) {
+ printf("debug id does not matched '%s' <> '%s'\n", dbglog_id_tag[m][td], dlog[d].desc);
+ break;
+ } else {
+ if (td!=d && !modules[m].bsearch) {
+ printf("Module %s debugid %s(%d) mismatched. using binary search for debugid",
+ modules[m].name, dbglog_id_tag[m][td], td);
+ modules[m].bsearch = 1;
+ }
+ }
+ ++d; ++td;
+ }
+ if (modules[m].bsearch && dlog) {
+ qsort(dlog, mlen, sizeof(dlog[0]), compOid);
+ }
+ }
+ check_ids = 1;
+}
+
+static DbgLogFormatter getFormatter(A_INT32 moduleid, A_INT32 debugid)
+{
+ if (!check_ids) {
+ do_check_ids();
+ }
+
+ if ( moduleid < ARRAY_SIZE(modules)) {
+ const struct module_desc *m = &modules[moduleid];
+ if (m->descs ) {
+ if (m->bsearch){
+ struct dbglog_desc *d;
+ d = (struct dbglog_desc*)bsearch(&debugid, m->descs, m->len, sizeof(m->descs[0]), compOid);
+ return d ? d->formatter : NULL;
+ } else if (debugid>0 && debugid<m->len) {
+ return m->descs[debugid].formatter;
+ }
+ }
+ }
+ return NULL;
+}
+
+int dbg_formater(int lv, char *output, size_t len, A_UINT32 ts, A_INT32 *logbuf)
+{
+ int ret = 0;
+ A_UINT32 idx, last_idx;
+ A_UINT32 debugid = DBGLOG_GET_DBGID(logbuf[0]);
+ A_UINT32 moduleid = DBGLOG_GET_MODULEID(logbuf[0]);
+ A_UINT32 numargs = DBGLOG_GET_NUMARGS(logbuf[0]);
+ A_UINT32 timestamp = DBGLOG_GET_TIMESTAMP(logbuf[0]);
+ DbgLogFormatter dbgFormatter = NULL;
+
+ if (numargs>2) {
+ return ret;
+ }
+
+ if (lv > 0) {
+ dbgFormatter = getFormatter(moduleid, debugid);
+ }
+
+ if (ts>0) {
+ if (lv == 0) {
+ ret += snprintf(output+ret, len-ret, "%8d: ", ts);
+ } else {
+ ret += strftime(output+ret, len-ret, "%m-%d %H:%M:%S ", gmtime((time_t*)&ts));
+ }
+ }
+ ret += snprintf(output+ret, len-ret, "(%05d) %s", timestamp, dbglog_id_tag[moduleid][debugid]);
+ if (lv>1 || lv == 0 || !dbgFormatter) {
+
+ if(numargs == 1 && !strcmp(dbglog_id_tag[moduleid][debugid], "WMI_EVENT_SEND"))
+ {
+ idx = 0;
+ last_idx = ARRAY_SIZE(dbg_wmi_event_str);
+ for(idx = 0 ; idx < last_idx ; idx++) {
+ if(dbg_wmi_event_str[idx].id == logbuf[1]) {
+ break;
+ }
+ }
+ if(idx < last_idx) {
+ ret += snprintf(output+ret, len-ret, ": 0x%04x\t\t--- %s",
+ logbuf[1], dbg_wmi_event_str[idx].str );
+ } else {
+ ret += snprintf(output+ret, len-ret, ": 0x%04x", logbuf[1]);
+ }
+ } else if(numargs == 2 && !strcmp(dbglog_id_tag[moduleid][debugid], "WMI_CMD_RX")) {
+ idx = 0;
+ last_idx = ARRAY_SIZE(dbg_wmi_cmd_str);
+ for(idx = 0 ; idx < last_idx ; idx++) {
+ if(dbg_wmi_cmd_str[idx].id == logbuf[1])
+ break;
+ }
+ if(idx < last_idx) {
+ ret += snprintf(output+ret, len-ret, ": 0x%02x, 0x%02x\t\t+++ %s",
+ logbuf[1], logbuf[2], dbg_wmi_cmd_str[idx].str );
+ } else {
+ ret += snprintf(output+ret, len-ret, ": 0x%02x, 0x%02x",
+ logbuf[1], logbuf[2]);
+ }
+ } else {
+ if (numargs>0) {
+ ret += snprintf(output+ret, len-ret, ": 0x%x", logbuf[1]);
+ }
+ if (numargs>1) {
+ ret += snprintf(output+ret, len-ret, ", 0x%x", logbuf[2]);
+ }
+ if (dbgFormatter && numargs>0 && lv > 0) {
+ ret += snprintf(output+ret, len-ret, ", ");
+ }
+ }
+ } else {
+ ret += snprintf(output+ret, len-ret, ": ");
+ }
+
+ if (dbgFormatter && lv > 0) {
+ int pos = ret;
+ int addlen;
+ addlen = dbgFormatter(output+ret, len-ret, numargs, logbuf);
+ if (addlen>0) {
+ ret += addlen;
+ } else if (lv<=1) {
+ /* skip this message */
+ (void)pos;
+ return 0;
+ }
+ }
+ ret += snprintf(output+ret, len-ret, "\n");
+ return ret;
+}
+
diff --git a/host/tools/dbgParser/dbgParser b/host/tools/dbgParser/dbgParser
new file mode 100755
index 0000000..5a9ed9e
--- /dev/null
+++ b/host/tools/dbgParser/dbgParser
Binary files differ
diff --git a/host/tools/dbgParser/dbgParser.c b/host/tools/dbgParser/dbgParser.c
new file mode 100644
index 0000000..f499dcb
--- /dev/null
+++ b/host/tools/dbgParser/dbgParser.c
@@ -0,0 +1,502 @@
+/*
+ * Copyright (c) 2006 Atheros Communications Inc.
+ * All rights reserved.
+ *
+ *
+ *
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+//
+//
+ *
+ */
+
+/* This tool parses the recevent logs stored in the binary format
+ by the wince athsrc */
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <string.h>
+#include <errno.h>
+#include <getopt.h>
+#include <time.h>
+#include <asm/types.h>
+#include <sys/types.h>
+#include <sys/ioctl.h>
+#include <sys/socket.h>
+#include <linux/netlink.h>
+#include <linux/rtnetlink.h>
+#include <linux/types.h>
+#include <linux/if.h>
+#include <linux/wireless.h>
+#include <a_config.h>
+#include <a_osapi.h>
+#include <a_types.h>
+#include <athdefs.h>
+#include <ieee80211.h>
+#include <wmi.h>
+#include <athdrv_linux.h>
+#include <dbglog_api.h>
+
+#undef DEBUG
+#undef DBGLOG_DEBUG
+
+#define ID_LEN 2
+#define FILENAME_LENGTH_MAX 128
+#define DBGLOG_FILE "dbglog.h"
+#define DBGLOGID_FILE "dbglog_id.h"
+#define DBGLOG_OUTPUT_FILE "dbglog.out"
+
+const A_CHAR *progname;
+A_CHAR dbglogfile[FILENAME_LENGTH_MAX];
+A_CHAR dbglogidfile[FILENAME_LENGTH_MAX];
+A_CHAR dbglogoutfile[FILENAME_LENGTH_MAX];
+A_CHAR dbgloginfile[FILENAME_LENGTH_MAX];
+FILE *fpout;
+FILE *fpin;
+int fmtlv;
+int outfmt; /* 0: raw, 1: html 2: RTF */
+int headerlen;
+int noSystime;
+
+A_CHAR dbglog_id_tag[DBGLOG_MODULEID_NUM_MAX][DBGLOG_DBGID_NUM_MAX][DBGLOG_DBGID_DEFINITION_LEN_MAX];
+
+#define AR6K_MAX_DBG_BUFFER_SIZE 1500
+
+struct dbg_binary_record {
+ A_UINT32 ts;
+ A_UINT32 length;
+ A_UINT8 log[AR6K_MAX_DBG_BUFFER_SIZE];
+};
+
+struct dbg_binary_header {
+ A_UINT8 sig;
+ A_UINT8 ver;
+ A_UINT16 len;
+ A_UINT32 reserved;
+};
+
+
+#ifdef DEBUG
+A_INT32 debugRecEvent = 0;
+#define RECEVENT_DEBUG_PRINTF(args...) if (debugRecEvent) printf(args);
+#else
+#define RECEVENT_DEBUG_PRINTF(args...)
+#endif
+
+static const A_CHAR htmlHeader[] = "<br/><style type='text/css'>\
+.m0 { color:#ff0000; }\
+.m1 { color:#0000FF; }\
+.m2 { color:#8d8d8d; }\
+.m3 { color:#000000; }\
+.m4 { color:#a11693; }\
+.m5 { color:#b452ab; }\
+.m6 { color:#d18eca; }\
+.m7 { color:#ff3205; }\
+.m8 { color:#ff2428; }\
+.m9 { color:#d700b4; }\
+.m10 { color:#ffe20e; }\
+.m11 { color:#ff0072; }\
+.m12 { color:#00a700; }\
+.m13 { color:#437197; }\
+.m14 { color:#e64248; }\
+.m15 { color:#5a1484; }\
+</style>\n";
+
+static const A_CHAR htmlFooter[] = "";
+
+static const A_CHAR rtfHeader[] = "{\\rtf1\\ansi\\deff0{\\fonttbl\\f0\\fswiss Helvetica;}\n\
+{\\colortbl \\red255\\green0\\blue0;\
+\\red0\\green0\\blue255;\
+\\red141\\green141\\blue141;\
+\\red0\\green0\\blue0;\
+\\red161\\green22\\blue147;\
+\\red180\\green82\\blue171;\
+\\red209\\green142\\blue202;\
+\\red255\\green50\\blue5;\
+\\red255\\green36\\blue40;\
+\\red215\\green0\\blue180;\
+\\red255\\green226\\blue14;\
+\\red255\\green0\\blue114;\
+\\red0\\green167\\blue0;\
+\\red67\\green113\\blue151;\
+\\red230\\green66\\blue72;\
+\\red90\\green20\\blue132;\
+}\\f0\\cf3 ";
+
+static const A_CHAR rtfFooter[] = "}";
+
+A_INT32
+string_search(FILE *fp, A_CHAR *string)
+{
+ A_CHAR str[DBGLOG_DBGID_DEFINITION_LEN_MAX];
+
+ rewind(fp);
+ memset(str, 0, DBGLOG_DBGID_DEFINITION_LEN_MAX);
+ while (!feof(fp)) {
+ if (fgets(str, sizeof(str), fp)) {
+ if (strstr(str, string)) return 1;
+ }
+ }
+
+ return 0;
+}
+
+void
+get_module_name(A_CHAR *string, A_CHAR *dest)
+{
+ A_CHAR *str1, *str2;
+ A_CHAR str[DBGLOG_DBGID_DEFINITION_LEN_MAX];
+
+ memset(str, 0, DBGLOG_DBGID_DEFINITION_LEN_MAX);
+ strcpy(str, string);
+ str1 = strtok(str, "_");
+ while ((str2 = strtok(NULL, "_"))) {
+ str1 = str2;
+ }
+
+ strcpy(dest, str1);
+}
+
+#ifdef DBGLOG_DEBUG
+void
+dbglog_print_id_tags(void)
+{
+ A_INT32 i, j;
+
+ for (i = 0; i < DBGLOG_MODULEID_NUM_MAX; i++) {
+ for (j = 0; j < DBGLOG_DBGID_NUM_MAX; j++) {
+ printf("[%d][%d]: %s\n", i, j, dbglog_id_tag[i][j]);
+ }
+ }
+}
+#endif /* DBGLOG_DEBUG */
+
+A_INT32
+dbglog_generate_id_tags(void)
+{
+ A_INT32 id1, id2;
+ FILE *fp1, *fp2;
+ A_CHAR str1[DBGLOG_DBGID_DEFINITION_LEN_MAX];
+ A_CHAR str2[DBGLOG_DBGID_DEFINITION_LEN_MAX];
+ A_CHAR str3[DBGLOG_DBGID_DEFINITION_LEN_MAX];
+
+ if (!(fp1 = fopen(dbglogfile, "r"))) {
+ perror(dbglogfile);
+ return -1;
+ }
+
+ if (!(fp2 = fopen(dbglogidfile, "r"))) {
+ fclose(fp1);
+ perror(dbglogidfile);
+ return -1;
+ }
+
+ memset(dbglog_id_tag, 0, sizeof(dbglog_id_tag));
+ if (string_search(fp1, "DBGLOG_MODULEID_START")) {
+ int ret = fscanf(fp1, "%s %s %d", str1, str2, &id1);
+ do {
+ memset(str3, 0, DBGLOG_DBGID_DEFINITION_LEN_MAX);
+ get_module_name(str2, str3);
+ strcat(str3, "_DBGID_DEFINITION_START");
+ if (string_search(fp2, str3)) {
+ memset(str3, 0, DBGLOG_DBGID_DEFINITION_LEN_MAX);
+ get_module_name(str2, str3);
+ strcat(str3, "_DBGID_DEFINITION_END");
+ ret = fscanf(fp2, "%s %s %d", str1, str2, &id2);
+ while (!(strstr(str2, str3))) {
+ strcpy((A_CHAR *)&dbglog_id_tag[id1][id2], str2);
+ ret= fscanf(fp2, "%s %s %d", str1, str2, &id2);
+ }
+ }
+ ret = fscanf(fp1, "%s %s %d", str1, str2, &id1);
+ } while (!(strstr(str2, "DBGLOG_MODULEID_END")));
+ }
+
+ fclose(fp2);
+ fclose(fp1);
+
+ return 0;
+}
+
+static void
+usage(void)
+{
+const char options[] =
+"Options:\n\
+-d, --srcdir=<Directory containing the dbglog header files> [Optional]\n\
+-f, --fileformat 0:plain text, 1:HTML, 2:RTF \n\
+-s, --nosystime Don't print out system time\n\
+-t, --format 0:Raw, 1:brief, 2:full [0 by default]\n";
+
+ fprintf(stderr, "usage:\n%s [options] <input log file> <output file>\n", progname);
+ fprintf(stderr, "%s", options);
+ exit(-1);
+}
+
+static A_INT32
+decode_debug_rec(struct dbg_binary_record *dbg_rec)
+{
+#define BUF_SIZE 512
+ A_UINT32 count;
+ A_UINT32 numargs;
+ A_INT32 *buffer;
+ A_UINT32 length;
+ A_CHAR buf[BUF_SIZE];
+ A_UINT32 curpos;
+ static A_INT32 numOfRec = 0;
+ A_INT32 len;
+ char outputBuf[2048];
+
+#ifdef DBGLOG_DEBUG
+ RECEVENT_DEBUG_PRINTF("Application received target debug event: %d\n", len);
+#endif /* DBGLOG_DEBUG */
+ count = 0;
+ len = dbg_rec->length;
+ length = (len >> 2);
+ buffer = (A_INT32 *)dbg_rec->log;
+
+ while (count < length) {
+ A_INT32 lret, oret;
+ A_UINT32 moduleid = DBGLOG_GET_MODULEID(buffer[count]);
+ numargs = DBGLOG_GET_NUMARGS(buffer[count]);
+ oret = 0;
+ if (outfmt==1) {
+ oret += snprintf(outputBuf+oret, sizeof(outputBuf)-oret,
+ "<span class='m%d'>", moduleid);
+ } else if (outfmt==2) {
+ oret += snprintf(outputBuf+oret, sizeof(outputBuf)-oret,
+ "\\cf%d ", moduleid);
+ }
+ lret=dbg_formater(fmtlv, outputBuf+oret, sizeof(outputBuf)-oret,
+ noSystime ? 0 : dbg_rec->ts, &buffer[count]);
+ if ( lret > 0) {
+#ifdef DBGLOG_DEBUG
+ RECEVENT_DEBUG_PRINTF("%s", outputBuf+oret);
+#endif /* DBGLOG_DEBUG */
+
+ oret += lret;
+ if (outfmt==1) {
+ oret += snprintf(outputBuf+oret, sizeof(outputBuf)-oret, "</span><br/>");
+ } else if (outfmt==2) {
+ oret += snprintf(outputBuf+oret, sizeof(outputBuf)-oret, "\\par");
+ }
+ fprintf(fpout, "%s", outputBuf);
+ }
+ count += (numargs + 1);
+
+ numOfRec++;
+ }
+
+ /* Update the last rec at the top of file */
+ curpos = ftell(fpout);
+ if( fgets(buf, BUF_SIZE, fpout) ) {
+ buf[BUF_SIZE - 1] = 0; /* In case string is longer from logs */
+ length = strlen(buf);
+ memset(buf, ' ', length-1);
+ buf[length] = 0;
+ fseek(fpout, curpos, SEEK_SET);
+ fprintf(fpout, "%s", buf);
+ }
+
+ rewind(fpout);
+ /* Update last record */
+ fseek(fpout, headerlen, SEEK_SET);
+ fprintf(fpout, "%08d\n", numOfRec);
+ fseek(fpout, curpos, SEEK_SET);
+ fflush(fpout);
+
+#undef BUF_SIZE
+ return 0;
+}
+
+A_INT32 main(A_INT32 argc, A_CHAR** argv)
+{
+ A_CHAR *workarea = NULL;
+ struct dbg_binary_record dbg_rec;
+ A_UINT32 min_ts;
+ A_INT32 min_rec_num;
+ A_UINT32 rec_num;
+ A_INT32 i;
+ struct dbg_binary_header dbg_header;
+ A_UINT16 dbg_rec_len;
+ A_UINT16 dbg_header_len;
+
+ progname = argv[0];
+ memset(dbgloginfile, 0, FILENAME_LENGTH_MAX);
+ memset(dbglogoutfile, 0, FILENAME_LENGTH_MAX);
+
+ while (1) {
+ int option_index = 0;
+ int c;
+ static struct option long_options[] = {
+ {"srcdir", 1, NULL, 'd'},
+ {"format", 1, NULL, 't'},
+ {"fileformat", 1, NULL, 'f'},
+ {"nosystime", 0, NULL, 's'},
+ {0, 0, 0, 0}
+ };
+ c = getopt_long (argc, argv, "d:t:f:s", long_options, &option_index);
+ if (c == -1) break;
+
+ switch (c) {
+ case 'd':
+ workarea = optarg;
+ break;
+ case 't':
+ fmtlv = atoi(optarg);
+ break;
+ case 'f':
+ outfmt = atoi(optarg);
+ break;
+ case 's':
+ noSystime = 1;
+ break;
+ default:
+ usage();
+ }
+ }
+
+ if (!workarea) {
+ workarea = getenv("WORKAREA");
+ }
+
+ if (workarea == NULL) {
+ printf("export WORKAREA or use -d option\n");
+ return -1;
+ }
+ if ((argc - optind)<2) {
+ usage();
+ return -1;
+ }
+ /* Get the file name for dbglog header file */
+ memset(dbglogfile, 0, FILENAME_LENGTH_MAX);
+ strcpy(dbglogfile, workarea);
+ strcat(dbglogfile, "/include/");
+ strcat(dbglogfile, DBGLOG_FILE);
+
+ /* Get the file name for dbglog id header file */
+ memset(dbglogidfile, 0, FILENAME_LENGTH_MAX);
+ strcpy(dbglogidfile, workarea);
+ strcat(dbglogidfile, "/include/");
+ strcat(dbglogidfile, DBGLOGID_FILE);
+
+ /* Get the file name for dbglog input file */
+ memset(dbgloginfile, 0, FILENAME_LENGTH_MAX);
+ strcpy(dbgloginfile, argv[optind]);
+ if (!(fpin = fopen(dbgloginfile, "rb"))) {
+ perror(dbgloginfile);
+ return -1;
+ }
+
+ /* Get the file name for dbglog output file */
+ memset(dbglogoutfile, 0, FILENAME_LENGTH_MAX);
+ strcpy(dbglogoutfile, argv[optind+1]);
+ if (!(fpout = fopen(dbglogoutfile, "w+"))) {
+ perror(dbglogoutfile);
+ return -1;
+ }
+
+
+ /* first 8 bytes are to indicate the last record */
+ switch (outfmt) {
+ case 1:
+ headerlen = strlen(htmlHeader);
+ break;
+ case 2:
+ headerlen = strlen(rtfHeader);
+ break;
+ default:
+ headerlen = 0;
+ break;
+ }
+ if (outfmt==1) {
+ fprintf(fpout, "%s", htmlHeader);
+ } else if (outfmt==2) {
+ fprintf(fpout, "%s", rtfHeader);
+ }
+ fseek(fpout, headerlen + 8, SEEK_SET);
+ fprintf(fpout, "\n");
+
+ dbglog_generate_id_tags();
+#ifdef DBGLOG_DEBUG
+ dbglog_print_id_tags();
+#endif /* DBGLOG_DEBUG */
+
+ /* first 8 bytes are header */
+ if (fread(&dbg_header, sizeof(struct dbg_binary_header), 1, fpin)!=1) {
+ perror("dbg_header mismatch\n");
+ return -1;
+ }
+
+ /* check header signature */
+ dbg_rec_len = sizeof(A_UINT32) * 2;
+ if (dbg_header.sig == 0xDB) {
+ dbg_rec_len += dbg_header.len;
+ dbg_header_len = 8;
+ } else {
+ /* header not present; assume max size */
+ dbg_rec_len += AR6K_MAX_DBG_BUFFER_SIZE;
+ dbg_header_len = 0;
+ }
+
+ /* go past header */
+ fseek(fpin, dbg_header_len , SEEK_SET);
+
+ min_ts = 0xFFFFFFFF;
+ rec_num = 0;
+ min_rec_num = 0;
+ while (!feof(fpin)) {
+ if (fread (&dbg_rec, dbg_rec_len, 1, fpin)) {
+ if (dbg_rec.ts < min_ts) {
+ min_ts = dbg_rec.ts;
+ min_rec_num = rec_num;
+ }
+ rec_num++;
+ }
+ }
+
+ /* go past header */
+ fseek(fpin, dbg_header_len , SEEK_SET);
+
+ // Goto the first min record
+ fseek(fpin, min_rec_num * dbg_rec_len , SEEK_CUR);
+ while (!feof(fpin)) {
+ if (fread (&dbg_rec, dbg_rec_len, 1, fpin)) {
+ decode_debug_rec(&dbg_rec);
+ }
+ }
+
+ /* go past header */
+ fseek(fpin, dbg_header_len , SEEK_SET);
+
+ for (i=0;i<min_rec_num;i++) {
+ if (fread (&dbg_rec, dbg_rec_len, 1, fpin)) {
+ decode_debug_rec(&dbg_rec);
+ } else {
+ break;
+ }
+ }
+
+ if (outfmt==1) {
+ fprintf(fpout, "%s", htmlFooter);
+ } else if (outfmt==2) {
+ fprintf(fpout, "%s", rtfFooter);
+ }
+
+ fclose(fpin);
+ fclose(fpout);
+ return 0;
+}
+
diff --git a/host/tools/dbgParser/dbg_cmd_evt.h b/host/tools/dbgParser/dbg_cmd_evt.h
new file mode 100644
index 0000000..bc1ec06
--- /dev/null
+++ b/host/tools/dbgParser/dbg_cmd_evt.h
@@ -0,0 +1,264 @@
+#ifndef _DBG_CMD_EVT_H_
+#define _DBG_CMD_EVT_H_
+
+#include <wmi.h>
+
+struct dbg_id_str_entry {
+ A_UINT16 id;
+ A_CHAR *str;
+};
+
+static struct dbg_id_str_entry dbg_wmi_cmd_str[] = {
+ {WMI_CONNECT_CMDID, "CONNECT"},
+ {WMI_RECONNECT_CMDID, "RECONNECT"},
+ {WMI_DISCONNECT_CMDID, "DISCONNECT"},
+ {WMI_SYNCHRONIZE_CMDID, "SYNCHRONIZE"},
+ {WMI_CREATE_PSTREAM_CMDID, "CREATE_PSTREAM"},
+ {WMI_DELETE_PSTREAM_CMDID, "DELETE_PSTREAM"},
+ {WMI_START_SCAN_CMDID, "START_SCAN"},
+ {WMI_SET_SCAN_PARAMS_CMDID, "SET_SCAN_PARAMS"},
+ {WMI_SET_BSS_FILTER_CMDID, "SET_BSS_FILTER"},
+ {WMI_SET_PROBED_SSID_CMDID, "SET_PROBE_SSID"},
+ {WMI_SET_LISTEN_INT_CMDID, "SET_LISTEN_INT"},
+ {WMI_SET_BMISS_TIME_CMDID, "SET_BMISS_TIME"},
+ {WMI_SET_DISC_TIMEOUT_CMDID, "SET_DISC_TIMEOUT"},
+ {WMI_GET_CHANNEL_LIST_CMDID, "GET_CHANNEL_LIST"},
+ {WMI_SET_BEACON_INT_CMDID, "SET_BEACON_INT"},
+ {WMI_GET_STATISTICS_CMDID, "GET_STATISTICS"},
+ {WMI_SET_CHANNEL_PARAMS_CMDID, "SET_CHANNEL_PARAMS"},
+ {WMI_SET_POWER_MODE_CMDID, "SET_POWER_MODE"},
+ {WMI_SET_IBSS_PM_CAPS_CMDID, "IBSS_PM_CAPS"},
+ {WMI_SET_POWER_PARAMS_CMDID, "SET_POWER_PARAMS"},
+ {WMI_SET_POWERSAVE_TIMERS_POLICY_CMDID, "SET_POWERSAVE_TIMERS_POLICY"},
+ {WMI_ADD_CIPHER_KEY_CMDID, "ADD_CIPHER_KEY"},
+ {WMI_DELETE_CIPHER_KEY_CMDID, "DELETE_CIPHER_KEY"},
+ {WMI_ADD_KRK_CMDID, "ADD_KRK"},
+ {WMI_DELETE_KRK_CMDID, "DELETE_KRK"},
+ {WMI_SET_PMKID_CMDID, "SET_PMKID"},
+ {WMI_SET_TX_PWR_CMDID, "SET_TX_PWR"},
+ {WMI_GET_TX_PWR_CMDID, "GET_TX_PWR"},
+ {WMI_SET_ASSOC_INFO_CMDID, "SET_ASSOC_INFO"},
+ {WMI_ADD_BAD_AP_CMDID, "ADD_BAD_AP"},
+ {WMI_DELETE_BAD_AP_CMDID, "DELETE_BAD_AP"},
+ {WMI_SET_TKIP_COUNTERMEASURES_CMDID, "SET_TKIP_COUNTERMEASURESS"},
+ {WMI_RSSI_THRESHOLD_PARAMS_CMDID, "RSSI_THRESHOLD_PARAMS"},
+ {WMI_TARGET_ERROR_REPORT_BITMASK_CMDID, "TARGET_ERROR_REPORT_BITMASK"},
+ {WMI_SET_ACCESS_PARAMS_CMDID, "SET_ACCESS_PARAMS"},
+ {WMI_SET_RETRY_LIMITS_CMDID, "SET_RETRY_LIMITS"},
+ {WMI_RESERVED1, "SET_OPT_MODE"},
+ {WMI_RESERVED2, "OPT_TX_FRAME"},
+ {WMI_SET_VOICE_PKT_SIZE_CMDID, "SET_VOICE_PKT_SIZE"},
+ {WMI_SET_MAX_SP_LEN_CMDID, "SET_MAX_SP_LEN"},
+ {WMI_SET_ROAM_CTRL_CMDID, "SET_ROAM_CTRL"},
+ {WMI_GET_ROAM_TBL_CMDID, "GET_ROAM_TBL"},
+ {WMI_GET_ROAM_DATA_CMDID, "GET_ROAM_DATA"},
+ {WMI_ENABLE_RM_CMDID, "ENABLE_RM"},
+ {WMI_SET_MAX_OFFHOME_DURATION_CMDID, "SET_MAX_OFFHOME_DURATION"},
+ {WMI_EXTENSION_CMDID, "EXTENSION"},
+ {WMI_SNR_THRESHOLD_PARAMS_CMDID, "SNR_THRESHOLD_PARAMS"},
+ {WMI_LQ_THRESHOLD_PARAMS_CMDID, "LQ_THRESHOLD_PARAMS"},
+ {WMI_SET_LPREAMBLE_CMDID, "SET_LPREAMBLE"},
+ {WMI_SET_RTS_CMDID, "SET_RTS"},
+ {WMI_CLR_RSSI_SNR_CMDID, "CLR_RSSI_SNR"},
+ {WMI_SET_FIXRATES_CMDID, "SET_FIXRATES"},
+ {WMI_GET_FIXRATES_CMDID, "GET_FIXRATES"},
+ {WMI_SET_AUTH_MODE_CMDID, "SET_AUTH_MODE"},
+ {WMI_SET_REASSOC_MODE_CMDID, "SET_REASSOC_MODE"},
+ {WMI_SET_WMM_CMDID, "SET_WMM"},
+ {WMI_SET_WMM_TXOP_CMDID, "SET_WMM_TXOP"},
+ {WMI_TEST_CMDID, "TEST"},
+ {WMI_SET_BT_STATUS_CMDID, "SET_BT_STATUS"},
+ {WMI_SET_BT_PARAMS_CMDID, "SET_BT_PARAMS"},
+ {WMI_SET_KEEPALIVE_CMDID, "SET_KEEPALIVE"},
+ {WMI_GET_KEEPALIVE_CMDID, "GET_KEEPALIVE"},
+ {WMI_SET_APPIE_CMDID, "SET_APPIE"},
+ {WMI_GET_APPIE_CMDID, "GET_APPIE"},
+ {WMI_SET_WSC_STATUS_CMDID, "SET_WSC_STATUS"},
+ {WMI_SET_HOST_SLEEP_MODE_CMDID, "SET_HOST_SLEEP_MODE"},
+ {WMI_SET_WOW_MODE_CMDID, "SET_WOW_MODE"},
+ {WMI_GET_WOW_LIST_CMDID, "GET_WOW_LIST"},
+ {WMI_ADD_WOW_PATTERN_CMDID, "ADD_WOW_PATTERN"},
+ {WMI_DEL_WOW_PATTERN_CMDID, "DEL_WOW_PATTERN"},
+ {WMI_SET_FRAMERATES_CMDID, "SET_FRAMERATES"},
+ {WMI_SET_AP_PS_CMDID, "SET_AP_PS"},
+ {WMI_SET_QOS_SUPP_CMDID, "SET_QOS_SUPP"},
+ {WMI_THIN_RESERVED_START, "THIN_RESERVED_START"},
+ {WMI_THIN_RESERVED_END, "THIN_RESERVED_END"},
+ {WMI_SET_BITRATE_CMDID, "SET_BITRATE"},
+ {WMI_GET_BITRATE_CMDID, "GET_BITRATE"},
+ {WMI_SET_WHALPARAM_CMDID, "SET_WHALPARAM"},
+ {WMI_SET_MAC_ADDRESS_CMDID, "SET_MAC_ADDRESS"},
+ {WMI_SET_AKMP_PARAMS_CMDID, "SET_AKMP_PARAMS"},
+ {WMI_SET_PMKID_LIST_CMDID, "SET_PMKID_LIST"},
+ {WMI_GET_PMKID_LIST_CMDID, "GET_PMKID_LIST"},
+ {WMI_ABORT_SCAN_CMDID, "ABORT_SCAN"},
+ {WMI_SET_TARGET_EVENT_REPORT_CMDID, "SET_TARGET_EVENT_REPORT"},
+ {WMI_UNUSED1, "UNUSED1"},
+ {WMI_UNUSED2, "UNUSED2"},
+ {WMI_AP_HIDDEN_SSID_CMDID, "AP_HIDDEN_SSID"},
+ {WMI_AP_SET_NUM_STA_CMDID, "AP_SET_NUM_STA"},
+ {WMI_AP_ACL_POLICY_CMDID, "AP_ACL_POLICY"},
+ {WMI_AP_ACL_MAC_LIST_CMDID, "AP_ACL_MAC_LIST"},
+ {WMI_AP_CONFIG_COMMIT_CMDID, "AP_CONFIG_COMMIT"},
+ {WMI_AP_SET_MLME_CMDID, "AP_SET_MLME"},
+ {WMI_AP_SET_PVB_CMDID, "AP_SET_PVB"},
+ {WMI_AP_CONN_INACT_CMDID, "AP_CONN_INACT"},
+ {WMI_AP_PROT_SCAN_TIME_CMDID, "AP_PROT_SCAN_TIME"},
+ {WMI_AP_SET_COUNTRY_CMDID, "AP_SET_COUNTRY"},
+ {WMI_AP_SET_DTIM_CMDID, "AP_SET_DTIM"},
+ {WMI_AP_MODE_STAT_CMDID, "AP_MODE_STAT"},
+ {WMI_SET_IP_CMDID, "SET_IP"},
+ {WMI_SET_PARAMS_CMDID, "SET_PARAMS"},
+ {WMI_SET_MCAST_FILTER_CMDID, "SET_MCAST_FILTER"},
+ {WMI_DEL_MCAST_FILTER_CMDID, "DEL_MCAST_FILTER"},
+ {WMI_ALLOW_AGGR_CMDID, "ALLOW_AGGR"},
+ {WMI_ADDBA_REQ_CMDID, "ADDBA_REQ"},
+ {WMI_DELBA_REQ_CMDID, "DELBA_REQ"},
+ {WMI_SET_HT_CAP_CMDID, "SET_HT_CAP"},
+ {WMI_SET_HT_OP_CMDID, "SET_HT_OP"},
+ {WMI_SET_TX_SELECT_RATES_CMDID, "SET_TX_SELECT_RATES"},
+ {WMI_SET_TX_SGI_PARAM_CMDID, "SET_TX_SGI_PARAM"},
+ {WMI_SET_RATE_POLICY_CMDID, "SET_RATE_POLICY"},
+ {WMI_HCI_CMD_CMDID, "HCI_CMD"},
+ {WMI_RX_FRAME_FORMAT_CMDID, "RX_FRAME_FORMAT"},
+ {WMI_SET_THIN_MODE_CMDID, "SET_THIN_MODE"},
+ {WMI_SET_BT_WLAN_CONN_PRECEDENCE_CMDID, "SET_BT_WLAN_CONN_PRECEDENCE"},
+ {WMI_AP_SET_11BG_RATESET_CMDID, "AP_SET_11BG_RATESET"},
+ {WMI_SET_PMK_CMDID, "SET_PMK"},
+ {WMI_MCAST_FILTER_CMDID, "MCAST_FILTER"},
+ {WMI_SET_BTCOEX_FE_ANT_CMDID, "SET_BTCOEX_FE_ANT"},
+ {WMI_SET_BTCOEX_COLOCATED_BT_DEV_CMDID, "SET_BTCOEX_COLOCATED_BT_DEV"},
+ {WMI_SET_BTCOEX_SCO_CONFIG_CMDID, "SET_BTCOEX_SCO_CONFIG"},
+ {WMI_SET_BTCOEX_A2DP_CONFIG_CMDID, "SET_BTCOEX_A2DP_CONFIG"},
+ {WMI_SET_BTCOEX_ACLCOEX_CONFIG_CMDID, "SET_BTCOEX_ACLCOEX_CONFIG"},
+ {WMI_SET_BTCOEX_BTINQUIRY_PAGE_CONFIG_CMDID, "SET_BTCOEX_BTINQUIRY_PAGE_CONFIG"},
+ {WMI_SET_BTCOEX_DEBUG_CMDID, "SET_BTCOEX_DEBUG"},
+ {WMI_SET_BTCOEX_BT_OPERATING_STATUS_CMDID, "SET_BTCOEX_BT_OPERATING_STATUS"},
+ {WMI_GET_BTCOEX_STATS_CMDID, "GET_BTCOEX_STATS"},
+ {WMI_GET_BTCOEX_CONFIG_CMDID, "GET_BTCOEX_CONFIG"},
+ {WMI_SET_DFS_ENABLE_CMDID, "SET_DFS_ENABLE"},
+ {WMI_SET_DFS_MINRSSITHRESH_CMDID, "SET_DFS_MINRSSITHRESH"},
+ {WMI_SET_DFS_MAXPULSEDUR_CMDID, "SET_DFS_MAXPULSEDUR"},
+ {WMI_DFS_RADAR_DETECTED_CMDID, "DFS_RADAR_DETECTED"},
+ {WMI_P2P_SET_CONFIG_CMDID, "P2P_SET_CONFIG"},
+ {WMI_WPS_SET_CONFIG_CMDID, "WPS_SET_CONFIG"},
+ {WMI_SET_REQ_DEV_ATTR_CMDID, "SET_REQ_DEV_ATTR"},
+ {WMI_P2P_FIND_CMDID, "P2P_FIND"},
+ {WMI_P2P_STOP_FIND_CMDID, "P2P_STOP_FIND"},
+ {WMI_P2P_GO_NEG_START_CMDID, "P2P_GO_NEG_START"},
+ {WMI_P2P_LISTEN_CMDID, "P2P_LISTEN"},
+ {WMI_CONFIG_TX_MAC_RULES_CMDID, "CONFIG_TX_MAC_RULES"},
+ {WMI_SET_PROMISCUOUS_MODE_CMDID, "SET_PROMISCUOUS_MODE"},
+ {WMI_RX_FRAME_FILTER_CMDID, "RX_FRAME_FILTER"},
+ {WMI_SET_CHANNEL_CMDID, "SET_CHANNEL"},
+ {WMI_ENABLE_WAC_CMDID, "ENABLE_WAC"},
+ {WMI_WAC_SCAN_REPLY_CMDID, "WAC_SCAN_REPLY"},
+ {WMI_WAC_CTRL_REQ_CMDID, "WAC_CTRL_REQ"},
+ {WMI_SET_DIV_PARAMS_CMDID, "SET_DIV_PARAMS"},
+ {WMI_GET_PMK_CMDID, "GET_PMK"},
+ {WMI_SET_PASSPHRASE_CMDID, "SET_PASSPHRASE"},
+ {WMI_SEND_ASSOC_RES_CMDID, "SEND_ASSOC_RES"},
+ {WMI_SET_ASSOC_REQ_RELAY_CMDID, "SET_ASSOC_REQ_RELAY"},
+ {WMI_GET_RFKILL_MODE_CMDID, "GET_RFKILL_MODE"},
+ {WMI_SET_RFKILL_MODE_CMDID, "SET_RFKILL_MODE"},
+ {WMI_ACS_CTRL_CMDID, "ACS_CTRL"},
+ {WMI_STORERECALL_CONFIGURE_CMDID, "STORERECALL_CONFIGURE"},
+ {WMI_STORERECALL_RECALL_CMDID, "STORERECALL_RECALL"},
+ {WMI_STORERECALL_HOST_READY_CMDID, "STORERECALL_HOST_READY"},
+ {WMI_FORCE_TARGET_ASSERT_CMDID, "FORCE_TARGET_ASSERT"},
+ {WMI_SET_EXCESS_TX_RETRY_THRES_CMDID, "SET_EXCESS_TX_RETRY_THRES"},
+ {WMI_P2P_GO_NEG_REQ_RSP_CMDID, "P2P_GO_NEG_REQ_RSP"},
+ {WMI_P2P_GRP_INIT_CMDID, "P2P_GRP_INIT"},
+ {WMI_P2P_GRP_FORMATION_DONE_CMDID, "P2P_GRP_FORMATION_DONE"},
+ {WMI_P2P_INVITE_CMDID, "P2P_INVITE"},
+ {WMI_P2P_INVITE_REQ_RSP_CMDID, "P2P_INVITE_REQ_RSP"},
+ {WMI_P2P_PROV_DISC_REQ_CMDID, "P2P_PROV_DISC_REQ"},
+ {WMI_P2P_SET_CMDID, "P2P_SET"},
+ {WMI_AP_SET_APSD_CMDID, "AP_SET_APSD"},
+ {WMI_AP_APSD_BUFFERED_TRAFFIC_CMDID, "AP_APSD_BUFFERED_TRAFFIC"},
+ {WMI_P2P_SDPD_TX_CMDID, "P2P_SDPD_TX"},
+ {WMI_P2P_STOP_SDPD_CMDID, "P2P_STOP_SDPD"},
+ {WMI_P2P_CANCEL_CMDID, "P2P_CANCEL_CMDID"},
+};
+
+static struct dbg_id_str_entry dbg_wmi_event_str[] = {
+ {WMI_GET_CHANNEL_LIST_CMDID, "GET_CHANNEL_LIST"},
+ {WMI_READY_EVENTID, "READY"},
+ {WMI_CONNECT_EVENTID, "CONNECT"},
+ {WMI_DISCONNECT_EVENTID, "DISCONNECT"},
+ {WMI_BSSINFO_EVENTID, "BSSINFO"},
+ {WMI_CMDERROR_EVENTID, "CMDERROR"},
+ {WMI_REGDOMAIN_EVENTID, "REGDOMAIN"},
+ {WMI_PSTREAM_TIMEOUT_EVENTID, "PSTREAM_TIMEOUT"},
+ {WMI_NEIGHBOR_REPORT_EVENTID, "NEIGHBOR_REPORT"},
+ {WMI_TKIP_MICERR_EVENTID, "TKIP_MICERR"},
+ {WMI_SCAN_COMPLETE_EVENTID, "SCAN_COMPLETE"},
+ {WMI_REPORT_STATISTICS_EVENTID, "REPORT_STATISTICS"},
+ {WMI_RSSI_THRESHOLD_EVENTID, "RSSI_THRESHOLD"},
+ {WMI_ERROR_REPORT_EVENTID, "ERROR_REPORT"},
+ {WMI_OPT_RX_FRAME_EVENTID, "OPT_RX_FRAME"},
+ {WMI_REPORT_ROAM_TBL_EVENTID, "REPORT_ROAM_TBL"},
+ {WMI_EXTENSION_EVENTID, "EXTENSION"},
+ {WMI_CAC_EVENTID, "CAC"},
+ {WMI_SNR_THRESHOLD_EVENTID, "SNR_THRESHOLD"},
+ {WMI_LQ_THRESHOLD_EVENTID, "LQ_THRESHOLD"},
+ {WMI_TX_RETRY_ERR_EVENTID, "TX_RETRY_ROAM_DATA"},
+ {WMI_REPORT_ROAM_DATA_EVENTID, "REPORT_ROAM_DATA"},
+ {WMI_TEST_EVENTID, "TEST"},
+ {WMI_APLIST_EVENTID, "APLIST"},
+ {WMI_GET_WOW_LIST_EVENTID, "GET_WOR_LIST"},
+ {WMI_GET_PMKID_LIST_EVENTID, "GET_PMKID_LIST"},
+ {WMI_CHANNEL_CHANGE_EVENTID, "CHANNEL_CHANGE"},
+ {WMI_PEER_NODE_EVENTID, "PEER_NODE"},
+ {WMI_PSPOLL_EVENTID, "PSPOLL"},
+ {WMI_DTIMEXPIRY_EVENTID, "DTIMEXPIRY"},
+ {WMI_WLAN_VERSION_EVENTID, "WLAN_VERSION"},
+ {WMI_SET_PARAMS_REPLY_EVENTID, "SET_PARAMS_REPLY"},
+ {WMI_ADDBA_REQ_EVENTID, "ADDBA_REQ"},
+ {WMI_ADDBA_RESP_EVENTID, "ADDBA_RESP"},
+ {WMI_DELBA_REQ_EVENTID, "DELBA_REQ"},
+ {WMI_TX_COMPLETE_EVENTID, "TX_COMPLETE"},
+ {WMI_HCI_EVENT_EVENTID, "HCI_EVENT"},
+ {WMI_ACL_DATA_EVENTID, "ACL_DATA"},
+ {WMI_REPORT_SLEEP_STATE_EVENTID, "REPORT_SLEEP_STATE"},
+ {WMI_WAPI_REKEY_EVENTID, "WAPI_REKEY"},
+ {WMI_REPORT_BTCOEX_STATS_EVENTID, "REPORT_BTCOEX_STATS"},
+ {WMI_REPORT_BTCOEX_CONFIG_EVENTID, "REPORT_BTCOEX_CONFIG"},
+ {WMI_GET_PMK_EVENTID, "GET_PMK"},
+ {WMI_DFS_HOST_ATTACH_EVENTID, "DFS_HOST_ATTACH"},
+ {WMI_DFS_HOST_INIT_EVENTID, "DFS_HOST_INIT"},
+ {WMI_DFS_RESET_DELAYLINES_EVENTID, "DFS_RESET_DELAYLINES"},
+ {WMI_DFS_RESET_RADARQ_EVENTID, "DFS_RESET_RADARQ"},
+ {WMI_DFS_RESET_AR_EVENTID, "DFS_RESET_AR"},
+ {WMI_DFS_RESET_ARQ_EVENTID, "DFS_RESET_ARQ"},
+ {WMI_DFS_SET_DUR_MULTIPLIER_EVENTID, "DFS_SET_DUR_MULTIPLIER"},
+ {WMI_DFS_SET_BANGRADAR_EVENTID, "DFS_SET_BANGRADAR"},
+ {WMI_DFS_SET_DEBUGLEVEL_EVENTID, "DFS_SET_DEBUGLEVEL"},
+ {WMI_DFS_PHYERR_EVENTID, "DFS_PHYERR"},
+ {WMI_CCX_RM_STATUS_EVENTID, "CCX_RM_STATUS"},
+ {WMI_P2P_GO_NEG_RESULT_EVENTID, "P2P_GO_NEG_RESULT"},
+ {WMI_WAC_SCAN_DONE_EVENTID, "WAC_SCAN_DONE"},
+ {WMI_WAC_REPORT_BSS_EVENTID, "WAC_REPORT_BSS"},
+ {WMI_WAC_START_WPS_EVENTID, "WAC_START_WPS"},
+ {WMI_WAC_CTRL_REQ_REPLY_EVENTID, "WAC_CTRL_REQ_REPLY"},
+ {WMI_RFKILL_STATE_CHANGE_EVENTID, "RFKILL_STATE_CHANGE"},
+ {WMI_RFKILL_GET_MODE_CMD_EVENTID, "RFKILL_GET_MODE_CMD"},
+ {WMI_P2P_GO_NEG_REQ_EVENTID, "P2P_GO_NEG_REQ"},
+ {WMI_P2P_INVITE_REQ_EVENTID, "P2P_INVITE_REQ"},
+ {WMI_P2P_INVITE_RCVD_RESULT_EVENTID, "P2P_INVITE_RCVD_RESULT"},
+ {WMI_P2P_INVITE_SENT_RESULT_EVENTID, "P2P_INVITE_SENT_RESULT"},
+ {WMI_P2P_PROV_DISC_RESP_EVENTID, "P2P_PROV_DISC_RESP"},
+ {WMI_P2P_PROV_DISC_REQ_EVENTID, "P2P_PROV_DISC_REQ"},
+ {WMI_P2P_START_SDPD_EVENTID, "P2P_START_SDPD"},
+ {WMI_P2P_SDPD_RX_EVENTID, "P2P_SDPD_RX"},
+ {WMI_THIN_RESERVED_START_EVENTID, "THIN_RESERVED_START"},
+ {WMI_THIN_RESERVED_END_EVENTID, "THIN_RESERVED_END"},
+ {WMI_SET_CHANNEL_EVENTID, "SET_CHANNEL"},
+ {WMI_ASSOC_REQ_EVENTID, "ASSOC_REQ"},
+ {WMI_ACS_EVENTID, "ACS"},
+ {WMI_REPORT_WMM_PARAMS_EVENTID, "REPORT_WMM_PARAMS"},
+ {WMI_STORERECALL_STORE_EVENTID, "STORERECALL_STORE"},
+};
+
+#endif /* _DBG_CMD_EVT_H_ */
+
diff --git a/libtcmd/Android.mk b/libtcmd/Android.mk
new file mode 100755
index 0000000..d89c1ab
--- /dev/null
+++ b/libtcmd/Android.mk
@@ -0,0 +1,33 @@
+LOCAL_PATH:=$(call my-dir)
+
+# Build libtcmd =========================
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := libtcmd
+LOCAL_SRC_FILES:= \
+ nl80211.c \
+ libtcmd.c \
+ os.c
+
+LOCAL_CFLAGS += -include bionic/libc/kernel/arch-arm/asm/posix_types.h
+LOCAL_CFLAGS += -include bionic/libc/kernel/arch-arm/asm/byteorder.h
+LOCAL_CFLAGS += -include bionic/libc/kernel/common/linux/posix_types.h
+LOCAL_CFLAGS += -include bionic/libc/kernel/common/linux/types.h
+LOCAL_CFLAGS += -include bionic/libc/kernel/common/linux/socket.h
+LOCAL_CFLAGS += -include bionic/libc/kernel/common/linux/in.h
+
+LOCAL_C_INCLUDES += external/libnl-headers
+LOCAL_C_INCLUDES += $(TARGET_OUT_INTERMEDIATES)/KERNEL_OBJ/usr/include
+LOCAL_ADDITIONAL_DEPENDENCIES := $(TARGET_OUT_INTERMEDIATES)/KERNEL_OBJ/usr
+
+LOCAL_COPY_HEADERS_TO := libtcmd
+LOCAL_COPY_HEADERS := libtcmd.h
+
+LOCAL_CFLAGS += \
+ -DWLAN_API_NL80211 \
+ -DANDROID \
+ -DLIBNL_2 \
+
+# ICS ships with libnl 2.0
+LOCAL_SHARED_LIBRARIES := libnl_2
+include $(BUILD_STATIC_LIBRARY)
diff --git a/libtcmd/Makefile b/libtcmd/Makefile
new file mode 100644
index 0000000..3b441b1
--- /dev/null
+++ b/libtcmd/Makefile
@@ -0,0 +1,21 @@
+CC = gcc
+CFLAGS = -Wall -g
+
+NLLIBNAME = libnl-1
+WLAN_API = WLAN_API_NL80211
+WLAN_API_SRCS = nl80211.c
+
+SRCS = os.c $(WLAN_API_SRCS) libtcmd.c
+OBJS = $(SRCS:.c=.o)
+
+override LDLIBS += $(shell pkg-config --libs $(NLLIBNAME)) -lrt
+override CFLAGS += $(shell pkg-config --cflags $(NLLIBNAME)) -D$(WLAN_API)
+
+libtcmd.a: $(SRCS) $(OBJS)
+ $(AR) rcs $@ $(OBJS)
+
+$(OBJS): $(SRCS)
+ $(CC) $(CFLAGS) -c $(@:.o=.c) -o $@ $(LDLIBS)
+
+clean:
+ rm -f *.a *.o
diff --git a/libtcmd/libtcmd.c b/libtcmd/libtcmd.c
new file mode 100644
index 0000000..4601456
--- /dev/null
+++ b/libtcmd/libtcmd.c
@@ -0,0 +1,86 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#include "string.h"
+#include "libtcmd.h"
+#include "os.h"
+
+int tcmd_tx(void *buf, int len, bool resp)
+{
+ int err = 0;
+
+ /* XXX: just call nl80211 directly for now */
+#ifdef WLAN_API_NL80211
+ if ((err = nl80211_tcmd_tx(&tcmd_cfg, buf, len)))
+ goto err_out;
+#endif
+ if (resp)
+#ifdef WLAN_API_NL80211
+ err = nl80211_tcmd_rx(&tcmd_cfg);
+#endif
+
+ return err;
+err_out:
+ A_DBG("tcmd_tx failed: %s\n", strerror(-err));
+ return err;
+}
+
+static void tcmd_expire(union sigval sig)
+{
+ /* tcmd expired, do something */
+ A_DBG("timer expired\n");
+ tcmd_cfg.timeout = true;
+}
+
+/* get driver ep from tcmd ep */
+static int tcmd_set_ep(uint32_t *driv_ep, enum tcmd_ep ep)
+{
+#ifdef WLAN_API_NL80211
+ return nl80211_set_ep(driv_ep, ep);
+#endif
+}
+int tcmd_init(char *iface, void (*rx_cb)(void *buf, int len), ...)
+{
+ int err;
+ enum tcmd_ep ep;
+ va_list ap;
+ va_start(ap, rx_cb);
+ ep = va_arg(ap, enum tcmd_ep);
+ va_end(ap);
+
+ strcpy(tcmd_cfg.iface, iface);
+ tcmd_cfg.rx_cb = rx_cb;
+ if ((err = tcmd_set_ep(&tcmd_cfg.ep, ep)))
+ return err;
+
+ tcmd_cfg.sev.sigev_notify = SIGEV_THREAD;
+ tcmd_cfg.sev.sigev_notify_function = tcmd_expire;
+ timer_create(CLOCK_REALTIME, &tcmd_cfg.sev, &tcmd_cfg.timer);
+
+#ifdef WLAN_API_NL80211
+ if ((err = nl80211_init(&tcmd_cfg))) {
+ A_DBG("couldn't init nl80211!: %s\n", strerror(-err));
+ return err;
+ }
+#endif
+
+ return 0;
+}
+
+int tcmd_tx_init(char *iface, void (*rx_cb)(void *buf, int len))
+{
+ return tcmd_init(iface, rx_cb, TCMD_EP_TCMD);
+}
diff --git a/libtcmd/libtcmd.h b/libtcmd/libtcmd.h
new file mode 100644
index 0000000..353f25b
--- /dev/null
+++ b/libtcmd/libtcmd.h
@@ -0,0 +1,78 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#ifndef _LIBTCMD_H_
+#define _LIBTCMD_H_
+
+#include <errno.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <getopt.h>
+#include <stdint.h>
+#include <stdbool.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <net/if.h>
+#include <signal.h>
+#include <time.h>
+#include <stdarg.h>
+
+#define A_ERR(ret, args...) printf(args); exit(ret);
+#define A_DBG(args...) fprintf(stderr, args);
+
+#define TCMD_TIMEOUT 2 /* s */
+
+enum tcmd_ep {
+ TCMD_EP_TCMD,
+ TCMD_EP_WMI,
+};
+
+struct tcmd_cfg {
+ char iface[100];
+ void (*rx_cb)(void *buf, int len);
+ uint32_t ep;
+#ifdef WLAN_API_NL80211
+/* XXX: eventually default to libnl-2.0 API */
+#ifdef LIBNL_2
+#define nl_handle nl_sock
+#endif
+ struct nl_handle *nl_handle;
+ int nl_id;
+#endif
+ struct sigevent sev;
+ timer_t timer;
+ bool timeout;
+} tcmd_cfg;
+
+/* WLAN API */
+#ifdef WLAN_API_NL80211
+#include "nl80211_drv.h"
+#endif
+
+/* send tcmd in buffer buf of length len. resp == true if a response by the FW
+ * is required. Returns: 0 on success, -ETIMEOUT on timeout
+ */
+int tcmd_tx(void *buf, int len, bool resp);
+
+/* Initialize tcmd transport layer on given iface. Call given rx_cb on tcmd
+ * response */
+int tcmd_tx_init(char *iface, void (*rx_cb)(void *buf, int len));
+/* same as above, but takes optional testmode endpoint (e.g. WMI vs. TCMD) */
+int tcmd_init(char *iface, void (*rx_cb)(void *buf, int len), ...);
+#endif /* _LIBTCMD_H_ */
diff --git a/libtcmd/nl80211.c b/libtcmd/nl80211.c
new file mode 100644
index 0000000..ec44a68
--- /dev/null
+++ b/libtcmd/nl80211.c
@@ -0,0 +1,416 @@
+/*
+ * Copyright (c) 2011-2012 Qualcomm Atheros Inc. All Rights Reserved.
+ * Qualcomm Atheros Proprietary and Confidential.
+ */
+
+#include "libtcmd.h"
+#include "os.h"
+
+int cb_ret;
+
+#ifdef LIBNL_2
+static inline struct nl_sock *nl_handle_alloc(void)
+{
+ return nl_socket_alloc();
+}
+
+static inline void nl_handle_destroy(struct nl_handle *h)
+{
+ nl_socket_free(h);
+}
+
+#define nl_disable_sequence_check nl_socket_disable_seq_check
+#endif
+
+/* copied from ath6kl */
+enum ar6k_testmode_attr {
+ __AR6K_TM_ATTR_INVALID = 0,
+ AR6K_TM_ATTR_CMD = 1,
+ AR6K_TM_ATTR_DATA = 2,
+ AR6K_TM_ATTR_STREAM_ID = 3,
+
+ /* keep last */
+ __AR6K_TM_ATTR_AFTER_LAST,
+ AR6K_TM_ATTR_MAX = __AR6K_TM_ATTR_AFTER_LAST - 1
+};
+
+enum ar6k_testmode_cmd {
+ AR6K_TM_CMD_TCMD = 0,
+ AR6K_TM_CMD_WMI_CMD = 0xF000,
+};
+
+int nl80211_rx_cb(struct nl_msg *msg, void *arg);
+
+static int error_handler(struct sockaddr_nl *nla, struct nlmsgerr *err,
+ void *arg)
+{
+ int *ret = arg;
+ *ret = err->error;
+ return NL_STOP;
+}
+
+static int finish_handler(struct nl_msg *msg, void *arg)
+{
+ int *ret = arg;
+ *ret = 0;
+ return NL_SKIP;
+}
+
+static int ack_handler(struct nl_msg *msg, void *arg)
+{
+ int *ret = arg;
+ *ret = 0;
+ return NL_STOP;
+}
+
+#ifdef ANDROID
+#include "netlink-types.h"
+/* android's libnl_2 does not include this, define it here */
+static int android_genl_ctrl_resolve(struct nl_handle *handle,
+ const char *name)
+{
+ /*
+ * Android ICS has very minimal genl_ctrl_resolve() implementation, so
+ * need to work around that.
+ */
+ struct nl_cache *cache = NULL;
+ struct genl_family *nl80211 = NULL;
+ int id = -1;
+
+ if (genl_ctrl_alloc_cache(handle, &cache) < 0) {
+ A_DBG("nl80211: Failed to allocate generic "
+ "netlink cache");
+ goto fail;
+ }
+
+ nl80211 = genl_ctrl_search_by_name(cache, name);
+ if (nl80211 == NULL)
+ goto fail;
+
+ id = genl_family_get_id(nl80211);
+
+fail:
+ if (nl80211)
+ genl_family_put(nl80211);
+ if (cache)
+ nl_cache_free(cache);
+
+ return id;
+}
+#define genl_ctrl_resolve android_genl_ctrl_resolve
+
+#define nl_socket_get_cb nl_sk_get_cb
+struct nl_cb *nl_socket_get_cb(const struct nl_sock *sk)
+{
+ return nl_cb_get(sk->s_cb);
+}
+
+#define nl_socket_enable_msg_peek nl_sk_enable_msg_peek
+void nl_socket_enable_msg_peek(struct nl_sock *sk)
+{
+ sk->s_flags |= NL_MSG_PEEK;
+}
+
+#define nl_socket_set_nonblocking nl_sk_set_nb
+int nl_socket_set_nonblocking(const struct nl_sock *sk)
+{
+ fcntl(sk->s_fd, F_SETFL, O_NONBLOCK);
+ return 0;
+}
+
+static int seq_ok(struct nl_msg *msg, void *arg)
+{
+ return NL_OK;
+}
+
+#define nl_socket_disable_seq_check disable_seq_check
+static inline void disable_seq_check(struct nl_handle *handle)
+{
+ nl_cb_set(nl_socket_get_cb(handle), NL_CB_SEQ_CHECK,
+ NL_CB_CUSTOM, seq_ok, NULL);
+}
+#endif
+
+struct handler_args {
+ const char *group;
+ int id;
+};
+
+static int family_handler(struct nl_msg *msg, void *arg)
+{
+ struct handler_args *grp = arg;
+ struct nlattr *tb[CTRL_ATTR_MAX + 1];
+ struct genlmsghdr *gnlh = nlmsg_data(nlmsg_hdr(msg));
+ struct nlattr *mcgrp;
+ int rem_mcgrp;
+
+ nla_parse(tb, CTRL_ATTR_MAX, genlmsg_attrdata(gnlh, 0),
+ genlmsg_attrlen(gnlh, 0), NULL);
+
+ if (!tb[CTRL_ATTR_MCAST_GROUPS])
+ return NL_SKIP;
+
+ nla_for_each_nested(mcgrp, tb[CTRL_ATTR_MCAST_GROUPS], rem_mcgrp) {
+ struct nlattr *tb_mcgrp[CTRL_ATTR_MCAST_GRP_MAX + 1];
+
+ nla_parse(tb_mcgrp, CTRL_ATTR_MCAST_GRP_MAX,
+ nla_data(mcgrp), nla_len(mcgrp), NULL);
+
+ if (!tb_mcgrp[CTRL_ATTR_MCAST_GRP_NAME] ||
+ !tb_mcgrp[CTRL_ATTR_MCAST_GRP_ID])
+ continue;
+ if (strncmp(nla_data(tb_mcgrp[CTRL_ATTR_MCAST_GRP_NAME]),
+ grp->group, nla_len(tb_mcgrp[CTRL_ATTR_MCAST_GRP_NAME])))
+ continue;
+ grp->id = nla_get_u32(tb_mcgrp[CTRL_ATTR_MCAST_GRP_ID]);
+ break;
+ }
+
+ return NL_SKIP;
+}
+
+int nl_get_multicast_id(struct nl_handle *sock, const char *family, const char *group)
+{
+ struct nl_msg *msg;
+ struct nl_cb *cb;
+ int ret, ctrlid;
+ struct handler_args grp = {
+ .group = group,
+ .id = -ENOENT,
+ };
+
+ msg = nlmsg_alloc();
+ if (!msg)
+ return -ENOMEM;
+
+ cb = nl_cb_alloc(NL_CB_DEFAULT);
+ if (!cb) {
+ ret = -ENOMEM;
+ goto out_fail_cb;
+ }
+
+ ctrlid = genl_ctrl_resolve(sock, "nlctrl");
+
+#ifdef ANDROID
+ genlmsg_put(msg, NL_AUTO_PID, NL_AUTO_SEQ, GENL_ID_CTRL, 0, 0, CTRL_CMD_GETFAMILY, 1);
+#else
+ genlmsg_put(msg, 0, 0, ctrlid, 0, 0, CTRL_CMD_GETFAMILY, 0);
+#endif
+
+ ret = -ENOBUFS;
+ NLA_PUT_STRING(msg, CTRL_ATTR_FAMILY_NAME, family);
+
+ ret = nl_send_auto_complete(sock, msg);
+ if (ret < 0)
+ goto out;
+
+ ret = 1;
+
+ nl_cb_err(cb, NL_CB_CUSTOM, error_handler, &ret);
+ nl_cb_set(cb, NL_CB_ACK, NL_CB_CUSTOM, ack_handler, &ret);
+ nl_cb_set(cb, NL_CB_FINISH, NL_CB_CUSTOM, finish_handler, &ret);
+ nl_cb_set(cb, NL_CB_VALID, NL_CB_CUSTOM, family_handler, &grp);
+
+ while (ret > 0)
+ nl_recvmsgs(sock, cb);
+
+ if (ret == 0)
+ ret = grp.id;
+ nla_put_failure:
+ out:
+ nl_cb_put(cb);
+ out_fail_cb:
+ nlmsg_free(msg);
+ return ret;
+}
+
+int nl80211_set_ep(uint32_t *driv_ep, enum tcmd_ep ep)
+{
+ switch(ep) {
+ case TCMD_EP_TCMD:
+ *driv_ep = AR6K_TM_CMD_TCMD;
+ break;
+ case TCMD_EP_WMI:
+ *driv_ep = AR6K_TM_CMD_WMI_CMD;
+ break;
+ default:
+ fprintf(stderr, "nl80211: unknown ep!");
+ return -1;
+ }
+ return 0;
+}
+int nl80211_init(struct tcmd_cfg *cfg)
+{
+ struct nl_cb *cb;
+ int err;
+
+ cfg->nl_handle = nl_handle_alloc();
+ if (!cfg->nl_handle) {
+ A_DBG("Failed to allocate netlink socket.\n");
+ return -ENOMEM;
+ }
+
+ if (genl_connect(cfg->nl_handle)) {
+ A_DBG("Failed to connect to generic netlink.\n");
+ err = -ENOLINK;
+ goto out_handle_destroy;
+ }
+
+ cfg->nl_id = genl_ctrl_resolve(cfg->nl_handle, "nl80211");
+ if (cfg->nl_id < 0) {
+ A_DBG("nl80211 not found.\n");
+ err = -ENOENT;
+ goto out_handle_destroy;
+ }
+
+ /* replace this with genl_ctrl_resolve_grp() once we move to libnl3 */
+ err = nl_get_multicast_id(cfg->nl_handle, "nl80211", "testmode");
+ if (err >= 0) {
+ err = nl_socket_add_membership(cfg->nl_handle, err);
+ if (err) {
+ A_DBG("failed to join testmode group!\n");
+ goto out_handle_destroy;
+ }
+ }
+ else
+ goto out_handle_destroy;
+ /*
+ * Enable peek mode so drivers can send large amounts
+ * of data in blobs without problems.
+ */
+ nl_socket_enable_msg_peek(cfg->nl_handle);
+
+ /*
+ * disable sequence checking to handle events.
+ */
+ nl_disable_sequence_check(cfg->nl_handle);
+
+ cb = nl_socket_get_cb(cfg->nl_handle);
+#ifdef ANDROID
+ /* libnl_2 does not provide default handlers */
+ nl_cb_err(cb, NL_CB_CUSTOM, error_handler, &cb_ret);
+ nl_cb_set(cb, NL_CB_ACK, NL_CB_CUSTOM, ack_handler, &cb_ret);
+ nl_cb_set(cb, NL_CB_FINISH, NL_CB_CUSTOM, finish_handler, &cb_ret);
+#endif
+ nl_cb_set(cb, NL_CB_VALID, NL_CB_CUSTOM, nl80211_rx_cb, NULL);
+
+ /* so we can handle timeouts properly */
+ nl_socket_set_nonblocking(cfg->nl_handle);
+
+ return 0;
+
+ out_handle_destroy:
+ nl_handle_destroy(cfg->nl_handle);
+ return err;
+}
+
+int nl80211_tcmd_tx(struct tcmd_cfg *cfg, void *buf, int len)
+{
+ struct nl_msg *msg;
+ struct nlattr *nest;
+ int devidx, err = 0;
+
+ /* CHANGE HERE: you may need to allocate larger messages! */
+ msg = nlmsg_alloc();
+ if (!msg) {
+ A_DBG("failed to allocate netlink message\n");
+ return 2;
+ }
+
+ genlmsg_put(msg, 0, 0, cfg->nl_id, 0,
+ 0, NL80211_CMD_TESTMODE, 0);
+
+ devidx = if_nametoindex(cfg->iface);
+ if (devidx) {
+ NLA_PUT_U32(msg, NL80211_ATTR_IFINDEX, devidx);
+ } else {
+ A_DBG("Device not found\n");
+ err = -ENOENT;
+ goto out_free_msg;
+ }
+
+ nest = nla_nest_start(msg, NL80211_ATTR_TESTDATA);
+ if (!nest) {
+ A_DBG("failed to nest\n");
+ err = -1;
+ goto out_free_msg;
+ }
+
+ NLA_PUT_U32(msg, AR6K_TM_ATTR_CMD, cfg->ep);
+ NLA_PUT(msg, AR6K_TM_ATTR_DATA, len, buf);
+
+ nla_nest_end(msg, nest);
+
+ A_DBG("nl80211: sending message\n");
+ nl_send_auto_complete(cfg->nl_handle, msg);
+
+ out_free_msg:
+ nlmsg_free(msg);
+ return err;
+
+ nla_put_failure:
+ A_DBG("building message failed\n");
+ return 2;
+}
+
+int nl80211_tcmd_rx(struct tcmd_cfg *cfg)
+{
+ struct nl_cb *cb;
+ int err = 0;
+
+ cb = nl_socket_get_cb(cfg->nl_handle);
+ if (!cb) {
+ fprintf(stderr, "failed to allocate netlink callbacks\n");
+ err = 2;
+ goto out;
+ }
+
+ err = tcmd_set_timer(cfg);
+ if (err)
+ goto out;
+
+ A_DBG("nl80211: waiting for response\n");
+ while (!cfg->timeout)
+ nl_recvmsgs(cfg->nl_handle, cb);
+
+ return tcmd_reset_timer(cfg);
+out:
+ return err;
+}
+
+/* tcmd rx_cb wrapper to "unpack" the nl80211 msg and call the "real" cb */
+int nl80211_rx_cb(struct nl_msg *msg, void *arg)
+{
+ struct nlattr *tb[NL80211_ATTR_MAX + 1];
+ struct genlmsghdr *gnlh = nlmsg_data(nlmsg_hdr(msg));
+ struct nlattr *td[AR6K_TM_ATTR_MAX + 1];
+ void *buf;
+ int len;
+
+ A_DBG("nl80211: cb wrapper called\n");
+ nla_parse(tb, NL80211_ATTR_MAX, genlmsg_attrdata(gnlh, 0),
+ genlmsg_attrlen(gnlh, 0), NULL);
+
+ if (!tb[NL80211_ATTR_TESTDATA] || !tb[NL80211_ATTR_WIPHY]) {
+ printf("no data!\n");
+ return NL_SKIP;
+ }
+
+ nla_parse(td, AR6K_TM_ATTR_MAX, nla_data(tb[NL80211_ATTR_TESTDATA]),
+ nla_len(tb[NL80211_ATTR_TESTDATA]), NULL);
+
+ if (!td[AR6K_TM_ATTR_DATA]) {
+ printf("no data in reply\n");
+ return NL_SKIP;
+ }
+
+ buf = nla_data(td[AR6K_TM_ATTR_DATA]);
+ len = nla_len(td[AR6K_TM_ATTR_DATA]);
+
+ A_DBG("nl80211: resp received, calling custom cb\n");
+ tcmd_cfg.rx_cb(buf, len);
+ /* trip waiting thread */
+ tcmd_cfg.timeout = true;
+
+ return NL_SKIP;
+}
diff --git a/libtcmd/nl80211_drv.h b/libtcmd/nl80211_drv.h
new file mode 100644
index 0000000..773011d
--- /dev/null
+++ b/libtcmd/nl80211_drv.h
@@ -0,0 +1,34 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#ifndef _NL80211_DRV_H_
+#define _NL80211_DRV_H_
+
+#include <netlink/genl/genl.h>
+#include <netlink/genl/family.h>
+#include <netlink/genl/ctrl.h>
+#include <netlink/msg.h>
+#include <netlink/attr.h>
+#include <netlink/socket.h>
+
+#include <linux/nl80211.h>
+#include "libtcmd.h"
+
+int nl80211_init(struct tcmd_cfg *cfg);
+int nl80211_tcmd_tx(struct tcmd_cfg *cfg, void *buf, int len);
+int nl80211_tcmd_rx(struct tcmd_cfg *cfg);
+int nl80211_set_ep(uint32_t *driv_ep, enum tcmd_ep ep);
+#endif /* _NL80211_DRV_H_ */
diff --git a/libtcmd/os.c b/libtcmd/os.c
new file mode 100644
index 0000000..e52cfea
--- /dev/null
+++ b/libtcmd/os.c
@@ -0,0 +1,53 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#include "libtcmd.h"
+#include "os.h"
+
+int tcmd_set_timer(struct tcmd_cfg *cfg)
+{
+ struct itimerspec exp_time;
+ int err;
+
+ A_DBG("setting timer\n");
+ bzero(&exp_time, sizeof(exp_time));
+ exp_time.it_value.tv_sec = TCMD_TIMEOUT;
+ err = timer_settime(cfg->timer, 0, &exp_time, NULL);
+ cfg->timeout = false;
+ if (err < 0)
+ return errno;
+ return 0;
+}
+
+int tcmd_reset_timer(struct tcmd_cfg *cfg)
+{
+ struct itimerspec curr_time;
+ int err;
+
+ err = timer_gettime(cfg->timer, &curr_time);
+ if (err < 0)
+ return errno;
+
+ if (!curr_time.it_value.tv_sec && !curr_time.it_value.tv_nsec)
+ return -ETIMEDOUT;
+
+ A_DBG("resetting timer\n");
+ bzero(&curr_time, sizeof(curr_time));
+ err = timer_settime(cfg->timer, 0, &curr_time, NULL);
+ if (err < 0)
+ return errno;
+ return 0;
+}
diff --git a/libtcmd/os.h b/libtcmd/os.h
new file mode 100644
index 0000000..1b1c8dc
--- /dev/null
+++ b/libtcmd/os.h
@@ -0,0 +1,21 @@
+/*
+* Copyright (c) 2011-2012 Qualcomm Atheros Inc.
+*
+* Permission to use, copy, modify, and/or distribute this software for any
+* purpose with or without fee is hereby granted, provided that the above
+* copyright notice and this permission notice appear in all copies.
+*
+* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+/* private, os-specific things go here */
+int tcmd_set_timer(struct tcmd_cfg *cfg);
+/* reset timer and return 0 if still running, return -ETIMEDOUT if the tcmd
+ * timer timed out */
+int tcmd_reset_timer(struct tcmd_cfg *cfg);