Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
18775a7b
Commit
18775a7b
authored
Mar 14, 2012
by
Bryan Wu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ARM: mach-sa1100: retire custom LED code
Signed-off-by:
Bryan Wu
<
bryan.wu@canonical.com
>
parent
dafbeadf
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
215 additions
and
615 deletions
+215
-615
arch/arm/mach-sa1100/Makefile
arch/arm/mach-sa1100/Makefile
+0
-9
arch/arm/mach-sa1100/assabet.c
arch/arm/mach-sa1100/assabet.c
+85
-0
arch/arm/mach-sa1100/badge4.c
arch/arm/mach-sa1100/badge4.c
+30
-0
arch/arm/mach-sa1100/cerf.c
arch/arm/mach-sa1100/cerf.c
+42
-0
arch/arm/mach-sa1100/hackkit.c
arch/arm/mach-sa1100/hackkit.c
+32
-0
arch/arm/mach-sa1100/lart.c
arch/arm/mach-sa1100/lart.c
+26
-0
arch/arm/mach-sa1100/leds-assabet.c
arch/arm/mach-sa1100/leds-assabet.c
+0
-113
arch/arm/mach-sa1100/leds-badge4.c
arch/arm/mach-sa1100/leds-badge4.c
+0
-110
arch/arm/mach-sa1100/leds-cerf.c
arch/arm/mach-sa1100/leds-cerf.c
+0
-109
arch/arm/mach-sa1100/leds-hackkit.c
arch/arm/mach-sa1100/leds-hackkit.c
+0
-111
arch/arm/mach-sa1100/leds-lart.c
arch/arm/mach-sa1100/leds-lart.c
+0
-100
arch/arm/mach-sa1100/leds.c
arch/arm/mach-sa1100/leds.c
+0
-50
arch/arm/mach-sa1100/leds.h
arch/arm/mach-sa1100/leds.h
+0
-13
No files found.
arch/arm/mach-sa1100/Makefile
View file @
18775a7b
...
...
@@ -7,21 +7,17 @@ obj-y := clock.o generic.o irq.o time.o #nmi-oopser.o
obj-m
:=
obj-n
:=
obj-
:=
led-y
:=
leds.o
obj-$(CONFIG_CPU_FREQ_SA1100)
+=
cpu-sa1100.o
obj-$(CONFIG_CPU_FREQ_SA1110)
+=
cpu-sa1110.o
# Specific board support
obj-$(CONFIG_SA1100_ASSABET)
+=
assabet.o
led-$(CONFIG_SA1100_ASSABET)
+=
leds-assabet.o
obj-$(CONFIG_ASSABET_NEPONSET)
+=
neponset.o
obj-$(CONFIG_SA1100_BADGE4)
+=
badge4.o
led-$(CONFIG_SA1100_BADGE4)
+=
leds-badge4.o
obj-$(CONFIG_SA1100_CERF)
+=
cerf.o
led-$(CONFIG_SA1100_CERF)
+=
leds-cerf.o
obj-$(CONFIG_SA1100_COLLIE)
+=
collie.o
...
...
@@ -29,13 +25,11 @@ obj-$(CONFIG_SA1100_H3100) += h3100.o h3xxx.o
obj-$(CONFIG_SA1100_H3600)
+=
h3600.o h3xxx.o
obj-$(CONFIG_SA1100_HACKKIT)
+=
hackkit.o
led-$(CONFIG_SA1100_HACKKIT)
+=
leds-hackkit.o
obj-$(CONFIG_SA1100_JORNADA720)
+=
jornada720.o
obj-$(CONFIG_SA1100_JORNADA720_SSP)
+=
jornada720_ssp.o
obj-$(CONFIG_SA1100_LART)
+=
lart.o
led-$(CONFIG_SA1100_LART)
+=
leds-lart.o
obj-$(CONFIG_SA1100_NANOENGINE)
+=
nanoengine.o
obj-$(CONFIG_PCI_NANOENGINE)
+=
pci-nanoengine.o
...
...
@@ -46,9 +40,6 @@ obj-$(CONFIG_SA1100_SHANNON) += shannon.o
obj-$(CONFIG_SA1100_SIMPAD)
+=
simpad.o
# LEDs support
obj-$(CONFIG_LEDS)
+=
$
(
led-y
)
# Miscellaneous functions
obj-$(CONFIG_PM)
+=
pm.o sleep.o
obj-$(CONFIG_SA1100_SSP)
+=
ssp.o
...
...
arch/arm/mach-sa1100/assabet.c
View file @
18775a7b
...
...
@@ -20,6 +20,8 @@
#include <linux/mtd/partitions.h>
#include <linux/delay.h>
#include <linux/mm.h>
#include <linux/leds.h>
#include <linux/slab.h>
#include <video/sa1100fb.h>
...
...
@@ -529,6 +531,89 @@ static void __init assabet_map_io(void)
sa1100_register_uart
(
2
,
3
);
}
/* LEDs */
#if defined(CONFIG_NEW_LEDS) && defined(CONFIG_LEDS_CLASS)
struct
assabet_led
{
struct
led_classdev
cdev
;
u32
mask
;
};
/*
* The triggers lines up below will only be used if the
* LED triggers are compiled in.
*/
static
const
struct
{
const
char
*
name
;
const
char
*
trigger
;
}
assabet_leds
[]
=
{
{
"assabet:red"
,
"cpu0"
,},
{
"assabet:green"
,
"heartbeat"
,
},
};
/*
* The LED control in Assabet is reversed:
* - setting bit means turn off LED
* - clearing bit means turn on LED
*/
static
void
assabet_led_set
(
struct
led_classdev
*
cdev
,
enum
led_brightness
b
)
{
struct
assabet_led
*
led
=
container_of
(
cdev
,
struct
assabet_led
,
cdev
);
if
(
b
!=
LED_OFF
)
ASSABET_BCR_clear
(
led
->
mask
);
else
ASSABET_BCR_set
(
led
->
mask
);
}
static
enum
led_brightness
assabet_led_get
(
struct
led_classdev
*
cdev
)
{
struct
assabet_led
*
led
=
container_of
(
cdev
,
struct
assabet_led
,
cdev
);
return
(
ASSABET_BCR
&
led
->
mask
)
?
LED_OFF
:
LED_FULL
;
}
static
int
__init
assabet_leds_init
(
void
)
{
int
i
;
if
(
!
machine_is_assabet
())
return
-
ENODEV
;
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
assabet_leds
);
i
++
)
{
struct
assabet_led
*
led
;
led
=
kzalloc
(
sizeof
(
*
led
),
GFP_KERNEL
);
if
(
!
led
)
break
;
led
->
cdev
.
name
=
assabet_leds
[
i
].
name
;
led
->
cdev
.
brightness_set
=
assabet_led_set
;
led
->
cdev
.
brightness_get
=
assabet_led_get
;
led
->
cdev
.
default_trigger
=
assabet_leds
[
i
].
trigger
;
if
(
!
i
)
led
->
mask
=
ASSABET_BCR_LED_RED
;
else
led
->
mask
=
ASSABET_BCR_LED_GREEN
;
if
(
led_classdev_register
(
NULL
,
&
led
->
cdev
)
<
0
)
{
kfree
(
led
);
break
;
}
}
return
0
;
}
/*
* Since we may have triggers on any subsystem, defer registration
* until after subsystem_init.
*/
fs_initcall
(
assabet_leds_init
);
#endif
MACHINE_START
(
ASSABET
,
"Intel-Assabet"
)
.
atag_offset
=
0x100
,
...
...
arch/arm/mach-sa1100/badge4.c
View file @
18775a7b
...
...
@@ -22,6 +22,8 @@
#include <linux/mtd/mtd.h>
#include <linux/mtd/partitions.h>
#include <linux/errno.h>
#include <linux/gpio.h>
#include <linux/leds.h>
#include <mach/hardware.h>
#include <asm/mach-types.h>
...
...
@@ -76,8 +78,36 @@ static struct platform_device sa1111_device = {
.
resource
=
sa1111_resources
,
};
/* LEDs */
struct
gpio_led
badge4_gpio_leds
[]
=
{
{
.
name
=
"badge4:red"
,
.
default_trigger
=
"heartbeat"
,
.
gpio
=
7
,
},
{
.
name
=
"badge4:green"
,
.
default_trigger
=
"cpu0"
,
.
gpio
=
9
,
},
};
static
struct
gpio_led_platform_data
badge4_gpio_led_info
=
{
.
leds
=
badge4_gpio_leds
,
.
num_leds
=
ARRAY_SIZE
(
badge4_gpio_leds
),
};
static
struct
platform_device
badge4_leds
=
{
.
name
=
"leds-gpio"
,
.
id
=
-
1
,
.
dev
=
{
.
platform_data
=
&
badge4_gpio_led_info
,
}
};
static
struct
platform_device
*
devices
[]
__initdata
=
{
&
sa1111_device
,
&
badge4_leds
,
};
static
int
__init
badge4_sa1111_init
(
void
)
...
...
arch/arm/mach-sa1100/cerf.c
View file @
18775a7b
...
...
@@ -17,6 +17,8 @@
#include <linux/irq.h>
#include <linux/mtd/mtd.h>
#include <linux/mtd/partitions.h>
#include <linux/gpio.h>
#include <linux/leds.h>
#include <mach/hardware.h>
#include <asm/setup.h>
...
...
@@ -43,8 +45,48 @@ static struct platform_device cerfuart2_device = {
.
resource
=
cerfuart2_resources
,
};
/* LEDs */
struct
gpio_led
cerf_gpio_leds
[]
=
{
{
.
name
=
"cerf:d0"
,
.
default_trigger
=
"heartbeat"
,
.
gpio
=
0
,
},
{
.
name
=
"cerf:d1"
,
.
default_trigger
=
"cpu0"
,
.
gpio
=
1
,
},
{
.
name
=
"cerf:d2"
,
.
default_trigger
=
"default-on"
,
.
gpio
=
2
,
},
{
.
name
=
"cerf:d3"
,
.
default_trigger
=
"default-on"
,
.
gpio
=
3
,
},
};
static
struct
gpio_led_platform_data
cerf_gpio_led_info
=
{
.
leds
=
cerf_gpio_leds
,
.
num_leds
=
ARRAY_SIZE
(
cerf_gpio_leds
),
};
static
struct
platform_device
cerf_leds
=
{
.
name
=
"leds-gpio"
,
.
id
=
-
1
,
.
dev
=
{
.
platform_data
=
&
cerf_gpio_led_info
,
}
};
static
struct
platform_device
*
cerf_devices
[]
__initdata
=
{
&
cerfuart2_device
,
&
cerf_leds
,
};
#ifdef CONFIG_SA1100_CERF_FLASH_32MB
...
...
arch/arm/mach-sa1100/hackkit.c
View file @
18775a7b
...
...
@@ -21,6 +21,10 @@
#include <linux/serial_core.h>
#include <linux/mtd/mtd.h>
#include <linux/mtd/partitions.h>
#include <linux/tty.h>
#include <linux/gpio.h>
#include <linux/leds.h>
#include <linux/platform_device.h>
#include <asm/mach-types.h>
#include <asm/setup.h>
...
...
@@ -183,9 +187,37 @@ static struct flash_platform_data hackkit_flash_data = {
static
struct
resource
hackkit_flash_resource
=
DEFINE_RES_MEM
(
SA1100_CS0_PHYS
,
SZ_32M
);
/* LEDs */
struct
gpio_led
hackkit_gpio_leds
[]
=
{
{
.
name
=
"hackkit:red"
,
.
default_trigger
=
"cpu0"
,
.
gpio
=
22
,
},
{
.
name
=
"hackkit:green"
,
.
default_trigger
=
"heartbeat"
,
.
gpio
=
23
,
},
};
static
struct
gpio_led_platform_data
hackkit_gpio_led_info
=
{
.
leds
=
hackkit_gpio_leds
,
.
num_leds
=
ARRAY_SIZE
(
hackkit_gpio_leds
),
};
static
struct
platform_device
hackkit_leds
=
{
.
name
=
"leds-gpio"
,
.
id
=
-
1
,
.
dev
=
{
.
platform_data
=
&
hackkit_gpio_led_info
,
}
};
static
void
__init
hackkit_init
(
void
)
{
sa11x0_register_mtd
(
&
hackkit_flash_data
,
&
hackkit_flash_resource
,
1
);
platform_device_register
(
&
hackkit_leds
);
}
/**********************************************************************
...
...
arch/arm/mach-sa1100/lart.c
View file @
18775a7b
...
...
@@ -5,6 +5,9 @@
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/tty.h>
#include <linux/gpio.h>
#include <linux/leds.h>
#include <linux/platform_device.h>
#include <video/sa1100fb.h>
...
...
@@ -126,6 +129,27 @@ static struct map_desc lart_io_desc[] __initdata = {
}
};
/* LEDs */
struct
gpio_led
lart_gpio_leds
[]
=
{
{
.
name
=
"lart:red"
,
.
default_trigger
=
"cpu0"
,
.
gpio
=
23
,
},
};
static
struct
gpio_led_platform_data
lart_gpio_led_info
=
{
.
leds
=
lart_gpio_leds
,
.
num_leds
=
ARRAY_SIZE
(
lart_gpio_leds
),
};
static
struct
platform_device
lart_leds
=
{
.
name
=
"leds-gpio"
,
.
id
=
-
1
,
.
dev
=
{
.
platform_data
=
&
lart_gpio_led_info
,
}
};
static
void
__init
lart_map_io
(
void
)
{
sa1100_map_io
();
...
...
@@ -139,6 +163,8 @@ static void __init lart_map_io(void)
GPDR
|=
GPIO_UART_TXD
;
GPDR
&=
~
GPIO_UART_RXD
;
PPAR
|=
PPAR_UPR
;
platform_device_register
(
&
lart_leds
);
}
MACHINE_START
(
LART
,
"LART"
)
...
...
arch/arm/mach-sa1100/leds-assabet.c
deleted
100644 → 0
View file @
dafbeadf
/*
* linux/arch/arm/mach-sa1100/leds-assabet.c
*
* Copyright (C) 2000 John Dorsey <john+@cs.cmu.edu>
*
* Original (leds-footbridge.c) by Russell King
*
* Assabet uses the LEDs as follows:
* - Green - toggles state every 50 timer interrupts
* - Red - on if system is not idle
*/
#include <linux/init.h>
#include <mach/hardware.h>
#include <asm/leds.h>
#include <mach/assabet.h>
#include "leds.h"
#define LED_STATE_ENABLED 1
#define LED_STATE_CLAIMED 2
static
unsigned
int
led_state
;
static
unsigned
int
hw_led_state
;
#define ASSABET_BCR_LED_MASK (ASSABET_BCR_LED_GREEN | ASSABET_BCR_LED_RED)
void
assabet_leds_event
(
led_event_t
evt
)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
switch
(
evt
)
{
case
led_start
:
hw_led_state
=
ASSABET_BCR_LED_RED
|
ASSABET_BCR_LED_GREEN
;
led_state
=
LED_STATE_ENABLED
;
break
;
case
led_stop
:
led_state
&=
~
LED_STATE_ENABLED
;
hw_led_state
=
ASSABET_BCR_LED_RED
|
ASSABET_BCR_LED_GREEN
;
ASSABET_BCR_frob
(
ASSABET_BCR_LED_MASK
,
hw_led_state
);
break
;
case
led_claim
:
led_state
|=
LED_STATE_CLAIMED
;
hw_led_state
=
ASSABET_BCR_LED_RED
|
ASSABET_BCR_LED_GREEN
;
break
;
case
led_release
:
led_state
&=
~
LED_STATE_CLAIMED
;
hw_led_state
=
ASSABET_BCR_LED_RED
|
ASSABET_BCR_LED_GREEN
;
break
;
#ifdef CONFIG_LEDS_TIMER
case
led_timer
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
^=
ASSABET_BCR_LED_GREEN
;
break
;
#endif
#ifdef CONFIG_LEDS_CPU
case
led_idle_start
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
ASSABET_BCR_LED_RED
;
break
;
case
led_idle_end
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
ASSABET_BCR_LED_RED
;
break
;
#endif
case
led_halted
:
break
;
case
led_green_on
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
&=
~
ASSABET_BCR_LED_GREEN
;
break
;
case
led_green_off
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
|=
ASSABET_BCR_LED_GREEN
;
break
;
case
led_amber_on
:
break
;
case
led_amber_off
:
break
;
case
led_red_on
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
&=
~
ASSABET_BCR_LED_RED
;
break
;
case
led_red_off
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
|=
ASSABET_BCR_LED_RED
;
break
;
default:
break
;
}
if
(
led_state
&
LED_STATE_ENABLED
)
ASSABET_BCR_frob
(
ASSABET_BCR_LED_MASK
,
hw_led_state
);
local_irq_restore
(
flags
);
}
arch/arm/mach-sa1100/leds-badge4.c
deleted
100644 → 0
View file @
dafbeadf
/*
* linux/arch/arm/mach-sa1100/leds-badge4.c
*
* Author: Christopher Hoover <ch@hpl.hp.com>
* Copyright (C) 2002 Hewlett-Packard Company
*
* 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/init.h>
#include <mach/hardware.h>
#include <asm/leds.h>
#include "leds.h"
#define LED_STATE_ENABLED 1
#define LED_STATE_CLAIMED 2
static
unsigned
int
led_state
;
static
unsigned
int
hw_led_state
;
#define LED_RED GPIO_GPIO(7)
#define LED_GREEN GPIO_GPIO(9)
#define LED_MASK (LED_RED|LED_GREEN)
#define LED_IDLE LED_GREEN
#define LED_TIMER LED_RED
void
badge4_leds_event
(
led_event_t
evt
)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
switch
(
evt
)
{
case
led_start
:
GPDR
|=
LED_MASK
;
hw_led_state
=
LED_MASK
;
led_state
=
LED_STATE_ENABLED
;
break
;
case
led_stop
:
led_state
&=
~
LED_STATE_ENABLED
;
break
;
case
led_claim
:
led_state
|=
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
case
led_release
:
led_state
&=
~
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
#ifdef CONFIG_LEDS_TIMER
case
led_timer
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
^=
LED_TIMER
;
break
;
#endif
#ifdef CONFIG_LEDS_CPU
case
led_idle_start
:
/* LED off when system is idle */
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_IDLE
;
break
;
case
led_idle_end
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_IDLE
;
break
;
#endif
case
led_red_on
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_RED
;
break
;
case
led_red_off
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_RED
;
break
;
case
led_green_on
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_GREEN
;
break
;
case
led_green_off
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_GREEN
;
break
;
default:
break
;
}
if
(
led_state
&
LED_STATE_ENABLED
)
{
GPSR
=
hw_led_state
;
GPCR
=
hw_led_state
^
LED_MASK
;
}
local_irq_restore
(
flags
);
}
arch/arm/mach-sa1100/leds-cerf.c
deleted
100644 → 0
View file @
dafbeadf
/*
* linux/arch/arm/mach-sa1100/leds-cerf.c
*
* Author: ???
*/
#include <linux/init.h>
#include <mach/hardware.h>
#include <asm/leds.h>
#include "leds.h"
#define LED_STATE_ENABLED 1
#define LED_STATE_CLAIMED 2
static
unsigned
int
led_state
;
static
unsigned
int
hw_led_state
;
#define LED_D0 GPIO_GPIO(0)
#define LED_D1 GPIO_GPIO(1)
#define LED_D2 GPIO_GPIO(2)
#define LED_D3 GPIO_GPIO(3)
#define LED_MASK (LED_D0|LED_D1|LED_D2|LED_D3)
void
cerf_leds_event
(
led_event_t
evt
)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
switch
(
evt
)
{
case
led_start
:
hw_led_state
=
LED_MASK
;
led_state
=
LED_STATE_ENABLED
;
break
;
case
led_stop
:
led_state
&=
~
LED_STATE_ENABLED
;
break
;
case
led_claim
:
led_state
|=
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
case
led_release
:
led_state
&=
~
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
#ifdef CONFIG_LEDS_TIMER
case
led_timer
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
^=
LED_D0
;
break
;
#endif
#ifdef CONFIG_LEDS_CPU
case
led_idle_start
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_D1
;
break
;
case
led_idle_end
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_D1
;
break
;
#endif
case
led_green_on
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_D2
;
break
;
case
led_green_off
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_D2
;
break
;
case
led_amber_on
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_D3
;
break
;
case
led_amber_off
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_D3
;
break
;
case
led_red_on
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_D1
;
break
;
case
led_red_off
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_D1
;
break
;
default:
break
;
}
if
(
led_state
&
LED_STATE_ENABLED
)
{
GPSR
=
hw_led_state
;
GPCR
=
hw_led_state
^
LED_MASK
;
}
local_irq_restore
(
flags
);
}
arch/arm/mach-sa1100/leds-hackkit.c
deleted
100644 → 0
View file @
dafbeadf
/*
* linux/arch/arm/mach-sa1100/leds-hackkit.c
*
* based on leds-lart.c
*
* (C) Erik Mouw (J.A.K.Mouw@its.tudelft.nl), April 21, 2000
* (C) Stefan Eletzhofer <stefan.eletzhofer@eletztrick.de>, 2002
*
* The HackKit has two leds (GPIO 22/23). The red led (gpio 22) is used
* as cpu led, the green one is used as timer led.
*/
#include <linux/init.h>
#include <mach/hardware.h>
#include <asm/leds.h>
#include "leds.h"
#define LED_STATE_ENABLED 1
#define LED_STATE_CLAIMED 2
static
unsigned
int
led_state
;
static
unsigned
int
hw_led_state
;
#define LED_GREEN GPIO_GPIO23
#define LED_RED GPIO_GPIO22
#define LED_MASK (LED_RED | LED_GREEN)
void
hackkit_leds_event
(
led_event_t
evt
)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
switch
(
evt
)
{
case
led_start
:
/* pin 22/23 are outputs */
GPDR
|=
LED_MASK
;
hw_led_state
=
LED_MASK
;
led_state
=
LED_STATE_ENABLED
;
break
;
case
led_stop
:
led_state
&=
~
LED_STATE_ENABLED
;
break
;
case
led_claim
:
led_state
|=
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
case
led_release
:
led_state
&=
~
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
#ifdef CONFIG_LEDS_TIMER
case
led_timer
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
^=
LED_GREEN
;
break
;
#endif
#ifdef CONFIG_LEDS_CPU
case
led_idle_start
:
/* The LART people like the LED to be off when the
system is idle... */
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_RED
;
break
;
case
led_idle_end
:
/* ... and on if the system is not idle */
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_RED
;
break
;
#endif
case
led_red_on
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
&=
~
LED_RED
;
break
;
case
led_red_off
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
|=
LED_RED
;
break
;
case
led_green_on
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
&=
~
LED_GREEN
;
break
;
case
led_green_off
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
|=
LED_GREEN
;
break
;
default:
break
;
}
/* Now set the GPIO state, or nothing will happen at all */
if
(
led_state
&
LED_STATE_ENABLED
)
{
GPSR
=
hw_led_state
;
GPCR
=
hw_led_state
^
LED_MASK
;
}
local_irq_restore
(
flags
);
}
arch/arm/mach-sa1100/leds-lart.c
deleted
100644 → 0
View file @
dafbeadf
/*
* linux/arch/arm/mach-sa1100/leds-lart.c
*
* (C) Erik Mouw (J.A.K.Mouw@its.tudelft.nl), April 21, 2000
*
* LART uses the LED as follows:
* - GPIO23 is the LED, on if system is not idle
* You can use both CONFIG_LEDS_CPU and CONFIG_LEDS_TIMER at the same
* time, but in that case the timer events will still dictate the
* pace of the LED.
*/
#include <linux/init.h>
#include <mach/hardware.h>
#include <asm/leds.h>
#include "leds.h"
#define LED_STATE_ENABLED 1
#define LED_STATE_CLAIMED 2
static
unsigned
int
led_state
;
static
unsigned
int
hw_led_state
;
#define LED_23 GPIO_GPIO23
#define LED_MASK (LED_23)
void
lart_leds_event
(
led_event_t
evt
)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
switch
(
evt
)
{
case
led_start
:
/* pin 23 is output pin */
GPDR
|=
LED_23
;
hw_led_state
=
LED_MASK
;
led_state
=
LED_STATE_ENABLED
;
break
;
case
led_stop
:
led_state
&=
~
LED_STATE_ENABLED
;
break
;
case
led_claim
:
led_state
|=
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
case
led_release
:
led_state
&=
~
LED_STATE_CLAIMED
;
hw_led_state
=
LED_MASK
;
break
;
#ifdef CONFIG_LEDS_TIMER
case
led_timer
:
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
^=
LED_23
;
break
;
#endif
#ifdef CONFIG_LEDS_CPU
case
led_idle_start
:
/* The LART people like the LED to be off when the
system is idle... */
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
&=
~
LED_23
;
break
;
case
led_idle_end
:
/* ... and on if the system is not idle */
if
(
!
(
led_state
&
LED_STATE_CLAIMED
))
hw_led_state
|=
LED_23
;
break
;
#endif
case
led_red_on
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
&=
~
LED_23
;
break
;
case
led_red_off
:
if
(
led_state
&
LED_STATE_CLAIMED
)
hw_led_state
|=
LED_23
;
break
;
default:
break
;
}
/* Now set the GPIO state, or nothing will happen at all */
if
(
led_state
&
LED_STATE_ENABLED
)
{
GPSR
=
hw_led_state
;
GPCR
=
hw_led_state
^
LED_MASK
;
}
local_irq_restore
(
flags
);
}
arch/arm/mach-sa1100/leds.c
deleted
100644 → 0
View file @
dafbeadf
/*
* linux/arch/arm/mach-sa1100/leds.c
*
* SA1100 LEDs dispatcher
*
* Copyright (C) 2001 Nicolas Pitre
*/
#include <linux/compiler.h>
#include <linux/init.h>
#include <asm/leds.h>
#include <asm/mach-types.h>
#include "leds.h"
static
int
__init
sa1100_leds_init
(
void
)
{
if
(
machine_is_assabet
())
leds_event
=
assabet_leds_event
;
if
(
machine_is_consus
())
leds_event
=
consus_leds_event
;
if
(
machine_is_badge4
())
leds_event
=
badge4_leds_event
;
if
(
machine_is_brutus
())
leds_event
=
brutus_leds_event
;
if
(
machine_is_cerf
())
leds_event
=
cerf_leds_event
;
if
(
machine_is_flexanet
())
leds_event
=
flexanet_leds_event
;
if
(
machine_is_graphicsclient
())
leds_event
=
graphicsclient_leds_event
;
if
(
machine_is_hackkit
())
leds_event
=
hackkit_leds_event
;
if
(
machine_is_lart
())
leds_event
=
lart_leds_event
;
if
(
machine_is_pfs168
())
leds_event
=
pfs168_leds_event
;
if
(
machine_is_graphicsmaster
())
leds_event
=
graphicsmaster_leds_event
;
if
(
machine_is_adsbitsy
())
leds_event
=
adsbitsy_leds_event
;
if
(
machine_is_pt_system3
())
leds_event
=
system3_leds_event
;
leds_event
(
led_start
);
return
0
;
}
core_initcall
(
sa1100_leds_init
);
arch/arm/mach-sa1100/leds.h
deleted
100644 → 0
View file @
dafbeadf
extern
void
assabet_leds_event
(
led_event_t
evt
);
extern
void
badge4_leds_event
(
led_event_t
evt
);
extern
void
consus_leds_event
(
led_event_t
evt
);
extern
void
brutus_leds_event
(
led_event_t
evt
);
extern
void
cerf_leds_event
(
led_event_t
evt
);
extern
void
flexanet_leds_event
(
led_event_t
evt
);
extern
void
graphicsclient_leds_event
(
led_event_t
evt
);
extern
void
hackkit_leds_event
(
led_event_t
evt
);
extern
void
lart_leds_event
(
led_event_t
evt
);
extern
void
pfs168_leds_event
(
led_event_t
evt
);
extern
void
graphicsmaster_leds_event
(
led_event_t
evt
);
extern
void
adsbitsy_leds_event
(
led_event_t
evt
);
extern
void
system3_leds_event
(
led_event_t
evt
);
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment