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

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

?? isr.c

?? 2410開發板上鍵盤與LED的驅動實驗
?? C
字號:
/***************************************************************************\
	Copyright (c) 2004-2007 threewater@up-tech.com, All rights reserved.
	by threewter	2004.5.12
\***************************************************************************/
/***************************************************************************\
    #說明:中斷處理函數
    #接口函數
	----------------------------------  Bug  --------------------------------------

	----------------------------------  TODO list  --------------------------------------
	2004-5-12	對于邋IO口的多中斷源的共享
	----------------------------------修正--------------------------------------

	2004-5-12	1、移植
				2、改變了中斷函數的定義,添加了一個標志中斷號的參數
				3、添加了void ISR_Init(void)函數定義,系統初始化中斷的時候調用

\***************************************************************************/
#include "../inc/reg2410.h"
#include "inc/isr.h"
//#include "includes.h"
#include "inc/macro.h"
#include <string.h>


typedef void (*mask_func_t)(unsigned int);

typedef struct{
	Interrupt_func_t InterruptHandlers;
	void* data;
	int valid;		//設置中斷1=有效0=無效
	mask_func_t mask;
	mask_func_t unmask;
	mask_func_t ack_irq;
}struct_InterruptFunc;

static struct_InterruptFunc InterruptFunc[NR_IRQS]={NULL,};

#define GetISROffsetClr()	rINTOFFSET

#define	ClearPending(x)	do{rSRCPND = (1u << (x));	rINTPND = rINTPND;}while(0)

#define EINT_OFFSET(x)		((x) - NORMAL_IRQ_OFFSET + 4)
#define SUBIRQ_OFFSET(x)	((x) - EXT_IRQ_OFFSET)

#define EXTINT_MASK	0x7

//--------------------------------IRQ for s3c2410---------------------------------//

static int __inline fixup_irq_num(int irq)
{
	if (irq < IRQ_EINT4) return irq;
	else return ((irq + 4) - NORMAL_IRQ_OFFSET);
}

static void __inline set_gpios(int irq, int pullup)
{
	int shift;
	if (irq < 8) {
		shift = 2*irq;
		rGPFCON &= ~(0x3 << shift);
		rGPFCON |= (0x2 << shift);
		//GPFUP &= ~(GRAB_PULLUP(pullup) << irq); modify by threewater
		rGPFUP &= ~(1<< irq);
		rGPFUP |= (GRAB_PULLUP(pullup) << irq);
	} else {
		shift = 2*(irq - 8);
		rGPGCON &= ~(0x3 << shift);
		rGPGCON |= (0x2 << shift);
		//GPGUP &= ~(GRAB_PULLUP(pullup) << (irq - 8));
		rGPGUP &= ~(1<< (irq - 8));
		rGPGUP |= (GRAB_PULLUP(pullup) << (irq - 8));
	} 
}

int set_external_irq(int irq, int edge, int pullup)
{
	int real_irq, reg_ofs, shift;
	volatile U32 *extint = &rEXTINT0;

	if (((irq < IRQ_EINT0) && (irq > IRQ_EINT23)) ||
	    ((irq > IRQ_EINT3) && (irq < IRQ_EINT4)))
		return FAIL;

	real_irq = fixup_irq_num(irq);

	set_gpios(real_irq, pullup);

	reg_ofs = (real_irq / 8);
	shift = 4 * (real_irq - 8 * reg_ofs);
	extint += reg_ofs;

	*extint &= ~(EXTINT_MASK << shift);
	*extint |= (edge << shift);

	if (irq < 4) {
		rSRCPND |= (1 << real_irq);
		rINTPND |= (1 << real_irq);
	} else {
		rEINTPEND |= (1 << real_irq);
	}
	InterruptFunc[irq].valid=1;

	return 0;
}



/*
 * Defined irq handlers
 */
static void ack_irq(unsigned int irq)
{
	rSRCPND = (1 << irq);//1表請求
	rINTPND = (1 << irq);
}

static void mask_irq(unsigned int irq)
{
	rINTMSK |= (1 << irq);//1表屏蔽
}

static void unmask_irq(unsigned int irq)
{
	rINTMSK &= ~(1 << irq);
}

/* for EINT? */
static void EINT4_23ack_irq(unsigned int irq)
{
	irq = EINT_OFFSET(irq);
	rEINTPEND = (1 << irq);

	if (irq < EINT_OFFSET(IRQ_EINT8)) {
		ClearPending(SHIFT_EINT4_7);
	} else {
		ClearPending(SHIFT_EINT8_23);
	}
}

static void EINT4_23mask_irq(unsigned int irq)
{
	irq = EINT_OFFSET(irq);
	rEINTMASK |= (1 << irq);
}

static void EINT4_23unmask_irq(unsigned int irq)
{
	rEINTMASK &= ~(1 << EINT_OFFSET(irq));

	if (irq < IRQ_EINT8) {
	  rINTMSK &= ~(1 << SHIFT_EINT4_7);
	} else {
	  rINTMSK &= ~(1 << SHIFT_EINT8_23);
	}
}


/* for sub_IRQ */
static void SUB_ack_irq(unsigned int irq)
{
	rSUBSRCPND = (1 << SUBIRQ_OFFSET(irq));

	if (irq <= IRQ_ERR0){
		ClearPending(IRQ_UART0);
	}else if (irq <= IRQ_ERR1){
		ClearPending(IRQ_UART1);
	}else if (irq <= IRQ_ERR2){
		ClearPending(IRQ_UART2);
	} else {	/* if ( irq <= IRQ_ADC_DONE ) { */
		ClearPending(IRQ_ADCTC);
	}
}

static void SUB_mask_irq(unsigned int irq)
{
	rINTSUBMSK |= (1 << SUBIRQ_OFFSET(irq));
}

static void SUB_unmask_irq(unsigned int irq)
{
	rINTSUBMSK &= ~(1u << SUBIRQ_OFFSET(irq));

	if (irq <= IRQ_ERR0) {
		rINTMSK &= ~(1u << IRQ_UART0); 
        } else if (irq <= IRQ_ERR1) {
		rINTMSK &= ~(1u << IRQ_UART1);
	} else if (irq <= IRQ_ERR2){
	    	rINTMSK &= ~(1u << IRQ_UART2);
        } else {	/* if ( irq <= IRQ_ADC_DONE ) { */
		rINTMSK &= ~(1u << IRQ_ADCTC);
        }
}

__inline unsigned int get_subIRQ(int irq, int begin, int end, int fail_irq) {
	int i;

	for(i=begin; i <= end; i++) {
	  if (irq & (1 << i))
	    return (EXT_IRQ_OFFSET + i);
	}
	return fail_irq;
}

__inline unsigned int get_extIRQ(int irq, int begin, int end, int fail_irq) {
	int i;

	for(i=begin; i <= end; i++) {
	  if (irq & (1 << i))
	    return (NORMAL_IRQ_OFFSET - 4 + i);
	}
	return fail_irq;
}

static unsigned int fixup_irq(int irq) {
    unsigned int ret;
    unsigned long sub_mask, ext_mask;

    switch (irq) {
    case IRQ_UART0:
      sub_mask = rSUBSRCPND & ~rINTSUBMSK;
      ret = get_subIRQ(sub_mask, 0, 2, irq);
      break;
    case IRQ_UART1:
      sub_mask = rSUBSRCPND & ~rINTSUBMSK;
      ret = get_subIRQ(sub_mask, 3, 5, irq);
      break;
    case IRQ_UART2:
      sub_mask = rSUBSRCPND & ~rINTSUBMSK;
      ret = get_subIRQ(sub_mask, 6, 8, irq);
      break;
    case IRQ_ADCTC:
      sub_mask = rSUBSRCPND & ~rINTSUBMSK;
      ret = get_subIRQ(sub_mask, 9, 10, irq);
      break;
    case IRQ_EINT4_7:
      ext_mask = rEINTPEND & ~rEINTMASK;
      ret = get_extIRQ(ext_mask, 4, 7, irq);
      break;
    case IRQ_EINT8_23:
      ext_mask = rEINTPEND & ~rEINTMASK;
      ret = get_extIRQ(ext_mask, 8, 23, irq);
      break;
    default:
      ret = irq;
    }
	
    return ret;
}

void ISR_Init(void)
{
	int irq;

	//FIQ disable and disable all interrupt
	rINTMOD     = 0x0;                     //All=IRQ mode
	rINTMSK     = BIT_ALLMSK;              //All interrupt is masked.
	rINTSUBMSK  = BIT_SUB_ALLMSK;          //All sub-interrupt is masked

	// Define irq handler
	for (irq=0; irq < NORMAL_IRQ_OFFSET; irq++) {
		InterruptFunc[irq].valid = 1;//表中斷有效
		InterruptFunc[irq].ack_irq = ack_irq;
		InterruptFunc[irq].mask =  mask_irq;
		InterruptFunc[irq].unmask = unmask_irq;
	}

	InterruptFunc[IRQ_RESERVED6].valid	= 0;
	InterruptFunc[IRQ_RESERVED24].valid	= 0;

	InterruptFunc[IRQ_EINT4_7].valid	= 0;
	InterruptFunc[IRQ_EINT8_23].valid	= 0;

	InterruptFunc[IRQ_EINT0].valid		= 0;
	InterruptFunc[IRQ_EINT1].valid		= 0;
	InterruptFunc[IRQ_EINT2].valid		= 0;
	InterruptFunc[IRQ_EINT3].valid		= 0;

	for (irq=NORMAL_IRQ_OFFSET; irq < EXT_IRQ_OFFSET; irq++) {
		InterruptFunc[irq].valid	= 0;
		InterruptFunc[irq].ack_irq	= EINT4_23ack_irq;
		InterruptFunc[irq].mask	= EINT4_23mask_irq;
		InterruptFunc[irq].unmask	= EINT4_23unmask_irq;
	}

	for (irq=EXT_IRQ_OFFSET; irq < SUB_IRQ_OFFSET; irq++) {
		InterruptFunc[irq].valid	= 1;
		InterruptFunc[irq].ack_irq	= SUB_ack_irq;
		InterruptFunc[irq].mask	= SUB_mask_irq;
		InterruptFunc[irq].unmask	= SUB_unmask_irq;
	}  

}

//--------------------------------IRQ core---------------------------------//

#if 0
int GetISROffsetClr()
{
	//計算中斷的偏移地址,高位優先
	int i,ispr=rI_ISPR,tmp=1<<(MAXHNDLRS-1);//temp bit
	for(i=MAXHNDLRS;i>0;i--){
		if(ispr&tmp){
			return i-1;
		}
		tmp>>=1;
	}
	return -1;
}
#endif

int SetISR_Interrupt(int vector, void (*handler)(int, void*), void* data)
{
//#if OS_CRITICAL_METHOD == 3
//	OS_CPU_SR  cpu_sr;
//#endif

	if(vector>NR_IRQS || vector<0)
		return -1;

	if(!InterruptFunc[vector].valid)
		return -1;

	//OS_ENTER_CRITICAL();
    INTS_OFF();
	InterruptFunc[vector].ack_irq(vector);	//clear pending

	InterruptFunc[vector].InterruptHandlers = handler;
	InterruptFunc[vector].data = data;

	InterruptFunc[vector].unmask(vector);	//enable interrupt
    INTS_ON();
	//OS_EXIT_CRITICAL();

	return 0;
}

void Enable_Irq(int vector)
{
	if(vector>NR_IRQS || vector<0)
		return;

	if(!InterruptFunc[vector].valid)
		return;

	InterruptFunc[vector].ack_irq(vector);	//clear pending
	InterruptFunc[vector].unmask(vector);	//enable interrupt
}

void Disable_Irq(int vector)
{
	if(vector>NR_IRQS || vector<0)
		return;

	if(!InterruptFunc[vector].valid)
		return;

	InterruptFunc[vector].mask(vector);	//disable interrupt
}


void ISR_IrqHandler(void)
{
	unsigned int irq=GetISROffsetClr();	//得到中斷向量的偏移地址

	irq=fixup_irq(irq);

	if(irq>=NR_IRQS)
		return;
	if(InterruptFunc[irq].InterruptHandlers==NULL){
		InterruptFunc[irq].ack_irq(irq);	//clear pending
		return;
	}

	//OSIntEnter();
	
	 // Call interrupt service routine
	InterruptFunc[irq].InterruptHandlers(irq, InterruptFunc[irq].data);
	InterruptFunc[irq].ack_irq(irq);	//clear pending
    
	//OSIntExit();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品欧美日韩精品| 亚洲视频免费看| 亚洲精品在线一区二区| 亚洲国产一区视频| 大美女一区二区三区| 日韩欧美国产一区在线观看| 亚洲国产综合色| 94-欧美-setu| 欧美激情一区二区三区在线| 蜜桃视频在线一区| 在线成人av影院| 亚洲高清视频在线| 在线视频国内自拍亚洲视频| 亚洲一区二区成人在线观看| 欧洲精品中文字幕| 水蜜桃久久夜色精品一区的特点| 欧美群妇大交群中文字幕| 午夜视频在线观看一区| 欧美一二三在线| 国产一区二区三区日韩| 欧美激情在线看| 色综合中文字幕| 视频在线观看一区二区三区| 日韩一区和二区| 成人在线一区二区三区| 亚洲欧美日韩一区二区三区在线观看 | 国产精品99久久久| 中文字幕免费观看一区| 97超碰欧美中文字幕| 一区二区久久久久久| 欧美日韩精品二区第二页| 九色|91porny| 国产精品免费久久| 欧美日韩一区久久| 天天综合网天天综合色| 精品国产三级电影在线观看| 成人av影院在线| 午夜精品福利一区二区三区av| 精品美女一区二区三区| 91免费版pro下载短视频| 日韩精品乱码免费| 国产亚洲1区2区3区| 91国在线观看| 韩国女主播成人在线观看| 国产精品久久久久毛片软件| 欧美日韩一区视频| 成人a免费在线看| 蜜臀久久99精品久久久画质超高清| 国产三区在线成人av| 欧美亚洲丝袜传媒另类| 日日摸夜夜添夜夜添亚洲女人| 精品国产青草久久久久福利| 成人av中文字幕| 亚洲超碰精品一区二区| 国产亚洲精品资源在线26u| 成人av在线资源网站| 蜜臀91精品一区二区三区| 亚洲毛片av在线| 日韩欧美国产一区在线观看| 91在线免费视频观看| 天堂蜜桃91精品| 亚洲色图欧洲色图| 91精品国产综合久久久久久| 高清不卡一二三区| 麻豆一区二区三| 亚洲国产精品天堂| 国产精品久久久久久久裸模| 26uuu亚洲| 欧美精品乱码久久久久久按摩| 色综合天天综合给合国产| 国产剧情在线观看一区二区| 日韩国产欧美在线观看| 一区二区三区**美女毛片| 国产精品国产三级国产a| 久久亚洲捆绑美女| 日韩女优毛片在线| 欧美一级片在线看| 91精品婷婷国产综合久久性色 | 欧美性大战久久久久久久蜜臀| 日本亚洲三级在线| 一区二区三区成人在线视频| 亚洲欧美在线高清| 国产精品丝袜一区| 久久久99精品免费观看| 精品对白一区国产伦| 欧美白人最猛性xxxxx69交| 欧美剧情电影在线观看完整版免费励志电影 | 色老头久久综合| 国产成人综合视频| 日韩av电影天堂| 亚洲成人免费在线| 石原莉奈在线亚洲二区| 亚洲女厕所小便bbb| 中文字幕一区二区三区色视频 | 91精品国产免费| 91麻豆精品国产91久久久使用方法| 欧美综合天天夜夜久久| 欧美日韩中文另类| 欧美日韩不卡一区| 日韩一级完整毛片| 精品国产乱码久久久久久闺蜜| 日韩美女一区二区三区四区| 精品久久一二三区| 国产欧美一区二区精品性色| 国产日韩欧美高清| 亚洲日本电影在线| 亚洲成av人在线观看| 偷拍自拍另类欧美| 精品一区二区三区在线播放视频| 麻豆91精品91久久久的内涵| 经典三级视频一区| 国产99一区视频免费| 国产成人午夜精品5599| av不卡在线观看| 欧美在线观看一区| 精品国产凹凸成av人导航| 国产农村妇女毛片精品久久麻豆 | 亚洲高清视频的网址| 日本免费在线视频不卡一不卡二| 精品一区精品二区高清| 国产乱码精品一区二区三区av| 成人免费视频一区| 欧美日韩一区二区三区四区五区| 欧美一区二区三区播放老司机| 欧美精品一区二区三区蜜臀| 国产精品不卡视频| 日本欧美一区二区| 成人性生交大片免费看在线播放| 在线视频国内自拍亚洲视频| 欧美一级免费观看| 国产精品视频九色porn| 一区二区三区视频在线观看| 日韩高清一级片| 丁香亚洲综合激情啪啪综合| 欧美日韩精品电影| 国产精品国产自产拍高清av王其| 亚洲国产aⅴ天堂久久| 国产精品99久久久久久似苏梦涵 | 日韩欧美成人一区二区| 26uuu国产在线精品一区二区| 欧美激情一区二区| 亚洲高清免费在线| 国产老妇另类xxxxx| 91色.com| 国产欧美在线观看一区| 亚洲男人都懂的| 国产精品资源站在线| 欧美日韩三级一区二区| 国产精品―色哟哟| 日本欧美肥老太交大片| 91国偷自产一区二区开放时间| 久久久久亚洲综合| 日韩高清在线观看| 91福利视频久久久久| 国产日韩欧美精品电影三级在线| 日本大胆欧美人术艺术动态| 一本色道久久综合亚洲91| 国产亚洲综合在线| 日本怡春院一区二区| 欧美在线观看你懂的| 国产精品不卡在线| 国产99久久久国产精品潘金| 日韩精品一区二区三区swag| 一区二区三区四区精品在线视频| 成人免费视频播放| 久久众筹精品私拍模特| 久久99久久99小草精品免视看| 欧美伊人久久大香线蕉综合69 | 不卡av在线免费观看| 久久蜜桃一区二区| 激情图片小说一区| 日韩午夜激情视频| 五月天婷婷综合| 欧美色网站导航| 一区二区三区不卡在线观看 | 国产精品久久三| 国产综合久久久久影院| 欧美不卡123| 狠狠狠色丁香婷婷综合久久五月| 欧美一区欧美二区| 婷婷综合久久一区二区三区| 欧美日韩国产123区| 午夜精品福利一区二区三区av| 欧美性色aⅴ视频一区日韩精品| 最新中文字幕一区二区三区| 成人免费视频网站在线观看| 婷婷丁香激情综合| 91高清在线观看| 国产亚洲精品aa午夜观看| 日韩av高清在线观看| 日韩精品最新网址| 狠狠色伊人亚洲综合成人| 久久久久9999亚洲精品| 99久久综合狠狠综合久久| 久久久精品tv| 国产高清不卡一区| 8x8x8国产精品| 麻豆国产欧美一区二区三区| 久久亚洲捆绑美女| 91成人看片片|