blob: aaad5ab7867378f8b162eb127ed27242519152dd [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 {
39 void (*fn)(struct armada_crtc *,
40 struct armada_plane *,
41 struct armada_plane_work *);
42};
43
Russell King561f60b2015-07-15 18:11:24 +010044struct armada_plane {
45 struct drm_plane base;
Russell King5740d272015-07-15 18:11:25 +010046 wait_queue_head_t frame_wait;
Russell King4b5dda82015-08-06 16:37:18 +010047 struct armada_plane_work *work;
Russell King561f60b2015-07-15 18:11:24 +010048};
49#define drm_to_armada_plane(p) container_of(p, struct armada_plane, base)
50
Russell King5740d272015-07-15 18:11:25 +010051int armada_drm_plane_init(struct armada_plane *plane);
Russell King4b5dda82015-08-06 16:37:18 +010052int armada_drm_plane_work_queue(struct armada_crtc *dcrtc,
53 struct armada_plane *plane, struct armada_plane_work *work);
54int armada_drm_plane_work_wait(struct armada_plane *plane, long timeout);
Russell King5740d272015-07-15 18:11:25 +010055
Russell King96f60e32012-08-15 13:59:49 +010056struct armada_crtc {
57 struct drm_crtc crtc;
Russell King42e62ba2014-04-22 15:24:03 +010058 const struct armada_variant *variant;
Russell King96f60e32012-08-15 13:59:49 +010059 unsigned num;
60 void __iomem *base;
61 struct clk *clk;
Russell King3ecea262014-04-22 15:21:30 +010062 struct clk *extclk[2];
Russell King96f60e32012-08-15 13:59:49 +010063 struct {
64 uint32_t spu_v_h_total;
65 uint32_t spu_v_porch;
66 uint32_t spu_adv_reg;
67 } v[2];
68 bool interlaced;
Russell King662af0d2013-05-19 10:55:17 +010069 bool cursor_update;
Russell King96f60e32012-08-15 13:59:49 +010070 uint8_t csc_yuv_mode;
71 uint8_t csc_rgb_mode;
72
73 struct drm_plane *plane;
74
Russell King662af0d2013-05-19 10:55:17 +010075 struct armada_gem_object *cursor_obj;
76 int cursor_x;
77 int cursor_y;
78 uint32_t cursor_hw_pos;
79 uint32_t cursor_hw_sz;
80 uint32_t cursor_w;
81 uint32_t cursor_h;
82
Russell King96f60e32012-08-15 13:59:49 +010083 int dpms;
84 uint32_t cfg_dumb_ctrl;
85 uint32_t dumb_ctrl;
86 uint32_t spu_iopad_ctrl;
87
Russell King96f60e32012-08-15 13:59:49 +010088 spinlock_t irq_lock;
89 uint32_t irq_ena;
90 struct list_head vbl_list;
91};
92#define drm_to_armada_crtc(c) container_of(c, struct armada_crtc, crtc)
93
Russell King7c8f7e12015-06-29 17:52:16 +010094struct armada_vbl_event {
95 struct list_head node;
96 void *data;
97 void (*fn)(struct armada_crtc *, void *);
98};
99
100void armada_drm_vbl_event_add(struct armada_crtc *,
101 struct armada_vbl_event *);
102void armada_drm_vbl_event_remove(struct armada_crtc *,
103 struct armada_vbl_event *);
104#define armada_drm_vbl_event_init(_e, _f, _d) do { \
105 struct armada_vbl_event *__e = _e; \
106 INIT_LIST_HEAD(&__e->node); \
107 __e->data = _d; \
108 __e->fn = _f; \
109} while (0)
110
Russell King96f60e32012-08-15 13:59:49 +0100111void armada_drm_crtc_gamma_set(struct drm_crtc *, u16, u16, u16, int);
112void armada_drm_crtc_gamma_get(struct drm_crtc *, u16 *, u16 *, u16 *, int);
Russell King96f60e32012-08-15 13:59:49 +0100113void armada_drm_crtc_disable_irq(struct armada_crtc *, u32);
114void armada_drm_crtc_enable_irq(struct armada_crtc *, u32);
115void armada_drm_crtc_update_regs(struct armada_crtc *, struct armada_regs *);
116
Russell King58326802015-07-15 18:11:25 +0100117void armada_drm_crtc_plane_disable(struct armada_crtc *dcrtc,
118 struct drm_plane *plane);
119
Russell Kingd8c96082014-04-22 11:10:15 +0100120extern struct platform_driver armada_lcd_platform_driver;
121
Russell King96f60e32012-08-15 13:59:49 +0100122#endif