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

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

?? cmdlist.cpp

?? Sm501 VGA芯片wince下驅動代碼
?? CPP
字號:
#include "precomp.h"

#ifdef CMDLIST

DWORD *cmd_ptr;
DWORD *g_cmd_start_buf;
DWORD last_stop_address;
DWORD *last_finish_ptr;
DWORD physical_frame_number[4];

ULONG			g_CmdBuffer_offset;    		// Cmd List buffer offset 
ULONG			g_CmdBuffer_start_address;  // Cmd List buffer start address 
ULONG			g_CmdBuffer_end_address;    // Cmd List buffer end address
ULONG			g_CmdBuffer_base[4];        // Cmd List buffer base. dummy Cmd List buffer base for DMA write back is 128-bit (4 dword)
ULONG			g_CmdBuffer_base_phys;      // Cmd List buffer base physcial address
SYSTEM_INFO     g_SysInfo;
DWORD           g_pagesize;
DWORD           g_dwFlush; //dummy read to flush CMD to video memory
DWORD           g_dwVGXstatus;
DWORD           g_flush_read1, g_flush_read2;
DWORD           g_bXscaleNormalMode=TRUE;
#if TRACE_CMD
DWORD dwCount=0;
#endif

extern PUCHAR   g_pREG; 

void SMI::SetupCmdListBuffer(void)
{
	ULONG value=0;
#if CMDLIST_IN_SYS_MEM
    POKE_32(PCI_MASTER_BASE,  
        FIELD_INIT_VAL(PCI_MASTER_BASE, ADDRESS, 0)
        );
    
    POKE_32(SYSTEM_CTRL,  
        FIELD_INIT(SYSTEM_CTRL, PCI_MASTER, START ) 
        );
#if CMDLIST_CEPC //{
#else //}{
    if (g_bXscaleNormalMode)
    {
        value = peekRegisterDWord(MISC_CTRL);
        POKE_32(MISC_CTRL,  value |
            FIELD_INIT(MISC_CTRL, BURST_LENGTH, 1 ) 
            );
        
        value = peekRegisterDWord(DRAM_CTRL);
        value &= 0xFFFF;
        value |= 
            FIELD_INIT(DRAM_CTRL, CPU_BURST, 4 ) |
            FIELD_INIT(DRAM_CTRL, CPU_CAS_LATENCY, 2) |
            FIELD_INIT(DRAM_CTRL, CPU_SIZE, 64) |
            FIELD_INIT(DRAM_CTRL, CPU_COLUMN_SIZE, 512) |
            FIELD_INIT(DRAM_CTRL, CPU_ACTIVE_PRECHARGE, 7) |
            FIELD_INIT(DRAM_CTRL, CPU_RESET, DISABLE) |
            FIELD_INIT(DRAM_CTRL, CPU_BANKS, 4);
            

        pokeRegisterDWord(DRAM_CTRL, value); //value = 24B827C0 ;//0x2CB827C0; 
    }
#endif //}
    POKE_32(POWER_MODE0_CLOCK,
        FIELD_INIT(POWER_MODE0_CLOCK, P2XCLK_SELECT, 288 ) |
        FIELD_INIT(POWER_MODE0_CLOCK, P2XCLK_DIVIDER, 1) |
        FIELD_INIT(POWER_MODE0_CLOCK, P2XCLK_SHIFT, 2) |
        FIELD_INIT(POWER_MODE0_CLOCK, V2XCLK_SELECT, 288) |
        FIELD_INIT(POWER_MODE0_CLOCK, V2XCLK_DIVIDER, 1) |
        FIELD_INIT(POWER_MODE0_CLOCK, V2XCLK_SHIFT, 2) |
        FIELD_INIT(POWER_MODE0_CLOCK, MCLK_SELECT, 288) |
        FIELD_INIT(POWER_MODE0_CLOCK, MCLK_DIVIDER, 1) |
        FIELD_INIT(POWER_MODE0_CLOCK, MCLK_SHIFT, 2) |
        FIELD_INIT(POWER_MODE0_CLOCK, M2XCLK_SELECT, 288) |
        FIELD_INIT(POWER_MODE0_CLOCK, M2XCLK_DIVIDER, 1) |
        FIELD_INIT(POWER_MODE0_CLOCK, M2XCLK_SHIFT, 1)
        );  //0x02020201, PCI Bus master only works on Engine clock 72MHz on RevAA.


	g_CmdBuffer_start_address = (DWORD)VirtualAlloc(0, m_cmdlist_size, MEM_RESERVE, PAGE_NOACCESS);

    VirtualCopy((void *)g_CmdBuffer_start_address, (void *)m_cmdlist_address, m_cmdlist_size, PAGE_READWRITE | PAGE_NOCACHE);

    g_CmdBuffer_offset = m_cmdlist_address - m_sdrambase;
#else
    g_CmdBuffer_offset = m_nVideoMemoryAvail + CURSUR_IMAGE_SIZE;
    g_CmdBuffer_start_address = (ULONG)m_pLAW + g_CmdBuffer_offset; //Cmd list buffer is located after cursor image
#endif
    g_CmdBuffer_end_address = g_CmdBuffer_start_address + m_cmdlist_size-2*CMD_STRIDE_BYTE; //Cmd list buffer is located after cursor image, reserved space for GOTO (wrap around)
	cmd_ptr = (DWORD *)g_CmdBuffer_start_address; //set up command list buffer in video memory at this time.
    g_cmd_start_buf = cmd_ptr +m_cmdlist_size/2/4; //debug start address
    g_CmdBuffer_base[0] = 0;

#if CMDLIST_WRITEBACK
	GetSystemInfo(&g_SysInfo); 

	g_pagesize= g_SysInfo.dwPageSize;

	if (LockPages( g_CmdBuffer_base, 1024*8, physical_frame_number, LOCKFLAG_READ))
		g_CmdBuffer_base_phys = physical_frame_number[0] | ((ULONG)g_CmdBuffer_base & (g_pagesize-1));

	//LPVOID AllocPhysMem(DWORD cbSize, DWORD fdwProtect, DWORD dwAlignmentMask, DWORD dwFlags,PULONG pPhysicalAddress);
#endif
    memset(cmd_ptr, 0x80000080, m_cmdlist_size); //init to finish cmd

    //Init start CI
    POKE_32(CMD_INTPR_CONDITIONS, FIELD_INIT(CMD_INTPR_CONDITIONS, CMDPTR, NOWRAP)); //Clear ptr wrap flag
    INSERTCMD_FINISH(cmd_ptr, 0);
    last_finish_ptr = cmd_ptr - CMD_STRIDE_DWORD;
#if CMDLIST_IN_SYS_MEM
    POKE_32(CMD_INTPR_CTRL, 
        FIELD_INIT(CMD_INTPR_CTRL, STATUS, RUNNING ) | 
        FIELD_INIT(CMD_INTPR_CTRL, EXT, EXTERNAL) |
        g_CmdBuffer_offset);
#else
    POKE_32(CMD_INTPR_CTRL, FIELD_INIT(CMD_INTPR_CTRL, STATUS, RUNNING ) | g_CmdBuffer_offset);
#endif
    while (FIELD_GET(PEEK_32(CMD_INTPR_CTRL), CMD_INTPR_CTRL, STATUS) == CMD_INTPR_CTRL_STATUS_RUNNING);
}

#if 0
void  VALIDATE_SLOT(DWORD *cmdptr, DWORD req_dword)   
{ 
    while ((ULONG)cmdptr - g_CmdBuffer_start_address + req_dword*sizeof(DWORD) 
                  + FIELD_GET(PEEK_32(CMD_INTPR_CONDITIONS),CMD_INTPR_CONDITIONS,CMDPTR)*m_cmdlist_size 
                  >=  
                  FIELD_GET(PEEK_32(CMD_INTPR_CTRL), CMD_INTPR_CTRL, ADDRESS)-CMD_STRIDE_BYTE + m_cmdlist_size);   
    if ((ULONG)cmdptr + req_dword*sizeof(DWORD) > g_CmdBuffer_end_address) 
    { 
        POKE_32(CMD_INTPR_CONDITIONS, FIELD_INIT(CMD_INTPR_CONDITIONS, CMDPTR, WRAP)); 
        INSERTCMD_GOTO(cmdptr, g_CmdBuffer_offset, 0); /*jump to start of CMD list buffer*/ 
        cmdptr=(DWORD *)g_CmdBuffer_start_address; 
        while ( (req_dword+1)*sizeof(DWORD) >=  /*wait for requested free slots */
                  FIELD_GET(PEEK_32(CMD_INTPR_CTRL), CMD_INTPR_CTRL, ADDRESS)-CMD_STRIDE_BYTE );   
        INSERTCMD_LOADREG_D(cmd_ptr, REG(CMD_INTPR_CONDITIONS),  FIELD_INIT(CMD_INTPR_CONDITIONS, CMDPTR, NOWRAP)); /* clear ptr wrap  flag*/ 
    } 
}
#endif

#if CMDLIST_IN_SYS_MEM
#if CMDLIST_CEPC
void FLUSH_CMD()
{ 	_asm
	{
		push  edi
		push  esi
		push  eax

		mov      esi,  last_finish_ptr
		xor      eax,  eax
		lock  or  [esi],  eax		;// flush the begin

		add      esi,  4
		lock  or  [esi],  eax		;// flush the end part

		pop      eax
		pop      esi
		pop      edi
	}
}
#endif //CMDLIST_CEPC
#endif //CMDLIST_IN_SYS_MEM
#else //CMDLIST

/* ----------------------------------------
    Do nothing if not CMDLIST driver
   ---------------------------------------- */

#endif //CMDLIST

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲另类春色校园小说| 欧美大尺度电影在线| 欧美性大战久久久| 欧美撒尿777hd撒尿| 日韩欧美国产一区二区在线播放| 久久精品亚洲精品国产欧美| 亚洲免费三区一区二区| 亚洲v中文字幕| 国产成人一区在线| 欧美日韩一区二区三区四区五区 | 亚洲毛片av在线| 日韩精品1区2区3区| 国产精品77777| 在线中文字幕一区| 欧美成人bangbros| 亚洲欧美激情小说另类| 六月丁香综合在线视频| 91在线精品一区二区| 欧美精品一二三| 国产日韩欧美综合一区| 亚洲精品欧美综合四区| 日本亚洲欧美天堂免费| 国产福利一区在线| 色婷婷久久综合| 91精品国产免费久久综合| 国产性色一区二区| 樱花草国产18久久久久| 免费成人av资源网| 菠萝蜜视频在线观看一区| 欧美男人的天堂一二区| 国产亚洲精品超碰| 亚洲韩国一区二区三区| 久久99国产精品久久99| 99视频在线精品| 91精品国产福利| 欧美一级午夜免费电影| 精品福利av导航| 亚洲欧美一区二区在线观看| 免费看欧美女人艹b| 成人av资源下载| 欧美一级xxx| 亚洲欧美另类久久久精品2019| 日本vs亚洲vs韩国一区三区二区 | 欧美羞羞免费网站| 久久久久久久国产精品影院| 亚洲成a人片综合在线| 高清不卡在线观看| 欧美色图第一页| 中文字幕免费在线观看视频一区| 亚洲成人福利片| 成人性生交大片免费看在线播放 | 亚洲一区免费在线观看| 国产乱码精品一区二区三区忘忧草| 色狠狠色狠狠综合| 亚洲国产精品激情在线观看 | 欧美三级日韩三级国产三级| 日本一区二区三区在线不卡| 蜜臀a∨国产成人精品| 99精品一区二区| 久久综合色之久久综合| 五月婷婷综合激情| www.亚洲人| 26uuu色噜噜精品一区| 日日夜夜精品视频免费| 成人动漫中文字幕| 久久久天堂av| 久久精品久久久精品美女| 欧美三日本三级三级在线播放| 国产精品久久久久久久久久久免费看| 九九热在线视频观看这里只有精品| 欧美性极品少妇| 亚洲日本va在线观看| 成人av电影在线观看| 久久综合九色综合久久久精品综合| 五月婷婷欧美视频| 欧美综合在线视频| 一区二区欧美国产| 91蜜桃免费观看视频| 国产精品美女视频| 国产大陆精品国产| 久久久久久电影| 国产精品69毛片高清亚洲| 久久一区二区视频| 精品在线观看视频| 欧美成人福利视频| 狠狠色丁香久久婷婷综| 日韩精品中文字幕一区二区三区 | 首页综合国产亚洲丝袜| 欧美日韩一卡二卡三卡| 亚洲h精品动漫在线观看| 欧洲日韩一区二区三区| 亚洲精品欧美综合四区| 欧美亚洲国产一区二区三区| 亚洲妇女屁股眼交7| 欧美日韩国产一二三| 亚洲电影在线播放| 欧美三区在线观看| 亚洲一区二区在线观看视频 | 国产欧美视频在线观看| 激情另类小说区图片区视频区| 精品捆绑美女sm三区| 久久精品国产99| 26uuu色噜噜精品一区| 国产福利不卡视频| 国产精品久久影院| 在线免费精品视频| 亚洲bt欧美bt精品| 欧美成人a视频| 久久91精品国产91久久小草| 亚洲精品在线三区| 色哟哟国产精品| 图片区日韩欧美亚洲| 精品日韩在线观看| 国产精品99久| 亚洲男同性恋视频| 91麻豆精品国产自产在线| 美美哒免费高清在线观看视频一区二区| 欧美成人精品高清在线播放| 国产精品中文有码| 日韩久久一区二区| 欧美精品在线一区二区三区| 久久69国产一区二区蜜臀| 欧美激情一区二区在线| 色一情一乱一乱一91av| 五月天网站亚洲| ww亚洲ww在线观看国产| 成人午夜视频免费看| 亚洲一区在线免费观看| 欧美变态tickling挠脚心| 成人福利视频在线| 亚洲bdsm女犯bdsm网站| 久久久久久日产精品| 色天使色偷偷av一区二区| 青青草伊人久久| 日本一二三四高清不卡| 在线一区二区观看| 日本不卡免费在线视频| 国产亚洲美州欧州综合国| 日本福利一区二区| 精品一区二区在线免费观看| 综合久久综合久久| 日韩视频一区二区三区在线播放| 国产激情偷乱视频一区二区三区| 一区二区三区美女视频| 久久新电视剧免费观看| 色94色欧美sute亚洲线路一久| 久久精品99国产精品日本| 亚洲婷婷国产精品电影人久久| 91麻豆精品久久久久蜜臀| www.久久久久久久久| 男女激情视频一区| 亚洲精品国产视频| 国产视频亚洲色图| 日韩午夜av电影| 欧美性猛交xxxx乱大交退制版| 国产精品一区二区在线看| 亚洲成人动漫av| 国产精品第13页| 久久网这里都是精品| 欧美美女喷水视频| 91免费小视频| 免费观看久久久4p| 亚洲精品国产精品乱码不99| 精品成人在线观看| 欧美日韩一区在线观看| 99久久99久久精品免费观看 | 在线播放日韩导航| zzijzzij亚洲日本少妇熟睡| 国产在线不卡一区| 午夜一区二区三区视频| 亚洲图片另类小说| 国产欧美一区二区在线观看| 日韩欧美你懂的| 欧美日本乱大交xxxxx| 91老司机福利 在线| 国产黄色成人av| 美女精品一区二区| 午夜视频一区二区| 亚洲一区二区美女| 亚洲精品视频免费看| 欧美国产欧美综合| 日韩一区二区三区观看| 色婷婷综合久久久久中文一区二区 | 欧美日韩一区二区三区高清 | 欧美理论在线播放| 99精品一区二区| 国产jizzjizz一区二区| 国产乱人伦偷精品视频免下载| 免费观看日韩av| 日韩精品一二三四| 亚洲电影欧美电影有声小说| 一区二区在线观看不卡| 亚洲视频一区在线| 亚洲人成影院在线观看| 亚洲欧美另类小说视频| 亚洲天堂中文字幕| 中文天堂在线一区| 国产欧美日韩精品a在线观看| 久久人人爽人人爽| 久久久久久9999|