1daeccac2SArend van Spriel // SPDX-License-Identifier: ISC 205491d2cSKalle Valo /* 305491d2cSKalle Valo * Copyright (c) 2012 Broadcom Corporation 405491d2cSKalle Valo */ 505491d2cSKalle Valo #ifndef WL_CFGP2P_H_ 605491d2cSKalle Valo #define WL_CFGP2P_H_ 705491d2cSKalle Valo 805491d2cSKalle Valo #include <net/cfg80211.h> 905491d2cSKalle Valo 1005491d2cSKalle Valo struct brcmf_cfg80211_info; 1105491d2cSKalle Valo 1205491d2cSKalle Valo /** 1305491d2cSKalle Valo * enum p2p_bss_type - different type of BSS configurations. 1405491d2cSKalle Valo * 1505491d2cSKalle Valo * @P2PAPI_BSSCFG_PRIMARY: maps to driver's primary bsscfg. 1605491d2cSKalle Valo * @P2PAPI_BSSCFG_DEVICE: maps to driver's P2P device discovery bsscfg. 17*babfd3caSWright Feng * @P2PAPI_BSSCFG_CONNECTION: maps to driver's 1st P2P connection bsscfg. 18*babfd3caSWright Feng * @P2PAPI_BSSCFG_CONNECTION2: maps to driver's 2nd P2P connection bsscfg. 1905491d2cSKalle Valo * @P2PAPI_BSSCFG_MAX: used for range checking. 2005491d2cSKalle Valo */ 2105491d2cSKalle Valo enum p2p_bss_type { 2205491d2cSKalle Valo P2PAPI_BSSCFG_PRIMARY, /* maps to driver's primary bsscfg */ 2305491d2cSKalle Valo P2PAPI_BSSCFG_DEVICE, /* maps to driver's P2P device discovery bsscfg */ 24*babfd3caSWright Feng P2PAPI_BSSCFG_CONNECTION, /* driver's 1st P2P connection bsscfg */ 25*babfd3caSWright Feng P2PAPI_BSSCFG_CONNECTION2, /* driver's 2nd P2P connection bsscfg */ 2605491d2cSKalle Valo P2PAPI_BSSCFG_MAX 2705491d2cSKalle Valo }; 2805491d2cSKalle Valo 2905491d2cSKalle Valo /** 3005491d2cSKalle Valo * struct p2p_bss - peer-to-peer bss related information. 3105491d2cSKalle Valo * 3205491d2cSKalle Valo * @vif: virtual interface of this P2P bss. 3305491d2cSKalle Valo * @private_data: TBD 3405491d2cSKalle Valo */ 3505491d2cSKalle Valo struct p2p_bss { 3605491d2cSKalle Valo struct brcmf_cfg80211_vif *vif; 3705491d2cSKalle Valo void *private_data; 3805491d2cSKalle Valo }; 3905491d2cSKalle Valo 4005491d2cSKalle Valo /** 4105491d2cSKalle Valo * enum brcmf_p2p_status - P2P specific dongle status. 4205491d2cSKalle Valo * 4305491d2cSKalle Valo * @BRCMF_P2P_STATUS_IF_ADD: peer-to-peer vif add sent to dongle. 4405491d2cSKalle Valo * @BRCMF_P2P_STATUS_IF_DEL: NOT-USED? 4505491d2cSKalle Valo * @BRCMF_P2P_STATUS_IF_DELETING: peer-to-peer vif delete sent to dongle. 4605491d2cSKalle Valo * @BRCMF_P2P_STATUS_IF_CHANGING: peer-to-peer vif change sent to dongle. 4705491d2cSKalle Valo * @BRCMF_P2P_STATUS_IF_CHANGED: peer-to-peer vif change completed on dongle. 4805491d2cSKalle Valo * @BRCMF_P2P_STATUS_ACTION_TX_COMPLETED: action frame tx completed. 4905491d2cSKalle Valo * @BRCMF_P2P_STATUS_ACTION_TX_NOACK: action frame tx not acked. 5005491d2cSKalle Valo * @BRCMF_P2P_STATUS_GO_NEG_PHASE: P2P GO negotiation ongoing. 5105491d2cSKalle Valo * @BRCMF_P2P_STATUS_DISCOVER_LISTEN: P2P listen, remaining on channel. 5205491d2cSKalle Valo * @BRCMF_P2P_STATUS_SENDING_ACT_FRAME: In the process of sending action frame. 5305491d2cSKalle Valo * @BRCMF_P2P_STATUS_WAITING_NEXT_AF_LISTEN: extra listen time for af tx. 5405491d2cSKalle Valo * @BRCMF_P2P_STATUS_WAITING_NEXT_ACT_FRAME: waiting for action frame response. 5505491d2cSKalle Valo * @BRCMF_P2P_STATUS_FINDING_COMMON_CHANNEL: search channel for AF active. 5605491d2cSKalle Valo */ 5705491d2cSKalle Valo enum brcmf_p2p_status { 5805491d2cSKalle Valo BRCMF_P2P_STATUS_ENABLED, 5905491d2cSKalle Valo BRCMF_P2P_STATUS_IF_ADD, 6005491d2cSKalle Valo BRCMF_P2P_STATUS_IF_DEL, 6105491d2cSKalle Valo BRCMF_P2P_STATUS_IF_DELETING, 6205491d2cSKalle Valo BRCMF_P2P_STATUS_IF_CHANGING, 6305491d2cSKalle Valo BRCMF_P2P_STATUS_IF_CHANGED, 6405491d2cSKalle Valo BRCMF_P2P_STATUS_ACTION_TX_COMPLETED, 6505491d2cSKalle Valo BRCMF_P2P_STATUS_ACTION_TX_NOACK, 6605491d2cSKalle Valo BRCMF_P2P_STATUS_GO_NEG_PHASE, 6705491d2cSKalle Valo BRCMF_P2P_STATUS_DISCOVER_LISTEN, 6805491d2cSKalle Valo BRCMF_P2P_STATUS_SENDING_ACT_FRAME, 6905491d2cSKalle Valo BRCMF_P2P_STATUS_WAITING_NEXT_AF_LISTEN, 7005491d2cSKalle Valo BRCMF_P2P_STATUS_WAITING_NEXT_ACT_FRAME, 7105491d2cSKalle Valo BRCMF_P2P_STATUS_FINDING_COMMON_CHANNEL 7205491d2cSKalle Valo }; 7305491d2cSKalle Valo 7405491d2cSKalle Valo /** 7505491d2cSKalle Valo * struct afx_hdl - action frame off channel storage. 7605491d2cSKalle Valo * 7705491d2cSKalle Valo * @afx_work: worker thread for searching channel 7805491d2cSKalle Valo * @act_frm_scan: thread synchronizing struct. 7905491d2cSKalle Valo * @is_active: channel searching active. 8005491d2cSKalle Valo * @peer_chan: current channel. 8105491d2cSKalle Valo * @is_listen: sets mode for afx worker. 8205491d2cSKalle Valo * @my_listen_chan: this peers listen channel. 8305491d2cSKalle Valo * @peer_listen_chan: remote peers listen channel. 8405491d2cSKalle Valo * @tx_dst_addr: mac address where tx af should be sent to. 8505491d2cSKalle Valo */ 8605491d2cSKalle Valo struct afx_hdl { 8705491d2cSKalle Valo struct work_struct afx_work; 8805491d2cSKalle Valo struct completion act_frm_scan; 8905491d2cSKalle Valo bool is_active; 9005491d2cSKalle Valo s32 peer_chan; 9105491d2cSKalle Valo bool is_listen; 9205491d2cSKalle Valo u16 my_listen_chan; 9305491d2cSKalle Valo u16 peer_listen_chan; 9405491d2cSKalle Valo u8 tx_dst_addr[ETH_ALEN]; 9505491d2cSKalle Valo }; 9605491d2cSKalle Valo 9705491d2cSKalle Valo /** 9805491d2cSKalle Valo * struct brcmf_p2p_info - p2p specific driver information. 9905491d2cSKalle Valo * 10005491d2cSKalle Valo * @cfg: driver private data for cfg80211 interface. 10105491d2cSKalle Valo * @status: status of P2P (see enum brcmf_p2p_status). 10205491d2cSKalle Valo * @dev_addr: P2P device address. 10305491d2cSKalle Valo * @int_addr: P2P interface address. 10405491d2cSKalle Valo * @bss_idx: informate for P2P bss types. 10505491d2cSKalle Valo * @listen_timer: timer for @WL_P2P_DISC_ST_LISTEN discover state. 10605491d2cSKalle Valo * @listen_channel: channel for @WL_P2P_DISC_ST_LISTEN discover state. 10705491d2cSKalle Valo * @remain_on_channel: contains copy of struct used by cfg80211. 10805491d2cSKalle Valo * @remain_on_channel_cookie: cookie counter for remain on channel cmd 10905491d2cSKalle Valo * @next_af_subtype: expected action frame subtype. 11005491d2cSKalle Valo * @send_af_done: indication that action frame tx is complete. 11105491d2cSKalle Valo * @afx_hdl: action frame search handler info. 11205491d2cSKalle Valo * @af_sent_channel: channel action frame is sent. 11305491d2cSKalle Valo * @af_tx_sent_jiffies: jiffies time when af tx was transmitted. 11405491d2cSKalle Valo * @wait_next_af: thread synchronizing struct. 11505491d2cSKalle Valo * @gon_req_action: about to send go negotiation requets frame. 11605491d2cSKalle Valo * @block_gon_req_tx: drop tx go negotiation requets frame. 11705491d2cSKalle Valo * @p2pdev_dynamically: is p2p device if created by module param or supplicant. 118fbf07000SChung-Hsien Hsu * @wait_for_offchan_complete: wait for off-channel tx completion event. 11905491d2cSKalle Valo */ 12005491d2cSKalle Valo struct brcmf_p2p_info { 12105491d2cSKalle Valo struct brcmf_cfg80211_info *cfg; 12205491d2cSKalle Valo unsigned long status; 12305491d2cSKalle Valo u8 dev_addr[ETH_ALEN]; 124*babfd3caSWright Feng u8 conn_int_addr[ETH_ALEN]; 125*babfd3caSWright Feng u8 conn2_int_addr[ETH_ALEN]; 12605491d2cSKalle Valo struct p2p_bss bss_idx[P2PAPI_BSSCFG_MAX]; 12705491d2cSKalle Valo struct timer_list listen_timer; 12805491d2cSKalle Valo u8 listen_channel; 12905491d2cSKalle Valo struct ieee80211_channel remain_on_channel; 13005491d2cSKalle Valo u32 remain_on_channel_cookie; 13105491d2cSKalle Valo u8 next_af_subtype; 13205491d2cSKalle Valo struct completion send_af_done; 13305491d2cSKalle Valo struct afx_hdl afx_hdl; 13405491d2cSKalle Valo u32 af_sent_channel; 13505491d2cSKalle Valo unsigned long af_tx_sent_jiffies; 13605491d2cSKalle Valo struct completion wait_next_af; 13705491d2cSKalle Valo bool gon_req_action; 13805491d2cSKalle Valo bool block_gon_req_tx; 13905491d2cSKalle Valo bool p2pdev_dynamically; 140fbf07000SChung-Hsien Hsu bool wait_for_offchan_complete; 14105491d2cSKalle Valo }; 14205491d2cSKalle Valo 14305491d2cSKalle Valo s32 brcmf_p2p_attach(struct brcmf_cfg80211_info *cfg, bool p2pdev_forced); 14405491d2cSKalle Valo void brcmf_p2p_detach(struct brcmf_p2p_info *p2p); 14505491d2cSKalle Valo struct wireless_dev *brcmf_p2p_add_vif(struct wiphy *wiphy, const char *name, 14605491d2cSKalle Valo unsigned char name_assign_type, 147818a986eSJohannes Berg enum nl80211_iftype type, 14805491d2cSKalle Valo struct vif_params *params); 14905491d2cSKalle Valo int brcmf_p2p_del_vif(struct wiphy *wiphy, struct wireless_dev *wdev); 15005491d2cSKalle Valo int brcmf_p2p_ifchange(struct brcmf_cfg80211_info *cfg, 15105491d2cSKalle Valo enum brcmf_fil_p2p_if_types if_type); 15215dacf88Smhiramat@kernel.org void brcmf_p2p_ifp_removed(struct brcmf_if *ifp, bool rtnl_locked); 15305491d2cSKalle Valo int brcmf_p2p_start_device(struct wiphy *wiphy, struct wireless_dev *wdev); 15405491d2cSKalle Valo void brcmf_p2p_stop_device(struct wiphy *wiphy, struct wireless_dev *wdev); 15505491d2cSKalle Valo int brcmf_p2p_scan_prep(struct wiphy *wiphy, 15605491d2cSKalle Valo struct cfg80211_scan_request *request, 15705491d2cSKalle Valo struct brcmf_cfg80211_vif *vif); 15805491d2cSKalle Valo int brcmf_p2p_remain_on_channel(struct wiphy *wiphy, struct wireless_dev *wdev, 15905491d2cSKalle Valo struct ieee80211_channel *channel, 16005491d2cSKalle Valo unsigned int duration, u64 *cookie); 16105491d2cSKalle Valo int brcmf_p2p_notify_listen_complete(struct brcmf_if *ifp, 16205491d2cSKalle Valo const struct brcmf_event_msg *e, 16305491d2cSKalle Valo void *data); 16405491d2cSKalle Valo void brcmf_p2p_cancel_remain_on_channel(struct brcmf_if *ifp); 16505491d2cSKalle Valo int brcmf_p2p_notify_action_frame_rx(struct brcmf_if *ifp, 16605491d2cSKalle Valo const struct brcmf_event_msg *e, 16705491d2cSKalle Valo void *data); 16805491d2cSKalle Valo int brcmf_p2p_notify_action_tx_complete(struct brcmf_if *ifp, 16905491d2cSKalle Valo const struct brcmf_event_msg *e, 17005491d2cSKalle Valo void *data); 17105491d2cSKalle Valo bool brcmf_p2p_send_action_frame(struct brcmf_cfg80211_info *cfg, 17205491d2cSKalle Valo struct net_device *ndev, 17305491d2cSKalle Valo struct brcmf_fil_af_params_le *af_params); 17405491d2cSKalle Valo bool brcmf_p2p_scan_finding_common_channel(struct brcmf_cfg80211_info *cfg, 17505491d2cSKalle Valo struct brcmf_bss_info_le *bi); 17605491d2cSKalle Valo s32 brcmf_p2p_notify_rx_mgmt_p2p_probereq(struct brcmf_if *ifp, 17705491d2cSKalle Valo const struct brcmf_event_msg *e, 17805491d2cSKalle Valo void *data); 17905491d2cSKalle Valo #endif /* WL_CFGP2P_H_ */ 180