backlight.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * GMA500 Backlight Interface
  4. *
  5. * Copyright (c) 2009-2011, Intel Corporation.
  6. *
  7. * Authors: Eric Knopp
  8. */
  9. #include <acpi/video.h>
  10. #include "psb_drv.h"
  11. #include "psb_intel_reg.h"
  12. #include "psb_intel_drv.h"
  13. #include "intel_bios.h"
  14. #include "power.h"
  15. void gma_backlight_enable(struct drm_device *dev)
  16. {
  17. struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
  18. dev_priv->backlight_enabled = true;
  19. dev_priv->ops->backlight_set(dev, dev_priv->backlight_level);
  20. }
  21. void gma_backlight_disable(struct drm_device *dev)
  22. {
  23. struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
  24. dev_priv->backlight_enabled = false;
  25. dev_priv->ops->backlight_set(dev, 0);
  26. }
  27. void gma_backlight_set(struct drm_device *dev, int v)
  28. {
  29. struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
  30. dev_priv->backlight_level = v;
  31. if (dev_priv->backlight_enabled)
  32. dev_priv->ops->backlight_set(dev, v);
  33. }
  34. static int gma_backlight_get_brightness(struct backlight_device *bd)
  35. {
  36. struct drm_device *dev = bl_get_data(bd);
  37. struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
  38. if (dev_priv->ops->backlight_get)
  39. return dev_priv->ops->backlight_get(dev);
  40. return dev_priv->backlight_level;
  41. }
  42. static int gma_backlight_update_status(struct backlight_device *bd)
  43. {
  44. struct drm_device *dev = bl_get_data(bd);
  45. int level = backlight_get_brightness(bd);
  46. /* Percentage 1-100% being valid */
  47. if (level < 1)
  48. level = 1;
  49. gma_backlight_set(dev, level);
  50. return 0;
  51. }
  52. static const struct backlight_ops gma_backlight_ops __maybe_unused = {
  53. .get_brightness = gma_backlight_get_brightness,
  54. .update_status = gma_backlight_update_status,
  55. };
  56. int gma_backlight_init(struct drm_device *dev)
  57. {
  58. struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
  59. struct backlight_properties props __maybe_unused = {};
  60. int ret;
  61. dev_priv->backlight_enabled = true;
  62. dev_priv->backlight_level = 100;
  63. ret = dev_priv->ops->backlight_init(dev);
  64. if (ret)
  65. return ret;
  66. if (!acpi_video_backlight_use_native()) {
  67. drm_info(dev, "Skipping %s backlight registration\n",
  68. dev_priv->ops->backlight_name);
  69. return 0;
  70. }
  71. #ifdef CONFIG_BACKLIGHT_CLASS_DEVICE
  72. props.brightness = dev_priv->backlight_level;
  73. props.max_brightness = PSB_MAX_BRIGHTNESS;
  74. props.type = BACKLIGHT_RAW;
  75. dev_priv->backlight_device =
  76. backlight_device_register(dev_priv->ops->backlight_name,
  77. dev->dev, dev,
  78. &gma_backlight_ops, &props);
  79. if (IS_ERR(dev_priv->backlight_device))
  80. return PTR_ERR(dev_priv->backlight_device);
  81. #endif
  82. return 0;
  83. }
  84. void gma_backlight_exit(struct drm_device *dev)
  85. {
  86. #ifdef CONFIG_BACKLIGHT_CLASS_DEVICE
  87. struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
  88. if (dev_priv->backlight_device)
  89. backlight_device_unregister(dev_priv->backlight_device);
  90. #endif
  91. }