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

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

?? sleep.c

?? 研勤公司2440開發板的測試程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
	Uart_Printf("\nBattery fault interrupt setting.\n");
	Uart_Printf("Detect low-level.\n");

	Uart_Printf("0 : Reset system during nBATT_FLT=0.\n");
	Uart_Printf("4 : System will be wake-up from sleep mode during nBATT_FLT=0.\n");
	Uart_Printf("6 : System will ignore Eint0 signal during nBATT_FLT=0.\n");
	Uart_Printf("7 : Disable Battery function.\n");
	Uart_Printf("Select battery function : ");
	i = Uart_GetIntNum() & 0x7;
	
	rMISCCR = (rMISCCR & ~(0x1f<<20)) | (i<<20);
	// [22:20]
	// if 0, System will be Reset during nBATT_FLT=0.
	// if 4, System will be wake-up from sleep mode during nBATT_FLT=0.
	// if 6, System will ignore nBATT_FLT signal.
	// if 7, Disable Battery function.

	Uart_Printf("rMISCCR:%x\n", rMISCCR);
	pISR_BAT_FLT = (U32)BattFaultInt;
	rSRCPND = BIT_BAT_FLT;
	rINTPND = BIT_BAT_FLT;

	rINTMSK = rINTMSK & ~(BIT_BAT_FLT);	// unmask.

#endif	
/////////////////////////////////////////// add for battery fault...end



#if 0	
	Uart_Printf("Check SDRAM for self-refresh test\n");
	for(i=_NONCACHE_STARTADDRESS;i<(_NONCACHE_STARTADDRESS+0x400000);i+=4)
	{
	//Uart_Printf("%x=%x(%x)\n",i,*((U32 *)i),i^0x55555555);
	if(*((U32 *)i)!=(i^0x55555555))
	{
		Uart_Printf("Mem Error:%x=%x(%x)\n",i,*((U32 *)i),i^0x55555555);
		 error++;
	}
	if(error>20)
		break;
	}
	if(error)
		Uart_Printf("SDRAM self-refresh test:FAILED\n"); 
	else 
	Uart_Printf("SDRAM self-refresh test:O.K.\n");	
#endif

	Uart_TxEmpty(1);	//Wait until UART0 Tx buffer empty.
	   

#if 1	  
	SelectEintType();
#else
	rGPFCON=rGPFCON & ~(3<<0)|(2<<0); //PF0=EINT0
	rEXTINT0=rEXTINT0&~(7<<0)|(2<<0);  //EINT0=falling edge triggered
#endif

#if 1	//test whether or not the interrupt pending bit retain the wake-up source.
	pISR_EINT0=(U32)Eint0Int;
	pISR_EINT8_23=(U32)Eint8_23Int;
	pISR_RTC=(U32)AlarmInt;
	rINTMSK = ~(BIT_EINT0|BIT_EINT8_23|BIT_RTC);
	for(i=0;i<100;i++);

	rSRCPND = BIT_EINT0|BIT_EINT8_23|BIT_RTC;
	rINTPND = BIT_EINT0|BIT_EINT8_23|BIT_RTC;

	rEINTPEND=rEINTPEND;
	rSRCPND=rSRCPND;
	rINTPND=rINTPND;
#endif	 


	rEINTMASK = rEINTMASK&~(1<<11); //SRCPND:EINT8_23 will be set by EINT11 after wake-up.
	rINTMSK = BIT_ALLMSK;
	// NOTE: Any interrupt can't be used in Sleep mode. 
	//	   because SDRAM is in self-refresh mode and ISR code will access SDRAM.

	Uart_Printf("Alarm wake-up (y/n)? ");
	if(Uart_Getch()=='y')
	{
		Uart_Printf("S3C2440 will wake up by RTC alarm(10 sec) or EINT0 .\n");
		SetAlarmWakeUp();
	}


	rRTCCON=0x0;   // R/W disable, 1/32768, Normal(merge), No reset
	rADCCON|=(1<<2);

	rMISCCR|=(1<<12); //USB port0 = suspend
	rMISCCR|=(1<<13); //USB port1 = suspend


	rGSTATUS3=(U32)StartPointAfterSleepWakeUp;	// memory control part in startup code.
	Uart_Printf("set restart address:%x\n", rGSTATUS3);
	rGSTATUS4=0xaaaaaaaa;

	Uart_TxEmpty(1);	//Wait until UART0 Tx buffer empty.
	ConfigSleepGPIO();
	ConfigMiscIO();

	//Max1718_Set(110);

	rMISCCR=rMISCCR|(3<<0); 	// Data[31:0] pull-up disable.

	Lcd_EnvidOnOff(0); //Before entering Sleep mode, LCD must be off	


	//=================================================================
	//  VERY IMPORTANT NOTE 
	//  To enter SLEEP/SLIDLE mode, MMU TLB-fill operation should be prohibited
	//   because MTT table is in SDRAM and SDRAM is in the self-refresh mode.
	//  So, we will fill TLB before entering SDRAM self-refresh 
	//   instead of disabling MMU.
	rREFRESH;//To fill TLB for the special register used in EnterPWDN
	rCLKCON;
	//=================================================================

	

	EnterPWDN(0xffff8); //Sleep mode
	//Never return here. 
}

int batt_flag=0;
//================================================================================
static void __irq BattFaultInt(void)
{
	rINTMSK |= (BIT_BAT_FLT);	// mask.
	ClearPending(BIT_BAT_FLT)

	Uart_Printf("BATT_FLT interrupt occured\n");
	batt_flag=1;
	//Batt_Sleep();

}

//================================================================================
void Test_BattFaultInterrupt(void)
{
	int i;
	
	Uart_Printf("Battery fault interrupt test.\n");
	Uart_Printf("Detect low-level.\n");
/*
	Uart_Printf("0 : Reset system during nBATT_FLT=0.\n");
	Uart_Printf("4 : System will be wake-up from sleep mode during nBATT_FLT=0.\n");
	Uart_Printf("6 : System will ignore Eint0 signal during nBATT_FLT=0.\n");
	Uart_Printf("7 : Disable Battery function.\n");
	Uart_Printf("Select battery function : ");
	//i = Uart_GetIntNum() & 0x7;
*/
	i = 4;
	
	rMISCCR = (rMISCCR & ~(0x1f<<20)) | (i<<20);
	// [22:20]
	// if 0, System will be Reset during nBATT_FLT=0.
	// if 4, System will be wake-up from sleep mode during nBATT_FLT=0.
	// if 6, System will ignore nBATT_FLT signal.
	// if 7, Disable Battery function.

	pISR_BAT_FLT = (U32)BattFaultInt;
	rSRCPND = BIT_BAT_FLT;
	rINTPND = BIT_BAT_FLT;

	rINTMSK = rINTMSK & ~(BIT_BAT_FLT);	// unmask.

		while(batt_flag==0)
		{
			if(Uart_GetKey()){
				break; 
			}
		}	
		batt_flag=0;
		//Batt_Sleep();
		Uart_Printf("exit.\n");
		
}

void Batt_Sleep(void)
{
	int i;
	U32 portStatus[33+3];
	int error=0;
	int mode;
	Uart_Printf("[Sleep Mode Test]\n");

	Uart_Printf("nBATT_FLT pin should be tested.\n");
	
	Uart_Printf("S3C2440 will wake up by EINT0 .\n");

/////////////////////////////////////////// add for battery fault...
#if 1
	Uart_Printf("6 : System will ignore Eint0 signal during nBATT_FLT=0.\n");

	Uart_Printf("rMISCCR:%x\n", rMISCCR);

#endif	
/////////////////////////////////////////// add for battery fault...end

	Uart_TxEmpty(1);	//Wait until UART0 Tx buffer empty.
	   

#if 0	  
	SelectEintType();
#else
	rGPFCON=rGPFCON & ~(3<<0)|(2<<0); //PF0=EINT0
	rEXTINT0=rEXTINT0&~(7<<0)|(2<<0);  //EINT0=falling edge triggered
#endif

#if 1	//test whether or not the interrupt pending bit retain the wake-up source.
	pISR_EINT0=(U32)Eint0Int;
	pISR_EINT8_23=(U32)Eint8_23Int;
	pISR_RTC=(U32)AlarmInt;
	rINTMSK = ~(BIT_EINT0|BIT_EINT8_23|BIT_RTC);
	for(i=0;i<100;i++);

	rSRCPND = BIT_EINT0|BIT_EINT8_23|BIT_RTC;
	rINTPND = BIT_EINT0|BIT_EINT8_23|BIT_RTC;

	rEINTPEND=rEINTPEND;
	rSRCPND=rSRCPND;
	rINTPND=rINTPND;
#endif	 

	rEINTMASK = rEINTMASK&~(1<<11); //SRCPND:EINT8_23 will be set by EINT11 after wake-up.
	rINTMSK = BIT_ALLMSK;
	// NOTE: Any interrupt can't be used in Sleep mode. 
	//	   because SDRAM is in self-refresh mode and ISR code will access SDRAM.

	Uart_Printf("Alarm wake-up (y/n)? ");
	if(Uart_Getch()=='y')
	{
		Uart_Printf("S3C2440 will wake up by RTC alarm(10 sec) or EINT0 .\n");
		SetAlarmWakeUp();
	}

	rRTCCON=0x0;   // R/W disable, 1/32768, Normal(merge), No reset
	rADCCON|=(1<<2);

	rMISCCR|=(1<<12); //USB port0 = suspend
	rMISCCR|=(1<<13); //USB port1 = suspend

	rGSTATUS3=(U32)StartPointAfterSleepWakeUp;	// memory control part in startup code.
	Uart_Printf("set restart address:%x\n", rGSTATUS3);
	rGSTATUS4=0xaaaaaaaa;

	Uart_TxEmpty(1);	//Wait until UART0 Tx buffer empty.
	ConfigSleepGPIO();
	ConfigMiscIO();

	rMISCCR=rMISCCR|(3<<0); 	// Data line pull-up disable.

	Lcd_EnvidOnOff(0); //Before entering Sleep mode, LCD must be off	

	rMISCCR = (rMISCCR & ~(0x7<<20)) | (6<<20);	// set 6.

	//=================================================================
	//  VERY IMPORTANT NOTE 
	//  To enter SLEEP/SLIDLE mode, MMU TLB-fill operation should be prohibited
	//   because MTT table is in SDRAM and SDRAM is in the self-refresh mode.
	//  So, we will fill TLB before entering SDRAM self-refresh 
	//   instead of disabling MMU.
	rREFRESH;//To fill TLB for the special register used in EnterPWDN
	rCLKCON;
	//=================================================================


	EnterPWDN(0xffff8); //Sleep mode
}


/************************ Sleep Mode by 100hz test ************************/
//================================================================================
void Check_SleepWakeUp_100Hz(void)
{
}

//================================================================================

void Test_SleepMode_100Hz(void)
{
}


void Test_StopMode(void)
{
	int i;
	U32 portStatus[33+3];	// +3 is for 2440 GPJ port.
	int error=0;
	int mode;
	Uart_Printf("[STOP Mode Test]\n");

	Uart_Printf("S3C2440 will wake up by EINT0 .\n");

	Uart_TxEmpty(1);	//Wait until UART0 Tx buffer empty.

	rMISCCR = (rMISCCR & ~(7<<8) & ~(7<<4)) | (3<<8) | (2<<4);	// CLKSEL0=FCLK, CLKSEL1=HCLK
// Save the port configurations
	for(i=0;i<33;i++) {
		portStatus[i]=*( (volatile U32 *)0x56000000 + i);	// 0x5600_0000:GPACON addr.
	}
	for(i=0;i<3;i++) 
		portStatus[i+33]=*( (volatile U32 *)0x560000d0 + i);	// 0x5600_00d0:GPJCON addr. added ffor 2440

	ConfigSleepGPIO();
	ConfigMiscIO();
   
	//Uart_Printf("S3C2440 will wake up by EINT0 (Falling Edge Triggered).\n");
	rGPFCON=rGPFCON & ~(3<<0)|(2<<0);	//GPF0=EINT0
	rEXTINT0=rEXTINT0&~(7<<0)|(0x2<<0);  //EINT0=falling edge triggered

	//Uart_Printf("S3C2440 will wake up by EINT11 (Falling Edge Triggered).\n");
	rGPGCON=rGPGCON & ~(3<<6)|(2<<6);	//GPG3=EINT11
	rEXTINT1=rEXTINT1&~(7<<12)|(2<<12);  //EINT11=falling edge triggered

	//Uart_Printf("\nNow, I am entering Stop mode.\n");
	Uart_TxEmpty(1);	//Wait until UART0 Tx buffer empty.
	
	pISR_EINT0	= (U32)Eint0Int;
	pISR_EINT8_23 = (U32)Eint8_23Int;
	pISR_RTC	  = (U32)AlarmInt;

	rEINTPEND = (1<<11); // clear EINT11 pending bit in rEINTPEND
	rSRCPND = BIT_EINT0 | BIT_RTC | BIT_EINT8_23;
	rINTPND = BIT_EINT0 | BIT_RTC | BIT_EINT8_23;

	rINTMSK = BIT_ALLMSK;
	//rINTMSK = ~BIT_EINT0;
	// NOTE: Any interrupt can't be used in Sleep mode 
	//	   because SDRAM is in self-refresh mode and ISR code will access SDRAM.


	rRTCCON=0x0;   // R/W disable, 1/32768, Normal(merge), No reset
	rADCCON|=(1<<2);	// ADC stanby.

	rMISCCR|=(1<<12); //USB port0 = suspend
	rMISCCR|=(1<<13); //USB port1 = suspend

	//rMISCCR|=(1<<2); //Previous state at Sleep mode. 
	rMISCCR &= ~(1<<2); //Previous state at STOP(?) mode (???)
					 
	//For SDRAM self-refresh mode, rMISCCR[2] should be 1.

	rMISCCR=rMISCCR|(3<<0); 

	Lcd_EnvidOnOff(0); //Before entering Sleep mode, LCD must be off	
	Delay(1);

	Led_Display(0x5);
	//rCLKSLOW=0x34;  //csh (???)debug
	
	//=================================================================
	//  VERY IMPORTANT NOTE 
	//  To enter STOP/SLIDLE mode, MMU TLB-fill operation should be prohibited
	//   because MTT table is in SDRAM and SDRAM is in the self-refresh mode.
	//  So, we will fill TLB before entering SDRAM self-refresh 
	//   instead of disabling MMU.
	rREFRESH;	//To fill TLB for the special register used in EnterPWDN
	rCLKCON;
	rMISCCR;
	rGPFDAT;
	//=================================================================
	rGPGDAT=rGPGDAT&~(1<<11)|(0<<11);	//GPG11(EINT19)=L

	EnterPWDN(0xffff1); //Sleep mode added for 2440 bit[19] camera.

	rCLKCON=0xffff0;	//Clear STOP_BIT & IDLE_BIT just after exiting Sleep mode.

	//rCLKSLOW=0x4; //csh (???) debug
	Uart_Printf("wake-up\n");

	// Restore I/O drive strength 
	rDSC0 = (1<<31)|(0<<8)|(0<<0);
	rDSC1 = (0<<28)|(0<<26)|(0<24)|(0<<22)|(0<<20)|(0<<18);

	//Restore the port configurations
	for(i=0;i<33;i++){
		*( (volatile U32 *)0x56000000 + i)=portStatus[i];
	}
	for(i=0;i<3;i++) 	// GPJ port
		*( (volatile U32 *)0x560000d0 + i)=portStatus[i+33];

	Led_Display(0xa);
	Lcd_EnvidOnOff(1); 
	
	Uart_Printf("SRCPND=%x,INTPND=%x\n",rSRCPND,rINTPND);
	rINTMSK =~(BIT_EINT0|BIT_RTC|BIT_EINT8_23);
	for(i=0;i<10;i++); 

	//The Wake-up source is indicated by rSRCPND.
	//The corresponding interrupt wiil be occurred here.

	rINTMSK =BIT_ALLMSK;
	Uart_Printf("Return to Normal Mode.\n");	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人激情文学综合网| 首页国产丝袜综合| 成人国产精品视频| 最新热久久免费视频| av男人天堂一区| 亚洲蜜臀av乱码久久精品| 欧美图区在线视频| 亚洲1区2区3区4区| 日韩欧美区一区二| 国产一区二区在线看| 欧美国产精品v| 91福利在线看| 天堂成人国产精品一区| 日韩亚洲欧美成人一区| 国产在线精品一区二区三区不卡| 国产亚洲一本大道中文在线| www.久久久久久久久| 一区二区三区不卡视频| 欧美丰满一区二区免费视频| 国产在线一区观看| 日韩毛片在线免费观看| 欧美一卡二卡三卡| 国产成人av一区| 亚洲午夜电影网| 久久综合色婷婷| 色一情一乱一乱一91av| 免费观看在线综合色| 国产精品亲子乱子伦xxxx裸| 日本黄色一区二区| 国模套图日韩精品一区二区| 亚洲欧美日韩综合aⅴ视频| 欧美一区二区三区免费视频| 粉嫩嫩av羞羞动漫久久久| 午夜久久久影院| 久久老女人爱爱| 欧美日韩免费不卡视频一区二区三区| 国产一区在线看| 亚洲成人动漫在线免费观看| 国产午夜精品一区二区三区嫩草 | 色婷婷亚洲精品| 久久99精品久久久| 亚洲欧美乱综合| 久久影院电视剧免费观看| 欧美视频第二页| 成人一区二区三区视频| 日本中文在线一区| 亚洲欧美一区二区三区久本道91 | 日韩精品乱码免费| 亚洲人亚洲人成电影网站色| 精品电影一区二区| 777xxx欧美| 日本高清免费不卡视频| 丁香婷婷综合色啪| 久久99久久久久| 亚洲国产裸拍裸体视频在线观看乱了 | 色爱区综合激月婷婷| 国产大片一区二区| 卡一卡二国产精品 | 色婷婷狠狠综合| 国产福利一区在线| 久久精品国产亚洲a| 婷婷成人激情在线网| 亚洲一区在线免费观看| 亚洲丝袜另类动漫二区| 中文字幕制服丝袜一区二区三区| 精品免费一区二区三区| 日韩一区二区免费高清| 欧美三级视频在线观看| 欧美在线一二三四区| 在线观看日韩高清av| 99r国产精品| av在线这里只有精品| 高潮精品一区videoshd| 国产成人午夜高潮毛片| 国产自产高清不卡| 国产不卡高清在线观看视频| 国产一区不卡精品| 国产激情偷乱视频一区二区三区 | 粗大黑人巨茎大战欧美成人| 国产一区二区三区精品欧美日韩一区二区三区| 日本vs亚洲vs韩国一区三区二区 | 激情综合网av| 激情图片小说一区| 国产精品123| www.在线成人| 色综合婷婷久久| 欧美中文字幕一区| 欧美日韩久久一区| 日韩欧美亚洲国产另类| 欧美r级电影在线观看| 精品国产欧美一区二区| 国产欧美一区二区精品忘忧草 | 国产精品国产成人国产三级| 亚洲视频网在线直播| 亚洲www啪成人一区二区麻豆 | 一区二区在线观看免费| 亚洲一区二区三区在线看| 日韩黄色片在线观看| 开心九九激情九九欧美日韩精美视频电影| 久久国产麻豆精品| 成人免费视频一区| 欧洲一区在线电影| 日韩午夜av电影| 欧美激情中文不卡| 亚洲一区二区四区蜜桃| 麻豆精品一二三| 床上的激情91.| 欧美日韩久久久久久| 精品国产免费一区二区三区香蕉| 国产精品成人一区二区艾草| 亚洲一区在线观看视频| 久久99精品国产.久久久久久| 成人免费毛片高清视频| 一本大道久久精品懂色aⅴ| 欧美一二三四区在线| 国产情人综合久久777777| 一区二区三区精品视频在线| 久久99国产精品免费网站| 91丨porny丨国产| 欧美一级高清片| 亚洲欧美偷拍另类a∨色屁股| 日韩电影一二三区| www.综合网.com| 日韩午夜在线观看| 亚洲少妇30p| 精品综合久久久久久8888| 91免费国产在线观看| 亚洲精品一区二区三区在线观看| 亚洲欧美日韩人成在线播放| 麻豆成人免费电影| 91精品办公室少妇高潮对白| 久久久久久久网| 亚洲国产sm捆绑调教视频 | 亚洲一区二区三区小说| 国产精品亚洲综合一区在线观看| 欧美日韩久久不卡| 成人免费在线视频观看| 激情欧美一区二区| 欧美日韩亚洲另类| 亚洲视频一区在线| 高清视频一区二区| 日韩欧美专区在线| 亚洲不卡av一区二区三区| 色综合网站在线| 国产精品国产三级国产aⅴ中文 | 日本欧美在线看| 91美女在线看| 欧美国产国产综合| 国产一区久久久| 日韩欧美国产电影| 青娱乐精品视频| 91麻豆精品国产91久久久久久 | 蜜桃视频一区二区| 欧美日本在线观看| 一级精品视频在线观看宜春院| 夫妻av一区二区| 欧美精彩视频一区二区三区| 激情丁香综合五月| 欧美不卡激情三级在线观看| 丝袜脚交一区二区| 欧美日韩在线播放三区四区| 综合av第一页| 色悠悠久久综合| 亚洲色图一区二区三区| 成人福利视频在线| 国产精品色在线观看| 国产黄人亚洲片| 国产精品日韩精品欧美在线| 国产91露脸合集magnet| 欧美—级在线免费片| 暴力调教一区二区三区| 综合婷婷亚洲小说| 色婷婷av一区二区三区之一色屋| 亚洲美女视频一区| 在线免费视频一区二区| 亚洲国产精品一区二区www在线 | 色综合久久久久网| 一区二区三区蜜桃网| 欧美日韩久久久| 蜜桃av一区二区在线观看| 欧美mv日韩mv国产| 国产成人综合视频| 国产精品久久一级| 日本韩国精品在线| 丝袜美腿亚洲一区二区图片| 欧美成va人片在线观看| 国产成人日日夜夜| 亚洲欧美偷拍卡通变态| 67194成人在线观看| 毛片av中文字幕一区二区| 国产女人18毛片水真多成人如厕| 成人黄色大片在线观看| 亚洲欧美欧美一区二区三区| 欧美精品99久久久**| 国产一区二区三区在线观看免费| 国产视频一区二区在线| 99国内精品久久| 日韩二区在线观看| 国产欧美日韩久久| 欧美午夜电影一区|