1*4882a593Smuzhiyun // SPDX-License-Identifier: ISC 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Copyright (c) 2012 Broadcom Corporation 4*4882a593Smuzhiyun */ 5*4882a593Smuzhiyun #ifndef WL_CFGP2P_H_ 6*4882a593Smuzhiyun #define WL_CFGP2P_H_ 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #include <net/cfg80211.h> 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun struct brcmf_cfg80211_info; 11*4882a593Smuzhiyun 12*4882a593Smuzhiyun /** 13*4882a593Smuzhiyun * enum p2p_bss_type - different type of BSS configurations. 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * @P2PAPI_BSSCFG_PRIMARY: maps to driver's primary bsscfg. 16*4882a593Smuzhiyun * @P2PAPI_BSSCFG_DEVICE: maps to driver's P2P device discovery bsscfg. 17*4882a593Smuzhiyun * @P2PAPI_BSSCFG_CONNECTION: maps to driver's 1st P2P connection bsscfg. 18*4882a593Smuzhiyun * @P2PAPI_BSSCFG_CONNECTION2: maps to driver's 2nd P2P connection bsscfg. 19*4882a593Smuzhiyun * @P2PAPI_BSSCFG_MAX: used for range checking. 20*4882a593Smuzhiyun */ 21*4882a593Smuzhiyun enum p2p_bss_type { 22*4882a593Smuzhiyun P2PAPI_BSSCFG_PRIMARY, /* maps to driver's primary bsscfg */ 23*4882a593Smuzhiyun P2PAPI_BSSCFG_DEVICE, /* maps to driver's P2P device discovery bsscfg */ 24*4882a593Smuzhiyun P2PAPI_BSSCFG_CONNECTION, /* driver's 1st P2P connection bsscfg */ 25*4882a593Smuzhiyun P2PAPI_BSSCFG_CONNECTION2, /* driver's 2nd P2P connection bsscfg */ 26*4882a593Smuzhiyun P2PAPI_BSSCFG_MAX 27*4882a593Smuzhiyun }; 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun /** 30*4882a593Smuzhiyun * struct p2p_bss - peer-to-peer bss related information. 31*4882a593Smuzhiyun * 32*4882a593Smuzhiyun * @vif: virtual interface of this P2P bss. 33*4882a593Smuzhiyun * @private_data: TBD 34*4882a593Smuzhiyun */ 35*4882a593Smuzhiyun struct p2p_bss { 36*4882a593Smuzhiyun struct brcmf_cfg80211_vif *vif; 37*4882a593Smuzhiyun void *private_data; 38*4882a593Smuzhiyun }; 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun /** 41*4882a593Smuzhiyun * enum brcmf_p2p_status - P2P specific dongle status. 42*4882a593Smuzhiyun * 43*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_IF_ADD: peer-to-peer vif add sent to dongle. 44*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_IF_DEL: NOT-USED? 45*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_IF_DELETING: peer-to-peer vif delete sent to dongle. 46*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_IF_CHANGING: peer-to-peer vif change sent to dongle. 47*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_IF_CHANGED: peer-to-peer vif change completed on dongle. 48*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_ACTION_TX_COMPLETED: action frame tx completed. 49*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_ACTION_TX_NOACK: action frame tx not acked. 50*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_GO_NEG_PHASE: P2P GO negotiation ongoing. 51*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_DISCOVER_LISTEN: P2P listen, remaining on channel. 52*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_SENDING_ACT_FRAME: In the process of sending action frame. 53*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_WAITING_NEXT_AF_LISTEN: extra listen time for af tx. 54*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_WAITING_NEXT_ACT_FRAME: waiting for action frame response. 55*4882a593Smuzhiyun * @BRCMF_P2P_STATUS_FINDING_COMMON_CHANNEL: search channel for AF active. 56*4882a593Smuzhiyun */ 57*4882a593Smuzhiyun enum brcmf_p2p_status { 58*4882a593Smuzhiyun BRCMF_P2P_STATUS_ENABLED, 59*4882a593Smuzhiyun BRCMF_P2P_STATUS_IF_ADD, 60*4882a593Smuzhiyun BRCMF_P2P_STATUS_IF_DEL, 61*4882a593Smuzhiyun BRCMF_P2P_STATUS_IF_DELETING, 62*4882a593Smuzhiyun BRCMF_P2P_STATUS_IF_CHANGING, 63*4882a593Smuzhiyun BRCMF_P2P_STATUS_IF_CHANGED, 64*4882a593Smuzhiyun BRCMF_P2P_STATUS_ACTION_TX_COMPLETED, 65*4882a593Smuzhiyun BRCMF_P2P_STATUS_ACTION_TX_NOACK, 66*4882a593Smuzhiyun BRCMF_P2P_STATUS_GO_NEG_PHASE, 67*4882a593Smuzhiyun BRCMF_P2P_STATUS_DISCOVER_LISTEN, 68*4882a593Smuzhiyun BRCMF_P2P_STATUS_SENDING_ACT_FRAME, 69*4882a593Smuzhiyun BRCMF_P2P_STATUS_WAITING_NEXT_AF_LISTEN, 70*4882a593Smuzhiyun BRCMF_P2P_STATUS_WAITING_NEXT_ACT_FRAME, 71*4882a593Smuzhiyun BRCMF_P2P_STATUS_FINDING_COMMON_CHANNEL 72*4882a593Smuzhiyun }; 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun /** 75*4882a593Smuzhiyun * struct afx_hdl - action frame off channel storage. 76*4882a593Smuzhiyun * 77*4882a593Smuzhiyun * @afx_work: worker thread for searching channel 78*4882a593Smuzhiyun * @act_frm_scan: thread synchronizing struct. 79*4882a593Smuzhiyun * @is_active: channel searching active. 80*4882a593Smuzhiyun * @peer_chan: current channel. 81*4882a593Smuzhiyun * @is_listen: sets mode for afx worker. 82*4882a593Smuzhiyun * @my_listen_chan: this peers listen channel. 83*4882a593Smuzhiyun * @peer_listen_chan: remote peers listen channel. 84*4882a593Smuzhiyun * @tx_dst_addr: mac address where tx af should be sent to. 85*4882a593Smuzhiyun */ 86*4882a593Smuzhiyun struct afx_hdl { 87*4882a593Smuzhiyun struct work_struct afx_work; 88*4882a593Smuzhiyun struct completion act_frm_scan; 89*4882a593Smuzhiyun bool is_active; 90*4882a593Smuzhiyun s32 peer_chan; 91*4882a593Smuzhiyun bool is_listen; 92*4882a593Smuzhiyun u16 my_listen_chan; 93*4882a593Smuzhiyun u16 peer_listen_chan; 94*4882a593Smuzhiyun u8 tx_dst_addr[ETH_ALEN]; 95*4882a593Smuzhiyun }; 96*4882a593Smuzhiyun 97*4882a593Smuzhiyun /** 98*4882a593Smuzhiyun * struct brcmf_p2p_info - p2p specific driver information. 99*4882a593Smuzhiyun * 100*4882a593Smuzhiyun * @cfg: driver private data for cfg80211 interface. 101*4882a593Smuzhiyun * @status: status of P2P (see enum brcmf_p2p_status). 102*4882a593Smuzhiyun * @dev_addr: P2P device address. 103*4882a593Smuzhiyun * @int_addr: P2P interface address. 104*4882a593Smuzhiyun * @bss_idx: informate for P2P bss types. 105*4882a593Smuzhiyun * @listen_timer: timer for @WL_P2P_DISC_ST_LISTEN discover state. 106*4882a593Smuzhiyun * @listen_channel: channel for @WL_P2P_DISC_ST_LISTEN discover state. 107*4882a593Smuzhiyun * @remain_on_channel: contains copy of struct used by cfg80211. 108*4882a593Smuzhiyun * @remain_on_channel_cookie: cookie counter for remain on channel cmd 109*4882a593Smuzhiyun * @next_af_subtype: expected action frame subtype. 110*4882a593Smuzhiyun * @send_af_done: indication that action frame tx is complete. 111*4882a593Smuzhiyun * @afx_hdl: action frame search handler info. 112*4882a593Smuzhiyun * @af_sent_channel: channel action frame is sent. 113*4882a593Smuzhiyun * @af_tx_sent_jiffies: jiffies time when af tx was transmitted. 114*4882a593Smuzhiyun * @wait_next_af: thread synchronizing struct. 115*4882a593Smuzhiyun * @gon_req_action: about to send go negotiation requets frame. 116*4882a593Smuzhiyun * @block_gon_req_tx: drop tx go negotiation requets frame. 117*4882a593Smuzhiyun * @p2pdev_dynamically: is p2p device if created by module param or supplicant. 118*4882a593Smuzhiyun * @wait_for_offchan_complete: wait for off-channel tx completion event. 119*4882a593Smuzhiyun */ 120*4882a593Smuzhiyun struct brcmf_p2p_info { 121*4882a593Smuzhiyun struct brcmf_cfg80211_info *cfg; 122*4882a593Smuzhiyun unsigned long status; 123*4882a593Smuzhiyun u8 dev_addr[ETH_ALEN]; 124*4882a593Smuzhiyun u8 conn_int_addr[ETH_ALEN]; 125*4882a593Smuzhiyun u8 conn2_int_addr[ETH_ALEN]; 126*4882a593Smuzhiyun struct p2p_bss bss_idx[P2PAPI_BSSCFG_MAX]; 127*4882a593Smuzhiyun struct timer_list listen_timer; 128*4882a593Smuzhiyun u8 listen_channel; 129*4882a593Smuzhiyun struct ieee80211_channel remain_on_channel; 130*4882a593Smuzhiyun u32 remain_on_channel_cookie; 131*4882a593Smuzhiyun u8 next_af_subtype; 132*4882a593Smuzhiyun struct completion send_af_done; 133*4882a593Smuzhiyun struct afx_hdl afx_hdl; 134*4882a593Smuzhiyun u32 af_sent_channel; 135*4882a593Smuzhiyun unsigned long af_tx_sent_jiffies; 136*4882a593Smuzhiyun struct completion wait_next_af; 137*4882a593Smuzhiyun bool gon_req_action; 138*4882a593Smuzhiyun bool block_gon_req_tx; 139*4882a593Smuzhiyun bool p2pdev_dynamically; 140*4882a593Smuzhiyun bool wait_for_offchan_complete; 141*4882a593Smuzhiyun }; 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun s32 brcmf_p2p_attach(struct brcmf_cfg80211_info *cfg, bool p2pdev_forced); 144*4882a593Smuzhiyun void brcmf_p2p_detach(struct brcmf_p2p_info *p2p); 145*4882a593Smuzhiyun struct wireless_dev *brcmf_p2p_add_vif(struct wiphy *wiphy, const char *name, 146*4882a593Smuzhiyun unsigned char name_assign_type, 147*4882a593Smuzhiyun enum nl80211_iftype type, 148*4882a593Smuzhiyun struct vif_params *params); 149*4882a593Smuzhiyun int brcmf_p2p_del_vif(struct wiphy *wiphy, struct wireless_dev *wdev); 150*4882a593Smuzhiyun int brcmf_p2p_ifchange(struct brcmf_cfg80211_info *cfg, 151*4882a593Smuzhiyun enum brcmf_fil_p2p_if_types if_type); 152*4882a593Smuzhiyun void brcmf_p2p_ifp_removed(struct brcmf_if *ifp, bool rtnl_locked); 153*4882a593Smuzhiyun int brcmf_p2p_start_device(struct wiphy *wiphy, struct wireless_dev *wdev); 154*4882a593Smuzhiyun void brcmf_p2p_stop_device(struct wiphy *wiphy, struct wireless_dev *wdev); 155*4882a593Smuzhiyun int brcmf_p2p_scan_prep(struct wiphy *wiphy, 156*4882a593Smuzhiyun struct cfg80211_scan_request *request, 157*4882a593Smuzhiyun struct brcmf_cfg80211_vif *vif); 158*4882a593Smuzhiyun int brcmf_p2p_remain_on_channel(struct wiphy *wiphy, struct wireless_dev *wdev, 159*4882a593Smuzhiyun struct ieee80211_channel *channel, 160*4882a593Smuzhiyun unsigned int duration, u64 *cookie); 161*4882a593Smuzhiyun int brcmf_p2p_notify_listen_complete(struct brcmf_if *ifp, 162*4882a593Smuzhiyun const struct brcmf_event_msg *e, 163*4882a593Smuzhiyun void *data); 164*4882a593Smuzhiyun void brcmf_p2p_cancel_remain_on_channel(struct brcmf_if *ifp); 165*4882a593Smuzhiyun int brcmf_p2p_notify_action_frame_rx(struct brcmf_if *ifp, 166*4882a593Smuzhiyun const struct brcmf_event_msg *e, 167*4882a593Smuzhiyun void *data); 168*4882a593Smuzhiyun int brcmf_p2p_notify_action_tx_complete(struct brcmf_if *ifp, 169*4882a593Smuzhiyun const struct brcmf_event_msg *e, 170*4882a593Smuzhiyun void *data); 171*4882a593Smuzhiyun bool brcmf_p2p_send_action_frame(struct brcmf_cfg80211_info *cfg, 172*4882a593Smuzhiyun struct net_device *ndev, 173*4882a593Smuzhiyun struct brcmf_fil_af_params_le *af_params); 174*4882a593Smuzhiyun bool brcmf_p2p_scan_finding_common_channel(struct brcmf_cfg80211_info *cfg, 175*4882a593Smuzhiyun struct brcmf_bss_info_le *bi); 176*4882a593Smuzhiyun s32 brcmf_p2p_notify_rx_mgmt_p2p_probereq(struct brcmf_if *ifp, 177*4882a593Smuzhiyun const struct brcmf_event_msg *e, 178*4882a593Smuzhiyun void *data); 179*4882a593Smuzhiyun #endif /* WL_CFGP2P_H_ */ 180