Plan 9 from Bell Labs’s /usr/web/sources/contrib/fgb/root/sys/src/ape/X11/cmd/X/hw/xfree86/xaa/xaaTEGlyphBlt.S

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


/*
 * Copyright 1996  The XFree86 Project
 *
 * Permission is hereby granted, free of charge, to any person obtaining a 
 * copy of this software and associated documentation files (the "Software"), 
 * to deal in the Software without restriction, including without limitation 
 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 
 * and/or sell copies of the Software, and to permit persons to whom the 
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL 
 * HARM HANEMAAYER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 
 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF 
 * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 
 * SOFTWARE.
 * 
 * Written by Harm Hanemaayer ([email protected]).
 */
/* $XFree86: xc/programs/Xserver/hw/xfree86/xaa/xaaTEGlyphBlt.S,v 1.1 1999/07/10 07:24:54 dawes Exp $ */


/*
 * Intel Pentium-optimized versions of "terminal emulator font" text
 * bitmap transfer routines.
 *
 * SCANLINE_PAD_DWORD.
 *
 * Only for glyphs with a fixed width of 6 pixels or 8 pixels.
 */

#include "assyntax.h"

#ifndef QNX4
 	FILE("xaaTEGlyphBlt.s")
#else
 	FILE( __FILE__ )
#endif

	AS_BEGIN

/*
 * Definition of stack frame function arguments.
 * All functions have the same arguments (some don't have glyphwidth,
 * but that's OK, since it comes last and doesn't affect the offset
 * of the other arguments).
 */

#define base_arg	REGOFF(20,ESP)
#define glyphp_arg	REGOFF(24,ESP)
#define line_arg	REGOFF(28,ESP)
#define width_arg	REGOFF(32,ESP)
#define glyphwidth_arg	REGOFF(36,ESP)

#define BYTE_REVERSED	GLNAME(byte_reversed)

/* I assume %eax and %edx can be trashed. */

	SEG_TEXT

	ALIGNTEXT4

#ifdef FIXEDBASE
# ifdef MSBFIRST
	GLOBL GLNAME(DrawTETextScanlineWidth6PMSBFirstFixedBase)
GLNAME(DrawTETextScanlineWidth6PMSBFirstFixedBase):
# else
	GLOBL GLNAME(DrawTETextScanlineWidth6PLSBFirstFixedBase)
GLNAME(DrawTETextScanlineWidth6PLSBFirstFixedBase):
# endif
#else
# ifdef MSBFIRST
	GLOBL GLNAME(DrawTETextScanlineWidth6PMSBFirst)
GLNAME(DrawTETextScanlineWidth6PMSBFirst):
# else
	GLOBL GLNAME(DrawTETextScanlineWidth6PLSBFirst)
GLNAME(DrawTETextScanlineWidth6PLSBFirst):
# endif
#endif

/* Definition of stack frame function arguments. */

#define base_arg	REGOFF(20,ESP)
#define glyphp_arg	REGOFF(24,ESP)
#define line_arg	REGOFF(28,ESP)
#define width_arg	REGOFF(32,ESP)

	SUB_L	(CONST(16),ESP)
	MOV_L	(EBP,REGOFF(12,ESP))	/* PUSH EBP */
	MOV_L	(EBX,REGOFF(8,ESP))	/* PUSH EBX */
	MOV_L	(ESI,REGOFF(4,ESP))	/* PUSH ESI */
	MOV_L	(EDI,REGOFF(0,ESP))	/* PUSH EDI */

	MOV_L	(line_arg,EBP)
	MOV_L	(base_arg,EDI)
	MOV_L	(glyphp_arg,ESI)

	ALIGNTEXT4

.L6_1:
	/* Pentium-optimized instruction pairing. */
	/* EBX = bits = glyph[0][line] */
	MOV_L	(REGOFF(4,ESI),EDX)		/* glyphp[1] */
	MOV_L	(REGIND(ESI),EBX)		/* glyphp[0] */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[1][line] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[0][line] */
	SAL_L	(CONST(6),EDX)			/* glyphp[1][line] << 6 */
	MOV_L	(REGOFF(8,ESI),ECX)		/* glyphp[2] */
	MOV_L	(REGOFF(12,ESI),EAX)		/* glyphp[3] */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[2][line] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[3][line] */
	SAL_L	(CONST(12),ECX)			/* glyphp[2][line] << 12 */
	OR_L	(EDX,EBX)			/* bits |= ..[1].. << 6 */
	SAL_L	(CONST(18),EAX)			/* glyphp[3][line] << 18 */
	OR_L	(ECX,EBX)			/* bits |= ..[2].. << 12 */

	MOV_L	(REGOFF(16,ESI),EDX)		/* glyphp[4] */
	MOV_L	(REGOFF(20,ESI),ECX)		/* glyphp[5] */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[4][line] */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[5][line] */
	SAL_L	(CONST(24),EDX)			/* glyphp[4][line] << 24 */
	OR_L	(EAX,EBX)			/* bits |= ..[3].. << 18 */
	SAL_L	(CONST(30),ECX)			/* glyphp[5][line] << 30 */
	OR_L	(EDX,EBX)			/* bits |= ..[4].. << 24 */

#ifndef MSBFIRST
	MOV_L	(REGOFF(20,ESI),EAX)		/* glyphp[5] */
	OR_L	(ECX,EBX)			/* bits |= ..[5].. << 30 */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[5][line] */
	MOV_L	(EBX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(CONST(0),EAX)
	OR_L	(ECX,EBX)			/* bits |= ..[5].. << 30 */
	MOV_L	(CONST(0),EDX)
	MOV_B	(BL,AL)
	MOV_B	(BH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),BH)
	ROL_L	(CONST(16),EBX)
	MOV_B	(BL,AL)
	MOV_B	(BH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),BH)
	ROL_L	(CONST(16),EBX)
	MOV_L	(REGOFF(20,ESI),EAX)		/* glyphp[5] */
	MOV_L	(EBX,REGIND(EDI))
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[5][line] */
#endif

	CMP_L   (CONST(32),width_arg)
        JG      (.L6_2)
#ifndef FIXEDBASE
	ADD_L	(CONST(4),EDI)		/* base++ */
#endif
	JMP	(.L6_4)
.L6_2:
	/* Note that glyphp[5][line] is already read again. */
	/* EAX = bits = glyphp[5][line] >> 2 */
	MOV_L	(REGOFF(24,ESI),EDX)		/* glyphp[6] */
	MOV_L	(REGOFF(28,ESI),EBX)		/* glyphp[7] */
	SHR_L	(CONST(2),EAX)			/* glyphp[5][line] >> 2 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[6][line] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[7][line] */
	MOV_L	(REGOFF(32,ESI),ECX)		/* glyphp[8] */
	SAL_L	(CONST(4),EDX)			/* glyphp[6][line] << 4 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[8][line] */
	SAL_L	(CONST(10),EBX)			/* glyphp[7][line] << 10 */
	OR_L	(EDX,EAX)			/* bits |= ..[6].. << 4 */
	SAL_L	(CONST(16),ECX)			/* glyphp[8][line] << 16 */
	MOV_L	(REGOFF(36,ESI),EDX)		/* glyphp[9] */
	OR_L	(EBX,EAX)			/* bits |= ..[7].. << 10 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[9][line] */
	OR_L	(ECX,EAX)			/* bits |= ..[8].. << 16 */
	MOV_L	(REGOFF(40,ESI),EBX)		/* glyphp[10] */
	SAL_L	(CONST(22),EDX)			/* glyphp[9][line] << 22 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[10][line] */
	OR_L	(EDX,EAX)			/* bits |= ..[9].. << 22 */

#ifndef MSBFIRST
	MOV_L	(REGOFF(40,ESI),ECX)		/* glyphp[10] */
	SAL_L	(CONST(28),EBX)			/* glyphp[10][line] << 28 */
	MOV_L	(REGOFF(44,ESI),EDX)		/* glyphp[11] */
	OR_L	(EBX,EAX)			/* bits |= ..[10].. << 28 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[10][line] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(4,EDI)) /* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[11][line] */
#else
	MOV_L	(CONST(0),ECX)
	SAL_L	(CONST(28),EBX)			/* glyphp[10][line] << 28 */
	MOV_L	(CONST(0),EDX)
	OR_L	(EBX,EAX)			/* bits |= ..[10].. << 28 */
	MOV_B	(AL,CL)
	MOV_B	(AH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),AH)
	ROL_L	(CONST(16),EAX)
	MOV_B	(AL,CL)
	MOV_B	(AH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),AH)
	MOV_L	(REGOFF(40,ESI),ECX)		/* glyphp[10] */
	ROL_L	(CONST(16),EAX)
	MOV_L	(REGOFF(44,ESI),EDX)		/* glyphp[11] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(4,EDI)) /* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[10][line] */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[11][line] */
#endif

	CMP_L   (CONST(64),width_arg)
        JG      (.L6_3)
#ifndef FIXEDBASE
	ADD_L	(CONST(8),EDI)		/* base+=2 */
#endif
	JMP	(.L6_4)
.L6_3:
	/* Note that glyphp[10][line] is read again. */
	/* EAX = bits = glyphp[10][line] >> 4 */
	SHR_L	(CONST(4),ECX)			/* glyphp[10][line] >> 4 */
	MOV_L	(REGOFF(48,ESI),EBX)		/* glyphp[12] */
	SAL_L	(CONST(2),EDX)			/* glyphp[11][line] << 2 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[12][line] */
	OR_L	(EDX,ECX)			/* bits |= ..[11].. << 2 */
	MOV_L	(REGOFF(52,ESI),EAX)		/* glyphp[13] */
	SAL_L	(CONST(8),EBX)			/* glyphp[12][line] << 8 */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[13][line] */
	OR_L	(EBX,ECX)			/* bits |= ..[12].. << 8 */
	MOV_L	(REGOFF(56,ESI),EDX)		/* glyphp[14] */
	SAL_L	(CONST(14),EAX)			/* glyphp[13][line] << 14 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[14][line] */
	OR_L	(EAX,ECX)			/* bits |= ..[13].. << 14 */
	MOV_L	(REGOFF(60,ESI),EBX)		/* glyphp[15] */
	SAL_L	(CONST(20),EDX)			/* glyphp[14][line] << 20 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[15][line] */
	OR_L	(EDX,ECX)			/* bits |= ..[14].. << 20 */

#ifndef MSBFIRST
	SAL_L	(CONST(26),EBX)			/* glyphp[15][line] << 26 */
	OR_L	(EBX,ECX)			/* bits |= ..[15].. << 26 */
#ifndef FIXEDBASE
	MOV_L	(ECX,REGOFF(8,EDI)) /* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(ECX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),EAX)
	SAL_L	(CONST(26),EBX)			/* glyphp[15][line] << 26 */
	MOV_L	(CONST(0),EDX)
	OR_L	(EBX,ECX)			/* bits |= ..[15].. << 26 */
	MOV_B	(CL,AL)
	MOV_B	(CH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),CH)
	ROL_L	(CONST(16),ECX)
	MOV_B	(CL,AL)
	MOV_B	(CH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),CH)
	ROL_L	(CONST(16),ECX)
#ifndef FIXEDBASE
	MOV_L	(ECX,REGOFF(8,EDI)) /* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(ECX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#endif

#ifndef FIXEDBASE
	ADD_L	(CONST(12),EDI)		/* base += 3*/
#endif
	CMP_L   (CONST(96),width_arg)
        JLE     (.L6_4)
	ADD_L	(CONST(64),ESI)		/* glyphp += 16 */
	SUB_L	(CONST(96),width_arg)
        JMP     (.L6_1)

.L6_4:

#ifndef FIXEDBASE
	MOV_L	(EDI,EAX)		/* return base */
#else
	MOV_L	(base_arg,EAX)		/* return base */
#endif
	MOV_L	(REGOFF(0,ESP),EDI)	/* POPL EDI */
	MOV_L	(REGOFF(4,ESP),ESI)	/* POPL ESI */
	MOV_L	(REGOFF(8,ESP),EBX)	/* POPL EBX */
	MOV_L	(REGOFF(12,ESP),EBP)	/* POPL EBP */
	ADD_L	(CONST(16),ESP)
	RET
	

	ALIGNTEXT4

#ifdef FIXEDBASE
# ifdef MSBFIRST
	GLOBL GLNAME(DrawTETextScanlineWidth8PMSBFirstFixedBase)
GLNAME(DrawTETextScanlineWidth8PMSBFirstFixedBase):
# else
	GLOBL GLNAME(DrawTETextScanlineWidth8PLSBFirstFixedBase)
GLNAME(DrawTETextScanlineWidth8PLSBFirstFixedBase):
# endif
#else
# ifdef MSBFIRST
	GLOBL GLNAME(DrawTETextScanlineWidth8PMSBFirst)
GLNAME(DrawTETextScanlineWidth8PMSBFirst):
# else
	GLOBL GLNAME(DrawTETextScanlineWidth8PLSBFirst)
GLNAME(DrawTETextScanlineWidth8PLSBFirst):
# endif
#endif

	SUB_L	(CONST(16),ESP)
	MOV_L	(EBP,REGOFF(12,ESP))	/* PUSH EBP */
	MOV_L	(EBX,REGOFF(8,ESP))	/* PUSH EBX */
	MOV_L	(ESI,REGOFF(4,ESP))	/* PUSH ESI */
	MOV_L	(EDI,REGOFF(0,ESP))	/* PUSH EDI */

	MOV_L	(line_arg,EBP)
	MOV_L	(base_arg,EDI)
	MOV_L	(glyphp_arg,ESI)

	ALIGNTEXT4

.L8_1:
	/* Pentium-optimized instruction pairing. */
	/* EBX = bits */
	MOV_L	(REGIND(ESI),EAX)		/* glyphp[0] */
	MOV_L	(REGOFF(4,ESI),EDX)		/* glyphp[1] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[0][line] */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[1][line] */
#ifdef MSBFIRST
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),BH)
#else
	MOV_L	(EAX,EBX)			/* bits = glyph[0][line] */
	MOV_B   (DL,BH)				/* bits |= ..[1].. << 8 */
#endif

	ROL_L	(CONST(16),EBX)
	MOV_L	(REGOFF(8,ESI),EAX)		/* glyphp[2] */
	MOV_L	(REGOFF(12,ESI),ECX)		/* glyphp[3] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[2][line] */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[3][line] */
#ifdef MSBFIRST
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),BH)
#else
	MOV_B   (AL,BL)				/* bits |= ..[2].. << 16 */
	MOV_B   (CL,BH)				/* bits |= ..[3].. << 24 */
#endif
	ROL_L	(CONST(16),EBX)
	MOV_L	(EBX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
	CMP_L	(CONST(32),width_arg)
#ifndef FIXEDBASE
	JLE	(.L8_2)
#else
	JLE	(.L8_3)
#endif

	MOV_L	(REGOFF(16,ESI),EAX)		/* glyphp[4] */
	MOV_L	(REGOFF(20,ESI),EDX)		/* glyphp[5] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[4][line] */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[5][line] */
#ifdef MSBFIRST
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),BH)
#else
	MOV_L    (EAX,EBX)			/* bits = glyph[4][line] */
	MOV_B    (DL,BH)			/* nits |= ..[5].. << 8 */
#endif

	ROL_L	(CONST(16),EBX)
	MOV_L	(REGOFF(24,ESI),EAX)		/* glyphp[6] */
	MOV_L	(REGOFF(28,ESI),ECX)		/* glyphp[7] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[6][line] */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[7][line] */
#ifdef MSBFIRST
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),BH)
#else
	MOV_B   (AL,BL)				/* bits |= ..[6].. << 16 */
	MOV_B   (CL,BH)				/* bits |= ..[7].. << 24 */
#endif
	ROL_L	(CONST(16),EBX)
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(4,EDI))	/* WRITE_IN_BIT_ORDER(base+1, bits) */
	ADD_L	(CONST(8),EDI)		/* base += 2 */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
	CMP_L	(CONST(64),width_arg)
	JLE	(.L8_3)
	ADD_L	(CONST(32),ESI)		/* glyphp += 8 */
	SUB_L	(CONST(64),width_arg)
	JMP	(.L8_1)

#ifndef FIXEDBASE
.L8_2:
	ADD_L	(CONST(4),EDI)		/* base++ */
.L8_3:
	MOV_L	(EDI,EAX)		/* return base */
#else
.L8_3:
	MOV_L	(base_arg,EAX)		/* return base */
#endif
	MOV_L	(REGOFF(0,ESP),EDI)	/* POPL EDI */
	MOV_L	(REGOFF(4,ESP),ESI)	/* POPL ESI */
	MOV_L	(REGOFF(8,ESP),EBX)	/* POPL EBX */
	MOV_L	(REGOFF(12,ESP),EBP)	/* POPL EBP */
	ADD_L	(CONST(16),ESP)
	RET

	ALIGNTEXT4

#ifdef FIXEDBASE
# ifdef MSBFIRST
	GLOBL GLNAME(DrawTETextScanlineWidth9PMSBFirstFixedBase)
GLNAME(DrawTETextScanlineWidth9PMSBFirstFixedBase):
# else
	GLOBL GLNAME(DrawTETextScanlineWidth9PLSBFirstFixedBase)
GLNAME(DrawTETextScanlineWidth9PLSBFirstFixedBase):
# endif
#else
# ifdef MSBFIRST
	GLOBL GLNAME(DrawTETextScanlineWidth9PMSBFirst)
GLNAME(DrawTETextScanlineWidth9PMSBFirst):
# else
	GLOBL GLNAME(DrawTETextScanlineWidth9PLSBFirst)
GLNAME(DrawTETextScanlineWidth9PLSBFirst):
# endif
#endif

	SUB_L	(CONST(16),ESP)
	MOV_L	(EBP,REGOFF(12,ESP))	/* PUSH EBP */
	MOV_L	(EBX,REGOFF(8,ESP))	/* PUSH EBX */
	MOV_L	(ESI,REGOFF(4,ESP))	/* PUSH ESI */
	MOV_L	(EDI,REGOFF(0,ESP))	/* PUSH EDI */

	MOV_L	(line_arg,EBP)
	MOV_L	(base_arg,EDI)
	MOV_L	(glyphp_arg,ESI)

	ALIGNTEXT4

.L9_1:
	/* Pentium-optimized instruction pairing. */
	/* EAX = bits */
	MOV_L	(REGOFF(4,ESI),EBX)		/* glyphp[1] */
	MOV_L	(REGIND(ESI),EAX)		/* glyphp[0] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[1][line] */
	MOV_L	(REGOFF(8,ESI),ECX)		/* glyphp[2] */
	SAL_L	(CONST(9),EBX)			/* glyphp[1][line] << 9 */
	MOV_L	(REGOFF(12,ESI),EDX)		/* glyphp[3] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[0][line] */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[3][line] */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[2][line] */
	OR_L	(EBX,EAX)			/* bits |= ..[1].. << 9 */
	SAL_L	(CONST(18),ECX)			/* glyphp[2][line] << 18 */
	OR_L	(ECX,EAX)			/* bits |= ..[2].. << 18 */
	SAL_L	(CONST(27),EDX)			/* glyphp[3][line << 27 */
			
#ifndef MSBFIRST
	MOV_L	(REGOFF(12,ESI),EBX)		/* glyphp[3] */
	OR_L	(EDX,EAX)			/* bits |= ..[3].. << 27 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[3][line] */
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(CONST(0),EBX)
	OR_L	(EDX,EAX)			/* bits |= ..[3].. << 27 */
	MOV_L	(CONST(0),ECX)
	MOV_B	(AL,BL)
	MOV_B	(AH,CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AH)
	ROL_L	(CONST(16),EAX)
	MOV_B	(AL,BL)
	MOV_B	(AH,CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AH)
	MOV_L	(REGOFF(12,ESI),EBX)		/* glyphp[3] */
	ROL_L	(CONST(16),EAX)
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[3][line] */
	MOV_L	(EAX,REGIND(EDI))
#endif

	CMP_L   (CONST(32),width_arg)
        JG      (.L9_2)
#ifndef FIXEDBASE
	ADD_L	(CONST(4),EDI)		/* base++ */
#endif
	JMP	(.L9_11)
.L9_2:
	/* Note that glyphp[3][line] is read again. */
	/* EAX = bits, EBX = glyphp[3][line] >> 5 */
	SHR_L	(CONST(5),EBX)			/* glyphp[3][line] >> 5 */
	MOV_L	(REGOFF(16,ESI),EAX)		/* glyphp[4] */
	MOV_L	(REGOFF(20,ESI),ECX)		/* glyphp[5] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[4][line] */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[5][line] */
	MOV_L	(REGOFF(24,ESI),EDX)		/* glyphp[6] */
	SAL_L	(CONST(4),EAX)			/* glyphp[4][line] << 4 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[6][line] */
	SAL_L	(CONST(13),ECX)			/* glyphp[5][line] << 13 */
	OR_L	(EBX,EAX)			/* bits |= ..[4].. << 4 */
	SAL_L	(CONST(22),EDX)			/* glyphp[6][line] << 22 */
	MOV_L	(REGOFF(28,ESI),EBX)		/* glyphp[7] */
	OR_L	(ECX,EAX)			/* bits |= ..[5].. << 13 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[7][line] */
	OR_L	(EDX,EAX)			/* bits |= ..[6].. << 22 */

#ifndef MSBFIRST
	MOV_L	(REGOFF(28,ESI),ECX)		/* glyphp[7] */
	SAL_L	(CONST(31),EBX)			/* glyphp[7][line] << 31 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[7][line] */
	OR_L	(EBX,EAX)			/* bits |= ..[7].. << 31 */
	MOV_L	(REGOFF(32,ESI),EDX)		/* glyphp[8] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(4,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),ECX)
	SAL_L	(CONST(31),EBX)			/* glyphp[7][line] << 31 */
	MOV_L	(CONST(0),EDX)
	OR_L	(EBX,EAX)			/* bits |= ..[7].. << 31 */
	MOV_B	(AL,CL)
	MOV_B	(AH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),AH)
	ROL_L	(CONST(16),EAX)
	MOV_B	(AL,CL)
	MOV_B	(AH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),AH)
	MOV_L	(REGOFF(28,ESI),ECX)		/* glyphp[7] */
	ROL_L	(CONST(16),EAX)
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[7][line] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(4,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
	MOV_L	(REGOFF(32,ESI),EDX)		/* glyphp[8] */
#endif

	CMP_L   (CONST(64),width_arg)
        JG      (.L9_3)
#ifndef FIXEDBASE
	ADD_L	(CONST(8),EDI)		/* base+=2 */
#endif
	JMP	(.L9_11)
.L9_3:

	/* Note that glyphp[7][line] is read again. */
	/* ECX = bits = glyphp[7][line] >> 1 */
	SHR_L	(CONST(1),ECX)			/* glyphp[7][line] >> 1 */
	MOV_L	(REGOFF(36,ESI),EBX)		/* glyphp[9] */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[8][line] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[9][line] */
	SAL_L	(CONST(8),EDX)			/* glyphp[8][line] << 8 */
	MOV_L	(REGOFF(40,ESI),EAX)		/* glyphp[10] */
	SAL_L	(CONST(17),EBX)			/* glyphp[9][line] << 17 */
	OR_L	(EDX,ECX)			/* bits |= ..[8].. << 8 */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[10][line] */
	OR_L	(EBX,ECX)			/* bits |= ..[9].. << 17 */
	SAL_L	(CONST(26),EAX)			/* glyphp[10][line] << 26 */

#ifndef MSBFIRST
	MOV_L	(REGOFF(40,ESI),EDX)		/* glyphp[10] */
	OR_L	(EAX,ECX)			/* bits |= ..[10].. << 26 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[10][line] */
#ifndef FIXEDBASE
	MOV_L	(ECX,REGOFF(8,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(ECX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),EDX)
	OR_L	(EAX,ECX)			/* bits |= ..[10].. << 26 */
	MOV_L	(CONST(0),EBX)
	MOV_B	(CL,DL)
	MOV_B	(CH,BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),CH)
	ROL_L	(CONST(16),ECX)
	MOV_B	(CL,DL)
	MOV_B	(CH,BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),CH)
	MOV_L	(REGOFF(40,ESI),EDX)		/* glyphp[10] */
	ROL_L	(CONST(16),ECX)
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[10][line] */
#ifndef FIXEDBASE
	MOV_L	(ECX,REGOFF(8,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(ECX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#endif

	CMP_L   (CONST(96),width_arg)
        JG      (.L9_4)
#ifndef FIXEDBASE
	ADD_L	(CONST(12),EDI)		/* base+=3 */
#endif
	JMP	(.L9_11)
.L9_4:
	/* Note that glyphp[10][line] is read again. */
	/* EDX = bits = glyphp[10][line] >> 6 */
	SHR_L	(CONST(6),EDX)			/* glyphp[10][line] >> 6 */
	MOV_L	(REGOFF(44,ESI),EBX)		/* glyphp[11] */
	MOV_L	(REGOFF(48,ESI),EAX)		/* glyphp[12] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[11][line] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[12][line] */
	MOV_L	(REGOFF(52,ESI),ECX)		/* glyphp[13] */
	SAL_L	(CONST(3),EBX)			/* glyphp[11][line] << 3 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[13][line] */
	SAL_L	(CONST(12),EAX)			/* glyphp[12][line] << 12 */
	OR_L	(EBX,EDX)			/* bits |= ..[11].. << 3 */
	SAL_L	(CONST(21),ECX)			/* glyphp[13][line] << 21 */
	MOV_L	(REGOFF(56,ESI),EBX)		/* glyphp[14] */
	OR_L	(EAX,EDX)			/* bits |= ..[12].. << 17 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[14][line] */
	SAL_L	(CONST(30),EBX)			/* glyphp[14][line] << 30 */
	OR_L	(ECX,EDX)			/* bits |= ..[13].. << 21 */

#ifndef MSBFIRST
	MOV_L	(REGOFF(56,ESI),EAX)		/* glyphp[14] */
	OR_L	(EBX,EDX)			/* bits |= ..[14].. << 30 */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[14][line] */
#ifndef FIXEDBASE
	MOV_L	(EDX,REGOFF(12,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EDX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),EAX)
	OR_L	(EBX,EDX)			/* bits |= ..[14].. << 30 */
	MOV_L	(CONST(0),ECX)
	MOV_B	(DL,AL)
	MOV_B	(DH,CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),DH)
	ROL_L	(CONST(16),EDX)
	MOV_B	(DL,AL)
	MOV_B	(DH,CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),DH)
	MOV_L	(REGOFF(56,ESI),EAX)		/* glyphp[14] */
	ROL_L	(CONST(16),EDX)
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[14][line] */
#ifndef FIXEDBASE
	MOV_L	(EDX,REGOFF(12,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EDX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#endif

	CMP_L   (CONST(128),width_arg)
        JG      (.L9_5)
#ifndef FIXEDBASE
	ADD_L	(CONST(16),EDI)		/* base+=4 */
#endif
	JMP	(.L9_11)
.L9_5:	
	/* Note that glyphp[14][line] is read again. */
	/* EAX = bits = glyphp[14][line] >> 2 */
	SHR_L	(CONST(2),EAX)			/* glyphp[14][line] >> 2 */
	MOV_L	(REGOFF(60,ESI),ECX)		/* glyphp[15] */
	MOV_L	(REGOFF(64,ESI),EBX)		/* glyphp[16] */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[15][line] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[16][line] */
	MOV_L	(REGOFF(68,ESI),EDX)		/* glyphp[17] */
	SAL_L	(CONST(7),ECX)			/* glyphp[15][line] << 7 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[17][line] */
	SAL_L	(CONST(16),EBX)			/* glyphp[16][line] << 16 */
	OR_L	(ECX,EAX)			/* bits |= ..[15].. << 7 */
	SAL_L	(CONST(25),EDX)			/* glyphp[17][line] << 25 */
	OR_L	(EBX,EAX)			/* bits |= ..[16].. << 16 */
	
#ifndef MSBFIRST
	MOV_L	(REGOFF(68,ESI),ECX)		/* glyphp[17] */
	OR_L	(EDX,EAX)			/* bits |= ..[17].. << 25 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[17][line] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(16,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),ECX)
	OR_L	(EDX,EAX)			/* bits |= ..[17].. << 25 */
	MOV_L	(CONST(0),EBX)
	MOV_B	(AL,CL)
	MOV_B	(AH,BL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),AH)
	ROL_L	(CONST(16),EAX)
	MOV_B	(AL,CL)
	MOV_B	(AH,BL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),AH)
	MOV_L	(REGOFF(68,ESI),ECX)		/* glyphp[17] */
	ROL_L	(CONST(16),EAX)
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[17][line] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(16,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#endif

	CMP_L   (CONST(160),width_arg)
        JG      (.L9_6)
#ifndef FIXEDBASE
	ADD_L	(CONST(20),EDI)		/* base+=5 */
#endif
	JMP	(.L9_11)
.L9_6:	
	/* Note that glyphp[17][line] is read again. */
	/* ECX = bits = glyphp[17][line] >> 7 */
	SHR_L	(CONST(7),ECX)			/* glyphp[17][line] >> 7 */
	MOV_L	(REGOFF(72,ESI),EBX)		/* glyphp[18] */
	MOV_L	(REGOFF(76,ESI),EAX)		/* glyphp[19] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[18][line] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[19][line] */
	MOV_L	(REGOFF(80,ESI),EDX)		/* glyphp[20] */
	SAL_L	(CONST(2),EBX)			/* glyphp[18][line] << 2 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[20][line] */
	SAL_L	(CONST(11),EAX)			/* glyphp[19][line] << 11 */
	OR_L	(EBX,ECX)			/* bits |= ..[18].. << 2 */
	SAL_L	(CONST(20),EDX)			/* glyphp[20][line] << 20 */
	MOV_L	(REGOFF(84,ESI),EBX)		/* glyphp[21] */
	OR_L	(EAX,ECX)			/* bits |= ..[19].. << 11 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[21][line] */
	OR_L	(EDX,ECX)			/* bits |= ..[20].. << 20 */
	
#ifndef MSBFIRST
	MOV_L	(REGOFF(84,ESI),EAX)		/* glyphp[21] */
	SAL_L	(CONST(29),EBX)			/* glyphp[21][line] << 29 */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[21][line] */
	OR_L	(EBX,ECX)			/* bits |= ..[14].. << 30 */
	MOV_L	(REGOFF(88,ESI),EDX)		/* glyphp[22] */
#ifndef FIXEDBASE
	MOV_L	(ECX,REGOFF(20,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(ECX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),EAX)
	SAL_L	(CONST(29),EBX)			/* glyphp[21][line] << 29 */
	MOV_L	(CONST(0),EDX)
	OR_L	(EBX,ECX)			/* bits |= ..[14].. << 30 */
	MOV_B	(CL,AL)
	MOV_B	(CH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),CH)
	ROL_L	(CONST(16),ECX)
	MOV_B	(CL,AL)
	MOV_B	(CH,DL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),CH)
	MOV_L	(REGOFF(84,ESI),EAX)		/* glyphp[21] */
	ROL_L	(CONST(16),ECX)
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[21][line] */
#ifndef FIXEDBASE
	MOV_L	(ECX,REGOFF(20,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(ECX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
	MOV_L	(REGOFF(88,ESI),EDX)		/* glyphp[22] */
#endif

	CMP_L   (CONST(192),width_arg)
        JG      (.L9_7)
#ifndef FIXEDBASE
	ADD_L	(CONST(24),EDI)		/* base+=6 */
#endif
	JMP	(.L9_11)
.L9_7:
	/* Note that glyphp[21][line] is read again. */
	/* EAX = bits = glyphp[21][line] >> 3 */
	SHR_L	(CONST(3),EAX)			/* glyphp[21][line] >> 3 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[22][line] */
	MOV_L	(REGOFF(92,ESI),EBX)		/* glyphp[23] */
	MOV_L	(REGOFF(96,ESI),ECX)		/* glyphp[24] */
	SAL_L	(CONST(6),EDX)			/* glyphp[22][line] << 6 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[23][line] */
	OR_L	(EDX,EAX)			/* bits |= ..[22].. << 6 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[24][line] */
	SAL_L	(CONST(15),EBX)			/* glyphp[23][line] << 15 */
	OR_L	(EBX,EAX)			/* bits |= ..[23].. << 15 */
	SAL_L	(CONST(24),ECX)			/* glyphp[24][line] << 24 */

#ifndef MSBFIRST
	MOV_L	(REGOFF(96,ESI),EDX)		/* glyphp[24] */
	OR_L	(ECX,EAX)			/* bits |= ..[24].. << 24 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[24][line] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(24,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),EDX)
	OR_L	(ECX,EAX)			/* bits |= ..[24].. << 24 */
	MOV_L	(CONST(0),EBX)
	MOV_B	(AL,DL)
	MOV_B	(AH,BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),AH)
	ROL_L	(CONST(16),EAX)
	MOV_B	(AL,DL)
	MOV_B	(AH,BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EDX),AL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),AH)
	MOV_L	(REGOFF(96,ESI),EDX)		/* glyphp[24] */
	ROL_L	(CONST(16),EAX)
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[24][line] */
#ifndef FIXEDBASE
	MOV_L	(EAX,REGOFF(24,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EAX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#endif

	CMP_L   (CONST(224),width_arg)
        JG      (.L9_8)
#ifndef FIXEDBASE
	ADD_L	(CONST(28),EDI)		/* base+=7 */
#endif
	JMP	(.L9_11)
.L9_8:
	/* Note that glyphp[24][line] is read again. */
	/* EDX = bits = glyphp[24][line] >> 8 */

	SHR_L	(CONST(8),EDX)			/* glyphp[24][line] >> 8 */
	MOV_L	(REGOFF(100,ESI),EAX)		/* glyphp[25] */
	MOV_L	(REGOFF(104,ESI),EBX)		/* glyphp[26] */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[25][line] */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[26][line] */
	MOV_L	(REGOFF(108,ESI),ECX)		/* glyphp[27] */
	SAL_L	(CONST(1),EAX)			/* glyphp[25][line] << 1 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[27][line] */
	SAL_L	(CONST(10),EBX)			/* glyphp[26][line] << 10 */
	OR_L	(EAX,EDX)			/* bits |= ..[25].. << 1 */
	SAL_L	(CONST(19),ECX)			/* glyphp[27][line] << 19 */
	OR_L	(EBX,EDX)			/* bits |= ..[26].. << 10 */
	MOV_L	(REGOFF(112,ESI),EAX)		/* glyphp[28] */
	OR_L	(ECX,EDX)			/* bits |= ..[27].. << 19 */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[28][line] */

#ifndef MSBFIRST
	MOV_L	(REGOFF(112,ESI),EBX)		/* glyphp[28] */
	SAL_L	(CONST(28),EAX)			/* glyphp[28][line] << 28 */
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[28][line] */
	OR_L	(EAX,EDX)			/* bits |= ..[28].. << 28 */
	MOV_L	(REGOFF(116,ESI),ECX)		/* glyphp[29] */
#ifndef FIXEDBASE
	MOV_L	(EDX,REGOFF(28,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EDX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),EBX)
	SAL_L	(CONST(28),EAX)			/* glyphp[28][line] << 28 */
	MOV_L	(CONST(0),ECX)
	OR_L	(EAX,EDX)			/* bits |= ..[28].. << 28 */
	MOV_B	(DL,BL)
	MOV_B	(DH,CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),DH)
	ROL_L	(CONST(16),EDX)
	MOV_B	(DL,BL)
	MOV_B	(DH,CL)
	MOV_B	(REGOFF(BYTE_REVERSED,EBX),DL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),DH)
	MOV_L	(REGOFF(112,ESI),EBX)		/* glyphp[28] */
	ROL_L	(CONST(16),EDX)
	MOV_L	(REGOFF(116,ESI),ECX)		/* glyphp[29] */
#ifndef FIXEDBASE
	MOV_L	(EDX,REGOFF(28,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EDX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
	MOV_L	(REGBISD(EBX,EBP,4,0),EBX)	/* glyphp[28][line] */
#endif
	
	CMP_L   (CONST(256),width_arg)
        JG      (.L9_9)
#ifndef FIXEDBASE
	ADD_L	(CONST(32),EDI)		/* base+=8 */
#endif
	JMP	(.L9_11)
.L9_9:
	/* Note that glyphp[28][line] is read again. */
	/* EBX = bits = glyphp[28][line] >> 4 */
	SHR_L	(CONST(4),EBX)			/* glyphp[28][line] >> 4 */
	MOV_L	(REGBISD(ECX,EBP,4,0),ECX)	/* glyphp[29][line] */
	MOV_L	(REGOFF(120,ESI),EAX)		/* glyphp[30] */
	MOV_L	(REGOFF(124,ESI),EDX)		/* glyphp[31] */
	SAL_L	(CONST(5),ECX)			/* glyphp[29][line] << 5 */
	MOV_L	(REGBISD(EAX,EBP,4,0),EAX)	/* glyphp[30][line] */
	OR_L	(ECX,EBX)			/* bits |= ..[29].. << 5 */
	MOV_L	(REGBISD(EDX,EBP,4,0),EDX)	/* glyphp[31][line] */
	SAL_L	(CONST(14),EAX)			/* glyphp[30][line] << 14 */
	ADD_L	(CONST(128),ESI)		/* glyphp+=32 */
	SAL_L	(CONST(23),EDX)			/* glyphp[31][line] << 23 */
	OR_L	(EAX,EBX)			/* bits |= ..[30].. << 14 */
	SUB_L	(CONST(288),width_arg)		/* width-=288 */
	OR_L	(EDX,EBX)			/* bits |= ..[31].. << 23 */

#ifndef MSBFIRST
#ifndef FIXEDBASE
	MOV_L	(EBX,REGOFF(32,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EBX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#else
	MOV_L	(CONST(0),ECX)
	MOV_L	(CONST(0),EAX)
	MOV_B	(BL,CL)
	MOV_B	(BH,AL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BH)
	ROL_L	(CONST(16),EBX)
	MOV_B	(BL,CL)
	MOV_B	(BH,AL)
	MOV_B	(REGOFF(BYTE_REVERSED,ECX),BL)
	MOV_B	(REGOFF(BYTE_REVERSED,EAX),BH)
	ROL_L	(CONST(16),EBX)
#ifndef FIXEDBASE
	MOV_L	(EBX,REGOFF(32,EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#else
	MOV_L	(EBX,REGIND(EDI))	/* WRITE_IN_BIT_ORDER(base, bits) */
#endif
#endif
	
	ADD_L	(CONST(36),EDI)		/* base+=9 */
	CMP_L   (CONST(0),width_arg)
        JG      (.L9_1)
			
.L9_11:
#ifndef FIXEDBASE
	MOV_L	(EDI,EAX)		/* return base */
#else
	MOV_L	(base_arg,EAX)		/* return base */
#endif
	MOV_L	(REGOFF(0,ESP),EDI)	/* POPL EDI */
	MOV_L	(REGOFF(4,ESP),ESI)	/* POPL ESI */
	MOV_L	(REGOFF(8,ESP),EBX)	/* POPL EBX */
	MOV_L	(REGOFF(12,ESP),EBP)	/* POPL EBP */
	ADD_L	(CONST(16),ESP)
	RET

Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to [email protected].