mirror of
https://git.proxmox.com/git/mirror_ubuntu-kernels.git
synced 2025-12-08 05:34:14 +00:00
mt76: move mt76x02_sw_scan and mt76x02_sw_scan_complete in mt76x02-lib module
Move mt76x02_sw_scan and mt76x02_sw_scan_complete utility routines in mt76x02_util.c in order to be reused by mt76x0 and mt76x2u drivers and remove duplicated code Signed-off-by: Lorenzo Bianconi <lorenzo.bianconi@redhat.com> Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
parent
82b5c23941
commit
c2756a1c41
@ -127,24 +127,6 @@ void mt76x0_bss_info_changed(struct ieee80211_hw *hw,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(mt76x0_bss_info_changed);
|
EXPORT_SYMBOL_GPL(mt76x0_bss_info_changed);
|
||||||
|
|
||||||
void mt76x0_sw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
||||||
const u8 *mac_addr)
|
|
||||||
{
|
|
||||||
struct mt76x02_dev *dev = hw->priv;
|
|
||||||
|
|
||||||
set_bit(MT76_SCANNING, &dev->mt76.state);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(mt76x0_sw_scan);
|
|
||||||
|
|
||||||
void mt76x0_sw_scan_complete(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_vif *vif)
|
|
||||||
{
|
|
||||||
struct mt76x02_dev *dev = hw->priv;
|
|
||||||
|
|
||||||
clear_bit(MT76_SCANNING, &dev->mt76.state);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(mt76x0_sw_scan_complete);
|
|
||||||
|
|
||||||
int mt76x0_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
|
int mt76x0_set_rts_threshold(struct ieee80211_hw *hw, u32 value)
|
||||||
{
|
{
|
||||||
struct mt76x02_dev *dev = hw->priv;
|
struct mt76x02_dev *dev = hw->priv;
|
||||||
|
|||||||
@ -65,10 +65,6 @@ int mt76x0_config(struct ieee80211_hw *hw, u32 changed);
|
|||||||
void mt76x0_bss_info_changed(struct ieee80211_hw *hw,
|
void mt76x0_bss_info_changed(struct ieee80211_hw *hw,
|
||||||
struct ieee80211_vif *vif,
|
struct ieee80211_vif *vif,
|
||||||
struct ieee80211_bss_conf *info, u32 changed);
|
struct ieee80211_bss_conf *info, u32 changed);
|
||||||
void mt76x0_sw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
||||||
const u8 *mac_addr);
|
|
||||||
void mt76x0_sw_scan_complete(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_vif *vif);
|
|
||||||
int mt76x0_set_rts_threshold(struct ieee80211_hw *hw, u32 value);
|
int mt76x0_set_rts_threshold(struct ieee80211_hw *hw, u32 value);
|
||||||
|
|
||||||
/* PHY */
|
/* PHY */
|
||||||
|
|||||||
@ -80,8 +80,8 @@ static const struct ieee80211_ops mt76x0e_ops = {
|
|||||||
.sta_remove = mt76x02_sta_remove,
|
.sta_remove = mt76x02_sta_remove,
|
||||||
.set_key = mt76x02_set_key,
|
.set_key = mt76x02_set_key,
|
||||||
.conf_tx = mt76x02_conf_tx,
|
.conf_tx = mt76x02_conf_tx,
|
||||||
.sw_scan_start = mt76x0_sw_scan,
|
.sw_scan_start = mt76x02_sw_scan,
|
||||||
.sw_scan_complete = mt76x0_sw_scan_complete,
|
.sw_scan_complete = mt76x02_sw_scan_complete,
|
||||||
.ampdu_action = mt76x02_ampdu_action,
|
.ampdu_action = mt76x02_ampdu_action,
|
||||||
.sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
|
.sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
|
||||||
.wake_tx_queue = mt76_wake_tx_queue,
|
.wake_tx_queue = mt76_wake_tx_queue,
|
||||||
|
|||||||
@ -150,8 +150,8 @@ static const struct ieee80211_ops mt76x0u_ops = {
|
|||||||
.sta_remove = mt76x02_sta_remove,
|
.sta_remove = mt76x02_sta_remove,
|
||||||
.set_key = mt76x02_set_key,
|
.set_key = mt76x02_set_key,
|
||||||
.conf_tx = mt76x02_conf_tx,
|
.conf_tx = mt76x02_conf_tx,
|
||||||
.sw_scan_start = mt76x0_sw_scan,
|
.sw_scan_start = mt76x02_sw_scan,
|
||||||
.sw_scan_complete = mt76x0_sw_scan_complete,
|
.sw_scan_complete = mt76x02_sw_scan_complete,
|
||||||
.ampdu_action = mt76x02_ampdu_action,
|
.ampdu_action = mt76x02_ampdu_action,
|
||||||
.sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
|
.sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
|
||||||
.set_rts_threshold = mt76x0_set_rts_threshold,
|
.set_rts_threshold = mt76x0_set_rts_threshold,
|
||||||
|
|||||||
@ -147,6 +147,10 @@ int mt76x02_tx_prepare_skb(struct mt76_dev *mdev, void *txwi,
|
|||||||
struct sk_buff *skb, struct mt76_queue *q,
|
struct sk_buff *skb, struct mt76_queue *q,
|
||||||
struct mt76_wcid *wcid, struct ieee80211_sta *sta,
|
struct mt76_wcid *wcid, struct ieee80211_sta *sta,
|
||||||
u32 *tx_info);
|
u32 *tx_info);
|
||||||
|
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);
|
||||||
|
|
||||||
extern const u16 mt76x02_beacon_offsets[16];
|
extern const u16 mt76x02_beacon_offsets[16];
|
||||||
void mt76x02_set_beacon_offsets(struct mt76x02_dev *dev);
|
void mt76x02_set_beacon_offsets(struct mt76x02_dev *dev);
|
||||||
|
|||||||
@ -486,6 +486,28 @@ void mt76x02_remove_hdr_pad(struct sk_buff *skb, int len)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(mt76x02_remove_hdr_pad);
|
EXPORT_SYMBOL_GPL(mt76x02_remove_hdr_pad);
|
||||||
|
|
||||||
|
void mt76x02_sw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
|
const u8 *mac)
|
||||||
|
{
|
||||||
|
struct mt76x02_dev *dev = hw->priv;
|
||||||
|
|
||||||
|
if (mt76_is_mmio(dev))
|
||||||
|
tasklet_disable(&dev->pre_tbtt_tasklet);
|
||||||
|
set_bit(MT76_SCANNING, &dev->mt76.state);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(mt76x02_sw_scan);
|
||||||
|
|
||||||
|
void mt76x02_sw_scan_complete(struct ieee80211_hw *hw,
|
||||||
|
struct ieee80211_vif *vif)
|
||||||
|
{
|
||||||
|
struct mt76x02_dev *dev = hw->priv;
|
||||||
|
|
||||||
|
clear_bit(MT76_SCANNING, &dev->mt76.state);
|
||||||
|
if (mt76_is_mmio(dev))
|
||||||
|
tasklet_enable(&dev->pre_tbtt_tasklet);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(mt76x02_sw_scan_complete);
|
||||||
|
|
||||||
const u16 mt76x02_beacon_offsets[16] = {
|
const u16 mt76x02_beacon_offsets[16] = {
|
||||||
/* 1024 byte per beacon */
|
/* 1024 byte per beacon */
|
||||||
0xc000,
|
0xc000,
|
||||||
|
|||||||
@ -175,25 +175,6 @@ mt76x2_sta_ps(struct mt76_dev *mdev, struct ieee80211_sta *sta, bool ps)
|
|||||||
mt76x02_mac_wcid_set_drop(dev, idx, ps);
|
mt76x02_mac_wcid_set_drop(dev, idx, ps);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
mt76x2_sw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
||||||
const u8 *mac)
|
|
||||||
{
|
|
||||||
struct mt76x02_dev *dev = hw->priv;
|
|
||||||
|
|
||||||
tasklet_disable(&dev->pre_tbtt_tasklet);
|
|
||||||
set_bit(MT76_SCANNING, &dev->mt76.state);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
mt76x2_sw_scan_complete(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
|
|
||||||
{
|
|
||||||
struct mt76x02_dev *dev = hw->priv;
|
|
||||||
|
|
||||||
clear_bit(MT76_SCANNING, &dev->mt76.state);
|
|
||||||
tasklet_enable(&dev->pre_tbtt_tasklet);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
mt76x2_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
mt76x2_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
u32 queues, bool drop)
|
u32 queues, bool drop)
|
||||||
@ -292,8 +273,8 @@ const struct ieee80211_ops mt76x2_ops = {
|
|||||||
.sta_remove = mt76x02_sta_remove,
|
.sta_remove = mt76x02_sta_remove,
|
||||||
.set_key = mt76x02_set_key,
|
.set_key = mt76x02_set_key,
|
||||||
.conf_tx = mt76x02_conf_tx,
|
.conf_tx = mt76x02_conf_tx,
|
||||||
.sw_scan_start = mt76x2_sw_scan,
|
.sw_scan_start = mt76x02_sw_scan,
|
||||||
.sw_scan_complete = mt76x2_sw_scan_complete,
|
.sw_scan_complete = mt76x02_sw_scan_complete,
|
||||||
.flush = mt76x2_flush,
|
.flush = mt76x2_flush,
|
||||||
.ampdu_action = mt76x02_ampdu_action,
|
.ampdu_action = mt76x02_ampdu_action,
|
||||||
.get_txpower = mt76x2_get_txpower,
|
.get_txpower = mt76x2_get_txpower,
|
||||||
|
|||||||
@ -143,23 +143,6 @@ mt76x2u_config(struct ieee80211_hw *hw, u32 changed)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
mt76x2u_sw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
||||||
const u8 *mac)
|
|
||||||
{
|
|
||||||
struct mt76x02_dev *dev = hw->priv;
|
|
||||||
|
|
||||||
set_bit(MT76_SCANNING, &dev->mt76.state);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
mt76x2u_sw_scan_complete(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
|
|
||||||
{
|
|
||||||
struct mt76x02_dev *dev = hw->priv;
|
|
||||||
|
|
||||||
clear_bit(MT76_SCANNING, &dev->mt76.state);
|
|
||||||
}
|
|
||||||
|
|
||||||
const struct ieee80211_ops mt76x2u_ops = {
|
const struct ieee80211_ops mt76x2u_ops = {
|
||||||
.tx = mt76x02_tx,
|
.tx = mt76x02_tx,
|
||||||
.start = mt76x2u_start,
|
.start = mt76x2u_start,
|
||||||
@ -175,7 +158,7 @@ const struct ieee80211_ops mt76x2u_ops = {
|
|||||||
.bss_info_changed = mt76x2u_bss_info_changed,
|
.bss_info_changed = mt76x2u_bss_info_changed,
|
||||||
.configure_filter = mt76x02_configure_filter,
|
.configure_filter = mt76x02_configure_filter,
|
||||||
.conf_tx = mt76x02_conf_tx,
|
.conf_tx = mt76x02_conf_tx,
|
||||||
.sw_scan_start = mt76x2u_sw_scan,
|
.sw_scan_start = mt76x02_sw_scan,
|
||||||
.sw_scan_complete = mt76x2u_sw_scan_complete,
|
.sw_scan_complete = mt76x02_sw_scan_complete,
|
||||||
.sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
|
.sta_rate_tbl_update = mt76x02_sta_rate_tbl_update,
|
||||||
};
|
};
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user