blob: 8b1de877cb0213d71eadd850ea6ae5af6846257f [file] [log] [blame]
Russell King96f60e32012-08-15 13:59:49 +01001/*
2 * Copyright (C) 2012 Russell King
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 */
8#ifndef ARMADA_CRTC_H
9#define ARMADA_CRTC_H
10
11struct armada_gem_object;
12
13struct armada_regs {
14 uint32_t offset;
15 uint32_t mask;
16 uint32_t val;
17};
18
19#define armada_reg_queue_mod(_r, _i, _v, _m, _o) \
20 do { \
21 struct armada_regs *__reg = _r; \
22 __reg[_i].offset = _o; \
23 __reg[_i].mask = ~(_m); \
24 __reg[_i].val = _v; \
25 _i++; \
26 } while (0)
27
28#define armada_reg_queue_set(_r, _i, _v, _o) \
29 armada_reg_queue_mod(_r, _i, _v, ~0, _o)
30
31#define armada_reg_queue_end(_r, _i) \
32 armada_reg_queue_mod(_r, _i, 0, 0, ~0)
33
Russell King4b5dda82015-08-06 16:37:18 +010034struct armada_crtc;
35struct armada_plane;
Russell King42e62ba2014-04-22 15:24:03 +010036struct armada_variant;
Russell King96f60e32012-08-15 13:59:49 +010037
Russell King4b5dda82015-08-06 16:37:18 +010038struct armada_plane_work {
Russell Kingeaab0132017-07-07 15:55:53 +010039 void (*fn)(struct armada_crtc *, struct armada_plane_work *);
Russell King2839d452017-07-07 15:56:20 +010040 void (*cancel)(struct armada_crtc *, struct armada_plane_work *);
Russell Kingd9241552017-07-08 10:22:25 +010041 bool need_kfree;
Russell Kingeaab0132017-07-07 15:55:53 +010042 struct drm_plane *plane;
Russell Kingb972a802017-07-08 10:16:52 +010043 struct drm_framebuffer *old_fb;
Russell Kingeb19be52017-07-08 10:16:53 +010044 struct drm_pending_vblank_event *event;
Russell King61ba2522018-07-30 11:52:34 +010045 struct armada_regs regs[24];
Russell King4b5dda82015-08-06 16:37:18 +010046};
47
Russell King561f60b2015-07-15 18:11:24 +010048struct armada_plane {
49 struct drm_plane base;
Russell King5740d272015-07-15 18:11:25 +010050 wait_queue_head_t frame_wait;
Russell King4b5dda82015-08-06 16:37:18 +010051 struct armada_plane_work *work;
Russell King561f60b2015-07-15 18:11:24 +010052};
53#define drm_to_armada_plane(p) container_of(p, struct armada_plane, base)
54
Russell King4b5dda82015-08-06 16:37:18 +010055int armada_drm_plane_work_queue(struct armada_crtc *dcrtc,
Russell Kingeaab0132017-07-07 15:55:53 +010056 struct armada_plane_work *work);
Russell King4b5dda82015-08-06 16:37:18 +010057int armada_drm_plane_work_wait(struct armada_plane *plane, long timeout);
Russell Kingd3b84212017-07-07 15:55:40 +010058void armada_drm_plane_work_cancel(struct armada_crtc *dcrtc,
59 struct armada_plane *plane);
Russell King47dc4132018-07-30 11:52:34 +010060
Russell King96f60e32012-08-15 13:59:49 +010061struct armada_crtc {
62 struct drm_crtc crtc;
Russell King42e62ba2014-04-22 15:24:03 +010063 const struct armada_variant *variant;
Russell King96f60e32012-08-15 13:59:49 +010064 unsigned num;
65 void __iomem *base;
66 struct clk *clk;
Russell King3ecea262014-04-22 15:21:30 +010067 struct clk *extclk[2];
Russell King96f60e32012-08-15 13:59:49 +010068 struct {
69 uint32_t spu_v_h_total;
70 uint32_t spu_v_porch;
71 uint32_t spu_adv_reg;
72 } v[2];
73 bool interlaced;
Russell King662af0d2013-05-19 10:55:17 +010074 bool cursor_update;
Russell King96f60e32012-08-15 13:59:49 +010075
76 struct drm_plane *plane;
77
Russell King662af0d2013-05-19 10:55:17 +010078 struct armada_gem_object *cursor_obj;
79 int cursor_x;
80 int cursor_y;
81 uint32_t cursor_hw_pos;
82 uint32_t cursor_hw_sz;
83 uint32_t cursor_w;
84 uint32_t cursor_h;
85
Russell King96f60e32012-08-15 13:59:49 +010086 int dpms;
87 uint32_t cfg_dumb_ctrl;
Russell King96f60e32012-08-15 13:59:49 +010088 uint32_t spu_iopad_ctrl;
89
Russell King96f60e32012-08-15 13:59:49 +010090 spinlock_t irq_lock;
91 uint32_t irq_ena;
Russell Kingc36045e2018-07-30 11:52:34 +010092
Russell Kingdbb4ca82018-07-30 11:52:34 +010093 struct drm_pending_vblank_event *event;
Russell Kingc36045e2018-07-30 11:52:34 +010094 struct armada_regs atomic_regs[32];
95 struct armada_regs *regs;
96 unsigned int regs_idx;
Russell King96f60e32012-08-15 13:59:49 +010097};
98#define drm_to_armada_crtc(c) container_of(c, struct armada_crtc, crtc)
99
Russell King96f60e32012-08-15 13:59:49 +0100100void armada_drm_crtc_update_regs(struct armada_crtc *, struct armada_regs *);
101
Russell Kingd8c96082014-04-22 11:10:15 +0100102extern struct platform_driver armada_lcd_platform_driver;
103
Russell King96f60e32012-08-15 13:59:49 +0100104#endif