]> git.karo-electronics.de Git - linux-beck.git/commitdiff
OMAP: UART: use non-locking versions of hwmod enable/idle functions
authorKevin Hilman <khilman@deeprootsystems.com>
Mon, 27 Sep 2010 14:50:06 +0000 (20:20 +0530)
committerKevin Hilman <khilman@deeprootsystems.com>
Wed, 29 Sep 2010 19:42:58 +0000 (12:42 -0700)
Since the UART enable/idle is done during the idle path (with
interrupts disabled), use the non-locking versions of the hwmod
enable/idle functions.

Signed-off-by: Govindraj.R <govindraj.raja@ti.com>
Signed-off-by: Kevin Hilman <khilman@deeprootsystems.com>
arch/arm/mach-omap2/serial.c

index ff83e91e6109a131e61ba72842f4c9ed99315fad..72b5c98963909c940ece8cf913fa9a212e61bef4 100644 (file)
@@ -105,10 +105,29 @@ struct omap_uart_state {
 static LIST_HEAD(uart_list);
 static u8 num_uarts;
 
+/*
+ * Since these idle/enable hooks are used in the idle path itself
+ * which has interrupts disabled, use the non-locking versions of
+ * the hwmod enable/disable functions.
+ */
+static int uart_idle_hwmod(struct omap_device *od)
+{
+       _omap_hwmod_idle(od->hwmods[0]);
+
+       return 0;
+}
+
+static int uart_enable_hwmod(struct omap_device *od)
+{
+       _omap_hwmod_enable(od->hwmods[0]);
+
+       return 0;
+}
+
 static struct omap_device_pm_latency omap_uart_latency[] = {
        {
-               .deactivate_func = omap_device_idle_hwmods,
-               .activate_func   = omap_device_enable_hwmods,
+               .deactivate_func = uart_idle_hwmod,
+               .activate_func   = uart_enable_hwmod,
                .flags = OMAP_DEVICE_LATENCY_AUTO_ADJUST,
        },
 };