omap1_bl.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * Backlight driver for OMAP based boards.
  4. *
  5. * Copyright (c) 2006 Andrzej Zaborowski <balrog@zabor.org>
  6. */
  7. #include <linux/module.h>
  8. #include <linux/kernel.h>
  9. #include <linux/init.h>
  10. #include <linux/platform_device.h>
  11. #include <linux/backlight.h>
  12. #include <linux/slab.h>
  13. #include <linux/platform_data/omap1_bl.h>
  14. #include <linux/soc/ti/omap1-io.h>
  15. #include <linux/soc/ti/omap1-mux.h>
  16. #define OMAPBL_MAX_INTENSITY 0xff
  17. struct omap_backlight {
  18. bool enabled;
  19. int current_intensity;
  20. struct device *dev;
  21. struct omap_backlight_config *pdata;
  22. };
  23. static inline void omapbl_send_intensity(int intensity)
  24. {
  25. omap_writeb(intensity, OMAP_PWL_ENABLE);
  26. }
  27. static inline void omapbl_send_enable(int enable)
  28. {
  29. omap_writeb(enable, OMAP_PWL_CLK_ENABLE);
  30. }
  31. static void omapbl_enable(struct omap_backlight *bl, bool enable)
  32. {
  33. if (enable) {
  34. omapbl_send_intensity(bl->current_intensity);
  35. omapbl_send_enable(1);
  36. } else {
  37. omapbl_send_intensity(0);
  38. omapbl_send_enable(0);
  39. }
  40. }
  41. #ifdef CONFIG_PM_SLEEP
  42. static int omapbl_suspend(struct device *dev)
  43. {
  44. struct backlight_device *bl_dev = dev_get_drvdata(dev);
  45. struct omap_backlight *bl = bl_get_data(bl_dev);
  46. omapbl_enable(bl, false);
  47. return 0;
  48. }
  49. static int omapbl_resume(struct device *dev)
  50. {
  51. struct backlight_device *bl_dev = dev_get_drvdata(dev);
  52. struct omap_backlight *bl = bl_get_data(bl_dev);
  53. omapbl_enable(bl, bl->enabled);
  54. return 0;
  55. }
  56. #endif
  57. static void omapbl_set_enabled(struct backlight_device *dev, bool enable)
  58. {
  59. struct omap_backlight *bl = bl_get_data(dev);
  60. omapbl_enable(bl, enable);
  61. bl->enabled = enable;
  62. }
  63. static int omapbl_update_status(struct backlight_device *dev)
  64. {
  65. struct omap_backlight *bl = bl_get_data(dev);
  66. bool enable;
  67. if (bl->current_intensity != dev->props.brightness) {
  68. if (bl->enabled)
  69. omapbl_send_intensity(dev->props.brightness);
  70. bl->current_intensity = dev->props.brightness;
  71. }
  72. enable = !backlight_is_blank(dev);
  73. if (enable != bl->enabled)
  74. omapbl_set_enabled(dev, enable);
  75. return 0;
  76. }
  77. static int omapbl_get_intensity(struct backlight_device *dev)
  78. {
  79. struct omap_backlight *bl = bl_get_data(dev);
  80. return bl->current_intensity;
  81. }
  82. static const struct backlight_ops omapbl_ops = {
  83. .get_brightness = omapbl_get_intensity,
  84. .update_status = omapbl_update_status,
  85. };
  86. static int omapbl_probe(struct platform_device *pdev)
  87. {
  88. struct backlight_properties props;
  89. struct backlight_device *dev;
  90. struct omap_backlight *bl;
  91. struct omap_backlight_config *pdata = dev_get_platdata(&pdev->dev);
  92. if (!pdata)
  93. return -ENXIO;
  94. bl = devm_kzalloc(&pdev->dev, sizeof(struct omap_backlight),
  95. GFP_KERNEL);
  96. if (unlikely(!bl))
  97. return -ENOMEM;
  98. memset(&props, 0, sizeof(struct backlight_properties));
  99. props.type = BACKLIGHT_RAW;
  100. props.max_brightness = OMAPBL_MAX_INTENSITY;
  101. dev = devm_backlight_device_register(&pdev->dev, "omap-bl", &pdev->dev,
  102. bl, &omapbl_ops, &props);
  103. if (IS_ERR(dev))
  104. return PTR_ERR(dev);
  105. bl->enabled = false;
  106. bl->current_intensity = 0;
  107. bl->pdata = pdata;
  108. bl->dev = &pdev->dev;
  109. platform_set_drvdata(pdev, dev);
  110. omap_cfg_reg(PWL); /* Conflicts with UART3 */
  111. dev->props.brightness = pdata->default_intensity;
  112. omapbl_update_status(dev);
  113. dev_info(&pdev->dev, "OMAP LCD backlight initialised\n");
  114. return 0;
  115. }
  116. static SIMPLE_DEV_PM_OPS(omapbl_pm_ops, omapbl_suspend, omapbl_resume);
  117. static struct platform_driver omapbl_driver = {
  118. .probe = omapbl_probe,
  119. .driver = {
  120. .name = "omap-bl",
  121. .pm = &omapbl_pm_ops,
  122. },
  123. };
  124. module_platform_driver(omapbl_driver);
  125. MODULE_AUTHOR("Andrzej Zaborowski <balrog@zabor.org>");
  126. MODULE_DESCRIPTION("OMAP LCD Backlight driver");
  127. MODULE_LICENSE("GPL");