亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gfx_drawcontrol.c.svn-base

?? sigmadesign smp8623 gui source code ,bingo
?? SVN-BASE
?? 第 1 頁 / 共 5 頁
字號:
/* * * Copyright (c) Sigma Designs, Inc. 2004. All rights reserved. * *//** @file gfx_drawlib.c @brief  Some drawing routines using the graphics accelerator @author Raul Chirinos */#define ALLOW_OS_CODE#include "../include/gfx_drawcontrol.h"#include <sys/time.h>#include <time.h>#include <stdlib.h>#if 0#define GFXDBG ENABLE#else#define GFXDBG DISABLE#endif#define TIMEOUT_US 1000000			// 1 sec#define MAX_DRAWING_BUFFER_PARTS 2		// cannot be 0 !!!#define PICTURE_DISPLAY_OFFSET	5// from gfx_drawlib.cextern GFXLib_data gdata;// localRMbitmapdata g_bitmaps[MAX_BITMAPS]; // to keep loaded bitmap(s) data (including fonts) -- background page at item 0static RMbool g_useCodePageConversion;static RMuint8 g_bitmapBufferIndex = 0;static RMuint8 g_last_palbpp = 0; // last palette set bppstatic RMuint8 g_textBufferIndex = 0;static struct GFXEngine_Palette_4BPP_type g_lastpal; // to compare some pal colors before setting new palette if same bppstatic RMcriticalsection blt_cs;static RMuint8 step_accell = 4, accell_step = 2;LIST_HEAD(listhead, task) tasks;typedef struct task{	RMascii* file;	LIST_ENTRY(task) entries;} task;static RMthread g_preload = NULL;RMcriticalsection g_cs_media;RMcriticalsection g_cs;RMcriticalsection g_cstasks;RMbool end;RMstatus err;#define RuaSetProp(pRUA, moduleID, propertyID, pValue, ValueSize)						\	 err = RUASetProperty(pRUA, moduleID, propertyID, pValue, ValueSize, 0);		\														\	if (err != RM_OK) { 											\		RMDBGLOG((ENABLE, "Cannot set Property %d on module %d, %d\n", propertyID, moduleID, err));	\	        return err;                                                                                     \	}extern RMstatus gfxDrawHLine(struct RUA *pRua, RMuint16 x, RMuint16 y, RMuint16 length, RMuint16 thickness, RMuint32 color);void* PreloadThreadEntry(void *p);void* PreloadThreadEntry(void *p){	struct timespec time;	task* tp;	time.tv_sec = (RMuint32) 0;	time.tv_nsec = ((RMuint32) 20000000);	while (end)	{		if (tasks.lh_first)		{			RMuint8 bmpindex;			RMEnterCriticalSection(g_cstasks);			{				tp = tasks.lh_first;				LIST_REMOVE(&tasks, tp, entries);			}			RMLeaveCriticalSection(g_cstasks);			nanosleep(&time, NULL);			GetBitmapIndex(NULL, tp->file, &bmpindex, TRUE);			RFREE(tp);			tp = NULL;		}		else		{			nanosleep(&time, NULL);		}	}	return NULL;}static void AddTask(RMascii* file){	task* tp;	if (file)	{		tp = (task*) MALLOC(sizeof(task));		tp->file = file;		RMEnterCriticalSection(g_cstasks);		{			LIST_INSERT_HEAD(&tasks, tp, entries);		}		RMLeaveCriticalSection(g_cstasks);	}}RMstatus BitBlt(struct RUA *pRua){	struct GFXEngine_MoveReplaceRectangle_type replace_param;	RMEnterCriticalSection(blt_cs);	SetInputSurface(pRua, EMhwlibColorMode_TrueColor, gdata.backBuffer.baseAddr, gdata.osdWidth, GFX_SURFACE_ID_Y);	SetOutputSurface(pRua);	replace_param.SrcX = 0;	replace_param.SrcY = 0;	replace_param.DstX = 0;	replace_param.DstY = 0;	replace_param.Width = gdata.osdWidth;	replace_param.Height = gdata.osdHeight;	replace_param.AlphaX = 0;	replace_param.AlphaY = 0;	replace_param.Merge = FALSE;	while ((err = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_MoveRectangle, &replace_param, sizeof(replace_param), 0))			== RM_PENDING)		;	if (RMFAILED(err))		RMDBGLOG((ENABLE, "Error sending command move\n"));	RMLeaveCriticalSection(blt_cs);	//SetOutputSurfaceBuffer(pRua, gdata.backBuffer.baseAddr, gdata.osdWidth);	return err;}void InitPrefetch(){	LIST_INIT(&tasks);	end = TRUE;	g_cs = RMCreateCriticalSection();	g_cstasks = RMCreateCriticalSection();	g_cs_media = RMCreateCriticalSection();	g_preload = RMCreateThread("PreloadThread", PreloadThreadEntry, NULL);	blt_cs = RMCreateCriticalSection();}void ClosePrefetch(){	task* tp = NULL;	if (g_preload)	{		end = FALSE;		RMWaitForThreadToFinish(g_preload);		g_preload = NULL;	}	RMDeleteCriticalSection(g_cs);	RMDeleteCriticalSection(g_cstasks);	RMDeleteCriticalSection(g_cs_media);	while (tasks.lh_first)	{		tp = tasks.lh_first;		LIST_REMOVE(&tasks, tp, entries);		RFREE(tp);		tp = NULL;	}	RMDeleteCriticalSection(blt_cs);}static inline RMstatus GFXColorFormatProperty(struct RUA *pRua, struct GFXEngine_ColorFormat_type *format_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_ColorFormat, format_param,			sizeof(struct GFXEngine_ColorFormat_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)			RMDBGLOG((GFXDBG, "gfxColorFormat: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		goto tryagain;	}	return status;}static inline RMstatus GFX1BPPPaletteProperty(struct RUA *pRua, struct GFXEngine_Palette_1BPP_type *palette_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_Palette_1BPP, palette_param,			sizeof(struct GFXEngine_Palette_1BPP_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)			RMDBGLOG((GFXDBG, "gfx1bppPalette: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		goto tryagain;	}	return status;}static inline RMstatus GFX2BPPPaletteProperty(struct RUA *pRua, struct GFXEngine_Palette_2BPP_type *palette_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_Palette_2BPP, palette_param,			sizeof(struct GFXEngine_Palette_2BPP_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)			RMDBGLOG((GFXDBG, "gfx2bppPalette: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		goto tryagain;	}	return status;}static inline RMstatus GFX4BPPPaletteProperty(struct RUA *pRua, struct GFXEngine_Palette_4BPP_type *palette_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_Palette_4BPP, palette_param,			sizeof(struct GFXEngine_Palette_4BPP_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)			RMDBGLOG((GFXDBG, "gfx4bppPalette: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		goto tryagain;	}	return status;}static inline RMstatus GFX8BPPPaletteProperty(struct RUA *pRua, struct GFXEngine_Palette_8BPP_type *palette_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_Palette_8BPP, palette_param,			sizeof(struct GFXEngine_Palette_8BPP_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)			RMDBGLOG((GFXDBG, "gfx8bppPalette: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		goto tryagain;	}	return status;}static inline RMstatus GFXSurfaceProperty(struct RUA *pRua, struct GFXEngine_Surface_type *surface_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_Surface, surface_param,			sizeof(struct GFXEngine_Surface_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)			RMDBGLOG((GFXDBG, "gfxSurface: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		goto tryagain;	}	return status;}static inline RMstatus GFXFillRectangleProperty(struct RUA *pRua, struct GFXEngine_FillRectangle_type *fill_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_FillRectangle, fill_param,			sizeof(struct GFXEngine_FillRectangle_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)		{			RMDBGLOG((GFXDBG, "gfxFill: FAILED WAITING FOR 1 second... TIMING ISSUE?"));		}		goto tryagain;	}	return status;}static inline RMstatus GFXMoveRectangleProperty(struct RUA *pRua, struct GFXEngine_MoveReplaceRectangle_type *move_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_MoveRectangle, move_param,			sizeof(struct GFXEngine_MoveReplaceRectangle_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)		{			RMDBGLOG((GFXDBG, "gfxReplace: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		}		goto tryagain;	}	return status;}static inline RMstatus GFXReplaceRectangleProperty(struct RUA *pRua, struct GFXEngine_MoveReplaceRectangle_type *move_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_ReplaceRectangle, move_param,			sizeof(struct GFXEngine_MoveReplaceRectangle_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)		{			RMDBGLOG((GFXDBG, "gfxReplace: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		}		goto tryagain;	}	return status;}static inline RMstatus GFXReplaceAndScaleRectangleProperty(struct RUA *pRua,		struct GFXEngine_MoveReplaceScaleRectangle_type *move_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_ReplaceAndScaleRectangle, move_param,			sizeof(struct GFXEngine_MoveReplaceScaleRectangle_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)		{			RMDBGLOG((GFXDBG, "gfxReplaceAndScale: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		}		goto tryagain;	}	return status;}static inline RMstatus GFXMoveAndScaleRectangleProperty(struct RUA *pRua, struct GFXEngine_MoveReplaceScaleRectangle_type *move_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_MoveAndScaleRectangle, move_param,			sizeof(struct GFXEngine_MoveReplaceScaleRectangle_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)		{			RMDBGLOG((GFXDBG, "gfxMoveAndScale: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		}		goto tryagain;	}	return status;}static inline RMstatus GFXBlendRectanglesProperty(struct RUA *pRua, struct GFXEngine_BlendRectangles_type *blend_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_BlendRectangles, blend_param,			sizeof(struct GFXEngine_BlendRectangles_type), 0);	if (status == RM_PENDING && trycount--)	{		evt.ModuleID = gdata.gfx;		evt.Mask = RUAEVENT_COMMANDCOMPLETION;		if (RUAWaitForMultipleEvents(pRua, &evt, 1, TIMEOUT_US, NULL) != RM_OK)		{			RMDBGLOG((GFXDBG, "gfxBlend: FAILED WAITING FOR 1 second... TIMING ISSUE?\n"));		}		goto tryagain;	}	return status;}static inline RMstatus GFXBlendAndScaleRectanglesProperty(struct RUA *pRua, struct GFXEngine_BlendAndScaleRectangles_type *blend_param){	RMstatus status;	struct RUAEvent evt;	RMuint8 trycount;	trycount = 2; // try command only a couple of times then jump out	tryagain: status = RUASetProperty(pRua, gdata.gfx, RMGFXEnginePropertyID_BlendAndScaleRectangles, blend_param,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线免费观看亚洲| 国产成人在线网站| 亚洲欧洲国产专区| 国产精品久久久久久亚洲毛片| 精品国产伦一区二区三区免费 | 一区二区三区产品免费精品久久75| wwww国产精品欧美| 亚洲国产精品高清| 亚洲伦理在线免费看| 中文字幕亚洲一区二区av在线| 国产精品久久久久久久蜜臀| 日韩毛片在线免费观看| 亚洲综合一区在线| 香蕉成人伊视频在线观看| 日韩精品91亚洲二区在线观看 | 久久婷婷色综合| 国产丝袜美腿一区二区三区| 国产精品视频一二三区| 亚洲人成网站在线| 亚洲成人黄色影院| 国产呦萝稀缺另类资源| av亚洲产国偷v产偷v自拍| 色狠狠桃花综合| 欧美一区二区三区白人| 国产亚洲欧洲一区高清在线观看| 亚洲欧美日韩中文播放| 亚洲丶国产丶欧美一区二区三区| 免费在线观看成人| 成人综合婷婷国产精品久久免费| 色婷婷精品大在线视频| 正在播放一区二区| 国产欧美精品在线观看| 亚洲精品免费一二三区| 裸体一区二区三区| 91社区在线播放| 26uuu亚洲综合色欧美 | 韩国精品在线观看| 91久久国产综合久久| 亚洲精品在线一区二区| 一区二区三区精密机械公司| 国产在线视频一区二区| 日韩一级完整毛片| 亚洲日穴在线视频| 黑人精品欧美一区二区蜜桃| 在线精品视频一区二区| 久久久国际精品| 免费观看日韩电影| 色成年激情久久综合| 国产精品污网站| 久久精品噜噜噜成人88aⅴ| 日本韩国精品一区二区在线观看| 日韩欧美在线一区二区三区| 亚洲影院免费观看| 91视视频在线直接观看在线看网页在线看| 91精品国产综合久久香蕉的特点 | 国产福利精品导航| 日韩精品中文字幕在线一区| 亚洲成人在线观看视频| 91免费小视频| 亚洲欧美日韩国产综合| 成人激情av网| 欧美极品少妇xxxxⅹ高跟鞋| 精品一二三四区| 欧美一区二区三区四区视频| 韩国欧美国产1区| 欧美日韩国产欧美日美国产精品| 亚洲色图欧美激情| 99久久免费国产| 欧美激情一区二区三区蜜桃视频| 激情综合网av| 久久在线免费观看| 久久99精品国产91久久来源| 91麻豆精品国产91久久久久久久久 | 精品一区二区三区久久| 日韩欧美在线1卡| 日韩电影在线观看网站| 欧美肥妇bbw| 美女国产一区二区| 精品国产乱码久久久久久牛牛 | 日韩午夜中文字幕| 日韩av二区在线播放| 日韩精品一区二区在线观看| 精品一区二区在线视频| 久久久亚洲高清| 成人免费视频视频在线观看免费| 国产精品灌醉下药二区| 一本大道久久a久久精品综合| 亚洲精品国产高清久久伦理二区| 在线亚洲人成电影网站色www| 一区二区三区自拍| 欧美午夜精品一区| 久久99热99| 国产精品久久777777| 色视频欧美一区二区三区| 午夜日韩在线电影| 久久久www免费人成精品| 欧美日韩精品是欧美日韩精品| 亚洲成人一区二区| 2023国产精华国产精品| 成人高清av在线| 亚洲午夜私人影院| 久久久亚洲精品一区二区三区| 91女神在线视频| 蜜臂av日日欢夜夜爽一区| 国产亚洲精品免费| 欧美日韩一区久久| 国产麻豆精品在线| 亚洲二区视频在线| 国产精品色哟哟| 欧美日本视频在线| 成人动漫一区二区三区| 日韩精品电影一区亚洲| 日本一区二区成人| 日韩亚洲欧美高清| 欧洲视频一区二区| 国产经典欧美精品| 青青草伊人久久| 亚洲黄色小视频| 久久女同精品一区二区| 4438x亚洲最大成人网| av在线播放不卡| 另类小说综合欧美亚洲| 亚洲一区二区四区蜜桃| 欧美激情一区二区三区蜜桃视频| 欧美丰满一区二区免费视频| 91视频在线观看免费| 国产精品99久久久久久似苏梦涵 | 精品一区二区影视| 亚洲国产精品麻豆| 亚洲人成在线播放网站岛国| 国产日韩欧美在线一区| 精品剧情在线观看| 91精品国产综合久久久久久| 欧美影视一区二区三区| 99精品热视频| 国产91在线观看| 国产精品一区二区三区99| 日本美女一区二区三区视频| 一片黄亚洲嫩模| 一区二区三区国产精华| 亚洲人成7777| 亚洲欧美偷拍另类a∨色屁股| 国产欧美一区二区精品婷婷| 欧美精品一区二区三区四区| 日韩欧美亚洲国产另类| 这里只有精品电影| 日韩一级大片在线观看| 91精品国产高清一区二区三区| 欧美视频一区二区三区四区| 欧美天堂亚洲电影院在线播放| 日本丶国产丶欧美色综合| 97精品国产露脸对白| 99国产精品一区| 成人午夜在线免费| 99re成人在线| 欧美专区日韩专区| 欧美日韩另类国产亚洲欧美一级| 欧美中文字幕不卡| 欧美一区二区黄| 精品国产乱码久久| 国产欧美日本一区二区三区| 国产精品午夜在线| 亚洲一区免费在线观看| 日本在线不卡一区| 韩国精品免费视频| 99久久er热在这里只有精品15| 色婷婷狠狠综合| 91精品一区二区三区久久久久久 | 国产精品一区二区久久精品爱涩 | 欧美一区二区三区日韩视频| 4438亚洲最大| 久久精品亚洲一区二区三区浴池| 国产精品系列在线| 亚洲成人高清在线| 国产麻豆视频一区| 91国产免费看| 日韩精品一区二区三区四区| 久久精品在线免费观看| 亚洲精品国产无天堂网2021| 日本在线播放一区二区三区| 国产伦精品一区二区三区在线观看 | 欧美一卡二卡三卡| 欧美国产1区2区| 日韩专区中文字幕一区二区| 国产精一品亚洲二区在线视频| 99久久久国产精品免费蜜臀| 欧美日韩激情在线| 国产日产欧产精品推荐色| 亚洲成人一二三| av一区二区三区黑人| 欧美一级爆毛片| 亚洲女子a中天字幕| 久久精品久久精品| 在线亚洲高清视频| 欧美激情一区二区三区四区| 日韩影院精彩在线| 色综合久久久久网| 亚洲国产岛国毛片在线| 日韩一区精品字幕| 一本久道久久综合中文字幕|