blob: 08761ff01739368d31734f4188d2c01212cd6dde [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
Daniel Vetterfcd70cd2019-01-17 22:03:34 +010011#include <drm/drm_crtc.h>
12
Russell King96f60e32012-08-15 13:59:49 +010013struct armada_gem_object;
14
15struct armada_regs {
16 uint32_t offset;
17 uint32_t mask;
18 uint32_t val;
19};
20
21#define armada_reg_queue_mod(_r, _i, _v, _m, _o) \
22 do { \
23 struct armada_regs *__reg = _r; \
24 __reg[_i].offset = _o; \
25 __reg[_i].mask = ~(_m); \
26 __reg[_i].val = _v; \
27 _i++; \
28 } while (0)
29
30#define armada_reg_queue_set(_r, _i, _v, _o) \
31 armada_reg_queue_mod(_r, _i, _v, ~0, _o)
32
33#define armada_reg_queue_end(_r, _i) \
34 armada_reg_queue_mod(_r, _i, 0, 0, ~0)
35
Russell King4b5dda82015-08-06 16:37:18 +010036struct armada_crtc;
Russell King42e62ba2014-04-22 15:24:03 +010037struct armada_variant;
Russell King96f60e32012-08-15 13:59:49 +010038
39struct armada_crtc {
40 struct drm_crtc crtc;
Russell King42e62ba2014-04-22 15:24:03 +010041 const struct armada_variant *variant;
Russell King96f60e32012-08-15 13:59:49 +010042 unsigned num;
43 void __iomem *base;
44 struct clk *clk;
Russell King3ecea262014-04-22 15:21:30 +010045 struct clk *extclk[2];
Russell King96f60e32012-08-15 13:59:49 +010046 struct {
47 uint32_t spu_v_h_total;
48 uint32_t spu_v_porch;
49 uint32_t spu_adv_reg;
50 } v[2];
51 bool interlaced;
Russell King662af0d2013-05-19 10:55:17 +010052 bool cursor_update;
Russell King96f60e32012-08-15 13:59:49 +010053
Russell King662af0d2013-05-19 10:55:17 +010054 struct armada_gem_object *cursor_obj;
55 int cursor_x;
56 int cursor_y;
57 uint32_t cursor_hw_pos;
58 uint32_t cursor_hw_sz;
59 uint32_t cursor_w;
60 uint32_t cursor_h;
61
Russell King96f60e32012-08-15 13:59:49 +010062 uint32_t cfg_dumb_ctrl;
Russell King96f60e32012-08-15 13:59:49 +010063 uint32_t spu_iopad_ctrl;
64
Russell King96f60e32012-08-15 13:59:49 +010065 spinlock_t irq_lock;
66 uint32_t irq_ena;
Russell Kingc36045e2018-07-30 11:52:34 +010067
Russell King3cb13ac2018-07-30 11:53:06 +010068 bool update_pending;
Russell Kingdbb4ca82018-07-30 11:52:34 +010069 struct drm_pending_vblank_event *event;
Russell Kingc36045e2018-07-30 11:52:34 +010070 struct armada_regs atomic_regs[32];
71 struct armada_regs *regs;
72 unsigned int regs_idx;
Russell King96f60e32012-08-15 13:59:49 +010073};
74#define drm_to_armada_crtc(c) container_of(c, struct armada_crtc, crtc)
75
Russell King96f60e32012-08-15 13:59:49 +010076void armada_drm_crtc_update_regs(struct armada_crtc *, struct armada_regs *);
77
Russell Kingd8c96082014-04-22 11:10:15 +010078extern struct platform_driver armada_lcd_platform_driver;
79
Russell King96f60e32012-08-15 13:59:49 +010080#endif