From 6aac54298b88050bfff7789baa88cbf12a6b5c61 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Michael=20B=C3=BCsch?= <mb@bu3sch.de>
Date: Wed, 16 Nov 2011 22:26:12 +0000
Subject: [PATCH] p54spi: Lock fixes

SVN-Revision: 29200
---
 .../mac80211/patches/850-p54spi-lock-fix.patch  | 12 ++++++++++++
 .../mac80211/patches/851-p54spi-mutex-fix.patch | 17 +++++++++++++++++
 2 files changed, 29 insertions(+)
 create mode 100644 package/mac80211/patches/850-p54spi-lock-fix.patch
 create mode 100644 package/mac80211/patches/851-p54spi-mutex-fix.patch

diff --git a/package/mac80211/patches/850-p54spi-lock-fix.patch b/package/mac80211/patches/850-p54spi-lock-fix.patch
new file mode 100644
index 0000000000..9ab15dd555
--- /dev/null
+++ b/package/mac80211/patches/850-p54spi-lock-fix.patch
@@ -0,0 +1,12 @@
+Index: compat-wireless-2011-11-04/drivers/net/wireless/p54/p54spi.c
+===================================================================
+--- compat-wireless-2011-11-04.orig/drivers/net/wireless/p54/p54spi.c	2011-11-05 20:30:04.000000000 +0100
++++ compat-wireless-2011-11-04/drivers/net/wireless/p54/p54spi.c	2011-11-16 22:12:03.648829886 +0100
+@@ -656,6 +656,7 @@ static int __devinit p54spi_probe(struct
+ 	init_completion(&priv->fw_comp);
+ 	INIT_LIST_HEAD(&priv->tx_pending);
+ 	mutex_init(&priv->mutex);
++	spin_lock_init(&priv->tx_lock);
+ 	SET_IEEE80211_DEV(hw, &spi->dev);
+ 	priv->common.open = p54spi_op_start;
+ 	priv->common.stop = p54spi_op_stop;
diff --git a/package/mac80211/patches/851-p54spi-mutex-fix.patch b/package/mac80211/patches/851-p54spi-mutex-fix.patch
new file mode 100644
index 0000000000..27019de654
--- /dev/null
+++ b/package/mac80211/patches/851-p54spi-mutex-fix.patch
@@ -0,0 +1,17 @@
+Index: compat-wireless-2011-11-04/drivers/net/wireless/p54/p54spi.c
+===================================================================
+--- compat-wireless-2011-11-04.orig/drivers/net/wireless/p54/p54spi.c	2011-11-16 22:12:03.648829886 +0100
++++ compat-wireless-2011-11-04/drivers/net/wireless/p54/p54spi.c	2011-11-16 22:15:28.931976935 +0100
+@@ -581,11 +581,7 @@ static void p54spi_op_stop(struct ieee80
+ 	struct p54s_priv *priv = dev->priv;
+ 	unsigned long flags;
+ 
+-	if (mutex_lock_interruptible(&priv->mutex)) {
+-		/* FIXME: how to handle this error? */
+-		return;
+-	}
+-
++	mutex_lock(&priv->mutex);
+ 	WARN_ON(priv->fw_state != FW_STATE_READY);
+ 
+ 	cancel_work_sync(&priv->work);
-- 
GitLab