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

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

?? control.c

?? ARM7的一些試驗程序
?? C
字號:
#include "def.h"
#include "44b.h"
#include "option.h"
#include "utils.h"


void PortInit(void)
{
	// PORT A GROUP
	/*  BIT 9	8	7	6	5	4	3	2	1	0	*/
	/*  A24	  A23	A22	A21	A20	A19	A18	A17	A16	A0	*/	      
	/*  1		1	1	1	1	1	1	1	1	1	*/
	rPCONA = 0x3ff;	

	// PORT B GROUP
	/* BIT 10   9    8       7      6        5     4     3     2     1     0    */
	/*     /CS5 /CS4 /CS3    /CS2   /CS1     nWBE3 nWBE2 /SRAS /SCAS SCLS  SCKE	*/
	/*     NC   NC   RTL8019 USBD12 NV_Flash NC    NC    Sdram Sdram Sdram Sdram*/
	/*     1,   1,   1,      1,     1,       0,    0,    1,    1,    1,    1    */
	rPDATB = 0x7cf;
    
	//PORT C GROUP
	//BUSWIDTH=16													*/
	/*  PC15		14		13		12		11		10		9		8	*/
	/*	o		o		RXD1	TXD1	o		o		o		o	*/
	/*	NC		NC		Uart1	Uart1	NC		NC		NC		NC	*/
	/*   01		01		11		11		01		01		01		00	*/

	/*  PC7		6		5		4		3		2		1		0	*/
	/*   o		o		o		o		o		o		o		o	*/
	/*   NC		NC		NC		NC		NFALE 	NFCLE 	NFCE 	NFRB*/
	/*   01		01		01		01		01		01		01		00	*/
#ifdef FS44B0_BOARD
	rPDATC = 0x0100;	//All IO is low, PC8 = 1 LCD-Off, PC9 = 0 BackLight Off
	rPCONC = 0xfff5ff54;	//0->D12SUSPD, 1~3->LED, 4~7->VD7~VD4, 8->DISPON, 9->BACKLIGHT, 10~13->UART1, 14->RTS0, 15->CTS0
	rPUPC  = 0x0000;	//disable all pull-up
#elif defined ST44B0_BOARD
	rPDATC = 0x0300;	//All IO is low, PC8 = 1 LCD-Off, PC9 = 1 BackLight Off
	rPCONC = 0x0005ff00;	//0~3->input, 4~7->VD7~VD4, 8->DISPON, 9->BACKLIGHT, 10~15->input
	rPUPC  = 0x0000;	//disable all pull-up
#else
	rPDATC = 0x0100;	//All IO is low, PC8 = 1 LCD-Off, PC9 = 0 BackLight Off
	rPCONC = 0xfff5ff54;	//0->D12SUSPD, 1~3->LED, 4~7->VD7~VD4, 8->DISPON, 9->BACKLIGHT, 10~13->UART1, 14->RTS0, 15->CTS0
	rPUPC  = 0x0000;	//disable all pull-up
#endif	

	//PORT D GROUP
	/*  PORT D GROUP(I/O OR LCD)										*/
	/*  BIT7		6		5		4		3		2		1		0	*/
	/*      VF		VM		VLINE	VCLK	VD3		VD2		VD1		VD0	*/
	/*	   10		10		10		10		10		10		10		10	*/
	rPCOND= 0xaaaa;	
	rPUPD = 0x00;
	//These pins must be set only after CPU's internal LCD controller is enable
	
	//PORT E GROUP 
	/*  Bit 8		7		6		5		4		3		2		1		0		*/
	/*		ENDLAN	LED3	LED2	LED1	LED0	BEEP	RXD0	TXD0	CLKOUT	*/ 
	/*      10		01		01		01		01		01		10		10		11		*/
#ifdef FS44B0_BOARD
	rPCONE	= 0x20828;	//0->input, 1 2->TXD0 RXD0, 3 4 6 7->input, 5->beep, 8->CODECLK
	rPUPE	= 0x000;	//disable all pull-up
#elif defined ST44B0_BOARD
	rPDATE	= 0x70;
	rPCONE	= 0x15ab;	//0->FOUT, 1 2->TXD0 RXD0, 3->beep, 4~6->LED, 7->input, 8->ENDIAN
	rPUPE	= 0x000;	//disable all pull-up
#else
	rPCONE	= 0x26568;	//0->input, 1 2->TXD0 RXD0, 3 4->input, 5->led, 6->buzzer, 7->led, 8->CODECLK
	rPDATE	= 0x70;
	rPUPE	= 0x000;	//disable all pull-up
#endif	
	
	//PORT F GROUP
	/*  Bit8		7		6		5		 4		3		2		1		0		*/   
	/*  IISCLK	IISDI	IISDO	IISLRCK	Input	Input	Input	IICSDA	IICSCL	*/
	/*	100		100		100		100		00		01		01		10		10		*/
#ifdef 	FS44B0_BOARD
	rPCONF = 0x24900a;	//0 1->IICSCL IICSDA, 2~4->input 5~8->IIS PORT
	rPUPF  = 0x000;		//disable all pull-up
#elif defined ST44B0_BOARD
	rPCONF = 0x24000;	//0~5->input, 6 7->TXD1 RXD1, 8->input
	rPUPF  = 0x000;		//disable all pull-up
#else
	rPCONF = 0x24900a;	//0 1->IICSCL IICSDA, 2~4->input 5~8->IIS PORT
	rPUPF  = 0x000;		//disable all pull-up
#endif

	//PORT G GROUP
	/*  BIT7		6		5		4		3		2		1		0	 */
	/*	INT7		INT6		INT5		INT4		INT3		INT2		INT1		INT0	*/
	/*    S3		S4		S5		S6		NIC		EXT		IDE		USB	*/
	/*      11      11      11      11      11      11      11      11       */
	rPCONG = 0xff3c;	//eint1 is eth interrupt in FS44B0, eint2 for ide
	rPUPG  = 0x00;		//disable all pull-up
	
//	rSPUCR = 0x7;  //D15-D0 pull-up disable
	rSPUCR = 0x6;  //D15-D0 pull-up enable

	/*所有的外部硬件中斷為低電平觸發*/
	//rEXTINT = 0x0;
// need for uClinux	
//	rEXTINT = 0x42;				//所有的外部硬件中斷為低電平觸發, extint0 為下降沿,extint1為上升沿	
	rEXTINT = (4<<16)|(4<<8)|(4<<4);	//EINT1上升沿,EINT2上升沿,EINT4上升沿中斷
//	rINTCON = 5;				// non vector mode, irq enable
//	rINTMOD = 0;				//all are irq mode
}

void Beep(U32 freq, U32 ms)
{
#ifdef FS44B0_BOARD
	rPCONE &= ~(3<<10);
	rPCONE |= (2<<10);
	
	rTCON  	&= ~0xf000;				// clear manual update bit, stop Timer2
	rTCFG0 	&= ~0xff00;				// set Timer 2&3 prescaler 0
	rTCFG1 	&= ~0xf00;				// set Timer 2 MUX 1/16
	rTCFG1  |= 0x300;	
	rTCNTB2	 = GetCpuClock()/(2100*16);		//if set inverter off, when TCNT2<=TCMP2, TOUT is high, TCNT2>TCMP2, TOUT is low
	rTCMPB2  = rTCNTB2>>1;			//if set inverter on,  when TCNT2<=TCMP2, TOUT is low,  TCNT2>TCMP2, TOUT is high
	rTCON	|= 0x2000;				// manual update
	rTCON	&= ~0x2000;				// clear manal update bit
	rTCON   |= 0xd000;				// auto reload, inverter on, start Timer 2	
	
	Delay(ms);
	
	rTCON &= ~0x1000;
	
	rPCONE &= ~(3<<10);
	rPCONE |= 1<<10;
	rPDATE &= ~(1<<5);
	
#elif defined ST44B0_BOARD

	rTCON  	&= ~0x1f;				// clear manual update bit, stop Timer0
	rTCFG0 	&= ~0xff;				// set Timer 0&1 prescaler 0
	rTCFG1 	&= ~0xf;				// set Timer 0 MUX 1/16
	rTCFG1  |= 3;	
	rTCNTB0	 = GetCpuClock()/(2100*16);
	rTCMPB0  = rTCNTB0>>1;				
	rTCON   |= 2;
	rTCON   &= ~2;
	rTCON	|= 0xd;					//auto-reload, inverter off, manual update, start timer	

	Delay(ms);
	
	rTCON &= ~1;					//stop
#else

	rTCON  	&= ~0xf0000;			// clear manual update bit, stop Timer3
	rTCFG0 	&= ~0xff00;				// set Timer 2&3 prescaler 0
	rTCFG1 	&= ~0xf000;				// set Timer 3 MUX 1/16
	rTCFG1  |= 0x3000;
	rTCNTB3	 = GetCpuClock()/(2100*16);		//if set inverter off, when TCNT2<=TCMP2, TOUT is high, TCNT2>TCMP2, TOUT is low
	rTCMPB3  = rTCNTB3>>1;			//if set inverter on,  when TCNT2<=TCMP2, TOUT is low,  TCNT2>TCMP2, TOUT is high
	rTCON	|= 0x20000;				// manual update
	rTCON	&= ~0x20000;			// clear manal update bit
	rTCON   |= 0xd0000;				// auto reload, inverter on, start Timer 2	
	
	Delay(ms);
	
	rTCON &= ~0x10000;
	
#endif

}

#ifdef	FS44B0_BOARD
#define	LED1_ON()
#define	LED2_ON()	(rPDATC |= 2)
#define	LED3_ON()	(rPDATC |= 4)
#define	LED4_ON()	(rPDATC |= 8)
#define	LED1_OFF()	
#define	LED2_OFF()	(rPDATC &= ~2)
#define	LED3_OFF()	(rPDATC &= ~4)
#define	LED4_OFF()	(rPDATC &= ~8)
#elif defined ST44B0_BOARD
#define	LED1_ON()
#define	LED2_ON()	(rPDATE |= 0x10)
#define	LED3_ON()	(rPDATE |= 0x20)
#define	LED4_ON()	(rPDATE |= 0x40)
#define	LED1_OFF()
#define	LED2_OFF()	(rPDATE &= ~0x10)
#define	LED3_OFF()	(rPDATE &= ~0x20)
#define	LED4_OFF()	(rPDATE &= ~0x40)
#else
#define	LED1_ON()	(rPDATE |= 0x20)
#define	LED2_ON()	(rPDATC |= 2)
#define	LED3_ON()	(rPDATC |= 4)
#define	LED4_ON()	(rPDATC |= 8)
#define	LED1_OFF()	(rPDATE &= ~0x20)
#define	LED2_OFF()	(rPDATC &= ~2)
#define	LED3_OFF()	(rPDATC &= ~4)
#define	LED4_OFF()	(rPDATC &= ~8)
#endif

void LedSet(U32 LedStatus)
{
	if(LedStatus&1)
		LED1_ON();
	else
		LED1_OFF();
	
	if(LedStatus&2)
		LED2_ON();
	else
		LED2_OFF();
		
	if(LedStatus&4)
		LED3_ON();
	else
		LED3_OFF();
		
	if(LedStatus&8)
		LED4_ON();
	else
		LED4_OFF();
}

void MemCfgInit(void)
{
	rNCACHBE0 = ((unsigned int)(Non_Cache_End>>12)<<16)|(Non_Cache_Start>>12);
	rNCACHBE1 = (0xf000U<<16)|(0xe000);
#ifdef FS44B0_BOARD			//0 for FS44B0 BACK-LIGHT ON
	rBWSCON &= ~0xf000;		//8bits for RTL8019 in FS44B0 BOARD
#endif
}

void BoardInitStart(void)
{
}

void BoardInitEnd(void)
{
}

void CacheDisable(void)
{
	rSYSCFG = SYSCFG_0KB;
}

void CacheEnable(void)
{
	rSYSCFG = SYSCFG_8KB;
}

void CacheFlush(void)
{
	int i, saveSyscfg;
    
    saveSyscfg = rSYSCFG;

    rSYSCFG = SYSCFG_0KB;
    for(i = 0x10004000; i<0x10004800; i+=16)
		*((int *)i) = 0x0;
    rSYSCFG = saveSyscfg;
}

U16 GetKeyStatus(void)
{
	return (rPDATG>>4);
}

//nand flash operation
#define	SEL_SMART_MEDIA_CARD

#ifdef	SEL_SMART_MEDIA_CARD
#define	NAND_DAT	0x0e000000
#define	NAND_ALE	0x0e000004
#define	NAND_CLE	0x0e000002
#else
#define	NAND_DAT	0x02000000
#define	NAND_ALE	0x02000004
#define	NAND_CLE	0x02000002
#endif

void NFChipSel(U32 sel)
{
	if(sel)
		rPDATC &= ~(1<<9);
	else
		rPDATC |= 1<<9;
}

int NFIsReady(void)
{
	return rPDATC&(1<<8);
}

void NFWrCmd(int cmd)
{
	*(volatile U8 *)NAND_CLE = cmd;
}

void NFWrAddr(int addr)
{
	*(volatile U8 *)NAND_ALE = addr;
}

void NFWrDat(int dat)
{
	*(volatile U8 *)NAND_DAT = dat;
}

U8 NFRdDat(void)
{
	return *(volatile U8 *)NAND_DAT;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美色精品在线视频| 福利电影一区二区| 国产精品传媒入口麻豆| 欧美一区二区久久久| 欧美日韩一区在线| 色素色在线综合| av成人动漫在线观看| 大美女一区二区三区| 国产99精品国产| 国产精品18久久久久久久久久久久| 免费成人在线网站| 免费在线看成人av| 亚洲aaa精品| 亚洲激情中文1区| 亚洲男人的天堂在线aⅴ视频| 中文字幕精品—区二区四季| 国产亚洲婷婷免费| 国产精品免费看片| 成人欧美一区二区三区视频网页| 亚洲国产精品v| 亚洲婷婷综合色高清在线| 国产精品乱码一区二区三区软件| 欧美激情中文字幕一区二区| 国产精品久久三| 悠悠色在线精品| 日韩综合小视频| 狠狠色伊人亚洲综合成人| 国产黄色成人av| 91麻豆免费视频| 色国产精品一区在线观看| 欧美亚一区二区| 欧美电影免费观看完整版| 国产午夜精品久久久久久免费视 | 亚洲欧美日韩电影| 亚洲免费在线视频| 五月开心婷婷久久| 国产一区不卡视频| 91香蕉视频污| 欧美精品xxxxbbbb| 精品国精品自拍自在线| 中文幕一区二区三区久久蜜桃| 亚洲欧美另类久久久精品| 日韩av一区二区在线影视| 国产一区二区在线观看视频| 成人免费看黄yyy456| 日本国产一区二区| 精品国精品国产尤物美女| |精品福利一区二区三区| 午夜精品久久久久久久蜜桃app| 国内外成人在线视频| 91视频.com| 日韩亚洲欧美成人一区| 国产精品久久久久久久久免费桃花 | 亚洲综合在线五月| 日本欧美一区二区| 国产电影一区二区三区| 欧美午夜影院一区| 久久亚洲精华国产精华液| 亚洲二区在线观看| 国产精品羞羞答答xxdd| 欧美日韩免费观看一区二区三区| 久久免费电影网| 婷婷夜色潮精品综合在线| 成人av电影在线| 久久―日本道色综合久久| 亚洲国产精品视频| 色哟哟一区二区三区| 久久久久久久久久久久电影| 午夜电影一区二区| 色综合欧美在线视频区| 久久久天堂av| 麻豆一区二区三| 欧美日韩夫妻久久| 亚洲同性gay激情无套| 国产成人激情av| 日韩午夜三级在线| 午夜精品在线看| 在线精品观看国产| 亚洲日本在线天堂| 99久久精品99国产精品| 久久综合给合久久狠狠狠97色69| 调教+趴+乳夹+国产+精品| 色丁香久综合在线久综合在线观看| 色999日韩国产欧美一区二区| 中文欧美字幕免费| 国产麻豆视频一区二区| 制服.丝袜.亚洲.另类.中文 | 91精选在线观看| 亚洲精品中文字幕乱码三区 | 欧美日韩一区三区| 亚洲精品国产成人久久av盗摄| av中文一区二区三区| 国产精品久99| 91色九色蝌蚪| 亚洲精选一二三| 在线看一区二区| 一区二区成人在线观看| 欧洲视频一区二区| 亚洲电影视频在线| 欧美日韩成人综合天天影院| 亚洲123区在线观看| 欧美精品在线视频| 麻豆一区二区三| 久久综合狠狠综合| 丁香网亚洲国际| 亚洲精品高清在线| 欧美欧美午夜aⅴ在线观看| 视频一区视频二区中文字幕| 日韩一二三区不卡| 国产99一区视频免费| 一区二区中文字幕在线| 91精品福利视频| 日韩激情视频网站| 久久夜色精品国产噜噜av| 成人三级伦理片| 亚洲国产精品人人做人人爽| 日韩午夜中文字幕| 成人激情午夜影院| 一区二区免费视频| 精品国产亚洲在线| 99久久777色| 天天操天天综合网| 国产欧美日韩在线| 91久久精品一区二区三区| 美女视频一区二区| 国产精品成人免费在线| 欧美日韩另类国产亚洲欧美一级| 青青青伊人色综合久久| 国产精品污网站| 欧美精品18+| 波波电影院一区二区三区| 亚洲va在线va天堂| 国产喷白浆一区二区三区| 日本高清无吗v一区| 蜜桃一区二区三区在线| 国产精品乱码一区二区三区软件| 欧美日本在线播放| 成人精品小蝌蚪| 免费在线观看精品| 亚洲精品五月天| 2欧美一区二区三区在线观看视频| 91蜜桃视频在线| 国产资源在线一区| 亚洲国产一区二区a毛片| 国产亚洲精品超碰| 日韩午夜av电影| 91福利国产成人精品照片| 五月婷婷综合在线| 中文字幕中文在线不卡住| 精品美女被调教视频大全网站| 色香蕉成人二区免费| 国产精品99久久久久久久女警| 日韩一区精品视频| 亚洲欧美乱综合| 中文字幕va一区二区三区| 精品美女一区二区三区| 欧美精品1区2区| 精品视频一区三区九区| 99久久精品国产毛片| 国产成人综合亚洲91猫咪| 免费成人在线影院| 午夜一区二区三区视频| 樱桃视频在线观看一区| 亚洲日本va午夜在线影院| 欧美激情在线一区二区三区| 日韩欧美一区二区免费| 欧美巨大另类极品videosbest| 成人av电影在线网| 国产一区激情在线| 国模娜娜一区二区三区| 捆绑紧缚一区二区三区视频| 亚洲成人在线免费| 视频一区二区中文字幕| 亚洲成av人片在线观看无码| 成人黄色小视频| 国产又黄又大久久| 狠狠色综合色综合网络| 国内精品久久久久影院薰衣草| 三级久久三级久久久| 日韩精品每日更新| 日韩av一区二| 蜜桃视频在线观看一区二区| 秋霞午夜av一区二区三区| 日本美女一区二区三区视频| 美女视频黄免费的久久| 精品一区免费av| 国产九色sp调教91| 成人18精品视频| 日本大香伊一区二区三区| 欧美色窝79yyyycom| 91精品国产美女浴室洗澡无遮挡| 制服丝袜一区二区三区| 精品国产免费一区二区三区四区 | 狠狠狠色丁香婷婷综合激情| 老司机精品视频线观看86| 久久国产精品一区二区| 成人午夜视频网站| 色综合视频一区二区三区高清| 欧美日韩电影在线播放| 日韩一区二区三区视频在线观看|