|
@@ -461,13 +461,6 @@ static struct drm_framebuffer *atmel_hlcdc_fb_create(struct drm_device *dev,
|
|
|
return drm_gem_fb_create(dev, file_priv, mode_cmd);
|
|
|
}
|
|
|
|
|
|
-static void atmel_hlcdc_fb_output_poll_changed(struct drm_device *dev)
|
|
|
-{
|
|
|
- struct atmel_hlcdc_dc *dc = dev->dev_private;
|
|
|
-
|
|
|
- drm_fbdev_cma_hotplug_event(dc->fbdev);
|
|
|
-}
|
|
|
-
|
|
|
struct atmel_hlcdc_dc_commit {
|
|
|
struct work_struct work;
|
|
|
struct drm_device *dev;
|
|
@@ -563,7 +556,7 @@ error:
|
|
|
|
|
|
static const struct drm_mode_config_funcs mode_config_funcs = {
|
|
|
.fb_create = atmel_hlcdc_fb_create,
|
|
|
- .output_poll_changed = atmel_hlcdc_fb_output_poll_changed,
|
|
|
+ .output_poll_changed = drm_fb_helper_output_poll_changed,
|
|
|
.atomic_check = drm_atomic_helper_check,
|
|
|
.atomic_commit = atmel_hlcdc_dc_atomic_commit,
|
|
|
};
|
|
@@ -665,10 +658,7 @@ static int atmel_hlcdc_dc_load(struct drm_device *dev)
|
|
|
|
|
|
platform_set_drvdata(pdev, dev);
|
|
|
|
|
|
- dc->fbdev = drm_fbdev_cma_init(dev, 24,
|
|
|
- dev->mode_config.num_connector);
|
|
|
- if (IS_ERR(dc->fbdev))
|
|
|
- dc->fbdev = NULL;
|
|
|
+ drm_fb_cma_fbdev_init(dev, 24, 0);
|
|
|
|
|
|
drm_kms_helper_poll_init(dev);
|
|
|
|
|
@@ -688,8 +678,7 @@ static void atmel_hlcdc_dc_unload(struct drm_device *dev)
|
|
|
{
|
|
|
struct atmel_hlcdc_dc *dc = dev->dev_private;
|
|
|
|
|
|
- if (dc->fbdev)
|
|
|
- drm_fbdev_cma_fini(dc->fbdev);
|
|
|
+ drm_fb_cma_fbdev_fini(dev);
|
|
|
flush_workqueue(dc->wq);
|
|
|
drm_kms_helper_poll_fini(dev);
|
|
|
drm_mode_config_cleanup(dev);
|
|
@@ -705,13 +694,6 @@ static void atmel_hlcdc_dc_unload(struct drm_device *dev)
|
|
|
destroy_workqueue(dc->wq);
|
|
|
}
|
|
|
|
|
|
-static void atmel_hlcdc_dc_lastclose(struct drm_device *dev)
|
|
|
-{
|
|
|
- struct atmel_hlcdc_dc *dc = dev->dev_private;
|
|
|
-
|
|
|
- drm_fbdev_cma_restore_mode(dc->fbdev);
|
|
|
-}
|
|
|
-
|
|
|
static int atmel_hlcdc_dc_irq_postinstall(struct drm_device *dev)
|
|
|
{
|
|
|
struct atmel_hlcdc_dc *dc = dev->dev_private;
|
|
@@ -744,7 +726,7 @@ static struct drm_driver atmel_hlcdc_dc_driver = {
|
|
|
.driver_features = DRIVER_HAVE_IRQ | DRIVER_GEM |
|
|
|
DRIVER_MODESET | DRIVER_PRIME |
|
|
|
DRIVER_ATOMIC,
|
|
|
- .lastclose = atmel_hlcdc_dc_lastclose,
|
|
|
+ .lastclose = drm_fb_helper_lastclose,
|
|
|
.irq_handler = atmel_hlcdc_dc_irq_handler,
|
|
|
.irq_preinstall = atmel_hlcdc_dc_irq_uninstall,
|
|
|
.irq_postinstall = atmel_hlcdc_dc_irq_postinstall,
|