Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/sunxi Implement page flip API
details: https://anonhg.NetBSD.org/src/rev/36b5cbc50065
branches: trunk
changeset: 839019:36b5cbc50065
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Tue Feb 05 21:01:38 2019 +0000
description:
Implement page flip API
diffstat:
sys/arch/arm/sunxi/sunxi_mixer.c | 75 ++++++++++++++++++++++++++-------------
1 files changed, 50 insertions(+), 25 deletions(-)
diffs (103 lines):
diff -r a246f7b1dd43 -r 36b5cbc50065 sys/arch/arm/sunxi/sunxi_mixer.c
--- a/sys/arch/arm/sunxi/sunxi_mixer.c Tue Feb 05 19:53:13 2019 +0000
+++ b/sys/arch/arm/sunxi/sunxi_mixer.c Tue Feb 05 21:01:38 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sunxi_mixer.c,v 1.4 2019/02/05 00:21:35 jmcneill Exp $ */
+/* $NetBSD: sunxi_mixer.c,v 1.5 2019/02/05 21:01:38 jmcneill Exp $ */
/*-
* Copyright (c) 2019 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sunxi_mixer.c,v 1.4 2019/02/05 00:21:35 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sunxi_mixer.c,v 1.5 2019/02/05 21:01:38 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -222,29 +222,6 @@
#define to_sunxi_mixer_crtc(x) container_of(x, struct sunxi_mixer_crtc, base)
#define to_sunxi_mixer_overlay(x) container_of(x, struct sunxi_mixer_overlay, base)
-static void
-sunxi_mixer_destroy(struct drm_crtc *crtc)
-{
- drm_crtc_cleanup(crtc);
-}
-
-static const struct drm_crtc_funcs sunxi_mixer_crtc_funcs = {
- .set_config = drm_crtc_helper_set_config,
- .destroy = sunxi_mixer_destroy,
-};
-
-static void
-sunxi_mixer_dpms(struct drm_crtc *crtc, int mode)
-{
-}
-
-static bool
-sunxi_mixer_mode_fixup(struct drm_crtc *crtc,
- const struct drm_display_mode *mode, struct drm_display_mode *adjusted_mode)
-{
- return true;
-}
-
static int
sunxi_mixer_mode_do_set_base(struct drm_crtc *crtc, struct drm_framebuffer *fb,
int x, int y, int atomic)
@@ -267,6 +244,54 @@
return 0;
}
+static void
+sunxi_mixer_destroy(struct drm_crtc *crtc)
+{
+ drm_crtc_cleanup(crtc);
+}
+
+static int
+sunxi_mixer_page_flip(struct drm_crtc *crtc, struct drm_framebuffer *fb,
+ struct drm_pending_vblank_event *event, uint32_t flags)
+{
+ struct sunxi_mixer_crtc *mixer_crtc = to_sunxi_mixer_crtc(crtc);
+ struct sunxi_mixer_softc * const sc = mixer_crtc->sc;
+ unsigned long irqflags;
+
+ drm_crtc_wait_one_vblank(crtc);
+
+ sunxi_mixer_mode_do_set_base(crtc, fb, 0, 0, true);
+
+ /* Commit settings */
+ GLB_WRITE(sc, GLB_DBUFFER, GLB_DBUFFER_DOUBLE_BUFFER_RDY);
+
+ if (event) {
+ spin_lock_irqsave(&crtc->dev->event_lock, irqflags);
+ drm_send_vblank_event(crtc->dev, drm_crtc_index(crtc), event);
+ spin_unlock_irqrestore(&crtc->dev->event_lock, irqflags);
+ }
+
+ return 0;
+}
+
+static const struct drm_crtc_funcs sunxi_mixer_crtc_funcs = {
+ .set_config = drm_crtc_helper_set_config,
+ .page_flip = sunxi_mixer_page_flip,
+ .destroy = sunxi_mixer_destroy,
+};
+
+static void
+sunxi_mixer_dpms(struct drm_crtc *crtc, int mode)
+{
+}
+
+static bool
+sunxi_mixer_mode_fixup(struct drm_crtc *crtc,
+ const struct drm_display_mode *mode, struct drm_display_mode *adjusted_mode)
+{
+ return true;
+}
+
static int
sunxi_mixer_mode_set(struct drm_crtc *crtc, struct drm_display_mode *mode,
struct drm_display_mode *adjusted_mode, int x, int y,
Home |
Main Index |
Thread Index |
Old Index