/*
 * Silicon Motion SM712 2D drawing engine functions.
 *
 * Copyright (C) 2006 Silicon Motion Technology Corp.
 * Author: Ge Wang, gewang@siliconmotion.com
 *
 * Copyright (C) 2009 Lemote, Inc.
 * Author: Wu Zhangjin, wuzhangjin@gmail.com
 *
 *  This file is subject to the terms and conditions of the GNU General Public
 *  License. See the file COPYING in the main directory of this archive for
 *  more details.
 */

#ifndef NULL
#define NULL	 0
#endif

/* Internal macros */

#define _F_START(f)		(0 ? f)
#define _F_END(f)		(1 ? f)
#define _F_SIZE(f)		(1 + _F_END(f) - _F_START(f))
#define _F_MASK(f)		(((1ULL << _F_SIZE(f)) - 1) << _F_START(f))
#define _F_NORMALIZE(v, f)	(((v) & _F_MASK(f)) >> _F_START(f))
#define _F_DENORMALIZE(v, f)	(((v) << _F_START(f)) & _F_MASK(f))

/* Global macros */

#define FIELD_GET(x, reg, field) \
( \
    _F_NORMALIZE((x), reg ## _ ## field) \
)

#define FIELD_SET(x, reg, field, value) \
( \
    (x & ~_F_MASK(reg ## _ ## field)) \
    | _F_DENORMALIZE(reg ## _ ## field ## _ ## value, reg ## _ ## field) \
)

#define FIELD_VALUE(x, reg, field, value) \
( \
    (x & ~_F_MASK(reg ## _ ## field)) \
    | _F_DENORMALIZE(value, reg ## _ ## field) \
)

#define FIELD_CLEAR(reg, field) \
( \
    ~_F_MASK(reg ## _ ## field) \
)

/* Field Macros                        */

#define FIELD_START(field)	(0 ? field)
#define FIELD_END(field)	(1 ? field)
#define FIELD_SIZE(field) \
	(1 + FIELD_END(field) - FIELD_START(field))

#define FIELD_MASK(field) \
	(((1 << (FIELD_SIZE(field)-1)) \
	| ((1 << (FIELD_SIZE(field)-1)) - 1)) \
	<< FIELD_START(field))

#define FIELD_NORMALIZE(reg, field) \
	(((reg) & FIELD_MASK(field)) >> FIELD_START(field))

#define FIELD_DENORMALIZE(field, value) \
	(((value) << FIELD_START(field)) & FIELD_MASK(field))

#define FIELD_INIT(reg, field, value) \
	FIELD_DENORMALIZE(reg ## _ ## field, \
		reg ## _ ## field ## _ ## value)

#define FIELD_INIT_VAL(reg, field, value) \
	(FIELD_DENORMALIZE(reg ## _ ## field, value))

#define FIELD_VAL_SET(x, r, f, v) ({ \
	x = (x & ~FIELD_MASK(r ## _ ## f)) \
	| FIELD_DENORMALIZE(r ## _ ## f, r ## _ ## f ## _ ## v) \
})

#define RGB(r, g, b)	((unsigned long)(((r) << 16) | ((g) << 8) | (b)))

/* Transparent info definition */
typedef struct {
	unsigned long match;	/* Matching pixel is OPAQUE/TRANSPARENT */
	unsigned long select;	/* Transparency controlled by SRC/DST */
	unsigned long control;	/* ENABLE/DISABLE transparency */
	unsigned long color;	/* Transparent color */
} Transparent, *pTransparent;

#define PIXEL_DEPTH_1_BP	0	/* 1 bit per pixel */
#define PIXEL_DEPTH_8_BPP	1	/* 8 bits per pixel */
#define PIXEL_DEPTH_16_BPP	2	/* 16 bits per pixel */
#define PIXEL_DEPTH_32_BPP	3	/* 32 bits per pixel */
#define PIXEL_DEPTH_YUV422	8	/* 16 bits per pixel YUV422 */
#define PIXEL_DEPTH_YUV420	9	/* 16 bits per pixel YUV420 */

#define PATTERN_WIDTH		8
#define PATTERN_HEIGHT		8

#define	TOP_TO_BOTTOM		0
#define	BOTTOM_TO_TOP		1
#define RIGHT_TO_LEFT		BOTTOM_TO_TOP
#define LEFT_TO_RIGHT		TOP_TO_BOTTOM

/* Constants used in Transparent structure */
#define MATCH_OPAQUE		0x00000000
#define MATCH_TRANSPARENT	0x00000400
#define SOURCE			0x00000000
#define DESTINATION		0x00000200

/* 2D registers. */

#define	DE_SOURCE			0x000000
#define	DE_SOURCE_WRAP			31 : 31
#define	DE_SOURCE_WRAP_DISABLE		0
#define	DE_SOURCE_WRAP_ENABLE		1
#define	DE_SOURCE_X_K1			29 : 16
#define	DE_SOURCE_Y_K2			15 : 0

#define	DE_DESTINATION			0x000004
#define	DE_DESTINATION_WRAP		31 : 31
#define	DE_DESTINATION_WRAP_DISABLE	0
#define	DE_DESTINATION_WRAP_ENABLE	1
#define	DE_DESTINATION_X		28 : 16
#define	DE_DESTINATION_Y		15 : 0

#define	DE_DIMENSION			0x000008
#define	DE_DIMENSION_X			28 : 16
#define	DE_DIMENSION_Y_ET		15 : 0

#define	DE_CONTROL			0x00000C
#define	DE_CONTROL_STATUS		31 : 31
#define	DE_CONTROL_STATUS_STOP		0
#define	DE_CONTROL_STATUS_START		1
#define	DE_CONTROL_PATTERN		30 : 30
#define	DE_CONTROL_PATTERN_MONO		0
#define	DE_CONTROL_PATTERN_COLOR	1
#define	DE_CONTROL_UPDATE_DESTINATION_X		29 : 29
#define	DE_CONTROL_UPDATE_DESTINATION_X_DISABLE	0
#define	DE_CONTROL_UPDATE_DESTINATION_X_ENABLE	1
#define	DE_CONTROL_QUICK_START			28 : 28
#define	DE_CONTROL_QUICK_START_DISABLE		0
#define	DE_CONTROL_QUICK_START_ENABLE		1
#define	DE_CONTROL_DIRECTION			27 : 27
#define	DE_CONTROL_DIRECTION_LEFT_TO_RIGHT	0
#define	DE_CONTROL_DIRECTION_RIGHT_TO_LEFT	1
#define	DE_CONTROL_MAJOR			26 : 26
#define	DE_CONTROL_MAJOR_X			0
#define	DE_CONTROL_MAJOR_Y			1
#define	DE_CONTROL_STEP_X			25 : 25
#define	DE_CONTROL_STEP_X_POSITIVE		1
#define	DE_CONTROL_STEP_X_NEGATIVE		0
#define	DE_CONTROL_STEP_Y			24 : 24
#define	DE_CONTROL_STEP_Y_POSITIVE		1
#define	DE_CONTROL_STEP_Y_NEGATIVE		0
#define	DE_CONTROL_STRETCH			23 : 23
#define	DE_CONTROL_STRETCH_DISABLE		0
#define	DE_CONTROL_STRETCH_ENABLE		1
#define	DE_CONTROL_HOST				22 : 22
#define	DE_CONTROL_HOST_COLOR			0
#define	DE_CONTROL_HOST_MONO			1
#define	DE_CONTROL_LAST_PIXEL			21 : 21
#define	DE_CONTROL_LAST_PIXEL_OFF		0
#define	DE_CONTROL_LAST_PIXEL_ON		1
#define	DE_CONTROL_COMMAND			20 : 16
#define	DE_CONTROL_COMMAND_BITBLT		0
#define	DE_CONTROL_COMMAND_RECTANGLE_FILL	1
#define	DE_CONTROL_COMMAND_DE_TILE		2
#define	DE_CONTROL_COMMAND_TRAPEZOID_FILL	3
#define	DE_CONTROL_COMMAND_ALPHA_BLEND		4
#define	DE_CONTROL_COMMAND_RLE_STRIP		5
#define	DE_CONTROL_COMMAND_SHORT_STROKE		6
#define	DE_CONTROL_COMMAND_LINE_DRAW		7
#define	DE_CONTROL_COMMAND_HOST_WRITE		8
#define	DE_CONTROL_COMMAND_HOST_READ		9
#define	DE_CONTROL_COMMAND_HOST_WRITE_BOTTOM_UP	10
#define	DE_CONTROL_COMMAND_ROTATE		11
#define	DE_CONTROL_COMMAND_FONT			12
#define	DE_CONTROL_COMMAND_TEXTURE_LOAD		15
#define	DE_CONTROL_ROP_SELECT			15 : 15
#define	DE_CONTROL_ROP_SELECT_ROP3		0
#define	DE_CONTROL_ROP_SELECT_ROP2		1
#define	DE_CONTROL_ROP2_SOURCE			14 : 14
#define	DE_CONTROL_ROP2_SOURCE_BITMAP		0
#define	DE_CONTROL_ROP2_SOURCE_PATTERN		1
#define	DE_CONTROL_MONO_DATA			13 : 12
#define	DE_CONTROL_MONO_DATA_NOT_PACKED		0
#define	DE_CONTROL_MONO_DATA_8_PACKED		1
#define	DE_CONTROL_MONO_DATA_16_PACKED		2
#define	DE_CONTROL_MONO_DATA_32_PACKED		3
#define	DE_CONTROL_REPEAT_ROTATE		11 : 11
#define	DE_CONTROL_REPEAT_ROTATE_DISABLE	0
#define	DE_CONTROL_REPEAT_ROTATE_ENABLE		1
#define	DE_CONTROL_TRANSPARENCY_MATCH		10 : 10
#define	DE_CONTROL_TRANSPARENCY_MATCH_OPAQUE		0
#define	DE_CONTROL_TRANSPARENCY_MATCH_TRANSPARENT	1
#define	DE_CONTROL_TRANSPARENCY_SELECT			9 : 9
#define	DE_CONTROL_TRANSPARENCY_SELECT_SOURCE		0
#define	DE_CONTROL_TRANSPARENCY_SELECT_DESTINATION	1
#define	DE_CONTROL_TRANSPARENCY				8 : 8
#define	DE_CONTROL_TRANSPARENCY_DISABLE			0
#define	DE_CONTROL_TRANSPARENCY_ENABLE			1
#define	DE_CONTROL_ROP					7 : 0

/* Pseudo fields. */

#define	DE_CONTROL_SHORT_STROKE_DIR			27 : 24
#define	DE_CONTROL_SHORT_STROKE_DIR_225			0
#define	DE_CONTROL_SHORT_STROKE_DIR_135			1
#define	DE_CONTROL_SHORT_STROKE_DIR_315			2
#define	DE_CONTROL_SHORT_STROKE_DIR_45			3
#define	DE_CONTROL_SHORT_STROKE_DIR_270			4
#define	DE_CONTROL_SHORT_STROKE_DIR_90			5
#define	DE_CONTROL_SHORT_STROKE_DIR_180			8
#define	DE_CONTROL_SHORT_STROKE_DIR_0			10
#define	DE_CONTROL_ROTATION				25 : 24
#define	DE_CONTROL_ROTATION_0				0
#define	DE_CONTROL_ROTATION_270				1
#define	DE_CONTROL_ROTATION_90				2
#define	DE_CONTROL_ROTATION_180				3

#define	DE_PITCH					0x000010
#define	DE_PITCH_DESTINATION				28 : 16
#define	DE_PITCH_SOURCE					12 : 0

#define	DE_FOREGROUND					0x000014
#define	DE_FOREGROUND_COLOR				31 : 0

#define	DE_BACKGROUND					0x000018
#define	DE_BACKGROUND_COLOR				31 : 0

#define	DE_STRETCH_FORMAT				0x00001C
#define	DE_STRETCH_FORMAT_PATTERN_XY			30 : 30
#define	DE_STRETCH_FORMAT_PATTERN_XY_NORMAL		0
#define	DE_STRETCH_FORMAT_PATTERN_XY_OVERWRITE		1
#define	DE_STRETCH_FORMAT_PATTERN_Y			29 : 27
#define	DE_STRETCH_FORMAT_PATTERN_X			25 : 23
#define	DE_STRETCH_FORMAT_PIXEL_FORMAT			21 : 20
#define	DE_STRETCH_FORMAT_PIXEL_FORMAT_8		0
#define	DE_STRETCH_FORMAT_PIXEL_FORMAT_16		1
#define	DE_STRETCH_FORMAT_PIXEL_FORMAT_24		3
#define	DE_STRETCH_FORMAT_PIXEL_FORMAT_32		2
#define	DE_STRETCH_FORMAT_ADDRESSING			19 : 16
#define	DE_STRETCH_FORMAT_ADDRESSING_XY			0
#define	DE_STRETCH_FORMAT_ADDRESSING_LINEAR		15
#define	DE_STRETCH_FORMAT_SOURCE_HEIGHT			11 : 0

#define	DE_COLOR_COMPARE				0x000020
#define	DE_COLOR_COMPARE_COLOR				23 : 0

#define	DE_COLOR_COMPARE_MASK				0x000024
#define	DE_COLOR_COMPARE_MASK_MASKS			23 : 0

#define	DE_MASKS					0x000028
#define	DE_MASKS_BYTE_MASK				31 : 16
#define	DE_MASKS_BIT_MASK				15 : 0

#define	DE_CLIP_TL					0x00002C
#define	DE_CLIP_TL_TOP					31 : 16
#define	DE_CLIP_TL_STATUS				13 : 13
#define	DE_CLIP_TL_STATUS_DISABLE			0
#define	DE_CLIP_TL_STATUS_ENABLE			1
#define	DE_CLIP_TL_INHIBIT				12 : 12
#define	DE_CLIP_TL_INHIBIT_OUTSIDE			0
#define	DE_CLIP_TL_INHIBIT_INSIDE			1
#define	DE_CLIP_TL_LEFT					11 : 0

#define	DE_CLIP_BR					0x000030
#define	DE_CLIP_BR_BOTTOM				31 : 16
#define	DE_CLIP_BR_RIGHT				12 : 0

#define	DE_MONO_PATTERN_LOW				0x000034
#define	DE_MONO_PATTERN_LOW_PATTERN			31 : 0

#define	DE_MONO_PATTERN_HIGH				0x000038
#define	DE_MONO_PATTERN_HIGH_PATTERN			31 : 0

#define	DE_WINDOW_WIDTH					0x00003C
#define	DE_WINDOW_WIDTH_DESTINATION			28 : 16
#define	DE_WINDOW_WIDTH_SOURCE				12 : 0

#define	DE_WINDOW_SOURCE_BASE				0x000040
#define	DE_WINDOW_SOURCE_BASE_EXT			27 : 27
#define	DE_WINDOW_SOURCE_BASE_EXT_LOCAL			0
#define	DE_WINDOW_SOURCE_BASE_EXT_EXTERNAL		1
#define	DE_WINDOW_SOURCE_BASE_CS			26 : 26
#define	DE_WINDOW_SOURCE_BASE_CS_0			0
#define	DE_WINDOW_SOURCE_BASE_CS_1			1
#define	DE_WINDOW_SOURCE_BASE_ADDRESS			25 : 0

#define	DE_WINDOW_DESTINATION_BASE			0x000044
#define	DE_WINDOW_DESTINATION_BASE_EXT			27 : 27
#define	DE_WINDOW_DESTINATION_BASE_EXT_LOCAL		0
#define	DE_WINDOW_DESTINATION_BASE_EXT_EXTERNAL		1
#define	DE_WINDOW_DESTINATION_BASE_CS			26 : 26
#define	DE_WINDOW_DESTINATION_BASE_CS_0			0
#define	DE_WINDOW_DESTINATION_BASE_CS_1			1
#define	DE_WINDOW_DESTINATION_BASE_ADDRESS		25 : 0

#define	DE_ALPHA					0x000048
#define	DE_ALPHA_VALUE					7 : 0

#define	DE_WRAP						0x00004C
#define	DE_WRAP_X					31 : 16
#define	DE_WRAP_Y					15 : 0

#define	DE_STATUS					0x000050
#define	DE_STATUS_CSC					1 : 1
#define	DE_STATUS_CSC_CLEAR				0
#define	DE_STATUS_CSC_NOT_ACTIVE			0
#define	DE_STATUS_CSC_ACTIVE				1
#define	DE_STATUS_2D					0 : 0
#define	DE_STATUS_2D_CLEAR				0
#define	DE_STATUS_2D_NOT_ACTIVE				0
#define	DE_STATUS_2D_ACTIVE				1

/* Color Space Conversion registers. */

#define	CSC_Y_SOURCE_BASE				0x0000C8
#define	CSC_Y_SOURCE_BASE_EXT				27 : 27
#define	CSC_Y_SOURCE_BASE_EXT_LOCAL			0
#define	CSC_Y_SOURCE_BASE_EXT_EXTERNAL			1
#define	CSC_Y_SOURCE_BASE_CS				26 : 26
#define	CSC_Y_SOURCE_BASE_CS_0				0
#define	CSC_Y_SOURCE_BASE_CS_1				1
#define	CSC_Y_SOURCE_BASE_ADDRESS			25 : 0

#define	CSC_CONSTANTS					0x0000CC
#define	CSC_CONSTANTS_Y					31 : 24
#define	CSC_CONSTANTS_R					23 : 16
#define	CSC_CONSTANTS_G					15 : 8
#define	CSC_CONSTANTS_B					7 : 0

#define	CSC_Y_SOURCE_X					0x0000D0
#define	CSC_Y_SOURCE_X_INTEGER				26 : 16
#define	CSC_Y_SOURCE_X_FRACTION				15 : 3

#define	CSC_Y_SOURCE_Y					0x0000D4
#define	CSC_Y_SOURCE_Y_INTEGER				27 : 16
#define	CSC_Y_SOURCE_Y_FRACTION				15 : 3

#define	CSC_U_SOURCE_BASE				0x0000D8
#define	CSC_U_SOURCE_BASE_EXT				27 : 27
#define	CSC_U_SOURCE_BASE_EXT_LOCAL			0
#define	CSC_U_SOURCE_BASE_EXT_EXTERNAL			1
#define	CSC_U_SOURCE_BASE_CS				26 : 26
#define	CSC_U_SOURCE_BASE_CS_0				0
#define	CSC_U_SOURCE_BASE_CS_1				1
#define	CSC_U_SOURCE_BASE_ADDRESS			25 : 0

#define	CSC_V_SOURCE_BASE				0x0000DC
#define	CSC_V_SOURCE_BASE_EXT				27 : 27
#define	CSC_V_SOURCE_BASE_EXT_LOCAL			0
#define	CSC_V_SOURCE_BASE_EXT_EXTERNAL			1
#define	CSC_V_SOURCE_BASE_CS				26 : 26
#define	CSC_V_SOURCE_BASE_CS_0				0
#define	CSC_V_SOURCE_BASE_CS_1				1
#define	CSC_V_SOURCE_BASE_ADDRESS			25 : 0

#define	CSC_SOURCE_DIMENSION				0x0000E0
#define	CSC_SOURCE_DIMENSION_X				31 : 16
#define	CSC_SOURCE_DIMENSION_Y				15 : 0

#define	CSC_SOURCE_PITCH				0x0000E4
#define	CSC_SOURCE_PITCH_Y				31 : 16
#define	CSC_SOURCE_PITCH_UV				15 : 0

#define	CSC_DESTINATION					0x0000E8
#define	CSC_DESTINATION_WRAP				31 : 31
#define	CSC_DESTINATION_WRAP_DISABLE			0
#define	CSC_DESTINATION_WRAP_ENABLE			1
#define	CSC_DESTINATION_X				27 : 16
#define	CSC_DESTINATION_Y				11 : 0

#define	CSC_DESTINATION_DIMENSION			0x0000EC
#define	CSC_DESTINATION_DIMENSION_X			31 : 16
#define	CSC_DESTINATION_DIMENSION_Y			15 : 0

#define	CSC_DESTINATION_PITCH				0x0000F0
#define	CSC_DESTINATION_PITCH_X				31 : 16
#define	CSC_DESTINATION_PITCH_Y				15 : 0

#define	CSC_SCALE_FACTOR				0x0000F4
#define	CSC_SCALE_FACTOR_HORIZONTAL			31 : 16
#define	CSC_SCALE_FACTOR_VERTICAL			15 : 0

#define	CSC_DESTINATION_BASE				0x0000F8
#define	CSC_DESTINATION_BASE_EXT			27 : 27
#define	CSC_DESTINATION_BASE_EXT_LOCAL			0
#define	CSC_DESTINATION_BASE_EXT_EXTERNAL		1
#define	CSC_DESTINATION_BASE_CS				26 : 26
#define	CSC_DESTINATION_BASE_CS_0			0
#define	CSC_DESTINATION_BASE_CS_1			1
#define	CSC_DESTINATION_BASE_ADDRESS			25 : 0

#define	CSC_CONTROL					0x0000FC
#define	CSC_CONTROL_STATUS				31 : 31
#define	CSC_CONTROL_STATUS_STOP				0
#define	CSC_CONTROL_STATUS_START			1
#define	CSC_CONTROL_SOURCE_FORMAT			30 : 28
#define	CSC_CONTROL_SOURCE_FORMAT_YUV422		0
#define	CSC_CONTROL_SOURCE_FORMAT_YUV420I		1
#define	CSC_CONTROL_SOURCE_FORMAT_YUV420		2
#define	CSC_CONTROL_SOURCE_FORMAT_YVU9			3
#define	CSC_CONTROL_SOURCE_FORMAT_IYU1			4
#define	CSC_CONTROL_SOURCE_FORMAT_IYU2			5
#define	CSC_CONTROL_SOURCE_FORMAT_RGB565		6
#define	CSC_CONTROL_SOURCE_FORMAT_RGB8888		7
#define	CSC_CONTROL_DESTINATION_FORMAT			27 : 26
#define	CSC_CONTROL_DESTINATION_FORMAT_RGB565		0
#define	CSC_CONTROL_DESTINATION_FORMAT_RGB8888		1
#define	CSC_CONTROL_HORIZONTAL_FILTER			25 : 25
#define	CSC_CONTROL_HORIZONTAL_FILTER_DISABLE		0
#define	CSC_CONTROL_HORIZONTAL_FILTER_ENABLE		1
#define	CSC_CONTROL_VERTICAL_FILTER			24 : 24
#define	CSC_CONTROL_VERTICAL_FILTER_DISABLE		0
#define	CSC_CONTROL_VERTICAL_FILTER_ENABLE		1
#define	CSC_CONTROL_BYTE_ORDER				23 : 23
#define	CSC_CONTROL_BYTE_ORDER_YUYV			0
#define	CSC_CONTROL_BYTE_ORDER_UYVY			1

#define	DE_DATA_PORT_501				0x110000
#define	DE_DATA_PORT_712				0x400000
#define	DE_DATA_PORT_722				0x6000

/* point to virtual Memory Map IO starting address */
extern char *smtc_RegBaseAddress;
/* point to virtual video memory starting address */
extern char *smtc_VRAMBaseAddress;
extern unsigned char smtc_de_busy;

extern unsigned long memRead32(unsigned long nOffset);
extern void memWrite32(unsigned long nOffset, unsigned long nData);
extern unsigned long SMTC_read2Dreg(unsigned long nOffset);

/* 2D functions */
extern void deInit(unsigned int nModeWidth, unsigned int nModeHeight,
		   unsigned int bpp);

extern void deWaitForNotBusy(void);

extern void deVerticalLine(unsigned long dst_base,
	unsigned long dst_pitch,
	unsigned long nX,
	unsigned long nY,
	unsigned long dst_height,
	unsigned long nColor);

extern void deHorizontalLine(unsigned long dst_base,
	unsigned long dst_pitch,
	unsigned long nX,
	unsigned long nY,
	unsigned long dst_width,
	unsigned long nColor);

extern void deLine(unsigned long dst_base,
	unsigned long dst_pitch,
	unsigned long nX1,
	unsigned long nY1,
	unsigned long nX2,
	unsigned long nY2,
	unsigned long nColor);

extern void deFillRect(unsigned long dst_base,
	unsigned long dst_pitch,
	unsigned long dst_X,
	unsigned long dst_Y,
	unsigned long dst_width,
	unsigned long dst_height,
	unsigned long nColor);

extern void deRotatePattern(unsigned char *pattern_dstaddr,
	unsigned long pattern_src_addr,
	unsigned long pattern_BPP,
	unsigned long pattern_stride,
	int	patternX,
	int	patternY);

extern void deCopy(unsigned long dst_base,
	unsigned long dst_pitch,
	unsigned long dst_BPP,
	unsigned long dst_X,
	unsigned long dst_Y,
	unsigned long dst_width,
	unsigned long dst_height,
	unsigned long src_base,
	unsigned long src_pitch,
	unsigned long src_X,
	unsigned long src_Y,
	pTransparent	pTransp,
	unsigned char nROP2);

/*
 * System memory to Video memory monochrome expansion.
 *
 * Source is monochrome image in system memory.  This function expands the
 * monochrome data to color image in video memory.
 *
 * @pSrcbuf: pointer to start of source buffer in system memory
 * @srcDelta: Pitch value (in bytes) of the source buffer, +ive means top
 * 		down and -ive mean button up
 * @startBit: Mono data can start at any bit in a byte, this value should
 * 		be 0 to 7
 * @dBase: Address of destination :  offset in frame buffer
 * @dPitch: Pitch value of destination surface in BYTE
 * @bpp: Color depth of destination surface
 * @dx, dy: Starting coordinate of destination surface
 * @width, height: width and height of rectange in pixel value
 * @fColor,bColor: Foreground, Background color (corresponding to a 1, 0 in
 * 	the monochrome data)
 * @rop2: ROP value
 */

extern long deSystemMem2VideoMemMonoBlt(
	const char *pSrcbuf,
	long srcDelta,
	unsigned long startBit,
	unsigned long dBase,
	unsigned long dPitch,
	unsigned long bpp,
	unsigned long dx, unsigned long dy,
	unsigned long width, unsigned long height,
	unsigned long fColor,
	unsigned long bColor,
	unsigned long rop2);

extern unsigned long deGetTransparency(void);
extern void deSetPixelFormat(unsigned long bpp);