SmartAudio/lichee/linux-4.9/drivers/net/wireless/xradio/wlan/etf.h

201 lines
5.3 KiB
C
Raw Normal View History

2018-07-13 01:31:50 +00:00
/*
* Common interfaces for XRadio drivers
*
* Copyright (c) 2013
* Xradio Technology Co., Ltd. <www.xradiotech.com>
*
* 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.
*/
#ifndef XRADIO_ETF_H
#define XRADIO_ETF_H
#include <generated/uapi/linux/version.h>
/* ETF Adapter layer */
#define NL_FOR_XRADIO 30
/*
* When queue mode is enable, user space operate is non-block if items in rx_pool,
* but it may sleep and will drop msg when rx_pool is empty for a long time.
* When queue mode is disable, user space operate is block and user packet
* will not be drop, but driver can be panic if etf cli be kill during operate.
* So, for more safe in driver, enable this by default.
*/
#define ETF_QUEUEMODE 1
#define ETF_QUEUE_TIMEOUT 50 /* about 2s.*/
#define ADAPTER_RX_BUF_LEN (528*3) /* pay respect for SDIO_BLOCK_SIZE*/
#if (ETF_QUEUEMODE)
#define ADAPTER_ITEM_MAX (32)
#define XRADIO_ADAPTER ("xradio_etf")
struct adapter_item {
struct list_head head;
void *skb;
};
#endif
typedef int (*msg_proc)(void *data, int len);
struct xradio_adapter {
struct sock *sock;
msg_proc handler;
void *msg_buf;
int msg_len;
#if (ETF_QUEUEMODE)
struct adapter_item rx_items[ADAPTER_ITEM_MAX];
struct list_head rx_queue;
struct list_head rx_pool;
spinlock_t recv_lock;
atomic_t rx_cnt;
struct semaphore proc_sem;
struct task_struct *thread_tsk;
int exit;
#endif
int send_pid;
struct semaphore send_lock;
};
/* ETF internal connect state*/
#define ETF_STAT_NULL 0
#define ETF_STAT_CONNECTING 1
#define ETF_STAT_CONNECTED 2
struct xradio_etf {
int etf_state;
int is_wlan;
void *core_priv;
struct semaphore etf_lock;
struct xradio_adapter *adapter;
int seq_send;
int seq_recv;
u8 *fw_path;
u8 *sdd_path;
};
/* ETF fw cmd defines*/
#define ETF_REQ_BASE 0x0000
#define ETF_CNF_BASE 0x0400
#define ETF_IND_BASE 0x0800
#define ETF_MSG_STARTUP_IND_ID 0x0801
#define ETF_DOWNLOAD_SDD (0x20 + 22)
#define ETF_HWT_REQ 0x0004
struct etf_sdd_req {
u16 len;
u16 id;
u32 sdd_cmd;
};
/* ETF driver cmd defines */
#define ETF_DRIVER_CMD_START_ID (ETF_REQ_BASE + 0x03F0)
#define ETF_GET_API_CONTEXT_ID (ETF_REQ_BASE + 0x03F8)
#define ETF_GET_SDD_PARAM_ID (ETF_REQ_BASE + 0x03F9)
#define ETF_CONNECT_ID (ETF_REQ_BASE + 0x03FA)
#define ETF_DISCONNECT_ID (ETF_REQ_BASE + 0x03FB)
#define ETF_RECONNECT_ID (ETF_REQ_BASE + 0x03FC)
#define ETF_DOWNLOAD_SDD_ID (ETF_REQ_BASE + 0x03FD)
#define ETF_DOWNLOAD_ID (ETF_REQ_BASE + 0x03FE)
#define ETF_SOFT_RESET_REQ_ID (ETF_REQ_BASE + 0x03FF)
#define ETF_DRIVER_IND_ID (ETF_IND_BASE + 0x03FF)
#define ETF_GET_SDD_POWER_DEFT (ETF_REQ_BASE + 0x1FFF)
#define FLAG_GET_SDD_ALL 0x1
struct get_sdd_param_req {
u16 len;
u16 id;
u8 flags;
u8 ies;
};
struct get_sdd_result {
u16 len;
u16 id;
u32 result;
u32 length;
/* sdd data follow */
};
struct etf_api_context_req {
u16 len;
u16 id;
u32 param;
};
#define HI_SW_LABEL_MAX 128
struct etf_api_context_result {
u16 len;
u16 id;
u32 result;
u8 is_etf_fw_run;
u8 reversed[3];
u32 mib_baseaddr;
u8 fw_label[HI_SW_LABEL_MAX];
u16 fw_api_ver;
};
#define ETF_CONTEXT_OFFSET (20 + HI_SW_LABEL_MAX)
#define HI_MAX_CONFIG_TABLES 4
struct etf_api_context {
u32 config[HI_MAX_CONFIG_TABLES];
};
/* boot State, for download file from GUI */
#define BOOT_STATE_NULL 0
#define BOOT_WAITING_DOWNLOAD 1
#define BOOT_IN_PROGRESS 2
#define BOOT_COMPLETE 3
#define BOOT_SDD_COMPLETE 4
/* Driver Result code */
#define BOOT_SUCCESS (0)
#define BOOT_ERR_DECODE (1)
#define BOOT_ERR_CHECKSUM (2)
#define BOOT_ERR_FILE_SIZE (3)
#define BOOT_ERR_BAD_OP (4)
#define ETF_ERR_CONNECTED (5)
#define ETF_ERR_WLAN_MODE (6)
#define ETF_ERR_NOT_CONNECT (7)
#define ETF_ERR_IO_FAILED (8)
#define ETF_ERR_DRIVER_HANG (9)
struct drv_resp {
u16 len;
u16 id;
u32 state;
u32 result;
};
#define MSG_ID(x) ((u16)((x)&0x1fff))
#define MSG_SEQ(x) (((x)>>13)&0x0007)
#define SEQ_MASK(x) ((x) & 0x0007)
#define DOWNLOAD_F_START 0x01
#define DOWNLOAD_F_END 0x02
#define DOWNLOAD_F_PATH_ONLY 0x04
struct drv_download {
u32 offset;
u32 flags;
/* data followed, max size is HI_MEM_BLK_BYTES */
};
#ifdef USE_VFS_FIRMWARE
#define XR819_ETF_FIRMWARE ("/lib/firmware/etf_xr819.bin")
#else
#define XR819_ETF_FIRMWARE ("etf_xr819.bin")
#endif
/* ETF interfaces called by WLAN core */
int xradio_etf_init(void);
void xradio_etf_deinit(void);
const char *etf_get_fwpath(void);
const char *etf_get_sddpath(void);
bool etf_is_connect(void);
void etf_set_core(void *core_priv);
int xradio_etf_from_device(struct sk_buff **skb);
void xradio_etf_save_context(void *buf, int len);
int xradio_etf_suspend(void);
int xradio_etf_resume(void);
/* External interfaces called by etf */
extern int xradio_core_init(void);
extern void xradio_core_deinit(void);
#endif /*XRADIO_ETF_H*/