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

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

?? cfw.c

?? share-2440 wince5.0 of LCD drivers 源代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
	volatile INTreg *s2440INT	= (INTreg *)INT_BASE;
	volatile IOPreg *s2440IOP	= (IOPreg *)IOP_BASE;    

	INTERRUPTS_OFF();
	
	switch (idInt) 
	{

    case SYSINTR_DMA0:
        s2440INT->rINTMSK &= ~BIT_DMA0; // SDIO DMA interrupt
		//RETAILMSG(1,(TEXT("::: SYSINTR_DMA0    OEMInterruptDone\r\n")));
		break;

	case SYSINTR_SDMMC:
		s2440INT->rINTMSK &= ~BIT_MMC;
		//RETAILMSG(1,(TEXT("::: SYSINTR_SDMMC    OEMInterruptDone\r\n")));
		break;

	case SYSINTR_SDMMC_SDIO_INTERRUPT:
		s2440INT->rINTMSK &= ~BIT_MMC;
		//RETAILMSG(1,(TEXT("::: SYSINTR_SDMMC_SDIO_INTERRUPT    OEMInterruptDone\r\n")));
		break;

	case SYSINTR_SDMMC_CARD_DETECT:
#if SDIO_FOR_100BD		// for b'd revision 1.00
		s2440IOP->rEINTPEND  = (1<<18);
		s2440IOP->rEINTMASK &= ~(1 << 18);
		//RETAILMSG(1,(TEXT("::: SYSINTR_SDMMC_CARD_DETECT    OEMInterruptDone\r\n")));
#else					// for b'd revision 0.17
		s2440IOP->rEINTPEND  = (1<<16);
		s2440IOP->rEINTMASK &= ~(1 << 16);
#endif
		s2440INT->rINTMSK   &= ~BIT_EINT8_23;
		break;        

    case SYSINTR_TOUCH:
        /*
         * Nothing has to be done here as interrupts are masked and unmasked by the touch
         * handler in the HAL.
         */
		s2440INT->rINTMSK &= ~BIT_TIMER1;
        break;

    case SYSINTR_TOUCH_CHANGED:
        /*
         * Nothing has to be done here as interrupts are masked and unmasked by the touch
         * handler in the HAL.
         */
		s2440INT->rINTMSK &= ~BIT_ADC;
		s2440INT->rINTSUBMSK &= ~INTSUB_TC;
		//RETAILMSG(0,(TEXT("OEMInterruptDone:TOUCH CHANGED\n\r\n")));
        break;

	case SYSINTR_KEYBOARD:
		s2440INT->rINTMSK &= ~BIT_EINT1;
		break;

	case SYSINTR_SERIAL:
		s2440INT->rINTMSK    &= ~BIT_UART0;
		s2440INT->rINTSUBMSK &= ~INTSUB_RXD0;
		break;

	case SYSINTR_IR:
		s2440INT->rINTMSK    &= ~BIT_UART2;
		s2440INT->rINTSUBMSK &= ~INTSUB_RXD2;
		break;

	case SYSINTR_AUDIO:
		// DMA1 is for audio input.
		// DMA2 is for audio output.
		s2440INT->rSRCPND = (BIT_DMA1 | BIT_DMA2); 
		if (s2440INT->rINTPND & BIT_DMA1) s2440INT->rINTPND = BIT_DMA1;
		if (s2440INT->rINTPND & BIT_DMA2) s2440INT->rINTPND = BIT_DMA2;
        s2440INT->rINTMSK &= ~BIT_DMA1;
        s2440INT->rINTMSK &= ~BIT_DMA2;
		break;

	case SYSINTR_ADC:
		break;

	case SYSINTR_PCMCIA_LEVEL:
		s2440INT->rSRCPND	= BIT_EINT8_23;
		if (s2440INT->rINTPND & BIT_EINT8_23) s2440INT->rINTPND = BIT_EINT8_23; 
		s2440INT->rINTMSK   &= ~BIT_EINT8_23;
		s2440IOP->rEINTMASK &= ~(1<<8);
		//RETAILMSG(1,(TEXT("::: SYSINTR_PCMCIA_LEVEL    OEMInterruptDone\r\n")));
		break;

	case SYSINTR_PCMCIA_EDGE:
		//RETAILMSG(1,(TEXT("::: SYSINTR_PCMCIA_EDGE    OEMInterruptDone\r\n")));
		break;

	case SYSINTR_PCMCIA_STATE:
		s2440INT->rINTMSK &= ~BIT_EINT3;
		//RETAILMSG(1,(TEXT("::: SYSINTR_PCMCIA_STATE    OEMInterruptDone\r\n")));
		break;

	case SYSINTR_ETHER:
		s2440INT->rINTMSK   &= ~BIT_EINT8_23;
		s2440IOP->rEINTMASK &= ~0x200;
		//RETAILMSG(1, (TEXT("::: SYSINTR_USBD	OEMInterruptDone\r\n")));
		break;
    case SYSINTR_DM9000:		// Ethernet on EINT14.
		s2440INT->rINTMSK   &= ~BIT_EINT8_23;
		s2440IOP->rEINTMASK &= ~0x4000;
		//RETAILMSG(1, (TEXT("::: SYSINTR_DM9000 OEMInterruptDone\r\n")));
		break;
			        
	case SYSINTR_USB:
		s2440INT->rINTMSK &= ~BIT_USBH;
		break;

	case SYSINTR_USBD:
		s2440INT->rINTMSK &= ~BIT_USBD;
		//RETAILMSG(1,(TEXT("::: SYSINTR_USBD    OEMInterruptDone\r\n")));
		break;
        
	case SYSINTR_POWER:
		s2440INT->rSRCPND = BIT_EINT0;
		// S3C2440X Developer Notice (page 4) warns against writing a 1 to a 0 bit in the INTPND register.
		if (s2440INT->rINTPND & BIT_EINT0) s2440INT->rINTPND = BIT_EINT0;
		s2440INT->rINTMSK &= ~BIT_EINT0;
		s2440INT->rSRCPND = BIT_EINT2;
		// S3C2440X Developer Notice (page 4) warns against writing a 1 to a 0 bit in the INTPND register.
		if (s2440INT->rINTPND & BIT_EINT2) s2440INT->rINTPND = BIT_EINT2;
		s2440INT->rINTMSK &= ~BIT_EINT2;
		break;

	case SYSINTR_CAM:
		s2440INT->rSUBSRCPND = INTSUB_CAM_P;
		s2440INT->rSUBSRCPND = INTSUB_CAM_C;
		s2440INT->rSRCPND = BIT_CAM;

		if (s2440INT->rINTPND & BIT_CAM)
		{
			s2440INT->rINTPND = BIT_CAM;
		}
		s2440INT->rINTSUBMSK &= ~(INTSUB_CAM_P | INTSUB_CAM_C);
		s2440INT->rINTMSK &= ~BIT_CAM;
		break;

    case SYSINTR_IIC:
        s2440INT->rINTMSK &= ~BIT_IIC;
       break;

	}
    INTERRUPTS_ON();	
}


//------------------------------------------------------------------------------
//------------------------------------------------------------------------------
BOOL 
OEMGetExtensionDRAM(
    LPDWORD lpMemStart, 
    LPDWORD lpMemLen
    ) 
{
    return FALSE; // no extension DRAM
}


//------------------------------------------------------------------------------
//
//  OEMQueryPerformanceCounter
//  
//      The OEMQueryPerformanceCounter function retrieves the current value of 
//      the high-resolution performance counter, if one exists. 
//  
//  BOOL QueryPerformanceCounter(
//  
//      LARGE_INTEGER  *lpliPerformanceCount    // address of current counter value
//     );   
//  
//  Parameters
//  
//  lpliPerformanceCount
//  
//      Points to a variable that the function sets, in counts, to the current 
//      performance-counter value. If the installed hardware does not support 
//      a high-resolution performance counter, this parameter can be to zero. 
//  
//  Return Value
//  
//      If the installed hardware supports a high-resolution performance 
//      counter, the return value is TRUE.
//      If the installed hardware does not support a high-resolution 
//      performance counter, the return value is FALSE.   
//  
//  If this function is implemented by the OEM, the pointer pQueryPerformanceCounter
//  should be initialized as follows:
//  
//  BOOL (*pQueryPerformanceCounter)(LARGE_INTEGER *lpliPerformanceCount)=OEMQueryPerformanceCounter;
//
//------------------------------------------------------------------------------
BOOL 
OEMQueryPerformanceCounter(
    LARGE_INTEGER *lpliPerformanceCount
    )
{
    extern DWORD PerfCountSinceTick();
    
    ULARGE_INTEGER liBase;
    DWORD dwCurCount;

	// Make sure CurTicks is the same before and after read of counter to account for
	// possible rollover
    do {
        liBase = CurTicks;
        dwCurCount = PerfCountSinceTick();
    } while  (liBase.LowPart != CurTicks.LowPart) ;  

    lpliPerformanceCount->QuadPart = liBase.QuadPart + dwCurCount;
    
    return TRUE;
}



//------------------------------------------------------------------------------
//
//  OEMQueryPerformanceFrequency
//  
//      The OEMQueryPerformanceFrequency function retrieves the frequency of 
//      the high-resolution performance counter, if one exists. 
//  
//  BOOL OEMQueryPerformanceFrequency(
//  
//      LARGE_INTEGER  *lpliPerformanceFreq     // address of current frequency
//     );   
//  
//  Parameters
//  
//  lpliPerformanceFreq
//  
//      Points to a variable that the function sets, in counts per second, to 
//      the current performance-counter frequency. If the installed hardware 
//      does not support a high-resolution performance counter, this parameter
//      can be to zero. 
//  
//  Return Value
//  
//      If the installed hardware supports a high-resolution performance 
//      counter, the return value is TRUE.
//      If the installed hardware does not support a high-resolution 
//      performance counter, the return value is FALSE.
//  
//  If this function is implemented by the OEM, the pointer pQueryPerformanceFrequency
//  should be initialized as follows:
//  
//  BOOL (*pQueryPerformanceFrequency)(LARGE_INTEGER *lpPerformanceFrequency)=OEMQueryPerformanceFrequency;
//
//------------------------------------------------------------------------------
BOOL 
OEMQueryPerformanceFrequency(
    LARGE_INTEGER *lpliPerformanceFreq
    ) 
{
    extern DWORD PerfCountFreq();
    
    lpliPerformanceFreq->HighPart = 0;
    lpliPerformanceFreq->LowPart  = PerfCountFreq();
    return TRUE;
}

// set pointers to OEM functions
BOOL (*pQueryPerformanceCounter)(LARGE_INTEGER *lpliPerformanceCount)=OEMQueryPerformanceCounter;
BOOL (*pQueryPerformanceFrequency)(LARGE_INTEGER *lpliPerformanceFreq)=OEMQueryPerformanceFrequency;


//
// CPU-specific functions for OEMIdle
//
extern void  CPUEnterIdle(DWORD dwIdleParam);
extern DWORD CPUGetSysTimerCountMax(DWORD dwIdleMSecRequested);
extern void  CPUSetSysTimerCount(DWORD dwIdleMSec);
extern BOOL CPUClearSysTimerIRQ(void);


//
// dougfir or later
//
extern DWORD
CPUGetSysTimerCountElapsed(
    DWORD dwTimerCountdownMSec,
    volatile DWORD *pCurMSec,
    DWORD *pPartialCurMSec,
    volatile ULARGE_INTEGER *pCurTicks
    );

//------------------------------------------------------------------------------
//
//  This routine is called by the kernel when there are no threads ready to
//  run. The CPU should be put into a reduced power mode and halted. It is 
//  important to be able to resume execution quickly upon receiving an interrupt.
//  Note: It is assumed that interrupts are off when OEMIdle is called.  Interrrupts
//  are turned off when OEMIdle returns.
//
//------------------------------------------------------------------------------
static DWORD dwPartialCurMSec = 0;		// Keep CPU-specific sub-millisecond leftover.
void
OEMIdle( DWORD dwIdleParam )
{
	DWORD dwIdleMSec;
	DWORD dwPrevMSec = *pCurMSec;

	// Use for 64-bit math
	ULARGE_INTEGER currIdle = { curridlelow, curridlehigh };

	if ((int) (dwIdleMSec = dwReschedTime - dwPrevMSec) <= 0) 
	{
		return;				// already time to wakeup
	}

	// just idle till tick if profiling or running iltiming
	if (bProfileTimerRunning || fIntrTime)	// fIntrTime : Interrupt Latency timeing.
	{
		// idle till end of 'tick'
		CPUEnterIdle(dwIdleParam);

		// Update global idle time and return
		currIdle.QuadPart += RESCHED_PERIOD;
		curridlelow = currIdle.LowPart;
		curridlehigh = currIdle.HighPart;
        
		return;
	}

	//
	// Since OEMIdle( ) is being called in the middle of a normal reschedule
	// period, CurMSec, dwPartialCurMSec, and CurTicks need to be updated accordingly.
	// Once we reach this point, we must re-program the timer (if we ever did) 
	// because dwPartialCurMSec will be modified in the next function call.
	//
	CPUGetSysTimerCountElapsed(RESCHED_PERIOD, pCurMSec, &dwPartialCurMSec, pCurTicks);

	if ((int) (dwIdleMSec -= *pCurMSec - dwPrevMSec) > 0)
	{
		dwPrevMSec = *pCurMSec;

		//
		// The system timer may not be capable of arbitrary timeouts. Get the
		// CPU-specific highest possible timeout available.
		//
		dwIdleMSec = CPUGetSysTimerCountMax(dwIdleMSec);

		//
		// Set the timer to wake up much later than usual, if needed.
		//
		CPUSetSysTimerCount(dwIdleMSec);
		CPUClearSysTimerIRQ( );

		//
		// Enable wakeup on any interrupt, then go to sleep.
		//
//		DEBUGMSG(1, (TEXT("OEMIDle  \r\n")));
		CPUEnterIdle(dwIdleParam);
		INTERRUPTS_OFF( );
        
		//
		// We're awake! The wake-up ISR (or any other ISR) has already run.
		//
		if (dwPrevMSec != *pCurMSec)
		{
			//
			// We completed the full period we asked to sleep.  Update the counters.
			//
			*pCurMSec  += (dwIdleMSec - RESCHED_PERIOD); // Subtract resched period, because ISR also incremented.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲va在线va天堂| 日本亚洲欧美天堂免费| 亚洲综合久久久| 麻豆成人av在线| 成人午夜精品在线| 日本高清成人免费播放| 国产午夜精品在线观看| 亚洲综合免费观看高清完整版| 国产一区二区三区在线看麻豆| 色婷婷综合中文久久一本| 2021国产精品久久精品| 婷婷国产在线综合| 色综合久久中文字幕| 久久精品人人做| 日韩中文字幕区一区有砖一区| www.日韩精品| 精品免费日韩av| 亚洲aaa精品| 91久久精品一区二区三| 国产午夜久久久久| 免费成人av资源网| 在线免费观看不卡av| 国产精品久久久久久久久快鸭| 国内精品国产成人| 日韩欧美123| 日韩中文字幕区一区有砖一区| 欧美在线观看一区| 一区二区三区小说| 91美女精品福利| 中文字幕日韩av资源站| 国产成人免费视频网站| 久久久久久免费毛片精品| 久久超碰97中文字幕| 欧美日韩成人在线| 性感美女久久精品| 欧美无乱码久久久免费午夜一区| 中文字幕在线不卡一区二区三区| 成人在线综合网| 国产蜜臀av在线一区二区三区| 国产激情一区二区三区| 久久精品视频在线免费观看| 精品一区在线看| 欧美精品一区在线观看| 国产尤物一区二区| 久久精品日产第一区二区三区高清版 | 91福利国产成人精品照片| 国产精品麻豆视频| 91在线视频免费观看| 亚洲日本在线观看| 欧美日韩精品欧美日韩精品| 奇米综合一区二区三区精品视频| 7777精品伊人久久久大香线蕉最新版| 午夜不卡av免费| 欧美一区二区私人影院日本| 国内一区二区在线| 国产精品不卡在线| 91美女在线视频| 日韩视频在线你懂得| 91精品国产综合久久福利软件| 久久疯狂做爰流白浆xx| 久久久精品日韩欧美| 成人av免费在线| 亚洲一区视频在线| 精品粉嫩超白一线天av| 成人app网站| 亚洲自拍与偷拍| 26uuu精品一区二区三区四区在线| 国产福利电影一区二区三区| 一区二区欧美国产| 日韩视频一区二区在线观看| 成人黄色免费短视频| 亚洲电影中文字幕在线观看| 久久久精品人体av艺术| 欧美怡红院视频| 国产精品亚洲第一区在线暖暖韩国 | 91精品国产色综合久久久蜜香臀| 国产露脸91国语对白| 亚洲精品你懂的| 久久亚洲一区二区三区明星换脸 | 国产精品白丝jk黑袜喷水| 综合精品久久久| 8x8x8国产精品| 成人免费看黄yyy456| 肉丝袜脚交视频一区二区| 国产日本欧美一区二区| 51精品国自产在线| 懂色中文一区二区在线播放| 日本不卡免费在线视频| 日韩理论电影院| 2023国产精品自拍| 在线国产电影不卡| 成人激情小说网站| 久草中文综合在线| 亚洲成av人片一区二区三区| 国产精品久久久久三级| 精品三级av在线| 欧美日韩久久不卡| 色婷婷av一区二区三区软件| 国产精品影视在线| 日本三级亚洲精品| 亚洲一区二区视频| 自拍偷拍亚洲欧美日韩| 国产亚洲一区二区三区| 欧美成人国产一区二区| 欧美电影影音先锋| 欧美日韩一区视频| 欧美优质美女网站| 欧洲精品在线观看| 色婷婷综合五月| 91黄色免费版| 色八戒一区二区三区| 99国产精品久| 99天天综合性| 91亚洲男人天堂| 99久久婷婷国产综合精品电影| 成人高清免费观看| 成人国产精品免费网站| 成人高清免费在线播放| 99re8在线精品视频免费播放| 岛国一区二区三区| av欧美精品.com| 久久精品视频免费观看| 久久久噜噜噜久久中文字幕色伊伊| 日韩视频免费直播| 久久亚区不卡日本| 国产精品久久久久精k8| 亚洲欧美日本在线| 亚洲综合av网| 蜜臀久久久99精品久久久久久| 日韩国产一区二| 麻豆成人av在线| 国产麻豆日韩欧美久久| 成人看片黄a免费看在线| 一本久久a久久免费精品不卡| 色婷婷激情一区二区三区| 欧美日韩aaa| 久久精品亚洲乱码伦伦中文| 最新热久久免费视频| 亚洲成av人片| 国模少妇一区二区三区| 成人黄色av网站在线| 色视频一区二区| 在线电影国产精品| 久久夜色精品一区| 亚洲九九爱视频| 蜜桃精品视频在线| 国产成人av电影在线播放| 91免费在线播放| 欧美一区二区在线不卡| 中文字幕国产一区二区| 伊人夜夜躁av伊人久久| 麻豆精品一区二区综合av| 国产91综合一区在线观看| 欧美在线短视频| 久久久久久久久久久久电影| 亚洲免费观看高清| 九色综合国产一区二区三区| 91视频www| 精品久久久久久久久久久久久久久 | 国产乱码精品1区2区3区| 91久久人澡人人添人人爽欧美| 欧美电影免费观看高清完整版在线观看 | 成人欧美一区二区三区白人 | 一区二区国产视频| 蜜臀久久久99精品久久久久久| 91在线播放网址| 久久久久久久电影| 日韩精品国产精品| 99久久精品免费看国产| 精品久久久久久久一区二区蜜臀| 一区二区三区四区在线播放 | 国内精品在线播放| 在线免费观看日本欧美| 国产免费久久精品| 久久精品国产在热久久| 欧美亚洲动漫另类| 中文字幕亚洲一区二区av在线| 美女任你摸久久| 日本久久一区二区三区| 国产欧美精品一区二区三区四区 | 欧美成人在线直播| 亚洲电影在线免费观看| 色综合av在线| 国产精品久久久久久久蜜臀| 久久激情五月婷婷| 91麻豆精品91久久久久久清纯 | 在线视频一区二区三| 中文字幕国产一区二区| 国产寡妇亲子伦一区二区| 精品奇米国产一区二区三区| 日韩中文字幕不卡| 欧美日韩一区二区三区在线| 一区二区三区不卡视频| 色屁屁一区二区| 一区二区三区中文字幕| 91亚洲精品一区二区乱码| 日韩一区在线看| 91在线视频播放| 亚洲免费在线电影| 在线观看日韩电影|