diff options
author | Marcus Glocker <mglocker@cvs.openbsd.org> | 2010-04-12 19:42:03 +0000 |
---|---|---|
committer | Marcus Glocker <mglocker@cvs.openbsd.org> | 2010-04-12 19:42:03 +0000 |
commit | 66fb47d386607c6a3b9bf1a287cf0a4d5e3a1be6 (patch) | |
tree | c07810e2853d5e98d26a2e83073cdc7755e43449 /sys | |
parent | 8baae7603e7d55899c1d962cc06e31e2d0358356 (diff) |
Enable transparent console cursor by adding a driver internal character
backing store.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/usb/udl.c | 56 | ||||
-rw-r--r-- | sys/dev/usb/udl.h | 3 |
2 files changed, 46 insertions, 13 deletions
diff --git a/sys/dev/usb/udl.c b/sys/dev/usb/udl.c index 3b069afcbd6..d5ee69ffa08 100644 --- a/sys/dev/usb/udl.c +++ b/sys/dev/usb/udl.c @@ -1,4 +1,4 @@ -/* $OpenBSD: udl.c,v 1.55 2009/10/13 19:33:17 pirofti Exp $ */ +/* $OpenBSD: udl.c,v 1.56 2010/04/12 19:42:02 mglocker Exp $ */ /* * Copyright (c) 2009 Marcus Glocker <mglocker@openbsd.org> @@ -649,6 +649,15 @@ udl_alloc_screen(void *v, const struct wsscreen_descr *type, *curxp = 0; *curyp = 0; + /* allocate character backing store */ + sc->sc_cbs = malloc((sc->sc_ri.ri_rows * sc->sc_ri.ri_cols) * + sizeof(*sc->sc_cbs), M_DEVBUF, M_ZERO); + if (sc->sc_cbs == NULL) { + printf("%s: can't allocate mem for character backing store!\n", + DN(sc)); + return (ENOMEM); + } + sc->sc_nscreens++; font = sc->sc_ri.ri_font; @@ -667,6 +676,10 @@ udl_free_screen(void *v, void *cookie) DPRINTF(1, "%s: %s\n", DN(sc), FUNC); + /* free character backing store */ + if (sc->sc_cbs != NULL) + free(sc->sc_cbs, M_DEVBUF); + sc->sc_nscreens--; } @@ -745,6 +758,11 @@ fail: return (EAGAIN); } + /* update character backing store */ + bcopy(sc->sc_cbs + ((row * sc->sc_ri.ri_cols) + src), + sc->sc_cbs + ((row * sc->sc_ri.ri_cols) + dst), + num * sizeof(*sc->sc_cbs)); + return (0); } @@ -787,6 +805,11 @@ fail: return (EAGAIN); } + /* update character backing store */ + bcopy(sc->sc_cbs + (src * sc->sc_ri.ri_cols), + sc->sc_cbs + (dst * sc->sc_ri.ri_cols), + (num * sc->sc_ri.ri_cols) * sizeof(*sc->sc_cbs)); + return (0); } @@ -826,6 +849,10 @@ fail: return (EAGAIN); } + /* update character backing store */ + bzero(sc->sc_cbs + ((row * sc->sc_ri.ri_cols) + col), + num * sizeof(*sc->sc_cbs)); + return (0); } @@ -864,6 +891,10 @@ fail: return (EAGAIN); } + /* update character backing store */ + bzero(sc->sc_cbs + (row * sc->sc_ri.ri_cols), + (num * sc->sc_ri.ri_cols) * sizeof(*sc->sc_cbs)); + return (0); } @@ -910,6 +941,9 @@ udl_putchar(void *cookie, int row, int col, u_int uc, long attr) * the buffer. */ + /* update character backing store */ + sc->sc_cbs[(row * sc->sc_ri.ri_cols) + col] = uc; + return (0); fail: @@ -921,19 +955,11 @@ int udl_do_cursor(struct rasops_info *ri) { struct udl_softc *sc = ri->ri_hw; - int r; + int r, pos; uint32_t x, y; uint8_t save_cursor; usbd_status error; - /* - * XXX - * We can't draw a transparent cursor yet because the chip - * doesn't offer an XOR command nor a read command for screen - * regions. Maybe this gets fixed once when wscons(4) is able - * to remember the on-screen characters. - */ - DPRINTF(2, "%s: %s: ccol=%d, crow=%d\n", DN(sc), FUNC, ri->ri_ccol, ri->ri_crow); @@ -951,8 +977,14 @@ udl_do_cursor(struct rasops_info *ri) goto fail; /* draw cursor */ - r = (sc->udl_fb_block_write)(sc, 0xffff, x, y, - ri->ri_font->fontwidth, ri->ri_font->fontheight); + pos = (ri->ri_crow * sc->sc_ri.ri_cols) + ri->ri_ccol; + if (sc->sc_cbs[pos] == 0 || sc->sc_cbs[pos] == ' ') { + r = (sc->udl_fb_block_write)(sc, 0xffff, x, y, + ri->ri_font->fontwidth, ri->ri_font->fontheight); + } else { + r = udl_draw_char(sc, 0x0000, 0xffff, sc->sc_cbs[pos], + x, y); + } if (r != 0) goto fail; diff --git a/sys/dev/usb/udl.h b/sys/dev/usb/udl.h index a400b27684c..87c49b65f67 100644 --- a/sys/dev/usb/udl.h +++ b/sys/dev/usb/udl.h @@ -1,4 +1,4 @@ -/* $OpenBSD: udl.h,v 1.15 2009/10/11 12:38:23 mglocker Exp $ */ +/* $OpenBSD: udl.h,v 1.16 2010/04/12 19:42:02 mglocker Exp $ */ /* * Copyright (c) 2009 Marcus Glocker <mglocker@openbsd.org> @@ -85,6 +85,7 @@ struct udl_softc { #define DLMAX 0x0004 #define DLUNK 0x00ff /* unknown */ uint8_t sc_cur_mode; + u_int *sc_cbs; /* character backing store */ /* * We use function pointers to the framebuffer manipulation |