xref: /openbmc/linux/drivers/net/wireless/broadcom/brcm80211/brcmfmac/p2p.h (revision 4b4193256c8d3bc3a5397b5cd9494c2ad386317d)
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