mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-01 19:34:35 +08:00
staging: r8723au: Additional source patches
These changes are fixes that were discovered late in the testing cycle. Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net> Cc: Jes Sorensen <Jes.Sorensen@redhat.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
364e30ebd2
commit
c17416ef70
@ -842,10 +842,10 @@ int rtw_check_beacon_data23a(struct rtw_adapter *padapter, u8 *pbuf, int len)
|
|||||||
/* beacon interval */
|
/* beacon interval */
|
||||||
/* ie + 8; 8: TimeStamp, 2: Beacon Interval 2:Capability */
|
/* ie + 8; 8: TimeStamp, 2: Beacon Interval 2:Capability */
|
||||||
p = rtw_get_beacon_interval23a_from_ie(ie);
|
p = rtw_get_beacon_interval23a_from_ie(ie);
|
||||||
pbss_network->Configuration.BeaconPeriod = RTW_GET_LE16(p);
|
pbss_network->Configuration.BeaconPeriod = get_unaligned_le16(p);
|
||||||
|
|
||||||
/* capability */
|
/* capability */
|
||||||
cap = RTW_GET_LE16(ie);
|
cap = get_unaligned_le16(ie);
|
||||||
|
|
||||||
/* SSID */
|
/* SSID */
|
||||||
p = rtw_get_ie23a(ie + _BEACON_IE_OFFSET_, _SSID_IE_, &ie_len,
|
p = rtw_get_ie23a(ie + _BEACON_IE_OFFSET_, _SSID_IE_, &ie_len,
|
||||||
|
@ -447,7 +447,7 @@ _next:
|
|||||||
|
|
||||||
pcmdpriv->cmd_issued_cnt++;
|
pcmdpriv->cmd_issued_cnt++;
|
||||||
|
|
||||||
pcmd->cmdsz = _RND4(pcmd->cmdsz);/* _RND4 */
|
pcmd->cmdsz = ALIGN(pcmd->cmdsz, 4);
|
||||||
|
|
||||||
memcpy(pcmdbuf, pcmd->parmbuf, pcmd->cmdsz);
|
memcpy(pcmdbuf, pcmd->parmbuf, pcmd->cmdsz);
|
||||||
|
|
||||||
@ -1141,7 +1141,9 @@ static void traffic_status_watchdog(struct rtw_adapter *padapter)
|
|||||||
u8 bHigherBusyTraffic = false, bHigherBusyRxTraffic = false;
|
u8 bHigherBusyTraffic = false, bHigherBusyRxTraffic = false;
|
||||||
u8 bHigherBusyTxTraffic = false;
|
u8 bHigherBusyTxTraffic = false;
|
||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
|
#ifndef CONFIG_8723AU_BT_COEXIST
|
||||||
|
int BusyThreshold = 100;
|
||||||
|
#endif
|
||||||
/* */
|
/* */
|
||||||
/* Determine if our traffic is busy now */
|
/* Determine if our traffic is busy now */
|
||||||
/* */
|
/* */
|
||||||
@ -1638,12 +1640,12 @@ u8 rtw_drvextra_cmd_hdl23a(struct rtw_adapter *padapter, unsigned char *pbuf)
|
|||||||
case P2P_PS_WK_CID:
|
case P2P_PS_WK_CID:
|
||||||
p2p_ps_wk_hdl23a(padapter, pdrvextra_cmd->type_size);
|
p2p_ps_wk_hdl23a(padapter, pdrvextra_cmd->type_size);
|
||||||
break;
|
break;
|
||||||
#endif /* CONFIG_8723AU_P2P */
|
|
||||||
case P2P_PROTO_WK_CID:
|
case P2P_PROTO_WK_CID:
|
||||||
/* Commented by Albert 2011/07/01 */
|
/* Commented by Albert 2011/07/01 */
|
||||||
/* I used the type_size as the type command */
|
/* I used the type_size as the type command */
|
||||||
p2p_protocol_wk_hdl23a(padapter, pdrvextra_cmd->type_size);
|
p2p_protocol_wk_hdl23a(padapter, pdrvextra_cmd->type_size);
|
||||||
break;
|
break;
|
||||||
|
#endif /* CONFIG_8723AU_P2P */
|
||||||
#ifdef CONFIG_8723AU_AP_MODE
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
case CHECK_HIQ_WK_CID:
|
case CHECK_HIQ_WK_CID:
|
||||||
rtw_chk_hi_queue_hdl(padapter);
|
rtw_chk_hi_queue_hdl(padapter);
|
||||||
|
@ -108,7 +108,6 @@ ReadEFuseByte23a(struct rtw_adapter *Adapter, u16 _offset, u8 *pbuf)
|
|||||||
u32 value32;
|
u32 value32;
|
||||||
u8 readbyte;
|
u8 readbyte;
|
||||||
u16 retry;
|
u16 retry;
|
||||||
/* u32 start = rtw_get_current_time(); */
|
|
||||||
|
|
||||||
/* Write Address */
|
/* Write Address */
|
||||||
rtw_write8(Adapter, EFUSE_CTRL+1, (_offset & 0xff));
|
rtw_write8(Adapter, EFUSE_CTRL+1, (_offset & 0xff));
|
||||||
@ -137,7 +136,6 @@ ReadEFuseByte23a(struct rtw_adapter *Adapter, u16 _offset, u8 *pbuf)
|
|||||||
value32 = rtw_read32(Adapter, EFUSE_CTRL);
|
value32 = rtw_read32(Adapter, EFUSE_CTRL);
|
||||||
|
|
||||||
*pbuf = (u8)(value32 & 0xff);
|
*pbuf = (u8)(value32 & 0xff);
|
||||||
/* DBG_8723A("ReadEFuseByte23a _offset:%08u, in %d ms\n", _offset , rtw_get_passing_time_ms23a(start)); */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* */
|
/* */
|
||||||
|
@ -196,8 +196,8 @@ inline u8 *rtw_set_ie23a_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl,
|
|||||||
|
|
||||||
ie_data[0] = ttl;
|
ie_data[0] = ttl;
|
||||||
ie_data[1] = flags;
|
ie_data[1] = flags;
|
||||||
RTW_PUT_LE16((u8*)&ie_data[2], reason);
|
put_unaligned_le16(reason, (u8*)&ie_data[2]);
|
||||||
RTW_PUT_LE16((u8*)&ie_data[4], precedence);
|
put_unaligned_le16(precedence, (u8*)&ie_data[4]);
|
||||||
|
|
||||||
return rtw_set_ie23a(buf, 0x118, 6, ie_data, buf_len);
|
return rtw_set_ie23a(buf, 0x118, 6, ie_data, buf_len);
|
||||||
}
|
}
|
||||||
@ -585,7 +585,7 @@ int rtw_parse_wpa_ie23a(u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pair
|
|||||||
/* pairwise_cipher */
|
/* pairwise_cipher */
|
||||||
if (left >= 2) {
|
if (left >= 2) {
|
||||||
/* count = le16_to_cpu(*(u16*)pos); */
|
/* count = le16_to_cpu(*(u16*)pos); */
|
||||||
count = RTW_GET_LE16(pos);
|
count = get_unaligned_le16(pos);
|
||||||
pos += 2;
|
pos += 2;
|
||||||
left -= 2;
|
left -= 2;
|
||||||
|
|
||||||
@ -661,7 +661,7 @@ int rtw_parse_wpa2_ie23a(u8* rsn_ie, int rsn_ie_len, int *group_cipher,
|
|||||||
/* pairwise_cipher */
|
/* pairwise_cipher */
|
||||||
if (left >= 2) {
|
if (left >= 2) {
|
||||||
/* count = le16_to_cpu(*(u16*)pos); */
|
/* count = le16_to_cpu(*(u16*)pos); */
|
||||||
count = RTW_GET_LE16(pos);
|
count = get_unaligned_le16(pos);
|
||||||
pos += 2;
|
pos += 2;
|
||||||
left -= 2;
|
left -= 2;
|
||||||
|
|
||||||
@ -876,8 +876,8 @@ u8 *rtw_get_wps_attr23a(u8 *wps_ie, uint wps_ielen, u16 target_attr_id,
|
|||||||
|
|
||||||
while (attr_ptr - wps_ie < wps_ielen) {
|
while (attr_ptr - wps_ie < wps_ielen) {
|
||||||
/* 4 = 2(Attribute ID) + 2(Length) */
|
/* 4 = 2(Attribute ID) + 2(Length) */
|
||||||
u16 attr_id = RTW_GET_BE16(attr_ptr);
|
u16 attr_id = get_unaligned_be16(attr_ptr);
|
||||||
u16 attr_data_len = RTW_GET_BE16(attr_ptr + 2);
|
u16 attr_data_len = get_unaligned_be16(attr_ptr + 2);
|
||||||
u16 attr_len = attr_data_len + 4;
|
u16 attr_len = attr_data_len + 4;
|
||||||
|
|
||||||
/* DBG_8723A("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len); */
|
/* DBG_8723A("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len); */
|
||||||
@ -1246,8 +1246,8 @@ void dump_wps_ie23a(u8 *ie, u32 ie_len) {
|
|||||||
|
|
||||||
pos+= 6;
|
pos+= 6;
|
||||||
while (pos-ie < ie_len) {
|
while (pos-ie < ie_len) {
|
||||||
id = RTW_GET_BE16(pos);
|
id = get_unaligned_be16(pos);
|
||||||
len = RTW_GET_BE16(pos + 2);
|
len = get_unaligned_be16(pos + 2);
|
||||||
|
|
||||||
DBG_8723A("%s ID:0x%04x, LEN:%u\n", __func__, id, len);
|
DBG_8723A("%s ID:0x%04x, LEN:%u\n", __func__, id, len);
|
||||||
|
|
||||||
@ -1271,7 +1271,7 @@ void dump_p2p_ie23a(u8 *ie, u32 ie_len) {
|
|||||||
pos += 6;
|
pos += 6;
|
||||||
while (pos-ie < ie_len) {
|
while (pos-ie < ie_len) {
|
||||||
id = *pos;
|
id = *pos;
|
||||||
len = RTW_GET_LE16(pos+1);
|
len = get_unaligned_le16(pos+1);
|
||||||
|
|
||||||
DBG_8723A("%s ID:%u, LEN:%u\n", __func__, id, len);
|
DBG_8723A("%s ID:%u, LEN:%u\n", __func__, id, len);
|
||||||
|
|
||||||
@ -1362,7 +1362,7 @@ u8 *rtw_get_p2p_attr23a(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id,
|
|||||||
while (attr_ptr - p2p_ie < p2p_ielen) {
|
while (attr_ptr - p2p_ie < p2p_ielen) {
|
||||||
/* 3 = 1(Attribute ID) + 2(Length) */
|
/* 3 = 1(Attribute ID) + 2(Length) */
|
||||||
u8 attr_id = *attr_ptr;
|
u8 attr_id = *attr_ptr;
|
||||||
u16 attr_data_len = RTW_GET_LE16(attr_ptr + 1);
|
u16 attr_data_len = get_unaligned_le16(attr_ptr + 1);
|
||||||
u16 attr_len = attr_data_len + 3;
|
u16 attr_len = attr_data_len + 3;
|
||||||
|
|
||||||
/* DBG_8723A("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len); */
|
/* DBG_8723A("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len); */
|
||||||
@ -1429,7 +1429,7 @@ u32 rtw_set_p2p_attr_content23a(u8 *pbuf, u8 attr_id, u16 attr_len, u8 *pdata_at
|
|||||||
*pbuf = attr_id;
|
*pbuf = attr_id;
|
||||||
|
|
||||||
/* u16*)(pbuf + 1) = cpu_to_le16(attr_len); */
|
/* u16*)(pbuf + 1) = cpu_to_le16(attr_len); */
|
||||||
RTW_PUT_LE16(pbuf + 1, attr_len);
|
put_unaligned_le16(attr_len, pbuf + 1);
|
||||||
|
|
||||||
if (pdata_attr)
|
if (pdata_attr)
|
||||||
memcpy(pbuf + 3, pdata_attr, attr_len);
|
memcpy(pbuf + 3, pdata_attr, attr_len);
|
||||||
@ -1561,7 +1561,7 @@ int rtw_get_wfd_attr_content(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id,
|
|||||||
/* 1 (WFD IE) + 1 (Length) + 3 (OUI) + 1 (OUI Type) */
|
/* 1 (WFD IE) + 1 (Length) + 3 (OUI) + 1 (OUI Type) */
|
||||||
cnt = 6;
|
cnt = 6;
|
||||||
while (cnt < wfd_ielen) {
|
while (cnt < wfd_ielen) {
|
||||||
u16 attrlen = RTW_GET_BE16(wfd_ie + cnt + 1);
|
u16 attrlen = get_unaligned_be16(wfd_ie + cnt + 1);
|
||||||
|
|
||||||
attr_id = wfd_ie[cnt];
|
attr_id = wfd_ie[cnt];
|
||||||
if (attr_id == target_attr_id) {
|
if (attr_id == target_attr_id) {
|
||||||
|
@ -69,6 +69,7 @@ int _rtw_init_mlme_priv23a(struct rtw_adapter *padapter)
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
|
static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
|
||||||
{
|
{
|
||||||
if(*ppie)
|
if(*ppie)
|
||||||
@ -78,6 +79,7 @@ static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
|
|||||||
*ppie=NULL;
|
*ppie=NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void rtw23a_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
|
void rtw23a_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
|
||||||
{
|
{
|
||||||
@ -94,9 +96,7 @@ void rtw23a_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
|
|||||||
rtw_free_mlme_ie_data(&pmlmepriv->p2p_probe_resp_ie, &pmlmepriv->p2p_probe_resp_ie_len);
|
rtw_free_mlme_ie_data(&pmlmepriv->p2p_probe_resp_ie, &pmlmepriv->p2p_probe_resp_ie_len);
|
||||||
rtw_free_mlme_ie_data(&pmlmepriv->p2p_go_probe_resp_ie, &pmlmepriv->p2p_go_probe_resp_ie_len);
|
rtw_free_mlme_ie_data(&pmlmepriv->p2p_go_probe_resp_ie, &pmlmepriv->p2p_go_probe_resp_ie_len);
|
||||||
rtw_free_mlme_ie_data(&pmlmepriv->p2p_assoc_req_ie, &pmlmepriv->p2p_assoc_req_ie_len);
|
rtw_free_mlme_ie_data(&pmlmepriv->p2p_assoc_req_ie, &pmlmepriv->p2p_assoc_req_ie_len);
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_8723AU_P2P)
|
|
||||||
rtw_free_mlme_ie_data(&pmlmepriv->wfd_beacon_ie, &pmlmepriv->wfd_beacon_ie_len);
|
rtw_free_mlme_ie_data(&pmlmepriv->wfd_beacon_ie, &pmlmepriv->wfd_beacon_ie_len);
|
||||||
rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_req_ie, &pmlmepriv->wfd_probe_req_ie_len);
|
rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_req_ie, &pmlmepriv->wfd_probe_req_ie_len);
|
||||||
rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_resp_ie, &pmlmepriv->wfd_probe_resp_ie_len);
|
rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_resp_ie, &pmlmepriv->wfd_probe_resp_ie_len);
|
||||||
@ -941,7 +941,7 @@ void rtw_indicate_disconnect23a(struct rtw_adapter *padapter)
|
|||||||
|
|
||||||
/* set ips_deny_time to avoid enter IPS before LPS leave */
|
/* set ips_deny_time to avoid enter IPS before LPS leave */
|
||||||
padapter->pwrctrlpriv.ips_deny_time =
|
padapter->pwrctrlpriv.ips_deny_time =
|
||||||
rtw_get_current_time() + rtw_ms_to_systime23a(3000);
|
jiffies + msecs_to_jiffies(3000);
|
||||||
|
|
||||||
_clr_fwstate_(pmlmepriv, _FW_LINKED);
|
_clr_fwstate_(pmlmepriv, _FW_LINKED);
|
||||||
|
|
||||||
@ -1675,7 +1675,7 @@ static int rtw_check_join_candidate(struct mlme_priv *pmlmepriv
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* check ssid, if needed */
|
/* check ssid, if needed */
|
||||||
if (pmlmepriv->assoc_ssid.ssid && pmlmepriv->assoc_ssid.ssid_len) {
|
if (pmlmepriv->assoc_ssid.ssid_len) {
|
||||||
if (competitor->network.Ssid.ssid_len !=
|
if (competitor->network.Ssid.ssid_len !=
|
||||||
pmlmepriv->assoc_ssid.ssid_len ||
|
pmlmepriv->assoc_ssid.ssid_len ||
|
||||||
memcmp(competitor->network.Ssid.ssid,
|
memcmp(competitor->network.Ssid.ssid,
|
||||||
@ -1839,8 +1839,7 @@ int rtw_set_key23a(struct rtw_adapter *adapter,
|
|||||||
res = _FAIL; /* try again */
|
res = _FAIL; /* try again */
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
psetkeyparm = (struct setkey_parm *)
|
psetkeyparm = kzalloc(sizeof(struct setkey_parm), GFP_KERNEL);
|
||||||
kzalloc(sizeof(struct setkey_parm), GFP_KERNEL);
|
|
||||||
if (!psetkeyparm) {
|
if (!psetkeyparm) {
|
||||||
kfree(pcmd);
|
kfree(pcmd);
|
||||||
res = _FAIL;
|
res = _FAIL;
|
||||||
@ -1902,6 +1901,8 @@ int rtw_set_key23a(struct rtw_adapter *adapter,
|
|||||||
"%x (must be 1 or 2 or 4 or 5)\n",
|
"%x (must be 1 or 2 or 4 or 5)\n",
|
||||||
psecuritypriv->dot11PrivacyAlgrthm));
|
psecuritypriv->dot11PrivacyAlgrthm));
|
||||||
res = _FAIL;
|
res = _FAIL;
|
||||||
|
kfree(pcmd);
|
||||||
|
kfree(psetkeyparm);
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -762,9 +762,9 @@ unsigned int OnProbeRsp23a(struct rtw_adapter *padapter,
|
|||||||
struct recv_frame *precv_frame)
|
struct recv_frame *precv_frame)
|
||||||
{
|
{
|
||||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
struct sk_buff *skb = precv_frame->pkt;
|
struct sk_buff *skb = precv_frame->pkt;
|
||||||
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
|
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
|
||||||
#ifdef CONFIG_8723AU_P2P
|
|
||||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1309,10 +1309,10 @@ unsigned int OnAssocReq23a(struct rtw_adapter *padapter, struct recv_frame *prec
|
|||||||
goto asoc_class2_error;
|
goto asoc_class2_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
capab_info = RTW_GET_LE16(pframe + sizeof(struct ieee80211_hdr_3addr));
|
capab_info = get_unaligned_le16(pframe + sizeof(struct ieee80211_hdr_3addr));
|
||||||
/* capab_info = le16_to_cpu(*(unsigned short *)(pframe + sizeof(struct ieee80211_hdr_3addr))); */
|
/* capab_info = le16_to_cpu(*(unsigned short *)(pframe + sizeof(struct ieee80211_hdr_3addr))); */
|
||||||
/* listen_interval = le16_to_cpu(*(unsigned short *)(pframe + sizeof(struct ieee80211_hdr_3addr)+2)); */
|
/* listen_interval = le16_to_cpu(*(unsigned short *)(pframe + sizeof(struct ieee80211_hdr_3addr)+2)); */
|
||||||
listen_interval = RTW_GET_LE16(pframe + sizeof(struct ieee80211_hdr_3addr)+2);
|
listen_interval = get_unaligned_le16(pframe + sizeof(struct ieee80211_hdr_3addr)+2);
|
||||||
|
|
||||||
left = pkt_len - (sizeof(struct ieee80211_hdr_3addr) + ie_offset);
|
left = pkt_len - (sizeof(struct ieee80211_hdr_3addr) + ie_offset);
|
||||||
pos = pframe + (sizeof(struct ieee80211_hdr_3addr) + ie_offset);
|
pos = pframe + (sizeof(struct ieee80211_hdr_3addr) + ie_offset);
|
||||||
@ -1665,7 +1665,7 @@ unsigned int OnAssocReq23a(struct rtw_adapter *padapter, struct recv_frame *prec
|
|||||||
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
||||||
if (attr_contentlen)
|
if (attr_contentlen)
|
||||||
{
|
{
|
||||||
pwdinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
|
pwdinfo->wfd_info->peer_rtsp_ctrlport = get_unaligned_be16(attr_content + 2);
|
||||||
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2091,7 +2091,7 @@ unsigned int OnAction23a_back23a(struct rtw_adapter *padapter, struct recv_frame
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WLAN_ACTION_ADDBA_RESP: /* ADDBA response */
|
case WLAN_ACTION_ADDBA_RESP: /* ADDBA response */
|
||||||
status = RTW_GET_LE16(&frame_body[3]);
|
status = get_unaligned_le16(&frame_body[3]);
|
||||||
tid = ((frame_body[5] >> 2) & 0x7);
|
tid = ((frame_body[5] >> 2) & 0x7);
|
||||||
if (status == 0) { /* successful */
|
if (status == 0) { /* successful */
|
||||||
DBG_8723A("agg_enable for TID =%d\n", tid);
|
DBG_8723A("agg_enable for TID =%d\n", tid);
|
||||||
@ -2110,7 +2110,7 @@ unsigned int OnAction23a_back23a(struct rtw_adapter *padapter, struct recv_frame
|
|||||||
~(1 << ((frame_body[3] >> 4) & 0xf));
|
~(1 << ((frame_body[3] >> 4) & 0xf));
|
||||||
|
|
||||||
/* reason_code = frame_body[4] | (frame_body[5] << 8); */
|
/* reason_code = frame_body[4] | (frame_body[5] << 8); */
|
||||||
reason_code = RTW_GET_LE16(&frame_body[4]);
|
reason_code = get_unaligned_le16(&frame_body[4]);
|
||||||
} else if ((frame_body[3] & BIT(3)) == BIT(3)) {
|
} else if ((frame_body[3] & BIT(3)) == BIT(3)) {
|
||||||
tid = (frame_body[3] >> 4) & 0x0F;
|
tid = (frame_body[3] >> 4) & 0x0F;
|
||||||
|
|
||||||
@ -4531,14 +4531,14 @@ static s32 rtw_action_public_decache(struct recv_frame *recv_frame, s32 token)
|
|||||||
|
|
||||||
static unsigned int on_action_public23a_p2p(struct recv_frame *precv_frame)
|
static unsigned int on_action_public23a_p2p(struct recv_frame *precv_frame)
|
||||||
{
|
{
|
||||||
struct rtw_adapter *padapter = precv_frame->adapter;
|
|
||||||
struct sk_buff *skb = precv_frame->pkt;
|
struct sk_buff *skb = precv_frame->pkt;
|
||||||
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
|
|
||||||
u8 *pframe = skb->data;
|
u8 *pframe = skb->data;
|
||||||
uint len = skb->len;
|
|
||||||
u8 *frame_body;
|
u8 *frame_body;
|
||||||
u8 dialogToken = 0;
|
u8 dialogToken = 0;
|
||||||
#ifdef CONFIG_8723AU_P2P
|
#ifdef CONFIG_8723AU_P2P
|
||||||
|
struct rtw_adapter *padapter = precv_frame->adapter;
|
||||||
|
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
|
||||||
|
uint len = skb->len;
|
||||||
u8 *p2p_ie;
|
u8 *p2p_ie;
|
||||||
u32 p2p_ielen;
|
u32 p2p_ielen;
|
||||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||||
@ -5262,9 +5262,7 @@ void issue_beacon23a(struct rtw_adapter *padapter, int timeout_ms)
|
|||||||
unsigned short *fctrl;
|
unsigned short *fctrl;
|
||||||
unsigned int rate_len;
|
unsigned int rate_len;
|
||||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||||
#ifdef CONFIG_8723AU_AP_MODE
|
|
||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
#endif
|
|
||||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||||
struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
|
struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
|
||||||
@ -5579,6 +5577,13 @@ void issue_probersp23a(struct rtw_adapter *padapter, unsigned char *da,
|
|||||||
#ifdef CONFIG_8723AU_AP_MODE
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
u8 *pwps_ie;
|
u8 *pwps_ie;
|
||||||
uint wps_ielen;
|
uint wps_ielen;
|
||||||
|
u8 *ssid_ie;
|
||||||
|
int ssid_ielen;
|
||||||
|
int ssid_ielen_diff;
|
||||||
|
u8 buf[MAX_IE_SZ];
|
||||||
|
u8 *ies;
|
||||||
|
#endif
|
||||||
|
#if defined(CONFIG_8723AU_AP_MODE) || defined(CONFIG_8723AU_P2P)
|
||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
#endif
|
#endif
|
||||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||||
@ -5588,11 +5593,6 @@ void issue_probersp23a(struct rtw_adapter *padapter, unsigned char *da,
|
|||||||
#ifdef CONFIG_8723AU_P2P
|
#ifdef CONFIG_8723AU_P2P
|
||||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||||
#endif /* CONFIG_8723AU_P2P */
|
#endif /* CONFIG_8723AU_P2P */
|
||||||
u8 *ssid_ie;
|
|
||||||
int ssid_ielen;
|
|
||||||
int ssid_ielen_diff;
|
|
||||||
u8 buf[MAX_IE_SZ];
|
|
||||||
u8 *ies;
|
|
||||||
|
|
||||||
/* DBG_8723A("%s\n", __func__); */
|
/* DBG_8723A("%s\n", __func__); */
|
||||||
|
|
||||||
@ -7559,6 +7559,7 @@ unsigned int send_beacon23a(struct rtw_adapter *padapter)
|
|||||||
int issue = 0;
|
int issue = 0;
|
||||||
int poll = 0;
|
int poll = 0;
|
||||||
unsigned long start = jiffies;
|
unsigned long start = jiffies;
|
||||||
|
unsigned int passing_time;
|
||||||
|
|
||||||
rtw_hal_set_hwreg23a(padapter, HW_VAR_BCN_VALID, NULL);
|
rtw_hal_set_hwreg23a(padapter, HW_VAR_BCN_VALID, NULL);
|
||||||
do {
|
do {
|
||||||
@ -7578,11 +7579,12 @@ unsigned int send_beacon23a(struct rtw_adapter *padapter)
|
|||||||
if (padapter->bSurpriseRemoved || padapter->bDriverStopped)
|
if (padapter->bSurpriseRemoved || padapter->bDriverStopped)
|
||||||
return _FAIL;
|
return _FAIL;
|
||||||
|
|
||||||
|
passing_time = jiffies_to_msecs(jiffies - start);
|
||||||
|
|
||||||
if (!bxmitok) {
|
if (!bxmitok) {
|
||||||
DBG_8723A("%s fail! %u ms\n", __func__, rtw_get_passing_time_ms23a(start));
|
DBG_8723A("%s fail! %u ms\n", __func__, passing_time);
|
||||||
return _FAIL;
|
return _FAIL;
|
||||||
} else {
|
} else {
|
||||||
unsigned int passing_time = jiffies_to_msecs(jiffies - start);
|
|
||||||
|
|
||||||
if (passing_time > 100 || issue > 3)
|
if (passing_time > 100 || issue > 3)
|
||||||
DBG_8723A("%s success, issue:%d, poll:%d, %u ms\n",
|
DBG_8723A("%s success, issue:%d, poll:%d, %u ms\n",
|
||||||
|
@ -81,7 +81,7 @@ static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
pcur++;
|
pcur++;
|
||||||
|
|
||||||
/* u16*)(pcur) = cpu_to_be16(psta->config_methods); */
|
/* u16*)(pcur) = cpu_to_be16(psta->config_methods); */
|
||||||
RTW_PUT_BE16(pcur, psta->config_methods);
|
put_unaligned_be16(psta->config_methods, pcur);
|
||||||
pcur += 2;
|
pcur += 2;
|
||||||
|
|
||||||
memcpy(pcur, psta->primary_dev_type, 8);
|
memcpy(pcur, psta->primary_dev_type, 8);
|
||||||
@ -96,11 +96,11 @@ static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
if (psta->dev_name_len>0)
|
if (psta->dev_name_len>0)
|
||||||
{
|
{
|
||||||
/* u16*)(pcur) = cpu_to_be16(WPS_ATTR_DEVICE_NAME); */
|
/* u16*)(pcur) = cpu_to_be16(WPS_ATTR_DEVICE_NAME); */
|
||||||
RTW_PUT_BE16(pcur, WPS_ATTR_DEVICE_NAME);
|
put_unaligned_be16(WPS_ATTR_DEVICE_NAME, pcur);
|
||||||
pcur += 2;
|
pcur += 2;
|
||||||
|
|
||||||
/* u16*)(pcur) = cpu_to_be16(psta->dev_name_len); */
|
/* u16*)(pcur) = cpu_to_be16(psta->dev_name_len); */
|
||||||
RTW_PUT_BE16(pcur, psta->dev_name_len);
|
put_unaligned_be16(psta->dev_name_len, pcur);
|
||||||
pcur += 2;
|
pcur += 2;
|
||||||
|
|
||||||
memcpy(pcur, psta->dev_name, psta->dev_name_len);
|
memcpy(pcur, psta->dev_name, psta->dev_name_len);
|
||||||
@ -320,23 +320,23 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8* raddr,
|
|||||||
wpsielen = 0;
|
wpsielen = 0;
|
||||||
/* WPS OUI */
|
/* WPS OUI */
|
||||||
/* u32*) (wpsie) = cpu_to_be32(WPSOUI); */
|
/* u32*) (wpsie) = cpu_to_be32(WPSOUI); */
|
||||||
RTW_PUT_BE32(wpsie, WPSOUI);
|
put_unaligned_be32(WPSOUI, wpsie);
|
||||||
wpsielen += 4;
|
wpsielen += 4;
|
||||||
|
|
||||||
/* Config Method */
|
/* Config Method */
|
||||||
/* Type: */
|
/* Type: */
|
||||||
/* u16*) (wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD); */
|
/* u16*) (wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD); */
|
||||||
RTW_PUT_BE16(wpsie + wpsielen, WPS_ATTR_CONF_METHOD);
|
put_unaligned_be16(WPS_ATTR_CONF_METHOD, wpsie + wpsielen);
|
||||||
wpsielen += 2;
|
wpsielen += 2;
|
||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* u16*) (wpsie + wpsielen) = cpu_to_be16(0x0002); */
|
/* u16*) (wpsie + wpsielen) = cpu_to_be16(0x0002); */
|
||||||
RTW_PUT_BE16(wpsie + wpsielen, 0x0002);
|
put_unaligned_be16(0x0002, wpsie + wpsielen);
|
||||||
wpsielen += 2;
|
wpsielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
/* u16*) (wpsie + wpsielen) = cpu_to_be16(config_method); */
|
/* u16*) (wpsie + wpsielen) = cpu_to_be16(config_method); */
|
||||||
RTW_PUT_BE16(wpsie + wpsielen, config_method);
|
put_unaligned_be16(config_method, wpsie + wpsielen);
|
||||||
wpsielen += 2;
|
wpsielen += 2;
|
||||||
|
|
||||||
pframe = rtw_set_ie23a(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
|
pframe = rtw_set_ie23a(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
|
||||||
@ -513,7 +513,7 @@ u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
@ -524,19 +524,24 @@ u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
if (is_any_client_associated(pwdinfo->padapter))
|
if (is_any_client_associated(pwdinfo->padapter))
|
||||||
{
|
{
|
||||||
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_WSD, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
|
WFD_DEVINFO_WSD, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
|
WFD_DEVINFO_WSD, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
|
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
@ -544,13 +549,13 @@ u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -559,7 +564,7 @@ u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -581,7 +586,7 @@ u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -628,7 +633,7 @@ u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
@ -637,17 +642,17 @@ u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
if (1 == pwdinfo->wfd_tdls_enable)
|
if (1 == pwdinfo->wfd_tdls_enable)
|
||||||
{
|
{
|
||||||
/* WFD primary sink + available for WFD session + WiFi TDLS mode + WSC (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi TDLS mode + WSC (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type |
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
WFD_DEVINFO_SESSION_AVAIL |
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
WFD_DEVINFO_WSD |
|
WFD_DEVINFO_WSD |
|
||||||
WFD_DEVINFO_PC_TDLS);
|
WFD_DEVINFO_PC_TDLS, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSC (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSC (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type |
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
WFD_DEVINFO_SESSION_AVAIL |
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
WFD_DEVINFO_WSD);
|
WFD_DEVINFO_WSD, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
|
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
@ -655,13 +660,13 @@ u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -670,7 +675,7 @@ u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -692,7 +697,7 @@ u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -740,7 +745,7 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
@ -756,12 +761,12 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
if (pwdinfo->wfd_tdls_enable)
|
if (pwdinfo->wfd_tdls_enable)
|
||||||
{
|
{
|
||||||
/* TDLS mode + WSD (WFD Service Discovery) */
|
/* TDLS mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -769,12 +774,12 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
if (pwdinfo->wfd_tdls_enable)
|
if (pwdinfo->wfd_tdls_enable)
|
||||||
{
|
{
|
||||||
/* available for WFD session + TDLS mode + WSD (WFD Service Discovery) */
|
/* available for WFD session + TDLS mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT, wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -783,13 +788,22 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
if (pwdinfo->wfd_tdls_enable)
|
if (pwdinfo->wfd_tdls_enable)
|
||||||
{
|
{
|
||||||
/* available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
|
WFD_DEVINFO_WSD |
|
||||||
|
WFD_DEVINFO_PC_TDLS |
|
||||||
|
WFD_DEVINFO_HDCP_SUPPORT,
|
||||||
|
wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
||||||
/* available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
|
WFD_DEVINFO_WSD |
|
||||||
|
WFD_DEVINFO_HDCP_SUPPORT,
|
||||||
|
wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -797,11 +811,18 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
{
|
{
|
||||||
if (pwdinfo->wfd_tdls_enable)
|
if (pwdinfo->wfd_tdls_enable)
|
||||||
{
|
{
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD |WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_WSD |
|
||||||
|
WFD_DEVINFO_PC_TDLS |
|
||||||
|
WFD_DEVINFO_HDCP_SUPPORT,
|
||||||
|
wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_WSD |
|
||||||
|
WFD_DEVINFO_HDCP_SUPPORT,
|
||||||
|
wfdie + wfdielen);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -811,13 +832,13 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -826,7 +847,7 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -848,7 +869,7 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -871,7 +892,7 @@ u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunnel
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
|
put_unaligned_be16(0x0000, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Todo: to add the list of WFD device info descriptor in WFD group. */
|
/* Todo: to add the list of WFD device info descriptor in WFD group. */
|
||||||
@ -919,25 +940,27 @@ u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
|
WFD_DEVINFO_WSD, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -946,7 +969,7 @@ u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -968,7 +991,7 @@ u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1015,25 +1038,27 @@ u32 build_assoc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL |
|
||||||
|
WFD_DEVINFO_WSD, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1042,7 +1067,7 @@ u32 build_assoc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1064,7 +1089,7 @@ u32 build_assoc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1111,25 +1136,27 @@ u32 build_nego_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) + WFD Session Available */
|
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) + WFD Session Available */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL,
|
||||||
|
wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1138,7 +1165,7 @@ u32 build_nego_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1160,7 +1187,7 @@ u32 build_nego_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1207,25 +1234,27 @@ u32 build_nego_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) + WFD Session Available */
|
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) + WFD Session Available */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL,
|
||||||
|
wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1234,7 +1263,7 @@ u32 build_nego_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1256,7 +1285,7 @@ u32 build_nego_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1303,25 +1332,26 @@ u32 build_nego_confirm_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) + WFD Session Available */
|
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) + WFD Session Available */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL);
|
put_unaligned_be16(pwfd_info->wfd_device_type | WFD_DEVINFO_WSD |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1330,7 +1360,7 @@ u32 build_nego_confirm_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1352,7 +1382,7 @@ u32 build_nego_confirm_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1399,25 +1429,27 @@ u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD,
|
||||||
|
wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1426,7 +1458,7 @@ u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1448,7 +1480,7 @@ u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1471,7 +1503,7 @@ u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
|
put_unaligned_be16(0x0000, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Todo: to add the list of WFD device info descriptor in WFD group. */
|
/* Todo: to add the list of WFD device info descriptor in WFD group. */
|
||||||
@ -1510,25 +1542,27 @@ u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD,
|
||||||
|
wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1537,7 +1571,7 @@ u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1559,7 +1593,7 @@ u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1582,7 +1616,7 @@ u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
|
put_unaligned_be16(0x0000, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Todo: to add the list of WFD device info descriptor in WFD group. */
|
/* Todo: to add the list of WFD device info descriptor in WFD group. */
|
||||||
@ -1621,25 +1655,27 @@ u32 build_provdisc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD,
|
||||||
|
wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1648,7 +1684,7 @@ u32 build_provdisc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1670,7 +1706,7 @@ u32 build_provdisc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1717,25 +1753,27 @@ u32 build_provdisc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value1: */
|
/* Value1: */
|
||||||
/* WFD device information */
|
/* WFD device information */
|
||||||
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD);
|
put_unaligned_be16(pwfd_info->wfd_device_type |
|
||||||
|
WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD,
|
||||||
|
wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value2: */
|
/* Value2: */
|
||||||
/* Session Management Control Port */
|
/* Session Management Control Port */
|
||||||
/* Default TCP port for RTSP messages is 554 */
|
/* Default TCP port for RTSP messages is 554 */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
|
put_unaligned_be16(pwfd_info->rtsp_ctrlport, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value3: */
|
/* Value3: */
|
||||||
/* WFD Device Maximum Throughput */
|
/* WFD Device Maximum Throughput */
|
||||||
/* 300Mbps is the maximum throughput */
|
/* 300Mbps is the maximum throughput */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 300);
|
put_unaligned_be16(300, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Associated BSSID ATTR */
|
/* Associated BSSID ATTR */
|
||||||
@ -1744,7 +1782,7 @@ u32 build_provdisc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
|
put_unaligned_be16(0x0006, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1766,7 +1804,7 @@ u32 build_provdisc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* Note: In the WFD specification, the size of length field is 2. */
|
/* Note: In the WFD specification, the size of length field is 2. */
|
||||||
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
|
put_unaligned_be16(0x0007, wfdie + wfdielen);
|
||||||
wfdielen += 2;
|
wfdielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1814,7 +1852,7 @@ u32 build_probe_resp_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0x0002); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0x0002); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, 0x0002);
|
put_unaligned_le16(0x0002, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1846,18 +1884,18 @@ u32 build_probe_resp_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0x0004); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0x0004); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, 0x0004);
|
put_unaligned_le16(0x0004, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
/* Availability Period */
|
/* Availability Period */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0xFFFF); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0xFFFF); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, 0xFFFF);
|
put_unaligned_le16(0xFFFF, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Availability Interval */
|
/* Availability Interval */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0xFFFF); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0xFFFF); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, 0xFFFF);
|
put_unaligned_le16(0xFFFF, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Notice of Absence ATTR */
|
/* Notice of Absence ATTR */
|
||||||
@ -1877,7 +1915,7 @@ u32 build_probe_resp_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
/* 21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
|
/* 21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
|
||||||
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
|
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, 21 + pwdinfo->device_name_len);
|
put_unaligned_le16(21 + pwdinfo->device_name_len, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1888,23 +1926,23 @@ u32 build_probe_resp_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
/* Config Method */
|
/* Config Method */
|
||||||
/* This field should be big endian. Noted by P2P specification. */
|
/* This field should be big endian. Noted by P2P specification. */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->supported_wps_cm);
|
put_unaligned_be16(pwdinfo->supported_wps_cm, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Primary Device Type */
|
/* Primary Device Type */
|
||||||
/* Category ID */
|
/* Category ID */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_CID_MULIT_MEDIA);
|
put_unaligned_be16(WPS_PDT_CID_MULIT_MEDIA, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* OUI */
|
/* OUI */
|
||||||
/* u32*) (p2pie + p2pielen) = cpu_to_be32(WPSOUI); */
|
/* u32*) (p2pie + p2pielen) = cpu_to_be32(WPSOUI); */
|
||||||
RTW_PUT_BE32(p2pie + p2pielen, WPSOUI);
|
put_unaligned_be32(WPSOUI, p2pie + p2pielen);
|
||||||
p2pielen += 4;
|
p2pielen += 4;
|
||||||
|
|
||||||
/* Sub Category ID */
|
/* Sub Category ID */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_SCID_MEDIA_SERVER);
|
put_unaligned_be16(WPS_PDT_SCID_MEDIA_SERVER, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Number of Secondary Device Types */
|
/* Number of Secondary Device Types */
|
||||||
@ -1913,12 +1951,12 @@ u32 build_probe_resp_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf)
|
|||||||
/* Device Name */
|
/* Device Name */
|
||||||
/* Type: */
|
/* Type: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_ATTR_DEVICE_NAME);
|
put_unaligned_be16(WPS_ATTR_DEVICE_NAME, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->device_name_len);
|
put_unaligned_be16(pwdinfo->device_name_len, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1963,7 +2001,7 @@ u32 build_prov_disc_request_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf,
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0x0002); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(0x0002); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, 0x0002);
|
put_unaligned_le16(0x0002, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1984,7 +2022,7 @@ u32 build_prov_disc_request_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf,
|
|||||||
/* 21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
|
/* 21 -> P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
|
||||||
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
|
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, 21 + pwdinfo->device_name_len);
|
put_unaligned_le16(21 + pwdinfo->device_name_len, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -1997,12 +2035,12 @@ u32 build_prov_disc_request_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf,
|
|||||||
if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC)
|
if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC)
|
||||||
{
|
{
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_PBC); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_PBC); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_CONFIG_METHOD_PBC);
|
put_unaligned_be16(WPS_CONFIG_METHOD_PBC, p2pie + p2pielen);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_DISPLAY); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_DISPLAY); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_CONFIG_METHOD_DISPLAY);
|
put_unaligned_be16(WPS_CONFIG_METHOD_DISPLAY, p2pie + p2pielen);
|
||||||
}
|
}
|
||||||
|
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
@ -2010,17 +2048,17 @@ u32 build_prov_disc_request_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf,
|
|||||||
/* Primary Device Type */
|
/* Primary Device Type */
|
||||||
/* Category ID */
|
/* Category ID */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_CID_MULIT_MEDIA);
|
put_unaligned_be16(WPS_PDT_CID_MULIT_MEDIA, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* OUI */
|
/* OUI */
|
||||||
/* u32*) (p2pie + p2pielen) = cpu_to_be32(WPSOUI); */
|
/* u32*) (p2pie + p2pielen) = cpu_to_be32(WPSOUI); */
|
||||||
RTW_PUT_BE32(p2pie + p2pielen, WPSOUI);
|
put_unaligned_be32(WPSOUI, p2pie + p2pielen);
|
||||||
p2pielen += 4;
|
p2pielen += 4;
|
||||||
|
|
||||||
/* Sub Category ID */
|
/* Sub Category ID */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_SCID_MEDIA_SERVER);
|
put_unaligned_be16(WPS_PDT_SCID_MEDIA_SERVER, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Number of Secondary Device Types */
|
/* Number of Secondary Device Types */
|
||||||
@ -2029,12 +2067,12 @@ u32 build_prov_disc_request_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf,
|
|||||||
/* Device Name */
|
/* Device Name */
|
||||||
/* Type: */
|
/* Type: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, WPS_ATTR_DEVICE_NAME);
|
put_unaligned_be16(WPS_ATTR_DEVICE_NAME, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len); */
|
||||||
RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->device_name_len);
|
put_unaligned_be16(pwdinfo->device_name_len, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -2052,7 +2090,7 @@ u32 build_prov_disc_request_p2p_ie23a(struct wifidirect_info *pwdinfo, u8 *pbuf,
|
|||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
/* u16*) (p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + ussidlen); */
|
/* u16*) (p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + ussidlen); */
|
||||||
RTW_PUT_LE16(p2pie + p2pielen, ETH_ALEN + ussidlen);
|
put_unaligned_le16(ETH_ALEN + ussidlen, p2pie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -2685,7 +2723,7 @@ u8 process_p2p_group_negotation_req23a(struct wifidirect_info *pwdinfo, u8 *pfra
|
|||||||
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
||||||
if (attr_contentlen)
|
if (attr_contentlen)
|
||||||
{
|
{
|
||||||
pwdinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
|
pwdinfo->wfd_info->peer_rtsp_ctrlport = get_unaligned_be16(attr_content + 2);
|
||||||
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2926,7 +2964,7 @@ u8 process_p2p_group_negotation_resp23a(struct wifidirect_info *pwdinfo, u8 *pfr
|
|||||||
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
||||||
if (attr_contentlen)
|
if (attr_contentlen)
|
||||||
{
|
{
|
||||||
pwdinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
|
pwdinfo->wfd_info->peer_rtsp_ctrlport = get_unaligned_be16(attr_content + 2);
|
||||||
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3859,7 +3897,7 @@ void init_wifidirect_info23a(struct rtw_adapter *padapter, enum P2P_ROLE role)
|
|||||||
|
|
||||||
rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
|
rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
|
||||||
|
|
||||||
pwdinfo->listen_dwell = (u8) ((rtw_get_current_time() % 3) + 1);
|
pwdinfo->listen_dwell = (u8) ((jiffies % 3) + 1);
|
||||||
/* DBG_8723A("[%s] listen_dwell time is %d00ms\n", __func__, pwdinfo->listen_dwell); */
|
/* DBG_8723A("[%s] listen_dwell time is %d00ms\n", __func__, pwdinfo->listen_dwell); */
|
||||||
|
|
||||||
memset(&pwdinfo->tx_prov_disc_info, 0x00, sizeof(struct tx_provdisc_req_info));
|
memset(&pwdinfo->tx_prov_disc_info, 0x00, sizeof(struct tx_provdisc_req_info));
|
||||||
|
@ -108,13 +108,11 @@ static bool rtw_pwr_unassociated_idle(struct rtw_adapter *adapter)
|
|||||||
struct rtw_adapter *buddy = adapter->pbuddy_adapter;
|
struct rtw_adapter *buddy = adapter->pbuddy_adapter;
|
||||||
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
|
||||||
struct xmit_priv *pxmit_priv = &adapter->xmitpriv;
|
struct xmit_priv *pxmit_priv = &adapter->xmitpriv;
|
||||||
#ifdef CONFIG_8723AU_P2P
|
|
||||||
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
|
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
|
||||||
#endif
|
|
||||||
|
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
|
|
||||||
if (adapter->pwrctrlpriv.ips_deny_time >= rtw_get_current_time())
|
if (time_after_eq(adapter->pwrctrlpriv.ips_deny_time, jiffies))
|
||||||
goto exit;
|
goto exit;
|
||||||
|
|
||||||
if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE|WIFI_SITE_MONITOR)
|
if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE|WIFI_SITE_MONITOR)
|
||||||
@ -129,9 +127,7 @@ static bool rtw_pwr_unassociated_idle(struct rtw_adapter *adapter)
|
|||||||
/* consider buddy, if exist */
|
/* consider buddy, if exist */
|
||||||
if (buddy) {
|
if (buddy) {
|
||||||
struct mlme_priv *b_pmlmepriv = &buddy->mlmepriv;
|
struct mlme_priv *b_pmlmepriv = &buddy->mlmepriv;
|
||||||
#ifdef CONFIG_8723AU_P2P
|
|
||||||
struct wifidirect_info *b_pwdinfo = &buddy->wdinfo;
|
struct wifidirect_info *b_pwdinfo = &buddy->wdinfo;
|
||||||
#endif
|
|
||||||
|
|
||||||
if (check_fwstate(b_pmlmepriv, WIFI_ASOC_STATE|WIFI_SITE_MONITOR)
|
if (check_fwstate(b_pmlmepriv, WIFI_ASOC_STATE|WIFI_SITE_MONITOR)
|
||||||
|| check_fwstate(b_pmlmepriv, WIFI_UNDER_LINKING|WIFI_UNDER_WPS)
|
|| check_fwstate(b_pmlmepriv, WIFI_UNDER_LINKING|WIFI_UNDER_WPS)
|
||||||
@ -386,11 +382,13 @@ void rtw_set_ps_mode23a(struct rtw_adapter *padapter, u8 ps_mode, u8 smart_ps, u
|
|||||||
*/
|
*/
|
||||||
s32 LPS_RF_ON_check23a(struct rtw_adapter *padapter, u32 delay_ms)
|
s32 LPS_RF_ON_check23a(struct rtw_adapter *padapter, u32 delay_ms)
|
||||||
{
|
{
|
||||||
u32 start_time;
|
unsigned long start_time, end_time;
|
||||||
u8 bAwake = false;
|
u8 bAwake = false;
|
||||||
s32 err = 0;
|
s32 err = 0;
|
||||||
|
|
||||||
start_time = rtw_get_current_time();
|
start_time = jiffies;
|
||||||
|
end_time = start_time + msecs_to_jiffies(delay_ms);
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
rtw23a_hal_get_hwreg(padapter, HW_VAR_FWLPS_RF_ON, &bAwake);
|
rtw23a_hal_get_hwreg(padapter, HW_VAR_FWLPS_RF_ON, &bAwake);
|
||||||
@ -404,8 +402,7 @@ s32 LPS_RF_ON_check23a(struct rtw_adapter *padapter, u32 delay_ms)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rtw_get_passing_time_ms23a(start_time) > delay_ms)
|
if (time_after(jiffies, end_time)) {
|
||||||
{
|
|
||||||
err = -1;
|
err = -1;
|
||||||
DBG_8723A("%s: Wait for FW LPS leave more than %u ms!!!\n", __func__, delay_ms);
|
DBG_8723A("%s: Wait for FW LPS leave more than %u ms!!!\n", __func__, delay_ms);
|
||||||
break;
|
break;
|
||||||
@ -539,7 +536,7 @@ u8 rtw_interface_ps_func23a(struct rtw_adapter *padapter, enum hal_intf_ps_func
|
|||||||
inline void rtw_set_ips_deny23a(struct rtw_adapter *padapter, u32 ms)
|
inline void rtw_set_ips_deny23a(struct rtw_adapter *padapter, u32 ms)
|
||||||
{
|
{
|
||||||
struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
|
struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
|
||||||
pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime23a(ms);
|
pwrpriv->ips_deny_time = jiffies + msecs_to_jiffies(ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -554,14 +551,18 @@ int _rtw_pwr_wakeup23a(struct rtw_adapter *padapter, u32 ips_deffer_ms, const ch
|
|||||||
struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
|
struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
|
||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
int ret = _SUCCESS;
|
int ret = _SUCCESS;
|
||||||
u32 start = rtw_get_current_time();
|
unsigned long start = jiffies;
|
||||||
|
unsigned long new_deny_time;
|
||||||
|
|
||||||
if (pwrpriv->ips_deny_time < rtw_get_current_time() + rtw_ms_to_systime23a(ips_deffer_ms))
|
new_deny_time = jiffies + msecs_to_jiffies(ips_deffer_ms);
|
||||||
pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime23a(ips_deffer_ms);
|
|
||||||
|
if (time_before(pwrpriv->ips_deny_time, new_deny_time))
|
||||||
|
pwrpriv->ips_deny_time = new_deny_time;
|
||||||
|
|
||||||
if (pwrpriv->ps_processing) {
|
if (pwrpriv->ps_processing) {
|
||||||
DBG_8723A("%s wait ps_processing...\n", __func__);
|
DBG_8723A("%s wait ps_processing...\n", __func__);
|
||||||
while (pwrpriv->ps_processing && rtw_get_passing_time_ms23a(start) <= 3000)
|
while (pwrpriv->ps_processing &&
|
||||||
|
jiffies_to_msecs(jiffies - start) <= 3000)
|
||||||
msleep(10);
|
msleep(10);
|
||||||
if (pwrpriv->ps_processing)
|
if (pwrpriv->ps_processing)
|
||||||
DBG_8723A("%s wait ps_processing timeout\n", __func__);
|
DBG_8723A("%s wait ps_processing timeout\n", __func__);
|
||||||
@ -571,7 +572,8 @@ int _rtw_pwr_wakeup23a(struct rtw_adapter *padapter, u32 ips_deffer_ms, const ch
|
|||||||
|
|
||||||
if (rtw_hal_sreset_inprogress(padapter)) {
|
if (rtw_hal_sreset_inprogress(padapter)) {
|
||||||
DBG_8723A("%s wait sreset_inprogress...\n", __func__);
|
DBG_8723A("%s wait sreset_inprogress...\n", __func__);
|
||||||
while (rtw_hal_sreset_inprogress(padapter) && rtw_get_passing_time_ms23a(start) <= 4000)
|
while (rtw_hal_sreset_inprogress(padapter) &&
|
||||||
|
jiffies_to_msecs(jiffies - start) <= 4000)
|
||||||
msleep(10);
|
msleep(10);
|
||||||
if (rtw_hal_sreset_inprogress(padapter))
|
if (rtw_hal_sreset_inprogress(padapter))
|
||||||
DBG_8723A("%s wait sreset_inprogress timeout\n", __func__);
|
DBG_8723A("%s wait sreset_inprogress timeout\n", __func__);
|
||||||
@ -582,7 +584,7 @@ int _rtw_pwr_wakeup23a(struct rtw_adapter *padapter, u32 ips_deffer_ms, const ch
|
|||||||
if (pwrpriv->bInternalAutoSuspend == false && pwrpriv->bInSuspend) {
|
if (pwrpriv->bInternalAutoSuspend == false && pwrpriv->bInSuspend) {
|
||||||
DBG_8723A("%s wait bInSuspend...\n", __func__);
|
DBG_8723A("%s wait bInSuspend...\n", __func__);
|
||||||
while (pwrpriv->bInSuspend &&
|
while (pwrpriv->bInSuspend &&
|
||||||
(rtw_get_passing_time_ms23a(start) <= 3000)) {
|
(jiffies_to_msecs(jiffies - start) <= 3000)) {
|
||||||
msleep(10);
|
msleep(10);
|
||||||
}
|
}
|
||||||
if (pwrpriv->bInSuspend)
|
if (pwrpriv->bInSuspend)
|
||||||
@ -630,8 +632,9 @@ int _rtw_pwr_wakeup23a(struct rtw_adapter *padapter, u32 ips_deffer_ms, const ch
|
|||||||
}
|
}
|
||||||
|
|
||||||
exit:
|
exit:
|
||||||
if (pwrpriv->ips_deny_time < rtw_get_current_time() + rtw_ms_to_systime23a(ips_deffer_ms))
|
new_deny_time = jiffies + msecs_to_jiffies(ips_deffer_ms);
|
||||||
pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime23a(ips_deffer_ms);
|
if (time_before(pwrpriv->ips_deny_time, new_deny_time))
|
||||||
|
pwrpriv->ips_deny_time = new_deny_time;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,7 +202,7 @@ void rtw_wep_encrypt23a(struct rtw_adapter *padapter,
|
|||||||
arcfour_encrypt(&mycontext, payload + length, crc, 4);
|
arcfour_encrypt(&mycontext, payload + length, crc, 4);
|
||||||
|
|
||||||
pframe += pxmitpriv->frag_len;
|
pframe += pxmitpriv->frag_len;
|
||||||
pframe = (u8 *)RND4((unsigned long)(pframe));
|
pframe = PTR_ALIGN(pframe, 4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -225,7 +225,7 @@ void rtw_wep_decrypt23a(struct rtw_adapter *padapter,
|
|||||||
pframe = skb->data;
|
pframe = skb->data;
|
||||||
|
|
||||||
/* start to decrypt recvframe */
|
/* start to decrypt recvframe */
|
||||||
if ((prxattrib->encrypt =! _WEP40_) && (prxattrib->encrypt != _WEP104_))
|
if ((prxattrib->encrypt != _WEP40_) && (prxattrib->encrypt != _WEP104_))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
iv = pframe + prxattrib->hdrlen;
|
iv = pframe + prxattrib->hdrlen;
|
||||||
@ -699,8 +699,7 @@ u32 rtw_tkip_encrypt23a(struct rtw_adapter *padapter,
|
|||||||
arcfour_encrypt(&mycontext, payload+length, crc, 4);
|
arcfour_encrypt(&mycontext, payload+length, crc, 4);
|
||||||
|
|
||||||
pframe+= pxmitpriv->frag_len;
|
pframe+= pxmitpriv->frag_len;
|
||||||
pframe = (u8 *)RND4((unsigned long)(pframe));
|
pframe = PTR_ALIGN(pframe, 4);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1371,7 +1370,7 @@ u32 rtw_aes_encrypt23a(struct rtw_adapter *padapter, struct xmit_frame *pxmitfra
|
|||||||
|
|
||||||
aes_cipher(prwskey, pattrib->hdrlen, pframe, length);
|
aes_cipher(prwskey, pattrib->hdrlen, pframe, length);
|
||||||
pframe += pxmitpriv->frag_len;
|
pframe += pxmitpriv->frag_len;
|
||||||
pframe = (u8*)RND4((unsigned long)pframe);
|
pframe = PTR_ALIGN(pframe, 4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
out:
|
out:
|
||||||
@ -1599,7 +1598,7 @@ u32 rtw_aes_decrypt23a(struct rtw_adapter *padapter, struct recv_frame *precvfra
|
|||||||
|
|
||||||
pframe = skb->data;
|
pframe = skb->data;
|
||||||
/* 4 start to encrypt each fragment */
|
/* 4 start to encrypt each fragment */
|
||||||
if (!prxattrib->encrypt != _AES_)
|
if (prxattrib->encrypt != _AES_)
|
||||||
return _FAIL;
|
return _FAIL;
|
||||||
|
|
||||||
stainfo = rtw_get_stainfo23a(&padapter->stapriv, &prxattrib->ta[0]);
|
stainfo = rtw_get_stainfo23a(&padapter->stapriv, &prxattrib->ta[0]);
|
||||||
|
@ -165,9 +165,11 @@ static void sreset_restore_network_status(struct rtw_adapter *padapter)
|
|||||||
if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
|
if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
|
||||||
DBG_8723A(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
DBG_8723A(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
||||||
sreset_restore_network_station(padapter);
|
sreset_restore_network_station(padapter);
|
||||||
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
} else if (check_fwstate(mlmepriv, WIFI_AP_STATE)) {
|
} else if (check_fwstate(mlmepriv, WIFI_AP_STATE)) {
|
||||||
DBG_8723A(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_AP_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
DBG_8723A(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_AP_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
||||||
rtw_ap_restore_network(padapter);
|
rtw_ap_restore_network(padapter);
|
||||||
|
#endif
|
||||||
} else if (check_fwstate(mlmepriv, WIFI_ADHOC_STATE)) {
|
} else if (check_fwstate(mlmepriv, WIFI_ADHOC_STATE)) {
|
||||||
DBG_8723A(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
DBG_8723A(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
|
||||||
} else {
|
} else {
|
||||||
|
@ -581,7 +581,7 @@ int WFD_info_handler(struct rtw_adapter *padapter, struct ndis_802_11_var_ies *
|
|||||||
DBG_8723A("[%s] Found WFD IE\n", __func__);
|
DBG_8723A("[%s] Found WFD IE\n", __func__);
|
||||||
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, attr_content, &attr_contentlen);
|
||||||
if (attr_contentlen) {
|
if (attr_contentlen) {
|
||||||
pwdinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
|
pwdinfo->wfd_info->peer_rtsp_ctrlport = get_unaligned_be16(attr_content + 2);
|
||||||
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
DBG_8723A("[%s] Peer PORT NUM = %d\n", __func__, pwdinfo->wfd_info->peer_rtsp_ctrlport);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -785,7 +785,7 @@ static s32 xmitframe_addmic(struct rtw_adapter *padapter,
|
|||||||
|
|
||||||
for (curfragnum = 0; curfragnum < pattrib->nr_frags;
|
for (curfragnum = 0; curfragnum < pattrib->nr_frags;
|
||||||
curfragnum++) {
|
curfragnum++) {
|
||||||
payload = (u8 *)RND4((unsigned long)payload);
|
payload = PTR_ALIGN(payload, 4);
|
||||||
RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
|
RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
|
||||||
("=== curfragnum =%d, pframe = 0x%.2x, "
|
("=== curfragnum =%d, pframe = 0x%.2x, "
|
||||||
"0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x, 0x"
|
"0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x, 0x"
|
||||||
@ -1124,7 +1124,6 @@ s32 rtw_xmitframe_coalesce23a(struct rtw_adapter *padapter, struct sk_buff *pkt,
|
|||||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||||
struct pkt_attrib *pattrib = &pxmitframe->attrib;
|
struct pkt_attrib *pattrib = &pxmitframe->attrib;
|
||||||
s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
|
s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
|
||||||
unsigned long addr;
|
|
||||||
u8 *pframe, *mem_start;
|
u8 *pframe, *mem_start;
|
||||||
u8 hw_hdr_offset;
|
u8 hw_hdr_offset;
|
||||||
u8 *pbuf_start;
|
u8 *pbuf_start;
|
||||||
@ -1261,9 +1260,7 @@ s32 rtw_xmitframe_coalesce23a(struct rtw_adapter *padapter, struct sk_buff *pkt,
|
|||||||
RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("%s: There're still something in packet!\n", __func__));
|
RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_, ("%s: There're still something in packet!\n", __func__));
|
||||||
}
|
}
|
||||||
|
|
||||||
addr = (unsigned long)pframe;
|
mem_start = PTR_ALIGN(pframe, 4) + hw_hdr_offset;
|
||||||
|
|
||||||
mem_start = (unsigned char *)RND4(addr) + hw_hdr_offset;
|
|
||||||
memcpy(mem_start, pbuf_start + hw_hdr_offset, pattrib->hdrlen);
|
memcpy(mem_start, pbuf_start + hw_hdr_offset, pattrib->hdrlen);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -259,7 +259,9 @@ void rtw_hal_update_ra_mask23a(struct sta_info *psta, u8 rssi_level)
|
|||||||
pmlmepriv = &padapter->mlmepriv;
|
pmlmepriv = &padapter->mlmepriv;
|
||||||
|
|
||||||
if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
|
if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
|
||||||
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
add_RATid23a(padapter, psta, rssi_level);
|
add_RATid23a(padapter, psta, rssi_level);
|
||||||
|
#endif
|
||||||
} else {
|
} else {
|
||||||
if (padapter->HalFunc.UpdateRAMaskHandler)
|
if (padapter->HalFunc.UpdateRAMaskHandler)
|
||||||
padapter->HalFunc.UpdateRAMaskHandler(padapter, psta->mac_id, rssi_level);
|
padapter->HalFunc.UpdateRAMaskHandler(padapter, psta->mac_id, rssi_level);
|
||||||
|
@ -4620,11 +4620,11 @@ bthci_StateConnected(struct rtw_adapter *padapter,
|
|||||||
/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
|
/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
|
||||||
struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
|
struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
|
||||||
struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
|
struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
|
||||||
|
u8 i;
|
||||||
|
u16 logicHandle = 0;
|
||||||
|
|
||||||
RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Connected], "));
|
RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Connected], "));
|
||||||
switch (StateCmd) {
|
switch (StateCmd) {
|
||||||
u8 i;
|
|
||||||
u16 logicHandle = 0;
|
|
||||||
case STATE_CMD_DISCONNECT_PHY_LINK:
|
case STATE_CMD_DISCONNECT_PHY_LINK:
|
||||||
RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
|
RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
|
||||||
|
|
||||||
@ -7076,17 +7076,17 @@ static void btdm_2AntBtInquiryPage(struct rtw_adapter *padapter)
|
|||||||
static u8 btdm_HoldForBtInqPage(struct rtw_adapter *padapter)
|
static u8 btdm_HoldForBtInqPage(struct rtw_adapter *padapter)
|
||||||
{
|
{
|
||||||
struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
|
struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
|
||||||
u32 curTime = rtw_get_current_time();
|
u32 curTime = jiffies;
|
||||||
|
|
||||||
if (pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage) {
|
if (pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage) {
|
||||||
/* bt inquiry or page is started. */
|
/* bt inquiry or page is started. */
|
||||||
if (pHalData->bt_coexist.halCoex8723.btInqPageStartTime == 0) {
|
if (pHalData->bt_coexist.halCoex8723.btInqPageStartTime == 0) {
|
||||||
pHalData->bt_coexist.halCoex8723.btInqPageStartTime = curTime;
|
pHalData->bt_coexist.halCoex8723.btInqPageStartTime = curTime;
|
||||||
RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Inquiry/page is started at time : 0x%"i64fmt"x \n",
|
RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Inquiry/page is started at time : 0x%lx \n",
|
||||||
pHalData->bt_coexist.halCoex8723.btInqPageStartTime));
|
pHalData->bt_coexist.halCoex8723.btInqPageStartTime));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Inquiry/page started time : 0x%"i64fmt"x, curTime : 0x%x \n",
|
RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Inquiry/page started time : 0x%lx, curTime : 0x%x \n",
|
||||||
pHalData->bt_coexist.halCoex8723.btInqPageStartTime, curTime));
|
pHalData->bt_coexist.halCoex8723.btInqPageStartTime, curTime));
|
||||||
|
|
||||||
if (pHalData->bt_coexist.halCoex8723.btInqPageStartTime) {
|
if (pHalData->bt_coexist.halCoex8723.btInqPageStartTime) {
|
||||||
|
@ -388,7 +388,7 @@ s32 rtl8723a_FirmwareDownload(struct rtw_adapter *padapter)
|
|||||||
rtStatus = _WriteFW(padapter, buf, fw_size);
|
rtStatus = _WriteFW(padapter, buf, fw_size);
|
||||||
|
|
||||||
if (rtStatus == _SUCCESS ||
|
if (rtStatus == _SUCCESS ||
|
||||||
(rtw_get_passing_time_ms23a(fwdl_start_time) > 500 &&
|
(jiffies_to_msecs(jiffies - fwdl_start_time) > 500 &&
|
||||||
writeFW_retry++ >= 3))
|
writeFW_retry++ >= 3))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -366,7 +366,7 @@ static s32 rtw_dump_xframe(struct rtw_adapter *padapter, struct xmit_frame *pxmi
|
|||||||
|
|
||||||
mem_addr += w_sz;
|
mem_addr += w_sz;
|
||||||
|
|
||||||
mem_addr = (u8 *)RND4(((unsigned long)(mem_addr)));
|
mem_addr = PTR_ALIGN(mem_addr, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
|
rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
|
||||||
|
@ -65,8 +65,6 @@ enum RF_RADIO_PATH {
|
|||||||
RF_PATH_MAX /* Max RF number 90 support */
|
RF_PATH_MAX /* Max RF number 90 support */
|
||||||
};
|
};
|
||||||
|
|
||||||
#define RF_PATH_MAX 3
|
|
||||||
|
|
||||||
#define CHANNEL_MAX_NUMBER 14 /* 14 is the max channel number */
|
#define CHANNEL_MAX_NUMBER 14 /* 14 is the max channel number */
|
||||||
#define CHANNEL_GROUP_MAX 3 /* ch1~3, ch4~9, ch10~14 total three groups */
|
#define CHANNEL_GROUP_MAX 3 /* ch1~3, ch4~9, ch10~14 total three groups */
|
||||||
|
|
||||||
|
@ -258,13 +258,9 @@ struct rtw_adapter {
|
|||||||
struct hostapd_priv *phostapdpriv;
|
struct hostapd_priv *phostapdpriv;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_P2P
|
|
||||||
struct cfg80211_wifidirect_info cfg80211_wdinfo;
|
struct cfg80211_wifidirect_info cfg80211_wdinfo;
|
||||||
#endif /* CONFIG_8723AU_P2P */
|
|
||||||
u32 setband;
|
u32 setband;
|
||||||
#ifdef CONFIG_8723AU_P2P
|
|
||||||
struct wifidirect_info wdinfo;
|
struct wifidirect_info wdinfo;
|
||||||
#endif /* CONFIG_8723AU_P2P */
|
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_P2P
|
#ifdef CONFIG_8723AU_P2P
|
||||||
struct wifi_display_info wfd_info;
|
struct wifi_display_info wfd_info;
|
||||||
|
@ -265,35 +265,30 @@ struct odm_rate_adapt {
|
|||||||
#define DM_Type_ByFW 0
|
#define DM_Type_ByFW 0
|
||||||
#define DM_Type_ByDriver 1
|
#define DM_Type_ByDriver 1
|
||||||
|
|
||||||
/* */
|
|
||||||
/* Declare for common info */
|
/* Declare for common info */
|
||||||
/* */
|
|
||||||
/* Declare for common info */
|
|
||||||
/* */
|
|
||||||
#define MAX_PATH_NUM_92CS 2
|
|
||||||
|
|
||||||
struct odm_phy_info {
|
struct odm_phy_info {
|
||||||
u8 RxPWDBAll;
|
u8 RxPWDBAll;
|
||||||
u8 SignalQuality; /* in 0-100 index. */
|
u8 SignalQuality; /* in 0-100 index. */
|
||||||
u8 RxMIMOSignalQuality[MAX_PATH_NUM_92CS]; /* EVM */
|
u8 RxMIMOSignalQuality[RF_PATH_MAX]; /* EVM */
|
||||||
u8 RxMIMOSignalStrength[MAX_PATH_NUM_92CS];/* in 0~100 index */
|
u8 RxMIMOSignalStrength[RF_PATH_MAX];/* in 0~100 index */
|
||||||
s8 RxPower; /* in dBm Translate from PWdB */
|
s8 RxPower; /* in dBm Translate from PWdB */
|
||||||
s8 RecvSignalPower;/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. */
|
s8 RecvSignalPower;/* Real power in dBm for this packet, no beautification and aggregation. Keep this raw info to be used for the other procedures. */
|
||||||
u8 BTRxRSSIPercentage;
|
u8 BTRxRSSIPercentage;
|
||||||
u8 SignalStrength; /* in 0-100 index. */
|
u8 SignalStrength; /* in 0-100 index. */
|
||||||
u8 RxPwr[MAX_PATH_NUM_92CS];/* per-path's pwdb */
|
u8 RxPwr[RF_PATH_MAX];/* per-path's pwdb */
|
||||||
u8 RxSNR[MAX_PATH_NUM_92CS];/* per-path's SNR */
|
u8 RxSNR[RF_PATH_MAX];/* per-path's SNR */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
struct odm_phy_dbg_info {
|
struct odm_phy_dbg_info {
|
||||||
/* ODM Write,debug info */
|
/* ODM Write,debug info */
|
||||||
s8 RxSNRdB[MAX_PATH_NUM_92CS];
|
s8 RxSNRdB[RF_PATH_MAX];
|
||||||
u64 NumQryPhyStatus;
|
u64 NumQryPhyStatus;
|
||||||
u64 NumQryPhyStatusCCK;
|
u64 NumQryPhyStatusCCK;
|
||||||
u64 NumQryPhyStatusOFDM;
|
u64 NumQryPhyStatusOFDM;
|
||||||
/* Others */
|
/* Others */
|
||||||
s32 RxEVM[MAX_PATH_NUM_92CS];
|
s32 RxEVM[RF_PATH_MAX];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -74,21 +74,21 @@ struct phy_rx_agc_info {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct phy_status_rpt {
|
struct phy_status_rpt {
|
||||||
struct phy_rx_agc_info path_agc[2];
|
struct phy_rx_agc_info path_agc[RF_PATH_MAX];
|
||||||
u8 ch_corr[2];
|
u8 ch_corr[RF_PATH_MAX];
|
||||||
u8 cck_sig_qual_ofdm_pwdb_all;
|
u8 cck_sig_qual_ofdm_pwdb_all;
|
||||||
u8 cck_agc_rpt_ofdm_cfosho_a;
|
u8 cck_agc_rpt_ofdm_cfosho_a;
|
||||||
u8 cck_rpt_b_ofdm_cfosho_b;
|
u8 cck_rpt_b_ofdm_cfosho_b;
|
||||||
u8 rsvd_1;/* ch_corr_msb; */
|
u8 rsvd_1;/* ch_corr_msb; */
|
||||||
u8 noise_power_db_msb;
|
u8 noise_power_db_msb;
|
||||||
u8 path_cfotail[2];
|
u8 path_cfotail[RF_PATH_MAX];
|
||||||
u8 pcts_mask[2];
|
u8 pcts_mask[RF_PATH_MAX];
|
||||||
s8 stream_rxevm[2];
|
s8 stream_rxevm[RF_PATH_MAX];
|
||||||
u8 path_rxsnr[2];
|
u8 path_rxsnr[RF_PATH_MAX];
|
||||||
u8 noise_power_db_lsb;
|
u8 noise_power_db_lsb;
|
||||||
u8 rsvd_2[3];
|
u8 rsvd_2[3];
|
||||||
u8 stream_csi[2];
|
u8 stream_csi[RF_PATH_MAX];
|
||||||
u8 stream_target_csi[2];
|
u8 stream_target_csi[RF_PATH_MAX];
|
||||||
s8 sig_evm;
|
s8 sig_evm;
|
||||||
u8 rsvd_3;
|
u8 rsvd_3;
|
||||||
|
|
||||||
|
@ -149,70 +149,6 @@ extern unsigned char MCS_rate_1R23A[16];
|
|||||||
void _rtw_init_queue23a(struct rtw_queue *pqueue);
|
void _rtw_init_queue23a(struct rtw_queue *pqueue);
|
||||||
u32 _rtw_queue_empty23a(struct rtw_queue *pqueue);
|
u32 _rtw_queue_empty23a(struct rtw_queue *pqueue);
|
||||||
|
|
||||||
u32 rtw_get_current_time(void);
|
|
||||||
u32 rtw_systime_to_ms23a(u32 systime);
|
|
||||||
u32 rtw_ms_to_systime23a(u32 ms);
|
|
||||||
s32 rtw_get_passing_time_ms23a(u32 start);
|
|
||||||
s32 rtw_get_time_interval_ms23a(u32 start, u32 end);
|
|
||||||
|
|
||||||
#define _RND(sz, r) ((((sz)+((r)-1))/(r))*(r))
|
|
||||||
#define RND4(x) (((x >> 2) + (((x & 3) == 0) ? 0: 1)) << 2)
|
|
||||||
|
|
||||||
static inline u32 _RND4(u32 sz)
|
|
||||||
{
|
|
||||||
|
|
||||||
u32 val;
|
|
||||||
|
|
||||||
val = ((sz >> 2) + ((sz & 3) ? 1: 0)) << 2;
|
|
||||||
|
|
||||||
return val;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u32 _RND8(u32 sz)
|
|
||||||
{
|
|
||||||
|
|
||||||
u32 val;
|
|
||||||
|
|
||||||
val = ((sz >> 3) + ((sz & 7) ? 1: 0)) << 3;
|
|
||||||
|
|
||||||
return val;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u32 _RND128(u32 sz)
|
|
||||||
{
|
|
||||||
|
|
||||||
u32 val;
|
|
||||||
|
|
||||||
val = ((sz >> 7) + ((sz & 127) ? 1: 0)) << 7;
|
|
||||||
|
|
||||||
return val;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u32 _RND256(u32 sz)
|
|
||||||
{
|
|
||||||
|
|
||||||
u32 val;
|
|
||||||
|
|
||||||
val = ((sz >> 8) + ((sz & 255) ? 1: 0)) << 8;
|
|
||||||
|
|
||||||
return val;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u32 _RND512(u32 sz)
|
|
||||||
{
|
|
||||||
|
|
||||||
u32 val;
|
|
||||||
|
|
||||||
val = ((sz >> 9) + ((sz & 511) ? 1: 0)) << 9;
|
|
||||||
|
|
||||||
return val;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u32 bitshift(u32 bitmask)
|
static inline u32 bitshift(u32 bitmask)
|
||||||
{
|
{
|
||||||
u32 i;
|
u32 i;
|
||||||
@ -223,20 +159,11 @@ static inline u32 bitshift(u32 bitmask)
|
|||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define STRUCT_PACKED __attribute__ ((packed))
|
|
||||||
|
|
||||||
/* limitation of path length */
|
|
||||||
#define PATH_LENGTH_MAX PATH_MAX
|
|
||||||
|
|
||||||
void rtw_suspend_lock_init(void);
|
void rtw_suspend_lock_init(void);
|
||||||
void rtw_suspend_lock_uninit(void);
|
void rtw_suspend_lock_uninit(void);
|
||||||
void rtw_lock_suspend(void);
|
void rtw_lock_suspend(void);
|
||||||
void rtw_unlock_suspend(void);
|
void rtw_unlock_suspend(void);
|
||||||
|
|
||||||
/* File operation APIs, just for linux now */
|
|
||||||
int rtw_is_file_readable(char *path);
|
|
||||||
int rtw_retrive_from_file(char *path, u8* buf, u32 sz);
|
|
||||||
int rtw_store_to_file(char *path, u8* buf, u32 sz);
|
|
||||||
|
|
||||||
#define NDEV_FMT "%s"
|
#define NDEV_FMT "%s"
|
||||||
#define NDEV_ARG(ndev) ndev->name
|
#define NDEV_ARG(ndev) ndev->name
|
||||||
@ -255,69 +182,9 @@ u64 rtw_division6423a(u64 x, u64 y);
|
|||||||
|
|
||||||
/* Macros for handling unaligned memory accesses */
|
/* Macros for handling unaligned memory accesses */
|
||||||
|
|
||||||
#define RTW_GET_BE16(a) ((u16) (((a)[0] << 8) | (a)[1]))
|
|
||||||
#define RTW_PUT_BE16(a, val) \
|
|
||||||
do { \
|
|
||||||
(a)[0] = ((u16) (val)) >> 8; \
|
|
||||||
(a)[1] = ((u16) (val)) & 0xff; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define RTW_GET_LE16(a) ((u16) (((a)[1] << 8) | (a)[0]))
|
|
||||||
#define RTW_PUT_LE16(a, val) \
|
|
||||||
do { \
|
|
||||||
(a)[1] = ((u16) (val)) >> 8; \
|
|
||||||
(a)[0] = ((u16) (val)) & 0xff; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define RTW_GET_BE24(a) ((((u32) (a)[0]) << 16) | (((u32) (a)[1]) << 8) | \
|
#define RTW_GET_BE24(a) ((((u32) (a)[0]) << 16) | (((u32) (a)[1]) << 8) | \
|
||||||
((u32) (a)[2]))
|
((u32) (a)[2]))
|
||||||
#define RTW_PUT_BE24(a, val) \
|
|
||||||
do { \
|
|
||||||
(a)[0] = (u8) ((((u32) (val)) >> 16) & 0xff); \
|
|
||||||
(a)[1] = (u8) ((((u32) (val)) >> 8) & 0xff); \
|
|
||||||
(a)[2] = (u8) (((u32) (val)) & 0xff); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define RTW_GET_BE32(a) ((((u32) (a)[0]) << 24) | (((u32) (a)[1]) << 16) | \
|
|
||||||
(((u32) (a)[2]) << 8) | ((u32) (a)[3]))
|
|
||||||
#define RTW_PUT_BE32(a, val) \
|
|
||||||
do { \
|
|
||||||
(a)[0] = (u8) ((((u32) (val)) >> 24) & 0xff); \
|
|
||||||
(a)[1] = (u8) ((((u32) (val)) >> 16) & 0xff); \
|
|
||||||
(a)[2] = (u8) ((((u32) (val)) >> 8) & 0xff); \
|
|
||||||
(a)[3] = (u8) (((u32) (val)) & 0xff); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define RTW_GET_LE32(a) ((((u32) (a)[3]) << 24) | (((u32) (a)[2]) << 16) | \
|
|
||||||
(((u32) (a)[1]) << 8) | ((u32) (a)[0]))
|
|
||||||
#define RTW_PUT_LE32(a, val) \
|
|
||||||
do { \
|
|
||||||
(a)[3] = (u8) ((((u32) (val)) >> 24) & 0xff); \
|
|
||||||
(a)[2] = (u8) ((((u32) (val)) >> 16) & 0xff); \
|
|
||||||
(a)[1] = (u8) ((((u32) (val)) >> 8) & 0xff); \
|
|
||||||
(a)[0] = (u8) (((u32) (val)) & 0xff); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define RTW_GET_BE64(a) ((((u64) (a)[0]) << 56) | (((u64) (a)[1]) << 48) | \
|
|
||||||
(((u64) (a)[2]) << 40) | (((u64) (a)[3]) << 32) | \
|
|
||||||
(((u64) (a)[4]) << 24) | (((u64) (a)[5]) << 16) | \
|
|
||||||
(((u64) (a)[6]) << 8) | ((u64) (a)[7]))
|
|
||||||
#define RTW_PUT_BE64(a, val) \
|
|
||||||
do { \
|
|
||||||
(a)[0] = (u8) (((u64) (val)) >> 56); \
|
|
||||||
(a)[1] = (u8) (((u64) (val)) >> 48); \
|
|
||||||
(a)[2] = (u8) (((u64) (val)) >> 40); \
|
|
||||||
(a)[3] = (u8) (((u64) (val)) >> 32); \
|
|
||||||
(a)[4] = (u8) (((u64) (val)) >> 24); \
|
|
||||||
(a)[5] = (u8) (((u64) (val)) >> 16); \
|
|
||||||
(a)[6] = (u8) (((u64) (val)) >> 8); \
|
|
||||||
(a)[7] = (u8) (((u64) (val)) & 0xff); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define RTW_GET_LE64(a) ((((u64) (a)[7]) << 56) | (((u64) (a)[6]) << 48) | \
|
|
||||||
(((u64) (a)[5]) << 40) | (((u64) (a)[4]) << 32) | \
|
|
||||||
(((u64) (a)[3]) << 24) | (((u64) (a)[2]) << 16) | \
|
|
||||||
(((u64) (a)[1]) << 8) | ((u64) (a)[0]))
|
|
||||||
|
|
||||||
struct rtw_cbuf {
|
struct rtw_cbuf {
|
||||||
u32 write;
|
u32 write;
|
||||||
|
@ -1074,7 +1074,7 @@ struct packet_irp_acl_data {
|
|||||||
struct packet_irp_hcievent_data {
|
struct packet_irp_hcievent_data {
|
||||||
u8 EventCode;
|
u8 EventCode;
|
||||||
u8 Length;
|
u8 Length;
|
||||||
u8 Data[5];
|
u8 Data[20];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct common_triple {
|
struct common_triple {
|
||||||
@ -1332,7 +1332,7 @@ struct bt_coexist_8723a {
|
|||||||
u8 c2hBtInfoOriginal;
|
u8 c2hBtInfoOriginal;
|
||||||
u8 prec2hBtInfo; /* for 1Ant */
|
u8 prec2hBtInfo; /* for 1Ant */
|
||||||
u8 bC2hBtInquiryPage;
|
u8 bC2hBtInquiryPage;
|
||||||
u64 btInqPageStartTime; /* for 2Ant */
|
unsigned long btInqPageStartTime; /* for 2Ant */
|
||||||
u8 c2hBtProfile; /* for 1Ant */
|
u8 c2hBtProfile; /* for 1Ant */
|
||||||
u8 btRetryCnt;
|
u8 btRetryCnt;
|
||||||
u8 btInfoExt;
|
u8 btInfoExt;
|
||||||
|
@ -15,9 +15,7 @@
|
|||||||
#ifndef __RTL8723A_PG_H__
|
#ifndef __RTL8723A_PG_H__
|
||||||
#define __RTL8723A_PG_H__
|
#define __RTL8723A_PG_H__
|
||||||
|
|
||||||
/* */
|
|
||||||
/* EEPROM/Efuse PG Offset for 8723E/8723U/8723S */
|
/* EEPROM/Efuse PG Offset for 8723E/8723U/8723S */
|
||||||
/* */
|
|
||||||
#define EEPROM_CCK_TX_PWR_INX_8723A 0x10
|
#define EEPROM_CCK_TX_PWR_INX_8723A 0x10
|
||||||
#define EEPROM_HT40_1S_TX_PWR_INX_8723A 0x16
|
#define EEPROM_HT40_1S_TX_PWR_INX_8723A 0x16
|
||||||
#define EEPROM_HT20_TX_PWR_INX_DIFF_8723A 0x1C
|
#define EEPROM_HT20_TX_PWR_INX_DIFF_8723A 0x1C
|
||||||
@ -53,31 +51,24 @@
|
|||||||
/* RTL8723AS */
|
/* RTL8723AS */
|
||||||
#define EEPROM_MAC_ADDR_8723AS 0xAA
|
#define EEPROM_MAC_ADDR_8723AS 0xAA
|
||||||
|
|
||||||
/* */
|
|
||||||
/* EEPROM/Efuse Value Type */
|
/* EEPROM/Efuse Value Type */
|
||||||
/* */
|
|
||||||
#define EETYPE_TX_PWR 0x0
|
#define EETYPE_TX_PWR 0x0
|
||||||
|
|
||||||
/* */
|
|
||||||
/* EEPROM/Efuse Default Value */
|
/* EEPROM/Efuse Default Value */
|
||||||
/* */
|
|
||||||
#define EEPROM_Default_CrystalCap_8723A 0x20
|
#define EEPROM_Default_CrystalCap_8723A 0x20
|
||||||
|
|
||||||
|
|
||||||
/* */
|
|
||||||
/* EEPROM/EFUSE data structure definition. */
|
/* EEPROM/EFUSE data structure definition. */
|
||||||
/* */
|
|
||||||
#define MAX_RF_PATH_NUM 2
|
|
||||||
#define MAX_CHNL_GROUP 3+9
|
#define MAX_CHNL_GROUP 3+9
|
||||||
|
|
||||||
struct txpowerinfo {
|
struct txpowerinfo {
|
||||||
u8 CCKIndex[MAX_RF_PATH_NUM][MAX_CHNL_GROUP];
|
u8 CCKIndex[RF_PATH_MAX][MAX_CHNL_GROUP];
|
||||||
u8 HT40_1SIndex[MAX_RF_PATH_NUM][MAX_CHNL_GROUP];
|
u8 HT40_1SIndex[RF_PATH_MAX][MAX_CHNL_GROUP];
|
||||||
u8 HT40_2SIndexDiff[MAX_RF_PATH_NUM][MAX_CHNL_GROUP];
|
u8 HT40_2SIndexDiff[RF_PATH_MAX][MAX_CHNL_GROUP];
|
||||||
u8 HT20IndexDiff[MAX_RF_PATH_NUM][MAX_CHNL_GROUP];
|
u8 HT20IndexDiff[RF_PATH_MAX][MAX_CHNL_GROUP];
|
||||||
u8 OFDMIndexDiff[MAX_RF_PATH_NUM][MAX_CHNL_GROUP];
|
u8 OFDMIndexDiff[RF_PATH_MAX][MAX_CHNL_GROUP];
|
||||||
u8 HT40MaxOffset[MAX_RF_PATH_NUM][MAX_CHNL_GROUP];
|
u8 HT40MaxOffset[RF_PATH_MAX][MAX_CHNL_GROUP];
|
||||||
u8 HT20MaxOffset[MAX_RF_PATH_NUM][MAX_CHNL_GROUP];
|
u8 HT20MaxOffset[RF_PATH_MAX][MAX_CHNL_GROUP];
|
||||||
u8 TSSI_A[3];
|
u8 TSSI_A[3];
|
||||||
u8 TSSI_B[3];
|
u8 TSSI_B[3];
|
||||||
u8 TSSI_A_5G[3]; /* 5GL/5GM/5GH */
|
u8 TSSI_A_5G[3]; /* 5GL/5GM/5GH */
|
||||||
|
@ -379,6 +379,28 @@ struct mlme_priv {
|
|||||||
|
|
||||||
u8 *wps_probe_req_ie;
|
u8 *wps_probe_req_ie;
|
||||||
u32 wps_probe_req_ie_len;
|
u32 wps_probe_req_ie_len;
|
||||||
|
u8 *assoc_req;
|
||||||
|
u32 assoc_req_len;
|
||||||
|
u32 assoc_rsp_len;
|
||||||
|
u8 *assoc_rsp;
|
||||||
|
u32 wps_assoc_resp_ie_len;
|
||||||
|
u8 *wps_assoc_resp_ie;
|
||||||
|
u8 *wps_probe_resp_ie;
|
||||||
|
u32 wps_probe_resp_ie_len;
|
||||||
|
u8 *wps_beacon_ie;
|
||||||
|
u32 wps_beacon_ie_len;
|
||||||
|
u32 p2p_go_probe_resp_ie_len; /* for GO */
|
||||||
|
u32 p2p_assoc_req_ie_len;
|
||||||
|
u8 *p2p_beacon_ie;
|
||||||
|
u8 *p2p_probe_req_ie;
|
||||||
|
u8 *p2p_probe_resp_ie;
|
||||||
|
u8 *p2p_go_probe_resp_ie; /* for GO */
|
||||||
|
u8 *p2p_assoc_req_ie;
|
||||||
|
u32 p2p_beacon_ie_len;
|
||||||
|
u32 p2p_probe_req_ie_len;
|
||||||
|
u32 p2p_probe_resp_ie_len;
|
||||||
|
u8 *wfd_assoc_req_ie;
|
||||||
|
u32 wfd_assoc_req_ie_len;
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_AP_MODE
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
/* Number of associated Non-ERP stations (i.e., stations using 802.11b
|
/* Number of associated Non-ERP stations (i.e., stations using 802.11b
|
||||||
@ -407,50 +429,20 @@ struct mlme_priv {
|
|||||||
|
|
||||||
u16 ht_op_mode;
|
u16 ht_op_mode;
|
||||||
|
|
||||||
u8 *assoc_req;
|
|
||||||
u32 assoc_req_len;
|
|
||||||
u8 *assoc_rsp;
|
|
||||||
u32 assoc_rsp_len;
|
|
||||||
|
|
||||||
u8 *wps_beacon_ie;
|
|
||||||
/* u8 *wps_probe_req_ie; */
|
|
||||||
u8 *wps_probe_resp_ie;
|
|
||||||
u8 *wps_assoc_resp_ie;
|
|
||||||
|
|
||||||
u32 wps_beacon_ie_len;
|
|
||||||
/* u32 wps_probe_req_ie_len; */
|
|
||||||
u32 wps_probe_resp_ie_len;
|
|
||||||
u32 wps_assoc_resp_ie_len;
|
|
||||||
|
|
||||||
u8 *p2p_beacon_ie;
|
|
||||||
u8 *p2p_probe_req_ie;
|
|
||||||
u8 *p2p_probe_resp_ie;
|
|
||||||
u8 *p2p_go_probe_resp_ie; /* for GO */
|
|
||||||
u8 *p2p_assoc_req_ie;
|
|
||||||
|
|
||||||
u32 p2p_beacon_ie_len;
|
|
||||||
u32 p2p_probe_req_ie_len;
|
|
||||||
u32 p2p_probe_resp_ie_len;
|
|
||||||
u32 p2p_go_probe_resp_ie_len; /* for GO */
|
|
||||||
u32 p2p_assoc_req_ie_len;
|
|
||||||
spinlock_t bcn_update_lock;
|
spinlock_t bcn_update_lock;
|
||||||
u8 update_bcn;
|
u8 update_bcn;
|
||||||
|
|
||||||
#endif /* ifdef CONFIG_8723AU_AP_MODE */
|
#endif /* ifdef CONFIG_8723AU_AP_MODE */
|
||||||
|
|
||||||
#if defined(CONFIG_8723AU_P2P)
|
|
||||||
u8 *wfd_beacon_ie;
|
u8 *wfd_beacon_ie;
|
||||||
u8 *wfd_probe_req_ie;
|
u8 *wfd_probe_req_ie;
|
||||||
u8 *wfd_probe_resp_ie;
|
u8 *wfd_probe_resp_ie;
|
||||||
u8 *wfd_go_probe_resp_ie; /* for GO */
|
u8 *wfd_go_probe_resp_ie; /* for GO */
|
||||||
u8 *wfd_assoc_req_ie;
|
|
||||||
|
|
||||||
u32 wfd_beacon_ie_len;
|
u32 wfd_beacon_ie_len;
|
||||||
u32 wfd_probe_req_ie_len;
|
u32 wfd_probe_req_ie_len;
|
||||||
u32 wfd_probe_resp_ie_len;
|
u32 wfd_probe_resp_ie_len;
|
||||||
u32 wfd_go_probe_resp_ie_len; /* for GO */
|
u32 wfd_go_probe_resp_ie_len; /* for GO */
|
||||||
u32 wfd_assoc_req_ie_len;
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_AP_MODE
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
|
@ -451,9 +451,7 @@ struct mlme_ext_priv {
|
|||||||
|
|
||||||
u64 TSFValue;
|
u64 TSFValue;
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_AP_MODE
|
|
||||||
unsigned char bstart_bss;
|
unsigned char bstart_bss;
|
||||||
#endif
|
|
||||||
u8 update_channel_plan_by_ap_done;
|
u8 update_channel_plan_by_ap_done;
|
||||||
/* recv_decache check for Action_public frame */
|
/* recv_decache check for Action_public frame */
|
||||||
u8 action_public_dialog_token;
|
u8 action_public_dialog_token;
|
||||||
|
@ -180,7 +180,7 @@ struct pwrctrl_priv {
|
|||||||
u8 ips_mode;
|
u8 ips_mode;
|
||||||
u8 ips_mode_req; /* used to accept the mode setting request */
|
u8 ips_mode_req; /* used to accept the mode setting request */
|
||||||
uint bips_processing;
|
uint bips_processing;
|
||||||
u32 ips_deny_time; /* will deny IPS when system time is smaller */
|
unsigned long ips_deny_time; /* deny IPS when system time is smaller */
|
||||||
u8 ps_processing; /* used to mark whether in rtw_ps_processor23a */
|
u8 ps_processing; /* used to mark whether in rtw_ps_processor23a */
|
||||||
|
|
||||||
u8 bLeisurePs;
|
u8 bLeisurePs;
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
|
|
||||||
#include <osdep_service.h>
|
#include <osdep_service.h>
|
||||||
#include <drv_types.h>
|
#include <drv_types.h>
|
||||||
|
#include <Hal8723APhyCfg.h>
|
||||||
|
|
||||||
#define NR_RECVFRAME 256
|
#define NR_RECVFRAME 256
|
||||||
|
|
||||||
@ -75,13 +76,11 @@ struct signal_stat {
|
|||||||
u32 total_val; /* sum of valid elements */
|
u32 total_val; /* sum of valid elements */
|
||||||
};
|
};
|
||||||
|
|
||||||
#define MAX_PATH_NUM_92CS 2
|
|
||||||
|
|
||||||
struct phy_info {
|
struct phy_info {
|
||||||
u8 RxPWDBAll;
|
u8 RxPWDBAll;
|
||||||
u8 SignalQuality; /* in 0-100 index. */
|
u8 SignalQuality; /* in 0-100 index. */
|
||||||
u8 RxMIMOSignalQuality[MAX_PATH_NUM_92CS]; /* EVM */
|
u8 RxMIMOSignalQuality[RF_PATH_MAX]; /* EVM */
|
||||||
u8 RxMIMOSignalStrength[MAX_PATH_NUM_92CS];/* 0~100 */
|
u8 RxMIMOSignalStrength[RF_PATH_MAX];/* 0~100 */
|
||||||
s8 RxPower; /* in dBm Translate from PWdB */
|
s8 RxPower; /* in dBm Translate from PWdB */
|
||||||
/* Real power in dBm for this packet, no beautification and aggregation.
|
/* Real power in dBm for this packet, no beautification and aggregation.
|
||||||
* Keep this raw info to be used for the other procedures.
|
* Keep this raw info to be used for the other procedures.
|
||||||
@ -89,8 +88,8 @@ struct phy_info {
|
|||||||
s8 RecvSignalPower;
|
s8 RecvSignalPower;
|
||||||
u8 BTRxRSSIPercentage;
|
u8 BTRxRSSIPercentage;
|
||||||
u8 SignalStrength; /* in 0-100 index. */
|
u8 SignalStrength; /* in 0-100 index. */
|
||||||
u8 RxPwr[MAX_PATH_NUM_92CS];/* per-path's pwdb */
|
u8 RxPwr[RF_PATH_MAX];/* per-path's pwdb */
|
||||||
u8 RxSNR[MAX_PATH_NUM_92CS];/* per-path's SNR */
|
u8 RxSNR[RF_PATH_MAX];/* per-path's SNR */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -140,8 +140,6 @@ struct sta_info {
|
|||||||
/* curr_network(mlme_priv/security_priv/qos/ht) : AP CAP/INFO */
|
/* curr_network(mlme_priv/security_priv/qos/ht) : AP CAP/INFO */
|
||||||
/* sta_info: (AP & STA) CAP/INFO */
|
/* sta_info: (AP & STA) CAP/INFO */
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_AP_MODE
|
|
||||||
|
|
||||||
struct list_head asoc_list;
|
struct list_head asoc_list;
|
||||||
struct list_head auth_list;
|
struct list_head auth_list;
|
||||||
|
|
||||||
@ -183,11 +181,12 @@ struct sta_info {
|
|||||||
u8 has_legacy_ac;
|
u8 has_legacy_ac;
|
||||||
unsigned int sleepq_ac_len;
|
unsigned int sleepq_ac_len;
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_P2P
|
|
||||||
/* p2p priv data */
|
/* p2p priv data */
|
||||||
u8 is_p2p_device;
|
u8 is_p2p_device;
|
||||||
u8 p2p_status_code;
|
u8 p2p_status_code;
|
||||||
|
|
||||||
|
u8 keep_alive_trycnt;
|
||||||
|
|
||||||
/* p2p client info */
|
/* p2p client info */
|
||||||
u8 dev_addr[ETH_ALEN];
|
u8 dev_addr[ETH_ALEN];
|
||||||
u8 dev_cap;
|
u8 dev_cap;
|
||||||
@ -197,12 +196,6 @@ struct sta_info {
|
|||||||
u8 secdev_types_list[32];/* 32/8 == 4; */
|
u8 secdev_types_list[32];/* 32/8 == 4; */
|
||||||
u16 dev_name_len;
|
u16 dev_name_len;
|
||||||
u8 dev_name[32];
|
u8 dev_name[32];
|
||||||
#endif /* CONFIG_8723AU_P2P */
|
|
||||||
|
|
||||||
u8 keep_alive_trycnt;
|
|
||||||
|
|
||||||
#endif /* CONFIG_8723AU_AP_MODE */
|
|
||||||
|
|
||||||
u8 *passoc_req;
|
u8 *passoc_req;
|
||||||
u32 assoc_req_len;
|
u32 assoc_req_len;
|
||||||
|
|
||||||
@ -329,9 +322,6 @@ struct sta_priv {
|
|||||||
struct rtw_queue wakeup_q;
|
struct rtw_queue wakeup_q;
|
||||||
|
|
||||||
struct rtw_adapter *padapter;
|
struct rtw_adapter *padapter;
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_8723AU_AP_MODE
|
|
||||||
struct list_head asoc_list;
|
struct list_head asoc_list;
|
||||||
struct list_head auth_list;
|
struct list_head auth_list;
|
||||||
spinlock_t asoc_list_lock;
|
spinlock_t asoc_list_lock;
|
||||||
@ -357,7 +347,6 @@ struct sta_priv {
|
|||||||
u16 max_num_sta;
|
u16 max_num_sta;
|
||||||
|
|
||||||
struct wlan_acl_pool acl_list;
|
struct wlan_acl_pool acl_list;
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline u32 wifi_mac_hash(u8 *mac)
|
static inline u32 wifi_mac_hash(u8 *mac)
|
||||||
|
@ -1495,9 +1495,11 @@ static int rtw_cfg80211_set_probe_req_wpsp2pie(struct rtw_adapter *padapter,
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
uint wps_ielen = 0;
|
uint wps_ielen = 0;
|
||||||
u8 *wps_ie;
|
u8 *wps_ie;
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
u32 p2p_ielen = 0;
|
u32 p2p_ielen = 0;
|
||||||
u8 *p2p_ie;
|
u8 *p2p_ie;
|
||||||
u32 wfd_ielen = 0;
|
u32 wfd_ielen = 0;
|
||||||
|
#endif
|
||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
|
|
||||||
#ifdef CONFIG_DEBUG_CFG80211
|
#ifdef CONFIG_DEBUG_CFG80211
|
||||||
@ -1595,12 +1597,12 @@ static int cfg80211_rtw_scan(struct wiphy *wiphy,
|
|||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
struct cfg80211_ssid ssid[RTW_SSID_SCAN_AMOUNT];
|
struct cfg80211_ssid ssid[RTW_SSID_SCAN_AMOUNT];
|
||||||
struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
|
struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
|
||||||
#ifdef CONFIG_8723AU_P2P
|
|
||||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
|
||||||
#endif /* CONFIG_8723AU_P2P */
|
|
||||||
struct rtw_wdev_priv *pwdev_priv = wdev_to_priv(padapter->rtw_wdev);
|
struct rtw_wdev_priv *pwdev_priv = wdev_to_priv(padapter->rtw_wdev);
|
||||||
struct cfg80211_ssid *ssids = request->ssids;
|
struct cfg80211_ssid *ssids = request->ssids;
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
|
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||||
int social_channel = 0;
|
int social_channel = 0;
|
||||||
|
#endif /* CONFIG_8723AU_P2P */
|
||||||
bool need_indicate_scan_done = false;
|
bool need_indicate_scan_done = false;
|
||||||
|
|
||||||
#ifdef CONFIG_DEBUG_CFG80211
|
#ifdef CONFIG_DEBUG_CFG80211
|
||||||
@ -1625,8 +1627,7 @@ static int cfg80211_rtw_scan(struct wiphy *wiphy,
|
|||||||
goto check_need_indicate_scan_done;
|
goto check_need_indicate_scan_done;
|
||||||
}
|
}
|
||||||
#ifdef CONFIG_8723AU_P2P
|
#ifdef CONFIG_8723AU_P2P
|
||||||
if (ssids->ssid != NULL &&
|
if (!memcmp(ssids->ssid, "DIRECT-", 7) &&
|
||||||
!memcmp(ssids->ssid, "DIRECT-", 7) &&
|
|
||||||
rtw_get_p2p_ie23a((u8 *) request->ie, request->ie_len, NULL, NULL)) {
|
rtw_get_p2p_ie23a((u8 *) request->ie, request->ie_len, NULL, NULL)) {
|
||||||
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
|
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
|
||||||
rtw_p2p_enable23a(padapter, P2P_ROLE_DEVICE);
|
rtw_p2p_enable23a(padapter, P2P_ROLE_DEVICE);
|
||||||
@ -2738,7 +2739,9 @@ static int rtw_cfg80211_monitor_if_xmit_entry(struct sk_buff *skb,
|
|||||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||||
u32 len = skb->len;
|
u32 len = skb->len;
|
||||||
u8 category, action;
|
u8 category, action;
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
int type = -1;
|
int type = -1;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (rtw_action_frame_parse23a(skb->data, len, &category,
|
if (rtw_action_frame_parse23a(skb->data, len, &category,
|
||||||
&action) == false) {
|
&action) == false) {
|
||||||
@ -2760,7 +2763,9 @@ static int rtw_cfg80211_monitor_if_xmit_entry(struct sk_buff *skb,
|
|||||||
else
|
else
|
||||||
DBG_8723A("RTW_Tx:category(%u), action(%u)\n", category,
|
DBG_8723A("RTW_Tx:category(%u), action(%u)\n", category,
|
||||||
action);
|
action);
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
dump:
|
dump:
|
||||||
|
#endif
|
||||||
/* starting alloc mgmt frame to dump it */
|
/* starting alloc mgmt frame to dump it */
|
||||||
pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
|
pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
|
||||||
if (pmgntframe == NULL)
|
if (pmgntframe == NULL)
|
||||||
@ -2971,8 +2976,10 @@ static int rtw_add_beacon(struct rtw_adapter *adapter, const u8 *head,
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
u8 *pbuf = NULL;
|
u8 *pbuf = NULL;
|
||||||
uint len, wps_ielen = 0;
|
uint len, wps_ielen = 0;
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
uint p2p_ielen = 0;
|
uint p2p_ielen = 0;
|
||||||
u8 got_p2p_ie = false;
|
u8 got_p2p_ie = false;
|
||||||
|
#endif
|
||||||
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
|
||||||
/* struct sta_priv *pstapriv = &padapter->stapriv; */
|
/* struct sta_priv *pstapriv = &padapter->stapriv; */
|
||||||
|
|
||||||
@ -3245,7 +3252,9 @@ static int cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,
|
|||||||
void rtw_cfg80211_rx_action_p2p(struct rtw_adapter *padapter, u8 *pmgmt_frame,
|
void rtw_cfg80211_rx_action_p2p(struct rtw_adapter *padapter, u8 *pmgmt_frame,
|
||||||
uint frame_len)
|
uint frame_len)
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
int type;
|
int type;
|
||||||
|
#endif
|
||||||
s32 freq;
|
s32 freq;
|
||||||
int channel;
|
int channel;
|
||||||
u8 category, action;
|
u8 category, action;
|
||||||
@ -3261,7 +3270,9 @@ void rtw_cfg80211_rx_action_p2p(struct rtw_adapter *padapter, u8 *pmgmt_frame,
|
|||||||
rtw_action_frame_parse23a(pmgmt_frame, frame_len, &category, &action);
|
rtw_action_frame_parse23a(pmgmt_frame, frame_len, &category, &action);
|
||||||
DBG_8723A("RTW_Rx:category(%u), action(%u)\n", category, action);
|
DBG_8723A("RTW_Rx:category(%u), action(%u)\n", category, action);
|
||||||
|
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
indicate:
|
indicate:
|
||||||
|
#endif
|
||||||
if (channel <= RTW_CH_MAX_2G_CHANNEL)
|
if (channel <= RTW_CH_MAX_2G_CHANNEL)
|
||||||
freq = ieee80211_channel_to_frequency(channel,
|
freq = ieee80211_channel_to_frequency(channel,
|
||||||
IEEE80211_BAND_2GHZ);
|
IEEE80211_BAND_2GHZ);
|
||||||
@ -3276,7 +3287,9 @@ indicate:
|
|||||||
void rtw_cfg80211_rx_p2p_action_public(struct rtw_adapter *padapter,
|
void rtw_cfg80211_rx_p2p_action_public(struct rtw_adapter *padapter,
|
||||||
u8 *pmgmt_frame, uint frame_len)
|
u8 *pmgmt_frame, uint frame_len)
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
int type;
|
int type;
|
||||||
|
#endif
|
||||||
s32 freq;
|
s32 freq;
|
||||||
int channel;
|
int channel;
|
||||||
u8 category, action;
|
u8 category, action;
|
||||||
@ -3298,7 +3311,9 @@ void rtw_cfg80211_rx_p2p_action_public(struct rtw_adapter *padapter,
|
|||||||
rtw_action_frame_parse23a(pmgmt_frame, frame_len, &category, &action);
|
rtw_action_frame_parse23a(pmgmt_frame, frame_len, &category, &action);
|
||||||
DBG_8723A("RTW_Rx:category(%u), action(%u)\n", category, action);
|
DBG_8723A("RTW_Rx:category(%u), action(%u)\n", category, action);
|
||||||
|
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
indicate:
|
indicate:
|
||||||
|
#endif
|
||||||
if (channel <= RTW_CH_MAX_2G_CHANNEL)
|
if (channel <= RTW_CH_MAX_2G_CHANNEL)
|
||||||
freq = ieee80211_channel_to_frequency(channel,
|
freq = ieee80211_channel_to_frequency(channel,
|
||||||
IEEE80211_BAND_2GHZ);
|
IEEE80211_BAND_2GHZ);
|
||||||
@ -3485,7 +3500,7 @@ void rtw_cfg80211_issue_p2p_provision_request23a(struct rtw_adapter *padapter,
|
|||||||
p2p_ie[p2pielen++] = P2P_ATTR_CAPABILITY;
|
p2p_ie[p2pielen++] = P2P_ATTR_CAPABILITY;
|
||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
RTW_PUT_LE16(p2p_ie + p2pielen, 0x0002);
|
put_unaligned_le16(0x0002, p2p_ie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -3499,7 +3514,7 @@ void rtw_cfg80211_issue_p2p_provision_request23a(struct rtw_adapter *padapter,
|
|||||||
p2p_ie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
|
p2p_ie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
|
||||||
|
|
||||||
/* Length: */
|
/* Length: */
|
||||||
RTW_PUT_LE16(p2p_ie + p2pielen, devinfo_contentlen);
|
put_unaligned_le16(devinfo_contentlen, p2p_ie + p2pielen);
|
||||||
p2pielen += 2;
|
p2pielen += 2;
|
||||||
|
|
||||||
/* Value: */
|
/* Value: */
|
||||||
@ -3580,7 +3595,9 @@ static s32 cfg80211_rtw_remain_on_channel(struct wiphy *wiphy,
|
|||||||
|
|
||||||
del_timer_sync(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
|
del_timer_sync(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
|
||||||
|
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
p2p_protocol_wk_hdl23a(padapter, P2P_RO_CH_WK);
|
p2p_protocol_wk_hdl23a(padapter, P2P_RO_CH_WK);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
pcfg80211_wdinfo->is_ro_ch = true;
|
pcfg80211_wdinfo->is_ro_ch = true;
|
||||||
@ -3663,7 +3680,9 @@ static s32 cfg80211_rtw_cancel_remain_on_channel(struct wiphy *wiphy,
|
|||||||
if (pcfg80211_wdinfo->is_ro_ch == true) {
|
if (pcfg80211_wdinfo->is_ro_ch == true) {
|
||||||
DBG_8723A("%s, cancel ro ch timer\n", __func__);
|
DBG_8723A("%s, cancel ro ch timer\n", __func__);
|
||||||
del_timer_sync(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
|
del_timer_sync(&padapter->cfg80211_wdinfo.remain_on_ch_timer);
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
p2p_protocol_wk_hdl23a(padapter, P2P_RO_CH_WK);
|
p2p_protocol_wk_hdl23a(padapter, P2P_RO_CH_WK);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
|
rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
|
||||||
@ -3834,7 +3853,9 @@ static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy, struct wireless_dev *wdev,
|
|||||||
DBG_8723A("RTW_Tx:category(%u), action(%u)\n",
|
DBG_8723A("RTW_Tx:category(%u), action(%u)\n",
|
||||||
category, action);
|
category, action);
|
||||||
|
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
dump:
|
dump:
|
||||||
|
#endif
|
||||||
do {
|
do {
|
||||||
dump_cnt++;
|
dump_cnt++;
|
||||||
tx_ret = _cfg80211_rtw_mgmt_tx(padapter, tx_ch, buf, len);
|
tx_ret = _cfg80211_rtw_mgmt_tx(padapter, tx_ch, buf, len);
|
||||||
@ -3890,10 +3911,14 @@ static int rtw_cfg80211_set_beacon_wpsp2pie(struct net_device *ndev, char *buf,
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
uint wps_ielen = 0;
|
uint wps_ielen = 0;
|
||||||
u8 *wps_ie;
|
u8 *wps_ie;
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
u32 p2p_ielen = 0;
|
u32 p2p_ielen = 0;
|
||||||
u8 wps_oui[8] = { 0x0, 0x50, 0xf2, 0x04 };
|
|
||||||
u8 *p2p_ie;
|
|
||||||
u32 wfd_ielen = 0;
|
u32 wfd_ielen = 0;
|
||||||
|
u8 *p2p_ie;
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
|
u8 wps_oui[8] = { 0x0, 0x50, 0xf2, 0x04 };
|
||||||
|
#endif
|
||||||
struct rtw_adapter *padapter = netdev_priv(ndev);
|
struct rtw_adapter *padapter = netdev_priv(ndev);
|
||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||||
@ -3923,8 +3948,10 @@ static int rtw_cfg80211_set_beacon_wpsp2pie(struct net_device *ndev, char *buf,
|
|||||||
memcpy(pmlmepriv->wps_beacon_ie, wps_ie, wps_ielen);
|
memcpy(pmlmepriv->wps_beacon_ie, wps_ie, wps_ielen);
|
||||||
pmlmepriv->wps_beacon_ie_len = wps_ielen;
|
pmlmepriv->wps_beacon_ie_len = wps_ielen;
|
||||||
|
|
||||||
|
#ifdef CONFIG_8723AU_AP_MODE
|
||||||
update_beacon23a(padapter, _VENDOR_SPECIFIC_IE_, wps_oui,
|
update_beacon23a(padapter, _VENDOR_SPECIFIC_IE_, wps_oui,
|
||||||
true);
|
true);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
#ifdef CONFIG_8723AU_P2P
|
#ifdef CONFIG_8723AU_P2P
|
||||||
p2p_ie = rtw_get_p2p_ie23a(buf, len, NULL, &p2p_ielen);
|
p2p_ie = rtw_get_p2p_ie23a(buf, len, NULL, &p2p_ielen);
|
||||||
@ -3992,12 +4019,14 @@ static int rtw_cfg80211_set_probe_resp_wpsp2pie(struct net_device *net,
|
|||||||
{
|
{
|
||||||
struct rtw_adapter *padapter = netdev_priv(net);
|
struct rtw_adapter *padapter = netdev_priv(net);
|
||||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||||
int ret = 0;
|
#ifdef CONFIG_8723AU_P2P
|
||||||
uint wps_ielen = 0;
|
|
||||||
u8 *wps_ie;
|
|
||||||
u32 p2p_ielen = 0;
|
u32 p2p_ielen = 0;
|
||||||
u8 *p2p_ie;
|
u8 *p2p_ie;
|
||||||
u32 wfd_ielen = 0;
|
u32 wfd_ielen = 0;
|
||||||
|
#endif
|
||||||
|
int ret = 0;
|
||||||
|
uint wps_ielen = 0;
|
||||||
|
u8 *wps_ie;
|
||||||
|
|
||||||
if (len > 0) {
|
if (len > 0) {
|
||||||
wps_ie = rtw_get_wps_ie23a(buf, len, NULL, &wps_ielen);
|
wps_ie = rtw_get_wps_ie23a(buf, len, NULL, &wps_ielen);
|
||||||
@ -4176,7 +4205,9 @@ int rtw_cfg80211_set_mgnt_wpsp2pie(struct net_device *net, char *buf, int len,
|
|||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
uint wps_ielen = 0;
|
uint wps_ielen = 0;
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
u32 p2p_ielen = 0;
|
u32 p2p_ielen = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_DEBUG_CFG80211
|
#ifdef CONFIG_DEBUG_CFG80211
|
||||||
DBG_8723A("%s, ielen =%d\n", __func__, len);
|
DBG_8723A("%s, ielen =%d\n", __func__, len);
|
||||||
|
@ -71,260 +71,6 @@ u32 _rtw_queue_empty23a(struct rtw_queue *pqueue)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 rtw_get_current_time(void)
|
|
||||||
{
|
|
||||||
return jiffies;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline u32 rtw_systime_to_ms23a(u32 systime)
|
|
||||||
{
|
|
||||||
return systime * 1000 / HZ;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline u32 rtw_ms_to_systime23a(u32 ms)
|
|
||||||
{
|
|
||||||
return ms * HZ / 1000;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* the input parameter start use the same unit as returned
|
|
||||||
* by rtw_get_current_time
|
|
||||||
*/
|
|
||||||
inline s32 rtw_get_passing_time_ms23a(u32 start)
|
|
||||||
{
|
|
||||||
return rtw_systime_to_ms23a(jiffies-start);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline s32 rtw_get_time_interval_ms23a(u32 start, u32 end)
|
|
||||||
{
|
|
||||||
return rtw_systime_to_ms23a(end-start);
|
|
||||||
}
|
|
||||||
|
|
||||||
#define RTW_SUSPEND_LOCK_NAME "rtw_wifi"
|
|
||||||
|
|
||||||
inline void rtw_suspend_lock_init(void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void rtw_suspend_lock_uninit(void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void rtw_lock_suspend(void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void rtw_unlock_suspend(void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open a file with the specific @param path, @param flag, @param mode
|
|
||||||
* @param fpp the pointer of struct file pointer to get struct
|
|
||||||
* file pointer while file opening is success
|
|
||||||
* @param path the path of the file to open
|
|
||||||
* @param flag file operation flags, please refer to linux document
|
|
||||||
* @param mode please refer to linux document
|
|
||||||
* @return Linux specific error code
|
|
||||||
*/
|
|
||||||
static int openFile(struct file **fpp, char *path, int flag, int mode)
|
|
||||||
{
|
|
||||||
struct file *fp;
|
|
||||||
|
|
||||||
fp = filp_open(path, flag, mode);
|
|
||||||
if (IS_ERR(fp)) {
|
|
||||||
*fpp = NULL;
|
|
||||||
return PTR_ERR(fp);
|
|
||||||
} else {
|
|
||||||
*fpp = fp;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Close the file with the specific @param fp
|
|
||||||
* @param fp the pointer of struct file to close
|
|
||||||
* @return always 0
|
|
||||||
*/
|
|
||||||
static int closeFile(struct file *fp)
|
|
||||||
{
|
|
||||||
filp_close(fp, NULL);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int readFile(struct file *fp, char *buf, int len)
|
|
||||||
{
|
|
||||||
int rlen = 0, sum = 0;
|
|
||||||
|
|
||||||
if (!fp->f_op || !fp->f_op->read)
|
|
||||||
return -EPERM;
|
|
||||||
|
|
||||||
while (sum < len) {
|
|
||||||
rlen = fp->f_op->read(fp, buf+sum, len-sum, &fp->f_pos);
|
|
||||||
if (rlen > 0)
|
|
||||||
sum += rlen;
|
|
||||||
else if (0 != rlen)
|
|
||||||
return rlen;
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return sum;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int writeFile(struct file *fp, char *buf, int len)
|
|
||||||
{
|
|
||||||
int wlen = 0, sum = 0;
|
|
||||||
|
|
||||||
if (!fp->f_op || !fp->f_op->write)
|
|
||||||
return -EPERM;
|
|
||||||
|
|
||||||
while (sum < len) {
|
|
||||||
wlen = fp->f_op->write(fp, buf+sum, len-sum, &fp->f_pos);
|
|
||||||
if (wlen > 0)
|
|
||||||
sum += wlen;
|
|
||||||
else if (0 != wlen)
|
|
||||||
return wlen;
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return sum;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Test if the specifi @param path is a file and readable
|
|
||||||
* @param path the path of the file to test
|
|
||||||
* @return Linux specific error code
|
|
||||||
*/
|
|
||||||
static int isFileReadable(char *path)
|
|
||||||
{
|
|
||||||
struct file *fp;
|
|
||||||
int ret = 0;
|
|
||||||
mm_segment_t oldfs;
|
|
||||||
char buf;
|
|
||||||
|
|
||||||
fp = filp_open(path, O_RDONLY, 0);
|
|
||||||
if (IS_ERR(fp)) {
|
|
||||||
ret = PTR_ERR(fp);
|
|
||||||
} else {
|
|
||||||
oldfs = get_fs();
|
|
||||||
set_fs(get_ds());
|
|
||||||
|
|
||||||
if (1 != readFile(fp, &buf, 1))
|
|
||||||
ret = PTR_ERR(fp);
|
|
||||||
|
|
||||||
set_fs(oldfs);
|
|
||||||
filp_close(fp, NULL);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open the file with @param path and retrive the file content into
|
|
||||||
* memory starting from @param buf for @param sz at most
|
|
||||||
* @param path the path of the file to open and read
|
|
||||||
* @param buf the starting address of the buffer to store file content
|
|
||||||
* @param sz how many bytes to read at most
|
|
||||||
* @return the byte we've read, or Linux specific error code
|
|
||||||
*/
|
|
||||||
static int retriveFromFile(char *path, u8 *buf, u32 sz)
|
|
||||||
{
|
|
||||||
int ret = -1;
|
|
||||||
mm_segment_t oldfs;
|
|
||||||
struct file *fp;
|
|
||||||
|
|
||||||
if (path && buf) {
|
|
||||||
ret = openFile(&fp, path, O_RDONLY, 0);
|
|
||||||
if (!ret) {
|
|
||||||
DBG_8723A("%s openFile path:%s fp =%p\n",
|
|
||||||
__func__, path, fp);
|
|
||||||
|
|
||||||
oldfs = get_fs(); set_fs(get_ds());
|
|
||||||
ret = readFile(fp, buf, sz);
|
|
||||||
set_fs(oldfs);
|
|
||||||
closeFile(fp);
|
|
||||||
|
|
||||||
DBG_8723A("%s readFile, ret:%d\n", __func__, ret);
|
|
||||||
} else {
|
|
||||||
DBG_8723A("%s openFile path:%s Fail, ret:%d\n",
|
|
||||||
__func__, path, ret);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
DBG_8723A("%s NULL pointer\n", __func__);
|
|
||||||
ret = -EINVAL;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open the file with @param path and wirte @param sz byte of data starting
|
|
||||||
* from @param buf into the file
|
|
||||||
* @param path the path of the file to open and write
|
|
||||||
* @param buf the starting address of the data to write into file
|
|
||||||
* @param sz how many bytes to write at most
|
|
||||||
* @return the byte we've written, or Linux specific error code
|
|
||||||
*/
|
|
||||||
static int storeToFile(char *path, u8 *buf, u32 sz)
|
|
||||||
{
|
|
||||||
struct file *fp;
|
|
||||||
int ret = 0;
|
|
||||||
mm_segment_t oldfs;
|
|
||||||
|
|
||||||
if (path && buf) {
|
|
||||||
ret = openFile(&fp, path, O_CREAT|O_WRONLY, 0666);
|
|
||||||
if (!ret) {
|
|
||||||
DBG_8723A("%s openFile path:%s fp =%p\n", __func__,
|
|
||||||
path, fp);
|
|
||||||
|
|
||||||
oldfs = get_fs(); set_fs(get_ds());
|
|
||||||
ret = writeFile(fp, buf, sz);
|
|
||||||
set_fs(oldfs);
|
|
||||||
closeFile(fp);
|
|
||||||
|
|
||||||
DBG_8723A("%s writeFile, ret:%d\n", __func__, ret);
|
|
||||||
} else {
|
|
||||||
DBG_8723A("%s openFile path:%s Fail, ret:%d\n",
|
|
||||||
__func__, path, ret);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
DBG_8723A("%s NULL pointer\n", __func__);
|
|
||||||
ret = -EINVAL;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Test if the specifi @param path is a file and readable
|
|
||||||
* @param path the path of the file to test
|
|
||||||
* @return true or false
|
|
||||||
*/
|
|
||||||
int rtw_is_file_readable(char *path)
|
|
||||||
{
|
|
||||||
if (isFileReadable(path) == 0)
|
|
||||||
return true;
|
|
||||||
else
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open the file with @param path and retrive the file content into memoryi
|
|
||||||
* starting from @param buf for @param sz at most
|
|
||||||
* @param path the path of the file to open and read
|
|
||||||
* @param buf the starting address of the buffer to store file content
|
|
||||||
* @param sz how many bytes to read at most
|
|
||||||
* @return the byte we've read
|
|
||||||
*/
|
|
||||||
int rtw_retrive_from_file(char *path, u8 *buf, u32 sz)
|
|
||||||
{
|
|
||||||
int ret = retriveFromFile(path, buf, sz);
|
|
||||||
return ret >= 0 ? ret : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open the file with @param path and wirte @param sz byte of
|
|
||||||
* data starting from @param buf into the file
|
|
||||||
* @param path the path of the file to open and write
|
|
||||||
* @param buf the starting address of the data to write into file
|
|
||||||
* @param sz how many bytes to write at most
|
|
||||||
* @return the byte we've written
|
|
||||||
*/
|
|
||||||
int rtw_store_to_file(char *path, u8 *buf, u32 sz)
|
|
||||||
{
|
|
||||||
int ret = storeToFile(path, buf, sz);
|
|
||||||
return ret >= 0 ? ret : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
u64 rtw_modular6423a(u64 x, u64 y)
|
u64 rtw_modular6423a(u64 x, u64 y)
|
||||||
{
|
{
|
||||||
return do_div(x, y);
|
return do_div(x, y);
|
||||||
|
@ -664,8 +664,10 @@ static struct rtw_adapter *rtw_usb_if1_init(struct dvobj_priv *dvobj,
|
|||||||
|
|
||||||
/* set mac addr */
|
/* set mac addr */
|
||||||
rtw_macaddr_cfg23a(padapter->eeprompriv.mac_addr);
|
rtw_macaddr_cfg23a(padapter->eeprompriv.mac_addr);
|
||||||
|
#ifdef CONFIG_8723AU_P2P
|
||||||
rtw_init_wifidirect_addrs23a(padapter, padapter->eeprompriv.mac_addr,
|
rtw_init_wifidirect_addrs23a(padapter, padapter->eeprompriv.mac_addr,
|
||||||
padapter->eeprompriv.mac_addr);
|
padapter->eeprompriv.mac_addr);
|
||||||
|
#endif
|
||||||
|
|
||||||
DBG_8723A("bDriverStopped:%d, bSurpriseRemoved:%d, bup:%d, hw_init_completed:%d\n",
|
DBG_8723A("bDriverStopped:%d, bSurpriseRemoved:%d, bup:%d, hw_init_completed:%d\n",
|
||||||
padapter->bDriverStopped, padapter->bSurpriseRemoved,
|
padapter->bDriverStopped, padapter->bSurpriseRemoved,
|
||||||
@ -811,12 +813,9 @@ static void rtw_disconnect(struct usb_interface *pusb_intf)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern int console_suspend_enabled;
|
|
||||||
|
|
||||||
static int __init rtw_drv_entry(void)
|
static int __init rtw_drv_entry(void)
|
||||||
{
|
{
|
||||||
RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("+rtw_drv_entry\n"));
|
RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("+rtw_drv_entry\n"));
|
||||||
rtw_suspend_lock_init();
|
|
||||||
return usb_register(usb_drv);
|
return usb_register(usb_drv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -825,8 +824,6 @@ static void __exit rtw_drv_halt(void)
|
|||||||
RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("+rtw_drv_halt\n"));
|
RT_TRACE(_module_hci_intfs_c_, _drv_err_, ("+rtw_drv_halt\n"));
|
||||||
DBG_8723A("+rtw_drv_halt\n");
|
DBG_8723A("+rtw_drv_halt\n");
|
||||||
|
|
||||||
rtw_suspend_lock_uninit();
|
|
||||||
|
|
||||||
usb_deregister(usb_drv);
|
usb_deregister(usb_drv);
|
||||||
|
|
||||||
DBG_8723A("-rtw_drv_halt\n");
|
DBG_8723A("-rtw_drv_halt\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user