2 * Copyright (C) 2012 Russell King
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.
11 struct armada_gem_object;
19 #define armada_reg_queue_mod(_r, _i, _v, _m, _o) \
21 struct armada_regs *__reg = _r; \
22 __reg[_i].offset = _o; \
23 __reg[_i].mask = ~(_m); \
28 #define armada_reg_queue_set(_r, _i, _v, _o) \
29 armada_reg_queue_mod(_r, _i, _v, ~0, _o)
31 #define armada_reg_queue_end(_r, _i) \
32 armada_reg_queue_mod(_r, _i, 0, 0, ~0)
36 struct armada_variant;
38 struct armada_plane_work {
39 void (*fn)(struct armada_crtc *,
40 struct armada_plane *,
41 struct armada_plane_work *);
44 struct armada_plane_state {
52 struct drm_plane base;
53 wait_queue_head_t frame_wait;
54 struct armada_plane_work *work;
55 struct armada_plane_state state;
57 #define drm_to_armada_plane(p) container_of(p, struct armada_plane, base)
59 int armada_drm_plane_init(struct armada_plane *plane);
60 int armada_drm_plane_work_queue(struct armada_crtc *dcrtc,
61 struct armada_plane *plane, struct armada_plane_work *work);
62 int armada_drm_plane_work_wait(struct armada_plane *plane, long timeout);
63 struct armada_plane_work *armada_drm_plane_work_cancel(
64 struct armada_crtc *dcrtc, struct armada_plane *plane);
65 void armada_drm_plane_calc_addrs(u32 *addrs, struct drm_framebuffer *fb,
70 const struct armada_variant *variant;
74 struct clk *extclk[2];
76 uint32_t spu_v_h_total;
85 struct drm_plane *plane;
87 struct armada_gem_object *cursor_obj;
90 uint32_t cursor_hw_pos;
91 uint32_t cursor_hw_sz;
96 uint32_t cfg_dumb_ctrl;
98 uint32_t spu_iopad_ctrl;
103 #define drm_to_armada_crtc(c) container_of(c, struct armada_crtc, crtc)
105 void armada_drm_crtc_update_regs(struct armada_crtc *, struct armada_regs *);
107 void armada_drm_crtc_plane_disable(struct armada_crtc *dcrtc,
108 struct drm_plane *plane);
110 extern struct platform_driver armada_lcd_platform_driver;