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)
34 struct armada_frame_work
;
35 struct armada_variant
;
39 const struct armada_variant
*variant
;
43 struct clk
*extclk
[2];
45 uint32_t spu_v_h_total
;
54 struct drm_plane
*plane
;
56 struct armada_gem_object
*cursor_obj
;
59 uint32_t cursor_hw_pos
;
60 uint32_t cursor_hw_sz
;
65 uint32_t cfg_dumb_ctrl
;
67 uint32_t spu_iopad_ctrl
;
69 wait_queue_head_t frame_wait
;
70 struct armada_frame_work
*frame_work
;
74 struct list_head vbl_list
;
76 #define drm_to_armada_crtc(c) container_of(c, struct armada_crtc, crtc)
78 struct armada_vbl_event
{
79 struct list_head node
;
81 void (*fn
)(struct armada_crtc
*, void *);
84 void armada_drm_vbl_event_add(struct armada_crtc
*,
85 struct armada_vbl_event
*);
86 void armada_drm_vbl_event_remove(struct armada_crtc
*,
87 struct armada_vbl_event
*);
88 #define armada_drm_vbl_event_init(_e, _f, _d) do { \
89 struct armada_vbl_event *__e = _e; \
90 INIT_LIST_HEAD(&__e->node); \
95 void armada_drm_crtc_gamma_set(struct drm_crtc
*, u16
, u16
, u16
, int);
96 void armada_drm_crtc_gamma_get(struct drm_crtc
*, u16
*, u16
*, u16
*, int);
97 void armada_drm_crtc_disable_irq(struct armada_crtc
*, u32
);
98 void armada_drm_crtc_enable_irq(struct armada_crtc
*, u32
);
99 void armada_drm_crtc_update_regs(struct armada_crtc
*, struct armada_regs
*);
101 extern struct platform_driver armada_lcd_platform_driver
;