2008-04-15 21:13:33 +01:00
/*
* LED driver for KS8695 - based boards .
*
* Copyright ( C ) Andrew Victor
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*/
# include <linux/kernel.h>
# include <linux/module.h>
# include <linux/init.h>
# include <asm/leds.h>
2008-08-05 16:14:15 +01:00
# include <mach/devices.h>
# include <mach/gpio.h>
2008-04-15 21:13:33 +01:00
static inline void ks8695_led_on ( unsigned int led )
{
gpio_set_value ( led , 0 ) ;
}
static inline void ks8695_led_off ( unsigned int led )
{
gpio_set_value ( led , 1 ) ;
}
static inline void ks8695_led_toggle ( unsigned int led )
{
unsigned long is_off = gpio_get_value ( led ) ;
if ( is_off )
ks8695_led_on ( led ) ;
else
ks8695_led_off ( led ) ;
}
/*
* Handle LED events .
*/
static void ks8695_leds_event ( led_event_t evt )
{
unsigned long flags ;
local_irq_save ( flags ) ;
switch ( evt ) {
case led_start : /* System startup */
ks8695_led_on ( ks8695_leds_cpu ) ;
break ;
case led_stop : /* System stop / suspend */
ks8695_led_off ( ks8695_leds_cpu ) ;
break ;
# ifdef CONFIG_LEDS_TIMER
case led_timer : /* Every 50 timer ticks */
ks8695_led_toggle ( ks8695_leds_timer ) ;
break ;
# endif
# ifdef CONFIG_LEDS_CPU
case led_idle_start : /* Entering idle state */
ks8695_led_off ( ks8695_leds_cpu ) ;
break ;
case led_idle_end : /* Exit idle state */
ks8695_led_on ( ks8695_leds_cpu ) ;
break ;
# endif
default :
break ;
}
local_irq_restore ( flags ) ;
}
static int __init leds_init ( void )
{
if ( ( ks8695_leds_timer = = - 1 ) | | ( ks8695_leds_cpu = = - 1 ) )
return - ENODEV ;
leds_event = ks8695_leds_event ;
leds_event ( led_start ) ;
return 0 ;
}
__initcall ( leds_init ) ;