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

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

?? idle.c

?? 51eda s3c44b0 測試程序
?? C
字號:
#include "..\inc\44b.h"
#include "..\inc\44blib.h"
#include "..\inc\def.h"
#include "..\inc\idle.h"
#include "..\inc\rtc.h"

void SLIdleMode(void); //160x240


int debug;

int t0cnt,t1cnt;


void __irq Eint45Int(void)
{
    rEXTINTPND=0xf;		//clear EXTINTPND reg.
    rI_ISPC=BIT_EINT4567;
    Uart_Printf("EINT45 ISR is occurred for wake-up from IDLE mode.\n");
}


void __irq Timer0Int(void)
{
    int i;
    //for(i=0;i<10000;i++);
    rI_ISPC=BIT_TIMER0;
    for(i=0;i<100;i++); //why???
    t0cnt++;
}


void __irq Timer1Int(void)
{
    rI_ISPC=BIT_TIMER1;
    t1cnt++;
}


void __irq AlarmInt(void)
{
    rI_ISPC=BIT_RTC;
    Uart_Printf("ALARM ISR is occurred for wake-up from IDLE mode.\n");
}

void __irq SlEint45Int(void)
{
    rEXTINTPND=0xf;		//clear EXTINTPND reg.
    rI_ISPC=BIT_EINT4567;
    debug=1;   
    //????
    //why does not this interrupt occur in SL-IDLE mode? 
    //????
}

void __irq SlAlarmInt(void)
{
    //If you have to use the internal peripherals, 
    //you must configure CLKCON,CLKSLOW,PLL   

    rI_ISPC=BIT_RTC;
    debug=2;
}




/**********************
 *   IDLE mode test   *
 **********************/

void Test_IdleMode(void)
{
    int i;
    int extintMode;
    Uart_Printf("[IDLE Mode Test]\n");
    Uart_Printf("Check the current cunsumption. Push the buttons to exit IDLE mode.\n");
    Uart_Printf("After 10 seconds, S3C44B0X will wake up by RTC alarm interrupt.\n");
    Uart_Printf("S3C44B0X will also wake up by EINT4/5.\n");
    Uart_Printf("1.L-LEVEL  2.H-LEVEL  3.F-EDGE  4.R-EDGE  5.B-EDGE\n");
    Uart_Printf("Select the external interrupt type. Press the number!!!\n");
    extintMode=Uart_Getch();

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

    rPCONG=0xf00;	//PG2=EINT2

    switch(extintMode)
    {
    case '1':
    	rEXTINT=0x0;	//low
    	break;
    case '2':
    	rEXTINT=0x11111111;	//high
    	break;
    case '3':
    	rEXTINT=0x22222222;	//falling
    	break;
    case '4':
     	rEXTINT=0x44444444;	//rising
     	break;
    case '5':
    	rEXTINT=0x66666666;	//both edge
    	break;
    default:
    	break;
    }

    Rtc_Init();
 
    rRTCCON = 0x01;    // R/W enable, 1/32768, Normal(merge), No reset

    rALMYEAR=TESTYEAR2 ;
    rALMMON =TESTMONTH2;
    rALMDAY =TESTDAY2  ;
    rALMHOUR=TESTHOUR2 ;
    rALMMIN =TESTMIN2  ;
    rALMSEC =TESTSEC2+9;

    rRTCALM=0x7f;

    rI_ISPC=BIT_EINT4567|BIT_RTC;	//to clear the previous pending status.
    Uart_Printf("rINTPND=%x\n",rINTPND);
    
    pISR_EINT4567=(U32)Eint45Int;
    pISR_RTC=(U32)AlarmInt;
    rINTMSK=~(BIT_GLOBAL|BIT_EINT4567|BIT_RTC);
    for(i=0;i<2;i++);	//wait until the pended interrupt is executed.
    
    rCLKCON=0x7ff8|0x4;  //enter IDLE mode.
    //Uart_Getch();    
    for(i=0;i<10;i++);   //wait until S3C44B0X enters IDLE mode.	

    // wait EINT[7:0] interrupt or alarm wake-up

    rCLKCON=0x7ff8;      
    //turn-off IDLE bit on rCLKCON to synchronize rCLKCON with the real mode.

    Uart_Printf("Return to Normal Mode.\n");

    rINTMSK=BIT_GLOBAL;
}




void Test_IdleModeHard(void)
{   
    int i,j;
    
    Uart_Printf("[IDLE Mode Test with Timer0,1 10000times]\n");
    Uart_Printf("S3C44B0X will also wake up by EINT4/5.\n");
    Uart_TxEmpty(0);    //Wait until UART0 Tx buffer empty.


    rPCONG=0xf00;	//PG2=EINT2
    rEXTINT=rEXTINT&~(7<<8)|(2<<8);	//falling

    pISR_TIMER0=(U32)Timer0Int; 
    pISR_TIMER1=(U32)Timer1Int;
    pISR_EINT4567=(U32)Eint45Int;
    
    rTCFG0=0x00010110;	//PRESC01,23,45= 1
    rTCFG1=0x00000000; 	//TIMER0,1,2,3,4,5= 1/2    
    rTCNTB0=65535;	
    rTCNTB1=2570;
    //rTCON=0xa0a;	//T1=MU,ITV,T0=MU,ITV
    //rTCON=0x909;	//Start T0,T1.
    rTCON=0x00a;
    rTCON=0x009;

    rINTMSK=~(BIT_GLOBAL|BIT_EINT4567|BIT_TIMER0|BIT_TIMER1);
    //rINTMSK=~(BIT_GLOBAL|BIT_EINT2);

    //The two timer will test the IDLE mode hard.
     
    for(i=0;i<10000;i++)
    {
    	rCLKCON=0x7ff8|0x4;  //enter IDLE mode.

    	for(j=0;j<10;j++);   //wait until KS32C41100 enters IDLE mode.
    	//wake up from normal mode
    	
    	rCLKCON=0x7ff8;      
    	//turn-off IDLE bit on rCLKCON to synchronize rCLKCON with the real mode.
    	Uart_Printf(".");
    }
    
    rTCON=0x0; //timer off
    rINTMSK=BIT_GLOBAL;
}




/*********************
 * SL_IDLE mode test *
 *********************/

#define MVAL_USED	(0)
#define MVAL 		(13)
#define L248 		(8)
#define CLKVAL_SL	(38)	// 60Mhz, fr=100Hz (CLKVAL=38.6)


#define M5D(n) ((n) & 0x1fffff)

unsigned int (*_frameBuffer4)[10];

void LcdInit_4Gray160x240(void);
void Display_4Gray160x240(void);



void Test_SLIdleMode20(void)
{
    int i;
    LcdInit_4Gray160x240();
    Display_4Gray160x240();
    Delay(1000); //wait more than 1 frame time.     
    for(i=0;i<20;i++)SLIdleMode();
}



void Test_SLIdleMode(void)
{
    LcdInit_4Gray160x240();
    Display_4Gray160x240();
    Delay(1000); //wait more than 1 frame time.     
    SLIdleMode();
}



void SLIdleMode(void) //160x240
{
    int i;
    int saveDramcon;
    debug=0;
    Uart_Printf("[SL_IDLE MODE TEST for 160x240]\n");
    Uart_Printf("After 10 seconds, S3C44B0X will wake up by RTC alarm interrupt.\n");
    Uart_Printf("S3C44B0X can wake up by EINT4/5.\n");
    Uart_TxEmpty(0);

    rPCONG=0xf00;	//PG2=EINT2
    rEXTINT=0x22222222;	//falling

    //pISR_EINT2=(U32)SlEint2Int;
    //pISR_RTC=(U32)SlAlarmInt;
    //rINTMSK=~(BIT_GLOBAL|BIT_EINT2|BIT_RTC);

    //If you want to use interrupt generation,the ISR should be on ROM/SRAM
    //(DRAM can't be allowed because of DRAM self-refresh)
    
    Rtc_Init();
    rRTCCON = 0x01;    // R/W enable, 1/32768, Normal(merge), No reset


    rALMYEAR=TESTYEAR2 ;
    rALMMON =TESTMONTH2;
    rALMDAY =TESTDAY2  ;
    rALMHOUR=TESTHOUR2 ;
    rALMMIN =TESTMIN2  ;
    rALMSEC =TESTSEC2+9; 
    //rALMSEC =TESTSEC2+1; 

    rRTCALM=0x7f;   //To test alarm wake-up.
    
    rADCCON|=0x20;  //ADC power down mode

    //
    // The I/O ports have to be configured properly to reduce STOP mode current.
    //
    
    
    //           LINECNT  4n+m th line
    //  1st line 239      4n+1th       
    //  2nd line 238      4n+2th 
    //  3rd line 237      4n+3th 
    //  4th line 236      4n  th 
    //   ....
    //236th line 4        4n  th   
    //237th line 3        4n+1th   
    //238th line 2        4n+2th   
    //239th line 1        4n+3th   
    //240th line 0        4n  th   


    while((rLCDCON1>>22)!=9);   
    while((rLCDCON1>>22)!=8);   
    // To enter self-refresh mode, the VCLK has to be 'L' after 4n-th line is displayed completely,
    // So,the self-refresh command has to be issued at 4n th line.
    // VCLK will be 'L' from 4n+1th line.

    //for(i=0;i<10;i++); 
    rLCDCON3=0x1;  //Enter self-refresh mode.
        
    while((rLCDCON1>>22)!=0); 

    //Because the SLOW mode is used, the LCDCON1,2 should be changed.
    rLCDCON1=(0)|(1<<5)|(MVAL_USED<<7)|(0x0<<8)|(0x0<<10)|(1/*CLKVAL*/<<12);
	// disable,4B_SNGL_SCAN,WDLY=2clk,WLH=2clk
    rLCDCON2=(239+L248)|(15/*39*/<<10)|(1<<21);  //LINEBLANK=1
    rCLKSLOW=2|(1<<4)|(1<<5); //SLOWVAL=2,Fout=Fin/(2x2),PLL off. 
    //DRAM refresh may not be done because of slow MCLK. but,the abnormal period is very short.
    rLCDCON1=(1)|(1<<5)|(MVAL_USED<<7)|(0x0<<8)|(0x0<<10)|(1<<12);


    saveDramcon=rREFRESH; 
    rREFRESH=(2017)|(0<<22)|(1<<23); 
    //15,6us@2Mhz, tchr,trc,trp=min, refresh enable. 
    // DRAM refresh may not be done every 15.6uS 
    // because of slow MCLK(1Mhz) and long memory access cycle. 
           
    EnterPWDN(0x46);  //enters SL_IDLE mode. rCLKCON=0x46   
                      //DRAM/SDRAM self-refresh is executed in EnterPWDN()
    //NOTE:
    //Any special registers setting will not accepted because CPU is not normal mode.
    
    rCLKCON=0x7ff8;  

    rCLKSLOW=2|(1<<4)|(0<<5); //SLOWVAL=2,Fout=Fin/(2x2),PLL on.   
    for(i=0;i<2048;i++);      //Wait PLL lock time.
    
    while((rLCDCON1>>22)!=1); 
    while((rLCDCON1>>22)!=0);     

    //Because the SLOW mode is exited, the LCDCON1,2 should be changed.
    rLCDCON1=(0)|(1<<5)|(MVAL_USED<<7)|(0x3<<8)|(0x3<<10)|(CLKVAL_SL<<12);
	    // disable,4B_SNGL_SCAN,WDLY=8clk,WLH=8clk,
    rLCDCON2=(239+L248)|(39<<10)|(10<<21); //HOZVAL=39,LINEBLANK=1
    rCLKSLOW=2;      //SLOWVAL=2,Fout=Fpllo,PLL on.   

    rLCDCON3=0x0; //LCD self refresh mode off.

    rLCDCON1=(1)|(1<<5)|(MVAL_USED<<7)|(0x3<<8)|(0x3<<10)|(CLKVAL_SL<<12);

    rREFRESH=saveDramcon;    

    while((rLCDCON1>>22)!=1); 
    while((rLCDCON1>>22)!=0); //Display 1 more frame before exiting SL_IDLE mode. 
                              //why? no reason. it may be better.  

    //while((rLCDCON1>>22)!=9);   
    //while((rLCDCON1>>22)!=8);  //to catch the exit time for SL_IDLE mode.
    //rLCDCON3=0x0; //LCD self refresh mode off.

    //for(i=0;i<10;i++); 

    rADCCON&=~(0x20);
    
    rEXTINTPND=0xf;	//Clear EXTINTPND register

    Uart_Printf("debug=%d\n",debug);
    Uart_Printf("I have exited LCD SELFREF mode.\n");
}



void LcdInit_4Gray160x240(void)
{
	if((U32)_frameBuffer4==0)
	{
	    _frameBuffer4=(unsigned int (*)[10])malloc(10*4*240); 
	}

	rLCDCON1=(0)|(1<<5)|(MVAL_USED<<7)|(0x3<<8)|(0x3<<10)|(CLKVAL_SL<<12);
	    // disable,4B_SNGL_SCAN,WDLY=8clk,WLH=8clk,CLKVAL=?
	rLCDCON2=(239+L248)|(39<<10)|(10<<21);
	    //LINEBLANK=10 (without any calculation) 
	rLCDSADDR1= (0x1<<27) | ( ((U32)_frameBuffer4>>22)<<21 ) | M5D((U32)_frameBuffer4>>1);
	    // 4-gray, LCDBANK, LCDBASEU
	rLCDSADDR2= M5D((((U32)_frameBuffer4+((160/4)*(240+L248)))>>1)) | (MVAL<<21);
	rLCDSADDR3= (160/8) | ( 0<<9 );   
	    //No virtual screen. 

	//The following value has to be changed for better display.
	//Select 4 levels among 16 gray levels.

	rBLUELUT=0xfa40; 
	rDITHMODE=0x0;
	rDP1_2 =0xa5a5;      
	rDP4_7 =0xba5da65;
	rDP3_5 =0xa5a5f;
	rDP2_3 =0xd6b;
	rDP5_7 =0xeb7b5ed;
	rDP3_4 =0x7dbe;
	rDP4_5 =0x7ebdf;
	rDP6_7 =0x7fdfbfe;

	rLCDCON1=(1)|(1<<5)|(MVAL_USED<<7)|(0x3<<8)|(0x3<<10)|(CLKVAL_SL<<12);
	    // enable,4B_SNGL_SCAN,WDLY=8clk,WLH=8clk,CLKVAL=?
}




void Display_4Gray160x240(void)
{
    int i,j;

    for(j=0;j<100;j++)
        for(i=2;i<10;i++)
        {
            _frameBuffer4[j][i]=0x55aa55aa;
        }

    for(j=0;j<100;j++)
    {
        _frameBuffer4[j][9]=0x5555ffff;
    }


    for(j=100;j<240;j++)
        for(i=2;i<10;i++)
            _frameBuffer4[j][i]=0x0;
            
   
    for(i=2;i<10;i++)
        _frameBuffer4[100][i]=0xffffffff;
    for(i=2;i<10;i++)
        _frameBuffer4[0][i]=0xffffffff;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品第1页| 国产一区二区在线观看视频| 久久久久久久精| 日韩欧美国产一区二区三区| 欧美在线一区二区| 欧美午夜在线一二页| 成人av网址在线| 99精品在线观看视频| 99视频国产精品| 91丨porny丨蝌蚪视频| 波多野结衣亚洲| eeuss鲁一区二区三区| 不卡一卡二卡三乱码免费网站| 成人网在线播放| 不卡高清视频专区| 97久久超碰国产精品| 色偷偷久久人人79超碰人人澡| av不卡一区二区三区| 91国在线观看| 宅男在线国产精品| 欧美一区二区三区喷汁尤物| 日韩欧美精品三级| 中文字幕第一区第二区| 亚洲特级片在线| 亚洲成人久久影院| 看片网站欧美日韩| 国产高清亚洲一区| 91色视频在线| 日韩欧美国产小视频| 国产欧美日韩激情| 亚洲香肠在线观看| 国产在线精品免费av| 久久九九99视频| 色诱视频网站一区| 欧美高清性hdvideosex| 91精品福利视频| 国产精品自在欧美一区| 欧美亚洲图片小说| 亚洲一区在线观看免费| eeuss影院一区二区三区| 欧美国产激情二区三区| 国产成人在线免费观看| ww亚洲ww在线观看国产| 激情成人午夜视频| 国产欧美精品日韩区二区麻豆天美| 久久国产综合精品| 久久久国产一区二区三区四区小说 | 精品视频一区二区不卡| 一二三四区精品视频| 欧美系列一区二区| 日本v片在线高清不卡在线观看| 在线综合视频播放| 极品尤物av久久免费看| 国产情人综合久久777777| 欧美一区二区三区在线视频 | 日日夜夜一区二区| 日韩一卡二卡三卡四卡| 久久99精品久久只有精品| 久久人人97超碰com| 福利视频网站一区二区三区| 综合在线观看色| 欧美日本乱大交xxxxx| 久久99久久久欧美国产| 久久欧美中文字幕| 99re这里只有精品视频首页| 亚洲一本大道在线| 91精品国产综合久久蜜臀| 国产在线精品一区二区不卡了| 欧美激情一区二区在线| 欧美性色黄大片| 国产91色综合久久免费分享| 亚洲啪啪综合av一区二区三区| 欧美日韩久久不卡| 国产一区久久久| 亚洲一区日韩精品中文字幕| 精品国产伦一区二区三区观看体验| 成人av小说网| 久久国产夜色精品鲁鲁99| 亚洲视频一区二区在线| 日韩欧美123| 91久久精品一区二区二区| 久久精品国产久精国产| 亚洲精品乱码久久久久久黑人| 日韩欧美国产高清| 在线观看日韩高清av| 国产乱码精品一区二区三| 亚洲国产美国国产综合一区二区| 久久久噜噜噜久久中文字幕色伊伊| 色偷偷88欧美精品久久久| 国产尤物一区二区在线| 午夜精品久久久久久久99水蜜桃| 国产午夜精品久久久久久免费视| 欧美日韩一区二区欧美激情| 成人午夜电影网站| 精彩视频一区二区三区| 亚洲h动漫在线| 亚洲欧美日韩电影| 国产精品人人做人人爽人人添| 7777精品伊人久久久大香线蕉| 91丨porny丨国产入口| 国产二区国产一区在线观看| 日本不卡一二三区黄网| 亚洲成人在线观看视频| 亚洲女人的天堂| 亚洲欧洲国产专区| 国产精品午夜电影| 国产欧美精品在线观看| 久久先锋资源网| 精品黑人一区二区三区久久| 欧美精品vⅰdeose4hd| 欧美色爱综合网| 色老头久久综合| 91精品1区2区| 欧美在线高清视频| 欧美色综合久久| 欧美三片在线视频观看| 在线观看精品一区| 欧美少妇xxx| 在线播放中文字幕一区| 欧美视频一二三区| 欧美日韩国产在线播放网站| 欧美性大战久久久久久久蜜臀 | 亚洲九九爱视频| 亚洲精品免费看| 夜夜操天天操亚洲| 午夜激情一区二区三区| 日韩va亚洲va欧美va久久| 免费日韩伦理电影| 狠狠久久亚洲欧美| 国产精品911| 99久久婷婷国产综合精品电影| 91在线观看视频| 欧美日韩国产首页| 欧美大度的电影原声| 国产午夜精品在线观看| 国产精品女同互慰在线看| 成人免费在线观看入口| 亚洲一区二区精品视频| 日韩电影一区二区三区| 国产一区二区电影| 99视频在线精品| 欧美三级在线看| 国产精品你懂的在线欣赏| 亚洲免费电影在线| 另类欧美日韩国产在线| 国产成人午夜精品5599| 色av成人天堂桃色av| 欧美一区二区三区播放老司机| 久久婷婷色综合| 日韩美女精品在线| 欧美a一区二区| 成人一区在线看| 欧美精品777| 国产亚洲婷婷免费| 亚洲一区二区精品视频| 国产精一区二区三区| 在线精品国精品国产尤物884a| 欧美一级日韩免费不卡| 国产精品国产a级| 免费精品视频最新在线| 9l国产精品久久久久麻豆| 日韩一区二区三区四区 | jiyouzz国产精品久久| 欧美美女黄视频| 亚洲欧洲日韩一区二区三区| 日本欧美一区二区在线观看| 成人app网站| 日韩精品一区二区三区中文精品| 国产精品沙发午睡系列990531| 视频一区二区三区在线| 972aa.com艺术欧美| 久久蜜臀中文字幕| 天天影视色香欲综合网老头| 不卡电影一区二区三区| 精品国产一区二区精华| 午夜视频在线观看一区| 成人av网站免费观看| 久久先锋影音av| 青青青伊人色综合久久| 在线观看亚洲一区| 国产精品护士白丝一区av| 久久狠狠亚洲综合| 91精品国产一区二区三区| 亚洲男同性视频| 成人激情图片网| 国产欧美视频在线观看| 美女一区二区视频| 欧美一区日韩一区| 久久99这里只有精品| 欧美日韩一级二级| 伊人一区二区三区| 99久久精品费精品国产一区二区 | 在线欧美小视频| 中文字幕日本不卡| 成人深夜视频在线观看| 久久精品人人做| 国产福利91精品一区二区三区| 精品国产1区2区3区| 精品一区二区三区视频| 日韩美女视频在线|