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;
42 uint32_t spu_v_h_total;
51 struct drm_plane *plane;
53 struct armada_gem_object *cursor_obj;
56 uint32_t cursor_hw_pos;
57 uint32_t cursor_hw_sz;
62 uint32_t cfg_dumb_ctrl;
64 uint32_t spu_iopad_ctrl;
66 wait_queue_head_t frame_wait;
67 struct armada_frame_work *frame_work;
71 struct list_head vbl_list;
73 #define drm_to_armada_crtc(c) container_of(c, struct armada_crtc, crtc)
75 int armada_drm_crtc_create(struct drm_device *, unsigned, struct resource *);
76 void armada_drm_crtc_gamma_set(struct drm_crtc *, u16, u16, u16, int);
77 void armada_drm_crtc_gamma_get(struct drm_crtc *, u16 *, u16 *, u16 *, int);
78 void armada_drm_crtc_irq(struct armada_crtc *, u32);
79 void armada_drm_crtc_disable_irq(struct armada_crtc *, u32);
80 void armada_drm_crtc_enable_irq(struct armada_crtc *, u32);
81 void armada_drm_crtc_update_regs(struct armada_crtc *, struct armada_regs *);