shithub: riscv

Download patch

ref: d115bd0e20fbfdadfb7370a5d12156f1f488e533
parent: 9f11d4f6899071558e751dc0a9e6651e51d4cf6f
author: cinap_lenrek <[email protected]>
date: Tue Jan 13 13:04:33 EST 2015

igfx: cursor/plane pipe assign is G45 only, add magic dsp a toggle from enable sequence

--- a/sys/src/cmd/aux/vga/igfx.c
+++ b/sys/src/cmd/aux/vga/igfx.c
@@ -815,6 +815,8 @@
 
 	/* plane enable, 32bpp */
 	p->dsp->cntr.v = (1<<31) | (6<<26);
+	if(igfx->type == TypeG45)
+		p->dsp->cntr.v |= x<<24;	/* pipe assign */
 
 	/* stride must be 64 byte aligned */
 	p->dsp->stride.v = m->x * (m->z / 8);
@@ -829,7 +831,9 @@
 	p->dsp->tileoff.v = 0;
 
 	/* cursor plane off */
-	p->cur->cntr.v = x<<28;
+	p->cur->cntr.v = 0;
+	if(igfx->type == TypeG45)
+		p->cur->cntr.v |= x<<28;	/* pipe assign */
 	p->cur->pos.v = 0;
 	p->cur->base.v = 0;
 
@@ -999,10 +1003,10 @@
 
 	/* planes off */
 	csr(igfx, p->dsp->cntr.a, 1<<31, 0);
-	csr(igfx, p->dsp->surf.a, ~0, 0);	/* arm */
+	wr(igfx, p->dsp->surf.a, 0);	/* arm */
 	/* cursor off */
 	csr(igfx, p->cur->cntr.a, 1<<5 | 7, 0);
-	csr(igfx, p->cur->base.a, ~0, 0);	/* arm */
+	wr(igfx, p->cur->base.a, 0);	/* arm */
 
 	/* display/overlay/cursor planes off */
 	if(igfx->type == TypeG45)
@@ -1063,6 +1067,16 @@
 	/* turn off all pipes */
 	for(x = 0; x < igfx->npipe; x++)
 		disablepipe(igfx, x);
+
+	if(igfx->type == TypeG45){
+		/* toggle dsp a on and off (from enable sequence) */
+		csr(igfx, igfx->pipe[0].conf.a, 3<<18, 0);
+		csr(igfx, igfx->pipe[0].dsp->cntr.a, 0, 1<<31);
+		wr(igfx, igfx->pipe[0].dsp->surf.a, 0);		/* arm */
+		csr(igfx, igfx->pipe[0].dsp->cntr.a, 1<<31, 0);
+		wr(igfx, igfx->pipe[0].dsp->surf.a, 0);		/* arm */
+		csr(igfx, igfx->pipe[0].conf.a, 0, 3<<18);
+	}
 
 	/* program new clock sources */
 	loadreg(igfx, igfx->rawclkfreq);