| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420 |
- /******************************************************************************
- *
- * Copyright(c) 2013 - 2017 Realtek Corporation.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *****************************************************************************/
- #include <rtw_odm.h>
- #include <hal_data.h>
- u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability)
- {
- HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
- struct dm_struct *podmpriv = &pHalData->odmpriv;
- u32 result = 0;
- switch (ops) {
- case HAL_PHYDM_DIS_ALL_FUNC:
- podmpriv->support_ability = DYNAMIC_FUNC_DISABLE;
- halrf_cmn_info_set(podmpriv, HALRF_CMNINFO_ABILITY, DYNAMIC_FUNC_DISABLE);
- break;
- case HAL_PHYDM_FUNC_SET:
- podmpriv->support_ability |= ability;
- break;
- case HAL_PHYDM_FUNC_CLR:
- podmpriv->support_ability &= ~(ability);
- break;
- case HAL_PHYDM_ABILITY_BK:
- /* dm flag backup*/
- podmpriv->bk_support_ability = podmpriv->support_ability;
- pHalData->bk_rf_ability = halrf_cmn_info_get(podmpriv, HALRF_CMNINFO_ABILITY);
- break;
- case HAL_PHYDM_ABILITY_RESTORE:
- /* restore dm flag */
- podmpriv->support_ability = podmpriv->bk_support_ability;
- halrf_cmn_info_set(podmpriv, HALRF_CMNINFO_ABILITY, pHalData->bk_rf_ability);
- break;
- case HAL_PHYDM_ABILITY_SET:
- podmpriv->support_ability = ability;
- break;
- case HAL_PHYDM_ABILITY_GET:
- result = podmpriv->support_ability;
- break;
- }
- return result;
- }
- /* set ODM_CMNINFO_IC_TYPE based on chip_type */
- void rtw_odm_init_ic_type(_adapter *adapter)
- {
- struct dm_struct *odm = adapter_to_phydm(adapter);
- u4Byte ic_type = chip_type_to_odm_ic_type(rtw_get_chip_type(adapter));
- rtw_warn_on(!ic_type);
- odm_cmn_info_init(odm, ODM_CMNINFO_IC_TYPE, ic_type);
- }
- void rtw_odm_adaptivity_ver_msg(void *sel, _adapter *adapter)
- {
- RTW_PRINT_SEL(sel, "ADAPTIVITY_VERSION "ADAPTIVITY_VERSION"\n");
- }
- #define RTW_ADAPTIVITY_EN_DISABLE 0
- #define RTW_ADAPTIVITY_EN_ENABLE 1
- void rtw_odm_adaptivity_en_msg(void *sel, _adapter *adapter)
- {
- struct registry_priv *regsty = &adapter->registrypriv;
- RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_EN_");
- if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_DISABLE)
- _RTW_PRINT_SEL(sel, "DISABLE\n");
- else if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_ENABLE)
- _RTW_PRINT_SEL(sel, "ENABLE\n");
- else
- _RTW_PRINT_SEL(sel, "INVALID\n");
- }
- #define RTW_ADAPTIVITY_MODE_NORMAL 0
- #define RTW_ADAPTIVITY_MODE_CARRIER_SENSE 1
- void rtw_odm_adaptivity_mode_msg(void *sel, _adapter *adapter)
- {
- struct registry_priv *regsty = &adapter->registrypriv;
- RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_MODE_");
- if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_NORMAL)
- _RTW_PRINT_SEL(sel, "NORMAL\n");
- else if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_CARRIER_SENSE)
- _RTW_PRINT_SEL(sel, "CARRIER_SENSE\n");
- else
- _RTW_PRINT_SEL(sel, "INVALID\n");
- }
- void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter)
- {
- rtw_odm_adaptivity_ver_msg(sel, adapter);
- rtw_odm_adaptivity_en_msg(sel, adapter);
- rtw_odm_adaptivity_mode_msg(sel, adapter);
- }
- bool rtw_odm_adaptivity_needed(_adapter *adapter)
- {
- struct registry_priv *regsty = &adapter->registrypriv;
- bool ret = _FALSE;
- if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_ENABLE)
- ret = _TRUE;
- return ret;
- }
- void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter)
- {
- struct dm_struct *odm = adapter_to_phydm(adapter);
- rtw_odm_adaptivity_config_msg(sel, adapter);
- RTW_PRINT_SEL(sel, "%10s %16s\n"
- , "th_l2h_ini", "th_edcca_hl_diff");
- RTW_PRINT_SEL(sel, "0x%-8x %-16d\n"
- , (u8)odm->th_l2h_ini
- , odm->th_edcca_hl_diff
- );
- }
- void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff)
- {
- struct dm_struct *odm = adapter_to_phydm(adapter);
- odm->th_l2h_ini = th_l2h_ini;
- odm->th_edcca_hl_diff = th_edcca_hl_diff;
- }
- void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter)
- {
- struct dm_struct *odm = adapter_to_phydm(adapter);
- RTW_PRINT_SEL(sel, "rx_rate = %s, rssi_a = %d(%%), rssi_b = %d(%%)\n",
- HDATA_RATE(odm->rx_rate), odm->rssi_a, odm->rssi_b);
- }
- void rtw_odm_acquirespinlock(_adapter *adapter, enum rt_spinlock_type type)
- {
- PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
- _irqL irqL;
- switch (type) {
- case RT_IQK_SPINLOCK:
- _enter_critical_bh(&pHalData->IQKSpinLock, &irqL);
- default:
- break;
- }
- }
- void rtw_odm_releasespinlock(_adapter *adapter, enum rt_spinlock_type type)
- {
- PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
- _irqL irqL;
- switch (type) {
- case RT_IQK_SPINLOCK:
- _exit_critical_bh(&pHalData->IQKSpinLock, &irqL);
- default:
- break;
- }
- }
- inline u8 rtw_odm_get_dfs_domain(struct dvobj_priv *dvobj)
- {
- #ifdef CONFIG_DFS_MASTER
- struct dm_struct *pDM_Odm = dvobj_to_phydm(dvobj);
- return pDM_Odm->dfs_region_domain;
- #else
- return PHYDM_DFS_DOMAIN_UNKNOWN;
- #endif
- }
- inline u8 rtw_odm_dfs_domain_unknown(struct dvobj_priv *dvobj)
- {
- #ifdef CONFIG_DFS_MASTER
- return rtw_odm_get_dfs_domain(dvobj) == PHYDM_DFS_DOMAIN_UNKNOWN;
- #else
- return 1;
- #endif
- }
- #ifdef CONFIG_DFS_MASTER
- inline VOID rtw_odm_radar_detect_reset(_adapter *adapter)
- {
- phydm_radar_detect_reset(adapter_to_phydm(adapter));
- }
- inline VOID rtw_odm_radar_detect_disable(_adapter *adapter)
- {
- phydm_radar_detect_disable(adapter_to_phydm(adapter));
- }
- /* called after ch, bw is set */
- inline VOID rtw_odm_radar_detect_enable(_adapter *adapter)
- {
- phydm_radar_detect_enable(adapter_to_phydm(adapter));
- }
- inline BOOLEAN rtw_odm_radar_detect(_adapter *adapter)
- {
- return phydm_radar_detect(adapter_to_phydm(adapter));
- }
- inline u8 rtw_odm_radar_detect_polling_int_ms(struct dvobj_priv *dvobj)
- {
- return phydm_dfs_polling_time(dvobj_to_phydm(dvobj));
- }
- #endif /* CONFIG_DFS_MASTER */
- void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)
- {
- #ifndef DBG_RX_PHYSTATUS_CHINFO
- #define DBG_RX_PHYSTATUS_CHINFO 0
- #endif
- #if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
- _adapter *adapter = rframe->u.hdr.adapter;
- struct dm_struct *phydm = adapter_to_phydm(adapter);
- struct rx_pkt_attrib *attrib = &rframe->u.hdr.attrib;
- u8 *wlanhdr = get_recvframe_data(rframe);
- if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
- /*
- * 8723D:
- * type_0(CCK)
- * l_rxsc
- * is filled with primary channel SC, not real rxsc.
- * 0:LSC, 1:USC
- * type_1(OFDM)
- * rf_mode
- * RF bandwidth when RX
- * l_rxsc(legacy), ht_rxsc
- * see below RXSC N-series
- * type_2(Not used)
- */
- /*
- * 8821C, 8822B:
- * type_0(CCK)
- * l_rxsc
- * is filled with primary channel SC, not real rxsc.
- * 0:LSC, 1:USC
- * type_1(OFDM)
- * rf_mode
- * RF bandwidth when RX
- * l_rxsc(legacy), ht_rxsc
- * see below RXSC AC-series
- * type_2(Not used)
- */
- if ((*phys & 0xf) == 0) {
- struct phy_status_rpt_jaguar2_type0 *phys_t0 = (struct phy_status_rpt_jaguar2_type0 *)phys;
- if (DBG_RX_PHYSTATUS_CHINFO) {
- RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u)\n"
- , *phys & 0xf
- , MAC_ARG(get_ta(wlanhdr))
- , is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
- , HDATA_RATE(attrib->data_rate)
- , phys_t0->band, phys_t0->channel, phys_t0->rxsc
- );
- }
- } else if ((*phys & 0xf) == 1) {
- struct phy_status_rpt_jaguar2_type1 *phys_t1 = (struct phy_status_rpt_jaguar2_type1 *)phys;
- u8 rxsc = (attrib->data_rate > DESC_RATE11M && attrib->data_rate < DESC_RATEMCS0) ? phys_t1->l_rxsc : phys_t1->ht_rxsc;
- u8 pkt_cch = 0;
- u8 pkt_bw = CHANNEL_WIDTH_20;
- #if ODM_IC_11N_SERIES_SUPPORT
- if (phydm->support_ic_type & ODM_IC_11N_SERIES) {
- /* RXSC N-series */
- #define RXSC_DUP 0
- #define RXSC_LSC 1
- #define RXSC_USC 2
- #define RXSC_40M 3
- static const s8 cch_offset_by_rxsc[4] = {0, -2, 2, 0};
- if (phys_t1->rf_mode == 0) {
- pkt_cch = phys_t1->channel;
- pkt_bw = CHANNEL_WIDTH_20;
- } else if (phys_t1->rf_mode == 1) {
- if (rxsc == RXSC_LSC || rxsc == RXSC_USC) {
- pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
- pkt_bw = CHANNEL_WIDTH_20;
- } else if (rxsc == RXSC_40M) {
- pkt_cch = phys_t1->channel;
- pkt_bw = CHANNEL_WIDTH_40;
- }
- } else
- rtw_warn_on(1);
- goto type1_end;
- }
- #endif /* ODM_IC_11N_SERIES_SUPPORT */
- #if ODM_IC_11AC_SERIES_SUPPORT
- if (phydm->support_ic_type & ODM_IC_11AC_SERIES) {
- /* RXSC AC-series */
- #define RXSC_DUP 0 /* 0: RX from all SC of current rf_mode */
- #define RXSC_LL20M_OF_160M 8 /* 1~8: RX from 20MHz SC */
- #define RXSC_L20M_OF_160M 6
- #define RXSC_L20M_OF_80M 4
- #define RXSC_L20M_OF_40M 2
- #define RXSC_U20M_OF_40M 1
- #define RXSC_U20M_OF_80M 3
- #define RXSC_U20M_OF_160M 5
- #define RXSC_UU20M_OF_160M 7
- #define RXSC_L40M_OF_160M 12 /* 9~12: RX from 40MHz SC */
- #define RXSC_L40M_OF_80M 10
- #define RXSC_U40M_OF_80M 9
- #define RXSC_U40M_OF_160M 11
- #define RXSC_L80M_OF_160M 14 /* 13~14: RX from 80MHz SC */
- #define RXSC_U80M_OF_160M 13
- static const s8 cch_offset_by_rxsc[15] = {0, 2, -2, 6, -6, 10, -10, 14, -14, 4, -4, 12, -12, 8, -8};
- if (phys_t1->rf_mode > 3) {
- /* invalid rf_mode */
- rtw_warn_on(1);
- goto type1_end;
- }
- if (phys_t1->rf_mode == 0) {
- /* RF 20MHz */
- pkt_cch = phys_t1->channel;
- pkt_bw = CHANNEL_WIDTH_20;
- goto type1_end;
- }
- if (rxsc == 0) {
- /* RF and RX with same BW */
- if (attrib->data_rate >= DESC_RATEMCS0) {
- pkt_cch = phys_t1->channel;
- pkt_bw = phys_t1->rf_mode;
- }
- goto type1_end;
- }
- if ((phys_t1->rf_mode == 1 && rxsc >= 1 && rxsc <= 2) /* RF 40MHz, RX 20MHz */
- || (phys_t1->rf_mode == 2 && rxsc >= 1 && rxsc <= 4) /* RF 80MHz, RX 20MHz */
- || (phys_t1->rf_mode == 3 && rxsc >= 1 && rxsc <= 8) /* RF 160MHz, RX 20MHz */
- ) {
- pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
- pkt_bw = CHANNEL_WIDTH_20;
- } else if ((phys_t1->rf_mode == 2 && rxsc >= 9 && rxsc <= 10) /* RF 80MHz, RX 40MHz */
- || (phys_t1->rf_mode == 3 && rxsc >= 9 && rxsc <= 12) /* RF 160MHz, RX 40MHz */
- ) {
- if (attrib->data_rate >= DESC_RATEMCS0) {
- pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
- pkt_bw = CHANNEL_WIDTH_40;
- }
- } else if ((phys_t1->rf_mode == 3 && rxsc >= 13 && rxsc <= 14) /* RF 160MHz, RX 80MHz */
- ) {
- if (attrib->data_rate >= DESC_RATEMCS0) {
- pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
- pkt_bw = CHANNEL_WIDTH_80;
- }
- } else
- rtw_warn_on(1);
- }
- #endif /* ODM_IC_11AC_SERIES_SUPPORT */
- type1_end:
- if (DBG_RX_PHYSTATUS_CHINFO) {
- RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, rf_mode:%u, l_rxsc:%u, ht_rxsc:%u) => %u,%u\n"
- , *phys & 0xf
- , MAC_ARG(get_ta(wlanhdr))
- , is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
- , HDATA_RATE(attrib->data_rate)
- , phys_t1->band, phys_t1->channel, phys_t1->rf_mode, phys_t1->l_rxsc, phys_t1->ht_rxsc
- , pkt_cch, pkt_bw
- );
- }
- /* for now, only return cneter channel of 20MHz packet */
- if (pkt_cch && pkt_bw == CHANNEL_WIDTH_20)
- attrib->ch = pkt_cch;
- } else {
- struct phy_status_rpt_jaguar2_type2 *phys_t2 = (struct phy_status_rpt_jaguar2_type2 *)phys;
- if (DBG_RX_PHYSTATUS_CHINFO) {
- RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u, ht_rxsc:%u)\n"
- , *phys & 0xf
- , MAC_ARG(get_ta(wlanhdr))
- , is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
- , HDATA_RATE(attrib->data_rate)
- , phys_t2->band, phys_t2->channel, phys_t2->l_rxsc, phys_t2->ht_rxsc
- );
- }
- }
- }
- #endif /* (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1) */
- }
|