Received: by 10.223.176.5 with SMTP id f5csp1138613wra; Tue, 6 Feb 2018 13:25:52 -0800 (PST) X-Google-Smtp-Source: AH8x2265bDbnMJofaHmDdZhM5wb483sjntgccLVln/mAaTDWcRcn/lWLgLiVT7IiCLd4hadxgUvN X-Received: by 10.99.120.139 with SMTP id t133mr3002741pgc.382.1517952352048; Tue, 06 Feb 2018 13:25:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517952352; cv=none; d=google.com; s=arc-20160816; b=fPMzykpWp1oJLkKaPmVPKB51Vjc/FJ40wB6wPEvoB8NQDDJlWpXRVrO2lGpu8h0TnO tB+u8zzejBedKPW8yc2tn1euJPgYMdLGkgQhpqf+4z7y0TsM5oe2r8Nek9iWU/2aKFUW 2VP6+bAwCaBkSgipiK8zpe6qT4iEjHnAyic0LSOV6ogLrNAvx0QOrtzXKirXdtBK3FUs 7hxX6p/zJ5b5I1nOcDNOEXpK5W9EIx7/PeALVz++Lw5DJ8/VmURIGK9Q5vz/ZPKeref0 025+JB95QHzIOv9jt9Js8JZ3VtcfIImh0xcAqrcntu4cN0XEo22sbMJeVQ7frwwY2PRn 575Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=HTN8d28E7edd76Q+DFdB1P3yq5Xyu3XexHReA/vouR8=; b=EYeuqs8a9WhC65NkF1t0Dr8t3eGuP11QEzWRgXf986iLZvx3T3Xy0t3UR8kHYcwR2q 1utYPr2XuCkhc9DxSbamSpPU5eBRY7zBa0Rj+AXOPRbGC2VWMGv+7lA9P9edxssoej8e esS4b0KprEVXVH5+OMZm6wGRx5+2yEZ/9AqKnw0c+6U/hANgQ9Gnb6KYXVQKhjZRo8hE fe7vlkSFTfQZ5J3Vuucs8JoZV6DzlkmlOv9serqdUq+4B/1RwNyApooWE/NmBdtaXQqD ifJau1elfw6Y9OQqDyhPlBmWB8EUxSKTJU6LeqP8kN3I/2QssGdmibivIoy4wQTN45Nn ZZJg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Kl61ZQW6; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f29si177250pfk.117.2018.02.06.13.25.38; Tue, 06 Feb 2018 13:25:52 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Kl61ZQW6; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754139AbeBFVXu (ORCPT + 99 others); Tue, 6 Feb 2018 16:23:50 -0500 Received: from mail-pg0-f66.google.com ([74.125.83.66]:45038 "EHLO mail-pg0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753535AbeBFVXr (ORCPT ); Tue, 6 Feb 2018 16:23:47 -0500 Received: by mail-pg0-f66.google.com with SMTP id r1so1612548pgn.11 for ; Tue, 06 Feb 2018 13:23:47 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=HTN8d28E7edd76Q+DFdB1P3yq5Xyu3XexHReA/vouR8=; b=Kl61ZQW6RUbrZr1wMgtm8VVe+7ZFE5+8Y6HekVC3nMQgGQ9ujUXtvOQ0JBle5Cclbg tU0MqG8Nfl9L1Nita20xlWEiVQnfYsFqntGO9Boipoa4vs0sSKuMmpDgv3ZZ04f+d38h gbt/8N/IJpIKT1dOVxW1cBx2xoXgXbxFjpUgIN1hurIyK9UInARJoP5CM7/xjg280ihD OBHG+DgopBq52uzYDfu0rnjsJNk+w1VM7dyBTd9bMm4TbUWZw0lBP7GUWXgwtbF7wlFq QWpWxJkSo0Aqh99uUnq5vz2DtW1EZBY9TIUwz5ZNVzezamQrN/NzJ915Zl1Y73a3jqzF epiw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=HTN8d28E7edd76Q+DFdB1P3yq5Xyu3XexHReA/vouR8=; b=tXMpidi66fC16ZT7wu3R00Mm+zW81+3IKhnYLZ0VioiW7Nx7FRHMz5GD2TEFPrC8wN fjbuw0rAAr8kxnsVywt1PaXc86HP4TZhXAy/6w0nzX3bpi2lhA9aUp9pmwzC0rPhH/jx lmNqmw1pV1/DYB5u6bd7wPOZFfQCQupKamZrFV1MF8sbjRJO0OMiALqoa7DuY8o8sjrU yrUEyUmBMPeACG3B0Tj70LwCtZXczhBP8aC4or6jpITFdNZdI8Jnmv+Pm4mjS0ToVnMH zSdSSdkKNFLH17WRR+tyAAtYt0XCL8lMDGaEVe6qBsJ7R7zIrtT5BV45A2emL7IdY+X5 GT/Q== X-Gm-Message-State: APf1xPCvM5oBQu0MPmGogKX4xjtHunZ6ryINW4dreh8YEoLlPlwPQ7EO fqeq/EZIOrpKqk12Hfz816I= X-Received: by 10.98.74.20 with SMTP id x20mr3719117pfa.191.1517952227206; Tue, 06 Feb 2018 13:23:47 -0800 (PST) Received: from localhost.localdomain ([1.240.193.50]) by smtp.googlemail.com with ESMTPSA id x15sm5515789pff.55.2018.02.06.13.23.42 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 06 Feb 2018 13:23:46 -0800 (PST) From: l4stpr0gr4m@gmail.com To: gregkh@linuxfoundation.org Cc: justin@jvreeland.com, hdegoede@redhat.com, hadess@hadess.net, colin.king@canonical.com, Larry.Finger@lwfinger.net, aishpant@gmail.com, himanshujha199640@gmail.com, arnd@arndb.de, ianwmorrison@gmail.com, davem@davemloft.net, joe@perches.com, devel@driverdev.osuosl.org, linux-kernel@vger.kernel.org, Kangmin Park Subject: [PATCH] Update rf_type_definition Date: Wed, 7 Feb 2018 06:23:34 +0900 Message-Id: <1517952214-3434-1-git-send-email-l4stpr0gr4m@gmail.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Kangmin Park enum RT_RF_TYPE_DEFINITION on rtl8723bs/include/rtw_rf.h is different from enum tag_HAL_RF_Type_Definition on rtl8723bs/include/HalVerDef.h So, update them to be the same reference from enum rf_type on rtlwifi/wifi.h which recent version. As a result, ODM_RF_TYPE_E needs to be updated as well Therefore, it is updated reference from enum odm_rf_type on rtlwifi/phydm/phydm_pre_define.h too. And update some additional code to check more chip versions that resulted from it. Also, fixed some space required errors and line over 80 characters warnings by checkpatch.pl. Signed-off-by: Kangmin Park --- drivers/staging/rtl8723bs/hal/odm.h | 18 +++--- drivers/staging/rtl8723bs/hal/rtl8723b_dm.c | 18 +++++- drivers/staging/rtl8723bs/hal/rtl8723b_hal_init.c | 12 ++++ drivers/staging/rtl8723bs/include/HalVerDef.h | 77 ++++++++++++++++------- drivers/staging/rtl8723bs/include/rtw_rf.h | 14 +++-- drivers/staging/rtl8723bs/os_dep/ioctl_cfg80211.c | 20 +++--- 6 files changed, 111 insertions(+), 48 deletions(-) diff --git a/drivers/staging/rtl8723bs/hal/odm.h b/drivers/staging/rtl8723bs/hal/odm.h index 87a76ba..771b894 100644 --- a/drivers/staging/rtl8723bs/hal/odm.h +++ b/drivers/staging/rtl8723bs/hal/odm.h @@ -511,14 +511,16 @@ typedef enum tag_ODM_RF_Path_Bit_Definition { typedef enum tag_ODM_RF_Type_Definition { - ODM_1T1R = 0, - ODM_1T2R = 1, - ODM_2T2R = 2, - ODM_2T3R = 3, - ODM_2T4R = 4, - ODM_3T3R = 5, - ODM_3T4R = 6, - ODM_4T4R = 7, + ODM_1T1R = 0, + ODM_1T2R = 1, + ODM_2T2R = 2, + ODM_2T2R_GREEN = 3, + ODM_2T3R = 4, + ODM_2T4R = 5, + ODM_3T3R = 6, + ODM_3T4R = 7, + ODM_4T4R = 8, + ODM_XTXR = 9, } ODM_RF_TYPE_E; diff --git a/drivers/staging/rtl8723bs/hal/rtl8723b_dm.c b/drivers/staging/rtl8723bs/hal/rtl8723b_dm.c index b162559..6069e1c 100644 --- a/drivers/staging/rtl8723bs/hal/rtl8723b_dm.c +++ b/drivers/staging/rtl8723bs/hal/rtl8723b_dm.c @@ -64,10 +64,24 @@ static void Init_ODM_ComInfo_8723b(struct adapter *Adapter) if (pHalData->rf_type == RF_1T1R) { ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_1T1R); - } else if (pHalData->rf_type == RF_2T2R) { - ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T2R); } else if (pHalData->rf_type == RF_1T2R) { ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_1T2R); + } else if (pHalData->rf_type == RF_2T2R) { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T2R); + } else if (pHalData->rf_type == RF_2T2R_GREEN) { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T2R_GREEN); + } else if (pHalData->rf_type == RF_2T3R) { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T3R); + } else if (pHalData->rf_type == RF_2T4R) { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_2T4R); + } else if (pHalData->rf_type == RF_3T3R) { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_3T3R); + } else if (pHalData->rf_type == RF_3T4R) { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_3T4R); + } else if (pHalData->rf_type == RF_4T4R) { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_4T4R); + } else { + ODM_CmnInfoUpdate(pDM_Odm, ODM_CMNINFO_RF_TYPE, ODM_XTXR); } pdmpriv->InitODMFlag = ODM_RF_CALIBRATION|ODM_RF_TX_PWR_TRACK; diff --git a/drivers/staging/rtl8723bs/hal/rtl8723b_hal_init.c b/drivers/staging/rtl8723bs/hal/rtl8723b_hal_init.c index d6cef9e..a4df098 100644 --- a/drivers/staging/rtl8723bs/hal/rtl8723b_hal_init.c +++ b/drivers/staging/rtl8723bs/hal/rtl8723b_hal_init.c @@ -1926,6 +1926,18 @@ static HAL_VERSION ReadChipVersion8723B(struct adapter *padapter) pHalData->rf_type = RF_1T2R; else if (IS_2T2R(ChipVersion)) pHalData->rf_type = RF_2T2R; + else if (IS_2T2R_GREEN(ChipVersion)) + pHalData->rf_type = RF_2T2R_GREEN; + else if (IS_2T3R(ChipVersion)) + pHalData->rf_type = RF_2T3R; + else if (IS_2T4R(ChipVersion)) + pHalData->rf_type = RF_2T4R; + else if (IS_3T3R(ChipVersion)) + pHalData->rf_type = RF_3T3R; + else if (IS_3T4R(ChipVersion)) + pHalData->rf_type = RF_3T4R; + else if (IS_4T4R(ChipVersion)) + pHalData->rf_type = RF_4T4R; else pHalData->rf_type = RF_1T1R; diff --git a/drivers/staging/rtl8723bs/include/HalVerDef.h b/drivers/staging/rtl8723bs/include/HalVerDef.h index a9e8609..08301fc 100644 --- a/drivers/staging/rtl8723bs/include/HalVerDef.h +++ b/drivers/staging/rtl8723bs/include/HalVerDef.h @@ -64,14 +64,15 @@ typedef enum tag_HAL_Manufacturer_Version_Definition typedef enum tag_HAL_RF_Type_Definition { - RF_TYPE_1T1R = 0, - RF_TYPE_1T2R = 1, - RF_TYPE_2T2R = 2, - RF_TYPE_2T3R = 3, - RF_TYPE_2T4R = 4, - RF_TYPE_3T3R = 5, - RF_TYPE_3T4R = 6, - RF_TYPE_4T4R = 7, + RF_TYPE_1T1R = 0, + RF_TYPE_1T2R = 1, + RF_TYPE_2T2R = 2, + RF_TYPE_2T2R_GREEN = 3, + RF_TYPE_2T3R = 4, + RF_TYPE_2T4R = 5, + RF_TYPE_3T3R = 6, + RF_TYPE_3T4R = 7, + RF_TYPE_4T4R = 8, }HAL_RF_TYPE_E; typedef struct tag_HAL_VERSION @@ -101,27 +102,55 @@ typedef struct tag_HAL_VERSION /* HAL_VERSION VersionID */ /* HAL_CHIP_TYPE_E */ -#define IS_TEST_CHIP(version) ((GET_CVID_CHIP_TYPE(version) ==TEST_CHIP)? true: false) -#define IS_NORMAL_CHIP(version) ((GET_CVID_CHIP_TYPE(version) ==NORMAL_CHIP)? true: false) +#define IS_TEST_CHIP(version) \ + ((GET_CVID_CHIP_TYPE(version) == TEST_CHIP) ? true : false) +#define IS_NORMAL_CHIP(version) \ + ((GET_CVID_CHIP_TYPE(version) == NORMAL_CHIP) ? true : false) /* HAL_CUT_VERSION_E */ -#define IS_A_CUT(version) ((GET_CVID_CUT_VERSION(version) == A_CUT_VERSION) ? true : false) -#define IS_B_CUT(version) ((GET_CVID_CUT_VERSION(version) == B_CUT_VERSION) ? true : false) -#define IS_C_CUT(version) ((GET_CVID_CUT_VERSION(version) == C_CUT_VERSION) ? true : false) -#define IS_D_CUT(version) ((GET_CVID_CUT_VERSION(version) == D_CUT_VERSION) ? true : false) -#define IS_E_CUT(version) ((GET_CVID_CUT_VERSION(version) == E_CUT_VERSION) ? true : false) -#define IS_I_CUT(version) ((GET_CVID_CUT_VERSION(version) == I_CUT_VERSION) ? true : false) -#define IS_J_CUT(version) ((GET_CVID_CUT_VERSION(version) == J_CUT_VERSION) ? true : false) -#define IS_K_CUT(version) ((GET_CVID_CUT_VERSION(version) == K_CUT_VERSION) ? true : false) +#define IS_A_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == A_CUT_VERSION) ? true : false) +#define IS_B_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == B_CUT_VERSION) ? true : false) +#define IS_C_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == C_CUT_VERSION) ? true : false) +#define IS_D_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == D_CUT_VERSION) ? true : false) +#define IS_E_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == E_CUT_VERSION) ? true : false) +#define IS_I_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == I_CUT_VERSION) ? true : false) +#define IS_J_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == J_CUT_VERSION) ? true : false) +#define IS_K_CUT(version) \ + ((GET_CVID_CUT_VERSION(version) == K_CUT_VERSION) ? true : false) /* HAL_VENDOR_E */ -#define IS_CHIP_VENDOR_TSMC(version) ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_TSMC)? true: false) -#define IS_CHIP_VENDOR_UMC(version) ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_UMC)? true: false) -#define IS_CHIP_VENDOR_SMIC(version) ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_SMIC)? true: false) +#define IS_CHIP_VENDOR_TSMC(version) \ + ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_TSMC) ? true : false) +#define IS_CHIP_VENDOR_UMC(version) \ + ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_UMC) ? true : false) +#define IS_CHIP_VENDOR_SMIC(version) \ + ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_SMIC) ? true : false) /* HAL_RF_TYPE_E */ -#define IS_1T1R(version) ((GET_CVID_RF_TYPE(version) == RF_TYPE_1T1R)? true : false) -#define IS_1T2R(version) ((GET_CVID_RF_TYPE(version) == RF_TYPE_1T2R)? true : false) -#define IS_2T2R(version) ((GET_CVID_RF_TYPE(version) == RF_TYPE_2T2R)? true : false) +#define IS_1T1R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_1T1R) ? true : false) +#define IS_1T2R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_1T2R) ? true : false) +#define IS_2T2R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_2T2R) ? true : false) +#define IS_2T2R_GREEN(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_2T2R_GREEN) ? true : false) +#define IS_2T3R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_2T3R) ? true : false) +#define IS_2T4R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_2T4R) ? true : false) +#define IS_3T3R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_3T3R) ? true : false) +#define IS_3T4R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_3T4R) ? true : false) +#define IS_4T4R(version) \ + ((GET_CVID_RF_TYPE(version) == RF_TYPE_4T4R) ? true : false) #endif diff --git a/drivers/staging/rtl8723bs/include/rtw_rf.h b/drivers/staging/rtl8723bs/include/rtw_rf.h index f9becab..d1fc396 100644 --- a/drivers/staging/rtl8723bs/include/rtw_rf.h +++ b/drivers/staging/rtl8723bs/include/rtw_rf.h @@ -146,12 +146,16 @@ enum PROTECTION_MODE { /* 2007/11/15 MH Define different RF type. */ enum RT_RF_TYPE_DEFINITION { - RF_1T2R = 0, - RF_2T4R = 1, + RF_1T1R = 0, + RF_1T2R = 1, RF_2T2R = 2, - RF_1T1R = 3, - RF_2T2R_GREEN = 4, - RF_MAX_TYPE = 5, + RF_2T2R_GREEN = 3, + RF_2T3R = 4, + RF_2T4R = 5, + RF_3T3R = 6, + RF_3T4R = 7, + RF_4T4R = 8, + RF_MAX_TYPE = 9, }; u32 rtw_ch2freq(u32 ch); diff --git a/drivers/staging/rtl8723bs/os_dep/ioctl_cfg80211.c b/drivers/staging/rtl8723bs/os_dep/ioctl_cfg80211.c index 51d48de..22fc6fa 100644 --- a/drivers/staging/rtl8723bs/os_dep/ioctl_cfg80211.c +++ b/drivers/staging/rtl8723bs/os_dep/ioctl_cfg80211.c @@ -3299,7 +3299,7 @@ static int cfg80211_rtw_sched_scan_stop(struct wiphy *wiphy, static void rtw_cfg80211_init_ht_capab(struct ieee80211_sta_ht_cap *ht_cap, enum nl80211_band band, u8 rf_type) { - +#define MAX_BIT_RATE_40MHZ_MCS23 450 /* Mbps */ #define MAX_BIT_RATE_40MHZ_MCS15 300 /* Mbps */ #define MAX_BIT_RATE_40MHZ_MCS7 150 /* Mbps */ @@ -3330,24 +3330,26 @@ static void rtw_cfg80211_init_ht_capab(struct ieee80211_sta_ht_cap *ht_cap, enum *if BW_40 rx_mask[4]= 0x01; *highest supported RX rate */ - if (rf_type == RF_1T1R) - { + if (rf_type == RF_1T1R) { ht_cap->mcs.rx_mask[0] = 0xFF; ht_cap->mcs.rx_mask[1] = 0x00; ht_cap->mcs.rx_mask[4] = 0x01; ht_cap->mcs.rx_highest = cpu_to_le16(MAX_BIT_RATE_40MHZ_MCS7); - } - else if ((rf_type == RF_1T2R) || (rf_type ==RF_2T2R)) - { + } else if ((rf_type == RF_1T2R) || (rf_type == RF_2T2R) + || (rf_type == RF_2T2R_GREEN)) { ht_cap->mcs.rx_mask[0] = 0xFF; ht_cap->mcs.rx_mask[1] = 0xFF; ht_cap->mcs.rx_mask[4] = 0x01; ht_cap->mcs.rx_highest = cpu_to_le16(MAX_BIT_RATE_40MHZ_MCS15); - } - else - { + } else if ((rf_type == RF_2T3R) || (rf_type == RF_3T3R)) { + ht_cap->mcs.rx_mask[0] = 0xFF; + ht_cap->mcs.rx_mask[1] = 0xFF; + ht_cap->mcs.rx_mask[2] = 0x01; + + ht_cap->mcs.rx_highest = cpu_to_le16(MAX_BIT_RATE_40MHZ_MCS23); + } else { DBG_8192C("%s, error rf_type =%d\n", __func__, rf_type); } -- 2.7.4