leds-cobalt-qube.c 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*
  2. * Copyright 2006 - Florian Fainelli <florian@openwrt.org>
  3. *
  4. * Control the Cobalt Qube/RaQ front LED
  5. */
  6. #include <linux/io.h>
  7. #include <linux/ioport.h>
  8. #include <linux/leds.h>
  9. #include <linux/module.h>
  10. #include <linux/platform_device.h>
  11. #include <linux/types.h>
  12. #define LED_FRONT_LEFT 0x01
  13. #define LED_FRONT_RIGHT 0x02
  14. static void __iomem *led_port;
  15. static u8 led_value;
  16. static void qube_front_led_set(struct led_classdev *led_cdev,
  17. enum led_brightness brightness)
  18. {
  19. if (brightness)
  20. led_value = LED_FRONT_LEFT | LED_FRONT_RIGHT;
  21. else
  22. led_value = ~(LED_FRONT_LEFT | LED_FRONT_RIGHT);
  23. writeb(led_value, led_port);
  24. }
  25. static struct led_classdev qube_front_led = {
  26. .name = "qube::front",
  27. .brightness = LED_FULL,
  28. .brightness_set = qube_front_led_set,
  29. .default_trigger = "default-on",
  30. };
  31. static int cobalt_qube_led_probe(struct platform_device *pdev)
  32. {
  33. struct resource *res;
  34. int retval;
  35. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  36. if (!res)
  37. return -EBUSY;
  38. led_port = devm_ioremap(&pdev->dev, res->start, resource_size(res));
  39. if (!led_port)
  40. return -ENOMEM;
  41. led_value = LED_FRONT_LEFT | LED_FRONT_RIGHT;
  42. writeb(led_value, led_port);
  43. retval = led_classdev_register(&pdev->dev, &qube_front_led);
  44. if (retval)
  45. goto err_null;
  46. return 0;
  47. err_null:
  48. led_port = NULL;
  49. return retval;
  50. }
  51. static int cobalt_qube_led_remove(struct platform_device *pdev)
  52. {
  53. led_classdev_unregister(&qube_front_led);
  54. if (led_port)
  55. led_port = NULL;
  56. return 0;
  57. }
  58. static struct platform_driver cobalt_qube_led_driver = {
  59. .probe = cobalt_qube_led_probe,
  60. .remove = cobalt_qube_led_remove,
  61. .driver = {
  62. .name = "cobalt-qube-leds",
  63. },
  64. };
  65. module_platform_driver(cobalt_qube_led_driver);
  66. MODULE_LICENSE("GPL");
  67. MODULE_DESCRIPTION("Front LED support for Cobalt Server");
  68. MODULE_AUTHOR("Florian Fainelli <florian@openwrt.org>");
  69. MODULE_ALIAS("platform:cobalt-qube-leds");