jornada720_bl.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. *
  4. * Backlight driver for HP Jornada 700 series (710/720/728)
  5. * Copyright (C) 2006-2009 Kristoffer Ericson <kristoffer.ericson@gmail.com>
  6. */
  7. #include <linux/backlight.h>
  8. #include <linux/device.h>
  9. #include <linux/kernel.h>
  10. #include <linux/module.h>
  11. #include <linux/platform_device.h>
  12. #include <mach/jornada720.h>
  13. #include <mach/hardware.h>
  14. #include <video/s1d13xxxfb.h>
  15. #define BL_MAX_BRIGHT 255
  16. #define BL_DEF_BRIGHT 25
  17. static int jornada_bl_get_brightness(struct backlight_device *bd)
  18. {
  19. int ret;
  20. /* check if backlight is on */
  21. if (!(PPSR & PPC_LDD1))
  22. return 0;
  23. jornada_ssp_start();
  24. /* cmd should return txdummy */
  25. ret = jornada_ssp_byte(GETBRIGHTNESS);
  26. if (jornada_ssp_byte(GETBRIGHTNESS) != TXDUMMY) {
  27. dev_err(&bd->dev, "get brightness timeout\n");
  28. jornada_ssp_end();
  29. return -ETIMEDOUT;
  30. }
  31. /* exchange txdummy for value */
  32. ret = jornada_ssp_byte(TXDUMMY);
  33. jornada_ssp_end();
  34. return BL_MAX_BRIGHT - ret;
  35. }
  36. static int jornada_bl_update_status(struct backlight_device *bd)
  37. {
  38. int ret = 0;
  39. jornada_ssp_start();
  40. /* If backlight is off then really turn it off */
  41. if (backlight_is_blank(bd)) {
  42. ret = jornada_ssp_byte(BRIGHTNESSOFF);
  43. if (ret != TXDUMMY) {
  44. dev_info(&bd->dev, "brightness off timeout\n");
  45. /* turn off backlight */
  46. PPSR &= ~PPC_LDD1;
  47. PPDR |= PPC_LDD1;
  48. ret = -ETIMEDOUT;
  49. }
  50. } else /* turn on backlight */
  51. PPSR |= PPC_LDD1;
  52. /* send command to our mcu */
  53. if (jornada_ssp_byte(SETBRIGHTNESS) != TXDUMMY) {
  54. dev_info(&bd->dev, "failed to set brightness\n");
  55. ret = -ETIMEDOUT;
  56. goto out;
  57. }
  58. /*
  59. * at this point we expect that the mcu has accepted
  60. * our command and is waiting for our new value
  61. * please note that maximum brightness is 255,
  62. * but due to physical layout it is equal to 0, so we simply
  63. * invert the value (MAX VALUE - NEW VALUE).
  64. */
  65. if (jornada_ssp_byte(BL_MAX_BRIGHT - bd->props.brightness)
  66. != TXDUMMY) {
  67. dev_err(&bd->dev, "set brightness failed\n");
  68. ret = -ETIMEDOUT;
  69. }
  70. /*
  71. * If infact we get an TXDUMMY as output we are happy and dont
  72. * make any further comments about it
  73. */
  74. out:
  75. jornada_ssp_end();
  76. return ret;
  77. }
  78. static const struct backlight_ops jornada_bl_ops = {
  79. .get_brightness = jornada_bl_get_brightness,
  80. .update_status = jornada_bl_update_status,
  81. .options = BL_CORE_SUSPENDRESUME,
  82. };
  83. static int jornada_bl_probe(struct platform_device *pdev)
  84. {
  85. struct backlight_properties props;
  86. int ret;
  87. struct backlight_device *bd;
  88. memset(&props, 0, sizeof(struct backlight_properties));
  89. props.type = BACKLIGHT_RAW;
  90. props.max_brightness = BL_MAX_BRIGHT;
  91. bd = devm_backlight_device_register(&pdev->dev, S1D_DEVICENAME,
  92. &pdev->dev, NULL, &jornada_bl_ops,
  93. &props);
  94. if (IS_ERR(bd)) {
  95. ret = PTR_ERR(bd);
  96. dev_err(&pdev->dev, "failed to register device, err=%x\n", ret);
  97. return ret;
  98. }
  99. bd->props.power = BACKLIGHT_POWER_ON;
  100. bd->props.brightness = BL_DEF_BRIGHT;
  101. /*
  102. * note. make sure max brightness is set otherwise
  103. * you will get seemingly non-related errors when
  104. * trying to change brightness
  105. */
  106. jornada_bl_update_status(bd);
  107. platform_set_drvdata(pdev, bd);
  108. dev_info(&pdev->dev, "HP Jornada 700 series backlight driver\n");
  109. return 0;
  110. }
  111. static struct platform_driver jornada_bl_driver = {
  112. .probe = jornada_bl_probe,
  113. .driver = {
  114. .name = "jornada_bl",
  115. },
  116. };
  117. module_platform_driver(jornada_bl_driver);
  118. MODULE_AUTHOR("Kristoffer Ericson <kristoffer.ericson>");
  119. MODULE_DESCRIPTION("HP Jornada 710/720/728 Backlight driver");
  120. MODULE_LICENSE("GPL");