mt76: add support for an extra wiphy in the main tx path

This is preparation for supporting multiple wiphys per device to support the
concurrent dual-band feature of MT7615D

Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
Felix Fietkau 2019-10-11 23:27:20 +02:00
parent bfc394dd65
commit 9fba6d077f
11 changed files with 45 additions and 37 deletions

View File

@ -720,15 +720,15 @@ static inline bool mt76_is_skb_pktid(u8 pktid)
} }
void mt76_rx(struct mt76_dev *dev, enum mt76_rxq_id q, struct sk_buff *skb); void mt76_rx(struct mt76_dev *dev, enum mt76_rxq_id q, struct sk_buff *skb);
void mt76_tx(struct mt76_dev *dev, struct ieee80211_sta *sta, void mt76_tx(struct mt76_phy *dev, struct ieee80211_sta *sta,
struct mt76_wcid *wcid, struct sk_buff *skb); struct mt76_wcid *wcid, struct sk_buff *skb);
void mt76_txq_init(struct mt76_dev *dev, struct ieee80211_txq *txq); void mt76_txq_init(struct mt76_dev *dev, struct ieee80211_txq *txq);
void mt76_txq_remove(struct mt76_dev *dev, struct ieee80211_txq *txq); void mt76_txq_remove(struct mt76_dev *dev, struct ieee80211_txq *txq);
void mt76_wake_tx_queue(struct ieee80211_hw *hw, struct ieee80211_txq *txq); void mt76_wake_tx_queue(struct ieee80211_hw *hw, struct ieee80211_txq *txq);
void mt76_stop_tx_queues(struct mt76_dev *dev, struct ieee80211_sta *sta, void mt76_stop_tx_queues(struct mt76_dev *dev, struct ieee80211_sta *sta,
bool send_bar); bool send_bar);
void mt76_txq_schedule(struct mt76_dev *dev, enum mt76_txq_id qid); void mt76_txq_schedule(struct mt76_phy *phy, enum mt76_txq_id qid);
void mt76_txq_schedule_all(struct mt76_dev *dev); void mt76_txq_schedule_all(struct mt76_phy *phy);
void mt76_tx_tasklet(unsigned long data); void mt76_tx_tasklet(unsigned long data);
void mt76_release_buffered_frames(struct ieee80211_hw *hw, void mt76_release_buffered_frames(struct ieee80211_hw *hw,
struct ieee80211_sta *sta, struct ieee80211_sta *sta,

View File

@ -1392,7 +1392,7 @@ static void mt7603_mac_watchdog_reset(struct mt7603_dev *dev)
set_bit(MT76_RESET, &dev->mt76.state); set_bit(MT76_RESET, &dev->mt76.state);
/* lock/unlock all queues to ensure that no tx is pending */ /* lock/unlock all queues to ensure that no tx is pending */
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
tasklet_disable(&dev->mt76.tx_tasklet); tasklet_disable(&dev->mt76.tx_tasklet);
tasklet_disable(&dev->mt76.pre_tbtt_tasklet); tasklet_disable(&dev->mt76.pre_tbtt_tasklet);
@ -1456,7 +1456,7 @@ static void mt7603_mac_watchdog_reset(struct mt7603_dev *dev)
napi_schedule(&dev->mt76.napi[1]); napi_schedule(&dev->mt76.napi[1]);
ieee80211_wake_queues(dev->mt76.hw); ieee80211_wake_queues(dev->mt76.hw);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
} }
static u32 mt7603_dma_debug(struct mt7603_dev *dev, u8 index) static u32 mt7603_dma_debug(struct mt7603_dev *dev, u8 index)

View File

@ -178,7 +178,7 @@ mt7603_set_channel(struct mt7603_dev *dev, struct cfg80211_chan_def *def)
clear_bit(MT76_RESET, &dev->mt76.state); clear_bit(MT76_RESET, &dev->mt76.state);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work, ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work,
msecs_to_jiffies(MT7603_WATCHDOG_TIME)); msecs_to_jiffies(MT7603_WATCHDOG_TIME));
@ -667,7 +667,7 @@ static void mt7603_tx(struct ieee80211_hw *hw,
wcid = &mvif->sta.wcid; wcid = &mvif->sta.wcid;
} }
mt76_tx(&dev->mt76, control->sta, wcid, skb); mt76_tx(&dev->mphy, control->sta, wcid, skb);
} }
const struct ieee80211_ops mt7603_ops = { const struct ieee80211_ops mt7603_ops = {

View File

@ -171,7 +171,7 @@ static int mt7615_set_channel(struct mt7615_dev *dev)
clear_bit(MT76_RESET, &dev->mt76.state); clear_bit(MT76_RESET, &dev->mt76.state);
mutex_unlock(&dev->mt76.mutex); mutex_unlock(&dev->mt76.mutex);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work, ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work,
MT7615_WATCHDOG_TIME); MT7615_WATCHDOG_TIME);
return ret; return ret;
@ -458,7 +458,7 @@ static void mt7615_tx(struct ieee80211_hw *hw,
wcid = &mvif->sta.wcid; wcid = &mvif->sta.wcid;
} }
mt76_tx(&dev->mt76, control->sta, wcid, skb); mt76_tx(&dev->mphy, control->sta, wcid, skb);
} }
static int mt7615_set_rts_threshold(struct ieee80211_hw *hw, u32 val) static int mt7615_set_rts_threshold(struct ieee80211_hw *hw, u32 val)

View File

@ -28,7 +28,7 @@ mt76x0_set_channel(struct mt76x02_dev *dev, struct cfg80211_chan_def *chandef)
} }
mt76x02_pre_tbtt_enable(dev, true); mt76x02_pre_tbtt_enable(dev, true);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
} }
int mt76x0_config(struct ieee80211_hw *hw, u32 changed) int mt76x0_config(struct ieee80211_hw *hw, u32 changed)

View File

@ -151,7 +151,7 @@ static void mt76x02_tx_tasklet(unsigned long data)
mt76x02_mac_poll_tx_status(dev, false); mt76x02_mac_poll_tx_status(dev, false);
mt76x02_process_tx_status_fifo(dev); mt76x02_process_tx_status_fifo(dev);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
} }
static int mt76x02_poll_tx(struct napi_struct *napi, int budget) static int mt76x02_poll_tx(struct napi_struct *napi, int budget)
@ -514,7 +514,7 @@ static void mt76x02_watchdog_reset(struct mt76x02_dev *dev)
ieee80211_restart_hw(dev->mt76.hw); ieee80211_restart_hw(dev->mt76.hw);
} else { } else {
ieee80211_wake_queues(dev->mt76.hw); ieee80211_wake_queues(dev->mt76.hw);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
} }
} }

View File

@ -28,7 +28,7 @@ void mt76x02_tx(struct ieee80211_hw *hw, struct ieee80211_tx_control *control,
wcid = &mvif->group_wcid; wcid = &mvif->group_wcid;
} }
mt76_tx(&dev->mt76, control->sta, wcid, skb); mt76_tx(&dev->mphy, control->sta, wcid, skb);
} }
EXPORT_SYMBOL_GPL(mt76x02_tx); EXPORT_SYMBOL_GPL(mt76x02_tx);

View File

@ -63,7 +63,7 @@ mt76x2_set_channel(struct mt76x02_dev *dev, struct cfg80211_chan_def *chandef)
tasklet_enable(&dev->dfs_pd.dfs_tasklet); tasklet_enable(&dev->dfs_pd.dfs_tasklet);
tasklet_enable(&dev->mt76.pre_tbtt_tasklet); tasklet_enable(&dev->mt76.pre_tbtt_tasklet);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
return ret; return ret;
} }

View File

@ -56,7 +56,7 @@ mt76x2u_set_channel(struct mt76x02_dev *dev,
mutex_unlock(&dev->mt76.mutex); mutex_unlock(&dev->mt76.mutex);
mt76x02_pre_tbtt_enable(dev, true); mt76x02_pre_tbtt_enable(dev, true);
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mphy);
return err; return err;
} }

View File

@ -245,9 +245,10 @@ void mt76_tx_complete_skb(struct mt76_dev *dev, struct sk_buff *skb)
EXPORT_SYMBOL_GPL(mt76_tx_complete_skb); EXPORT_SYMBOL_GPL(mt76_tx_complete_skb);
void void
mt76_tx(struct mt76_dev *dev, struct ieee80211_sta *sta, mt76_tx(struct mt76_phy *phy, struct ieee80211_sta *sta,
struct mt76_wcid *wcid, struct sk_buff *skb) struct mt76_wcid *wcid, struct sk_buff *skb)
{ {
struct mt76_dev *dev = phy->dev;
struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
struct mt76_queue *q; struct mt76_queue *q;
@ -282,7 +283,7 @@ mt76_tx(struct mt76_dev *dev, struct ieee80211_sta *sta,
dev->queue_ops->kick(dev, q); dev->queue_ops->kick(dev, q);
if (q->queued > q->ndesc - 8 && !q->stopped) { if (q->queued > q->ndesc - 8 && !q->stopped) {
ieee80211_stop_queue(dev->hw, skb_get_queue_mapping(skb)); ieee80211_stop_queue(phy->hw, skb_get_queue_mapping(skb));
q->stopped = true; q->stopped = true;
} }
@ -291,7 +292,7 @@ mt76_tx(struct mt76_dev *dev, struct ieee80211_sta *sta,
EXPORT_SYMBOL_GPL(mt76_tx); EXPORT_SYMBOL_GPL(mt76_tx);
static struct sk_buff * static struct sk_buff *
mt76_txq_dequeue(struct mt76_dev *dev, struct mt76_txq *mtxq, bool ps) mt76_txq_dequeue(struct mt76_phy *phy, struct mt76_txq *mtxq, bool ps)
{ {
struct ieee80211_txq *txq = mtxq_to_txq(mtxq); struct ieee80211_txq *txq = mtxq_to_txq(mtxq);
struct sk_buff *skb; struct sk_buff *skb;
@ -306,7 +307,7 @@ mt76_txq_dequeue(struct mt76_dev *dev, struct mt76_txq *mtxq, bool ps)
return skb; return skb;
} }
skb = ieee80211_tx_dequeue(dev->hw, txq); skb = ieee80211_tx_dequeue(phy->hw, txq);
if (!skb) if (!skb)
return NULL; return NULL;
@ -335,7 +336,8 @@ mt76_release_buffered_frames(struct ieee80211_hw *hw, struct ieee80211_sta *sta,
enum ieee80211_frame_release_type reason, enum ieee80211_frame_release_type reason,
bool more_data) bool more_data)
{ {
struct mt76_dev *dev = hw->priv; struct mt76_phy *phy = hw->priv;
struct mt76_dev *dev = phy->dev;
struct sk_buff *last_skb = NULL; struct sk_buff *last_skb = NULL;
struct mt76_queue *hwq = dev->q_tx[MT_TXQ_PSD].q; struct mt76_queue *hwq = dev->q_tx[MT_TXQ_PSD].q;
int i; int i;
@ -350,7 +352,7 @@ mt76_release_buffered_frames(struct ieee80211_hw *hw, struct ieee80211_sta *sta,
continue; continue;
do { do {
skb = mt76_txq_dequeue(dev, mtxq, true); skb = mt76_txq_dequeue(phy, mtxq, true);
if (!skb) if (!skb)
break; break;
@ -377,9 +379,10 @@ mt76_release_buffered_frames(struct ieee80211_hw *hw, struct ieee80211_sta *sta,
EXPORT_SYMBOL_GPL(mt76_release_buffered_frames); EXPORT_SYMBOL_GPL(mt76_release_buffered_frames);
static int static int
mt76_txq_send_burst(struct mt76_dev *dev, struct mt76_sw_queue *sq, mt76_txq_send_burst(struct mt76_phy *phy, struct mt76_sw_queue *sq,
struct mt76_txq *mtxq) struct mt76_txq *mtxq)
{ {
struct mt76_dev *dev = phy->dev;
struct ieee80211_txq *txq = mtxq_to_txq(mtxq); struct ieee80211_txq *txq = mtxq_to_txq(mtxq);
enum mt76_txq_id qid = mt76_txq_get_qid(txq); enum mt76_txq_id qid = mt76_txq_get_qid(txq);
struct mt76_wcid *wcid = mtxq->wcid; struct mt76_wcid *wcid = mtxq->wcid;
@ -395,7 +398,7 @@ mt76_txq_send_burst(struct mt76_dev *dev, struct mt76_sw_queue *sq,
if (test_bit(MT_WCID_FLAG_PS, &wcid->flags)) if (test_bit(MT_WCID_FLAG_PS, &wcid->flags))
return 0; return 0;
skb = mt76_txq_dequeue(dev, mtxq, false); skb = mt76_txq_dequeue(phy, mtxq, false);
if (!skb) if (!skb)
return 0; return 0;
@ -426,7 +429,7 @@ mt76_txq_send_burst(struct mt76_dev *dev, struct mt76_sw_queue *sq,
if (test_bit(MT76_RESET, &dev->state)) if (test_bit(MT76_RESET, &dev->state))
return -EBUSY; return -EBUSY;
skb = mt76_txq_dequeue(dev, mtxq, false); skb = mt76_txq_dequeue(phy, mtxq, false);
if (!skb) if (!skb)
break; break;
@ -464,8 +467,9 @@ mt76_txq_send_burst(struct mt76_dev *dev, struct mt76_sw_queue *sq,
} }
static int static int
mt76_txq_schedule_list(struct mt76_dev *dev, enum mt76_txq_id qid) mt76_txq_schedule_list(struct mt76_phy *phy, enum mt76_txq_id qid)
{ {
struct mt76_dev *dev = phy->dev;
struct mt76_sw_queue *sq = &dev->q_tx[qid]; struct mt76_sw_queue *sq = &dev->q_tx[qid];
struct mt76_queue *hwq = sq->q; struct mt76_queue *hwq = sq->q;
struct ieee80211_txq *txq; struct ieee80211_txq *txq;
@ -483,7 +487,7 @@ mt76_txq_schedule_list(struct mt76_dev *dev, enum mt76_txq_id qid)
break; break;
} }
txq = ieee80211_next_txq(dev->hw, qid); txq = ieee80211_next_txq(phy->hw, qid);
if (!txq) if (!txq)
break; break;
@ -505,8 +509,8 @@ mt76_txq_schedule_list(struct mt76_dev *dev, enum mt76_txq_id qid)
spin_lock_bh(&hwq->lock); spin_lock_bh(&hwq->lock);
} }
ret += mt76_txq_send_burst(dev, sq, mtxq); ret += mt76_txq_send_burst(phy, sq, mtxq);
ieee80211_return_txq(dev->hw, txq, ieee80211_return_txq(phy->hw, txq,
!skb_queue_empty(&mtxq->retry_q)); !skb_queue_empty(&mtxq->retry_q));
} }
spin_unlock_bh(&hwq->lock); spin_unlock_bh(&hwq->lock);
@ -514,8 +518,9 @@ mt76_txq_schedule_list(struct mt76_dev *dev, enum mt76_txq_id qid)
return ret; return ret;
} }
void mt76_txq_schedule(struct mt76_dev *dev, enum mt76_txq_id qid) void mt76_txq_schedule(struct mt76_phy *phy, enum mt76_txq_id qid)
{ {
struct mt76_dev *dev = phy->dev;
struct mt76_sw_queue *sq = &dev->q_tx[qid]; struct mt76_sw_queue *sq = &dev->q_tx[qid];
int len; int len;
@ -528,21 +533,21 @@ void mt76_txq_schedule(struct mt76_dev *dev, enum mt76_txq_id qid)
rcu_read_lock(); rcu_read_lock();
do { do {
ieee80211_txq_schedule_start(dev->hw, qid); ieee80211_txq_schedule_start(phy->hw, qid);
len = mt76_txq_schedule_list(dev, qid); len = mt76_txq_schedule_list(phy, qid);
ieee80211_txq_schedule_end(dev->hw, qid); ieee80211_txq_schedule_end(phy->hw, qid);
} while (len > 0); } while (len > 0);
rcu_read_unlock(); rcu_read_unlock();
} }
EXPORT_SYMBOL_GPL(mt76_txq_schedule); EXPORT_SYMBOL_GPL(mt76_txq_schedule);
void mt76_txq_schedule_all(struct mt76_dev *dev) void mt76_txq_schedule_all(struct mt76_phy *phy)
{ {
int i; int i;
for (i = 0; i <= MT_TXQ_BK; i++) for (i = 0; i <= MT_TXQ_BK; i++)
mt76_txq_schedule(dev, i); mt76_txq_schedule(phy, i);
} }
EXPORT_SYMBOL_GPL(mt76_txq_schedule_all); EXPORT_SYMBOL_GPL(mt76_txq_schedule_all);
@ -550,7 +555,9 @@ void mt76_tx_tasklet(unsigned long data)
{ {
struct mt76_dev *dev = (struct mt76_dev *)data; struct mt76_dev *dev = (struct mt76_dev *)data;
mt76_txq_schedule_all(dev); mt76_txq_schedule_all(&dev->phy);
if (dev->phy2)
mt76_txq_schedule_all(dev->phy2);
} }
void mt76_stop_tx_queues(struct mt76_dev *dev, struct ieee80211_sta *sta, void mt76_stop_tx_queues(struct mt76_dev *dev, struct ieee80211_sta *sta,
@ -578,7 +585,8 @@ EXPORT_SYMBOL_GPL(mt76_stop_tx_queues);
void mt76_wake_tx_queue(struct ieee80211_hw *hw, struct ieee80211_txq *txq) void mt76_wake_tx_queue(struct ieee80211_hw *hw, struct ieee80211_txq *txq)
{ {
struct mt76_dev *dev = hw->priv; struct mt76_phy *phy = hw->priv;
struct mt76_dev *dev = phy->dev;
if (!test_bit(MT76_STATE_RUNNING, &dev->state)) if (!test_bit(MT76_STATE_RUNNING, &dev->state))
return; return;

View File

@ -694,7 +694,7 @@ static void mt76u_tx_tasklet(unsigned long data)
spin_unlock_bh(&q->lock); spin_unlock_bh(&q->lock);
mt76_txq_schedule(dev, i); mt76_txq_schedule(&dev->phy, i);
if (!test_and_set_bit(MT76_READING_STATS, &dev->state)) if (!test_and_set_bit(MT76_READING_STATS, &dev->state))
queue_work(dev->usb.stat_wq, &dev->usb.stat_work); queue_work(dev->usb.stat_wq, &dev->usb.stat_work);