leds-idp.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. /*
  2. * linux/arch/arm/mach-pxa/leds-idp.c
  3. *
  4. * Copyright (C) 2000 John Dorsey <john+@cs.cmu.edu>
  5. *
  6. * Copyright (c) 2001 Jeff Sutherland <jeffs@accelent.com>
  7. *
  8. * Original (leds-footbridge.c) by Russell King
  9. *
  10. * Macros for actual LED manipulation should be in machine specific
  11. * files in this 'mach' directory.
  12. */
  13. #include <linux/config.h>
  14. #include <linux/init.h>
  15. #include <asm/hardware.h>
  16. #include <asm/leds.h>
  17. #include <asm/system.h>
  18. #include <asm/arch/pxa-regs.h>
  19. #include <asm/arch/idp.h>
  20. #include "leds.h"
  21. #define LED_STATE_ENABLED 1
  22. #define LED_STATE_CLAIMED 2
  23. static unsigned int led_state;
  24. static unsigned int hw_led_state;
  25. void idp_leds_event(led_event_t evt)
  26. {
  27. unsigned long flags;
  28. local_irq_save(flags);
  29. switch (evt) {
  30. case led_start:
  31. hw_led_state = IDP_HB_LED | IDP_BUSY_LED;
  32. led_state = LED_STATE_ENABLED;
  33. break;
  34. case led_stop:
  35. led_state &= ~LED_STATE_ENABLED;
  36. break;
  37. case led_claim:
  38. led_state |= LED_STATE_CLAIMED;
  39. hw_led_state = IDP_HB_LED | IDP_BUSY_LED;
  40. break;
  41. case led_release:
  42. led_state &= ~LED_STATE_CLAIMED;
  43. hw_led_state = IDP_HB_LED | IDP_BUSY_LED;
  44. break;
  45. #ifdef CONFIG_LEDS_TIMER
  46. case led_timer:
  47. if (!(led_state & LED_STATE_CLAIMED))
  48. hw_led_state ^= IDP_HB_LED;
  49. break;
  50. #endif
  51. #ifdef CONFIG_LEDS_CPU
  52. case led_idle_start:
  53. if (!(led_state & LED_STATE_CLAIMED))
  54. hw_led_state &= ~IDP_BUSY_LED;
  55. break;
  56. case led_idle_end:
  57. if (!(led_state & LED_STATE_CLAIMED))
  58. hw_led_state |= IDP_BUSY_LED;
  59. break;
  60. #endif
  61. case led_halted:
  62. break;
  63. case led_green_on:
  64. if (led_state & LED_STATE_CLAIMED)
  65. hw_led_state |= IDP_HB_LED;
  66. break;
  67. case led_green_off:
  68. if (led_state & LED_STATE_CLAIMED)
  69. hw_led_state &= ~IDP_HB_LED;
  70. break;
  71. case led_amber_on:
  72. break;
  73. case led_amber_off:
  74. break;
  75. case led_red_on:
  76. if (led_state & LED_STATE_CLAIMED)
  77. hw_led_state |= IDP_BUSY_LED;
  78. break;
  79. case led_red_off:
  80. if (led_state & LED_STATE_CLAIMED)
  81. hw_led_state &= ~IDP_BUSY_LED;
  82. break;
  83. default:
  84. break;
  85. }
  86. if (led_state & LED_STATE_ENABLED)
  87. IDP_CPLD_LED_CONTROL = ( (IDP_CPLD_LED_CONTROL | IDP_LEDS_MASK) & ~hw_led_state);
  88. else
  89. IDP_CPLD_LED_CONTROL |= IDP_LEDS_MASK;
  90. local_irq_restore(flags);
  91. }