Commit 03488826 authored by David chosrova's avatar David chosrova Committed by David S. Miller

[IRDA]: sti/cli removal from EP7211 IrDA driver

This patch replaces the deprecated sti/cli routines with the corresponding
spin_lock ones.
Signed-off-by: default avatarDavid chosrova <david.chosrova@libertysurf.fr>
Signed-off-by: default avatarSamuel Ortiz <samuel.ortiz@nokia.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 0ed79c9b
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/tty.h> #include <linux/tty.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/spinlock.h>
#include <net/irda/irda.h> #include <net/irda/irda.h>
#include <net/irda/irda_device.h> #include <net/irda/irda_device.h>
...@@ -23,6 +24,8 @@ static void ep7211_ir_close(dongle_t *self); ...@@ -23,6 +24,8 @@ static void ep7211_ir_close(dongle_t *self);
static int ep7211_ir_change_speed(struct irda_task *task); static int ep7211_ir_change_speed(struct irda_task *task);
static int ep7211_ir_reset(struct irda_task *task); static int ep7211_ir_reset(struct irda_task *task);
static DEFINE_SPINLOCK(ep7211_lock);
static struct dongle_reg dongle = { static struct dongle_reg dongle = {
.type = IRDA_EP7211_IR, .type = IRDA_EP7211_IR,
.open = ep7211_ir_open, .open = ep7211_ir_open,
...@@ -36,7 +39,7 @@ static void ep7211_ir_open(dongle_t *self, struct qos_info *qos) ...@@ -36,7 +39,7 @@ static void ep7211_ir_open(dongle_t *self, struct qos_info *qos)
{ {
unsigned int syscon1, flags; unsigned int syscon1, flags;
save_flags(flags); cli(); spin_lock_irqsave(&ep7211_lock, flags);
/* Turn on the SIR encoder. */ /* Turn on the SIR encoder. */
syscon1 = clps_readl(SYSCON1); syscon1 = clps_readl(SYSCON1);
...@@ -46,14 +49,14 @@ static void ep7211_ir_open(dongle_t *self, struct qos_info *qos) ...@@ -46,14 +49,14 @@ static void ep7211_ir_open(dongle_t *self, struct qos_info *qos)
/* XXX: We should disable modem status interrupts on the first /* XXX: We should disable modem status interrupts on the first
UART (interrupt #14). */ UART (interrupt #14). */
restore_flags(flags); spin_unlock_irqrestore(&ep7211_lock, flags);
} }
static void ep7211_ir_close(dongle_t *self) static void ep7211_ir_close(dongle_t *self)
{ {
unsigned int syscon1, flags; unsigned int syscon1, flags;
save_flags(flags); cli(); spin_lock_irqsave(&ep7211_lock, flags);
/* Turn off the SIR encoder. */ /* Turn off the SIR encoder. */
syscon1 = clps_readl(SYSCON1); syscon1 = clps_readl(SYSCON1);
...@@ -63,7 +66,7 @@ static void ep7211_ir_close(dongle_t *self) ...@@ -63,7 +66,7 @@ static void ep7211_ir_close(dongle_t *self)
/* XXX: If we've disabled the modem status interrupts, we should /* XXX: If we've disabled the modem status interrupts, we should
reset them back to their original state. */ reset them back to their original state. */
restore_flags(flags); spin_unlock_irqrestore(&ep7211_lock, flags);
} }
/* /*
......
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