| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2011-05-17 13:36:18 +05:30
										 |  |  |  * Copyright (c) 2010-2011 Atheros Communications Inc. | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  |  * | 
					
						
							|  |  |  |  * 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 WMI_H
 | 
					
						
							|  |  |  | #define WMI_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct wmi_event_txrate { | 
					
						
							| 
									
										
										
										
											2010-04-16 11:54:03 +05:30
										 |  |  | 	__be32 txrate; | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | 	struct { | 
					
						
							|  |  |  | 		u8 rssi_thresh; | 
					
						
							|  |  |  | 		u8 per; | 
					
						
							|  |  |  | 	} rc_stats; | 
					
						
							|  |  |  | } __packed; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct wmi_cmd_hdr { | 
					
						
							| 
									
										
										
										
											2010-04-16 11:54:03 +05:30
										 |  |  | 	__be16 command_id; | 
					
						
							|  |  |  | 	__be16 seq_no; | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | } __packed; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-13 11:22:51 +05:30
										 |  |  | struct wmi_fw_version { | 
					
						
							|  |  |  | 	__be16 major; | 
					
						
							|  |  |  | 	__be16 minor; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } __packed; | 
					
						
							| 
									
										
										
										
											2011-04-13 11:22:59 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | struct wmi_event_swba { | 
					
						
							|  |  |  | 	__be64 tsf; | 
					
						
							|  |  |  | 	u8 beacon_pending; | 
					
						
							| 
									
										
										
										
											2013-09-13 12:14:09 -04:00
										 |  |  | } __packed; | 
					
						
							| 
									
										
										
										
											2011-04-13 11:25:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * 64 - HTC header - WMI header - 1 / txstatus | 
					
						
							|  |  |  |  * And some other hdr. space is also accounted for. | 
					
						
							| 
									
										
										
										
											2011-04-13 11:26:18 +05:30
										 |  |  |  * 12 seems to be the magic number. | 
					
						
							| 
									
										
										
										
											2011-04-13 11:25:18 +05:30
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-04-13 11:26:18 +05:30
										 |  |  | #define HTC_MAX_TX_STATUS 12
 | 
					
						
							| 
									
										
										
										
											2011-04-13 11:25:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_ACK        BIT(0)
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_FILT       BIT(1)
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_RTC_CTS    BIT(2)
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_MCS        BIT(3)
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_CW40       BIT(4)
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_SGI        BIT(5)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Legacy rates are indicated as indices. | 
					
						
							|  |  |  |  * HT rates are indicated as dot11 numbers. | 
					
						
							|  |  |  |  * This allows us to resrict the rate field | 
					
						
							|  |  |  |  * to 4 bits. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_RATE       0x0f
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_RATE_S     0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_EPID       0xf0
 | 
					
						
							|  |  |  | #define ATH9K_HTC_TXSTAT_EPID_S     4
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct __wmi_event_txstatus { | 
					
						
							|  |  |  | 	u8 cookie; | 
					
						
							|  |  |  | 	u8 ts_rate; /* Also holds EP ID */ | 
					
						
							|  |  |  | 	u8 ts_flags; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct wmi_event_txstatus { | 
					
						
							|  |  |  | 	u8 cnt; | 
					
						
							|  |  |  | 	struct __wmi_event_txstatus txstatus[HTC_MAX_TX_STATUS]; | 
					
						
							|  |  |  | } __packed; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | enum wmi_cmd_id { | 
					
						
							|  |  |  | 	WMI_ECHO_CMDID = 0x0001, | 
					
						
							|  |  |  | 	WMI_ACCESS_MEMORY_CMDID, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Commands to Target */ | 
					
						
							| 
									
										
										
										
											2011-04-13 11:22:51 +05:30
										 |  |  | 	WMI_GET_FW_VERSION, | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | 	WMI_DISABLE_INTR_CMDID, | 
					
						
							|  |  |  | 	WMI_ENABLE_INTR_CMDID, | 
					
						
							|  |  |  | 	WMI_ATH_INIT_CMDID, | 
					
						
							|  |  |  | 	WMI_ABORT_TXQ_CMDID, | 
					
						
							|  |  |  | 	WMI_STOP_TX_DMA_CMDID, | 
					
						
							|  |  |  | 	WMI_ABORT_TX_DMA_CMDID, | 
					
						
							|  |  |  | 	WMI_DRAIN_TXQ_CMDID, | 
					
						
							|  |  |  | 	WMI_DRAIN_TXQ_ALL_CMDID, | 
					
						
							|  |  |  | 	WMI_START_RECV_CMDID, | 
					
						
							|  |  |  | 	WMI_STOP_RECV_CMDID, | 
					
						
							|  |  |  | 	WMI_FLUSH_RECV_CMDID, | 
					
						
							|  |  |  | 	WMI_SET_MODE_CMDID, | 
					
						
							|  |  |  | 	WMI_NODE_CREATE_CMDID, | 
					
						
							|  |  |  | 	WMI_NODE_REMOVE_CMDID, | 
					
						
							|  |  |  | 	WMI_VAP_REMOVE_CMDID, | 
					
						
							|  |  |  | 	WMI_VAP_CREATE_CMDID, | 
					
						
							|  |  |  | 	WMI_REG_READ_CMDID, | 
					
						
							|  |  |  | 	WMI_REG_WRITE_CMDID, | 
					
						
							|  |  |  | 	WMI_RC_STATE_CHANGE_CMDID, | 
					
						
							|  |  |  | 	WMI_RC_RATE_UPDATE_CMDID, | 
					
						
							|  |  |  | 	WMI_TARGET_IC_UPDATE_CMDID, | 
					
						
							|  |  |  | 	WMI_TX_AGGR_ENABLE_CMDID, | 
					
						
							|  |  |  | 	WMI_TGT_DETACH_CMDID, | 
					
						
							| 
									
										
										
										
											2011-04-13 11:26:58 +05:30
										 |  |  | 	WMI_NODE_UPDATE_CMDID, | 
					
						
							|  |  |  | 	WMI_INT_STATS_CMDID, | 
					
						
							|  |  |  | 	WMI_TX_STATS_CMDID, | 
					
						
							|  |  |  | 	WMI_RX_STATS_CMDID, | 
					
						
							| 
									
										
										
										
											2011-04-27 17:13:23 +05:30
										 |  |  | 	WMI_BITRATE_MASK_CMDID, | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum wmi_event_id { | 
					
						
							|  |  |  | 	WMI_TGT_RDY_EVENTID = 0x1001, | 
					
						
							|  |  |  | 	WMI_SWBA_EVENTID, | 
					
						
							|  |  |  | 	WMI_FATAL_EVENTID, | 
					
						
							|  |  |  | 	WMI_TXTO_EVENTID, | 
					
						
							|  |  |  | 	WMI_BMISS_EVENTID, | 
					
						
							|  |  |  | 	WMI_DELBA_EVENTID, | 
					
						
							| 
									
										
										
										
											2011-04-13 11:25:18 +05:30
										 |  |  | 	WMI_TXSTATUS_EVENTID, | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-16 11:53:53 +05:30
										 |  |  | #define MAX_CMD_NUMBER 62
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct register_write { | 
					
						
							| 
									
										
										
										
											2010-04-16 11:54:03 +05:30
										 |  |  | 	__be32 reg; | 
					
						
							|  |  |  | 	__be32 val; | 
					
						
							| 
									
										
										
										
											2010-04-16 11:53:53 +05:30
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-13 11:26:39 +05:30
										 |  |  | struct ath9k_htc_tx_event { | 
					
						
							|  |  |  | 	int count; | 
					
						
							|  |  |  | 	struct __wmi_event_txstatus txs; | 
					
						
							|  |  |  | 	struct list_head list; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | struct wmi { | 
					
						
							|  |  |  | 	struct ath9k_htc_priv *drv_priv; | 
					
						
							|  |  |  | 	struct htc_target *htc; | 
					
						
							|  |  |  | 	enum htc_endpoint_id ctrl_epid; | 
					
						
							|  |  |  | 	struct mutex op_mutex; | 
					
						
							|  |  |  | 	struct completion cmd_wait; | 
					
						
							| 
									
										
										
										
											2010-04-16 11:54:01 +05:30
										 |  |  | 	enum wmi_cmd_id last_cmd_id; | 
					
						
							| 
									
										
										
										
											2011-04-13 11:23:52 +05:30
										 |  |  | 	struct sk_buff_head wmi_event_queue; | 
					
						
							|  |  |  | 	struct tasklet_struct wmi_event_tasklet; | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | 	u16 tx_seq_id; | 
					
						
							|  |  |  | 	u8 *cmd_rsp_buf; | 
					
						
							|  |  |  | 	u32 cmd_rsp_len; | 
					
						
							|  |  |  | 	bool stopped; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-13 11:26:39 +05:30
										 |  |  | 	struct list_head pending_tx_events; | 
					
						
							|  |  |  | 	spinlock_t event_lock; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | 	spinlock_t wmi_lock; | 
					
						
							| 
									
										
										
										
											2010-04-16 11:53:53 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 	atomic_t mwrite_cnt; | 
					
						
							|  |  |  | 	struct register_write multi_write[MAX_CMD_NUMBER]; | 
					
						
							|  |  |  | 	u32 multi_write_idx; | 
					
						
							|  |  |  | 	struct mutex multi_write_mutex; | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct wmi *ath9k_init_wmi(struct ath9k_htc_priv *priv); | 
					
						
							|  |  |  | void ath9k_deinit_wmi(struct ath9k_htc_priv *priv); | 
					
						
							|  |  |  | int ath9k_wmi_connect(struct htc_target *htc, struct wmi *wmi, | 
					
						
							|  |  |  | 		      enum htc_endpoint_id *wmi_ctrl_epid); | 
					
						
							|  |  |  | int ath9k_wmi_cmd(struct wmi *wmi, enum wmi_cmd_id cmd_id, | 
					
						
							|  |  |  | 		  u8 *cmd_buf, u32 cmd_len, | 
					
						
							|  |  |  | 		  u8 *rsp_buf, u32 rsp_len, | 
					
						
							|  |  |  | 		  u32 timeout); | 
					
						
							| 
									
										
										
										
											2011-04-13 11:23:52 +05:30
										 |  |  | void ath9k_wmi_event_tasklet(unsigned long data); | 
					
						
							| 
									
										
										
										
											2010-12-28 14:28:27 +05:30
										 |  |  | void ath9k_fatal_work(struct work_struct *work); | 
					
						
							| 
									
										
										
										
											2011-04-13 11:23:52 +05:30
										 |  |  | void ath9k_wmi_event_drain(struct ath9k_htc_priv *priv); | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | #define WMI_CMD(_wmi_cmd)						\
 | 
					
						
							|  |  |  | 	do {								\ | 
					
						
							|  |  |  | 		ret = ath9k_wmi_cmd(priv->wmi, _wmi_cmd, NULL, 0,	\ | 
					
						
							|  |  |  | 				    (u8 *) &cmd_rsp,			\ | 
					
						
							| 
									
										
										
										
											2010-04-23 10:28:18 +05:30
										 |  |  | 				    sizeof(cmd_rsp), HZ*2);		\ | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | 	} while (0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define WMI_CMD_BUF(_wmi_cmd, _buf)					\
 | 
					
						
							|  |  |  | 	do {								\ | 
					
						
							|  |  |  | 		ret = ath9k_wmi_cmd(priv->wmi, _wmi_cmd,		\ | 
					
						
							|  |  |  | 				    (u8 *) _buf, sizeof(*_buf),		\ | 
					
						
							| 
									
										
										
										
											2010-04-23 10:28:18 +05:30
										 |  |  | 				    &cmd_rsp, sizeof(cmd_rsp), HZ*2);	\ | 
					
						
							| 
									
										
										
										
											2010-03-17 14:25:25 +05:30
										 |  |  | 	} while (0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* WMI_H */
 |