Commit 37426fb6 authored by Lorenzo Bianconi's avatar Lorenzo Bianconi Committed by Felix Fietkau

mt76: move mac_work in mt76_dev

Move mac_work delayed work in mt76_dev data structure since
it is used by all drivers and it will be reused adding mac work to
mt7615
Signed-off-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
parent 41634aa8
...@@ -448,6 +448,7 @@ struct mt76_dev { ...@@ -448,6 +448,7 @@ struct mt76_dev {
int tx_dma_idx[4]; int tx_dma_idx[4];
struct tasklet_struct tx_tasklet; struct tasklet_struct tx_tasklet;
struct delayed_work mac_work;
wait_queue_head_t tx_wait; wait_queue_head_t tx_wait;
struct sk_buff_head status_list; struct sk_buff_head status_list;
......
...@@ -513,7 +513,7 @@ int mt7603_register_device(struct mt7603_dev *dev) ...@@ -513,7 +513,7 @@ int mt7603_register_device(struct mt7603_dev *dev)
spin_lock_init(&dev->ps_lock); spin_lock_init(&dev->ps_lock);
INIT_DELAYED_WORK(&dev->mac_work, mt7603_mac_work); INIT_DELAYED_WORK(&dev->mt76.mac_work, mt7603_mac_work);
tasklet_init(&dev->pre_tbtt_tasklet, mt7603_pre_tbtt_tasklet, tasklet_init(&dev->pre_tbtt_tasklet, mt7603_pre_tbtt_tasklet,
(unsigned long)dev); (unsigned long)dev);
......
...@@ -1667,7 +1667,7 @@ mt7603_false_cca_check(struct mt7603_dev *dev) ...@@ -1667,7 +1667,7 @@ mt7603_false_cca_check(struct mt7603_dev *dev)
void mt7603_mac_work(struct work_struct *work) void mt7603_mac_work(struct work_struct *work)
{ {
struct mt7603_dev *dev = container_of(work, struct mt7603_dev, struct mt7603_dev *dev = container_of(work, struct mt7603_dev,
mac_work.work); mt76.mac_work.work);
bool reset = false; bool reset = false;
mt76_tx_status_check(&dev->mt76, NULL, false); mt76_tx_status_check(&dev->mt76, NULL, false);
...@@ -1720,6 +1720,6 @@ void mt7603_mac_work(struct work_struct *work) ...@@ -1720,6 +1720,6 @@ void mt7603_mac_work(struct work_struct *work)
if (reset) if (reset)
mt7603_mac_watchdog_reset(dev); mt7603_mac_watchdog_reset(dev);
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->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));
} }
...@@ -16,7 +16,7 @@ mt7603_start(struct ieee80211_hw *hw) ...@@ -16,7 +16,7 @@ mt7603_start(struct ieee80211_hw *hw)
mt7603_mac_start(dev); mt7603_mac_start(dev);
dev->survey_time = ktime_get_boottime(); dev->survey_time = ktime_get_boottime();
set_bit(MT76_STATE_RUNNING, &dev->mt76.state); set_bit(MT76_STATE_RUNNING, &dev->mt76.state);
mt7603_mac_work(&dev->mac_work.work); mt7603_mac_work(&dev->mt76.mac_work.work);
return 0; return 0;
} }
...@@ -27,7 +27,7 @@ mt7603_stop(struct ieee80211_hw *hw) ...@@ -27,7 +27,7 @@ mt7603_stop(struct ieee80211_hw *hw)
struct mt7603_dev *dev = hw->priv; struct mt7603_dev *dev = hw->priv;
clear_bit(MT76_STATE_RUNNING, &dev->mt76.state); clear_bit(MT76_STATE_RUNNING, &dev->mt76.state);
cancel_delayed_work_sync(&dev->mac_work); cancel_delayed_work_sync(&dev->mt76.mac_work);
mt7603_mac_stop(dev); mt7603_mac_stop(dev);
} }
...@@ -132,7 +132,7 @@ mt7603_set_channel(struct mt7603_dev *dev, struct cfg80211_chan_def *def) ...@@ -132,7 +132,7 @@ mt7603_set_channel(struct mt7603_dev *dev, struct cfg80211_chan_def *def)
u8 bw = MT_BW_20; u8 bw = MT_BW_20;
bool failed = false; bool failed = false;
cancel_delayed_work_sync(&dev->mac_work); cancel_delayed_work_sync(&dev->mt76.mac_work);
mutex_lock(&dev->mt76.mutex); mutex_lock(&dev->mt76.mutex);
set_bit(MT76_RESET, &dev->mt76.state); set_bit(MT76_RESET, &dev->mt76.state);
...@@ -171,7 +171,7 @@ mt7603_set_channel(struct mt7603_dev *dev, struct cfg80211_chan_def *def) ...@@ -171,7 +171,7 @@ mt7603_set_channel(struct mt7603_dev *dev, struct cfg80211_chan_def *def)
mt76_txq_schedule_all(&dev->mt76); mt76_txq_schedule_all(&dev->mt76);
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mac_work, ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work,
MT7603_WATCHDOG_TIME); MT7603_WATCHDOG_TIME);
/* reset channel stats */ /* reset channel stats */
...@@ -189,7 +189,7 @@ mt7603_set_channel(struct mt7603_dev *dev, struct cfg80211_chan_def *def) ...@@ -189,7 +189,7 @@ mt7603_set_channel(struct mt7603_dev *dev, struct cfg80211_chan_def *def)
mutex_unlock(&dev->mt76.mutex); mutex_unlock(&dev->mt76.mutex);
if (failed) if (failed)
mt7603_mac_work(&dev->mac_work.work); mt7603_mac_work(&dev->mt76.mac_work.work);
return ret; return ret;
} }
......
...@@ -144,7 +144,6 @@ struct mt7603_dev { ...@@ -144,7 +144,6 @@ struct mt7603_dev {
unsigned int reset_cause[__RESET_CAUSE_MAX]; unsigned int reset_cause[__RESET_CAUSE_MAX];
struct delayed_work mac_work;
struct tasklet_struct pre_tbtt_tasklet; struct tasklet_struct pre_tbtt_tasklet;
}; };
......
...@@ -29,7 +29,7 @@ static int mt76x0e_start(struct ieee80211_hw *hw) ...@@ -29,7 +29,7 @@ static int mt76x0e_start(struct ieee80211_hw *hw)
mt76x02_mac_start(dev); mt76x02_mac_start(dev);
mt76x0_phy_calibrate(dev, true); mt76x0_phy_calibrate(dev, true);
ieee80211_queue_delayed_work(dev->mt76.hw, &dev->mac_work, ieee80211_queue_delayed_work(dev->mt76.hw, &dev->mt76.mac_work,
MT_MAC_WORK_INTERVAL); MT_MAC_WORK_INTERVAL);
ieee80211_queue_delayed_work(dev->mt76.hw, &dev->cal_work, ieee80211_queue_delayed_work(dev->mt76.hw, &dev->cal_work,
MT_CALIBRATE_INTERVAL); MT_CALIBRATE_INTERVAL);
...@@ -43,7 +43,7 @@ static int mt76x0e_start(struct ieee80211_hw *hw) ...@@ -43,7 +43,7 @@ static int mt76x0e_start(struct ieee80211_hw *hw)
static void mt76x0e_stop_hw(struct mt76x02_dev *dev) static void mt76x0e_stop_hw(struct mt76x02_dev *dev)
{ {
cancel_delayed_work_sync(&dev->cal_work); cancel_delayed_work_sync(&dev->cal_work);
cancel_delayed_work_sync(&dev->mac_work); cancel_delayed_work_sync(&dev->mt76.mac_work);
if (!mt76_poll(dev, MT_WPDMA_GLO_CFG, MT_WPDMA_GLO_CFG_TX_DMA_BUSY, if (!mt76_poll(dev, MT_WPDMA_GLO_CFG, MT_WPDMA_GLO_CFG_TX_DMA_BUSY,
0, 1000)) 0, 1000))
......
...@@ -85,7 +85,7 @@ static void mt76x0u_mac_stop(struct mt76x02_dev *dev) ...@@ -85,7 +85,7 @@ static void mt76x0u_mac_stop(struct mt76x02_dev *dev)
{ {
clear_bit(MT76_STATE_RUNNING, &dev->mt76.state); clear_bit(MT76_STATE_RUNNING, &dev->mt76.state);
cancel_delayed_work_sync(&dev->cal_work); cancel_delayed_work_sync(&dev->cal_work);
cancel_delayed_work_sync(&dev->mac_work); cancel_delayed_work_sync(&dev->mt76.mac_work);
mt76u_stop_stat_wk(&dev->mt76); mt76u_stop_stat_wk(&dev->mt76);
mt76x02u_exit_beacon_config(dev); mt76x02u_exit_beacon_config(dev);
...@@ -113,7 +113,7 @@ static int mt76x0u_start(struct ieee80211_hw *hw) ...@@ -113,7 +113,7 @@ static int mt76x0u_start(struct ieee80211_hw *hw)
goto out; goto out;
mt76x0_phy_calibrate(dev, true); mt76x0_phy_calibrate(dev, true);
ieee80211_queue_delayed_work(dev->mt76.hw, &dev->mac_work, ieee80211_queue_delayed_work(dev->mt76.hw, &dev->mt76.mac_work,
MT_MAC_WORK_INTERVAL); MT_MAC_WORK_INTERVAL);
ieee80211_queue_delayed_work(dev->mt76.hw, &dev->cal_work, ieee80211_queue_delayed_work(dev->mt76.hw, &dev->cal_work,
MT_CALIBRATE_INTERVAL); MT_CALIBRATE_INTERVAL);
......
...@@ -92,7 +92,6 @@ struct mt76x02_dev { ...@@ -92,7 +92,6 @@ struct mt76x02_dev {
struct tasklet_struct tx_tasklet; struct tasklet_struct tx_tasklet;
struct tasklet_struct pre_tbtt_tasklet; struct tasklet_struct pre_tbtt_tasklet;
struct delayed_work cal_work; struct delayed_work cal_work;
struct delayed_work mac_work;
struct delayed_work wdt_work; struct delayed_work wdt_work;
struct hrtimer pre_tbtt_timer; struct hrtimer pre_tbtt_timer;
......
...@@ -1029,7 +1029,7 @@ static void mt76x02_edcca_check(struct mt76x02_dev *dev) ...@@ -1029,7 +1029,7 @@ static void mt76x02_edcca_check(struct mt76x02_dev *dev)
void mt76x02_mac_work(struct work_struct *work) void mt76x02_mac_work(struct work_struct *work)
{ {
struct mt76x02_dev *dev = container_of(work, struct mt76x02_dev, struct mt76x02_dev *dev = container_of(work, struct mt76x02_dev,
mac_work.work); mt76.mac_work.work);
int i, idx; int i, idx;
mutex_lock(&dev->mt76.mutex); mutex_lock(&dev->mt76.mutex);
...@@ -1052,7 +1052,7 @@ void mt76x02_mac_work(struct work_struct *work) ...@@ -1052,7 +1052,7 @@ void mt76x02_mac_work(struct work_struct *work)
mt76_tx_status_check(&dev->mt76, NULL, false); mt76_tx_status_check(&dev->mt76, NULL, false);
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mac_work, ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work,
MT_MAC_WORK_INTERVAL); MT_MAC_WORK_INTERVAL);
} }
......
...@@ -132,7 +132,7 @@ void mt76x02_init_device(struct mt76x02_dev *dev) ...@@ -132,7 +132,7 @@ void mt76x02_init_device(struct mt76x02_dev *dev)
struct ieee80211_hw *hw = mt76_hw(dev); struct ieee80211_hw *hw = mt76_hw(dev);
struct wiphy *wiphy = hw->wiphy; struct wiphy *wiphy = hw->wiphy;
INIT_DELAYED_WORK(&dev->mac_work, mt76x02_mac_work); INIT_DELAYED_WORK(&dev->mt76.mac_work, mt76x02_mac_work);
hw->queues = 4; hw->queues = 4;
hw->max_rates = 1; hw->max_rates = 1;
......
...@@ -291,7 +291,7 @@ static int mt76x2_init_hardware(struct mt76x02_dev *dev) ...@@ -291,7 +291,7 @@ static int mt76x2_init_hardware(struct mt76x02_dev *dev)
void mt76x2_stop_hardware(struct mt76x02_dev *dev) void mt76x2_stop_hardware(struct mt76x02_dev *dev)
{ {
cancel_delayed_work_sync(&dev->cal_work); cancel_delayed_work_sync(&dev->cal_work);
cancel_delayed_work_sync(&dev->mac_work); cancel_delayed_work_sync(&dev->mt76.mac_work);
cancel_delayed_work_sync(&dev->wdt_work); cancel_delayed_work_sync(&dev->wdt_work);
mt76x02_mcu_set_radio_state(dev, false); mt76x02_mcu_set_radio_state(dev, false);
mt76x2_mac_stop(dev, false); mt76x2_mac_stop(dev, false);
......
...@@ -32,7 +32,7 @@ mt76x2_start(struct ieee80211_hw *hw) ...@@ -32,7 +32,7 @@ mt76x2_start(struct ieee80211_hw *hw)
if (ret) if (ret)
goto out; goto out;
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mac_work, ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work,
MT_MAC_WORK_INTERVAL); MT_MAC_WORK_INTERVAL);
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->wdt_work, ieee80211_queue_delayed_work(mt76_hw(dev), &dev->wdt_work,
MT_WATCHDOG_TIME); MT_WATCHDOG_TIME);
......
...@@ -246,7 +246,7 @@ void mt76x2u_stop_hw(struct mt76x02_dev *dev) ...@@ -246,7 +246,7 @@ void mt76x2u_stop_hw(struct mt76x02_dev *dev)
{ {
mt76u_stop_stat_wk(&dev->mt76); mt76u_stop_stat_wk(&dev->mt76);
cancel_delayed_work_sync(&dev->cal_work); cancel_delayed_work_sync(&dev->cal_work);
cancel_delayed_work_sync(&dev->mac_work); cancel_delayed_work_sync(&dev->mt76.mac_work);
mt76x2u_mac_stop(dev); mt76x2u_mac_stop(dev);
} }
......
...@@ -27,7 +27,7 @@ static int mt76x2u_start(struct ieee80211_hw *hw) ...@@ -27,7 +27,7 @@ static int mt76x2u_start(struct ieee80211_hw *hw)
if (ret) if (ret)
goto out; goto out;
ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mac_work, ieee80211_queue_delayed_work(mt76_hw(dev), &dev->mt76.mac_work,
MT_MAC_WORK_INTERVAL); MT_MAC_WORK_INTERVAL);
set_bit(MT76_STATE_RUNNING, &dev->mt76.state); set_bit(MT76_STATE_RUNNING, &dev->mt76.state);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment