fsl_dcu_drm_kms.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * Copyright 2015 Freescale Semiconductor, Inc.
  3. *
  4. * Freescale DCU drm device driver
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. */
  11. #include <drm/drmP.h>
  12. #include <drm/drm_atomic_helper.h>
  13. #include <drm/drm_crtc_helper.h>
  14. #include <drm/drm_fb_cma_helper.h>
  15. #include <drm/drm_gem_framebuffer_helper.h>
  16. #include "fsl_dcu_drm_crtc.h"
  17. #include "fsl_dcu_drm_drv.h"
  18. static const struct drm_mode_config_funcs fsl_dcu_drm_mode_config_funcs = {
  19. .atomic_check = drm_atomic_helper_check,
  20. .atomic_commit = drm_atomic_helper_commit,
  21. .fb_create = drm_gem_fb_create,
  22. };
  23. int fsl_dcu_drm_modeset_init(struct fsl_dcu_drm_device *fsl_dev)
  24. {
  25. int ret;
  26. drm_mode_config_init(fsl_dev->drm);
  27. fsl_dev->drm->mode_config.min_width = 0;
  28. fsl_dev->drm->mode_config.min_height = 0;
  29. fsl_dev->drm->mode_config.max_width = 2031;
  30. fsl_dev->drm->mode_config.max_height = 2047;
  31. fsl_dev->drm->mode_config.funcs = &fsl_dcu_drm_mode_config_funcs;
  32. ret = fsl_dcu_drm_crtc_create(fsl_dev);
  33. if (ret)
  34. goto err;
  35. ret = fsl_dcu_drm_encoder_create(fsl_dev, &fsl_dev->crtc);
  36. if (ret)
  37. goto err;
  38. ret = fsl_dcu_create_outputs(fsl_dev);
  39. if (ret)
  40. goto err;
  41. drm_mode_config_reset(fsl_dev->drm);
  42. drm_kms_helper_poll_init(fsl_dev->drm);
  43. return 0;
  44. err:
  45. drm_mode_config_cleanup(fsl_dev->drm);
  46. return ret;
  47. }