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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? lcdlib.c

?? 三星給予ARM920T內(nèi)核的S3C2413的demo版本
?? C
?? 第 1 頁(yè) / 共 4 頁(yè)
字號(hào):
//====================================================================
// File Name : LCDlib.c
// Function  : S3C2440 LCD configuration low-level codes
// Program   : 
// Date      : March 13, 2002
// Version   : 0.0
// History
// -2410
//   0.0 : Programming start ????
// -2440
//   R0.0 (20030421): Modified for 2440. -> Junon
//====================================================================

#include <stdio.h>
#include <stdlib.h>

#include "def.h"
#include "2413addr.h"
#include "lcdlib.h"

#define LCD_DEN		(1<<2)   //GPG2,  nSS
#define LCD_DSERI	(1<<12)  //GPE12, SPIMOSI
#define LCD_DCLK	(1<<13)  //GPE13, SPICLK
#define LCD_RESET     (0)

#define LCD_DEN_Lo		(rGPGDAT&= ~LCD_DEN)
#define LCD_DEN_Hi		(rGPGDAT |=	LCD_DEN)
#define LCD_DCLK_Lo		(rGPEDAT &= ~LCD_DCLK)
#define LCD_DCLK_Hi		(rGPEDAT |=	LCD_DCLK)
#define LCD_DSERI_Lo	(rGPEDAT &= ~LCD_DSERI)
#define LCD_DSERI_Hi	(rGPEDAT |=	LCD_DSERI)
#define LCD_RESET_Lo	(0)
#define LCD_RESET_Hi	(1)


//Mono STN
U32 (*frameBuffer1Bit)[SCR_XSIZE_STN/32];
//Gray
U32 (*frameBuffer2Bit)[SCR_XSIZE_STN/16];
U32 (*frameBuffer4Bit)[SCR_XSIZE_STN/8];
//Color STN
U32 (*frameBuffer8Bit)[SCR_XSIZE_CSTN/4];
U32 (*frameBuffer12Bit)[SCR_XSIZE_CSTN/2];
U32 (*frameBuffer16Bit)[SCR_XSIZE_CSTN/2]; // for 2440A
//TFT 240320
U32 (*frameBuffer8BitTft240320)[SCR_XSIZE_TFT_240320/4];
U32 (*frameBuffer16BitTft240320)[SCR_XSIZE_TFT_240320/2];
U32 (*frameBuffer24BitTft240320)[SCR_XSIZE_TFT_240320];
//TFT 320240
U32 (*frameBuffer8BitTft320240)[SCR_XSIZE_TFT_320240/4];
U32 (*frameBuffer16BitTft320240)[SCR_XSIZE_TFT_320240/2];
U32 (*frameBuffer24BitTft320240)[SCR_XSIZE_TFT_320240];
//TFT 640480
U32 (*frameBuffer1BitTft640480)[SCR_XSIZE_TFT_640480/32];
U32 (*frameBuffer8BitTft640480)[SCR_XSIZE_TFT_640480/4];
U32 (*frameBuffer16BitTft640480)[SCR_XSIZE_TFT_640480/2];
U32 (*frameBuffer24BitTft640480)[SCR_XSIZE_TFT_640480];
//TFT 800600
U32 (*frameBuffer1BitTft800600)[SCR_XSIZE_TFT_800600/32];
U32 (*frameBuffer8BitTft800600)[SCR_XSIZE_TFT_800600/4];
U32 (*frameBuffer16BitTft800600)[SCR_XSIZE_TFT_800600/2];

void Lcd_Init(int type)
{
    switch(type)
    {
/*    case MODE_STN_1BIT:
       	frameBuffer1Bit=(U32 (*)[SCR_XSIZE_STN/32])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_STN_MONO<<8)|(MVAL_USED<<7)|(1<<5)|(0<<1)|0; 
   	// 4-bit single scan,1bpp STN,ENVID=off
	rLCDCON2=(0<<24)|(LINEVAL_STN<<14)|(0<<6)|(0<<0);	// It is not TFT LCD. So,.....    		
	rLCDCON3=(WDLY_STN<<19)|(HOZVAL_STN<<8)|(LINEBLANK_MONO<<0);
	rLCDCON4=(MVAL<<8)|(WLH_STN<<0);
	rLCDCON5=0;
	//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:x,INVVFRAME:x,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
	rLCDSADDR1=(((U32)frameBuffer1Bit>>22)<<21)|M5D((U32)frameBuffer1Bit>>1);		
	rLCDSADDR2=M5D( ((U32)frameBuffer1Bit+(SCR_XSIZE_STN*LCD_YSIZE_STN/8))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_STN-LCD_XSIZE_STN)/16)<<11)|(LCD_XSIZE_STN/16);
    break;

    case MODE_STN_2BIT:
    	frameBuffer2Bit=(U32 (*)[SCR_XSIZE_STN/16])LCDFRAMEBUFFER;
    	rLCDCON1=(CLKVAL_STN_GRAY<<8)|(MVAL_USED<<7)|(1<<5)|(1<<1)|0;
   	// 4-bit single scan,2bpp STN,ENVID=off
    	rLCDCON2=(0<<24)|(LINEVAL_STN<<14)|(0<<6)|(0<<0);
    	rLCDCON3=(WDLY_STN<<19)|(HOZVAL_STN<<8)|(LINEBLANK_GRAY<<0);
    	rLCDCON4=(MVAL<<8)|(WLH_STN<<0);
    	rLCDCON5=0;
	//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:x,INVVFRAME:x,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
    	rLCDSADDR1=(((U32)frameBuffer2Bit>>22)<<21)|M5D((U32)frameBuffer2Bit>>1);
    	rLCDSADDR2=M5D( ((U32)frameBuffer2Bit+(SCR_XSIZE_STN*LCD_YSIZE_STN/4))>>1);
    	rLCDSADDR3=(((SCR_XSIZE_STN-LCD_XSIZE_STN)/8)<<11)|(LCD_XSIZE_STN/8);
	rDITHMODE=0x0;
	rBLUELUT =0xf950;	// 4-Gray only
    break;
    	
    case MODE_STN_4BIT:
    	frameBuffer4Bit=(U32 (*)[SCR_XSIZE_STN/8])LCDFRAMEBUFFER;
    	rLCDCON1=(CLKVAL_STN_GRAY<<8)|(MVAL_USED<<7)|(1<<5)|(2<<1)|0;
    	// 4-bit single scan,4bpp STN,ENVID=off
	rLCDCON2=(0<<24)|(LINEVAL_STN<<14)|(0<<6)|(0<<0);
	rLCDCON3=(WDLY_STN<<19)|(HOZVAL_STN<<8)|(LINEBLANK_GRAY<<0);
	rLCDCON4=(MVAL<<8)|(WLH_STN<<0);
	rLCDCON5=0;
	//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:x,INVVFRAME:x,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
	rLCDSADDR1=(((U32)frameBuffer4Bit>>22)<<21)|M5D((U32)frameBuffer4Bit>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer4Bit+(SCR_XSIZE_STN*LCD_YSIZE_STN/2))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_STN-LCD_XSIZE_STN)/4)<<11)|(LCD_XSIZE_STN/4);
	rDITHMODE=0x0;
    break;

    case MODE_CSTN_8BIT:
    	frameBuffer8Bit=(U32 (*)[SCR_XSIZE_CSTN/4])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_CSTN<<8)|(MVAL_USED<<7)|(2<<5)|(3<<1)|0;
    	// 8-bit single scan,8bpp CSTN,ENVID=off
	rLCDCON2=(0<<24)|(LINEVAL_CSTN<<14)|(0<<6)|(0<<0);
	rLCDCON3=(WDLY_CSTN<<19)|(HOZVAL_CSTN<<8)|(LINEBLANK_CSTN<<0);
	rLCDCON4=(MVAL<<8)|(WLH_CSTN<<0);
	rLCDCON5=0;
	//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:x,INVVFRAME:x,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
	rLCDSADDR1=(((U32)frameBuffer8Bit>>22)<<21 )|M5D((U32)frameBuffer8Bit>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer8Bit+(SCR_XSIZE_CSTN*LCD_YSIZE_CSTN/1))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_CSTN-LCD_XSIZE_CSTN)/2)<<11)|(LCD_XSIZE_CSTN/2);
	rDITHMODE=0x0;
	rREDLUT  =0xfdb96420;
	rGREENLUT=0xfdb96420;
	rBLUELUT =0xfb40;
    break;
	
    case MODE_CSTN_12BIT:
    	frameBuffer12Bit=(U32 (*)[SCR_XSIZE_CSTN*3/8])LCDFRAMEBUFFER;
    	// Packed Type : The L.C.M of 12 and 32 is 96.
    	rLCDCON1=(CLKVAL_CSTN<<8)|(MVAL_USED<<7)|(2<<5)|(4<<1)|0;
    	// 8-bit single scan,12bpp CSTN,ENVID=off
    	rLCDCON2=(0<<24)|(LINEVAL_CSTN<<14)|(0<<6)|0;
    	rLCDCON3=(WDLY_CSTN<<19)|(HOZVAL_CSTN<<8)|(LINEBLANK_CSTN<<0);
    	rLCDCON4=(MVAL<<8)|(WLH_CSTN<<0);
    	rLCDCON5=0;
    	//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:x,INVVFRAME:x,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
    	rLCDSADDR1=(((U32)frameBuffer12Bit>>22)<<21)|M5D((U32)frameBuffer12Bit>>1);
    	rLCDSADDR2=M5D(((U32)frameBuffer12Bit+((SCR_XSIZE_CSTN*3/2)*LCD_YSIZE_CSTN))>>1);
    	rLCDSADDR3=(((SCR_XSIZE_CSTN-LCD_XSIZE_CSTN)*3/4)<<11)|(LCD_XSIZE_CSTN*3/4);
	rDITHMODE=0;
    break;

	case MODE_CSTN_12BIT_UP: // for 2440A
		frameBuffer16Bit=(U32 (*)[SCR_XSIZE_CSTN/2])LCDFRAMEBUFFER;
		// Unpacked Type : 12
		rLCDCON1=(CLKVAL_CSTN<<8)|(MVAL_USED<<7)|(2<<5)|(5<<1)|0;
		// 8-bit single scan,16bpp CSTN,ENVID=off
		rLCDCON2=(0<<24)|(LINEVAL_CSTN<<14)|(0<<6)|0;
		rLCDCON3=(WDLY_CSTN<<19)|(HOZVAL_CSTN<<8)|(LINEBLANK_CSTN<<0);
		rLCDCON4=(MVAL<<8)|(WLH_CSTN<<0);
		rLCDCON5=0;
		//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:x,INVVFRAME:x,INVVD:x,
		//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
		rLCDSADDR1=(((U32)frameBuffer16Bit>>22)<<21)|M5D((U32)frameBuffer16Bit>>1);
		rLCDSADDR2=M5D(((U32)frameBuffer16Bit+(SCR_XSIZE_CSTN*LCD_YSIZE_CSTN*2))>>1);
		rLCDSADDR3=((SCR_XSIZE_CSTN-LCD_XSIZE_CSTN)<<11)|(LCD_XSIZE_CSTN);
	rDITHMODE=0;
	break;

	case MODE_CSTN_16BIT: // for 2440A
		frameBuffer16Bit=(U32 (*)[SCR_XSIZE_CSTN/2])LCDFRAMEBUFFER;
		// Packed Type : 16.
		rLCDCON1=(CLKVAL_CSTN<<8)|(MVAL_USED<<7)|(2<<5)|(6<<1)|0;
		// 8-bit single scan,16bpp CSTN,ENVID=off
		rLCDCON2=(0<<24)|(LINEVAL_CSTN<<14)|(0<<6)|0;
		rLCDCON3=(WDLY_CSTN<<19)|(HOZVAL_CSTN<<8)|(LINEBLANK_CSTN<<0);
		rLCDCON4=(MVAL<<8)|(WLH_CSTN<<0);
		rLCDCON5=0;
		//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:x,INVVFRAME:x,INVVD:x,
		//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
		rLCDSADDR1=(((U32)frameBuffer16Bit>>22)<<21)|M5D((U32)frameBuffer16Bit>>1);
		rLCDSADDR2=M5D(((U32)frameBuffer16Bit+(SCR_XSIZE_CSTN*LCD_YSIZE_CSTN*2))>>1);
		rLCDSADDR3=((SCR_XSIZE_CSTN-LCD_XSIZE_CSTN)<<11)|(LCD_XSIZE_CSTN);
	rDITHMODE=0;
	break;


    case MODE_TFT_8BIT_240320:
	frameBuffer8BitTft240320=(U32 (*)[SCR_XSIZE_TFT_240320/4])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_TFT_240320<<8)|(MVAL_USED<<7)|(3<<5)|(11<<1)|0;
        // TFT LCD panel,8bpp TFT,ENVID=off
	rLCDCON2=(VBPD_240320<<24)|(LINEVAL_TFT_240320<<14)|(VFPD_240320<<6)|(VSPW_240320);
	rLCDCON3=(HBPD_240320<<19)|(HOZVAL_TFT_240320<<8)|(HFPD_240320);
	rLCDCON4=(MVAL<<8)|(HSPW_240320);
	rLCDCON5=(1<<11)|(1<<9)|(1<<8);	//FRM5:6:5,HSYNC and VSYNC are inverted
	rLCDSADDR1=(((U32)frameBuffer8BitTft240320>>22)<<21)|M5D((U32)frameBuffer8BitTft240320>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer8BitTft240320+(SCR_XSIZE_TFT_240320*LCD_YSIZE_TFT_240320/1))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_240320-LCD_XSIZE_TFT_240320)/2)<<11)|(LCD_XSIZE_TFT_240320/2);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;
    		
    case MODE_TFT_16BIT_240320:
	frameBuffer16BitTft240320=(U32 (*)[SCR_XSIZE_TFT_240320/2])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_TFT_240320<<8)|(MVAL_USED<<7)|(3<<5)|(12<<1)|0;
    	// TFT LCD panel,12bpp TFT,ENVID=off
	rLCDCON2=(VBPD_240320<<24)|(LINEVAL_TFT_240320<<14)|(VFPD_240320<<6)|(VSPW_240320);
	rLCDCON3=(HBPD_240320<<19)|(HOZVAL_TFT_240320<<8)|(HFPD_240320);
	rLCDCON4=(MVAL<<8)|(HSPW_240320);
	rLCDCON5=(1<<11)|(1<<9)|(1<<8);	//FRM5:6:5,HSYNC and VSYNC are inverted
	rLCDSADDR1=(((U32)frameBuffer16BitTft240320>>22)<<21)|M5D((U32)frameBuffer16BitTft240320>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer16BitTft240320+(SCR_XSIZE_TFT_240320*LCD_YSIZE_TFT_240320*2))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_240320-LCD_XSIZE_TFT_240320)/1)<<11)|(LCD_XSIZE_TFT_240320/1);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;

	case MODE_TFT_24BIT_240320:
		frameBuffer24BitTft240320=(U32 (*)[SCR_XSIZE_TFT_240320])LCDFRAMEBUFFER;
		rLCDCON1=(CLKVAL_TFT_240320<<8)|(MVAL_USED<<7)|(3<<5)|(13<<1)|0;
				// TFT LCD panel,12bpp TFT,ENVID=off
		rLCDCON2=(VBPD_240320<<24)|(LINEVAL_TFT_240320<<14)|(VFPD_240320<<6)|(VSPW_240320);
		rLCDCON3=(HBPD_240320<<19)|(HOZVAL_TFT_240320<<8)|(HFPD_240320);
		rLCDCON4=(MVAL<<8)|(HSPW_240320);
		rLCDCON5=(0<12)|(1<<9)|(1<<8); //BPP24:MSB,HSYNC and VSYNC are inverted
		rLCDSADDR1=(((U32)frameBuffer24BitTft240320>>22)<<21)|M5D((U32)frameBuffer24BitTft240320>>1);
		rLCDSADDR2=M5D( ((U32)frameBuffer24BitTft240320+(SCR_XSIZE_TFT_240320*LCD_YSIZE_TFT_240320*4))>>1 );
		rLCDSADDR3=(((SCR_XSIZE_TFT_240320-LCD_XSIZE_TFT_240320)*2)<<11)|(LCD_XSIZE_TFT_240320*2);
		rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
		rTCONSEL&=(~7); // Disable LPC3600
		rTPAL=0; // Disable Temp Palette
	break;
 
    case MODE_TFT_1BIT_640480:
    frameBuffer1BitTft640480=(U32 (*)[SCR_XSIZE_TFT_640480/32])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_TFT_640480<<8)|(MVAL_USED<<7)|(3<<5)|(8<<1)|0;
	rLCDCON2=(VBPD_640480<<24)|(LINEVAL_TFT_640480<<14)|(VFPD_640480<<6)|(VSPW_640480);
	rLCDCON3=(HBPD_640480<<19)|(HOZVAL_TFT_640480<<8)|(HFPD_640480);
	rLCDCON4=(MVAL<<8)|(HSPW_640480);
	rLCDCON5=(1<<11)|(1<<9)|(1<<8);	//FRM5:6:5,HSYNC and VSYNC are inverted
	rLCDSADDR1=(((U32)frameBuffer1BitTft640480>>22)<<21)|M5D((U32)frameBuffer1BitTft640480>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer1BitTft640480+(SCR_XSIZE_TFT_640480*LCD_YSIZE_TFT_640480/8))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_640480-LCD_XSIZE_TFT_640480)/16)<<11)|(LCD_XSIZE_TFT_640480/16);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;

    case MODE_TFT_8BIT_640480:
   	frameBuffer8BitTft640480=(U32 (*)[SCR_XSIZE_TFT_640480/4])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_TFT_640480<<8)|(MVAL_USED<<7)|(3<<5)|(11<<1)|0;
   	// TFT LCD panel,8bpp TFT,ENVID=off
	rLCDCON2=(VBPD_640480<<24)|(LINEVAL_TFT_640480<<14)|(VFPD_640480<<6)|(VSPW_640480);
	rLCDCON3=(HBPD_640480<<19)|(HOZVAL_TFT_640480<<8)|(HFPD_640480);
	rLCDCON4=(MVAL<<8)|(HSPW_640480);
	rLCDCON5=(1<<11)|(1<<9)|(1<<8);	//FRM5:6:5,HSYNC and VSYNC are inverted
	rLCDSADDR1=(((U32)frameBuffer8BitTft640480>>22)<<21)|M5D((U32)frameBuffer8BitTft640480>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer8BitTft640480+(SCR_XSIZE_TFT_640480*LCD_YSIZE_TFT_640480/1))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_640480-LCD_XSIZE_TFT_640480)/2)<<11)|(LCD_XSIZE_TFT_640480/2);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;
    	
    case MODE_TFT_16BIT_640480:
    frameBuffer16BitTft640480=(U32 (*)[SCR_XSIZE_TFT_640480/2])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_TFT_640480<<8)|(MVAL_USED<<7)|(3<<5)|(12<<1)|0;
        // TFT LCD panel,16bpp TFT,ENVID=off
	rLCDCON2=(VBPD_640480<<24)|(LINEVAL_TFT_640480<<14)|(VFPD_640480<<6)|(VSPW_640480);
	rLCDCON3=(HBPD_640480<<19)|(HOZVAL_TFT_640480<<8)|(HFPD_640480);
	rLCDCON4=(MVAL<<8)|(HSPW_640480);
	rLCDCON5=(1<<11)|(1<<9)|(1<<8);	//FRM5:6:5,HSYNC and VSYNC are inverted
	rLCDSADDR1=(((U32)frameBuffer16BitTft640480>>22)<<21)|M5D((U32)frameBuffer16BitTft640480>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer16BitTft640480+(SCR_XSIZE_TFT_640480*LCD_YSIZE_TFT_640480*2))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_640480-LCD_XSIZE_TFT_640480)/1)<<11)|(LCD_XSIZE_TFT_640480/1);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;

    case MODE_TFT_24BIT_640480:
    frameBuffer24BitTft640480=(U32 (*)[SCR_XSIZE_TFT_640480])LCDFRAMEBUFFER;
	rLCDCON1=(CLKVAL_TFT_640480<<8)|(MVAL_USED<<7)|(3<<5)|(13<<1)|0;
        // TFT LCD panel,24bpp TFT,ENVID=off
	rLCDCON2=(VBPD_640480<<24)|(LINEVAL_TFT_640480<<14)|(VFPD_640480<<6)|(VSPW_640480);
	rLCDCON3=(HBPD_640480<<19)|(HOZVAL_TFT_640480<<8)|(HFPD_640480);
	rLCDCON4=(MVAL<<8)|(HSPW_640480);
	rLCDCON5=(1<<12)|(1<<9)|(1<<8);	// BPP24:MSB,HSYNC and VSYNC are inverted
	rLCDSADDR1=(((U32)frameBuffer24BitTft640480>>22)<<21)|M5D((U32)frameBuffer24BitTft640480>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer24BitTft640480+(SCR_XSIZE_TFT_640480*LCD_YSIZE_TFT_640480*4))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_640480-LCD_XSIZE_TFT_640480)*2)<<11)|(LCD_XSIZE_TFT_640480*2);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;

    case MODE_TFT_1BIT_800600:
	frameBuffer1BitTft800600=(U32 (*)[SCR_XSIZE_TFT_800600/32])LCDFRAMEBUFFER;
   	rLCDCON1=(CLKVAL_TFT_800600<<8)|(MVAL_USED<<7)|(3<<5)|(8<<1)|0;
        // TFT LCD panel,1bpp TFT,ENVID=off
	rLCDCON2=(VBPD_800600<<24)|(LINEVAL_TFT_800600<<14)|(VFPD_800600<<6)|(VSPW_800600);
	rLCDCON3=(HBPD_800600<<19)|(HOZVAL_TFT_800600<<8)|(HFPD_800600);
	rLCDCON4=(MVAL<<8)|(HSPW_800600);
	rLCDCON5=(1<<9)|(1<<8);	
   	//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:o,INVVFRAME:o,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
	rLCDSADDR1=(((U32)frameBuffer1BitTft800600>>22)<<21)|M5D((U32)frameBuffer1BitTft800600>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer1BitTft800600+(SCR_XSIZE_TFT_800600*LCD_YSIZE_TFT_800600/8))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_800600-LCD_XSIZE_TFT_800600)/16)<<11)|(LCD_XSIZE_TFT_800600/16);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;

    case MODE_TFT_8BIT_800600:
	frameBuffer8BitTft800600=(U32 (*)[SCR_XSIZE_TFT_800600/4])LCDFRAMEBUFFER;
   	rLCDCON1=(CLKVAL_TFT_800600<<8)|(MVAL_USED<<7)|(3<<5)|(11<<1)|0;
        // TFT LCD panel,8bpp TFT,ENVID=off
	rLCDCON2=(VBPD_800600<<24)|(LINEVAL_TFT_800600<<14)|(VFPD_800600<<6)|(VSPW_800600);
	rLCDCON3=(HBPD_800600<<19)|(HOZVAL_TFT_800600<<8)|(HFPD_800600);
	rLCDCON4=(MVAL<<8)|(HSPW_800600);
	rLCDCON5=(1<<9)|(1<<8);	
	//BPP24BL:x,FRM565:x,INVVCLK:x,INVVLINE:o,INVVFRAME:o,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
	rLCDSADDR1=(((U32)frameBuffer8BitTft800600>>22)<<21)|M5D((U32)frameBuffer8BitTft800600>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer8BitTft800600+(SCR_XSIZE_TFT_800600*LCD_YSIZE_TFT_800600/1))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_800600-LCD_XSIZE_TFT_800600)/2)<<11)|(LCD_XSIZE_TFT_800600/2);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;
    	
    case MODE_TFT_16BIT_800600:
	frameBuffer16BitTft800600=(U32 (*)[SCR_XSIZE_TFT_800600/2])LCDFRAMEBUFFER;
   	rLCDCON1=(CLKVAL_TFT_800600<<8)|(MVAL_USED<<7)|(3<<5)|(12<<1)|0;
        // TFT LCD panel,16bpp TFT,ENVID=off
	rLCDCON2=(VBPD_800600<<24)|(LINEVAL_TFT_800600<<14)|(VFPD_800600<<6)|(VSPW_800600);
	rLCDCON3=(HBPD_800600<<19)|(HOZVAL_TFT_800600<<8)|(HFPD_800600);
	rLCDCON4=(MVAL<<8)|(HSPW_800600);
	rLCDCON5=(1<<11)|(1<<10)|(1<<9)|(1<<8);
	//BPP24BL:x,FRM565:o,INVVCLK:x,INVVLINE:o,INVVFRAME:o,INVVD:x,
	//INVVDEN:x,INVPWREN:x,INVLEND:x,PWREN:x,ENLEND:x,BSWP:x,HWSWP:x
	rLCDSADDR1=(((U32)frameBuffer16BitTft800600>>22)<<21)|M5D((U32)frameBuffer16BitTft800600>>1);
	rLCDSADDR2=M5D( ((U32)frameBuffer16BitTft800600+(SCR_XSIZE_TFT_800600*LCD_YSIZE_TFT_800600*2))>>1 );
	rLCDSADDR3=(((SCR_XSIZE_TFT_800600-LCD_XSIZE_TFT_800600)/1)<<11)|(LCD_XSIZE_TFT_800600/1);
	rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
	rTCONSEL&=(~7); // Disable LPC3600
	rTPAL=0; // Disable Temp Palette
    break;
*/

    case MODE_TFT_16BIT_240320:
		frameBuffer16BitTft240320=(U32 (*)[SCR_XSIZE_TFT_240320/2])LCDFRAMEBUFFER;
		rLCDCON1=(CLKVAL_TFT_240320<<8)|(MVAL_USED<<7)|(3<<5)|(12<<1)|0;
	    	// TFT LCD panel,12bpp TFT,ENVID=off
		rLCDCON2=(VBPD_240320<<24)|(LINEVAL_TFT_240320<<14)|(VFPD_240320<<6)|(VSPW_240320);
		rLCDCON3=(HBPD_240320<<19)|(HOZVAL_TFT_240320<<8)|(HFPD_240320);
		rLCDCON4=(MVAL<<8)|(HSPW_240320);
		rLCDCON5=(1<<11)|(1<<9)|(1<<8);	//FRM5:6:5,HSYNC and VSYNC are inverted
		rLCDSADDR1=(((U32)frameBuffer16BitTft240320>>22)<<21)|M5D((U32)frameBuffer16BitTft240320>>1);
		rLCDSADDR2=M5D( ((U32)frameBuffer16BitTft240320+(SCR_XSIZE_TFT_240320*LCD_YSIZE_TFT_240320*2))>>1 );
		rLCDSADDR3=(((SCR_XSIZE_TFT_240320-LCD_XSIZE_TFT_240320)/1)<<11)|(LCD_XSIZE_TFT_240320/1);
		rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
		rTCONSEL&=(~7); // Disable LPC3600
		rTPAL=0; // Disable Temp Palette
		printf("x:%d|y:%d\n", SCR_XSIZE_TFT_240320, SCR_YSIZE_TFT_240320);
    break;

	case MODE_TFT_24BIT_320240:
		frameBuffer24BitTft320240=(U32 (*)[SCR_XSIZE_TFT_320240])LCDFRAMEBUFFER;
		rLCDCON1=(CLKVAL_TFT_320240<<8)|(3<<5)|(13<<1)|0;
				// TFT LCD panel,12bpp TFT,ENVID=off
		rLCDCON2=(VBPD_320240<<24)|(LINEVAL_TFT_320240<<14)|(VFPD_320240<<6)|(VSPW_320240);
		rLCDCON3=(HBPD_320240<<19)|(HOZVAL_TFT_320240<<8)|(HFPD_320240);
		rLCDCON4=(MVAL<<8)|(HSPW_320240);
		rLCDCON5=(0<12)|(1<<9)|(1<<8); //BPP24:MSB,HSYNC and VSYNC are inverted
		rLCDSADDR1=(((U32)frameBuffer24BitTft320240>>22)<<21)|M5D((U32)frameBuffer24BitTft320240>>1);
		rLCDSADDR2=M5D( ((U32)frameBuffer24BitTft320240+(SCR_XSIZE_TFT_320240*LCD_YSIZE_TFT_320240*4))>>1 );
		rLCDSADDR3=(((SCR_XSIZE_TFT_320240-LCD_XSIZE_TFT_320240)*2)<<11)|(LCD_XSIZE_TFT_320240*2);
		rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
		rTCONSEL&=(~0x1f); // Disable LPC3600, LCC3600
		rTPAL=0; // Disable Temp Palette
	break;

    case MODE_TFT_16BIT_320240:
		frameBuffer16BitTft320240=(U32 (*)[SCR_XSIZE_TFT_320240/2])LCDFRAMEBUFFER;
		rLCDCON1=(CLKVAL_TFT_320240<<8)|(3<<5)|(12<<1)|0;
	    	// TFT LCD panel,12bpp TFT,ENVID=off
		rLCDCON2=(VBPD_320240<<24)|(LINEVAL_TFT_320240<<14)|(VFPD_320240<<6)|(VSPW_320240);
		rLCDCON3=(HBPD_320240<<19)|(HOZVAL_TFT_320240<<8)|(HFPD_320240);
		rLCDCON4=(MVAL<<8)|(HSPW_320240);
		rLCDCON5=(1<<11)|(1<<9)|(1<<8);	//FRM5:6:5,HSYNC and VSYNC are inverted
		rLCDSADDR1=(((U32)frameBuffer16BitTft320240>>22)<<21)|M5D((U32)frameBuffer16BitTft320240>>1);
		rLCDSADDR2=M5D( ((U32)frameBuffer16BitTft320240+(SCR_XSIZE_TFT_320240*LCD_YSIZE_TFT_320240*2))>>1 );
		rLCDSADDR3=(((SCR_XSIZE_TFT_320240-LCD_XSIZE_TFT_320240)/1)<<11)|(LCD_XSIZE_TFT_320240/1);
		rLCDINTMSK|=(3); // MASK LCD Sub Interrupt
		rTCONSEL&=(~0x7); // Disable LPC3600, LCC3600
		rTPAL=0; // Disable Temp Palette
    break;

    case MODE_CSTN_8BIT:
    	frameBuffer8Bit=(U32 (*)[SCR_XSIZE_CSTN/4])LCDFRAMEBUFFER;

		LutSetting(MODE_CSTN_8BIT);
		FrcSetting();
		
		CstnCommonSetting();
    	
    	rLCDCON1=(CLKVAL_CSTN<<8)|(0<<7)|(2<<5)|(4<<1)|0;
    	rLCDCON5=(1<<11)|(0); 

    	rLCDSADDR1=0x19c00000;
    	rLCDSADDR2=0x9600;
    	//rLCDSADDR1=(((U32)frameBuffer12Bit>>22)<<21)|M5D((U32)frameBuffer12Bit>>1);
    	//rLCDSADDR2=M5D(((U32)frameBuffer12Bit+((LCD_XSIZE_CSTN/2)*LCD_YSIZE_CSTN))>>1);
    	rLCDSADDR3=(0<<11)|(LCD_XSIZE_CSTN);	
    break;
        
    case MODE_CSTN_12BIT:
    	frameBuffer12Bit=(U32 (*)[SCR_XSIZE_CSTN/2])LCDFRAMEBUFFER;

		LutSetting(MODE_CSTN_12BIT);
		FrcSetting();
		
		CstnCommonSetting();
    	
    	rLCDCON1=(CLKVAL_CSTN<<8)|(0<<7)|(2<<5)|(5<<1)|0;
    	rLCDCON5=(1<<11)|(1);

    	rLCDSADDR1=0x19c00000;
    	rLCDSADDR2=0x12c00;
    	//rLCDSADDR1=(((U32)frameBuffer12Bit>>22)<<21)|M5D((U32)frameBuffer12Bit>>1);
    	//rLCDSADDR2=M5D(((U32)frameBuffer12Bit+((LCD_XSIZE_CSTN/2)*LCD_YSIZE_CSTN))>>1);
    	rLCDSADDR3=(0<<11)|(LCD_XSIZE_CSTN);	
    break;

    case MODE_CSTN_16BIT:
    	frameBuffer16Bit=(U32 (*)[SCR_XSIZE_CSTN/2])LCDFRAMEBUFFER;

		LutSetting(MODE_CSTN_16BIT);
		FrcSetting();
		
		CstnCommonSetting();
				
    	rLCDCON1=(CLKVAL_CSTN<<8)|(0<<7)|(2<<5)|(6<<1)|0;
    	rLCDCON5=(1<<11)|(1);
    	
    	rLCDSADDR1=0x19c00000;
    	rLCDSADDR2=0x12c00;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩国产乱码电影| 国产成a人亚洲| 成人激情电影免费在线观看| 欧美无砖砖区免费| 亚洲国产精品高清| 老汉av免费一区二区三区 | 自拍偷在线精品自拍偷无码专区 | 国产婷婷一区二区| 午夜不卡av在线| 91视频在线观看| 久久精品亚洲精品国产欧美kt∨| 视频一区二区三区入口| 91女神在线视频| 欧美国产一区二区在线观看| 男女性色大片免费观看一区二区 | 91丨九色丨国产丨porny| 精品国免费一区二区三区| 亚洲一区二区三区中文字幕在线| 国产福利一区二区三区在线视频| 制服丝袜在线91| 亚洲一区二区三区四区五区中文| caoporm超碰国产精品| 久久久精品日韩欧美| 精品一区二区久久久| 欧美一二三在线| 亚洲二区在线视频| 在线免费观看不卡av| 中文字幕色av一区二区三区| 国产成人鲁色资源国产91色综| 欧美mv日韩mv| 精品一区二区久久久| 精品女同一区二区| 日韩精品一二三| 欧美人妖巨大在线| 亚洲地区一二三色| 欧美午夜精品久久久久久超碰| 亚洲欧美视频在线观看| www.日韩精品| 中文字幕在线不卡一区| 国产91精品在线观看| 欧美精品一区二区三区久久久| 另类专区欧美蜜桃臀第一页| 日韩美女主播在线视频一区二区三区| 日韩一区欧美二区| 日韩欧美在线123| 麻豆精品视频在线观看免费| 日韩欧美亚洲国产另类| 黄色日韩三级电影| 久久久精品综合| 成人一级片在线观看| 国产精品情趣视频| 99久久久久久| 一区二区三区视频在线观看| 欧美亚洲图片小说| 五月天欧美精品| 日韩一级免费一区| 经典三级一区二区| 国产午夜精品久久久久久免费视 | 91麻豆国产香蕉久久精品| 亚洲天堂免费在线观看视频| 91久久精品一区二区| 偷窥少妇高潮呻吟av久久免费| 欧美一区国产二区| 经典三级一区二区| 中文字幕在线一区二区三区| 色综合久久久久久久| 亚洲bt欧美bt精品| 欧美本精品男人aⅴ天堂| 国产美女精品一区二区三区| 国产精品免费网站在线观看| 91国内精品野花午夜精品| 午夜视频久久久久久| 欧美草草影院在线视频| 成人一区二区三区视频| 一区二区三区四区av| 日韩免费福利电影在线观看| 成人网在线免费视频| 亚洲一区二区在线播放相泽| 欧美成人一区二区| 成人av动漫网站| 亚洲成人777| ww久久中文字幕| 99精品视频在线播放观看| 午夜精品视频一区| 久久久久久电影| 在线一区二区三区| 久久国产麻豆精品| 自拍偷自拍亚洲精品播放| 91精品婷婷国产综合久久| 国产成人免费视频精品含羞草妖精| 亚洲精品视频在线观看网站| 日韩欧美在线综合网| 97精品电影院| 看片的网站亚洲| 亚洲男人的天堂一区二区| 日韩午夜激情视频| 91免费在线看| 精品一区在线看| 一区二区三区视频在线看| 久久久五月婷婷| 欧美少妇一区二区| 高清不卡在线观看av| 偷窥少妇高潮呻吟av久久免费| 国产欧美1区2区3区| 欧美精品第1页| 成人ar影院免费观看视频| 男人操女人的视频在线观看欧美| 亚洲欧洲三级电影| 欧美mv日韩mv亚洲| 欧美日韩另类国产亚洲欧美一级| 国产成人一区在线| 男男视频亚洲欧美| 一区二区三区自拍| 日本一区二区免费在线观看视频 | 欧美性猛片xxxx免费看久爱| 国产成人自拍高清视频在线免费播放| 亚洲午夜视频在线| 中文字幕av不卡| 精品久久久久av影院| 欧美视频一区在线观看| www.日韩av| 国产成人av在线影院| 奇米色一区二区三区四区| 一区二区三区四区亚洲| 欧美激情综合五月色丁香小说| 91精品国产高清一区二区三区| 91小视频在线免费看| 国产成人av一区二区| 久久99国产精品久久| 日欧美一区二区| 一区二区三区加勒比av| 国产精品传媒在线| 国产婷婷精品av在线| 精品国产一区二区亚洲人成毛片| 欧美剧在线免费观看网站| 色婷婷久久久亚洲一区二区三区| 成人在线综合网| 国产一区二区福利视频| 久久精品久久99精品久久| 天天色 色综合| 亚洲成人av福利| 亚洲一区二区三区美女| 亚洲日本va午夜在线电影| 欧美韩日一区二区三区| 国产亚洲美州欧州综合国| 精品国产乱码久久久久久久久| 欧美一区二区福利在线| 欧美群妇大交群的观看方式| 欧美午夜影院一区| 欧美日韩在线不卡| 欧美三级视频在线观看| 91成人免费在线视频| 91电影在线观看| 在线观看视频一区二区欧美日韩| 不卡电影免费在线播放一区| 成人夜色视频网站在线观看| 顶级嫩模精品视频在线看| 国产成人在线观看免费网站| 国产成人一区二区精品非洲| 国产成人在线免费| 成人黄色免费短视频| 99久久99久久综合| 91视频xxxx| 欧美在线一区二区| 欧美日韩另类一区| 日韩亚洲国产中文字幕欧美| 日韩美女在线视频| 久久蜜桃av一区精品变态类天堂| 久久久久久久综合色一本| 中文子幕无线码一区tr| 国产精品电影院| 亚洲欧美日本在线| 亚洲一级片在线观看| 日韩在线一区二区三区| 看电影不卡的网站| 国产精品白丝jk黑袜喷水| 成人爽a毛片一区二区免费| 99国产精品视频免费观看| 在线一区二区三区四区五区 | 色综合中文综合网| 欧日韩精品视频| 欧美精品久久久久久久多人混战| 日韩色视频在线观看| 久久久久国产精品麻豆ai换脸 | 91精品国产综合久久香蕉麻豆| 欧美精品乱人伦久久久久久| 欧美电影免费观看高清完整版在线 | av网站一区二区三区| 色婷婷av一区二区三区gif | 国产成人8x视频一区二区| 色悠久久久久综合欧美99| 欧美电影在线免费观看| 久久老女人爱爱| 亚洲免费色视频| 日韩av网站在线观看| 国产一区免费电影| 一本久久a久久免费精品不卡| 欧美剧情电影在线观看完整版免费励志电影 | 久久精品二区亚洲w码| 风间由美一区二区av101|