blob: 5f29850ef8acf4318772ec0fa791670884dca1ea [file] [log] [blame]
Maxime Ripard9026e0d2015-10-29 09:36:23 +01001/*
2 * Copyright (C) 2015 Free Electrons
3 * Copyright (C) 2015 NextThing Co
4 *
5 * Maxime Ripard <maxime.ripard@free-electrons.com>
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License as
9 * published by the Free Software Foundation; either version 2 of
10 * the License, or (at your option) any later version.
11 */
12
Maxime Ripard5d68be92018-01-22 10:25:25 +010013#include <drm/drm_atomic.h>
Maxime Ripard9026e0d2015-10-29 09:36:23 +010014#include <drm/drm_atomic_helper.h>
Noralf Trønnes22efc852017-11-15 15:19:53 +010015#include <drm/drm_fb_helper.h>
Maxime Ripard9026e0d2015-10-29 09:36:23 +010016#include <drm/drm_fb_cma_helper.h>
Noralf Trønnes1287c942017-09-24 14:26:23 +020017#include <drm/drm_gem_framebuffer_helper.h>
Maxime Ripard9026e0d2015-10-29 09:36:23 +010018#include <drm/drmP.h>
19
20#include "sun4i_drv.h"
Baoyou Xie0c3ff442016-09-08 18:59:22 +080021#include "sun4i_framebuffer.h"
Maxime Ripard9026e0d2015-10-29 09:36:23 +010022
Maxime Ripardb8f12302017-12-17 18:06:05 +010023static int sun4i_de_atomic_check(struct drm_device *dev,
24 struct drm_atomic_state *state)
25{
26 int ret;
27
28 ret = drm_atomic_helper_check_modeset(dev, state);
29 if (ret)
30 return ret;
31
Maxime Ripard47a05f42017-05-01 10:52:32 +020032 ret = drm_atomic_normalize_zpos(dev, state);
33 if (ret)
34 return ret;
35
Maxime Ripardb8f12302017-12-17 18:06:05 +010036 return drm_atomic_helper_check_planes(dev, state);
37}
38
Maxime Ripard9026e0d2015-10-29 09:36:23 +010039static const struct drm_mode_config_funcs sun4i_de_mode_config_funcs = {
Noralf Trønnes22efc852017-11-15 15:19:53 +010040 .output_poll_changed = drm_fb_helper_output_poll_changed,
Maxime Ripardb8f12302017-12-17 18:06:05 +010041 .atomic_check = sun4i_de_atomic_check,
Maxime Ripard9026e0d2015-10-29 09:36:23 +010042 .atomic_commit = drm_atomic_helper_commit,
Noralf Trønnes1287c942017-09-24 14:26:23 +020043 .fb_create = drm_gem_fb_create,
Maxime Ripard9026e0d2015-10-29 09:36:23 +010044};
45
Maxime Ripard5d68be92018-01-22 10:25:25 +010046static struct drm_mode_config_helper_funcs sun4i_de_mode_config_helpers = {
47 .atomic_commit_tail = drm_atomic_helper_commit_tail_rpm,
48};
49
Noralf Trønnes22efc852017-11-15 15:19:53 +010050int sun4i_framebuffer_init(struct drm_device *drm)
Maxime Ripard9026e0d2015-10-29 09:36:23 +010051{
52 drm_mode_config_reset(drm);
53
54 drm->mode_config.max_width = 8192;
55 drm->mode_config.max_height = 8192;
56
57 drm->mode_config.funcs = &sun4i_de_mode_config_funcs;
Maxime Ripard5d68be92018-01-22 10:25:25 +010058 drm->mode_config.helper_private = &sun4i_de_mode_config_helpers;
Maxime Ripard9026e0d2015-10-29 09:36:23 +010059
Noralf Trønnes22efc852017-11-15 15:19:53 +010060 return drm_fb_cma_fbdev_init(drm, 32, 0);
Maxime Ripard9026e0d2015-10-29 09:36:23 +010061}
62
63void sun4i_framebuffer_free(struct drm_device *drm)
64{
Noralf Trønnes22efc852017-11-15 15:19:53 +010065 drm_fb_cma_fbdev_fini(drm);
Maxime Ripard9026e0d2015-10-29 09:36:23 +010066}