xref: /OK3568_Linux_fs/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/common.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun // SPDX-License-Identifier: ISC
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * Copyright (c) 2014 Broadcom Corporation
4*4882a593Smuzhiyun  */
5*4882a593Smuzhiyun #ifndef BRCMFMAC_COMMON_H
6*4882a593Smuzhiyun #define BRCMFMAC_COMMON_H
7*4882a593Smuzhiyun 
8*4882a593Smuzhiyun #include <linux/platform_device.h>
9*4882a593Smuzhiyun #include <linux/platform_data/brcmfmac.h>
10*4882a593Smuzhiyun #include "fwil_types.h"
11*4882a593Smuzhiyun 
12*4882a593Smuzhiyun #define BRCMF_FW_ALTPATH_LEN			256
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun /* Definitions for the module global and device specific settings are defined
15*4882a593Smuzhiyun  * here. Two structs are used for them. brcmf_mp_global_t and brcmf_mp_device.
16*4882a593Smuzhiyun  * The mp_global is instantiated once in a global struct and gets initialized
17*4882a593Smuzhiyun  * by the common_attach function which should be called before any other
18*4882a593Smuzhiyun  * (module) initiliazation takes place. The device specific settings is part
19*4882a593Smuzhiyun  * of the drvr struct and should be initialized on every brcmf_attach.
20*4882a593Smuzhiyun  */
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun /**
23*4882a593Smuzhiyun  * struct brcmf_mp_global_t - Global module paramaters.
24*4882a593Smuzhiyun  *
25*4882a593Smuzhiyun  * @firmware_path: Alternative firmware path.
26*4882a593Smuzhiyun  */
27*4882a593Smuzhiyun struct brcmf_mp_global_t {
28*4882a593Smuzhiyun 	char	firmware_path[BRCMF_FW_ALTPATH_LEN];
29*4882a593Smuzhiyun };
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun extern struct brcmf_mp_global_t brcmf_mp_global;
32*4882a593Smuzhiyun 
33*4882a593Smuzhiyun /**
34*4882a593Smuzhiyun  * struct brcmf_mp_device - Device module paramaters.
35*4882a593Smuzhiyun  *
36*4882a593Smuzhiyun  * @p2p_enable: Legacy P2P0 enable (old wpa_supplicant).
37*4882a593Smuzhiyun  * @feature_disable: Feature_disable bitmask.
38*4882a593Smuzhiyun  * @fcmode: FWS flow control.
39*4882a593Smuzhiyun  * @roamoff: Firmware roaming off?
40*4882a593Smuzhiyun  * @ignore_probe_fail: Ignore probe failure.
41*4882a593Smuzhiyun  * @country_codes: If available, pointer to struct for translating country codes
42*4882a593Smuzhiyun  * @bus: Bus specific platform data. Only SDIO at the mmoment.
43*4882a593Smuzhiyun  */
44*4882a593Smuzhiyun struct brcmf_mp_device {
45*4882a593Smuzhiyun 	bool		p2p_enable;
46*4882a593Smuzhiyun 	unsigned int	feature_disable;
47*4882a593Smuzhiyun 	int		fcmode;
48*4882a593Smuzhiyun 	bool		roamoff;
49*4882a593Smuzhiyun 	bool		iapp;
50*4882a593Smuzhiyun 	bool		ignore_probe_fail;
51*4882a593Smuzhiyun 	struct brcmfmac_pd_cc *country_codes;
52*4882a593Smuzhiyun 	const char	*board_type;
53*4882a593Smuzhiyun 	union {
54*4882a593Smuzhiyun 		struct brcmfmac_sdio_pd sdio;
55*4882a593Smuzhiyun 	} bus;
56*4882a593Smuzhiyun };
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun void brcmf_c_set_joinpref_default(struct brcmf_if *ifp);
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun struct brcmf_mp_device *brcmf_get_module_param(struct device *dev,
61*4882a593Smuzhiyun 					       enum brcmf_bus_type bus_type,
62*4882a593Smuzhiyun 					       u32 chip, u32 chiprev);
63*4882a593Smuzhiyun void brcmf_release_module_param(struct brcmf_mp_device *module_param);
64*4882a593Smuzhiyun 
65*4882a593Smuzhiyun /* Sets dongle media info (drv_version, mac address). */
66*4882a593Smuzhiyun int brcmf_c_preinit_dcmds(struct brcmf_if *ifp);
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun #ifdef CONFIG_DMI
69*4882a593Smuzhiyun void brcmf_dmi_probe(struct brcmf_mp_device *settings, u32 chip, u32 chiprev);
70*4882a593Smuzhiyun #else
71*4882a593Smuzhiyun static inline void
brcmf_dmi_probe(struct brcmf_mp_device * settings,u32 chip,u32 chiprev)72*4882a593Smuzhiyun brcmf_dmi_probe(struct brcmf_mp_device *settings, u32 chip, u32 chiprev) {}
73*4882a593Smuzhiyun #endif
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun u8 brcmf_map_prio_to_prec(void *cfg, u8 prio);
76*4882a593Smuzhiyun 
77*4882a593Smuzhiyun u8 brcmf_map_prio_to_aci(void *cfg, u8 prio);
78*4882a593Smuzhiyun 
79*4882a593Smuzhiyun #endif /* BRCMFMAC_COMMON_H */
80