mt76: move mt76x02_get_txpower to mt76 core
authorFelix Fietkau <nbd@nbd.name>
Thu, 6 Dec 2018 13:27:34 +0000 (14:27 +0100)
committerFelix Fietkau <nbd@nbd.name>
Thu, 17 Jan 2019 13:50:15 +0000 (14:50 +0100)
It will be reused by mt7603 later

Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mac80211.c
drivers/net/wireless/mediatek/mt76/mt76.h
drivers/net/wireless/mediatek/mt76/mt76x0/pci.c
drivers/net/wireless/mediatek/mt76/mt76x0/usb.c
drivers/net/wireless/mediatek/mt76/mt76x02.h
drivers/net/wireless/mediatek/mt76/mt76x02_util.c
drivers/net/wireless/mediatek/mt76/mt76x2/pci_main.c
drivers/net/wireless/mediatek/mt76/mt76x2/usb_main.c

index 3d976ac4cb4108e4ec9c50ae6f29cd2be4f7d05e..467b5a692ed130a3ff59b49ff26702b9003df3c2 100644 (file)
@@ -710,3 +710,21 @@ int mt76_sta_state(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        return 0;
 }
 EXPORT_SYMBOL_GPL(mt76_sta_state);
+
+int mt76_get_txpower(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
+                    int *dbm)
+{
+       struct mt76_dev *dev = hw->priv;
+       int n_chains = __sw_hweight8(dev->antenna_mask);
+
+       *dbm = dev->txpower_cur / 2;
+
+       /* convert from per-chain power to combined
+        * output on 2x2 devices
+        */
+       if (n_chains > 1)
+               *dbm += 3;
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(mt76_get_txpower);
index 8d56ab97abe3d33988534ceb2c362ec1ea069765..16b342f63d292e2a60da29d342c009bbe3ca5524 100644 (file)
@@ -680,6 +680,9 @@ int mt76_sta_state(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
 
 struct ieee80211_sta *mt76_rx_convert(struct sk_buff *skb);
 
+int mt76_get_txpower(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
+                    int *dbm);
+
 /* internal */
 void mt76_tx_free(struct mt76_dev *dev);
 struct mt76_txwi_cache *mt76_get_txwi(struct mt76_dev *dev);
index 720b05e325a5bd67aa2f9afeceadfcd755950044..1472c8699b29a19d3ab96c95f6c7e38cc477ffb6 100644 (file)
@@ -99,7 +99,7 @@ static const struct ieee80211_ops mt76x0e_ops = {
        .sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
        .wake_tx_queue = mt76_wake_tx_queue,
        .get_survey = mt76_get_survey,
-       .get_txpower = mt76x02_get_txpower,
+       .get_txpower = mt76_get_txpower,
        .flush = mt76x0e_flush,
        .set_tim = mt76x0e_set_tim,
        .release_buffered_frames = mt76_release_buffered_frames,
index 0e6b43bb4678a9cd01d7883f5c6c37cf8006a9cb..f66e1b2f0980ca380b73c41ced936659f08890be 100644 (file)
@@ -155,7 +155,7 @@ static const struct ieee80211_ops mt76x0u_ops = {
        .sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
        .set_rts_threshold = mt76x02_set_rts_threshold,
        .wake_tx_queue = mt76_wake_tx_queue,
-       .get_txpower = mt76x02_get_txpower,
+       .get_txpower = mt76_get_txpower,
 };
 
 static int mt76x0u_register_device(struct mt76x02_dev *dev)
index d8bd0509a790f517e83a60d6d1b3c02e1eda1aa6..6d96766a6ed389382e68f482d4813f3e54c768df 100644 (file)
@@ -172,8 +172,6 @@ void mt76x02_sw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
                     const u8 *mac);
 void mt76x02_sw_scan_complete(struct ieee80211_hw *hw,
                              struct ieee80211_vif *vif);
-int mt76x02_get_txpower(struct ieee80211_hw *hw,
-                       struct ieee80211_vif *vif, int *dbm);
 void mt76x02_sta_ps(struct mt76_dev *dev, struct ieee80211_sta *sta, bool ps);
 void mt76x02_bss_info_changed(struct ieee80211_hw *hw,
                              struct ieee80211_vif *vif,
index d80c8eb5a0ec332184392ff45bf55a9dcee3480c..59f50a957cd5724005692db039ac3d35636f15c1 100644 (file)
@@ -607,24 +607,6 @@ void mt76x02_sw_scan_complete(struct ieee80211_hw *hw,
 }
 EXPORT_SYMBOL_GPL(mt76x02_sw_scan_complete);
 
-int mt76x02_get_txpower(struct ieee80211_hw *hw,
-                       struct ieee80211_vif *vif, int *dbm)
-{
-       struct mt76x02_dev *dev = hw->priv;
-       u8 nstreams = dev->mt76.chainmask & 0xf;
-
-       *dbm = dev->mt76.txpower_cur / 2;
-
-       /* convert from per-chain power to combined
-        * output on 2x2 devices
-        */
-       if (nstreams > 1)
-               *dbm += 3;
-
-       return 0;
-}
-EXPORT_SYMBOL_GPL(mt76x02_get_txpower);
-
 void mt76x02_sta_ps(struct mt76_dev *mdev, struct ieee80211_sta *sta,
                    bool ps)
 {
index 6a87b88eb036fbdb24886cdd02b8f22e1e082fe8..06a26a152ba421df6c623e22b5b6f9c99d816e5e 100644 (file)
@@ -191,7 +191,7 @@ const struct ieee80211_ops mt76x2_ops = {
        .sw_scan_complete = mt76x02_sw_scan_complete,
        .flush = mt76x2_flush,
        .ampdu_action = mt76x02_ampdu_action,
-       .get_txpower = mt76x02_get_txpower,
+       .get_txpower = mt76_get_txpower,
        .wake_tx_queue = mt76_wake_tx_queue,
        .sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
        .release_buffered_frames = mt76_release_buffered_frames,
index 2b48cc51a30d5ad624c3bfbda253521fb48b5831..286c7f451090348128d0b5fa3c6210b3e408c0e0 100644 (file)
@@ -138,5 +138,5 @@ const struct ieee80211_ops mt76x2u_ops = {
        .sw_scan_start = mt76x02_sw_scan,
        .sw_scan_complete = mt76x02_sw_scan_complete,
        .sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
-       .get_txpower = mt76x02_get_txpower,
+       .get_txpower = mt76_get_txpower,
 };