Commit 9419b6a2 authored by Vladimir Kondratiev's avatar Vladimir Kondratiev Committed by Kalle Valo

wil6210: use bitmap API for "status"

wil->status used as bitmap; use DECLARE_BITMAP for it.
Signed-off-by: default avatarVladimir Kondratiev <qca_vkondrat@qca.qualcomm.com>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent 327755fb
...@@ -162,7 +162,7 @@ int wil_cid_fill_sinfo(struct wil6210_priv *wil, int cid, ...@@ -162,7 +162,7 @@ int wil_cid_fill_sinfo(struct wil6210_priv *wil, int cid,
sinfo->tx_packets = stats->tx_packets; sinfo->tx_packets = stats->tx_packets;
sinfo->tx_failed = stats->tx_errors; sinfo->tx_failed = stats->tx_errors;
if (test_bit(wil_status_fwconnected, &wil->status)) { if (test_bit(wil_status_fwconnected, wil->status)) {
sinfo->filled |= STATION_INFO_SIGNAL; sinfo->filled |= STATION_INFO_SIGNAL;
sinfo->signal = reply.evt.sqi; sinfo->signal = reply.evt.sqi;
} }
...@@ -282,7 +282,7 @@ static int wil_cfg80211_scan(struct wiphy *wiphy, ...@@ -282,7 +282,7 @@ static int wil_cfg80211_scan(struct wiphy *wiphy,
} }
/* FW don't support scan after connection attempt */ /* FW don't support scan after connection attempt */
if (test_bit(wil_status_dontscan, &wil->status)) { if (test_bit(wil_status_dontscan, wil->status)) {
wil_err(wil, "Can't scan now\n"); wil_err(wil, "Can't scan now\n");
return -EBUSY; return -EBUSY;
} }
...@@ -362,8 +362,8 @@ static int wil_cfg80211_connect(struct wiphy *wiphy, ...@@ -362,8 +362,8 @@ static int wil_cfg80211_connect(struct wiphy *wiphy,
int ch; int ch;
int rc = 0; int rc = 0;
if (test_bit(wil_status_fwconnecting, &wil->status) || if (test_bit(wil_status_fwconnecting, wil->status) ||
test_bit(wil_status_fwconnected, &wil->status)) test_bit(wil_status_fwconnected, wil->status))
return -EALREADY; return -EALREADY;
wil_print_connect_params(wil, sme); wil_print_connect_params(wil, sme);
...@@ -450,7 +450,7 @@ static int wil_cfg80211_connect(struct wiphy *wiphy, ...@@ -450,7 +450,7 @@ static int wil_cfg80211_connect(struct wiphy *wiphy,
memcpy(conn.bssid, bss->bssid, ETH_ALEN); memcpy(conn.bssid, bss->bssid, ETH_ALEN);
memcpy(conn.dst_mac, bss->bssid, ETH_ALEN); memcpy(conn.dst_mac, bss->bssid, ETH_ALEN);
set_bit(wil_status_fwconnecting, &wil->status); set_bit(wil_status_fwconnecting, wil->status);
rc = wmi_send(wil, WMI_CONNECT_CMDID, &conn, sizeof(conn)); rc = wmi_send(wil, WMI_CONNECT_CMDID, &conn, sizeof(conn));
if (rc == 0) { if (rc == 0) {
...@@ -458,7 +458,7 @@ static int wil_cfg80211_connect(struct wiphy *wiphy, ...@@ -458,7 +458,7 @@ static int wil_cfg80211_connect(struct wiphy *wiphy,
mod_timer(&wil->connect_timer, mod_timer(&wil->connect_timer,
jiffies + msecs_to_jiffies(2000)); jiffies + msecs_to_jiffies(2000));
} else { } else {
clear_bit(wil_status_fwconnecting, &wil->status); clear_bit(wil_status_fwconnecting, wil->status);
} }
out: out:
......
...@@ -1313,7 +1313,7 @@ static void wil6210_debugfs_init_isr(struct wil6210_priv *wil, ...@@ -1313,7 +1313,7 @@ static void wil6210_debugfs_init_isr(struct wil6210_priv *wil,
/* fields in struct wil6210_priv */ /* fields in struct wil6210_priv */
static const struct dbg_off dbg_wil_off[] = { static const struct dbg_off dbg_wil_off[] = {
WIL_FIELD(secure_pcp, S_IRUGO | S_IWUSR, doff_u32), WIL_FIELD(secure_pcp, S_IRUGO | S_IWUSR, doff_u32),
WIL_FIELD(status, S_IRUGO | S_IWUSR, doff_ulong), WIL_FIELD(status[0], S_IRUGO | S_IWUSR, doff_ulong),
WIL_FIELD(fw_version, S_IRUGO, doff_u32), WIL_FIELD(fw_version, S_IRUGO, doff_u32),
WIL_FIELD(hw_version, S_IRUGO, doff_x32), WIL_FIELD(hw_version, S_IRUGO, doff_x32),
WIL_FIELD(recovery_count, S_IRUGO, doff_u32), WIL_FIELD(recovery_count, S_IRUGO, doff_u32),
......
...@@ -102,7 +102,7 @@ static void wil6210_mask_irq_pseudo(struct wil6210_priv *wil) ...@@ -102,7 +102,7 @@ static void wil6210_mask_irq_pseudo(struct wil6210_priv *wil)
iowrite32(WIL6210_IRQ_DISABLE, wil->csr + iowrite32(WIL6210_IRQ_DISABLE, wil->csr +
HOSTADDR(RGF_DMA_PSEUDO_CAUSE_MASK_SW)); HOSTADDR(RGF_DMA_PSEUDO_CAUSE_MASK_SW));
clear_bit(wil_status_irqen, &wil->status); clear_bit(wil_status_irqen, wil->status);
} }
void wil6210_unmask_irq_tx(struct wil6210_priv *wil) void wil6210_unmask_irq_tx(struct wil6210_priv *wil)
...@@ -130,7 +130,7 @@ static void wil6210_unmask_irq_pseudo(struct wil6210_priv *wil) ...@@ -130,7 +130,7 @@ static void wil6210_unmask_irq_pseudo(struct wil6210_priv *wil)
{ {
wil_dbg_irq(wil, "%s()\n", __func__); wil_dbg_irq(wil, "%s()\n", __func__);
set_bit(wil_status_irqen, &wil->status); set_bit(wil_status_irqen, wil->status);
iowrite32(WIL6210_IRQ_PSEUDO_MASK, wil->csr + iowrite32(WIL6210_IRQ_PSEUDO_MASK, wil->csr +
HOSTADDR(RGF_DMA_PSEUDO_CAUSE_MASK_SW)); HOSTADDR(RGF_DMA_PSEUDO_CAUSE_MASK_SW));
...@@ -198,8 +198,8 @@ static irqreturn_t wil6210_irq_rx(int irq, void *cookie) ...@@ -198,8 +198,8 @@ static irqreturn_t wil6210_irq_rx(int irq, void *cookie)
"of overflow\" interrupt\n"); "of overflow\" interrupt\n");
isr &= ~(BIT_DMA_EP_RX_ICR_RX_DONE | BIT_DMA_EP_RX_ICR_RX_HTRSH); isr &= ~(BIT_DMA_EP_RX_ICR_RX_DONE | BIT_DMA_EP_RX_ICR_RX_HTRSH);
if (test_bit(wil_status_reset_done, &wil->status)) { if (test_bit(wil_status_reset_done, wil->status)) {
if (test_bit(wil_status_napi_en, &wil->status)) { if (test_bit(wil_status_napi_en, wil->status)) {
wil_dbg_txrx(wil, "NAPI(Rx) schedule\n"); wil_dbg_txrx(wil, "NAPI(Rx) schedule\n");
need_unmask = false; need_unmask = false;
napi_schedule(&wil->napi_rx); napi_schedule(&wil->napi_rx);
...@@ -248,7 +248,7 @@ static irqreturn_t wil6210_irq_tx(int irq, void *cookie) ...@@ -248,7 +248,7 @@ static irqreturn_t wil6210_irq_tx(int irq, void *cookie)
isr &= ~BIT_DMA_EP_TX_ICR_TX_DONE; isr &= ~BIT_DMA_EP_TX_ICR_TX_DONE;
/* clear also all VRING interrupts */ /* clear also all VRING interrupts */
isr &= ~(BIT(25) - 1UL); isr &= ~(BIT(25) - 1UL);
if (test_bit(wil_status_reset_done, &wil->status)) { if (test_bit(wil_status_reset_done, wil->status)) {
wil_dbg_txrx(wil, "NAPI(Tx) schedule\n"); wil_dbg_txrx(wil, "NAPI(Tx) schedule\n");
need_unmask = false; need_unmask = false;
napi_schedule(&wil->napi_tx); napi_schedule(&wil->napi_tx);
...@@ -310,7 +310,7 @@ static irqreturn_t wil6210_irq_misc(int irq, void *cookie) ...@@ -310,7 +310,7 @@ static irqreturn_t wil6210_irq_misc(int irq, void *cookie)
if (isr & ISR_MISC_FW_ERROR) { if (isr & ISR_MISC_FW_ERROR) {
wil_err(wil, "Firmware error detected\n"); wil_err(wil, "Firmware error detected\n");
clear_bit(wil_status_fwready, &wil->status); clear_bit(wil_status_fwready, wil->status);
/* /*
* do not clear @isr here - we do 2-nd part in thread * do not clear @isr here - we do 2-nd part in thread
* there, user space get notified, and it should be done * there, user space get notified, and it should be done
...@@ -321,7 +321,7 @@ static irqreturn_t wil6210_irq_misc(int irq, void *cookie) ...@@ -321,7 +321,7 @@ static irqreturn_t wil6210_irq_misc(int irq, void *cookie)
if (isr & ISR_MISC_FW_READY) { if (isr & ISR_MISC_FW_READY) {
wil_dbg_irq(wil, "IRQ: FW ready\n"); wil_dbg_irq(wil, "IRQ: FW ready\n");
wil_cache_mbox_regs(wil); wil_cache_mbox_regs(wil);
set_bit(wil_status_reset_done, &wil->status); set_bit(wil_status_reset_done, wil->status);
/** /**
* Actual FW ready indicated by the * Actual FW ready indicated by the
* WMI_FW_READY_EVENTID * WMI_FW_READY_EVENTID
...@@ -394,7 +394,7 @@ static irqreturn_t wil6210_thread_irq(int irq, void *cookie) ...@@ -394,7 +394,7 @@ static irqreturn_t wil6210_thread_irq(int irq, void *cookie)
*/ */
static int wil6210_debug_irq_mask(struct wil6210_priv *wil, u32 pseudo_cause) static int wil6210_debug_irq_mask(struct wil6210_priv *wil, u32 pseudo_cause)
{ {
if (!test_bit(wil_status_irqen, &wil->status)) { if (!test_bit(wil_status_irqen, wil->status)) {
u32 icm_rx = wil_ioread32_and_clear(wil->csr + u32 icm_rx = wil_ioread32_and_clear(wil->csr +
HOSTADDR(RGF_DMA_EP_RX_ICR) + HOSTADDR(RGF_DMA_EP_RX_ICR) +
offsetof(struct RGF_ICR, ICM)); offsetof(struct RGF_ICR, ICM));
......
...@@ -217,16 +217,16 @@ static void _wil6210_disconnect(struct wil6210_priv *wil, const u8 *bssid, ...@@ -217,16 +217,16 @@ static void _wil6210_disconnect(struct wil6210_priv *wil, const u8 *bssid,
case NL80211_IFTYPE_STATION: case NL80211_IFTYPE_STATION:
case NL80211_IFTYPE_P2P_CLIENT: case NL80211_IFTYPE_P2P_CLIENT:
wil_link_off(wil); wil_link_off(wil);
if (test_bit(wil_status_fwconnected, &wil->status)) { if (test_bit(wil_status_fwconnected, wil->status)) {
clear_bit(wil_status_fwconnected, &wil->status); clear_bit(wil_status_fwconnected, wil->status);
cfg80211_disconnected(ndev, reason_code, cfg80211_disconnected(ndev, reason_code,
NULL, 0, GFP_KERNEL); NULL, 0, GFP_KERNEL);
} else if (test_bit(wil_status_fwconnecting, &wil->status)) { } else if (test_bit(wil_status_fwconnecting, wil->status)) {
cfg80211_connect_result(ndev, bssid, NULL, 0, NULL, 0, cfg80211_connect_result(ndev, bssid, NULL, 0, NULL, 0,
WLAN_STATUS_UNSPECIFIED_FAILURE, WLAN_STATUS_UNSPECIFIED_FAILURE,
GFP_KERNEL); GFP_KERNEL);
} }
clear_bit(wil_status_fwconnecting, &wil->status); clear_bit(wil_status_fwconnecting, wil->status);
break; break;
default: default:
break; break;
...@@ -259,7 +259,7 @@ static void wil_scan_timer_fn(ulong x) ...@@ -259,7 +259,7 @@ static void wil_scan_timer_fn(ulong x)
{ {
struct wil6210_priv *wil = (void *)x; struct wil6210_priv *wil = (void *)x;
clear_bit(wil_status_fwready, &wil->status); clear_bit(wil_status_fwready, wil->status);
wil_err(wil, "Scan timeout detected, start fw error recovery\n"); wil_err(wil, "Scan timeout detected, start fw error recovery\n");
wil->recovery_state = fw_recovery_pending; wil->recovery_state = fw_recovery_pending;
schedule_work(&wil->fw_error_worker); schedule_work(&wil->fw_error_worker);
...@@ -654,12 +654,13 @@ int wil_reset(struct wil6210_priv *wil) ...@@ -654,12 +654,13 @@ int wil_reset(struct wil6210_priv *wil)
wil_dbg_misc(wil, "%s()\n", __func__); wil_dbg_misc(wil, "%s()\n", __func__);
WARN_ON(!mutex_is_locked(&wil->mutex)); WARN_ON(!mutex_is_locked(&wil->mutex));
WARN_ON(test_bit(wil_status_napi_en, &wil->status)); WARN_ON(test_bit(wil_status_napi_en, wil->status));
cancel_work_sync(&wil->disconnect_worker); cancel_work_sync(&wil->disconnect_worker);
wil6210_disconnect(wil, NULL, WLAN_REASON_DEAUTH_LEAVING, false); wil6210_disconnect(wil, NULL, WLAN_REASON_DEAUTH_LEAVING, false);
wil->status = 0; /* prevent NAPI from being scheduled */ /* prevent NAPI from being scheduled */
bitmap_zero(wil->status, wil_status_last);
if (wil->scan_request) { if (wil->scan_request) {
wil_dbg_misc(wil, "Abort scan_request 0x%p\n", wil_dbg_misc(wil, "Abort scan_request 0x%p\n",
...@@ -798,7 +799,7 @@ int __wil_up(struct wil6210_priv *wil) ...@@ -798,7 +799,7 @@ int __wil_up(struct wil6210_priv *wil)
wil_dbg_misc(wil, "NAPI enable\n"); wil_dbg_misc(wil, "NAPI enable\n");
napi_enable(&wil->napi_rx); napi_enable(&wil->napi_rx);
napi_enable(&wil->napi_tx); napi_enable(&wil->napi_tx);
set_bit(wil_status_napi_en, &wil->status); set_bit(wil_status_napi_en, wil->status);
if (wil->platform_ops.bus_request) if (wil->platform_ops.bus_request)
wil->platform_ops.bus_request(wil->platform_handle, wil->platform_ops.bus_request(wil->platform_handle,
...@@ -831,7 +832,7 @@ int __wil_down(struct wil6210_priv *wil) ...@@ -831,7 +832,7 @@ int __wil_down(struct wil6210_priv *wil)
wil->platform_ops.bus_request(wil->platform_handle, 0); wil->platform_ops.bus_request(wil->platform_handle, 0);
wil_disable_irq(wil); wil_disable_irq(wil);
if (test_and_clear_bit(wil_status_napi_en, &wil->status)) { if (test_and_clear_bit(wil_status_napi_en, wil->status)) {
napi_disable(&wil->napi_rx); napi_disable(&wil->napi_rx);
napi_disable(&wil->napi_tx); napi_disable(&wil->napi_tx);
wil_dbg_misc(wil, "NAPI disable\n"); wil_dbg_misc(wil, "NAPI disable\n");
...@@ -846,15 +847,15 @@ int __wil_down(struct wil6210_priv *wil) ...@@ -846,15 +847,15 @@ int __wil_down(struct wil6210_priv *wil)
wil->scan_request = NULL; wil->scan_request = NULL;
} }
if (test_bit(wil_status_fwconnected, &wil->status) || if (test_bit(wil_status_fwconnected, wil->status) ||
test_bit(wil_status_fwconnecting, &wil->status)) test_bit(wil_status_fwconnecting, wil->status))
wmi_send(wil, WMI_DISCONNECT_CMDID, NULL, 0); wmi_send(wil, WMI_DISCONNECT_CMDID, NULL, 0);
/* make sure wil is idle (not connected) */ /* make sure wil is idle (not connected) */
mutex_unlock(&wil->mutex); mutex_unlock(&wil->mutex);
while (iter--) { while (iter--) {
int idle = !test_bit(wil_status_fwconnected, &wil->status) && int idle = !test_bit(wil_status_fwconnected, wil->status) &&
!test_bit(wil_status_fwconnecting, &wil->status); !test_bit(wil_status_fwconnecting, wil->status);
if (idle) if (idle)
break; break;
msleep(WAIT_FOR_DISCONNECT_INTERVAL_MS); msleep(WAIT_FOR_DISCONNECT_INTERVAL_MS);
......
...@@ -726,7 +726,7 @@ void wil_vring_fini_tx(struct wil6210_priv *wil, int id) ...@@ -726,7 +726,7 @@ void wil_vring_fini_tx(struct wil6210_priv *wil, int id)
/* make sure NAPI won't touch this vring */ /* make sure NAPI won't touch this vring */
wil->vring_tx_data[id].enabled = 0; wil->vring_tx_data[id].enabled = 0;
if (test_bit(wil_status_napi_en, &wil->status)) if (test_bit(wil_status_napi_en, wil->status))
napi_synchronize(&wil->napi_tx); napi_synchronize(&wil->napi_tx);
wil_vring_free(wil, vring, 1); wil_vring_free(wil, vring, 1);
...@@ -1038,14 +1038,14 @@ netdev_tx_t wil_start_xmit(struct sk_buff *skb, struct net_device *ndev) ...@@ -1038,14 +1038,14 @@ netdev_tx_t wil_start_xmit(struct sk_buff *skb, struct net_device *ndev)
int rc; int rc;
wil_dbg_txrx(wil, "%s()\n", __func__); wil_dbg_txrx(wil, "%s()\n", __func__);
if (!test_bit(wil_status_fwready, &wil->status)) { if (!test_bit(wil_status_fwready, wil->status)) {
if (!pr_once_fw) { if (!pr_once_fw) {
wil_err(wil, "FW not ready\n"); wil_err(wil, "FW not ready\n");
pr_once_fw = true; pr_once_fw = true;
} }
goto drop; goto drop;
} }
if (!test_bit(wil_status_fwconnected, &wil->status)) { if (!test_bit(wil_status_fwconnected, wil->status)) {
wil_err(wil, "FW not connected\n"); wil_err(wil, "FW not connected\n");
goto drop; goto drop;
} }
......
...@@ -341,6 +341,7 @@ enum { /* for wil6210_priv.status */ ...@@ -341,6 +341,7 @@ enum { /* for wil6210_priv.status */
wil_status_reset_done, wil_status_reset_done,
wil_status_irqen, /* FIXME: interrupts enabled - for debug */ wil_status_irqen, /* FIXME: interrupts enabled - for debug */
wil_status_napi_en, /* NAPI enabled protected by wil->mutex */ wil_status_napi_en, /* NAPI enabled protected by wil->mutex */
wil_status_last /* keep last */
}; };
struct pci_dev; struct pci_dev;
...@@ -448,7 +449,7 @@ struct wil6210_priv { ...@@ -448,7 +449,7 @@ struct wil6210_priv {
int n_msi; int n_msi;
struct wireless_dev *wdev; struct wireless_dev *wdev;
void __iomem *csr; void __iomem *csr;
ulong status; DECLARE_BITMAP(status, wil_status_last);
u32 fw_version; u32 fw_version;
u32 hw_version; u32 hw_version;
struct wil_board *board; struct wil_board *board;
......
...@@ -202,7 +202,7 @@ static int __wmi_send(struct wil6210_priv *wil, u16 cmdid, void *buf, u16 len) ...@@ -202,7 +202,7 @@ static int __wmi_send(struct wil6210_priv *wil, u16 cmdid, void *buf, u16 len)
might_sleep(); might_sleep();
if (!test_bit(wil_status_fwready, &wil->status)) { if (!test_bit(wil_status_fwready, wil->status)) {
wil_err(wil, "WMI: cannot send command while FW not ready\n"); wil_err(wil, "WMI: cannot send command while FW not ready\n");
return -EAGAIN; return -EAGAIN;
} }
...@@ -305,7 +305,7 @@ static void wmi_evt_fw_ready(struct wil6210_priv *wil, int id, void *d, ...@@ -305,7 +305,7 @@ static void wmi_evt_fw_ready(struct wil6210_priv *wil, int id, void *d,
wil_dbg_wmi(wil, "WMI: got FW ready event\n"); wil_dbg_wmi(wil, "WMI: got FW ready event\n");
wil_set_recovery_state(wil, fw_recovery_idle); wil_set_recovery_state(wil, fw_recovery_idle);
set_bit(wil_status_fwready, &wil->status); set_bit(wil_status_fwready, wil->status);
/* let the reset sequence continue */ /* let the reset sequence continue */
complete(&wil->wmi_ready); complete(&wil->wmi_ready);
} }
...@@ -443,7 +443,7 @@ static void wmi_evt_connect(struct wil6210_priv *wil, int id, void *d, int len) ...@@ -443,7 +443,7 @@ static void wmi_evt_connect(struct wil6210_priv *wil, int id, void *d, int len)
if ((wdev->iftype == NL80211_IFTYPE_STATION) || if ((wdev->iftype == NL80211_IFTYPE_STATION) ||
(wdev->iftype == NL80211_IFTYPE_P2P_CLIENT)) { (wdev->iftype == NL80211_IFTYPE_P2P_CLIENT)) {
if (!test_bit(wil_status_fwconnecting, &wil->status)) { if (!test_bit(wil_status_fwconnecting, wil->status)) {
wil_err(wil, "Not in connecting state\n"); wil_err(wil, "Not in connecting state\n");
return; return;
} }
...@@ -467,8 +467,8 @@ static void wmi_evt_connect(struct wil6210_priv *wil, int id, void *d, int len) ...@@ -467,8 +467,8 @@ static void wmi_evt_connect(struct wil6210_priv *wil, int id, void *d, int len)
cfg80211_new_sta(ndev, evt->bssid, &sinfo, GFP_KERNEL); cfg80211_new_sta(ndev, evt->bssid, &sinfo, GFP_KERNEL);
} }
clear_bit(wil_status_fwconnecting, &wil->status); clear_bit(wil_status_fwconnecting, wil->status);
set_bit(wil_status_fwconnected, &wil->status); set_bit(wil_status_fwconnected, wil->status);
/* FIXME FW can transmit only ucast frames to peer */ /* FIXME FW can transmit only ucast frames to peer */
/* FIXME real ring_id instead of hard coded 0 */ /* FIXME real ring_id instead of hard coded 0 */
...@@ -726,7 +726,7 @@ void wmi_recv_cmd(struct wil6210_priv *wil) ...@@ -726,7 +726,7 @@ void wmi_recv_cmd(struct wil6210_priv *wil)
ulong flags; ulong flags;
unsigned n; unsigned n;
if (!test_bit(wil_status_reset_done, &wil->status)) { if (!test_bit(wil_status_reset_done, wil->status)) {
wil_err(wil, "Reset in progress. Cannot handle WMI event\n"); wil_err(wil, "Reset in progress. Cannot handle WMI event\n");
return; return;
} }
......
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