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