qcacld-3.0: ADD MLME INI items of WMM AC_BE
Add the following WMM BE VO ini configs to MLME cfg: 1. CFG_QOS_WMM_INFRA_DIR_AC_BE_NAME 2. CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_NAME 3. CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_NAME 4. CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_NAME 5. CFG_QOS_WMM_INFRA_SBA_AC_BE_NAME 6. CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_NAME 7. CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_NAME Introduce the basic infra APIs related to these configs from mlme. Change-Id: Ibaf06ba2df07a4805d31a4748809c44d143dd12e CRs-Fixed: 2327689
This commit is contained in:
@@ -1279,6 +1279,20 @@ static void mlme_init_wmm_in_cfg(struct wlan_objmgr_psoc *psoc,
|
|||||||
wmm_params->ac_vi.uapsd_vi_sus_intv =
|
wmm_params->ac_vi.uapsd_vi_sus_intv =
|
||||||
cfg_get(psoc, CFG_QOS_WMM_UAPSD_VI_SUS_INTV);
|
cfg_get(psoc, CFG_QOS_WMM_UAPSD_VI_SUS_INTV);
|
||||||
|
|
||||||
|
wmm_params->ac_be.dir_ac_be =
|
||||||
|
cfg_get(psoc, CFG_QOS_WMM_DIR_AC_BE);
|
||||||
|
wmm_params->ac_be.nom_msdu_size_ac_be =
|
||||||
|
cfg_get(psoc, CFG_QOS_WMM_NOM_MSDU_SIZE_AC_BE);
|
||||||
|
wmm_params->ac_be.mean_data_rate_ac_be =
|
||||||
|
cfg_get(psoc, CFG_QOS_WMM_MEAN_DATA_RATE_AC_BE);
|
||||||
|
wmm_params->ac_be.min_phy_rate_ac_be =
|
||||||
|
cfg_get(psoc, CFG_QOS_WMM_MIN_PHY_RATE_AC_BE);
|
||||||
|
wmm_params->ac_be.sba_ac_be =
|
||||||
|
cfg_get(psoc, CFG_QOS_WMM_SBA_AC_BE);
|
||||||
|
wmm_params->ac_be.uapsd_be_srv_intv =
|
||||||
|
cfg_get(psoc, CFG_QOS_WMM_UAPSD_BE_SRV_INTV);
|
||||||
|
wmm_params->ac_be.uapsd_be_sus_intv =
|
||||||
|
cfg_get(psoc, CFG_QOS_WMM_UAPSD_BE_SUS_INTV);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mlme_init_wps_params_cfg(struct wlan_objmgr_psoc *psoc,
|
static void mlme_init_wps_params_cfg(struct wlan_objmgr_psoc *psoc,
|
||||||
|
@@ -406,6 +406,181 @@
|
|||||||
CFG_VALUE_OR_DEFAULT, \
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
"Infra uapsd vi sus intv")
|
"Infra uapsd vi sus intv")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* <ini>
|
||||||
|
* InfraDirAcBe - Set TSPEC direction for BE
|
||||||
|
* @Min: 0
|
||||||
|
* @Max: 3
|
||||||
|
* @Default: 3
|
||||||
|
*
|
||||||
|
* This ini is used to set TSPEC direction for BE
|
||||||
|
*
|
||||||
|
* Related: None.
|
||||||
|
*
|
||||||
|
* Supported Feature: WMM
|
||||||
|
*
|
||||||
|
* Usage: Internal/External
|
||||||
|
*
|
||||||
|
* </ini>
|
||||||
|
*/
|
||||||
|
#define CFG_QOS_WMM_DIR_AC_BE CFG_INI_UINT( \
|
||||||
|
"InfraDirAcBe", \
|
||||||
|
0, \
|
||||||
|
3, \
|
||||||
|
3, \
|
||||||
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
|
"TSPEC direction for BE")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* <ini>
|
||||||
|
* InfraNomMsduSizeAcBe - Set normal MSDU size for BE
|
||||||
|
* @Min: 0x0
|
||||||
|
* @Max: 0xFFFF
|
||||||
|
* @Default: 0x85DC
|
||||||
|
*
|
||||||
|
* This ini is used to set normal MSDU size for BE
|
||||||
|
*
|
||||||
|
* Related: None.
|
||||||
|
*
|
||||||
|
* Supported Feature: WMM
|
||||||
|
*
|
||||||
|
* Usage: Internal/External
|
||||||
|
*
|
||||||
|
* </ini>
|
||||||
|
*/
|
||||||
|
#define CFG_QOS_WMM_NOM_MSDU_SIZE_AC_BE CFG_INI_UINT( \
|
||||||
|
"InfraNomMsduSizeAcBe", \
|
||||||
|
0x0, \
|
||||||
|
0xFFFF, \
|
||||||
|
0x85DC, \
|
||||||
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
|
"MSDU size for BE")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* <ini>
|
||||||
|
* InfraMeanDataRateAcBe - Set mean data rate for BE
|
||||||
|
* @Min: 0x0
|
||||||
|
* @Max: 0xFFFFFFFF
|
||||||
|
* @Default: 0x493E0
|
||||||
|
*
|
||||||
|
* This ini is used to set mean data rate for BE
|
||||||
|
*
|
||||||
|
* Related: None.
|
||||||
|
*
|
||||||
|
* Supported Feature: WMM
|
||||||
|
*
|
||||||
|
* Usage: Internal/External
|
||||||
|
*
|
||||||
|
* </ini>
|
||||||
|
*/
|
||||||
|
#define CFG_QOS_WMM_MEAN_DATA_RATE_AC_BE CFG_INI_UINT( \
|
||||||
|
"InfraMeanDataRateAcBe", \
|
||||||
|
0x0, \
|
||||||
|
0xFFFFFFFF, \
|
||||||
|
0x493E0, \
|
||||||
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
|
"data rate for BE")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* <ini>
|
||||||
|
* InfraMinPhyRateAcBe - Set min PHY rate for BE
|
||||||
|
* @Min: 0x0
|
||||||
|
* @Max: 0xFFFFFFFF
|
||||||
|
* @Default: 0x5B8D80
|
||||||
|
*
|
||||||
|
* This ini is used to set min PHY rate for BE
|
||||||
|
*
|
||||||
|
* Related: None.
|
||||||
|
*
|
||||||
|
* Supported Feature: WMM
|
||||||
|
*
|
||||||
|
* Usage: Internal/External
|
||||||
|
*
|
||||||
|
* </ini>
|
||||||
|
*/
|
||||||
|
#define CFG_QOS_WMM_MIN_PHY_RATE_AC_BE CFG_INI_UINT( \
|
||||||
|
"InfraMinPhyRateAcBe", \
|
||||||
|
0x0, \
|
||||||
|
0xFFFFFFFF, \
|
||||||
|
0x5B8D80, \
|
||||||
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
|
"min PHY rate for BE")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* <ini>
|
||||||
|
* InfraSbaAcBe - Set surplus bandwidth allowance for BE
|
||||||
|
* @Min: 0x2001
|
||||||
|
* @Max: 0xFFFF
|
||||||
|
* @Default: 0x2001
|
||||||
|
*
|
||||||
|
* This ini is used to set surplus bandwidth allowance for BE
|
||||||
|
*
|
||||||
|
* Related: None.
|
||||||
|
*
|
||||||
|
* Supported Feature: WMM
|
||||||
|
*
|
||||||
|
* Usage: Internal/External
|
||||||
|
*
|
||||||
|
* </ini>
|
||||||
|
*/
|
||||||
|
#define CFG_QOS_WMM_SBA_AC_BE CFG_INI_UINT( \
|
||||||
|
"InfraSbaAcBe", \
|
||||||
|
0x2001, \
|
||||||
|
0xFFFF, \
|
||||||
|
0x2001, \
|
||||||
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
|
"surplus bandwidth allowance for BE")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* <ini>
|
||||||
|
* InfraUapsdBeSrvIntv - Set Uapsd service interval for BE
|
||||||
|
* @Min: 0
|
||||||
|
* @Max: 4294967295UL
|
||||||
|
* @Default: 300
|
||||||
|
*
|
||||||
|
* This ini is used to set Uapsd service interval for BE
|
||||||
|
*
|
||||||
|
* Related: None.
|
||||||
|
*
|
||||||
|
* Supported Feature: WMM
|
||||||
|
*
|
||||||
|
* Usage: Internal/External
|
||||||
|
*
|
||||||
|
* </ini>
|
||||||
|
*/
|
||||||
|
#define CFG_QOS_WMM_UAPSD_BE_SRV_INTV CFG_INI_UINT( \
|
||||||
|
"InfraUapsdBeSrvIntv", \
|
||||||
|
0, \
|
||||||
|
4294967295UL, \
|
||||||
|
300, \
|
||||||
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
|
"Infra uapsd be srv intv")
|
||||||
|
|
||||||
|
/*
|
||||||
|
* <ini>
|
||||||
|
* InfraUapsdBeSuspIntv - Set Uapsd suspension interval for BE
|
||||||
|
* @Min: 0
|
||||||
|
* @Max: 4294967295UL
|
||||||
|
* @Default: 2000
|
||||||
|
*
|
||||||
|
* This ini is used to set Uapsd suspension interval for BE
|
||||||
|
*
|
||||||
|
* Related: None.
|
||||||
|
*
|
||||||
|
* Supported Feature: WMM
|
||||||
|
*
|
||||||
|
* Usage: Internal/External
|
||||||
|
*
|
||||||
|
* </ini>
|
||||||
|
*/
|
||||||
|
#define CFG_QOS_WMM_UAPSD_BE_SUS_INTV CFG_INI_UINT( \
|
||||||
|
"InfraUapsdBeSuspIntv", \
|
||||||
|
0, \
|
||||||
|
4294967295UL, \
|
||||||
|
2000, \
|
||||||
|
CFG_VALUE_OR_DEFAULT, \
|
||||||
|
"Infra uapsd vi sus intv")
|
||||||
|
|
||||||
#define CFG_WMM_PARAMS_ALL \
|
#define CFG_WMM_PARAMS_ALL \
|
||||||
CFG(CFG_QOS_ENABLED) \
|
CFG(CFG_QOS_ENABLED) \
|
||||||
CFG(CFG_WME_ENABLED) \
|
CFG(CFG_WME_ENABLED) \
|
||||||
@@ -425,6 +600,13 @@
|
|||||||
CFG(CFG_QOS_WMM_MIN_PHY_RATE_AC_VI) \
|
CFG(CFG_QOS_WMM_MIN_PHY_RATE_AC_VI) \
|
||||||
CFG(CFG_QOS_WMM_SBA_AC_VI) \
|
CFG(CFG_QOS_WMM_SBA_AC_VI) \
|
||||||
CFG(CFG_QOS_WMM_UAPSD_VI_SRV_INTV) \
|
CFG(CFG_QOS_WMM_UAPSD_VI_SRV_INTV) \
|
||||||
CFG(CFG_QOS_WMM_UAPSD_VI_SUS_INTV)
|
CFG(CFG_QOS_WMM_UAPSD_VI_SUS_INTV) \
|
||||||
|
CFG(CFG_QOS_WMM_DIR_AC_BE) \
|
||||||
|
CFG(CFG_QOS_WMM_NOM_MSDU_SIZE_AC_BE) \
|
||||||
|
CFG(CFG_QOS_WMM_MEAN_DATA_RATE_AC_BE) \
|
||||||
|
CFG(CFG_QOS_WMM_MIN_PHY_RATE_AC_BE) \
|
||||||
|
CFG(CFG_QOS_WMM_SBA_AC_BE) \
|
||||||
|
CFG(CFG_QOS_WMM_UAPSD_BE_SRV_INTV) \
|
||||||
|
CFG(CFG_QOS_WMM_UAPSD_BE_SUS_INTV)
|
||||||
|
|
||||||
#endif /* __CFG_MLME_FE_WMM_H */
|
#endif /* __CFG_MLME_FE_WMM_H */
|
||||||
|
@@ -721,6 +721,86 @@ QDF_STATUS
|
|||||||
wlan_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc *psoc,
|
wlan_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc *psoc,
|
||||||
uint32_t *value);
|
uint32_t *value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wlan_mlme_get_wmm_dir_ac_be() - Get TSPEC direction
|
||||||
|
* for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
QDF_STATUS
|
||||||
|
wlan_mlme_get_wmm_dir_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint8_t *value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wlan_mlme_get_wmm_nom_msdu_size_ac_be() - Get normal
|
||||||
|
* MSDU size for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
QDF_STATUS
|
||||||
|
wlan_mlme_get_wmm_nom_msdu_size_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint16_t *value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wlan_mlme_get_wmm_mean_data_rate_ac_be() - mean data
|
||||||
|
* rate for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
QDF_STATUS
|
||||||
|
wlan_mlme_get_wmm_mean_data_rate_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wlan_mlme_get_wmm_min_phy_rate_ac_be() - min PHY
|
||||||
|
* rate for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
QDF_STATUS wlan_mlme_get_wmm_min_phy_rate_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wlan_mlme_get_wmm_sba_ac_be() - surplus bandwidth
|
||||||
|
* allowance for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
QDF_STATUS wlan_mlme_get_wmm_sba_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint16_t *value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wlan_mlme_get_wmm_uapsd_be_srv_intv() - Get Uapsd service
|
||||||
|
* interval for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: pointer to the value which will be filled for the caller
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
QDF_STATUS wlan_mlme_get_wmm_uapsd_be_srv_intv(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wlan_mlme_get_wmm_uapsd_be_sus_intv() - Get Uapsd suspension
|
||||||
|
* interval for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: pointer to the value which will be filled for the caller
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
QDF_STATUS wlan_mlme_get_wmm_uapsd_be_sus_intv(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* wlan_mlme_get_wmm_dir_ac_vo() - Get TSPEC direction
|
* wlan_mlme_get_wmm_dir_ac_vo() - Get TSPEC direction
|
||||||
* for VO
|
* for VO
|
||||||
@@ -729,9 +809,8 @@ wlan_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc *psoc,
|
|||||||
*
|
*
|
||||||
* Return: QDF Status
|
* Return: QDF Status
|
||||||
*/
|
*/
|
||||||
QDF_STATUS
|
QDF_STATUS wlan_mlme_get_wmm_dir_ac_vo(struct wlan_objmgr_psoc *psoc,
|
||||||
wlan_mlme_get_wmm_dir_ac_vo(struct wlan_objmgr_psoc *psoc,
|
uint8_t *value);
|
||||||
uint8_t *value);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* wlan_mlme_get_wmm_nom_msdu_size_ac_vo() - Get normal
|
* wlan_mlme_get_wmm_nom_msdu_size_ac_vo() - Get normal
|
||||||
|
@@ -1039,6 +1039,29 @@ struct wlan_mlme_wmm_ac_vi {
|
|||||||
uint32_t uapsd_vi_sus_intv;
|
uint32_t uapsd_vi_sus_intv;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct wlan_mlme_wmm_ac_be - Default TSPEC parameters
|
||||||
|
* for AC_BE
|
||||||
|
* @dir_ac_be: TSPEC direction for BE
|
||||||
|
* @nom_msdu_size_ac_be: normal MSDU size for BE
|
||||||
|
* @mean_data_rate_ac_be: mean data rate for BE
|
||||||
|
* @min_phy_rate_ac_be: min PHY rate for BE
|
||||||
|
* @sba_ac_be: surplus bandwidth allowance for BE
|
||||||
|
* @uapsd_be_srv_intv: Uapsd service interval for BE
|
||||||
|
* @uapsd_be_sus_intv: Uapsd suspension interval for BE
|
||||||
|
|
||||||
|
*/
|
||||||
|
struct wlan_mlme_wmm_ac_be {
|
||||||
|
uint8_t dir_ac_be;
|
||||||
|
uint16_t nom_msdu_size_ac_be;
|
||||||
|
uint32_t mean_data_rate_ac_be;
|
||||||
|
uint32_t min_phy_rate_ac_be;
|
||||||
|
uint16_t sba_ac_be;
|
||||||
|
uint32_t uapsd_be_srv_intv;
|
||||||
|
uint32_t uapsd_be_sus_intv;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct wlan_mlme_wmm_params - WMM CFG Items
|
* struct wlan_mlme_wmm_params - WMM CFG Items
|
||||||
* @qos_enabled: AP is enabled with 11E
|
* @qos_enabled: AP is enabled with 11E
|
||||||
@@ -1047,6 +1070,7 @@ struct wlan_mlme_wmm_ac_vi {
|
|||||||
* @wsm_enabled: AP is enabled with WSM
|
* @wsm_enabled: AP is enabled with WSM
|
||||||
* @ac_vo: Default TSPEC parameters for AC_VO
|
* @ac_vo: Default TSPEC parameters for AC_VO
|
||||||
* @ac_vi: Default TSPEC parameters for AC_VI
|
* @ac_vi: Default TSPEC parameters for AC_VI
|
||||||
|
* @ac_be: Default TSPEC parameters for AC_BE
|
||||||
*/
|
*/
|
||||||
struct wlan_mlme_wmm_params {
|
struct wlan_mlme_wmm_params {
|
||||||
bool qos_enabled;
|
bool qos_enabled;
|
||||||
@@ -1056,6 +1080,7 @@ struct wlan_mlme_wmm_params {
|
|||||||
uint32_t edca_profile;
|
uint32_t edca_profile;
|
||||||
struct wlan_mlme_wmm_ac_vo ac_vo;
|
struct wlan_mlme_wmm_ac_vo ac_vo;
|
||||||
struct wlan_mlme_wmm_ac_vi ac_vi;
|
struct wlan_mlme_wmm_ac_vi ac_vi;
|
||||||
|
struct wlan_mlme_wmm_ac_be ac_be;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -1815,4 +1815,121 @@ ucfg_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc *psoc,
|
|||||||
return wlan_mlme_get_wmm_uapsd_vi_sus_intv(psoc, value);
|
return wlan_mlme_get_wmm_uapsd_vi_sus_intv(psoc, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ucfg_mlme_get_wmm_dir_ac_be() - Get TSPEC direction
|
||||||
|
* for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Inline UCFG API to be used by HDD/OSIF callers
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
static inline QDF_STATUS
|
||||||
|
ucfg_mlme_get_wmm_dir_ac_be(struct wlan_objmgr_psoc *psoc, uint8_t *value)
|
||||||
|
{
|
||||||
|
return wlan_mlme_get_wmm_dir_ac_be(psoc, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ucfg_mlme_get_wmm_nom_msdu_size_ac_be() - Get normal
|
||||||
|
* MSDU size for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Inline UCFG API to be used by HDD/OSIF callers
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
static inline QDF_STATUS
|
||||||
|
ucfg_mlme_get_wmm_nom_msdu_size_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint16_t *value)
|
||||||
|
{
|
||||||
|
return wlan_mlme_get_wmm_nom_msdu_size_ac_be(psoc, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ucfg_mlme_get_wmm_mean_data_rate_ac_be() - mean data
|
||||||
|
* rate for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Inline UCFG API to be used by HDD/OSIF callers
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
static inline QDF_STATUS
|
||||||
|
ucfg_mlme_get_wmm_mean_data_rate_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
return wlan_mlme_get_wmm_mean_data_rate_ac_be(psoc, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ucfg_mlme_get_wmm_min_phy_rate_ac_be() - min PHY
|
||||||
|
* rate for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Inline UCFG API to be used by HDD/OSIF callers
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
static inline QDF_STATUS
|
||||||
|
ucfg_mlme_get_wmm_min_phy_rate_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
return wlan_mlme_get_wmm_min_phy_rate_ac_be(psoc, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ucfg_mlme_get_wmm_sba_ac_be() - surplus bandwidth
|
||||||
|
* allowance for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Inline UCFG API to be used by HDD/OSIF callers
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
static inline QDF_STATUS
|
||||||
|
ucfg_mlme_get_wmm_sba_ac_be(struct wlan_objmgr_psoc *psoc, uint16_t *value)
|
||||||
|
{
|
||||||
|
return wlan_mlme_get_wmm_sba_ac_be(psoc, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ucfg_mlme_get_wmm_uapsd_be_srv_intv() - Get Uapsd service
|
||||||
|
* interval for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: pointer to the value which will be filled for the caller
|
||||||
|
*
|
||||||
|
* Inline UCFG API to be used by HDD/OSIF callers
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
static inline QDF_STATUS
|
||||||
|
ucfg_mlme_get_wmm_uapsd_be_srv_intv(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
return wlan_mlme_get_wmm_uapsd_be_srv_intv(psoc, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ucfg_mlme_get_wmm_uapsd_be_sus_intv() - Get Uapsd suspension
|
||||||
|
* interval for BE
|
||||||
|
* @psoc: pointer to psoc object
|
||||||
|
* @value: Value that needs to be set from the caller
|
||||||
|
*
|
||||||
|
* Inline UCFG API to be used by HDD/OSIF callers
|
||||||
|
*
|
||||||
|
* Return: QDF Status
|
||||||
|
*/
|
||||||
|
static inline QDF_STATUS
|
||||||
|
ucfg_mlme_get_wmm_uapsd_be_sus_intv(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
return wlan_mlme_get_wmm_uapsd_be_sus_intv(psoc, value);
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* _WLAN_MLME_UCFG_API_H_ */
|
#endif /* _WLAN_MLME_UCFG_API_H_ */
|
||||||
|
@@ -794,6 +794,120 @@ QDF_STATUS wlan_mlme_get_wmm_uapsd_vi_sus_intv(struct wlan_objmgr_psoc *psoc,
|
|||||||
return QDF_STATUS_SUCCESS;
|
return QDF_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QDF_STATUS
|
||||||
|
wlan_mlme_get_wmm_dir_ac_be(struct wlan_objmgr_psoc *psoc, uint8_t *value)
|
||||||
|
{
|
||||||
|
struct wlan_mlme_psoc_obj *mlme_obj;
|
||||||
|
|
||||||
|
mlme_obj = mlme_get_psoc_obj(psoc);
|
||||||
|
if (!mlme_obj) {
|
||||||
|
mlme_err("Failed to get MLME Obj");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*value = mlme_obj->cfg.wmm_params.ac_be.dir_ac_be;
|
||||||
|
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
QDF_STATUS wlan_mlme_get_wmm_nom_msdu_size_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint16_t *value)
|
||||||
|
{
|
||||||
|
struct wlan_mlme_psoc_obj *mlme_obj;
|
||||||
|
|
||||||
|
mlme_obj = mlme_get_psoc_obj(psoc);
|
||||||
|
if (!mlme_obj) {
|
||||||
|
mlme_err("Failed to get MLME Obj");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*value = mlme_obj->cfg.wmm_params.ac_be.nom_msdu_size_ac_be;
|
||||||
|
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
QDF_STATUS
|
||||||
|
wlan_mlme_get_wmm_mean_data_rate_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
struct wlan_mlme_psoc_obj *mlme_obj;
|
||||||
|
|
||||||
|
mlme_obj = mlme_get_psoc_obj(psoc);
|
||||||
|
if (!mlme_obj) {
|
||||||
|
mlme_err("Failed to get MLME Obj");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*value = mlme_obj->cfg.wmm_params.ac_be.mean_data_rate_ac_be;
|
||||||
|
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
QDF_STATUS
|
||||||
|
wlan_mlme_get_wmm_min_phy_rate_ac_be(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
struct wlan_mlme_psoc_obj *mlme_obj;
|
||||||
|
|
||||||
|
mlme_obj = mlme_get_psoc_obj(psoc);
|
||||||
|
if (!mlme_obj) {
|
||||||
|
mlme_err("Failed to get MLME Obj");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*value = mlme_obj->cfg.wmm_params.ac_be.min_phy_rate_ac_be;
|
||||||
|
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
QDF_STATUS
|
||||||
|
wlan_mlme_get_wmm_sba_ac_be(struct wlan_objmgr_psoc *psoc, uint16_t *value)
|
||||||
|
{
|
||||||
|
struct wlan_mlme_psoc_obj *mlme_obj;
|
||||||
|
|
||||||
|
mlme_obj = mlme_get_psoc_obj(psoc);
|
||||||
|
if (!mlme_obj) {
|
||||||
|
mlme_err("Failed to get MLME Obj");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*value = mlme_obj->cfg.wmm_params.ac_be.sba_ac_be;
|
||||||
|
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
QDF_STATUS wlan_mlme_get_wmm_uapsd_be_srv_intv(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
struct wlan_mlme_psoc_obj *mlme_obj;
|
||||||
|
|
||||||
|
mlme_obj = mlme_get_psoc_obj(psoc);
|
||||||
|
if (!mlme_obj) {
|
||||||
|
mlme_err("Failed to get MLME Obj");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*value = mlme_obj->cfg.wmm_params.ac_be.uapsd_be_srv_intv;
|
||||||
|
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
QDF_STATUS wlan_mlme_get_wmm_uapsd_be_sus_intv(struct wlan_objmgr_psoc *psoc,
|
||||||
|
uint32_t *value)
|
||||||
|
{
|
||||||
|
struct wlan_mlme_psoc_obj *mlme_obj;
|
||||||
|
|
||||||
|
mlme_obj = mlme_get_psoc_obj(psoc);
|
||||||
|
if (!mlme_obj) {
|
||||||
|
mlme_err("Failed to get MLME Obj");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*value = mlme_obj->cfg.wmm_params.ac_be.uapsd_be_sus_intv;
|
||||||
|
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
QDF_STATUS wlan_mlme_set_sap_listen_interval(struct wlan_objmgr_psoc *psoc,
|
QDF_STATUS wlan_mlme_set_sap_listen_interval(struct wlan_objmgr_psoc *psoc,
|
||||||
int value)
|
int value)
|
||||||
{
|
{
|
||||||
|
@@ -2741,50 +2741,6 @@ enum station_keepalive_method {
|
|||||||
#define CFG_QOS_IMPLICIT_SETUP_ENABLED_MAX (1)
|
#define CFG_QOS_IMPLICIT_SETUP_ENABLED_MAX (1)
|
||||||
#define CFG_QOS_IMPLICIT_SETUP_ENABLED_DEFAULT (0)
|
#define CFG_QOS_IMPLICIT_SETUP_ENABLED_DEFAULT (0)
|
||||||
|
|
||||||
/*
|
|
||||||
* <ini>
|
|
||||||
* InfraUapsdBeSrvIntv - Set Uapsd service interval for BE
|
|
||||||
* @Min: 0
|
|
||||||
* @Max: 4294967295UL
|
|
||||||
* @Default: 300
|
|
||||||
*
|
|
||||||
* This ini is used to set Uapsd service interval for BE
|
|
||||||
*
|
|
||||||
* Related: None.
|
|
||||||
*
|
|
||||||
* Supported Feature: WMM
|
|
||||||
*
|
|
||||||
* Usage: Internal/External
|
|
||||||
*
|
|
||||||
* </ini>
|
|
||||||
*/
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_NAME "InfraUapsdBeSrvIntv"
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MIN (0)
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MAX (4294967295UL)
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_DEFAULT (300)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* <ini>
|
|
||||||
* InfraUapsdBeSuspIntv - Set Uapsd suspension interval for BE
|
|
||||||
* @Min: 0
|
|
||||||
* @Max: 4294967295UL
|
|
||||||
* @Default: 2000
|
|
||||||
*
|
|
||||||
* This ini is used to set Uapsd suspension interval for BE
|
|
||||||
*
|
|
||||||
* Related: None.
|
|
||||||
*
|
|
||||||
* Supported Feature: WMM
|
|
||||||
*
|
|
||||||
* Usage: Internal/External
|
|
||||||
*
|
|
||||||
* </ini>
|
|
||||||
*/
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_NAME "InfraUapsdBeSuspIntv"
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MIN (0)
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MAX (4294967295UL)
|
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_DEFAULT (2000)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* <ini>
|
* <ini>
|
||||||
* InfraUapsdBkSrvIntv - Set Uapsd service interval for BK
|
* InfraUapsdBkSrvIntv - Set Uapsd service interval for BK
|
||||||
@@ -2829,117 +2785,6 @@ enum station_keepalive_method {
|
|||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_MAX (4294967295UL)
|
#define CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_MAX (4294967295UL)
|
||||||
#define CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_DEFAULT (2000)
|
#define CFG_QOS_WMM_INFRA_UAPSD_BK_SUS_INTV_DEFAULT (2000)
|
||||||
|
|
||||||
/* default TSPEC parameters for AC_BE*/
|
|
||||||
/*
|
|
||||||
* <ini>
|
|
||||||
* InfraDirAcBe - Set TSPEC direction for BE
|
|
||||||
* @Min: 0
|
|
||||||
* @Max: 3
|
|
||||||
* @Default: 3
|
|
||||||
*
|
|
||||||
* This ini is used to set TSPEC direction for BE
|
|
||||||
*
|
|
||||||
* Related: None.
|
|
||||||
*
|
|
||||||
* Supported Feature: WMM
|
|
||||||
*
|
|
||||||
* Usage: Internal/External
|
|
||||||
*
|
|
||||||
* </ini>
|
|
||||||
*/
|
|
||||||
#define CFG_QOS_WMM_INFRA_DIR_AC_BE_NAME "InfraDirAcBe"
|
|
||||||
#define CFG_QOS_WMM_INFRA_DIR_AC_BE_MIN (0)
|
|
||||||
#define CFG_QOS_WMM_INFRA_DIR_AC_BE_MAX (3)
|
|
||||||
#define CFG_QOS_WMM_INFRA_DIR_AC_BE_DEFAULT (3) /*WLAN_QCT_CUST_WMM_TSDIR_BOTH*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* <ini>
|
|
||||||
* InfraNomMsduSizeAcBe - Set normal MSDU size for BE
|
|
||||||
* @Min: 0x0
|
|
||||||
* @Max: 0xFFFF
|
|
||||||
* @Default: 0x85DC
|
|
||||||
*
|
|
||||||
* This ini is used to set normal MSDU size for BE
|
|
||||||
*
|
|
||||||
* Related: None.
|
|
||||||
*
|
|
||||||
* Supported Feature: WMM
|
|
||||||
*
|
|
||||||
* Usage: Internal/External
|
|
||||||
*
|
|
||||||
* </ini>
|
|
||||||
*/
|
|
||||||
#define CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_NAME "InfraNomMsduSizeAcBe"
|
|
||||||
#define CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MIN (0x0)
|
|
||||||
#define CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MAX (0xFFFF)
|
|
||||||
#define CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_DEFAULT (0x85DC)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* <ini>
|
|
||||||
* InfraMeanDataRateAcBe - Set mean data rate for BE
|
|
||||||
* @Min: 0x0
|
|
||||||
* @Max: 0xFFFFFFFF
|
|
||||||
* @Default: 0x493E0
|
|
||||||
*
|
|
||||||
* This ini is used to set mean data rate for BE
|
|
||||||
*
|
|
||||||
* Related: None.
|
|
||||||
*
|
|
||||||
* Supported Feature: WMM
|
|
||||||
*
|
|
||||||
* Usage: Internal/External
|
|
||||||
*
|
|
||||||
* </ini>
|
|
||||||
*/
|
|
||||||
#define CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_NAME "InfraMeanDataRateAcBe"
|
|
||||||
#define CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MIN (0x0)
|
|
||||||
#define CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MAX (0xFFFFFFFF)
|
|
||||||
#define CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_DEFAULT (0x493E0)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* <ini>
|
|
||||||
* InfraMinPhyRateAcBe - Set min PHY rate for BE
|
|
||||||
* @Min: 0x0
|
|
||||||
* @Max: 0xFFFFFFFF
|
|
||||||
* @Default: 0x5B8D80
|
|
||||||
*
|
|
||||||
* This ini is used to set min PHY rate for BE
|
|
||||||
*
|
|
||||||
* Related: None.
|
|
||||||
*
|
|
||||||
* Supported Feature: WMM
|
|
||||||
*
|
|
||||||
* Usage: Internal/External
|
|
||||||
*
|
|
||||||
* </ini>
|
|
||||||
*/
|
|
||||||
#define CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_NAME "InfraMinPhyRateAcBe"
|
|
||||||
#define CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MIN (0x0)
|
|
||||||
#define CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MAX (0xFFFFFFFF)
|
|
||||||
#define CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_DEFAULT (0x5B8D80)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* <ini>
|
|
||||||
* InfraSbaAcBe - Set surplus bandwidth allowance for BE
|
|
||||||
* @Min: 0x2001
|
|
||||||
* @Max: 0xFFFF
|
|
||||||
* @Default: 0x2001
|
|
||||||
*
|
|
||||||
* This ini is used to set surplus bandwidth allowance for BE
|
|
||||||
*
|
|
||||||
* Related: None.
|
|
||||||
*
|
|
||||||
* Supported Feature: WMM
|
|
||||||
*
|
|
||||||
* Usage: Internal/External
|
|
||||||
*
|
|
||||||
* </ini>
|
|
||||||
*/
|
|
||||||
#define CFG_QOS_WMM_INFRA_SBA_AC_BE_NAME "InfraSbaAcBe"
|
|
||||||
#define CFG_QOS_WMM_INFRA_SBA_AC_BE_MIN (0x2001)
|
|
||||||
#define CFG_QOS_WMM_INFRA_SBA_AC_BE_MAX (0xFFFF)
|
|
||||||
#define CFG_QOS_WMM_INFRA_SBA_AC_BE_DEFAULT (0x2001)
|
|
||||||
|
|
||||||
/* default TSPEC parameters for AC_Bk*/
|
/* default TSPEC parameters for AC_Bk*/
|
||||||
/*
|
/*
|
||||||
* <ini>
|
* <ini>
|
||||||
@@ -6953,8 +6798,6 @@ struct hdd_config {
|
|||||||
enum hdd_wmm_user_mode WmmMode;
|
enum hdd_wmm_user_mode WmmMode;
|
||||||
bool b80211eIsEnabled;
|
bool b80211eIsEnabled;
|
||||||
uint8_t UapsdMask; /* what ACs to setup U-APSD for at assoc */
|
uint8_t UapsdMask; /* what ACs to setup U-APSD for at assoc */
|
||||||
uint32_t InfraUapsdBeSrvIntv;
|
|
||||||
uint32_t InfraUapsdBeSuspIntv;
|
|
||||||
uint32_t InfraUapsdBkSrvIntv;
|
uint32_t InfraUapsdBkSrvIntv;
|
||||||
uint32_t InfraUapsdBkSuspIntv;
|
uint32_t InfraUapsdBkSuspIntv;
|
||||||
bool isFastRoamIniFeatureEnabled;
|
bool isFastRoamIniFeatureEnabled;
|
||||||
@@ -6969,13 +6812,6 @@ struct hdd_config {
|
|||||||
bool isRoamOffloadScanEnabled;
|
bool isRoamOffloadScanEnabled;
|
||||||
bool bImplicitQosEnabled;
|
bool bImplicitQosEnabled;
|
||||||
|
|
||||||
/* default TSPEC parameters for AC_BE */
|
|
||||||
enum sme_qos_wmm_dir_type InfraDirAcBe;
|
|
||||||
uint16_t InfraNomMsduSizeAcBe;
|
|
||||||
uint32_t InfraMeanDataRateAcBe;
|
|
||||||
uint32_t InfraMinPhyRateAcBe;
|
|
||||||
uint16_t InfraSbaAcBe;
|
|
||||||
|
|
||||||
/* default TSPEC parameters for AC_BK */
|
/* default TSPEC parameters for AC_BK */
|
||||||
enum sme_qos_wmm_dir_type InfraDirAcBk;
|
enum sme_qos_wmm_dir_type InfraDirAcBk;
|
||||||
uint16_t InfraNomMsduSizeAcBk;
|
uint16_t InfraNomMsduSizeAcBk;
|
||||||
|
@@ -770,22 +770,6 @@ struct reg_table_entry g_registry_table[] = {
|
|||||||
CFG_QOS_WMM_UAPSD_MASK_MIN,
|
CFG_QOS_WMM_UAPSD_MASK_MIN,
|
||||||
CFG_QOS_WMM_UAPSD_MASK_MAX),
|
CFG_QOS_WMM_UAPSD_MASK_MAX),
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_NAME,
|
|
||||||
WLAN_PARAM_Integer,
|
|
||||||
struct hdd_config, InfraUapsdBeSrvIntv,
|
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MIN,
|
|
||||||
CFG_QOS_WMM_INFRA_UAPSD_BE_SRV_INTV_MAX),
|
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_NAME,
|
|
||||||
WLAN_PARAM_Integer,
|
|
||||||
struct hdd_config, InfraUapsdBeSuspIntv,
|
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MIN,
|
|
||||||
CFG_QOS_WMM_INFRA_UAPSD_BE_SUS_INTV_MAX),
|
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_NAME,
|
REG_VARIABLE(CFG_QOS_WMM_INFRA_UAPSD_BK_SRV_INTV_NAME,
|
||||||
WLAN_PARAM_Integer,
|
WLAN_PARAM_Integer,
|
||||||
struct hdd_config, InfraUapsdBkSrvIntv,
|
struct hdd_config, InfraUapsdBkSrvIntv,
|
||||||
@@ -883,44 +867,6 @@ struct reg_table_entry g_registry_table[] = {
|
|||||||
CFG_ROAM_SCAN_OFFLOAD_ENABLED_MAX,
|
CFG_ROAM_SCAN_OFFLOAD_ENABLED_MAX,
|
||||||
cb_notify_update_roam_scan_offload_enabled, 0),
|
cb_notify_update_roam_scan_offload_enabled, 0),
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_BE_NAME, WLAN_PARAM_Integer,
|
|
||||||
struct hdd_config, InfraDirAcBe,
|
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_DIR_AC_BE_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_DIR_AC_BE_MIN,
|
|
||||||
CFG_QOS_WMM_INFRA_DIR_AC_BE_MAX),
|
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_NAME,
|
|
||||||
WLAN_PARAM_HexInteger,
|
|
||||||
struct hdd_config, InfraNomMsduSizeAcBe,
|
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MIN,
|
|
||||||
CFG_QOS_WMM_INFRA_NOM_MSDU_SIZE_AC_BE_MAX),
|
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_NAME,
|
|
||||||
WLAN_PARAM_HexInteger,
|
|
||||||
struct hdd_config, InfraMeanDataRateAcBe,
|
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MIN,
|
|
||||||
CFG_QOS_WMM_INFRA_MEAN_DATA_RATE_AC_BE_MAX),
|
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_NAME,
|
|
||||||
WLAN_PARAM_HexInteger,
|
|
||||||
struct hdd_config, InfraMinPhyRateAcBe,
|
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MIN,
|
|
||||||
CFG_QOS_WMM_INFRA_MIN_PHY_RATE_AC_BE_MAX),
|
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_SBA_AC_BE_NAME, WLAN_PARAM_HexInteger,
|
|
||||||
struct hdd_config, InfraSbaAcBe,
|
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_SBA_AC_BE_DEFAULT,
|
|
||||||
CFG_QOS_WMM_INFRA_SBA_AC_BE_MIN,
|
|
||||||
CFG_QOS_WMM_INFRA_SBA_AC_BE_MAX),
|
|
||||||
|
|
||||||
REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_BK_NAME, WLAN_PARAM_Integer,
|
REG_VARIABLE(CFG_QOS_WMM_INFRA_DIR_AC_BK_NAME, WLAN_PARAM_Integer,
|
||||||
struct hdd_config, InfraDirAcBk,
|
struct hdd_config, InfraDirAcBk,
|
||||||
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
VAR_FLAGS_OPTIONAL | VAR_FLAGS_RANGE_CHECK_ASSUME_DEFAULT,
|
||||||
|
@@ -1200,22 +1200,61 @@ static void __hdd_wmm_do_implicit_qos(struct work_struct *work)
|
|||||||
((WLAN_HDD_GET_CTX(adapter))->config->
|
((WLAN_HDD_GET_CTX(adapter))->config->
|
||||||
UapsdMask & SME_QOS_UAPSD_BE) ? 1 : 0;
|
UapsdMask & SME_QOS_UAPSD_BE) ? 1 : 0;
|
||||||
}
|
}
|
||||||
qosInfo.ts_info.direction =
|
status = ucfg_mlme_get_wmm_dir_ac_be(hdd_ctx->psoc, &dir_ac);
|
||||||
(WLAN_HDD_GET_CTX(adapter))->config->InfraDirAcBe;
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
|
hdd_err("Get infra_dir_ac_be failed");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
qosInfo.ts_info.direction = dir_ac;
|
||||||
|
|
||||||
qosInfo.ts_info.tid = 255;
|
qosInfo.ts_info.tid = 255;
|
||||||
qosInfo.mean_data_rate =
|
status = ucfg_mlme_get_wmm_uapsd_be_srv_intv(hdd_ctx->psoc,
|
||||||
(WLAN_HDD_GET_CTX(adapter))->config->
|
&uapsd_value);
|
||||||
InfraMeanDataRateAcBe;
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
qosInfo.min_phy_rate =
|
hdd_err("Get uapsd_vi_srv_intv failed");
|
||||||
(WLAN_HDD_GET_CTX(adapter))->config->InfraMinPhyRateAcBe;
|
return;
|
||||||
qosInfo.min_service_interval =
|
}
|
||||||
(WLAN_HDD_GET_CTX(adapter))->config->InfraUapsdBeSrvIntv;
|
qosInfo.min_service_interval = uapsd_value;
|
||||||
qosInfo.nominal_msdu_size =
|
|
||||||
(WLAN_HDD_GET_CTX(adapter))->config->InfraNomMsduSizeAcBe;
|
status = ucfg_mlme_get_wmm_uapsd_be_sus_intv(hdd_ctx->psoc,
|
||||||
qosInfo.surplus_bw_allowance =
|
&uapsd_value);
|
||||||
(WLAN_HDD_GET_CTX(adapter))->config->InfraSbaAcBe;
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
qosInfo.suspension_interval =
|
hdd_err("Get uapsd_vi_sus_intv failed");
|
||||||
(WLAN_HDD_GET_CTX(adapter))->config->InfraUapsdBeSuspIntv;
|
return;
|
||||||
|
}
|
||||||
|
qosInfo.suspension_interval = uapsd_value;
|
||||||
|
|
||||||
|
status = ucfg_mlme_get_wmm_mean_data_rate_ac_be(hdd_ctx->psoc,
|
||||||
|
&rate_ac);
|
||||||
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
|
hdd_err("Get mean_data_rate_ac_be failed");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
qosInfo.mean_data_rate = rate_ac;
|
||||||
|
|
||||||
|
status = ucfg_mlme_get_wmm_min_phy_rate_ac_be(hdd_ctx->psoc,
|
||||||
|
&rate_ac);
|
||||||
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
|
hdd_err("Get min_phy_rate_ac_be failed");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
qosInfo.min_phy_rate = rate_ac;
|
||||||
|
|
||||||
|
status = ucfg_mlme_get_wmm_nom_msdu_size_ac_be(hdd_ctx->psoc,
|
||||||
|
&nom_msdu_size_ac);
|
||||||
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
|
hdd_err("Get nom_msdu_size_ac_be failed");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
qosInfo.nominal_msdu_size = nom_msdu_size_ac;
|
||||||
|
|
||||||
|
status = ucfg_mlme_get_wmm_sba_ac_be(hdd_ctx->psoc, &sba_ac);
|
||||||
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
|
hdd_err("Get sba_ac_be failed");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
qosInfo.surplus_bw_allowance = sba_ac;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case SME_AC_BK:
|
case SME_AC_BK:
|
||||||
qosInfo.ts_info.up = SME_QOS_WMM_UP_BK;
|
qosInfo.ts_info.up = SME_QOS_WMM_UP_BK;
|
||||||
@@ -2003,15 +2042,26 @@ QDF_STATUS hdd_wmm_assoc(struct hdd_adapter *adapter,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (uapsdMask & HDD_AC_BE) {
|
if (uapsdMask & HDD_AC_BE) {
|
||||||
status =
|
status = ucfg_mlme_get_wmm_uapsd_be_srv_intv(hdd_ctx->psoc,
|
||||||
sme_enable_uapsd_for_ac((WLAN_HDD_GET_STATION_CTX_PTR
|
&srv_value);
|
||||||
(adapter))->conn_info.staId[0],
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
SME_AC_BE, 3, 3,
|
hdd_err("Get uapsd_be_srv_intv failed");
|
||||||
hdd_ctx->config->InfraUapsdBeSrvIntv,
|
return QDF_STATUS_SUCCESS;
|
||||||
hdd_ctx->config->InfraUapsdBeSuspIntv,
|
}
|
||||||
SME_QOS_WMM_TS_DIR_BOTH, 1,
|
status = ucfg_mlme_get_wmm_uapsd_be_sus_intv(hdd_ctx->psoc,
|
||||||
adapter->session_id,
|
&sus_value);
|
||||||
hdd_ctx->config->DelayedTriggerFrmInt);
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
|
hdd_err("Get uapsd_be_sus_intv failed");
|
||||||
|
return QDF_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
status = sme_enable_uapsd_for_ac(
|
||||||
|
(WLAN_HDD_GET_STATION_CTX_PTR(
|
||||||
|
adapter))->conn_info.staId[0],
|
||||||
|
SME_AC_BE, 3, 3, srv_value, sus_value,
|
||||||
|
SME_QOS_WMM_TS_DIR_BOTH, 1,
|
||||||
|
adapter->session_id,
|
||||||
|
hdd_ctx->config->DelayedTriggerFrmInt);
|
||||||
|
|
||||||
QDF_ASSERT(QDF_IS_STATUS_SUCCESS(status));
|
QDF_ASSERT(QDF_IS_STATUS_SUCCESS(status));
|
||||||
}
|
}
|
||||||
@@ -2172,8 +2222,13 @@ QDF_STATUS hdd_wmm_get_uapsd_mask(struct hdd_adapter *adapter,
|
|||||||
uapsdMask &= ~HDD_AC_BK;
|
uapsdMask &= ~HDD_AC_BK;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((WLAN_HDD_GET_CTX(adapter))->config->
|
status = ucfg_mlme_get_wmm_uapsd_be_srv_intv(hdd_ctx->psoc,
|
||||||
InfraUapsdBeSrvIntv == 0) {
|
&uapsd_value);
|
||||||
|
if (!QDF_IS_STATUS_SUCCESS(status)) {
|
||||||
|
hdd_err("Get uapsd_be_srv_intv failed");
|
||||||
|
return QDF_STATUS_E_FAILURE;
|
||||||
|
}
|
||||||
|
if (uapsd_value == 0) {
|
||||||
uapsdMask &= ~HDD_AC_BE;
|
uapsdMask &= ~HDD_AC_BE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user