staging: r8723au: pwrctrl_priv: Replace semaphore lock with mutex
authorBinoy Jayan <binoy.jayan@linaro.org>
Wed, 8 Jun 2016 07:40:54 +0000 (13:10 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 21 Aug 2016 16:30:35 +0000 (18:30 +0200)
The semaphore 'lock' in pwrctrl_priv is a simple mutex, so it should
be written as one. Semaphores are going away in the future.

Signed-off-by: Binoy Jayan <binoy.jayan@linaro.org>
Reviewed-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/rtl8723au/core/rtw_pwrctrl.c
drivers/staging/rtl8723au/include/rtw_pwrctrl.h
drivers/staging/rtl8723au/os_dep/usb_intf.c

index 7488a104935b037427adbab657bbabb6607f9a3d..2d43958f6b3b8520de0857b8ccb94eaf71486796 100644 (file)
@@ -14,6 +14,7 @@
  ******************************************************************************/
 #define _RTW_PWRCTRL_C_
 
+#include <linux/mutex.h>
 #include <osdep_service.h>
 #include <drv_types.h>
 #include <osdep_intf.h>
@@ -27,7 +28,7 @@ void ips_enter23a(struct rtw_adapter *padapter)
 {
        struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
 
-       down(&pwrpriv->lock);
+       mutex_lock(&pwrpriv->mutex_lock);
 
        pwrpriv->bips_processing = true;
 
@@ -50,7 +51,7 @@ void ips_enter23a(struct rtw_adapter *padapter)
        }
        pwrpriv->bips_processing = false;
 
-       up(&pwrpriv->lock);
+       mutex_unlock(&pwrpriv->mutex_lock);
 }
 
 int ips_leave23a(struct rtw_adapter *padapter)
@@ -61,7 +62,7 @@ int ips_leave23a(struct rtw_adapter *padapter)
        int result = _SUCCESS;
        int keyid;
 
-       down(&pwrpriv->lock);
+       mutex_lock(&pwrpriv->mutex_lock);
 
        if (pwrpriv->rf_pwrstate == rf_off && !pwrpriv->bips_processing) {
                pwrpriv->bips_processing = true;
@@ -106,7 +107,7 @@ int ips_leave23a(struct rtw_adapter *padapter)
                pwrpriv->bpower_saving = false;
        }
 
-       up(&pwrpriv->lock);
+       mutex_unlock(&pwrpriv->mutex_lock);
 
        return result;
 }
@@ -423,7 +424,7 @@ void rtw_init_pwrctrl_priv23a(struct rtw_adapter *padapter)
 {
        struct pwrctrl_priv *pwrctrlpriv = &padapter->pwrctrlpriv;
 
-       sema_init(&pwrctrlpriv->lock, 1);
+       mutex_init(&pwrctrlpriv->mutex_lock);
        pwrctrlpriv->rf_pwrstate = rf_on;
        pwrctrlpriv->ips_enter23a_cnts = 0;
        pwrctrlpriv->ips_leave23a_cnts = 0;
index 599fed9b365dcc3cd3b4eb57bde62e8058094fe3..699b9f3cc36525d4d8693537ecbe49cbf0bc55a4 100644 (file)
@@ -15,6 +15,7 @@
 #ifndef __RTW_PWRCTRL_H_
 #define __RTW_PWRCTRL_H_
 
+#include <linux/mutex.h>
 #include <osdep_service.h>
 #include <drv_types.h>
 
@@ -149,7 +150,7 @@ enum { /*  for ips_mode */
 };
 
 struct pwrctrl_priv {
-       struct semaphore lock;
+       struct mutex mutex_lock;
        volatile u8 rpwm; /* requested power state for fw */
        volatile u8 cpwm; /* fw current power state. updated when 1.
                           * read from HCPWM 2. driver lowers power level
index cf83efffbffd0f679f2932d7fb60f18c3713a6ed..fa7dda55201cdec7392af151ca7d8bdce95f4965 100644 (file)
@@ -14,6 +14,7 @@
  ******************************************************************************/
 #define _HCI_INTF_C_
 
+#include <linux/mutex.h>
 #include <osdep_service.h>
 #include <drv_types.h>
 #include <recv_osdep.h>
@@ -291,7 +292,7 @@ static int rtw_suspend(struct usb_interface *pusb_intf, pm_message_t message)
        rtw_cancel_all_timer23a(padapter);
        LeaveAllPowerSaveMode23a(padapter);
 
-       down(&pwrpriv->lock);
+       mutex_lock(&pwrpriv->mutex_lock);
        /* padapter->net_closed = true; */
        /* s1. */
        if (pnetdev) {
@@ -321,7 +322,7 @@ static int rtw_suspend(struct usb_interface *pusb_intf, pm_message_t message)
        rtw_free_network_queue23a(padapter);
 
        rtw_dev_unload(padapter);
-       up(&pwrpriv->lock);
+       mutex_unlock(&pwrpriv->mutex_lock);
 
        if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
                rtw_cfg80211_indicate_scan_done(
@@ -353,20 +354,20 @@ static int rtw_resume(struct usb_interface *pusb_intf)
        pnetdev = padapter->pnetdev;
        pwrpriv = &padapter->pwrctrlpriv;
 
-       down(&pwrpriv->lock);
+       mutex_lock(&pwrpriv->mutex_lock);
        rtw_reset_drv_sw23a(padapter);
        pwrpriv->bkeepfwalive = false;
 
        DBG_8723A("bkeepfwalive(%x)\n", pwrpriv->bkeepfwalive);
        if (pm_netdev_open23a(pnetdev, true) != 0) {
-               up(&pwrpriv->lock);
+               mutex_unlock(&pwrpriv->mutex_lock);
                goto exit;
        }
 
        netif_device_attach(pnetdev);
        netif_carrier_on(pnetdev);
 
-       up(&pwrpriv->lock);
+       mutex_unlock(&pwrpriv->mutex_lock);
 
        if (padapter->pid[1] != 0) {
                DBG_8723A("pid[1]:%d\n", padapter->pid[1]);