OSDN Git Service

mt76: mt7615: add .set_tsf callback
authorRyder Lee <ryder.lee@mediatek.com>
Thu, 18 Jun 2020 04:41:48 +0000 (12:41 +0800)
committerFelix Fietkau <nbd@nbd.name>
Tue, 21 Jul 2020 17:01:15 +0000 (19:01 +0200)
It is useful for IBSS Mesh to adjust t_clockdrift.

Signed-off-by: Ryder Lee <ryder.lee@mediatek.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt7615/main.c
drivers/net/wireless/mediatek/mt76/mt7615/regs.h

index e6dbd70..f8ce485 100644 (file)
@@ -741,6 +741,26 @@ mt7615_get_tsf(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
 }
 
 static void
+mt7615_set_tsf(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
+              u64 timestamp)
+{
+       struct mt7615_dev *dev = mt7615_hw_dev(hw);
+       union {
+               u64 t64;
+               u32 t32[2];
+       } tsf = { .t64 = timestamp, };
+
+       mutex_lock(&dev->mt76.mutex);
+
+       mt76_wr(dev, MT_LPON_UTTR0, tsf.t32[0]);
+       mt76_wr(dev, MT_LPON_UTTR1, tsf.t32[1]);
+       /* TSF software overwrite */
+       mt76_set(dev, MT_LPON_T0CR, MT_LPON_T0CR_WRITE);
+
+       mutex_unlock(&dev->mt76.mutex);
+}
+
+static void
 mt7615_set_coverage_class(struct ieee80211_hw *hw, s16 coverage_class)
 {
        struct mt7615_phy *phy = mt7615_hw_phy(hw);
@@ -1038,6 +1058,7 @@ const struct ieee80211_ops mt7615_ops = {
        .channel_switch_beacon = mt7615_channel_switch_beacon,
        .get_stats = mt7615_get_stats,
        .get_tsf = mt7615_get_tsf,
+       .set_tsf = mt7615_set_tsf,
        .get_survey = mt76_get_survey,
        .get_antenna = mt76_get_antenna,
        .set_antenna = mt7615_set_antenna,
index aee433a..f0b36b1 100644 (file)
@@ -417,6 +417,7 @@ enum mt7615_reg_base {
 
 #define MT_LPON_T0CR                   MT_LPON(0x010)
 #define MT_LPON_T0CR_MODE              GENMASK(1, 0)
+#define MT_LPON_T0CR_WRITE             BIT(0)
 
 #define MT_LPON_UTTR0                  MT_LPON(0x018)
 #define MT_LPON_UTTR1                  MT_LPON(0x01c)