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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? armint.c

?? smdk2440的bsp
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
Copyright (c) 2001. Samsung Electronics, co. ltd  All rights reserved.

Module Name:  

Abstract:

	ARM920(S3C2440) interrupt service routine

rev:
	2002.4.3	: first S3C2410 version (SOC)	

	2002.2.5	: system tick modification (kwangyoon LEE, kwangyoon@samsung.com)	
					- one shot timer
	2002.1.29	: bug fixups (kwangyoon LEE, kwangyoon@samsung.com)	
					- system tick interrupt
	2002.1.28	: CE.NET port (kwangyoon LEE, kwangyoon@samsung.com)
	2002.1.22	: Add USBD interrupt (kwangyoon LEE, kwangyoon@samsung.com)

Notes: 
--*/

#include <windows.h>
#include <nkintr.h>
#include <oalintr.h>
#include "p2.h"
#include "p2debug.h"
#include "drv_glob.h"

#include <S2440.h>

#define SDIO_FOR_100BD	0

extern DWORD CurMSec;
extern DWORD DiffMSec;

#if (CE_MAJOR_VER == 0x0003)
	extern DWORD ticksleft, dwSleepMin, dwPreempt;
	extern DWORD DiffMSec;
#else
	extern DWORD dwReschedTime;
#endif

extern DWORD AlarmTime;
extern volatile LARGE_INTEGER CurTicks;
extern DWORD dwReschedIncrement;
extern int (*PProfileInterrupt)(void);

extern DWORD dwIsrTime1, dwIsrTime2;
extern BOOL fIntrTime, fIntrTimeToggle;
extern WORD wNumInterrupts;    // Reset by a read of the ISR times from the IST
extern DWORD dwIntrTimeCountdown;
extern DWORD dwIntrTimeCountdownRef;
extern DWORD dwSPC;
extern DWORD PerfCountSinceTick();
extern BOOL fInterruptFlag;
extern VOID CPUPowerReset();
extern VOID OEMEmergencyPowerOff();


static USBD_GLOBALS *usbdShMem=&((DRIVER_GLOBALS *)DRIVER_GLOBALS_PHYSICAL_MEMORY_START)->usbd; //:-)
void UsbdClearEir(void);  //:-)

DWORD OEMTranslateIrq(DWORD dwIrq)
{
    return dwIrq;
}
DWORD OEMTranslateSysIntr(DWORD SysIntr)
{
    return (SysIntr<SYSINTR_FIRMWARE?(DWORD)-1:SysIntr);
}

void OEMInterruptHandlerFIQ() 
{
	// This FIQ interrupt is from BAT_FLT.
	volatile IOPreg *s2440IOP = (IOPreg *)IOP_BASE;
	volatile INTreg *s2440INT = (INTreg *)INT_BASE;

	s2440IOP->rGPBDAT = ~(0xa << 5);   /* LED Off*/ 
	OEMEmergencyPowerOff();
	while(1);
//	RETAILMSG(1, (TEXT(">>> OEMInterruptHandlerFIQ \r\n")));
}


int flag = 1;
unsigned int tCnt = 0;
unsigned int ttt = 0;



int OEMInterruptHandler(unsigned int ra) 
{
	static BYTE nLED = 0x1;
	volatile INTreg *s2440INT = (INTreg *)INT_BASE;
	volatile IOPreg *s2440IOP = (IOPreg *)IOP_BASE;
	volatile PWMreg *s2440PWM = (PWMreg *)PWM_BASE;
	volatile MMCreg *s2440SDIO = (MMCreg *)MMC_BACE;

	unsigned int IntPendVal;
	unsigned int SubIntPendVal;	// for serial

	// jylee
	volatile ADCreg *s2440ADC = (ADCreg *)ADC_BASE;

	static DWORD HeartBeatCnt, HeartBeatStat;
	static volatile struct udcreg *s2440USBD = (volatile struct udcreg *)(0xB1200140); // 0xB1200140
	volatile BYTE usbd_eir = 0, usbd_uir = 0;

    TOUCH_GLOBALS *odo_tsb;  //Sample buffer stuff
    // for this, You MUST modify bsp/inc/drv_glob.h.. check drv_glob.h_jylee
    odo_tsb = &((DRIVER_GLOBALS *)DRIVER_GLOBALS_PHYSICAL_MEMORY_START)->tch;

	// Update LEDs.
	//
//	if (nLED++ > 0xf) nLED = 0;
//	OEMWriteDebugLED(0, ~nLED);
    
	IntPendVal = s2440INT->rINTOFFSET;	// Get pending IRQ mode interrupt in INTPND.
    
	// Fake CPUEnterIdle needs to know about interrupt firing.
	fInterruptFlag = TRUE;

    if (fIntrTime) {
        //
        // We're doing interrupt timing. Get Time to ISR. We subtract TIMER_COUNTDOWN
        // here because the compare register has not been updated.
        //
        dwIsrTime1 = PerfCountSinceTick() - dwReschedIncrement;
        dwSPC = ra;
        wNumInterrupts++;
    }

	//
	// Check the timer interrupt.
	//
	if (IntPendVal == INTSRC_TIMER4) 
	{
		DWORD ttmp;

        if (++HeartBeatCnt > 10)
        {
            HeartBeatCnt   = 0;
            HeartBeatStat ^= 1;

		   //capbily close HeartBeat Status LED
           // if (HeartBeatStat)                        
           //     s2440IOP->rGPBDAT &= ~(1 << 5); /* LED 0 On                 */
           // else
           //    s2440IOP->rGPBDAT |=  (1 << 5); /* LED 0 Off                */
        }
                             
		s2440PWM->rTCNTB4 = dwReschedIncrement;
                             
		ttmp = s2440PWM->rTCON & (~(0xf << 20));
                             
		s2440PWM->rTCON = ttmp | (2 << 20);		/* update TCVNTB4, stop					*/
		s2440PWM->rTCON = ttmp | (1 << 20);		/* one-shot mode,  start				*/
                             
		// Update the tick counter.
		//
		CurTicks.QuadPart += dwReschedIncrement;
                                     
		// Call the profile ISR if it's enabled.
		//
        if (PProfileInterrupt)
        {
			DWORD dwRetVal = SYSINTR_NOP;

			dwRetVal = PProfileInterrupt();
            if (dwRetVal == SYSINTR_RESCHED)
			{
				// Update the millisecond counter.
				//
				CurMSec  += RESCHED_PERIOD;
#if (CE_MAJOR_VER == 0x0003)
                DiffMSec += RESCHED_PERIOD;
#endif
            }

			// Clear the interrupt
			//
			s2440INT->rSRCPND = BIT_TIMER4;        
			if (s2440INT->rINTPND & BIT_TIMER4) s2440INT->rINTPND = BIT_TIMER4;

            // Return whatever we got back from the profiling ISR.
			//
            return(dwRetVal);
        }

		// Update the millisecond counter.
		//
#if (CE_MAJOR_VER == 0x0003)
		DiffMSec += RESCHED_PERIOD;
#endif
		CurMSec  += RESCHED_PERIOD;

		//
		// Clear the interrupt
		//
		s2440INT->rSRCPND = BIT_TIMER4;        
		if (s2440INT->rINTPND & BIT_TIMER4) s2440INT->rINTPND = BIT_TIMER4;
                             		
		if (fIntrTime) 
		{
			//
			// We're doing interrupt timing. Every other tick is a RESCHED.
			//
			dwIntrTimeCountdown--;
                                                                          
			if (dwIntrTimeCountdown == 0) 
			{
				dwIntrTimeCountdown = dwIntrTimeCountdownRef;
				wNumInterrupts = 0;
                                                                              
				dwIsrTime2 = PerfCountSinceTick();
				return (SYSINTR_TIMING);
			} else {
#if (CE_MAJOR_VER == 0x0003)
				if (ticksleft || (dwSleepMin && (dwSleepMin <= DiffMSec)) || (dwPreempt && (dwPreempt <= DiffMSec)))
#else
				if ((int) (CurMSec - dwReschedTime) >= 0)
#endif
					return(SYSINTR_RESCHED);
			}    
		} else {
#if (CE_MAJOR_VER == 0x0003)
			if (ticksleft || (dwSleepMin && (DiffMSec >= dwSleepMin)) || (dwPreempt && (DiffMSec >= dwPreempt)))
#else
			if ((int) (CurMSec - dwReschedTime) >= 0)
#endif
                             
			{
				return(SYSINTR_RESCHED);
			}
			return(SYSINTR_NOP);
		}
	} 

	else if(IntPendVal == INTSRC_MMC)	// SD, MMC
	{
		s2440INT->rINTMSK |= BIT_MMC;
        s2440INT->rSRCPND = BIT_MMC;        
        if (s2440INT->rINTPND & BIT_MMC) s2440INT->rINTPND = BIT_MMC;
//		RETAILMSG(1, (TEXT("ARMINT.C-INT:INTSRC_MMC INT\r\n")));
		if( s2440SDIO->rSDIDATSTA & (0x1<<9) ){
			// RETAILMSG(1, (TEXT("INT:SYSINTR_SDMMC_SDIO_INTERRUPT INT\r\n")));
			return SYSINTR_SDMMC_SDIO_INTERRUPT;
		}
		else {
			// RETAILMSG(1, (TEXT("INT:SYSINTR_SDMMC INT\r\n")));
			return SYSINTR_SDMMC;
		}
	}	
	else if(IntPendVal == INTSRC_DMA0)	// SD DMA interrupt
	{
		s2440INT->rINTMSK |= BIT_DMA0;
		s2440INT->rSRCPND = BIT_DMA0;
		if (s2440INT->rINTPND & BIT_DMA0) s2440INT->rINTPND = BIT_DMA0;
		return SYSINTR_DMA0;
	}
	
	else if (IntPendVal == INTSRC_EINT1)	// Keyboard interrupt is connected to EINT1.
	{ 
		s2440INT->rINTMSK |= BIT_EINT1;
		s2440INT->rSRCPND  = BIT_EINT1;        
		if (s2440INT->rINTPND & BIT_EINT1) s2440INT->rINTPND  = BIT_EINT1;

		return(SYSINTR_KEYBOARD);

	} 
	
	else if (IntPendVal == INTSRC_EINT2)	// EINT2
	{ 
		s2440IOP->rGPBCON &= ~(3<<18);
		s2440IOP->rGPBCON |=  (1<<18);
		s2440IOP->rGPBUP  |=  (1<<9);
		s2440IOP->rGPBDAT &= ~(1<<9);

		s2440INT->rINTMSK |= BIT_EINT2;
		s2440INT->rSRCPND  = BIT_EINT2;	/* Interrupt Clear				*/
		if (s2440INT->rINTPND & BIT_EINT2) s2440INT->rINTPND  = BIT_EINT2;
//		RETAILMSG(1, (TEXT(">>> CPUPowerReset \r\n")));
		//RETAILMSG(1,(TEXT(">>> >>> Reset Button Pressed <<< <<< \r\n")));
		CPUPowerReset();

		return(SYSINTR_POWER);
	}
	else if (IntPendVal == INTSRC_EINT3)	// PCMCIA interrupt is connected to EINT3. (nINT_P_DEV)
	{ 
   		s2440INT->rINTMSK |= BIT_EINT3;
   		s2440INT->rSRCPND  =  BIT_EINT3;        
   		if (s2440INT->rINTPND & BIT_EINT3) s2440INT->rINTPND = BIT_EINT3;
                           
   		return(SYSINTR_PCMCIA_STATE);
	}  
	else if (IntPendVal == INTSRC_EINT4_7)		// EINT4 ~ 7
	{ 

		///s2440INT->rINTMSK |= BIT_EINT8_23;	
		///submask = s2440IOP->rEINTPEND;

		DWORD dwSubMask = s2440IOP->rEINTPEND & (~s2440IOP->rEINTMASK);

		///if ( submask & (1 << 9))	// 0x200 EINT9 : CS8900
		if ( dwSubMask & (1 << 7))	// 0x200 EINT9 : CS8900
		{
			s2440IOP->rEINTMASK |= 0x80;
			s2440IOP->rEINTPEND = 0x80;

			s2440INT->rSRCPND = BIT_EINT4_7;        
			if (s2440INT->rINTPND & BIT_EINT4_7) s2440INT->rINTPND = BIT_EINT4_7;

			// RETAILMSG(1, (TEXT("INT:SYSINTR_ETHER INT s2440IOP->rEINTMASK = 0x%8x, s2440IOP->rEINTMASK\r\n")));
			// RETAILMSG(1, (TEXT("INT:SYSINTR_ETHER INT s2440IOP->rEINTPEND = 0x%8x, s2440IOP->rEINTPEND\r\n")));
			return SYSINTR_ETHER;
		}

#if SDIO_FOR_100BD	// for b'd revision 1.00
		///if ( submask & (1 << 18)) // EINT28 : SDMMC_CARD_DETECT
		if ( dwSubMask & (1 << 18)) // EINT28 : SDMMC_CARD_DETECT
		{
			s2440IOP->rEINTMASK |= (1 << 18);
			s2440IOP->rEINTPEND  = (1 << 18);
			s2440INT->rSRCPND  = BIT_EINT8_23;
			if (s2440INT->rINTPND & BIT_EINT8_23) 
				s2440INT->rINTPND = BIT_EINT8_23;

			// RETAILMSG(1, (TEXT("ARMINT.C - SYSINTR_SDMMC_CARD_DETECT rEINTMASK = 0x%8x, s2440IOP->rEINTMASK\r\n")));
			 RETAILMSG(1, (TEXT("ARMINT.C - SYSINTR_SDMMC_CARD_DETECT rEINTPEND = 0x%8x, s2440IOP->rEINTPEND\r\n")));			
			return SYSINTR_SDMMC_CARD_DETECT;
		}
#else					// for b'd revision 0.17
		if ( s2440IOP->rEINTPEND & (1 << 16))	// SD Card Detect
		{
			s2440IOP->rEINTMASK |= (1 << 16);
			s2440IOP->rEINTPEND  = (1 << 16);
			s2440INT->rSRCPND  = BIT_EINT8_23;
			if (s2440INT->rINTPND & BIT_EINT8_23) 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品区一区二区| 欧美午夜在线观看| 久久精品免费在线观看| 狠狠色狠狠色综合| 国产精品天美传媒沈樵| 99精品久久免费看蜜臀剧情介绍| 中文字幕一区二区不卡| 色一情一乱一乱一91av| 亚洲电影第三页| 日韩精品最新网址| 成人免费视频网站在线观看| 亚洲激情在线激情| 欧美一区二区三区不卡| 国产精品香蕉一区二区三区| 国产精品久久毛片| 欧美高清你懂得| 国产高清不卡一区| 亚洲女同一区二区| 欧美电影免费观看高清完整版| 国产精品99精品久久免费| 综合久久一区二区三区| 51精品视频一区二区三区| 国产毛片精品国产一区二区三区| 国产精品久久久久久久久图文区| 欧美影视一区在线| 国产美女娇喘av呻吟久久| 亚洲精品菠萝久久久久久久| 日韩精品一区二| 91麻豆高清视频| 美美哒免费高清在线观看视频一区二区 | 91美女视频网站| 日本欧美一区二区在线观看| 中文字幕电影一区| 欧美日韩1区2区| 国产91精品精华液一区二区三区 | 中文字幕视频一区二区三区久| 欧美视频三区在线播放| 成人在线综合网| 日本aⅴ免费视频一区二区三区| 国产精品国产三级国产有无不卡| 在线不卡的av| 一本久久综合亚洲鲁鲁五月天| 久久国产综合精品| 亚洲不卡在线观看| 中文字幕一区二区三区不卡在线| 欧美电视剧在线观看完整版| 在线观看视频欧美| 91在线云播放| 国产91对白在线观看九色| 男男视频亚洲欧美| 一区二区三区日韩在线观看| 日本不卡不码高清免费观看| 亚洲国产日韩综合久久精品| 日韩中文字幕av电影| 精品视频在线视频| www.成人网.com| 国产白丝网站精品污在线入口| 日韩在线一二三区| 亚洲国产精品尤物yw在线观看| 综合久久久久综合| 国产精品色一区二区三区| 久久伊99综合婷婷久久伊| 欧美一级午夜免费电影| 欧美日韩一区三区| 欧美吞精做爰啪啪高潮| 97se狠狠狠综合亚洲狠狠| 国产成人鲁色资源国产91色综 | 精品88久久久久88久久久| 欧美猛男男办公室激情| 欧美中文字幕一区二区三区 | 大桥未久av一区二区三区中文| 久久精品国产久精国产| 美女www一区二区| 免费高清不卡av| 另类小说一区二区三区| 麻豆精品新av中文字幕| 美女视频黄a大片欧美| 蜜臀av一区二区在线免费观看| 麻豆国产精品官网| 国产专区综合网| 丁香激情综合五月| 99国产一区二区三精品乱码| 不卡免费追剧大全电视剧网站| jvid福利写真一区二区三区| av在线不卡电影| 一本一道波多野结衣一区二区| 91免费观看视频在线| 欧美综合亚洲图片综合区| 欧美精品久久天天躁| 日韩美女主播在线视频一区二区三区 | 成人深夜福利app| 91麻豆.com| 欧美无人高清视频在线观看| 91.成人天堂一区| 精品久久久久久久久久久久久久久久久 | 26uuu亚洲综合色欧美| 国产日韩欧美制服另类| 中文字幕在线不卡一区| 亚洲乱码中文字幕| 三级久久三级久久| 国产一区二区主播在线| 99久久精品免费看| 欧美日韩美女一区二区| 26uuu亚洲婷婷狠狠天堂| 国产精品久久网站| 午夜激情久久久| 国产精品18久久久久| 91免费视频网| 欧美xxxx在线观看| 日韩一区有码在线| 日韩av午夜在线观看| 懂色av中文字幕一区二区三区| 欧美性猛交xxxx乱大交退制版| 欧美一个色资源| 综合电影一区二区三区 | 亚洲欧洲av另类| 视频一区二区欧美| 国产+成+人+亚洲欧洲自线| 在线视频国内自拍亚洲视频| 精品剧情v国产在线观看在线| 亚洲人妖av一区二区| 日本亚洲欧美天堂免费| 99精品视频一区二区三区| 91精选在线观看| 有码一区二区三区| 国产美女精品人人做人人爽| 欧美日韩亚洲不卡| 中文字幕在线一区免费| 蜜臀精品久久久久久蜜臀 | 欧美一级一区二区| 亚洲视频狠狠干| 久久精品国产99国产| 在线观看视频一区| 国产精品久久久久久久久免费樱桃| 免费精品视频在线| 欧美系列日韩一区| 日韩伦理电影网| 成+人+亚洲+综合天堂| 日韩精品一区二区三区老鸭窝 | 国产盗摄一区二区三区| 欧美老肥妇做.爰bbww| ●精品国产综合乱码久久久久| 麻豆91精品91久久久的内涵| 91福利国产精品| 亚洲乱码国产乱码精品精的特点| 国产精品一品视频| 久久综合九色综合欧美98| 青青草97国产精品免费观看| 欧美色图片你懂的| 亚洲精品日产精品乱码不卡| 成人激情图片网| 国产精品久久久久久久久免费相片 | 337p粉嫩大胆噜噜噜噜噜91av| 日韩av网站在线观看| 欧美福利视频导航| 天天综合色天天综合色h| 91女神在线视频| 亚洲乱码日产精品bd| 97久久超碰国产精品| 中文字幕一区二区三区蜜月| 成人一区二区三区中文字幕| 日本一区二区三区国色天香| 精品一区二区三区久久久| 日韩一区二区三区视频在线| 日本怡春院一区二区| 日韩免费看的电影| 韩国中文字幕2020精品| 久久久www免费人成精品| 国产毛片精品国产一区二区三区| 久久久久高清精品| 国产高清久久久久| 国产精品毛片大码女人| 成人小视频免费在线观看| 国产精品久久久久久久裸模| 99久久久久免费精品国产 | 欧美人与禽zozo性伦| 日本va欧美va精品发布| 精品入口麻豆88视频| 国产成人福利片| 亚洲视频你懂的| 欧美日韩国产一级| 麻豆一区二区99久久久久| 国产亚洲综合在线| 色8久久精品久久久久久蜜| 国产91精品在线观看| 国产精品美女久久久久久久久| thepron国产精品| 亚洲18色成人| 精品少妇一区二区三区| aaa国产一区| 亚洲国产成人91porn| 精品日韩欧美一区二区| 成人永久aaa| 亚洲6080在线| 久久久综合视频| 欧美在线你懂的| 久久99精品一区二区三区三区| 久久久蜜臀国产一区二区| 色综合色狠狠综合色| 丝袜诱惑制服诱惑色一区在线观看|