public inbox for linux-omap@vger.kernel.org
 help / color / mirror / Atom feed
From: Vivien Chappelier <vivien.chappelier@free.fr>
To: linux-omap-open-source@linux.omap.com
Subject: [PATCH 10/12] Add support for HTC Typhoon leds.
Date: Sat, 9 Jun 2007 20:47:00 +0200	[thread overview]
Message-ID: <20070609184700.GJ1889@varda> (raw)

This patch add support for the HTC Typhoon tricolor led.

Signed-off-by: Vivien Chappelier <vivien.chappelier@free.fr>

---
 arch/arm/mach-omap1/Makefile       |    1 +
 arch/arm/mach-omap1/leds-typhoon.c |  184 ++++++++++++++++++++++++++++++++++++
 arch/arm/mach-omap1/leds.c         |    3 +
 arch/arm/mach-omap1/leds.h         |    1 +
 4 files changed, 189 insertions(+), 0 deletions(-)
 create mode 100644 arch/arm/mach-omap1/leds-typhoon.c

diff --git a/arch/arm/mach-omap1/Makefile b/arch/arm/mach-omap1/Makefile
index 9f6bcbb..5153e43 100644
--- a/arch/arm/mach-omap1/Makefile
+++ b/arch/arm/mach-omap1/Makefile
@@ -46,4 +46,5 @@ led-$(CONFIG_MACH_OMAP_H3)		+= leds-h2p2-debug.o
 led-$(CONFIG_MACH_OMAP_INNOVATOR)	+= leds-innovator.o
 led-$(CONFIG_MACH_OMAP_PERSEUS2)	+= leds-h2p2-debug.o
 led-$(CONFIG_MACH_OMAP_OSK)		+= leds-osk.o
+led-$(CONFIG_MACH_TYPHOON)		+= leds-typhoon.o
 obj-$(CONFIG_LEDS)			+= $(led-y)
diff --git a/arch/arm/mach-omap1/leds-typhoon.c b/arch/arm/mach-omap1/leds-typhoon.c
new file mode 100644
index 0000000..eff868f
--- /dev/null
+++ b/arch/arm/mach-omap1/leds-typhoon.c
@@ -0,0 +1,184 @@
+/*
+ * linux/arch/arm/mach-omap1/leds-typhoon.c
+ *
+ * Copyright 2005 Vivien Chappelier <vivien.chappelier@free.fr>
+ *   Modified from leds-h2p2-debug.c
+ *
+ * The HTC Typhoon has a tricolor led. Timers can be setup the 'red'
+ * and 'green' components for blinking. The 'blue' component is on/off only.
+ */
+#include <linux/init.h>
+#include <linux/kernel_stat.h>
+#include <linux/sched.h>
+#include <linux/version.h>
+
+#include <asm/io.h>
+#include <asm/hardware.h>
+#include <asm/leds.h>
+#include <asm/system.h>
+
+#include <asm/arch/gpio.h>
+#include <asm/arch/board-typhoon.h>
+
+#include "leds.h"
+
+/* led registers */
+#define TYPHOON_LED_STATUS_ON       1
+#define TYPHOON_LED_STATUS_OFF      0
+#define TYPHOON_LED_STATUS_BLINK(on, off) (((on) << 2) | ((off) << 17))
+
+#define TYPHOON_LED_BASE   0xfffba800
+#define TYPHOON_LED_ENABLE 0xfffba801
+#	define LED_ON         (1 << 7)
+#	define LED_BLINK      (1 << 6)
+#	define LED_ONTIME(x)  ((x) & 0x7)
+#	define LED_OFFTIME(x) (((x) & 0x7) << 3)
+
+/* led status */
+#define LED_STATE_ENABLED	 (1 << 7)
+#define LED_STATE_CLAIMED	 (1 << 6)
+#define LED_BLUE  (1 <<  0)
+#define LED_GREEN (1 <<  1)
+#define LED_RED   (1 <<  2)
+#define LED_MASK (LED_BLUE | LED_GREEN | LED_RED)
+
+#define LED_TIMER LED_GREEN
+#define LED_CPU   LED_RED
+
+/* route power to the tricolor led */
+static void typhoon_start_led(void)
+{
+	omap_writel(omap_readl(OMAP730_IO_CONF_10) & ~0x20, OMAP730_IO_CONF_10);
+	omap_writel(omap_readl(OMAP730_IO_CONF_10) |  0xd0, OMAP730_IO_CONF_10);
+	omap_set_gpio_direction(TYPHOON_GPIO_LED_BLUE, 0); /* out */
+
+	omap_writel(omap_readl(OMAP730_MODE_1) | (1 << 29), OMAP730_MODE_1);
+	omap_writeb(LED_ON, TYPHOON_LED_BASE);
+	omap_writeb(1, TYPHOON_LED_ENABLE);
+}
+
+/* power off the tricolor led */
+static void typhoon_stop_led(void)
+{
+	omap_writel(omap_readl(OMAP730_MODE_1) & ~(1 << 29), OMAP730_MODE_1);
+	omap_writeb(0, TYPHOON_LED_BASE);
+	omap_writeb(0, TYPHOON_LED_ENABLE);
+}
+
+/* set the 'blue', 'green' and 'red' components of the tricolor led */
+static void typhoon_set_led(int led)
+{
+	if(led & LED_BLUE)
+		omap_set_gpio_dataout(TYPHOON_GPIO_LED_BLUE, 1);
+	else
+		omap_set_gpio_dataout(TYPHOON_GPIO_LED_BLUE, 0);
+
+	if(led & (LED_RED | LED_GREEN)) {
+		if(led & LED_GREEN) {
+			omap_set_gpio_direction(TYPHOON_GPIO_LED_GREEN, 1);
+		} else {
+			omap_set_gpio_direction(TYPHOON_GPIO_LED_GREEN, 0);
+			omap_set_gpio_dataout(TYPHOON_GPIO_LED_GREEN, 0);
+		}
+
+		if(led & LED_RED) {
+			omap_set_gpio_direction(TYPHOON_GPIO_LED_RED, 1);
+		} else {
+			omap_set_gpio_direction(TYPHOON_GPIO_LED_RED, 0);
+			omap_set_gpio_dataout(TYPHOON_GPIO_LED_RED, 0);
+		}
+	} else {
+		omap_set_gpio_direction(TYPHOON_GPIO_LED_GREEN, 0);
+		omap_set_gpio_dataout(TYPHOON_GPIO_LED_GREEN, 0);
+		omap_set_gpio_direction(TYPHOON_GPIO_LED_RED, 0);
+		omap_set_gpio_dataout(TYPHOON_GPIO_LED_RED, 0);
+	}
+}
+
+
+void typhoon_leds_event(led_event_t evt)
+{
+	unsigned long flags;
+
+	static u16 led_state, hw_led_state;
+
+	local_irq_save(flags);
+
+	if (!(led_state & LED_STATE_ENABLED) && evt != led_start)
+		goto done;
+
+	switch (evt) {
+	case led_start:
+		typhoon_start_led();
+		led_state |= LED_STATE_ENABLED;
+		break;
+
+	case led_stop:
+	case led_halted:
+		/* all leds off during suspend or shutdown */
+		typhoon_set_led(0);
+		typhoon_stop_led();
+		goto done;
+
+	case led_claim:
+		led_state |= LED_STATE_CLAIMED;
+		hw_led_state = 0;
+		break;
+
+	case led_release:
+		led_state &= ~LED_STATE_CLAIMED;
+		break;
+
+#ifdef CONFIG_LEDS_TIMER
+	case led_timer:
+		led_state ^= LED_TIMER;
+		break;
+#endif
+
+#ifdef CONFIG_LEDS_CPU
+	case led_idle_start:
+		led_state &= ~LED_CPU;
+		break;
+
+	case led_idle_end:
+		led_state |= LED_CPU;
+		break;
+#endif
+
+	case led_green_on:
+		hw_led_state |= LED_GREEN;
+		break;
+	case led_green_off:
+		hw_led_state &= ~LED_GREEN;
+		break;
+
+	case led_red_on:
+		hw_led_state |= LED_RED;
+		break;
+	case led_red_off:
+		hw_led_state &= ~LED_RED;
+		break;
+
+	case led_blue_on:
+		hw_led_state |= LED_BLUE;
+		break;
+	case led_blue_off:
+		hw_led_state &= ~LED_BLUE;
+		break;
+
+	default:
+		break;
+	}
+
+
+	/*
+	 *  Actually burn the LEDs
+	 */
+	if (led_state & LED_STATE_CLAIMED)
+		typhoon_set_led(hw_led_state);
+	else
+		typhoon_set_led(led_state & LED_MASK);
+
+done:
+	local_irq_restore(flags);
+}
diff --git a/arch/arm/mach-omap1/leds.c b/arch/arm/mach-omap1/leds.c
index 3f9dcac..59b7135 100644
--- a/arch/arm/mach-omap1/leds.c
+++ b/arch/arm/mach-omap1/leds.c
@@ -28,6 +28,9 @@ omap_leds_init(void)
 	else if (machine_is_omap_osk())
 		leds_event = osk_leds_event;
 
+	else if (machine_is_typhoon())
+		leds_event = typhoon_leds_event;
+
 	else
 		return -1;
 
diff --git a/arch/arm/mach-omap1/leds.h b/arch/arm/mach-omap1/leds.h
index a1e9fed..1760eb0 100644
--- a/arch/arm/mach-omap1/leds.h
+++ b/arch/arm/mach-omap1/leds.h
@@ -1,3 +1,4 @@
 extern void innovator_leds_event(led_event_t evt);
 extern void h2p2_dbg_leds_event(led_event_t evt);
 extern void osk_leds_event(led_event_t evt);
+extern void typhoon_leds_event(led_event_t evt);
-- 
1.5.1.3

             reply	other threads:[~2007-06-09 18:47 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-06-09 18:47 Vivien Chappelier [this message]
  -- strict thread matches above, loose matches on Subject: below --
2007-06-09 17:33 [PATCH 10/12] Add support for HTC Typhoon leds Vivien Chappelier
2007-06-12 11:34 ` Trilok Soni

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20070609184700.GJ1889@varda \
    --to=vivien.chappelier@free.fr \
    --cc=linux-omap-open-source@linux.omap.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox