backlight.c 2.8 KB

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