diff options
Diffstat (limited to 'drivers/net/wireless/ath/ath10k/wmi-ops.h')
| -rw-r--r-- | drivers/net/wireless/ath/ath10k/wmi-ops.h | 33 | 
1 files changed, 31 insertions, 2 deletions
| diff --git a/drivers/net/wireless/ath/ath10k/wmi-ops.h b/drivers/net/wireless/ath/ath10k/wmi-ops.h index 64ebd304f907..c9a8bb1186f2 100644 --- a/drivers/net/wireless/ath/ath10k/wmi-ops.h +++ b/drivers/net/wireless/ath/ath10k/wmi-ops.h @@ -51,6 +51,8 @@ struct wmi_ops {  			    struct wmi_roam_ev_arg *arg);  	int (*pull_wow_event)(struct ath10k *ar, struct sk_buff *skb,  			      struct wmi_wow_ev_arg *arg); +	int (*pull_echo_ev)(struct ath10k *ar, struct sk_buff *skb, +			    struct wmi_echo_ev_arg *arg);  	enum wmi_txbf_conf (*get_txbf_conf_scheme)(struct ath10k *ar);  	struct sk_buff *(*gen_pdev_suspend)(struct ath10k *ar, u32 suspend_opt); @@ -123,7 +125,7 @@ struct wmi_ops {  					     enum wmi_force_fw_hang_type type,  					     u32 delay_ms);  	struct sk_buff *(*gen_mgmt_tx)(struct ath10k *ar, struct sk_buff *skb); -	struct sk_buff *(*gen_dbglog_cfg)(struct ath10k *ar, u32 module_enable, +	struct sk_buff *(*gen_dbglog_cfg)(struct ath10k *ar, u64 module_enable,  					  u32 log_level);  	struct sk_buff *(*gen_pktlog_enable)(struct ath10k *ar, u32 filter);  	struct sk_buff *(*gen_pktlog_disable)(struct ath10k *ar); @@ -194,6 +196,7 @@ struct wmi_ops {  	struct sk_buff *(*gen_pdev_bss_chan_info_req)  					(struct ath10k *ar,  					 enum wmi_bss_survey_req_type type); +	struct sk_buff *(*gen_echo)(struct ath10k *ar, u32 value);  };  int ath10k_wmi_cmd_send(struct ath10k *ar, struct sk_buff *skb, u32 cmd_id); @@ -349,6 +352,16 @@ ath10k_wmi_pull_wow_event(struct ath10k *ar, struct sk_buff *skb,  	return ar->wmi.ops->pull_wow_event(ar, skb, arg);  } +static inline int +ath10k_wmi_pull_echo_ev(struct ath10k *ar, struct sk_buff *skb, +			struct wmi_echo_ev_arg *arg) +{ +	if (!ar->wmi.ops->pull_echo_ev) +		return -EOPNOTSUPP; + +	return ar->wmi.ops->pull_echo_ev(ar, skb, arg); +} +  static inline enum wmi_txbf_conf  ath10k_wmi_get_txbf_conf_scheme(struct ath10k *ar)  { @@ -932,7 +945,7 @@ ath10k_wmi_force_fw_hang(struct ath10k *ar,  }  static inline int -ath10k_wmi_dbglog_cfg(struct ath10k *ar, u32 module_enable, u32 log_level) +ath10k_wmi_dbglog_cfg(struct ath10k *ar, u64 module_enable, u32 log_level)  {  	struct sk_buff *skb; @@ -1382,4 +1395,20 @@ ath10k_wmi_pdev_bss_chan_info_request(struct ath10k *ar,  				   wmi->cmd->pdev_bss_chan_info_request_cmdid);  } +static inline int +ath10k_wmi_echo(struct ath10k *ar, u32 value) +{ +	struct ath10k_wmi *wmi = &ar->wmi; +	struct sk_buff *skb; + +	if (!wmi->ops->gen_echo) +		return -EOPNOTSUPP; + +	skb = wmi->ops->gen_echo(ar, value); +	if (IS_ERR(skb)) +		return PTR_ERR(skb); + +	return ath10k_wmi_cmd_send(ar, skb, wmi->cmd->echo_cmdid); +} +  #endif |