cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

smd.h (6639B)


      1/*
      2 * Copyright (c) 2013 Eugene Krasnikov <k.eugene.e@gmail.com>
      3 *
      4 * Permission to use, copy, modify, and/or distribute this software for any
      5 * purpose with or without fee is hereby granted, provided that the above
      6 * copyright notice and this permission notice appear in all copies.
      7 *
      8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
      9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
     10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
     11 * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
     12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
     13 * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
     14 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
     15 */
     16
     17#ifndef _SMD_H_
     18#define _SMD_H_
     19
     20#include "wcn36xx.h"
     21
     22/* Max shared size is 4k but we take less.*/
     23#define WCN36XX_NV_FRAGMENT_SIZE			3072
     24
     25#define WCN36XX_HAL_BUF_SIZE				4096
     26
     27#define HAL_MSG_TIMEOUT 10000
     28#define WCN36XX_SMSM_WLAN_TX_ENABLE			0x00000400
     29#define WCN36XX_SMSM_WLAN_TX_RINGS_EMPTY		0x00000200
     30/* The PNO version info be contained in the rsp msg */
     31#define WCN36XX_FW_MSG_PNO_VERSION_MASK			0x8000
     32
     33enum wcn36xx_fw_msg_result {
     34	WCN36XX_FW_MSG_RESULT_SUCCESS			= 0,
     35	WCN36XX_FW_MSG_RESULT_SUCCESS_SYNC		= 1,
     36
     37	WCN36XX_FW_MSG_RESULT_MEM_FAIL			= 5,
     38};
     39
     40/******************************/
     41/* SMD requests and responses */
     42/******************************/
     43struct wcn36xx_fw_msg_status_rsp {
     44	u32	status;
     45} __packed;
     46
     47struct wcn36xx_hal_ind_msg {
     48	struct list_head list;
     49	size_t msg_len;
     50	u8 msg[];
     51};
     52
     53struct wcn36xx;
     54struct rpmsg_device;
     55
     56int wcn36xx_smd_open(struct wcn36xx *wcn);
     57void wcn36xx_smd_close(struct wcn36xx *wcn);
     58
     59int wcn36xx_smd_load_nv(struct wcn36xx *wcn);
     60int wcn36xx_smd_start(struct wcn36xx *wcn);
     61int wcn36xx_smd_stop(struct wcn36xx *wcn);
     62int wcn36xx_smd_start_scan(struct wcn36xx *wcn, u8 scan_channel);
     63int wcn36xx_smd_end_scan(struct wcn36xx *wcn, u8 scan_channel);
     64int wcn36xx_smd_finish_scan(struct wcn36xx *wcn, enum wcn36xx_hal_sys_mode mode,
     65			    struct ieee80211_vif *vif);
     66int wcn36xx_smd_init_scan(struct wcn36xx *wcn, enum wcn36xx_hal_sys_mode mode,
     67			  struct ieee80211_vif *vif);
     68
     69int wcn36xx_smd_update_scan_params(struct wcn36xx *wcn, u8 *channels, size_t channel_count);
     70int wcn36xx_smd_start_hw_scan(struct wcn36xx *wcn, struct ieee80211_vif *vif,
     71			      struct cfg80211_scan_request *req);
     72int wcn36xx_smd_stop_hw_scan(struct wcn36xx *wcn);
     73int wcn36xx_smd_update_channel_list(struct wcn36xx *wcn, struct cfg80211_scan_request *req);
     74int wcn36xx_smd_add_sta_self(struct wcn36xx *wcn, struct ieee80211_vif *vif);
     75int wcn36xx_smd_delete_sta_self(struct wcn36xx *wcn, u8 *addr);
     76int wcn36xx_smd_delete_sta(struct wcn36xx *wcn, u8 sta_index);
     77int wcn36xx_smd_join(struct wcn36xx *wcn, const u8 *bssid, u8 *vif, u8 ch);
     78int wcn36xx_smd_set_link_st(struct wcn36xx *wcn, const u8 *bssid,
     79			    const u8 *sta_mac,
     80			    enum wcn36xx_hal_link_state state);
     81int wcn36xx_smd_config_bss(struct wcn36xx *wcn, struct ieee80211_vif *vif,
     82			   struct ieee80211_sta *sta, const u8 *bssid,
     83			   bool update);
     84int wcn36xx_smd_delete_bss(struct wcn36xx *wcn, struct ieee80211_vif *vif);
     85int wcn36xx_smd_config_sta(struct wcn36xx *wcn, struct ieee80211_vif *vif,
     86			   struct ieee80211_sta *sta);
     87int wcn36xx_smd_send_beacon(struct wcn36xx *wcn, struct ieee80211_vif *vif,
     88			    struct sk_buff *skb_beacon, u16 tim_off,
     89			    u16 p2p_off);
     90int wcn36xx_smd_switch_channel(struct wcn36xx *wcn,
     91			       struct ieee80211_vif *vif, int ch);
     92int wcn36xx_smd_process_ptt_msg(struct wcn36xx *wcn,
     93				struct ieee80211_vif *vif,
     94				void *ptt_msg, size_t len,
     95				void **ptt_rsp_msg);
     96int wcn36xx_smd_update_proberesp_tmpl(struct wcn36xx *wcn,
     97				      struct ieee80211_vif *vif,
     98				      struct sk_buff *skb);
     99int wcn36xx_smd_set_stakey(struct wcn36xx *wcn,
    100			   enum ani_ed_type enc_type,
    101			   u8 keyidx,
    102			   u8 keylen,
    103			   u8 *key,
    104			   u8 sta_index);
    105int wcn36xx_smd_set_bsskey(struct wcn36xx *wcn,
    106			   enum ani_ed_type enc_type,
    107			   u8 bssidx,
    108			   u8 keyidx,
    109			   u8 keylen,
    110			   u8 *key);
    111int wcn36xx_smd_remove_stakey(struct wcn36xx *wcn,
    112			      enum ani_ed_type enc_type,
    113			      u8 keyidx,
    114			      u8 sta_index);
    115int wcn36xx_smd_remove_bsskey(struct wcn36xx *wcn,
    116			      enum ani_ed_type enc_type,
    117			      u8 bssidx,
    118			      u8 keyidx);
    119int wcn36xx_smd_enter_bmps(struct wcn36xx *wcn, struct ieee80211_vif *vif);
    120int wcn36xx_smd_exit_bmps(struct wcn36xx *wcn, struct ieee80211_vif *vif);
    121int wcn36xx_smd_set_power_params(struct wcn36xx *wcn, bool ignore_dtim);
    122int wcn36xx_smd_keep_alive_req(struct wcn36xx *wcn,
    123			       struct ieee80211_vif *vif,
    124			       int packet_type);
    125int wcn36xx_smd_dump_cmd_req(struct wcn36xx *wcn, u32 arg1, u32 arg2,
    126			     u32 arg3, u32 arg4, u32 arg5);
    127int wcn36xx_smd_feature_caps_exchange(struct wcn36xx *wcn);
    128void set_feat_caps(u32 *bitmap, enum place_holder_in_cap_bitmap cap);
    129int get_feat_caps(u32 *bitmap, enum place_holder_in_cap_bitmap cap);
    130void clear_feat_caps(u32 *bitmap, enum place_holder_in_cap_bitmap cap);
    131
    132int wcn36xx_smd_add_ba_session(struct wcn36xx *wcn,
    133		struct ieee80211_sta *sta,
    134		u16 tid,
    135		u16 *ssn,
    136		u8 direction,
    137		u8 sta_index);
    138int wcn36xx_smd_add_ba(struct wcn36xx *wcn, u8 session_id);
    139int wcn36xx_smd_del_ba(struct wcn36xx *wcn, u16 tid, u8 direction, u8 sta_index);
    140int wcn36xx_smd_trigger_ba(struct wcn36xx *wcn, u8 sta_index, u16 tid, u16 *ssn);
    141int wcn36xx_smd_get_stats(struct wcn36xx *wcn, u8 sta_index, u32 stats_mask,
    142			  struct station_info *sinfo);
    143
    144int wcn36xx_smd_update_cfg(struct wcn36xx *wcn, u32 cfg_id, u32 value);
    145
    146int wcn36xx_smd_rsp_process(struct rpmsg_device *rpdev,
    147			    void *buf, int len, void *priv, u32 addr);
    148
    149int wcn36xx_smd_set_mc_list(struct wcn36xx *wcn,
    150			    struct ieee80211_vif *vif,
    151			    struct wcn36xx_hal_rcv_flt_mc_addr_list_type *fp);
    152
    153int wcn36xx_smd_arp_offload(struct wcn36xx *wcn, struct ieee80211_vif *vif,
    154			    bool enable);
    155
    156int wcn36xx_smd_ipv6_ns_offload(struct wcn36xx *wcn, struct ieee80211_vif *vif,
    157				bool enable);
    158
    159int wcn36xx_smd_gtk_offload(struct wcn36xx *wcn, struct ieee80211_vif *vif,
    160			    bool enable);
    161
    162int wcn36xx_smd_gtk_offload_get_info(struct wcn36xx *wcn,
    163				     struct ieee80211_vif *vif);
    164
    165int wcn36xx_smd_wlan_host_suspend_ind(struct wcn36xx *wcn);
    166
    167int wcn36xx_smd_host_resume(struct wcn36xx *wcn);
    168
    169int wcn36xx_smd_enter_imps(struct wcn36xx *wcn);
    170int wcn36xx_smd_exit_imps(struct wcn36xx *wcn);
    171
    172int wcn36xx_smd_add_beacon_filter(struct wcn36xx *wcn,
    173				  struct ieee80211_vif *vif);
    174
    175#endif	/* _SMD_H_ */