mgag200_vga.c 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. #include <drm/drm_atomic_helper.h>
  3. #include <drm/drm_modeset_helper_vtables.h>
  4. #include <drm/drm_print.h>
  5. #include <drm/drm_probe_helper.h>
  6. #include "mgag200_ddc.h"
  7. #include "mgag200_drv.h"
  8. static const struct drm_encoder_funcs mgag200_dac_encoder_funcs = {
  9. .destroy = drm_encoder_cleanup
  10. };
  11. static const struct drm_connector_helper_funcs mgag200_vga_connector_helper_funcs = {
  12. .get_modes = drm_connector_helper_get_modes,
  13. .detect_ctx = drm_connector_helper_detect_from_ddc
  14. };
  15. static const struct drm_connector_funcs mgag200_vga_connector_funcs = {
  16. .reset = drm_atomic_helper_connector_reset,
  17. .fill_modes = drm_helper_probe_single_connector_modes,
  18. .destroy = drm_connector_cleanup,
  19. .atomic_duplicate_state = drm_atomic_helper_connector_duplicate_state,
  20. .atomic_destroy_state = drm_atomic_helper_connector_destroy_state
  21. };
  22. int mgag200_vga_output_init(struct mga_device *mdev)
  23. {
  24. struct drm_device *dev = &mdev->base;
  25. struct drm_crtc *crtc = &mdev->crtc;
  26. struct drm_encoder *encoder;
  27. struct drm_connector *connector;
  28. struct i2c_adapter *ddc;
  29. int ret;
  30. encoder = &mdev->output.vga.encoder;
  31. ret = drm_encoder_init(dev, encoder, &mgag200_dac_encoder_funcs,
  32. DRM_MODE_ENCODER_DAC, NULL);
  33. if (ret) {
  34. drm_err(dev, "drm_encoder_init() failed: %d\n", ret);
  35. return ret;
  36. }
  37. encoder->possible_crtcs = drm_crtc_mask(crtc);
  38. ddc = mgag200_ddc_create(mdev);
  39. if (IS_ERR(ddc)) {
  40. ret = PTR_ERR(ddc);
  41. drm_err(dev, "failed to add DDC bus: %d\n", ret);
  42. return ret;
  43. }
  44. connector = &mdev->output.vga.connector;
  45. ret = drm_connector_init_with_ddc(dev, connector,
  46. &mgag200_vga_connector_funcs,
  47. DRM_MODE_CONNECTOR_VGA, ddc);
  48. if (ret) {
  49. drm_err(dev, "drm_connector_init_with_ddc() failed: %d\n", ret);
  50. return ret;
  51. }
  52. drm_connector_helper_add(connector, &mgag200_vga_connector_helper_funcs);
  53. connector->polled = DRM_CONNECTOR_POLL_CONNECT |
  54. DRM_CONNECTOR_POLL_DISCONNECT;
  55. ret = drm_connector_attach_encoder(connector, encoder);
  56. if (ret) {
  57. drm_err(dev, "drm_connector_attach_encoder() failed: %d\n", ret);
  58. return ret;
  59. }
  60. return 0;
  61. }