blob: 86e1ad30ee407c38f5aa78d401154800a73d809a [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Russell King96f60e32012-08-15 13:59:49 +01002/*
3 * Copyright (C) 2012 Russell King
Russell King96f60e32012-08-15 13:59:49 +01004 */
5#ifndef ARMADA_CRTC_H
6#define ARMADA_CRTC_H
7
Daniel Vetterfcd70cd2019-01-17 22:03:34 +01008#include <drm/drm_crtc.h>
9
Russell King96f60e32012-08-15 13:59:49 +010010struct armada_gem_object;
11
12struct armada_regs {
13 uint32_t offset;
14 uint32_t mask;
15 uint32_t val;
16};
17
18#define armada_reg_queue_mod(_r, _i, _v, _m, _o) \
19 do { \
20 struct armada_regs *__reg = _r; \
21 __reg[_i].offset = _o; \
22 __reg[_i].mask = ~(_m); \
23 __reg[_i].val = _v; \
24 _i++; \
25 } while (0)
26
27#define armada_reg_queue_set(_r, _i, _v, _o) \
28 armada_reg_queue_mod(_r, _i, _v, ~0, _o)
29
30#define armada_reg_queue_end(_r, _i) \
31 armada_reg_queue_mod(_r, _i, 0, 0, ~0)
32
Russell King4b5dda82015-08-06 16:37:18 +010033struct armada_crtc;
Russell King42e62ba2014-04-22 15:24:03 +010034struct armada_variant;
Russell King96f60e32012-08-15 13:59:49 +010035
36struct armada_crtc {
37 struct drm_crtc crtc;
Russell King42e62ba2014-04-22 15:24:03 +010038 const struct armada_variant *variant;
Russell King96f60e32012-08-15 13:59:49 +010039 unsigned num;
40 void __iomem *base;
41 struct clk *clk;
Russell King3ecea262014-04-22 15:21:30 +010042 struct clk *extclk[2];
Russell King96f60e32012-08-15 13:59:49 +010043 struct {
44 uint32_t spu_v_h_total;
45 uint32_t spu_v_porch;
46 uint32_t spu_adv_reg;
47 } v[2];
48 bool interlaced;
Russell King662af0d2013-05-19 10:55:17 +010049 bool cursor_update;
Russell King96f60e32012-08-15 13:59:49 +010050
Russell King662af0d2013-05-19 10:55:17 +010051 struct armada_gem_object *cursor_obj;
52 int cursor_x;
53 int cursor_y;
54 uint32_t cursor_hw_pos;
55 uint32_t cursor_hw_sz;
56 uint32_t cursor_w;
57 uint32_t cursor_h;
58
Russell King96f60e32012-08-15 13:59:49 +010059 uint32_t cfg_dumb_ctrl;
Russell King96f60e32012-08-15 13:59:49 +010060 uint32_t spu_iopad_ctrl;
61
Russell King96f60e32012-08-15 13:59:49 +010062 spinlock_t irq_lock;
63 uint32_t irq_ena;
Russell Kingc36045e2018-07-30 11:52:34 +010064
Russell King3cb13ac2018-07-30 11:53:06 +010065 bool update_pending;
Russell Kingdbb4ca82018-07-30 11:52:34 +010066 struct drm_pending_vblank_event *event;
Russell Kingc36045e2018-07-30 11:52:34 +010067 struct armada_regs atomic_regs[32];
68 struct armada_regs *regs;
69 unsigned int regs_idx;
Russell King96f60e32012-08-15 13:59:49 +010070};
71#define drm_to_armada_crtc(c) container_of(c, struct armada_crtc, crtc)
72
Russell King96f60e32012-08-15 13:59:49 +010073void armada_drm_crtc_update_regs(struct armada_crtc *, struct armada_regs *);
74
Russell Kingd8c96082014-04-22 11:10:15 +010075extern struct platform_driver armada_lcd_platform_driver;
76
Russell King96f60e32012-08-15 13:59:49 +010077#endif