summaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h
diff options
context:
space:
mode:
authorKalle Valo2018-10-14 10:40:41 +0200
committerKalle Valo2018-10-14 10:40:41 +0200
commit6bfa6975f1b72e3e65fb27eedabbe8348322f20a (patch)
treef5c753abcf0960ac84d8637962bed894702ec1ea /drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h
parentrtl8xxxu: Remove set but not used variables 'usedesc40' and 'seq_number' (diff)
parentmt76x0: phy: do not run calibration during channel switch (diff)
downloadkernel-qcow2-linux-6bfa6975f1b72e3e65fb27eedabbe8348322f20a.tar.gz
kernel-qcow2-linux-6bfa6975f1b72e3e65fb27eedabbe8348322f20a.tar.xz
kernel-qcow2-linux-6bfa6975f1b72e3e65fb27eedabbe8348322f20a.zip
Merge tag 'mt76-for-kvalo-2018-10-13' of https://github.com/nbd168/wireless
mt76 patches for 4.20 * mt76x0 fixes * mt76x0e improvements (should be usable now) * usb support improvements * more mt76x0/mt76x2 unification work * minor fix for aggregation + powersave clients
Diffstat (limited to 'drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h')
-rw-r--r--drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h23
1 files changed, 22 insertions, 1 deletions
diff --git a/drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h b/drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h
index c97b31c77d83..9e735524d367 100644
--- a/drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h
+++ b/drivers/net/wireless/mediatek/mt76/mt76x2/eeprom.h
@@ -62,7 +62,7 @@ void mt76x2_read_rx_gain(struct mt76x02_dev *dev);
static inline bool
mt76x2_has_ext_lna(struct mt76x02_dev *dev)
{
- u32 val = mt76x02_eeprom_get(&dev->mt76, MT_EE_NIC_CONF_1);
+ u32 val = mt76x02_eeprom_get(dev, MT_EE_NIC_CONF_1);
if (dev->mt76.chandef.chan->band == NL80211_BAND_2GHZ)
return val & MT_EE_NIC_CONF_1_LNA_EXT_2G;
@@ -70,4 +70,25 @@ mt76x2_has_ext_lna(struct mt76x02_dev *dev)
return val & MT_EE_NIC_CONF_1_LNA_EXT_5G;
}
+static inline bool
+mt76x2_temp_tx_alc_enabled(struct mt76x02_dev *dev)
+{
+ u16 val;
+
+ val = mt76x02_eeprom_get(dev, MT_EE_TX_POWER_EXT_PA_5G);
+ if (!(val & BIT(15)))
+ return false;
+
+ return mt76x02_eeprom_get(dev, MT_EE_NIC_CONF_1) &
+ MT_EE_NIC_CONF_1_TEMP_TX_ALC;
+}
+
+static inline bool
+mt76x2_tssi_enabled(struct mt76x02_dev *dev)
+{
+ return !mt76x2_temp_tx_alc_enabled(dev) &&
+ (mt76x02_eeprom_get(dev, MT_EE_NIC_CONF_1) &
+ MT_EE_NIC_CONF_1_TX_ALC_EN);
+}
+
#endif