201 lines
5.3 KiB
C
201 lines
5.3 KiB
C
|
/*
|
||
|
* 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*/
|