Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/ic some bugs in chipsfb_putchar_aa():
details: https://anonhg.NetBSD.org/src/rev/bee5d99b7ce8
branches: trunk
changeset: 351153:bee5d99b7ce8
user: macallan <macallan%NetBSD.org@localhost>
date: Fri Feb 03 20:09:49 2017 +0000
description:
some bugs in chipsfb_putchar_aa():
- fix 64bit padding for scanlines
- clean out latch for every scanline
now fonts with odd widths look right
diffstat:
sys/dev/ic/ct65550.c | 14 +++++++++-----
1 files changed, 9 insertions(+), 5 deletions(-)
diffs (58 lines):
diff -r 025d133539ab -r bee5d99b7ce8 sys/dev/ic/ct65550.c
--- a/sys/dev/ic/ct65550.c Fri Feb 03 20:07:55 2017 +0000
+++ b/sys/dev/ic/ct65550.c Fri Feb 03 20:09:49 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ct65550.c,v 1.12 2017/02/02 19:55:05 macallan Exp $ */
+/* $NetBSD: ct65550.c,v 1.13 2017/02/03 20:09:49 macallan Exp $ */
/*
* Copyright (c) 2006 Michael Lorenz
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ct65550.c,v 1.12 2017/02/02 19:55:05 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ct65550.c,v 1.13 2017/02/03 20:09:49 macallan Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -601,7 +601,7 @@
struct chipsfb_softc *sc = scr->scr_cookie;
uint32_t bg, latch = 0, bg8, fg8, pixel, dst, stride, size;
int i, l, x, y, wi, he, r, g, b, aval;
- int r1, g1, b1, r0, g0, b0, fgo, bgo, off;
+ int r1, g1, b1, r0, g0, b0, fgo, bgo, off, pad;
uint8_t *data8;
int rv;
@@ -664,8 +664,11 @@
bg8 = R3G3B2(r0, g0, b0);
fg8 = R3G3B2(r1, g1, b1);
+ /* see if we need to pad lines to 64bit */
+ pad = (wi + 3) & 4;
for (l = 0; l < he; l++) {
off = 0;
+ latch = 0;
for (i = 0; i < wi; i++) {
aval = *data8;
if (aval == 0) {
@@ -684,7 +687,8 @@
off += 8;
/* write in 32bit chunks */
if ((i & 3) == 3) {
- chipsfb_write32(sc, CT_OFF_DATA - CT_OFF_BITBLT, latch);
+ chipsfb_write32(sc,
+ CT_OFF_DATA - CT_OFF_BITBLT, latch);
latch = 0;
off = 0;
}
@@ -695,7 +699,7 @@
chipsfb_write32(sc, CT_OFF_DATA - CT_OFF_BITBLT, latch);
}
/* this chip needs scanlines 64bit aligned */
- if (wi & 7) chipsfb_write32(sc, CT_OFF_DATA - CT_OFF_BITBLT, 0);
+ if (pad) chipsfb_write32(sc, CT_OFF_DATA - CT_OFF_BITBLT, 0);
}
if (rv == GC_ADD) {
Home |
Main Index |
Thread Index |
Old Index