Thomas Chou | 836fcc5 | 2010-04-30 11:34:14 +0800 | [diff] [blame] | 1 | /* |
| 2 | * Status LED driver based on GPIO access conventions of Linux |
| 3 | * |
| 4 | * Copyright (C) 2010 Thomas Chou <thomas@wytron.com.tw> |
Thomas Chou | 2658e66 | 2010-06-09 13:32:46 +0800 | [diff] [blame] | 5 | * Licensed under the GPL-2 or later. |
Thomas Chou | 836fcc5 | 2010-04-30 11:34:14 +0800 | [diff] [blame] | 6 | */ |
| 7 | |
| 8 | #include <common.h> |
| 9 | #include <status_led.h> |
| 10 | #include <asm/gpio.h> |
| 11 | |
Igor Grinberg | 203bd9f | 2013-11-08 01:03:52 +0200 | [diff] [blame] | 12 | #ifndef CONFIG_GPIO_LED_INVERTED_TABLE |
| 13 | #define CONFIG_GPIO_LED_INVERTED_TABLE {} |
| 14 | #endif |
| 15 | |
| 16 | static led_id_t gpio_led_inv[] = CONFIG_GPIO_LED_INVERTED_TABLE; |
| 17 | |
| 18 | static int gpio_led_gpio_value(led_id_t mask, int state) |
| 19 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 20 | int i, gpio_value = (state == CONFIG_LED_STATUS_ON); |
Igor Grinberg | 203bd9f | 2013-11-08 01:03:52 +0200 | [diff] [blame] | 21 | |
| 22 | for (i = 0; i < ARRAY_SIZE(gpio_led_inv); i++) { |
| 23 | if (gpio_led_inv[i] == mask) |
| 24 | gpio_value = !gpio_value; |
| 25 | } |
| 26 | |
| 27 | return gpio_value; |
| 28 | } |
| 29 | |
Thomas Chou | 836fcc5 | 2010-04-30 11:34:14 +0800 | [diff] [blame] | 30 | void __led_init(led_id_t mask, int state) |
| 31 | { |
Igor Grinberg | 203bd9f | 2013-11-08 01:03:52 +0200 | [diff] [blame] | 32 | int gpio_value; |
| 33 | |
Igor Grinberg | 80dfc42 | 2013-11-08 01:03:51 +0200 | [diff] [blame] | 34 | if (gpio_request(mask, "gpio_led") != 0) { |
| 35 | printf("%s: failed requesting GPIO%lu!\n", __func__, mask); |
| 36 | return; |
| 37 | } |
| 38 | |
Igor Grinberg | 203bd9f | 2013-11-08 01:03:52 +0200 | [diff] [blame] | 39 | gpio_value = gpio_led_gpio_value(mask, state); |
| 40 | gpio_direction_output(mask, gpio_value); |
Thomas Chou | 836fcc5 | 2010-04-30 11:34:14 +0800 | [diff] [blame] | 41 | } |
| 42 | |
| 43 | void __led_set(led_id_t mask, int state) |
| 44 | { |
Igor Grinberg | 203bd9f | 2013-11-08 01:03:52 +0200 | [diff] [blame] | 45 | int gpio_value = gpio_led_gpio_value(mask, state); |
| 46 | |
| 47 | gpio_set_value(mask, gpio_value); |
Thomas Chou | 836fcc5 | 2010-04-30 11:34:14 +0800 | [diff] [blame] | 48 | } |
| 49 | |
| 50 | void __led_toggle(led_id_t mask) |
| 51 | { |
| 52 | gpio_set_value(mask, !gpio_get_value(mask)); |
| 53 | } |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 54 | |
| 55 | #ifdef CONFIG_GPIO_LED_STUBS |
| 56 | |
| 57 | /* 'generic' override of colored LED stubs, to use GPIO functions instead */ |
| 58 | |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 59 | #ifdef CONFIG_LED_STATUS_RED |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 60 | void red_led_on(void) |
| 61 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 62 | __led_set(CONFIG_LED_STATUS_RED, CONFIG_LED_STATUS_ON); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 63 | } |
| 64 | |
| 65 | void red_led_off(void) |
| 66 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 67 | __led_set(CONFIG_LED_STATUS_RED, CONFIG_LED_STATUS_OFF); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 68 | } |
| 69 | #endif |
| 70 | |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 71 | #ifdef CONFIG_LED_STATUS_GREEN |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 72 | void green_led_on(void) |
| 73 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 74 | __led_set(CONFIG_LED_STATUS_GREEN, CONFIG_LED_STATUS_ON); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 75 | } |
| 76 | |
| 77 | void green_led_off(void) |
| 78 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 79 | __led_set(CONFIG_LED_STATUS_GREEN, CONFIG_LED_STATUS_OFF); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 80 | } |
| 81 | #endif |
| 82 | |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 83 | #ifdef CONFIG_LED_STATUS_YELLOW |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 84 | void yellow_led_on(void) |
| 85 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 86 | __led_set(CONFIG_LED_STATUS_YELLOW, CONFIG_LED_STATUS_ON); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 87 | } |
| 88 | |
| 89 | void yellow_led_off(void) |
| 90 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 91 | __led_set(CONFIG_LED_STATUS_YELLOW, CONFIG_LED_STATUS_OFF); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 92 | } |
| 93 | #endif |
| 94 | |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 95 | #ifdef CONFIG_LED_STATUS_BLUE |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 96 | void blue_led_on(void) |
| 97 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 98 | __led_set(CONFIG_LED_STATUS_BLUE, CONFIG_LED_STATUS_ON); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 99 | } |
| 100 | |
| 101 | void blue_led_off(void) |
| 102 | { |
Uri Mashiach | 4892d39 | 2017-01-19 10:51:45 +0200 | [diff] [blame] | 103 | __led_set(CONFIG_LED_STATUS_BLUE, CONFIG_LED_STATUS_OFF); |
Bernhard Nortmann | 191be39 | 2015-08-21 15:13:20 +0200 | [diff] [blame] | 104 | } |
| 105 | #endif |
| 106 | |
| 107 | #endif /* CONFIG_GPIO_LED_STUBS */ |