2006-03-31 03:31:04 -07:00
|
|
|
/*
|
|
|
|
* Driver model for leds and led triggers
|
|
|
|
*
|
|
|
|
* Copyright (C) 2005 John Lenz <lenz@cs.wisc.edu>
|
|
|
|
* Copyright (C) 2005 Richard Purdie <rpurdie@openedhand.com>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#ifndef __LINUX_LEDS_H_INCLUDED
|
|
|
|
#define __LINUX_LEDS_H_INCLUDED
|
|
|
|
|
2006-09-29 03:00:14 -06:00
|
|
|
#include <linux/list.h>
|
2007-09-11 15:24:45 -06:00
|
|
|
#include <linux/spinlock.h>
|
2007-11-10 06:29:04 -07:00
|
|
|
#include <linux/rwsem.h>
|
2006-09-29 03:00:14 -06:00
|
|
|
|
2006-03-31 03:31:04 -07:00
|
|
|
struct device;
|
|
|
|
/*
|
|
|
|
* LED Core
|
|
|
|
*/
|
|
|
|
|
|
|
|
enum led_brightness {
|
2006-04-10 23:54:02 -06:00
|
|
|
LED_OFF = 0,
|
|
|
|
LED_HALF = 127,
|
|
|
|
LED_FULL = 255,
|
2006-03-31 03:31:04 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct led_classdev {
|
2006-04-10 23:54:02 -06:00
|
|
|
const char *name;
|
|
|
|
int brightness;
|
|
|
|
int flags;
|
2006-03-31 03:31:04 -07:00
|
|
|
|
2006-04-10 23:54:02 -06:00
|
|
|
#define LED_SUSPENDED (1 << 0)
|
2006-03-31 03:31:04 -07:00
|
|
|
|
2006-04-10 23:54:02 -06:00
|
|
|
/* Set LED brightness level */
|
2008-04-24 16:49:30 -06:00
|
|
|
/* Must not sleep, use a workqueue if needed */
|
2006-04-10 23:54:02 -06:00
|
|
|
void (*brightness_set)(struct led_classdev *led_cdev,
|
|
|
|
enum led_brightness brightness);
|
2008-03-18 03:47:48 -06:00
|
|
|
/* Get LED brightness level */
|
|
|
|
enum led_brightness (*brightness_get)(struct led_classdev *led_cdev);
|
2006-04-10 23:54:02 -06:00
|
|
|
|
2007-10-31 08:07:12 -06:00
|
|
|
/* Activate hardware accelerated blink */
|
|
|
|
int (*blink_set)(struct led_classdev *led_cdev,
|
|
|
|
unsigned long *delay_on,
|
|
|
|
unsigned long *delay_off);
|
|
|
|
|
2007-07-08 16:19:31 -06:00
|
|
|
struct device *dev;
|
2006-04-10 23:54:02 -06:00
|
|
|
struct list_head node; /* LED Device list */
|
2008-05-31 08:23:19 -06:00
|
|
|
const char *default_trigger; /* Trigger to use */
|
2006-03-31 03:31:04 -07:00
|
|
|
|
2006-03-31 03:31:05 -07:00
|
|
|
#ifdef CONFIG_LEDS_TRIGGERS
|
|
|
|
/* Protects the trigger data below */
|
2007-11-10 06:29:04 -07:00
|
|
|
struct rw_semaphore trigger_lock;
|
2006-03-31 03:31:05 -07:00
|
|
|
|
2006-04-10 23:54:02 -06:00
|
|
|
struct led_trigger *trigger;
|
|
|
|
struct list_head trig_list;
|
|
|
|
void *trigger_data;
|
2006-03-31 03:31:05 -07:00
|
|
|
#endif
|
2006-03-31 03:31:04 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
extern int led_classdev_register(struct device *parent,
|
2006-04-10 23:54:02 -06:00
|
|
|
struct led_classdev *led_cdev);
|
2008-03-23 13:28:24 -06:00
|
|
|
extern void led_classdev_unregister(struct led_classdev *lcd);
|
2006-03-31 03:31:04 -07:00
|
|
|
extern void led_classdev_suspend(struct led_classdev *led_cdev);
|
|
|
|
extern void led_classdev_resume(struct led_classdev *led_cdev);
|
|
|
|
|
2006-03-31 03:31:05 -07:00
|
|
|
/*
|
|
|
|
* LED Triggers
|
|
|
|
*/
|
|
|
|
#ifdef CONFIG_LEDS_TRIGGERS
|
|
|
|
|
|
|
|
#define TRIG_NAME_MAX 50
|
|
|
|
|
|
|
|
struct led_trigger {
|
|
|
|
/* Trigger Properties */
|
2006-04-10 23:54:02 -06:00
|
|
|
const char *name;
|
|
|
|
void (*activate)(struct led_classdev *led_cdev);
|
|
|
|
void (*deactivate)(struct led_classdev *led_cdev);
|
2006-03-31 03:31:05 -07:00
|
|
|
|
|
|
|
/* LEDs under control by this trigger (for simple triggers) */
|
2006-04-10 23:54:02 -06:00
|
|
|
rwlock_t leddev_list_lock;
|
|
|
|
struct list_head led_cdevs;
|
2006-03-31 03:31:05 -07:00
|
|
|
|
|
|
|
/* Link to next registered trigger */
|
2006-04-10 23:54:02 -06:00
|
|
|
struct list_head next_trig;
|
2006-03-31 03:31:05 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Registration functions for complex triggers */
|
|
|
|
extern int led_trigger_register(struct led_trigger *trigger);
|
|
|
|
extern void led_trigger_unregister(struct led_trigger *trigger);
|
|
|
|
|
|
|
|
/* Registration functions for simple triggers */
|
|
|
|
#define DEFINE_LED_TRIGGER(x) static struct led_trigger *x;
|
|
|
|
#define DEFINE_LED_TRIGGER_GLOBAL(x) struct led_trigger *x;
|
|
|
|
extern void led_trigger_register_simple(const char *name,
|
|
|
|
struct led_trigger **trigger);
|
|
|
|
extern void led_trigger_unregister_simple(struct led_trigger *trigger);
|
|
|
|
extern void led_trigger_event(struct led_trigger *trigger,
|
|
|
|
enum led_brightness event);
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
/* Triggers aren't active - null macros */
|
|
|
|
#define DEFINE_LED_TRIGGER(x)
|
|
|
|
#define DEFINE_LED_TRIGGER_GLOBAL(x)
|
|
|
|
#define led_trigger_register_simple(x, y) do {} while(0)
|
|
|
|
#define led_trigger_unregister_simple(x) do {} while(0)
|
|
|
|
#define led_trigger_event(x, y) do {} while(0)
|
|
|
|
|
|
|
|
#endif
|
2006-03-31 03:31:16 -07:00
|
|
|
|
|
|
|
/* Trigger specific functions */
|
|
|
|
#ifdef CONFIG_LEDS_TRIGGER_IDE_DISK
|
|
|
|
extern void ledtrig_ide_activity(void);
|
|
|
|
#else
|
|
|
|
#define ledtrig_ide_activity() do {} while(0)
|
|
|
|
#endif
|
|
|
|
|
2008-07-16 15:49:55 -06:00
|
|
|
/*
|
|
|
|
* Generic LED platform data for describing LED names and default triggers.
|
|
|
|
*/
|
|
|
|
struct led_info {
|
|
|
|
const char *name;
|
|
|
|
char *default_trigger;
|
|
|
|
int flags;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct led_platform_data {
|
|
|
|
int num_leds;
|
|
|
|
struct led_info *leds;
|
|
|
|
};
|
|
|
|
|
2007-02-27 12:49:53 -07:00
|
|
|
/* For the leds-gpio driver */
|
|
|
|
struct gpio_led {
|
|
|
|
const char *name;
|
|
|
|
char *default_trigger;
|
|
|
|
unsigned gpio;
|
|
|
|
u8 active_low;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct gpio_led_platform_data {
|
|
|
|
int num_leds;
|
|
|
|
struct gpio_led *leds;
|
2008-03-09 17:48:25 -06:00
|
|
|
int (*gpio_blink_set)(unsigned gpio,
|
|
|
|
unsigned long *delay_on,
|
|
|
|
unsigned long *delay_off);
|
2007-02-27 12:49:53 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2006-03-31 03:31:04 -07:00
|
|
|
#endif /* __LINUX_LEDS_H_INCLUDED */
|