1daeccac2SArend van Spriel // SPDX-License-Identifier: ISC 205491d2cSKalle Valo /* 305491d2cSKalle Valo * Copyright (c) 2014 Broadcom Corporation 405491d2cSKalle Valo */ 505491d2cSKalle Valo #ifndef _BRCMF_FEATURE_H 605491d2cSKalle Valo #define _BRCMF_FEATURE_H 705491d2cSKalle Valo 805491d2cSKalle Valo /* 905491d2cSKalle Valo * Features: 1005491d2cSKalle Valo * 1105491d2cSKalle Valo * MBSS: multiple BSSID support (eg. guest network in AP mode). 1205491d2cSKalle Valo * MCHAN: multi-channel for concurrent P2P. 1305491d2cSKalle Valo * PNO: preferred network offload. 1405491d2cSKalle Valo * WOWL: Wake-On-WLAN. 1505491d2cSKalle Valo * P2P: peer-to-peer 168abffd81SHante Meuleman * RSDB: Real Simultaneous Dual Band 17a7b82d47SHante Meuleman * TDLS: Tunneled Direct Link Setup 1848ed16e8SHante Meuleman * SCAN_RANDOM_MAC: Random MAC during (net detect) scheduled scan. 195c22fb85SHante Meuleman * WOWL_ND: WOWL net detect (PNO) 205c22fb85SHante Meuleman * WOWL_GTK: (WOWL) GTK rekeying offload 2173ef9e64SHante Meuleman * WOWL_ARP_ND: ARP and Neighbor Discovery offload support during WOWL. 22240d61a9SHante Meuleman * MFP: 802.11w Management Frame Protection. 239fe929aaSArend van Spriel * GSCAN: enhanced scan offload feature. 24b8a64f0eSArend van Spriel * FWSUP: Firmware supplicant. 2501f69dfaSRafał Miłecki * MONITOR: firmware can pass monitor packets to host. 26e63410acSRafał Miłecki * MONITOR_FMT_RADIOTAP: firmware provides monitor packets with radiotap header 27e665988bSRafał Miłecki * MONITOR_FMT_HW_RX_HDR: firmware provides monitor packets with hw/ucode header 2805491d2cSKalle Valo */ 2905491d2cSKalle Valo #define BRCMF_FEAT_LIST \ 3005491d2cSKalle Valo BRCMF_FEAT_DEF(MBSS) \ 3105491d2cSKalle Valo BRCMF_FEAT_DEF(MCHAN) \ 3205491d2cSKalle Valo BRCMF_FEAT_DEF(PNO) \ 3305491d2cSKalle Valo BRCMF_FEAT_DEF(WOWL) \ 348abffd81SHante Meuleman BRCMF_FEAT_DEF(P2P) \ 35a7b82d47SHante Meuleman BRCMF_FEAT_DEF(RSDB) \ 3648ed16e8SHante Meuleman BRCMF_FEAT_DEF(TDLS) \ 375c22fb85SHante Meuleman BRCMF_FEAT_DEF(SCAN_RANDOM_MAC) \ 385c22fb85SHante Meuleman BRCMF_FEAT_DEF(WOWL_ND) \ 3973ef9e64SHante Meuleman BRCMF_FEAT_DEF(WOWL_GTK) \ 40240d61a9SHante Meuleman BRCMF_FEAT_DEF(WOWL_ARP_ND) \ 419fe929aaSArend van Spriel BRCMF_FEAT_DEF(MFP) \ 42b8a64f0eSArend van Spriel BRCMF_FEAT_DEF(GSCAN) \ 4301f69dfaSRafał Miłecki BRCMF_FEAT_DEF(FWSUP) \ 44e63410acSRafał Miłecki BRCMF_FEAT_DEF(MONITOR) \ 45e665988bSRafał Miłecki BRCMF_FEAT_DEF(MONITOR_FMT_RADIOTAP) \ 46e665988bSRafał Miłecki BRCMF_FEAT_DEF(MONITOR_FMT_HW_RX_HDR) 478abffd81SHante Meuleman 4805491d2cSKalle Valo /* 4905491d2cSKalle Valo * Quirks: 5005491d2cSKalle Valo * 5105491d2cSKalle Valo * AUTO_AUTH: workaround needed for automatic authentication type. 5205491d2cSKalle Valo * NEED_MPC: driver needs to disable MPC during scanning operation. 5305491d2cSKalle Valo */ 5405491d2cSKalle Valo #define BRCMF_QUIRK_LIST \ 5505491d2cSKalle Valo BRCMF_QUIRK_DEF(AUTO_AUTH) \ 5605491d2cSKalle Valo BRCMF_QUIRK_DEF(NEED_MPC) 5705491d2cSKalle Valo 5805491d2cSKalle Valo #define BRCMF_FEAT_DEF(_f) \ 5905491d2cSKalle Valo BRCMF_FEAT_ ## _f, 6005491d2cSKalle Valo /* 6105491d2cSKalle Valo * expand feature list to enumeration. 6205491d2cSKalle Valo */ 6305491d2cSKalle Valo enum brcmf_feat_id { 6405491d2cSKalle Valo BRCMF_FEAT_LIST 6505491d2cSKalle Valo BRCMF_FEAT_LAST 6605491d2cSKalle Valo }; 6705491d2cSKalle Valo #undef BRCMF_FEAT_DEF 6805491d2cSKalle Valo 6905491d2cSKalle Valo #define BRCMF_QUIRK_DEF(_q) \ 7005491d2cSKalle Valo BRCMF_FEAT_QUIRK_ ## _q, 7105491d2cSKalle Valo /* 7205491d2cSKalle Valo * expand quirk list to enumeration. 7305491d2cSKalle Valo */ 7405491d2cSKalle Valo enum brcmf_feat_quirk { 7505491d2cSKalle Valo BRCMF_QUIRK_LIST 7605491d2cSKalle Valo BRCMF_FEAT_QUIRK_LAST 7705491d2cSKalle Valo }; 7805491d2cSKalle Valo #undef BRCMF_QUIRK_DEF 7905491d2cSKalle Valo 8005491d2cSKalle Valo /** 8105491d2cSKalle Valo * brcmf_feat_attach() - determine features and quirks. 8205491d2cSKalle Valo * 8305491d2cSKalle Valo * @drvr: driver instance. 8405491d2cSKalle Valo */ 8505491d2cSKalle Valo void brcmf_feat_attach(struct brcmf_pub *drvr); 8605491d2cSKalle Valo 8705491d2cSKalle Valo /** 8834789d0cSArend Van Spriel * brcmf_feat_debugfs_create() - create debugfs entries. 8934789d0cSArend Van Spriel * 9034789d0cSArend Van Spriel * @drvr: driver instance. 9134789d0cSArend Van Spriel */ 9234789d0cSArend Van Spriel void brcmf_feat_debugfs_create(struct brcmf_pub *drvr); 9334789d0cSArend Van Spriel 9434789d0cSArend Van Spriel /** 9505491d2cSKalle Valo * brcmf_feat_is_enabled() - query feature. 9605491d2cSKalle Valo * 9705491d2cSKalle Valo * @ifp: interface instance. 9805491d2cSKalle Valo * @id: feature id to check. 9905491d2cSKalle Valo * 10005491d2cSKalle Valo * Return: true is feature is enabled; otherwise false. 10105491d2cSKalle Valo */ 10205491d2cSKalle Valo bool brcmf_feat_is_enabled(struct brcmf_if *ifp, enum brcmf_feat_id id); 10305491d2cSKalle Valo 10405491d2cSKalle Valo /** 10505491d2cSKalle Valo * brcmf_feat_is_quirk_enabled() - query chip quirk. 10605491d2cSKalle Valo * 10705491d2cSKalle Valo * @ifp: interface instance. 10805491d2cSKalle Valo * @quirk: quirk id to check. 10905491d2cSKalle Valo * 11005491d2cSKalle Valo * Return: true is quirk is enabled; otherwise false. 11105491d2cSKalle Valo */ 11205491d2cSKalle Valo bool brcmf_feat_is_quirk_enabled(struct brcmf_if *ifp, 11305491d2cSKalle Valo enum brcmf_feat_quirk quirk); 11405491d2cSKalle Valo 11505491d2cSKalle Valo #endif /* _BRCMF_FEATURE_H */ 116