qcacld-3.0: Create object mgr self peer for STA mode
For self STA object manager peer is not created. To transmit some frames before association object manager peer is required in wlan_mgmt_txrx_mgmt_frame_tx. So, create self STA obj manager peer as part of vdev attach. CRs-Fixed: 2276106 Change-Id: If34e039e1bbadcafabd1f86579c7d639256c9267
This commit is contained in:
parent
f7562c330e
commit
110b03e0f7
@ -37,6 +37,9 @@
|
||||
#define HDD_MAX_NUM_TDLS_STA_P_UAPSD_OFFCHAN 1
|
||||
#define TDLS_STA_INDEX_VALID(staId) \
|
||||
(((staId) >= 0) && ((staId) < 0xFF))
|
||||
#else
|
||||
#define HDD_MAX_NUM_TDLS_STA 0
|
||||
|
||||
#endif
|
||||
/* Timeout (in ms) for Link to Up before Registering Station */
|
||||
#define ASSOC_LINKUP_TIMEOUT 60
|
||||
|
@ -229,6 +229,9 @@ static qdf_wake_lock_t wlan_wake_lock;
|
||||
#define WOW_MIN_PATTERN_SIZE 6
|
||||
#define WOW_MAX_PATTERN_SIZE 64
|
||||
|
||||
/* max peer can be tdls peers + self peer + bss peer */
|
||||
#define HDD_MAX_VDEV_PEER_COUNT (HDD_MAX_NUM_TDLS_STA + 2)
|
||||
|
||||
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 11, 0))
|
||||
static const struct wiphy_wowlan_support wowlan_support_reg_init = {
|
||||
.flags = WIPHY_WOWLAN_ANY |
|
||||
@ -4104,6 +4107,11 @@ int hdd_vdev_create(struct hdd_adapter *adapter,
|
||||
errno);
|
||||
}
|
||||
|
||||
if (adapter->device_mode == QDF_STA_MODE ||
|
||||
adapter->device_mode == QDF_P2P_CLIENT_MODE)
|
||||
wlan_vdev_set_max_peer_count(adapter->hdd_vdev,
|
||||
HDD_MAX_VDEV_PEER_COUNT);
|
||||
|
||||
hdd_info("vdev %d created successfully", adapter->session_id);
|
||||
|
||||
return 0;
|
||||
|
@ -770,6 +770,51 @@ static bool wma_vdev_uses_self_peer(uint32_t vdev_type, uint32_t vdev_subtype)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* wma_remove_objmgr_peer() - remove objmgr peer information from host driver
|
||||
* @wma: wma handle
|
||||
* @vdev_id: vdev id
|
||||
* @peer_addr: peer mac address
|
||||
*
|
||||
* Return: none
|
||||
*/
|
||||
static void wma_remove_objmgr_peer(tp_wma_handle wma, uint8_t vdev_id,
|
||||
uint8_t *peer_addr)
|
||||
{
|
||||
struct wlan_objmgr_psoc *psoc;
|
||||
struct wlan_objmgr_peer *obj_peer;
|
||||
struct wlan_objmgr_vdev *obj_vdev;
|
||||
struct wlan_objmgr_pdev *obj_pdev;
|
||||
uint8_t pdev_id = 0;
|
||||
|
||||
psoc = wma->psoc;
|
||||
if (!psoc) {
|
||||
WMA_LOGE("%s:PSOC is NULL", __func__);
|
||||
return;
|
||||
}
|
||||
|
||||
obj_vdev = wlan_objmgr_get_vdev_by_id_from_psoc(psoc, vdev_id,
|
||||
WLAN_LEGACY_WMA_ID);
|
||||
if (!obj_vdev) {
|
||||
WMA_LOGE("Obj vdev not found. Unable to remove peer");
|
||||
return;
|
||||
}
|
||||
obj_pdev = wlan_vdev_get_pdev(obj_vdev);
|
||||
pdev_id = wlan_objmgr_pdev_get_pdev_id(obj_pdev);
|
||||
obj_peer = wlan_objmgr_get_peer(psoc, pdev_id, peer_addr,
|
||||
WLAN_LEGACY_WMA_ID);
|
||||
if (obj_peer) {
|
||||
wlan_objmgr_peer_obj_delete(obj_peer);
|
||||
/* Unref to decrement ref happened in find_peer */
|
||||
wlan_objmgr_peer_release_ref(obj_peer, WLAN_LEGACY_WMA_ID);
|
||||
WMA_LOGD("Peer %pM deleted", peer_addr);
|
||||
} else {
|
||||
WMA_LOGE("Peer %pM not found", peer_addr);
|
||||
}
|
||||
|
||||
wlan_objmgr_vdev_release_ref(obj_vdev, WLAN_LEGACY_WMA_ID);
|
||||
}
|
||||
|
||||
/**
|
||||
* wma_vdev_detach() - send vdev delete command to fw
|
||||
* @wma_handle: wma handle
|
||||
@ -799,6 +844,11 @@ QDF_STATUS wma_vdev_detach(tp_wma_handle wma_handle,
|
||||
*/
|
||||
if (cds_is_driver_recovering()) {
|
||||
wma_force_vdev_cleanup(wma_handle, vdev_id);
|
||||
/* Delete objmgr self peer of STA as part of SSR. */
|
||||
if (iface->type == WMI_VDEV_TYPE_STA) {
|
||||
wma_remove_objmgr_peer(wma_handle, vdev_id,
|
||||
pdel_sta_self_req_param->self_mac_addr);
|
||||
}
|
||||
goto send_rsp;
|
||||
}
|
||||
|
||||
@ -844,6 +894,10 @@ QDF_STATUS wma_vdev_detach(tp_wma_handle wma_handle,
|
||||
status = wma_handle_vdev_detach(wma_handle,
|
||||
pdel_sta_self_req_param, generateRsp);
|
||||
} else {
|
||||
if (iface->type == WMI_VDEV_TYPE_STA) {
|
||||
wma_remove_objmgr_peer(wma_handle, vdev_id,
|
||||
pdel_sta_self_req_param->self_mac_addr);
|
||||
}
|
||||
status = wma_handle_vdev_detach(wma_handle,
|
||||
pdel_sta_self_req_param, generateRsp);
|
||||
}
|
||||
@ -1316,7 +1370,7 @@ bool wma_is_vdev_valid(uint32_t vdev_id)
|
||||
/**
|
||||
* wma_vdev_set_param() - set per vdev params in fw
|
||||
* @wmi_handle: wmi handle
|
||||
* @if_if: vdev id
|
||||
* @if_id: vdev id
|
||||
* @param_id: parameter id
|
||||
* @param_value: parameter value
|
||||
*
|
||||
@ -1343,7 +1397,7 @@ wma_vdev_set_param(wmi_unified_t wmi_handle, uint32_t if_id,
|
||||
|
||||
/**
|
||||
* wma_set_peer_authorized_cb() - set peer authorized callback function
|
||||
* @wma_Ctx: wma handle
|
||||
* @wma_ctx: wma handle
|
||||
* @auth_cb: peer authorized callback
|
||||
*
|
||||
* Return: none
|
||||
@ -1382,53 +1436,7 @@ QDF_STATUS wma_set_peer_param(void *wma_ctx, uint8_t *peer_addr,
|
||||
|
||||
return err;
|
||||
}
|
||||
/**
|
||||
* wma_remove_objmgr_peer() - remove objmgr peer information from host driver
|
||||
* @wma: wma handle
|
||||
* @vdev_id: vdev id
|
||||
* @peer: peer mac address
|
||||
*
|
||||
* Return: none
|
||||
*/
|
||||
|
||||
static void wma_remove_objmgr_peer(tp_wma_handle wma, uint8_t vdev_id,
|
||||
uint8_t *peer_addr)
|
||||
{
|
||||
|
||||
struct wlan_objmgr_psoc *psoc = NULL;
|
||||
struct wlan_objmgr_peer *obj_peer = NULL;
|
||||
struct wlan_objmgr_vdev *obj_vdev = NULL;
|
||||
struct wlan_objmgr_pdev *obj_pdev = NULL;
|
||||
uint8_t pdev_id = 0;
|
||||
|
||||
psoc = wma->psoc;
|
||||
if (!psoc) {
|
||||
WMA_LOGE("%s:PSOC is NULL", __func__);
|
||||
return;
|
||||
}
|
||||
|
||||
obj_vdev = wlan_objmgr_get_vdev_by_id_from_psoc(psoc, vdev_id,
|
||||
WLAN_LEGACY_WMA_ID);
|
||||
if (!obj_vdev) {
|
||||
WMA_LOGE("Obj vdev not found. Unable to remove peer");
|
||||
return;
|
||||
}
|
||||
obj_pdev = wlan_vdev_get_pdev(obj_vdev);
|
||||
pdev_id = wlan_objmgr_pdev_get_pdev_id(obj_pdev);
|
||||
obj_peer = wlan_objmgr_get_peer(psoc, pdev_id, peer_addr,
|
||||
WLAN_LEGACY_WMA_ID);
|
||||
if (obj_peer) {
|
||||
wlan_objmgr_peer_obj_delete(obj_peer);
|
||||
/* Unref to decrement ref happened in find_peer */
|
||||
wlan_objmgr_peer_release_ref(obj_peer, WLAN_LEGACY_WMA_ID);
|
||||
WMA_LOGD("Peer %pM deleted", peer_addr);
|
||||
} else {
|
||||
WMA_LOGE("Peer %pM not found", peer_addr);
|
||||
}
|
||||
|
||||
wlan_objmgr_vdev_release_ref(obj_vdev, WLAN_LEGACY_WMA_ID);
|
||||
|
||||
}
|
||||
/**
|
||||
* wma_remove_peer() - remove peer information from host driver and fw
|
||||
* @wma: wma handle
|
||||
@ -1585,13 +1593,13 @@ static bool wma_find_duplicate_peer_on_other_vdev(tp_wma_handle wma,
|
||||
* wma_get_peer_type() - Determine the type of peer(eg. STA/AP) and return it
|
||||
* @wma: wma handle
|
||||
* @vdev_id: vdev id
|
||||
* @peer: peer mac address
|
||||
* @peer_addr: peer mac address
|
||||
* @wma_peer_type: wma peer type
|
||||
*
|
||||
* Return: Peer type
|
||||
*/
|
||||
|
||||
static int wma_get_peer_type(tp_wma_handle wma, uint8_t vdev_id,
|
||||
uint8_t *peer_addr)
|
||||
static int wma_get_obj_mgr_peer_type(tp_wma_handle wma, uint8_t vdev_id,
|
||||
uint8_t *peer_addr, uint32_t wma_peer_type)
|
||||
|
||||
{
|
||||
uint32_t obj_peer_type = 0;
|
||||
@ -1601,6 +1609,9 @@ static int wma_get_peer_type(tp_wma_handle wma, uint8_t vdev_id,
|
||||
wma->interfaces[vdev_id].sub_type, peer_addr,
|
||||
wma->interfaces[vdev_id].addr);
|
||||
|
||||
if (wma_peer_type == WMI_PEER_TYPE_TDLS)
|
||||
return WLAN_PEER_TDLS;
|
||||
|
||||
if (!qdf_mem_cmp(wma->interfaces[vdev_id].addr, peer_addr,
|
||||
IEEE80211_ADDR_LEN)) {
|
||||
obj_peer_type = WLAN_PEER_SELF;
|
||||
@ -1634,20 +1645,24 @@ static int wma_get_peer_type(tp_wma_handle wma, uint8_t vdev_id,
|
||||
* wma_create_objmgr_peer() - create objmgr peer information in host driver
|
||||
* @wma: wma handle
|
||||
* @vdev_id: vdev id
|
||||
* @peer: peer mac address
|
||||
* @peer_addr: peer mac address
|
||||
* @wma_peer_type: peer type
|
||||
*
|
||||
* Return: objmgr peer pointer
|
||||
*/
|
||||
|
||||
static struct wlan_objmgr_peer *wma_create_objmgr_peer(tp_wma_handle wma,
|
||||
uint8_t vdev_id, uint8_t *peer_addr)
|
||||
uint8_t vdev_id,
|
||||
uint8_t *peer_addr,
|
||||
uint32_t wma_peer_type)
|
||||
{
|
||||
uint32_t obj_peer_type = 0;
|
||||
struct wlan_objmgr_peer *obj_peer = NULL;
|
||||
struct wlan_objmgr_vdev *obj_vdev = NULL;
|
||||
struct wlan_objmgr_psoc *psoc = wma->psoc;
|
||||
|
||||
obj_peer_type = wma_get_peer_type(wma, vdev_id, peer_addr);
|
||||
obj_peer_type = wma_get_obj_mgr_peer_type(wma, vdev_id, peer_addr,
|
||||
wma_peer_type);
|
||||
if (!obj_peer_type) {
|
||||
WMA_LOGE("Invalid obj peer type. Unable to create peer %d",
|
||||
obj_peer_type);
|
||||
@ -1731,7 +1746,7 @@ QDF_STATUS wma_create_peer(tp_wma_handle wma, struct cdp_pdev *pdev,
|
||||
vdev_id, peer_addr))
|
||||
goto err;
|
||||
|
||||
obj_peer = wma_create_objmgr_peer(wma, vdev_id, peer_addr);
|
||||
obj_peer = wma_create_objmgr_peer(wma, vdev_id, peer_addr, peer_type);
|
||||
if (!obj_peer)
|
||||
goto err;
|
||||
|
||||
@ -2339,6 +2354,7 @@ struct cdp_vdev *wma_vdev_attach(tp_wma_handle wma_handle,
|
||||
struct sir_set_tx_rx_aggregation_size tx_rx_aggregation_size;
|
||||
struct sir_set_tx_aggr_sw_retry_threshold tx_aggr_sw_retry_threshold;
|
||||
void *soc = cds_get_context(QDF_MODULE_ID_SOC);
|
||||
struct wlan_objmgr_peer *obj_peer;
|
||||
|
||||
qdf_mem_zero(&tx_rx_aggregation_size, sizeof(tx_rx_aggregation_size));
|
||||
WMA_LOGD("mac %pM, vdev_id %hu, type %d, sub_type %d, nss 2g %d, 5g %d",
|
||||
@ -2523,6 +2539,16 @@ struct cdp_vdev *wma_vdev_attach(tp_wma_handle wma_handle,
|
||||
wmi_unified_vdev_delete_send(wma_handle->wmi_handle,
|
||||
self_sta_req->session_id);
|
||||
}
|
||||
} else if (self_sta_req->type == WMI_VDEV_TYPE_STA) {
|
||||
obj_peer = wma_create_objmgr_peer(wma_handle,
|
||||
vdev_id,
|
||||
self_sta_req->self_mac_addr,
|
||||
WMI_PEER_TYPE_DEFAULT);
|
||||
if (!obj_peer) {
|
||||
WMA_LOGE("%s: Failed to create obj mgr peer for self sta",
|
||||
__func__);
|
||||
goto end;
|
||||
}
|
||||
}
|
||||
|
||||
WMA_LOGD("Setting WMI_VDEV_PARAM_DISCONNECT_TH: %d",
|
||||
|
Loading…
Reference in New Issue
Block a user