Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- /*
- * LCD.cpp
- *
- * Created on: 17 févr. 2012
- * Author: blackswords
- */
- #include "LCD.h"
- #define LCD_REG (*((volatile unsigned short *) 0x60000000)) /* RS = 0 */
- #define LCD_RAM (*((volatile unsigned short *) 0x60020000)) /* RS = 1 */
- LCD::LCD() {
- LCD::FSMCConfig();
- LCD::Inner_delay(50); /* delay 50 ms */
- //LCD_DeviceCode = LCD::ReadReg(0x0000);
- if(LCD_DeviceCode==0x9325 || LCD_DeviceCode==0x9328)
- {
- LCD::WriteReg(0x00e7,0x0010);
- LCD::WriteReg(0x0000,0x0001); /* start internal osc */
- LCD::WriteReg(0x0001,0x0100);
- LCD::WriteReg(0x0002,0x0700); /* power on sequence */
- LCD::WriteReg(0x0003,(1<<12)|(1<<5)|(1<<4)|(0<<3) ); /* importance */
- LCD::WriteReg(0x0004,0x0000);
- LCD::WriteReg(0x0008,0x0207);
- LCD::WriteReg(0x0009,0x0000);
- LCD::WriteReg(0x000a,0x0000); /* display setting */
- LCD::WriteReg(0x000c,0x0001); /* display setting */
- LCD::WriteReg(0x000d,0x0000);
- LCD::WriteReg(0x000f,0x0000);
- /* Power On sequence */
- LCD::WriteReg(0x0010,0x0000);
- LCD::WriteReg(0x0011,0x0007);
- LCD::WriteReg(0x0012,0x0000);
- LCD::WriteReg(0x0013,0x0000);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0010,0x1590);
- LCD::WriteReg(0x0011,0x0227);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0012,0x009c);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0013,0x1900);
- LCD::WriteReg(0x0029,0x0023);
- LCD::WriteReg(0x002b,0x000e);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0020,0x0000);
- LCD::WriteReg(0x0021,0x0000);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0030,0x0007);
- LCD::WriteReg(0x0031,0x0707);
- LCD::WriteReg(0x0032,0x0006);
- LCD::WriteReg(0x0035,0x0704);
- LCD::WriteReg(0x0036,0x1f04);
- LCD::WriteReg(0x0037,0x0004);
- LCD::WriteReg(0x0038,0x0000);
- LCD::WriteReg(0x0039,0x0706);
- LCD::WriteReg(0x003c,0x0701);
- LCD::WriteReg(0x003d,0x000f);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0050,0x0000);
- LCD::WriteReg(0x0051,0x00ef);
- LCD::WriteReg(0x0052,0x0000);
- LCD::WriteReg(0x0053,0x013f);
- LCD::WriteReg(0x0060,0xa700);
- LCD::WriteReg(0x0061,0x0001);
- LCD::WriteReg(0x006a,0x0000);
- LCD::WriteReg(0x0080,0x0000);
- LCD::WriteReg(0x0081,0x0000);
- LCD::WriteReg(0x0082,0x0000);
- LCD::WriteReg(0x0083,0x0000);
- LCD::WriteReg(0x0084,0x0000);
- LCD::WriteReg(0x0085,0x0000);
- LCD::WriteReg(0x0090,0x0010);
- LCD::WriteReg(0x0092,0x0000);
- LCD::WriteReg(0x0093,0x0003);
- LCD::WriteReg(0x0095,0x0110);
- LCD::WriteReg(0x0097,0x0000);
- LCD::WriteReg(0x0098,0x0000);
- /* display on sequence */
- LCD::WriteReg(0x0007,0x0133);
- LCD::WriteReg(0x0020,0x0000);
- LCD::WriteReg(0x0021,0x0000);
- }
- else if(LCD_DeviceCode==0x9320 || LCD_DeviceCode==0x9300)
- {
- LCD::WriteReg(0x00,0x0000);
- LCD::WriteReg(0x01,0x0100); /* Driver Output Contral */
- LCD::WriteReg(0x02,0x0700); /* LCD Driver Waveform Contral */
- LCD::WriteReg(0x03,0x1018); /* Entry Mode Set */
- LCD::WriteReg(0x04,0x0000); /* Scalling Contral */
- LCD::WriteReg(0x08,0x0202); /* Display Contral */
- LCD::WriteReg(0x09,0x0000); /* Display Contral 3.(0x0000) */
- LCD::WriteReg(0x0a,0x0000); /* Frame Cycle Contal.(0x0000) */
- LCD::WriteReg(0x0c,(1<<0)); /* Extern Display Interface Contral */
- LCD::WriteReg(0x0d,0x0000); /* Frame Maker Position */
- LCD::WriteReg(0x0f,0x0000); /* Extern Display Interface Contral 2. */
- LCD::Inner_delay(100); /* delay 100 ms */
- LCD::WriteReg(0x07,0x0101); /* Display Contral */
- LCD::Inner_delay(100); /* delay 100 ms */
- LCD::WriteReg(0x10,(1<<12)|(0<<8)|(1<<7)|(1<<6)|(0<<4)); /* Power Control 1.(0x16b0) */
- LCD::WriteReg(0x11,0x0007); /* Power Control 2 */
- LCD::WriteReg(0x12,(1<<8)|(1<<4)|(0<<0)); /* Power Control 3.(0x0138) */
- LCD::WriteReg(0x13,0x0b00); /* Power Control 4 */
- LCD::WriteReg(0x29,0x0000); /* Power Control 7 */
- LCD::WriteReg(0x2b,(1<<14)|(1<<4));
- LCD::WriteReg(0x50,0); /* Set X Start */
- LCD::WriteReg(0x51,239); /* Set X End */
- LCD::WriteReg(0x52,0); /* Set Y Start */
- LCD::WriteReg(0x53,319); /* Set Y End */
- LCD::WriteReg(0x60,0x2700); /* Driver Output Control */
- LCD::WriteReg(0x61,0x0001); /* Driver Output Control */
- LCD::WriteReg(0x6a,0x0000); /* Vertical Srcoll Control */
- LCD::WriteReg(0x80,0x0000); /* Display Position? Partial Display 1 */
- LCD::WriteReg(0x81,0x0000); /* RAM Address Start? Partial Display 1 */
- LCD::WriteReg(0x82,0x0000); /* RAM Address End-Partial Display 1 */
- LCD::WriteReg(0x83,0x0000); /* Displsy Position? Partial Display 2 */
- LCD::WriteReg(0x84,0x0000); /* RAM Address Start? Partial Display 2 */
- LCD::WriteReg(0x85,0x0000); /* RAM Address End? Partial Display 2 */
- LCD::WriteReg(0x90,(0<<7)|(16<<0)); /* Frame Cycle Contral.(0x0013) */
- LCD::WriteReg(0x92,0x0000); /* Panel Interface Contral 2.(0x0000) */
- LCD::WriteReg(0x93,0x0001); /* Panel Interface Contral 3. */
- LCD::WriteReg(0x95,0x0110); /* Frame Cycle Contral.(0x0110) */
- LCD::WriteReg(0x97,(0<<8));
- LCD::WriteReg(0x98,0x0000); /* Frame Cycle Contral */
- LCD::WriteReg(0x07,0x0173);
- }
- else if(LCD_DeviceCode==0x9331)
- {
- LCD::WriteReg(0x00E7, 0x1014);
- LCD::WriteReg(0x0001, 0x0100); /* set SS and SM bit */
- LCD::WriteReg(0x0002, 0x0200); /* set 1 line inversion */
- LCD::WriteReg(0x0003, 0x1030); /* set GRAM write direction and BGR=1 */
- LCD::WriteReg(0x0008, 0x0202); /* set the back porch and front porch */
- LCD::WriteReg(0x0009, 0x0000); /* set non-display area refresh cycle ISC[3:0] */
- LCD::WriteReg(0x000A, 0x0000); /* FMARK function */
- LCD::WriteReg(0x000C, 0x0000); /* RGB interface setting */
- LCD::WriteReg(0x000D, 0x0000); /* Frame marker Position */
- LCD::WriteReg(0x000F, 0x0000); /* RGB interface polarity */
- /* Power On sequence */
- LCD::WriteReg(0x0010, 0x0000); /* SAP, BT[3:0], AP, DSTB, SLP, STB */
- LCD::WriteReg(0x0011, 0x0007); /* DC1[2:0], DC0[2:0], VC[2:0] */
- LCD::WriteReg(0x0012, 0x0000); /* VREG1OUT voltage */
- LCD::WriteReg(0x0013, 0x0000); /* VDV[4:0] for VCOM amplitude */
- LCD::Inner_delay(200); /* delay 200 ms */
- LCD::WriteReg(0x0010, 0x1690); /* SAP, BT[3:0], AP, DSTB, SLP, STB */
- LCD::WriteReg(0x0011, 0x0227); /* DC1[2:0], DC0[2:0], VC[2:0] */
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0012, 0x000C); /* Internal reference voltage= Vci */
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0013, 0x0800); /* Set VDV[4:0] for VCOM amplitude */
- LCD::WriteReg(0x0029, 0x0011); /* Set VCM[5:0] for VCOMH */
- LCD::WriteReg(0x002B, 0x000B); /* Set Frame Rate */
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0020, 0x0000); /* GRAM horizontal Address */
- LCD::WriteReg(0x0021, 0x0000); /* GRAM Vertical Address */
- /* Adjust the Gamma Curve */
- LCD::WriteReg(0x0030, 0x0000);
- LCD::WriteReg(0x0031, 0x0106);
- LCD::WriteReg(0x0032, 0x0000);
- LCD::WriteReg(0x0035, 0x0204);
- LCD::WriteReg(0x0036, 0x160A);
- LCD::WriteReg(0x0037, 0x0707);
- LCD::WriteReg(0x0038, 0x0106);
- LCD::WriteReg(0x0039, 0x0707);
- LCD::WriteReg(0x003C, 0x0402);
- LCD::WriteReg(0x003D, 0x0C0F);
- /* Set GRAM area */
- LCD::WriteReg(0x0050, 0x0000); /* Horizontal GRAM Start Address */
- LCD::WriteReg(0x0051, 0x00EF); /* Horizontal GRAM End Address */
- LCD::WriteReg(0x0052, 0x0000); /* Vertical GRAM Start Address */
- LCD::WriteReg(0x0053, 0x013F); /* Vertical GRAM Start Address */
- LCD::WriteReg(0x0060, 0x2700); /* Gate Scan Line */
- LCD::WriteReg(0x0061, 0x0001); /* NDL,VLE, REV */
- LCD::WriteReg(0x006A, 0x0000); /* set scrolling line */
- /* Partial Display Control */
- LCD::WriteReg(0x0080, 0x0000);
- LCD::WriteReg(0x0081, 0x0000);
- LCD::WriteReg(0x0082, 0x0000);
- LCD::WriteReg(0x0083, 0x0000);
- LCD::WriteReg(0x0084, 0x0000);
- LCD::WriteReg(0x0085, 0x0000);
- /* Panel Control */
- LCD::WriteReg(0x0090, 0x0010);
- LCD::WriteReg(0x0092, 0x0600);
- LCD::WriteReg(0x0007,0x0021);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0007,0x0061);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0007,0x0133); /* 262K color and display ON */
- LCD::Inner_delay(50); /* delay 50 ms */
- }
- else if(LCD_DeviceCode==0x9919)
- {
- /* POWER ON &RESET DISPLAY OFF */
- LCD::WriteReg(0x28,0x0006);
- LCD::WriteReg(0x00,0x0001);
- LCD::WriteReg(0x10,0x0000);
- LCD::WriteReg(0x01,0x72ef);
- LCD::WriteReg(0x02,0x0600);
- LCD::WriteReg(0x03,0x6a38);
- LCD::WriteReg(0x11,0x6874);
- LCD::WriteReg(0x0f,0x0000); /* RAM WRITE DATA MASK */
- LCD::WriteReg(0x0b,0x5308); /* RAM WRITE DATA MASK */
- LCD::WriteReg(0x0c,0x0003);
- LCD::WriteReg(0x0d,0x000a);
- LCD::WriteReg(0x0e,0x2e00);
- LCD::WriteReg(0x1e,0x00be);
- LCD::WriteReg(0x25,0x8000);
- LCD::WriteReg(0x26,0x7800);
- LCD::WriteReg(0x27,0x0078);
- LCD::WriteReg(0x4e,0x0000);
- LCD::WriteReg(0x4f,0x0000);
- LCD::WriteReg(0x12,0x08d9);
- /* Adjust the Gamma Curve */
- LCD::WriteReg(0x30,0x0000);
- LCD::WriteReg(0x31,0x0104);
- LCD::WriteReg(0x32,0x0100);
- LCD::WriteReg(0x33,0x0305);
- LCD::WriteReg(0x34,0x0505);
- LCD::WriteReg(0x35,0x0305);
- LCD::WriteReg(0x36,0x0707);
- LCD::WriteReg(0x37,0x0300);
- LCD::WriteReg(0x3a,0x1200);
- LCD::WriteReg(0x3b,0x0800);
- LCD::WriteReg(0x07,0x0033);
- }
- else if(LCD_DeviceCode==0x1505)
- {
- /* second release on 3/5 ,luminance is acceptable,water wave appear during camera preview */
- LCD::WriteReg(0x0007,0x0000);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0012,0x011C); /* why need to set several times? */
- LCD::WriteReg(0x00A4,0x0001); /* NVM */
- LCD::WriteReg(0x0008,0x000F);
- LCD::WriteReg(0x000A,0x0008);
- LCD::WriteReg(0x000D,0x0008);
- /* GAMMA CONTROL */
- LCD::WriteReg(0x0030,0x0707);
- LCD::WriteReg(0x0031,0x0007);
- LCD::WriteReg(0x0032,0x0603);
- LCD::WriteReg(0x0033,0x0700);
- LCD::WriteReg(0x0034,0x0202);
- LCD::WriteReg(0x0035,0x0002);
- LCD::WriteReg(0x0036,0x1F0F);
- LCD::WriteReg(0x0037,0x0707);
- LCD::WriteReg(0x0038,0x0000);
- LCD::WriteReg(0x0039,0x0000);
- LCD::WriteReg(0x003A,0x0707);
- LCD::WriteReg(0x003B,0x0000);
- LCD::WriteReg(0x003C,0x0007);
- LCD::WriteReg(0x003D,0x0000);
- LCD::Inner_delay(50); /* delay 50 ms */
- LCD::WriteReg(0x0007,0x0001);
- LCD::WriteReg(0x0017,0x0001); /* Power supply startup enable */
- LCD::Inner_delay(50); /* delay 50 ms */
- /* power control */
- LCD::WriteReg(0x0010,0x17A0);
- LCD::WriteReg(0x0011,0x0217); /* reference voltage VC[2:0] Vciout = 1.00*Vcivl */
- LCD::WriteReg(0x0012,0x011E); /* Vreg1out = Vcilvl*1.80 is it the same as Vgama1out ? */
- LCD::WriteReg(0x0013,0x0F00); /* VDV[4:0]-->VCOM Amplitude VcomL = VcomH - Vcom Ampl */
- LCD::WriteReg(0x002A,0x0000);
- LCD::WriteReg(0x0029,0x000A); /* Vcomh = VCM1[4:0]*Vreg1out gate source voltage?? */
- LCD::WriteReg(0x0012,0x013E); /* power supply on */
- /* Coordinates Control */
- LCD::WriteReg(0x0050,0x0000);
- LCD::WriteReg(0x0051,0x00EF);
- LCD::WriteReg(0x0052,0x0000);
- LCD::WriteReg(0x0053,0x013F);
- /* Pannel Image Control */
- LCD::WriteReg(0x0060,0x2700);
- LCD::WriteReg(0x0061,0x0001);
- LCD::WriteReg(0x006A,0x0000);
- LCD::WriteReg(0x0080,0x0000);
- /* Partial Image Control */
- LCD::WriteReg(0x0081,0x0000);
- LCD::WriteReg(0x0082,0x0000);
- LCD::WriteReg(0x0083,0x0000);
- LCD::WriteReg(0x0084,0x0000);
- LCD::WriteReg(0x0085,0x0000);
- /* Panel Interface Control */
- LCD::WriteReg(0x0090,0x0013); /* frenqucy */
- LCD::WriteReg(0x0092,0x0300);
- LCD::WriteReg(0x0093,0x0005);
- LCD::WriteReg(0x0095,0x0000);
- LCD::WriteReg(0x0097,0x0000);
- LCD::WriteReg(0x0098,0x0000);
- LCD::WriteReg(0x0001,0x0100);
- LCD::WriteReg(0x0002,0x0700);
- LCD::WriteReg(0x0003,0x1030);
- LCD::WriteReg(0x0004,0x0000);
- LCD::WriteReg(0x000C,0x0000);
- LCD::WriteReg(0x000F,0x0000);
- LCD::WriteReg(0x0020,0x0000);
- LCD::WriteReg(0x0021,0x0000);
- LCD::WriteReg(0x0007,0x0021);
- LCD::Inner_delay(200); /* delay 200 ms */
- LCD::WriteReg(0x0007,0x0061);
- LCD::Inner_delay(200); /* delay 200 ms */
- LCD::WriteReg(0x0007,0x0173);
- LCD::Inner_delay(200); /* delay 200 ms */
- }
- else if(LCD_DeviceCode==0x8989)
- {
- LCD::WriteReg(0x0000,0x0001); LCD::Inner_delay(50);
- LCD::WriteReg(0x0003,0xA8A4); LCD::Inner_delay(50);
- LCD::WriteReg(0x000C,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x000D,0x080C); LCD::Inner_delay(50);
- LCD::WriteReg(0x000E,0x2B00); LCD::Inner_delay(50);
- LCD::WriteReg(0x001E,0x00B0); LCD::Inner_delay(50);
- LCD::WriteReg(0x0001,0x2B3F); LCD::Inner_delay(50);
- LCD::WriteReg(0x0002,0x0600); LCD::Inner_delay(50);
- LCD::WriteReg(0x0010,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0011,0x6070); LCD::Inner_delay(50);
- LCD::WriteReg(0x0005,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0006,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0016,0xEF1C); LCD::Inner_delay(50);
- LCD::WriteReg(0x0017,0x0003); LCD::Inner_delay(50);
- LCD::WriteReg(0x0007,0x0133); LCD::Inner_delay(50);
- LCD::WriteReg(0x000B,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x000F,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0041,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0042,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0048,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0049,0x013F); LCD::Inner_delay(50);
- LCD::WriteReg(0x004A,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x004B,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0044,0xEF00); LCD::Inner_delay(50);
- LCD::WriteReg(0x0045,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0046,0x013F); LCD::Inner_delay(50);
- LCD::WriteReg(0x0030,0x0707); LCD::Inner_delay(50);
- LCD::WriteReg(0x0031,0x0204); LCD::Inner_delay(50);
- LCD::WriteReg(0x0032,0x0204); LCD::Inner_delay(50);
- LCD::WriteReg(0x0033,0x0502); LCD::Inner_delay(50);
- LCD::WriteReg(0x0034,0x0507); LCD::Inner_delay(50);
- LCD::WriteReg(0x0035,0x0204); LCD::Inner_delay(50);
- LCD::WriteReg(0x0036,0x0204); LCD::Inner_delay(50);
- LCD::WriteReg(0x0037,0x0502); LCD::Inner_delay(50);
- LCD::WriteReg(0x003A,0x0302); LCD::Inner_delay(50);
- LCD::WriteReg(0x003B,0x0302); LCD::Inner_delay(50);
- LCD::WriteReg(0x0023,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0024,0x0000); LCD::Inner_delay(50);
- LCD::WriteReg(0x0025,0x8000); LCD::Inner_delay(50);
- LCD::WriteReg(0x004f,0);
- LCD::WriteReg(0x004e,0);
- }
- LCD::Inner_delay(50); /* delay 50 ms */
- // LCD::BackLight_Init();
- LCD::Clear(Black);
- }
- bool LCD::BackLight(uint8_t percent) {
- if( percent >= 0 && percent <= 100)
- {
- analogWrite(BL_Pin,percent * 655);
- return true;
- }
- else
- return false;
- }
- void LCD::BackLight_Init(void) {
- pinMode(BL_Pin,PWM);
- afio_remap(AFIO_REMAP_TIM3_PARTIAL);
- analogWrite(BL_Pin,0xFFFF);
- }
- uint16_t LCD::BGR2RGB(uint16_t color) {
- uint16_t r, g, b, rgb;
- b = ( color>>0 ) & 0x1f;
- g = ( color>>5 ) & 0x3f;
- r = ( color>>11 ) & 0x1f;
- rgb = (b<<11) + (g<<5) + (r<<0);
- return( rgb );
- }
- void LCD::Clear(uint16_t Color) {
- uint32_t in;
- // Set cursor to 0,0
- LCD_REG = 0x4e;
- LCD_RAM = 0;
- LCD_REG = 0x4f;
- LCD_RAM = 0;
- // Prepare to write di GRAM
- LCD_REG = R34;
- for(in=0;in<76800;in++)
- {
- LCD_RAM=Color;
- }
- }
- void LCD::DrawLine(int x1, int y1, int x2, int y2,uint16_t bkColor) {
- int x,y,dx,dy,Dx,Dy,e,i;
- Dx=x2-x1;
- Dy=y2-y1;
- dx=fabs(x2-x1);
- dy=fabs(y2-y1);
- x=x1;
- y=y1;
- if(dy>dx)
- {
- e=-dy;
- for(i=0;i<dy;i++)
- {
- LCD::SetPoint(x,y,bkColor);
- if(Dy>=0) y++;
- else y--;
- e+=2*dx;
- if(e>=0)
- {
- if(Dx>=0) x++;
- else x--;
- e-=2*dy;
- }
- }
- }
- else
- {
- e=-dx;
- for(i=0;i<dx;i++)
- {
- LCD::SetPoint(x,y,bkColor);
- if(Dx>=0) x++;
- else x--;
- e+=2*dy;
- if(e>=0)
- {
- if(Dy>=0) y++;
- else y--;
- e-=2*dx;
- }
- }
- }
- }
- void LCD::DrawPicture(uint16_t StartX,uint16_t StartY,uint16_t EndX,uint16_t EndY,uint16_t *pic) {
- uint16_t i;
- LCD::SetCursor(StartX,StartY);
- LCD::WriteRAM_Prepare();
- for (i=0;i<(EndX*EndY);i++)
- {
- LCD::WriteRAM(*pic++);
- }
- }
- void LCD::FSMCConfig(void) {
- fsmc_nor_psram_reg_map *regs = FSMC_NOR_PSRAM1_BASE;
- uint32_t* extended = (uint32_t*) 0xA0000000 + 0x104;
- fsmc_sram_init_gpios();
- rcc_clk_enable(RCC_FSMC);
- regs->BCR = (uint32_t)0x00000000 | //FSMC_DataAddressMux_Disable
- (uint32_t)0x00000000 | //FSMC_MemoryType_SRAM
- (uint32_t)0x00000010 | //FSMC_MemoryDataWidth_16b
- (uint32_t)0x00000000 | //FSMC_BurstAccessMode_Disable
- (uint32_t)0x00000000 | //FSMC_WaitSignalPolarity_Low
- (uint32_t)0x00000000 | //FSMC_WrapMode_Disable
- (uint32_t)0x00000000 | //FSMC_WaitSignalActive_BeforeWaitState
- (uint32_t)0x00001000 | //FSMC_WriteOperation_Enable
- (uint32_t)0x00000000 | //FSMC_WaitSignal_Disable
- (uint32_t)0x00000000 | //FSMC_AsynchronousWait_Disable
- (uint32_t)0x00000000 | //FSMC_ExtendedMode_Disable
- (uint32_t)0x00000000; //FSMC_WriteBurst_Disable
- regs->BCR |= (uint32_t)0x00000040; //BCR_FACCEN_Set
- regs->BTR = (uint32_t) 3 | //FSMC_AddressSetupTime
- 0 << 4 | //FSMC_AddressHoldTime
- 3 << 8 | //FSMC_DataSetupTime
- 0 << 16 | //FSMC_BusTurnAroundDuration
- 0 << 20 | //FSMC_CLKDivision
- 0 << 24 | //FSMC_DataLatency
- 0; //FSMC_AccessMode_A
- *(extended) = 0x0FFFFFFF;
- regs->BCR |= (uint32_t)0x00000001; //BCR_MBKEN_Set
- // FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;
- // FSMC_NORSRAMTimingInitTypeDef FSMC_NORSRAMTimingInitStructure;
- // FSMC_NORSRAMTimingInitStructure.FSMC_AddressSetupTime = 10;
- // FSMC_NORSRAMTimingInitStructure.FSMC_AddressHoldTime = 0;
- // FSMC_NORSRAMTimingInitStructure.FSMC_DataSetupTime = 10;
- // FSMC_NORSRAMTimingInitStructure.FSMC_BusTurnAroundDuration = 0x00;
- // FSMC_NORSRAMTimingInitStructure.FSMC_CLKDivision = 0x00;
- // FSMC_NORSRAMTimingInitStructure.FSMC_DataLatency = 0x00;
- // FSMC_NORSRAMTimingInitStructure.FSMC_AccessMode = FSMC_AccessMode_A;
- //
- // FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1;
- // FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;
- // FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM;
- // FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;
- // FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;
- // FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
- // FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;
- // FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
- // FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;
- // FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
- // FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable;
- // FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;
- // FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
- // FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &FSMC_NORSRAMTimingInitStructure;
- // FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);
- // FSMC_NORSRAMTimingInitStructure.FSMC_AddressSetupTime = 3;
- // FSMC_NORSRAMTimingInitStructure.FSMC_AddressHoldTime = 0;
- // FSMC_NORSRAMTimingInitStructure.FSMC_DataSetupTime = 3;
- // FSMC_NORSRAMTimingInitStructure.FSMC_BusTurnAroundDuration = 0x00;
- // FSMC_NORSRAMTimingInitStructure.FSMC_CLKDivision = 0x00;
- // FSMC_NORSRAMTimingInitStructure.FSMC_DataLatency = 0x00;
- // FSMC_NORSRAMTimingInitStructure.FSMC_AccessMode = FSMC_AccessMode_A;
- // FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &FSMC_NORSRAMTimingInitStructure;
- //
- // FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);
- //
- // /* Enable FSMC Bank1_SRAM Bank */
- // FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE);
- }
- uint16_t LCD::GetPoint(uint16_t Xpos,uint16_t Ypos) {
- LCD::SetCursor(Xpos,Ypos);
- return ( LCD::BGR2RGB(LCD::ReadRAM()) );
- }
- uint16_t LCD::ReadRAM(void) {
- /* Write 16-bit Index (then Read Reg) */
- LCD_REG = R34; /* Select GRAM Reg */
- /* Read 16-bit Reg */
- return LCD_RAM;
- }
- uint16_t LCD::ReadReg(uint8_t LCD_Reg) {
- /* Write 16-bit Index (then Read Reg) */
- LCD_REG = LCD_Reg;
- /* Read 16-bit Reg */
- return (LCD_RAM);
- }
- void LCD::SetCursor(uint16_t Xpos,uint16_t Ypos) {
- if(LCD_DeviceCode==0x8989)
- {
- LCD::WriteReg(0x004e,Xpos); /* Row */
- LCD::WriteReg(0x004f,Ypos); /* Line */
- }
- else if(LCD_DeviceCode==0x9919)
- {
- LCD::WriteReg(0x004e,Xpos); /* Row */
- LCD::WriteReg(0x004f,Ypos); /* Line */
- }
- else
- {
- LCD::WriteReg(0x0020,Xpos); /* Row */
- LCD::WriteReg(0x0021,Ypos); /* Line */
- }
- }
- void LCD::SetPoint(uint16_t Xpos,uint16_t Ypos,uint16_t point) {
- LCD::SetCursor(Xpos,Ypos);
- LCD::WriteRAM_Prepare();
- LCD::WriteRAM(point);
- }
- void LCD::SetWindows(uint16_t xStart,uint16_t yStart,uint16_t xLong,uint16_t yLong) {
- LCD::SetCursor(xStart,yStart);
- LCD::WriteReg(0x0050,xStart);
- LCD::WriteReg(0x0051,xStart+xLong-1);
- LCD::WriteReg(0x0052,yStart);
- LCD::WriteReg(0x0053,yStart+yLong-1);
- }
- void LCD::WriteRAM(uint16_t RGB_Code) {
- /* Write 16-bit GRAM Reg */
- LCD_RAM = RGB_Code;
- }
- void LCD::WriteRAM_Prepare(void) {
- LCD_REG = R34;
- }
- void LCD::WriteReg(uint8_t LCD_Reg,uint16_t LCD_RegValue) {
- /* Write 16-bit Index, then Write Reg */
- LCD_REG = LCD_Reg;
- /* Write 16-bit Reg */
- LCD_RAM = LCD_RegValue;
- }
- void LCD::WriteText(uint16_t Xpos, uint16_t Ypos, char *str,uint16_t Color, uint16_t bkColor) {
- uint8_t TempChar;
- do
- {
- TempChar=*str++;
- PutChar(Xpos,Ypos,TempChar,Color,bkColor);
- if (Xpos<232)
- {
- Xpos+=8;
- }
- else if (Ypos<304)
- {
- Xpos=0;
- Ypos+=16;
- }
- else
- {
- Xpos=0;
- Ypos=0;
- }
- }
- while (*str!=0);
- }
- void LCD::PutChar(unsigned short Xpos,unsigned short Ypos,unsigned char c,unsigned short charColor,unsigned short bkColor) {
- unsigned short i=0;
- unsigned short j=0;
- unsigned char buffer[16];
- unsigned char tmp_char=0;
- GetASCIICode(buffer,c);
- for (i=0;i<16;i++) {
- tmp_char=buffer[i];
- for (j=0;j<8;j++) {
- if ( (tmp_char >> (7-j)) & (0x01 == 0x01))
- {
- LCD::SetPoint(Xpos+j,Ypos+i,charColor);
- }
- else
- {
- LCD::SetPoint(Xpos+j,Ypos+i,bkColor);
- }
- }
- }
- }
- void LCD::Inner_delay(uint8_t t) {
- delay(t);
- }
Advertisement
Add Comment
Please, Sign In to add comment