blob: da9fae9203ff52120fcd1e1692d7d860739b24ca [file] [log] [blame]
wdenkc6097192002-11-03 00:24:07 +00001/*
wdenk3902d702004-04-15 18:22:41 +00002 * (C) Copyright 2000-2004
wdenkc6097192002-11-03 00:24:07 +00003 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4 *
5 * See file CREDITS for list of people who contributed to this
6 * project.
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of
11 * the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21 * MA 02111-1307 USA
22 */
23
24/*
25 * The purpose of this code is to signal the operational status of a
26 * target which usually boots over the network; while running in
27 * PCBoot, a status LED is blinking. As soon as a valid BOOTP reply
28 * message has been received, the LED is turned off. The Linux
29 * kernel, once it is running, will start blinking the LED again,
30 * with another frequency.
31 */
32
33#ifndef _STATUS_LED_H_
34#define _STATUS_LED_H_
35
36#ifdef CONFIG_STATUS_LED
37
38#define STATUS_LED_OFF 0
39#define STATUS_LED_BLINKING 1
40#define STATUS_LED_ON 2
41
42void status_led_tick (unsigned long timestamp);
43void status_led_set (int led, int state);
44
45/***** TQM8xxL ********************************************************/
Wolfgang Denkfb52e952010-09-19 21:28:25 +020046#if defined(CONFIG_TQM8xxL)
wdenkc6097192002-11-03 00:24:07 +000047# define STATUS_LED_PAR im_cpm.cp_pbpar
48# define STATUS_LED_DIR im_cpm.cp_pbdir
49# define STATUS_LED_ODR im_cpm.cp_pbodr
50# define STATUS_LED_DAT im_cpm.cp_pbdat
51
52# define STATUS_LED_BIT 0x00000001
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020053# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
wdenkc6097192002-11-03 00:24:07 +000054# define STATUS_LED_STATE STATUS_LED_BLINKING
55
56# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
57
58# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
59
60/***** MVS v1 **********************************************************/
61#elif (defined(CONFIG_MVS) && CONFIG_MVS < 2)
62# define STATUS_LED_PAR im_ioport.iop_pdpar
63# define STATUS_LED_DIR im_ioport.iop_pddir
64# undef STATUS_LED_ODR
65# define STATUS_LED_DAT im_ioport.iop_pddat
66
67# define STATUS_LED_BIT 0x00000001
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020068# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
wdenkc6097192002-11-03 00:24:07 +000069# define STATUS_LED_STATE STATUS_LED_BLINKING
70
71# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
72
73# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
74
wdenkc6097192002-11-03 00:24:07 +000075/***** GEN860T *********************************************************/
76#elif defined(CONFIG_GEN860T)
77
78# define STATUS_LED_PAR im_ioport.iop_papar
79# define STATUS_LED_DIR im_ioport.iop_padir
80# define STATUS_LED_ODR im_ioport.iop_paodr
81# define STATUS_LED_DAT im_ioport.iop_padat
82
83# define STATUS_LED_BIT 0x0800 /* Red LED 0 is on PA.4 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020084# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 4)
wdenk541a76d2003-05-03 15:50:43 +000085# define STATUS_LED_STATE STATUS_LED_OFF
wdenkc6097192002-11-03 00:24:07 +000086# define STATUS_LED_BIT1 0x0400 /* Grn LED 1 is on PA.5 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020087# define STATUS_LED_PERIOD1 (CONFIG_SYS_HZ / 8)
wdenkc6097192002-11-03 00:24:07 +000088# define STATUS_LED_STATE1 STATUS_LED_BLINKING
89# define STATUS_LED_BIT2 0x0080 /* Red LED 2 is on PA.8 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020090# define STATUS_LED_PERIOD2 (CONFIG_SYS_HZ / 4)
wdenk541a76d2003-05-03 15:50:43 +000091# define STATUS_LED_STATE2 STATUS_LED_OFF
wdenkc6097192002-11-03 00:24:07 +000092# define STATUS_LED_BIT3 0x0040 /* Grn LED 3 is on PA.9 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020093# define STATUS_LED_PERIOD3 (CONFIG_SYS_HZ / 4)
wdenk541a76d2003-05-03 15:50:43 +000094# define STATUS_LED_STATE3 STATUS_LED_OFF
wdenkc6097192002-11-03 00:24:07 +000095
96# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
wdenk541a76d2003-05-03 15:50:43 +000097# define STATUS_LED_BOOT 1 /* Boot status on LED 1 */
wdenkc6097192002-11-03 00:24:07 +000098
99/***** IVMS8 **********************************************************/
100#elif defined(CONFIG_IVMS8)
101
102# define STATUS_LED_PAR im_cpm.cp_pbpar
103# define STATUS_LED_DIR im_cpm.cp_pbdir
104# define STATUS_LED_ODR im_cpm.cp_pbodr
105# define STATUS_LED_DAT im_cpm.cp_pbdat
106
107# define STATUS_LED_BIT 0x00000010 /* LED 0 is on PB.27 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200108# define STATUS_LED_PERIOD (1 * CONFIG_SYS_HZ)
wdenkc6097192002-11-03 00:24:07 +0000109# define STATUS_LED_STATE STATUS_LED_OFF
110# define STATUS_LED_BIT1 0x00000020 /* LED 1 is on PB.26 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200111# define STATUS_LED_PERIOD1 (1 * CONFIG_SYS_HZ)
wdenkc6097192002-11-03 00:24:07 +0000112# define STATUS_LED_STATE1 STATUS_LED_OFF
113/* IDE LED usable for other purposes, too */
114# define STATUS_LED_BIT2 0x00000008 /* LED 2 is on PB.28 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200115# define STATUS_LED_PERIOD2 (1 * CONFIG_SYS_HZ)
wdenkc6097192002-11-03 00:24:07 +0000116# define STATUS_LED_STATE2 STATUS_LED_OFF
117
118# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
119
120# define STATUS_ILOCK_SWITCH 0x00800000 /* ILOCK switch in IRQ4 */
121
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200122# define STATUS_ILOCK_PERIOD (CONFIG_SYS_HZ / 10) /* about every 100 ms */
wdenkc6097192002-11-03 00:24:07 +0000123
124# define STATUS_LED_YELLOW 0
125# define STATUS_LED_GREEN 1
126# define STATUS_LED_BOOT 2 /* IDE LED used for boot status */
127
128/***** IVML24 *********************************************************/
129#elif defined(CONFIG_IVML24)
130
131# define STATUS_LED_PAR im_cpm.cp_pbpar
132# define STATUS_LED_DIR im_cpm.cp_pbdir
133# define STATUS_LED_ODR im_cpm.cp_pbodr
134# define STATUS_LED_DAT im_cpm.cp_pbdat
135
136# define STATUS_LED_BIT 0x00000010 /* LED 0 is on PB.27 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200137# define STATUS_LED_PERIOD (1 * CONFIG_SYS_HZ)
wdenkc6097192002-11-03 00:24:07 +0000138# define STATUS_LED_STATE STATUS_LED_OFF
139# define STATUS_LED_BIT1 0x00000020 /* LED 1 is on PB.26 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200140# define STATUS_LED_PERIOD1 (1 * CONFIG_SYS_HZ)
wdenkc6097192002-11-03 00:24:07 +0000141# define STATUS_LED_STATE1 STATUS_LED_OFF
142/* IDE LED usable for other purposes, too */
143# define STATUS_LED_BIT2 0x00000008 /* LED 2 is on PB.28 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200144# define STATUS_LED_PERIOD2 (1 * CONFIG_SYS_HZ)
wdenkc6097192002-11-03 00:24:07 +0000145# define STATUS_LED_STATE2 STATUS_LED_OFF
146
147# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
148
149# define STATUS_ILOCK_SWITCH 0x00004000 /* ILOCK is on PB.17 */
150
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200151# define STATUS_ILOCK_PERIOD (CONFIG_SYS_HZ / 10) /* about every 100 ms */
wdenkc6097192002-11-03 00:24:07 +0000152
153# define STATUS_LED_YELLOW 0
154# define STATUS_LED_GREEN 1
155# define STATUS_LED_BOOT 2 /* IDE LED used for boot status */
156
wdenkc6097192002-11-03 00:24:07 +0000157/***** ICU862 ********************************************************/
158#elif defined(CONFIG_ICU862)
159
160# define STATUS_LED_PAR im_ioport.iop_papar
161# define STATUS_LED_DIR im_ioport.iop_padir
162# define STATUS_LED_ODR im_ioport.iop_paodr
163# define STATUS_LED_DAT im_ioport.iop_padat
164
165# define STATUS_LED_BIT 0x4000 /* LED 0 is on PA.1 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200166# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
wdenkc6097192002-11-03 00:24:07 +0000167# define STATUS_LED_STATE STATUS_LED_BLINKING
168# define STATUS_LED_BIT1 0x1000 /* LED 1 is on PA.3 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200169# define STATUS_LED_PERIOD1 (CONFIG_SYS_HZ)
wdenkc6097192002-11-03 00:24:07 +0000170# define STATUS_LED_STATE1 STATUS_LED_OFF
171
172# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
173
174# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
175
176/***** Someone else defines these *************************************/
177#elif defined(STATUS_LED_PAR)
178
179 /*
180 * ADVICE: Define in your board configuration file rather than
181 * filling this file up with lots of custom board stuff.
182 */
183
184/***** NetVia ********************************************************/
185#elif defined(CONFIG_NETVIA)
186
wdenk70764a32003-06-26 22:04:09 +0000187#if !defined(CONFIG_NETVIA_VERSION) || CONFIG_NETVIA_VERSION == 1
188
wdenkc6097192002-11-03 00:24:07 +0000189#define STATUS_LED_PAR im_ioport.iop_pdpar
190#define STATUS_LED_DIR im_ioport.iop_pddir
191#undef STATUS_LED_ODR
192#define STATUS_LED_DAT im_ioport.iop_pddat
193
194# define STATUS_LED_BIT 0x0080 /* PD.8 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200195# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
wdenkc6097192002-11-03 00:24:07 +0000196# define STATUS_LED_STATE STATUS_LED_BLINKING
197
198# define STATUS_LED_BIT1 0x0040 /* PD.9 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200199# define STATUS_LED_PERIOD1 (CONFIG_SYS_HZ / 2)
wdenkc6097192002-11-03 00:24:07 +0000200# define STATUS_LED_STATE1 STATUS_LED_OFF
201
202# define STATUS_LED_ACTIVE 0 /* LED on for bit == 0 */
203# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
204
wdenk70764a32003-06-26 22:04:09 +0000205#endif
wdenk56f94be2002-11-05 16:35:14 +0000206
wdenk359733b2003-03-31 17:27:09 +0000207/***** CMI ********************************************************/
208#elif defined(CONFIG_CMI)
wdenk57b2d802003-06-27 21:31:46 +0000209# define STATUS_LED_DIR im_mios.mios_mpiosm32ddr
210# define STATUS_LED_DAT im_mios.mios_mpiosm32dr
wdenk359733b2003-03-31 17:27:09 +0000211
212# define STATUS_LED_BIT 0x2000 /* Select one of the 16 possible*/
213 /* MIOS outputs */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200214# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2) /* Blinking periode is 500 ms */
wdenk359733b2003-03-31 17:27:09 +0000215# define STATUS_LED_STATE STATUS_LED_BLINKING
216
217# define STATUS_LED_ACTIVE 1 /* LED on for bit == 0 */
218# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
219
wdenk65faef92004-03-25 19:29:38 +0000220/***** KUP4K, KUP4X ****************************************************/
Wolfgang Denk19d86f42010-10-05 22:54:54 +0200221#elif defined(CONFIG_KUP4K) || defined(CONFIG_KUP4X)
wdenk56f94be2002-11-05 16:35:14 +0000222
223# define STATUS_LED_PAR im_ioport.iop_papar
224# define STATUS_LED_DIR im_ioport.iop_padir
225# define STATUS_LED_ODR im_ioport.iop_paodr
226# define STATUS_LED_DAT im_ioport.iop_padat
227
228# define STATUS_LED_BIT 0x00000300 /* green + red PA[8]=yellow, PA[7]=red, PA[6]=green */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200229# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
wdenk56f94be2002-11-05 16:35:14 +0000230# define STATUS_LED_STATE STATUS_LED_BLINKING
231
232# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
233
234# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
235
wdenkc8434db2003-03-26 06:55:25 +0000236#elif defined(CONFIG_SVM_SC8xx)
237# define STATUS_LED_PAR im_cpm.cp_pbpar
238# define STATUS_LED_DIR im_cpm.cp_pbdir
239# define STATUS_LED_ODR im_cpm.cp_pbodr
240# define STATUS_LED_DAT im_cpm.cp_pbdat
241
242# define STATUS_LED_BIT 0x00000001
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200243# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
wdenkc8434db2003-03-26 06:55:25 +0000244# define STATUS_LED_STATE STATUS_LED_BLINKING
245
246# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
247
248# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
249
wdenk4e112c12003-06-03 23:54:09 +0000250/***** RBC823 ********************************************************/
251#elif defined(CONFIG_RBC823)
252
253# define STATUS_LED_PAR im_ioport.iop_pcpar
254# define STATUS_LED_DIR im_ioport.iop_pcdir
255# undef STATUS_LED_ODR
256# define STATUS_LED_DAT im_ioport.iop_pcdat
257
258# define STATUS_LED_BIT 0x0002 /* LED 0 is on PC.14 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200259# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
wdenk4e112c12003-06-03 23:54:09 +0000260# define STATUS_LED_STATE STATUS_LED_BLINKING
261# define STATUS_LED_BIT1 0x0004 /* LED 1 is on PC.13 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200262# define STATUS_LED_PERIOD1 (CONFIG_SYS_HZ)
wdenk4e112c12003-06-03 23:54:09 +0000263# define STATUS_LED_STATE1 STATUS_LED_OFF
264
265# define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
266
267# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
268
wdenk3902d702004-04-15 18:22:41 +0000269/***** NetPhone ********************************************************/
wdenkc4e854f2004-06-07 23:46:25 +0000270#elif defined(CONFIG_NETPHONE) || defined(CONFIG_NETTA2)
wdenk3902d702004-04-15 18:22:41 +0000271/* XXX empty just to avoid the error */
Wolfgang Denk72fdb6c2005-08-15 15:55:00 +0200272/***** STx XTc ********************************************************/
273#elif defined(CONFIG_STXXTC)
274/* XXX empty just to avoid the error */
wdenkc6097192002-11-03 00:24:07 +0000275/************************************************************************/
wdenkef3386f2004-10-10 21:27:30 +0000276#elif defined(CONFIG_NIOS2)
277/* XXX empty just to avoid the error */
278/************************************************************************/
Bartlomiej Sieka2dfa3d22006-10-13 21:09:09 +0200279#elif defined(CONFIG_V38B)
280
281# define STATUS_LED_BIT 0x0010 /* Timer7 GPIO */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200282# define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 2)
Bartlomiej Sieka2dfa3d22006-10-13 21:09:09 +0200283# define STATUS_LED_STATE STATUS_LED_BLINKING
284
285# define STATUS_LED_ACTIVE 0 /* LED on for bit == 0 */
286# define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
287
Bartlomiej Siekac9e6a1e2007-05-27 16:51:48 +0200288#elif defined(CONFIG_MOTIONPRO)
289
290#define STATUS_LED_BIT ((vu_long *) MPC5XXX_GPT6_ENABLE)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200291#define STATUS_LED_PERIOD (CONFIG_SYS_HZ / 10)
Bartlomiej Siekac9e6a1e2007-05-27 16:51:48 +0200292#define STATUS_LED_STATE STATUS_LED_BLINKING
293
294#define STATUS_LED_BIT1 ((vu_long *) MPC5XXX_GPT7_ENABLE)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200295#define STATUS_LED_PERIOD1 (CONFIG_SYS_HZ / 10)
Bartlomiej Siekac9e6a1e2007-05-27 16:51:48 +0200296#define STATUS_LED_STATE1 STATUS_LED_OFF
297
298#define STATUS_LED_BOOT 0 /* LED 0 used for boot status */
299
Heiko Schocher633e03a2007-06-22 19:11:54 +0200300#elif defined(CONFIG_BOARD_SPECIFIC_LED)
301/* led_id_t is unsigned long mask */
302typedef unsigned long led_id_t;
303
304extern void __led_toggle (led_id_t mask);
305extern void __led_init (led_id_t mask, int state);
306extern void __led_set (led_id_t mask, int state);
wdenkc6097192002-11-03 00:24:07 +0000307#else
308# error Status LED configuration missing
309#endif
310/************************************************************************/
311
wdenk7539dea2003-06-19 23:01:32 +0000312#ifndef CONFIG_BOARD_SPECIFIC_LED
313# include <asm/status_led.h>
314#endif
315
Wolfgang Denkebc15912007-10-13 21:15:39 +0200316/*
Peter Pearseabf2c5d2007-09-18 13:07:54 +0100317 * Coloured LEDs API
Wolfgang Denkebc15912007-10-13 21:15:39 +0200318 */
Peter Pearseabf2c5d2007-09-18 13:07:54 +0100319#ifndef __ASSEMBLY__
320extern void coloured_LED_init (void);
Jason Kridneraff0aa82011-09-04 14:40:16 -0400321extern void red_led_on(void);
322extern void red_led_off(void);
323extern void green_led_on(void);
324extern void green_led_off(void);
325extern void yellow_led_on(void);
326extern void yellow_led_off(void);
327extern void blue_led_on(void);
328extern void blue_led_off(void);
Peter Pearseabf2c5d2007-09-18 13:07:54 +0100329#else
330 .extern LED_init
Jason Kridneraff0aa82011-09-04 14:40:16 -0400331 .extern red_led_on
332 .extern red_led_off
333 .extern yellow_led_on
334 .extern yellow_led_off
335 .extern green_led_on
336 .extern green_led_off
337 .extern blue_led_on
338 .extern blue_led_off
Peter Pearseabf2c5d2007-09-18 13:07:54 +0100339#endif
340
wdenkc6097192002-11-03 00:24:07 +0000341#endif /* CONFIG_STATUS_LED */
342
343#endif /* _STATUS_LED_H_ */