Home | History | Annotate | Line # | Download | only in rasops
rasops1_putchar_width.h revision 1.6.8.2
      1  1.6.8.2  martin /* $NetBSD: rasops1_putchar_width.h,v 1.6.8.2 2020/04/13 08:04:47 martin Exp $ */
      2  1.6.8.2  martin 
      3  1.6.8.2  martin /* NetBSD: rasops1.c,v 1.28 2019/07/25 03:02:44 rin Exp */
      4  1.6.8.2  martin /*-
      5  1.6.8.2  martin  * Copyright (c) 1999 The NetBSD Foundation, Inc.
      6  1.6.8.2  martin  * All rights reserved.
      7  1.6.8.2  martin  *
      8  1.6.8.2  martin  * This code is derived from software contributed to The NetBSD Foundation
      9  1.6.8.2  martin  * by Andrew Doran.
     10  1.6.8.2  martin  *
     11  1.6.8.2  martin  * Redistribution and use in source and binary forms, with or without
     12  1.6.8.2  martin  * modification, are permitted provided that the following conditions
     13  1.6.8.2  martin  * are met:
     14  1.6.8.2  martin  * 1. Redistributions of source code must retain the above copyright
     15  1.6.8.2  martin  *    notice, this list of conditions and the following disclaimer.
     16  1.6.8.2  martin  * 2. Redistributions in binary form must reproduce the above copyright
     17  1.6.8.2  martin  *    notice, this list of conditions and the following disclaimer in the
     18  1.6.8.2  martin  *    documentation and/or other materials provided with the distribution.
     19  1.6.8.2  martin  *
     20  1.6.8.2  martin  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     21  1.6.8.2  martin  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     22  1.6.8.2  martin  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     23  1.6.8.2  martin  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     24  1.6.8.2  martin  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     25  1.6.8.2  martin  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     26  1.6.8.2  martin  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     27  1.6.8.2  martin  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     28  1.6.8.2  martin  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     29  1.6.8.2  martin  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     30  1.6.8.2  martin  * POSSIBILITY OF SUCH DAMAGE.
     31  1.6.8.2  martin  */
     32  1.6.8.2  martin 
     33  1.6.8.2  martin #if RASOPS_WIDTH != 8 && RASOPS_WIDTH != 16
     34  1.6.8.2  martin #error "Width not supported"
     35  1.6.8.2  martin #endif
     36  1.6.8.2  martin 
     37  1.6.8.2  martin #if RASOPS_WIDTH == 8
     38  1.6.8.2  martin #define	SUBST_UNIT	uint8_t
     39  1.6.8.2  martin #define	GET_GLYPH(fr)	(fr)[0]
     40  1.6.8.2  martin #endif
     41  1.6.8.2  martin 
     42  1.6.8.2  martin #if RASOPS_WIDTH == 16
     43  1.6.8.2  martin /*
     44  1.6.8.2  martin  * rp and hp are always half-word aligned, whereas
     45  1.6.8.2  martin  * fr may not be aligned in half-word boundary.
     46  1.6.8.2  martin  */
     47  1.6.8.2  martin #define	SUBST_UNIT	uint16_t
     48  1.6.8.2  martin #  if BYTE_ORDER == BIG_ENDIAN
     49  1.6.8.2  martin #define	GET_GLYPH(fr)	((fr)[0] << 8) | (fr)[1]
     50  1.6.8.2  martin #  else
     51  1.6.8.2  martin #define	GET_GLYPH(fr)	(fr)[0] | ((fr)[1] << 8)
     52  1.6.8.2  martin #  endif
     53  1.6.8.2  martin #endif /* RASOPS_WIDTH == 16 */
     54  1.6.8.2  martin 
     55  1.6.8.2  martin #define	NAME(width)	NAME1(width)
     56  1.6.8.2  martin #define	NAME1(width)	rasops1_putchar ## width
     57  1.6.8.2  martin 
     58  1.6.8.2  martin /*
     59  1.6.8.2  martin  * Width-optimized putchar function.
     60  1.6.8.2  martin  */
     61  1.6.8.2  martin static void
     62  1.6.8.2  martin NAME(RASOPS_WIDTH)(void *cookie, int row, int col, u_int uc, long attr)
     63  1.6.8.2  martin {
     64  1.6.8.2  martin 	struct rasops_info *ri = (struct rasops_info *)cookie;
     65  1.6.8.2  martin 	struct wsdisplay_font *font = PICK_FONT(ri, uc);
     66  1.6.8.2  martin 	int height;
     67  1.6.8.2  martin 	uint32_t bg, fg;
     68  1.6.8.2  martin 	uint8_t *fr;
     69  1.6.8.2  martin 	SUBST_UNIT tmp, *rp, *hp;
     70  1.6.8.2  martin 
     71  1.6.8.2  martin 	hp = NULL;	/* XXX GCC */
     72  1.6.8.2  martin 
     73  1.6.8.2  martin 	if (__predict_false(!CHAR_IN_FONT(uc, font)))
     74  1.6.8.2  martin 		return;
     75  1.6.8.2  martin 
     76  1.6.8.2  martin #ifdef RASOPS_CLIPPING
     77  1.6.8.2  martin 	/* Catches 'row < 0' case too */
     78  1.6.8.2  martin 	if ((unsigned)row >= (unsigned)ri->ri_rows)
     79  1.6.8.2  martin 		return;
     80  1.6.8.2  martin 
     81  1.6.8.2  martin 	if ((unsigned)col >= (unsigned)ri->ri_cols)
     82  1.6.8.2  martin 		return;
     83  1.6.8.2  martin #endif
     84  1.6.8.2  martin 
     85  1.6.8.2  martin 	height = font->fontheight;
     86  1.6.8.2  martin 
     87  1.6.8.2  martin 	rp = (SUBST_UNIT *)(ri->ri_bits + row * ri->ri_yscale +
     88  1.6.8.2  martin 	    col * sizeof(SUBST_UNIT));
     89  1.6.8.2  martin 	if (ri->ri_hwbits)
     90  1.6.8.2  martin 		hp = (SUBST_UNIT *)(ri->ri_hwbits + row * ri->ri_yscale +
     91  1.6.8.2  martin 		    col * sizeof(SUBST_UNIT));
     92  1.6.8.2  martin 
     93  1.6.8.2  martin 	bg = ATTR_BG(ri, attr);
     94  1.6.8.2  martin 	fg = ATTR_FG(ri, attr);
     95  1.6.8.2  martin 
     96  1.6.8.2  martin 	/* If fg and bg match this becomes a space character */
     97  1.6.8.2  martin 	if (uc == ' ' || __predict_false(fg == bg)) {
     98  1.6.8.2  martin 		while (height--) {
     99  1.6.8.2  martin 			*rp = bg;
    100  1.6.8.2  martin 			if (ri->ri_hwbits) {
    101  1.6.8.2  martin 				*hp = bg;
    102  1.6.8.2  martin 				DELTA(hp, ri->ri_stride, SUBST_UNIT *);
    103  1.6.8.2  martin 			}
    104  1.6.8.2  martin 			DELTA(rp, ri->ri_stride, SUBST_UNIT *);
    105  1.6.8.2  martin 		}
    106  1.6.8.2  martin 	} else {
    107  1.6.8.2  martin 		fr = FONT_GLYPH(uc, font, ri);
    108  1.6.8.2  martin 
    109  1.6.8.2  martin 		while (height--) {
    110  1.6.8.2  martin 			tmp = GET_GLYPH(fr);
    111  1.6.8.2  martin 			fr += font->stride;
    112  1.6.8.2  martin 			if (bg)
    113  1.6.8.2  martin 				tmp = ~tmp;
    114  1.6.8.2  martin 
    115  1.6.8.2  martin 			*rp = tmp;
    116  1.6.8.2  martin 
    117  1.6.8.2  martin 			if (ri->ri_hwbits) {
    118  1.6.8.2  martin 				*hp = tmp;
    119  1.6.8.2  martin 				DELTA(hp, ri->ri_stride, SUBST_UNIT *);
    120  1.6.8.2  martin 			}
    121  1.6.8.2  martin 
    122  1.6.8.2  martin 			DELTA(rp, ri->ri_stride, SUBST_UNIT *);
    123  1.6.8.2  martin 		}
    124  1.6.8.2  martin 	}
    125  1.6.8.2  martin 
    126  1.6.8.2  martin 	/* Do underline */
    127  1.6.8.2  martin 	if ((attr & WSATTR_UNDERLINE) != 0) {
    128  1.6.8.2  martin 		DELTA(rp, - ri->ri_stride * ri->ri_ul.off, SUBST_UNIT *);
    129  1.6.8.2  martin 		if (ri->ri_hwbits)
    130  1.6.8.2  martin 			DELTA(hp, - ri->ri_stride * ri->ri_ul.off,
    131  1.6.8.2  martin 			    SUBST_UNIT *);
    132  1.6.8.2  martin 
    133  1.6.8.2  martin 		for (height = ri->ri_ul.height; height; height--) {
    134  1.6.8.2  martin 			DELTA(rp, - ri->ri_stride, SUBST_UNIT *);
    135  1.6.8.2  martin 			*rp = fg;
    136  1.6.8.2  martin 			if (ri->ri_hwbits) {
    137  1.6.8.2  martin 				DELTA(hp, - ri->ri_stride, SUBST_UNIT *);
    138  1.6.8.2  martin 				*hp = fg;
    139  1.6.8.2  martin 			}
    140  1.6.8.2  martin 		}
    141  1.6.8.2  martin 	}
    142  1.6.8.2  martin }
    143  1.6.8.2  martin 
    144  1.6.8.2  martin #undef	SUBST_UNIT
    145  1.6.8.2  martin #undef	GET_GLYPH
    146  1.6.8.2  martin 
    147  1.6.8.2  martin #undef	NAME
    148  1.6.8.2  martin #undef	NAME1
    149