Lines Matching refs:crtc
23 static void sti_crtc_enable(struct drm_crtc *crtc) in sti_crtc_enable() argument
25 struct sti_mixer *mixer = to_sti_mixer(crtc); in sti_crtc_enable()
42 drm_crtc_vblank_on(crtc); in sti_crtc_enable()
45 static void sti_crtc_disabling(struct drm_crtc *crtc) in sti_crtc_disabling() argument
47 struct sti_mixer *mixer = to_sti_mixer(crtc); in sti_crtc_disabling()
54 static bool sti_crtc_mode_fixup(struct drm_crtc *crtc, in sti_crtc_mode_fixup() argument
63 sti_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *mode) in sti_crtc_mode_set() argument
65 struct sti_mixer *mixer = to_sti_mixer(crtc); in sti_crtc_mode_set()
73 crtc->base.id, sti_mixer_to_str(mixer), in sti_crtc_mode_set()
102 compo->vtg_main : compo->vtg_aux, &crtc->mode); in sti_crtc_mode_set()
104 res = sti_mixer_active_video_area(mixer, &crtc->mode); in sti_crtc_mode_set()
113 static void sti_crtc_disable(struct drm_crtc *crtc) in sti_crtc_disable() argument
115 struct sti_mixer *mixer = to_sti_mixer(crtc); in sti_crtc_disable()
119 DRM_DEBUG_KMS("CRTC:%d (%s)\n", crtc->base.id, sti_mixer_to_str(mixer)); in sti_crtc_disable()
124 drm_crtc_vblank_off(crtc); in sti_crtc_disable()
139 sti_crtc_mode_set_nofb(struct drm_crtc *crtc) in sti_crtc_mode_set_nofb() argument
141 sti_crtc_enable(crtc); in sti_crtc_mode_set_nofb()
142 sti_crtc_mode_set(crtc, &crtc->state->adjusted_mode); in sti_crtc_mode_set_nofb()
145 static void sti_crtc_atomic_begin(struct drm_crtc *crtc, in sti_crtc_atomic_begin() argument
148 struct sti_mixer *mixer = to_sti_mixer(crtc); in sti_crtc_atomic_begin()
150 if (crtc->state->event) { in sti_crtc_atomic_begin()
151 crtc->state->event->pipe = drm_crtc_index(crtc); in sti_crtc_atomic_begin()
153 WARN_ON(drm_crtc_vblank_get(crtc) != 0); in sti_crtc_atomic_begin()
155 mixer->pending_event = crtc->state->event; in sti_crtc_atomic_begin()
156 crtc->state->event = NULL; in sti_crtc_atomic_begin()
160 static void sti_crtc_atomic_flush(struct drm_crtc *crtc, in sti_crtc_atomic_flush() argument
163 struct drm_device *drm_dev = crtc->dev; in sti_crtc_atomic_flush()
164 struct sti_mixer *mixer = to_sti_mixer(crtc); in sti_crtc_atomic_flush()
240 static void sti_crtc_destroy(struct drm_crtc *crtc) in sti_crtc_destroy() argument
243 drm_crtc_cleanup(crtc); in sti_crtc_destroy()
246 static int sti_crtc_set_property(struct drm_crtc *crtc, in sti_crtc_set_property() argument
259 struct drm_crtc *crtc = data; in sti_crtc_vblank_cb() local
265 priv = crtc->dev->dev_private; in sti_crtc_vblank_cb()
266 pipe = drm_crtc_index(crtc); in sti_crtc_vblank_cb()
275 drm_crtc_handle_vblank(crtc); in sti_crtc_vblank_cb()
277 spin_lock_irqsave(&crtc->dev->event_lock, flags); in sti_crtc_vblank_cb()
279 drm_crtc_send_vblank_event(crtc, mixer->pending_event); in sti_crtc_vblank_cb()
280 drm_crtc_vblank_put(crtc); in sti_crtc_vblank_cb()
283 spin_unlock_irqrestore(&crtc->dev->event_lock, flags); in sti_crtc_vblank_cb()
290 list_for_each_entry(p, &crtc->dev->mode_config.plane_list, in sti_crtc_vblank_cb()
298 sti_crtc_disable(crtc); in sti_crtc_vblank_cb()
309 struct drm_crtc *crtc = &compo->mixer[pipe]->drm_crtc; in sti_crtc_enable_vblank() local
315 vtg_vblank_nb, crtc)) { in sti_crtc_enable_vblank()
328 struct drm_crtc *crtc = &compo->mixer[pipe]->drm_crtc; in sti_crtc_disable_vblank() local
338 drm_crtc_vblank_put(crtc); in sti_crtc_disable_vblank()
353 bool sti_crtc_is_main(struct drm_crtc *crtc) in sti_crtc_is_main() argument
355 struct sti_mixer *mixer = to_sti_mixer(crtc); in sti_crtc_is_main()
366 struct drm_crtc *crtc = &mixer->drm_crtc; in sti_crtc_init() local
369 res = drm_crtc_init_with_planes(drm_dev, crtc, primary, cursor, in sti_crtc_init()
376 drm_crtc_helper_add(crtc, &sti_crtc_helper_funcs); in sti_crtc_init()
379 crtc->base.id, sti_mixer_to_str(mixer)); in sti_crtc_init()