aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm')
-rw-r--r--arch/arm/kernel/Makefile1
-rw-r--r--arch/arm/kernel/leds.c115
-rw-r--r--arch/arm/kernel/time.c104
3 files changed, 116 insertions, 104 deletions
diff --git a/arch/arm/kernel/Makefile b/arch/arm/kernel/Makefile
index dd00f747e2ad..eb0284cd8661 100644
--- a/arch/arm/kernel/Makefile
+++ b/arch/arm/kernel/Makefile
@@ -17,6 +17,7 @@ obj-y := compat.o elf.o entry-armv.o entry-common.o irq.o \
17 process.o ptrace.o return_address.o setup.o signal.o \ 17 process.o ptrace.o return_address.o setup.o signal.o \
18 sys_arm.o stacktrace.o time.o traps.o 18 sys_arm.o stacktrace.o time.o traps.o
19 19
20obj-$(CONFIG_LEDS) += leds.o
20obj-$(CONFIG_OC_ETM) += etm.o 21obj-$(CONFIG_OC_ETM) += etm.o
21 22
22obj-$(CONFIG_ISA_DMA_API) += dma.o 23obj-$(CONFIG_ISA_DMA_API) += dma.o
diff --git a/arch/arm/kernel/leds.c b/arch/arm/kernel/leds.c
new file mode 100644
index 000000000000..31a316c1777b
--- /dev/null
+++ b/arch/arm/kernel/leds.c
@@ -0,0 +1,115 @@
1/*
2 * LED support code, ripped out of arch/arm/kernel/time.c
3 *
4 * Copyright (C) 1994-2001 Russell King
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 */
10#include <linux/module.h>
11#include <linux/init.h>
12#include <linux/sysdev.h>
13
14#include <asm/leds.h>
15
16static void dummy_leds_event(led_event_t evt)
17{
18}
19
20void (*leds_event)(led_event_t) = dummy_leds_event;
21
22struct leds_evt_name {
23 const char name[8];
24 int on;
25 int off;
26};
27
28static const struct leds_evt_name evt_names[] = {
29 { "amber", led_amber_on, led_amber_off },
30 { "blue", led_blue_on, led_blue_off },
31 { "green", led_green_on, led_green_off },
32 { "red", led_red_on, led_red_off },
33};
34
35static ssize_t leds_store(struct sys_device *dev,
36 struct sysdev_attribute *attr,
37 const char *buf, size_t size)
38{
39 int ret = -EINVAL, len = strcspn(buf, " ");
40
41 if (len > 0 && buf[len] == '\0')
42 len--;
43
44 if (strncmp(buf, "claim", len) == 0) {
45 leds_event(led_claim);
46 ret = size;
47 } else if (strncmp(buf, "release", len) == 0) {
48 leds_event(led_release);
49 ret = size;
50 } else {
51 int i;
52
53 for (i = 0; i < ARRAY_SIZE(evt_names); i++) {
54 if (strlen(evt_names[i].name) != len ||
55 strncmp(buf, evt_names[i].name, len) != 0)
56 continue;
57 if (strncmp(buf+len, " on", 3) == 0) {
58 leds_event(evt_names[i].on);
59 ret = size;
60 } else if (strncmp(buf+len, " off", 4) == 0) {
61 leds_event(evt_names[i].off);
62 ret = size;
63 }
64 break;
65 }
66 }
67 return ret;
68}
69
70static SYSDEV_ATTR(event, 0200, NULL, leds_store);
71
72static int leds_suspend(struct sys_device *dev, pm_message_t state)
73{
74 leds_event(led_stop);
75 return 0;
76}
77
78static int leds_resume(struct sys_device *dev)
79{
80 leds_event(led_start);
81 return 0;
82}
83
84static int leds_shutdown(struct sys_device *dev)
85{
86 leds_event(led_halted);
87 return 0;
88}
89
90static struct sysdev_class leds_sysclass = {
91 .name = "leds",
92 .shutdown = leds_shutdown,
93 .suspend = leds_suspend,
94 .resume = leds_resume,
95};
96
97static struct sys_device leds_device = {
98 .id = 0,
99 .cls = &leds_sysclass,
100};
101
102static int __init leds_init(void)
103{
104 int ret;
105 ret = sysdev_class_register(&leds_sysclass);
106 if (ret == 0)
107 ret = sysdev_register(&leds_device);
108 if (ret == 0)
109 ret = sysdev_create_file(&leds_device, &attr_event);
110 return ret;
111}
112
113device_initcall(leds_init);
114
115EXPORT_SYMBOL(leds_event);
diff --git a/arch/arm/kernel/time.c b/arch/arm/kernel/time.c
index e26f966d117b..28753805d2d1 100644
--- a/arch/arm/kernel/time.c
+++ b/arch/arm/kernel/time.c
@@ -79,110 +79,6 @@ static unsigned long dummy_gettimeoffset(void)
79} 79}
80#endif 80#endif
81 81
82#ifdef CONFIG_LEDS
83
84static void dummy_leds_event(led_event_t evt)
85{
86}
87
88void (*leds_event)(led_event_t) = dummy_leds_event;
89
90struct leds_evt_name {
91 const char name[8];
92 int on;
93 int off;
94};
95
96static const struct leds_evt_name evt_names[] = {
97 { "amber", led_amber_on, led_amber_off },
98 { "blue", led_blue_on, led_blue_off },
99 { "green", led_green_on, led_green_off },
100 { "red", led_red_on, led_red_off },
101};
102
103static ssize_t leds_store(struct sys_device *dev,
104 struct sysdev_attribute *attr,
105 const char *buf, size_t size)
106{
107 int ret = -EINVAL, len = strcspn(buf, " ");
108
109 if (len > 0 && buf[len] == '\0')
110 len--;
111
112 if (strncmp(buf, "claim", len) == 0) {
113 leds_event(led_claim);
114 ret = size;
115 } else if (strncmp(buf, "release", len) == 0) {
116 leds_event(led_release);
117 ret = size;
118 } else {
119 int i;
120
121 for (i = 0; i < ARRAY_SIZE(evt_names); i++) {
122 if (strlen(evt_names[i].name) != len ||
123 strncmp(buf, evt_names[i].name, len) != 0)
124 continue;
125 if (strncmp(buf+len, " on", 3) == 0) {
126 leds_event(evt_names[i].on);
127 ret = size;
128 } else if (strncmp(buf+len, " off", 4) == 0) {
129 leds_event(evt_names[i].off);
130 ret = size;
131 }
132 break;
133 }
134 }
135 return ret;
136}
137
138static SYSDEV_ATTR(event, 0200, NULL, leds_store);
139
140static int leds_suspend(struct sys_device *dev, pm_message_t state)
141{
142 leds_event(led_stop);
143 return 0;
144}
145
146static int leds_resume(struct sys_device *dev)
147{
148 leds_event(led_start);
149 return 0;
150}
151
152static int leds_shutdown(struct sys_device *dev)
153{
154 leds_event(led_halted);
155 return 0;
156}
157
158static struct sysdev_class leds_sysclass = {
159 .name = "leds",
160 .shutdown = leds_shutdown,
161 .suspend = leds_suspend,
162 .resume = leds_resume,
163};
164
165static struct sys_device leds_device = {
166 .id = 0,
167 .cls = &leds_sysclass,
168};
169
170static int __init leds_init(void)
171{
172 int ret;
173 ret = sysdev_class_register(&leds_sysclass);
174 if (ret == 0)
175 ret = sysdev_register(&leds_device);
176 if (ret == 0)
177 ret = sysdev_create_file(&leds_device, &attr_event);
178 return ret;
179}
180
181device_initcall(leds_init);
182
183EXPORT_SYMBOL(leds_event);
184#endif
185
186#ifdef CONFIG_LEDS_TIMER 82#ifdef CONFIG_LEDS_TIMER
187static inline void do_leds(void) 83static inline void do_leds(void)
188{ 84{