Browse Source

add new lcd driver ili9325

git-svn-id: https://rt-thread.googlecode.com/svn/trunk@200 bbd45198-f89e-11dd-88c7-29a3b14d5316
wuyangyong 15 years ago
parent
commit
e1a2102e51

+ 1002 - 0
bsp/stm32_radio/ili9325/ili9320.c

@@ -0,0 +1,1002 @@
+#include "stm32f10x.h"
+#include "ili9320.h"
+
+/* LCD Registers */
+#define       R0             0x00
+#define       R1             0x01
+#define       R2             0x02
+#define       R3             0x03
+#define       R4             0x04
+#define       R5             0x05
+#define       R6             0x06
+#define       R7             0x07
+#define       R8             0x08
+#define       R9             0x09
+#define       R10            0x0A
+#define       R12            0x0C
+#define       R13            0x0D
+#define       R14            0x0E
+#define       R15            0x0F
+#define       R16            0x10
+#define       R17            0x11
+#define       R18            0x12
+#define       R19            0x13
+#define       R20            0x14
+#define       R21            0x15
+#define       R22            0x16
+#define       R23            0x17
+#define       R24            0x18
+#define       R25            0x19
+#define       R26            0x1A
+#define       R27            0x1B
+#define       R28            0x1C
+#define       R29            0x1D
+#define       R30            0x1E
+#define       R31            0x1F
+#define       R32            0x20
+#define       R33            0x21
+#define       R34            0x22
+#define       R36            0x24
+#define       R37            0x25
+#define       R40            0x28
+#define       R41            0x29
+#define       R43            0x2B
+#define       R45            0x2D
+#define       R48            0x30
+#define       R49            0x31
+#define       R50            0x32
+#define       R51            0x33
+#define       R52            0x34
+#define       R53            0x35
+#define       R54            0x36
+#define       R55            0x37
+#define       R56            0x38
+#define       R57            0x39
+#define       R59            0x3B
+#define       R60            0x3C
+#define       R61            0x3D
+#define       R62            0x3E
+#define       R63            0x3F
+#define       R64            0x40
+#define       R65            0x41
+#define       R66            0x42
+#define       R67            0x43
+#define       R68            0x44
+#define       R69            0x45
+#define       R70            0x46
+#define       R71            0x47
+#define       R72            0x48
+#define       R73            0x49
+#define       R74            0x4A
+#define       R75            0x4B
+#define       R76            0x4C
+#define       R77            0x4D
+#define       R78            0x4E
+#define       R79            0x4F
+#define       R80            0x50
+#define       R81            0x51
+#define       R82            0x52
+#define       R83            0x53
+#define       R96            0x60
+#define       R97            0x61
+#define       R106           0x6A
+#define       R118           0x76
+#define       R128           0x80
+#define       R129           0x81
+#define       R130           0x82
+#define       R131           0x83
+#define       R132           0x84
+#define       R133           0x85
+#define       R134           0x86
+#define       R135           0x87
+#define       R136           0x88
+#define       R137           0x89
+#define       R139           0x8B
+#define       R140           0x8C
+#define       R141           0x8D
+#define       R143           0x8F
+#define       R144           0x90
+#define       R145           0x91
+#define       R146           0x92
+#define       R147           0x93
+#define       R148           0x94
+#define       R149           0x95
+#define       R150           0x96
+#define       R151           0x97
+#define       R152           0x98
+#define       R153           0x99
+#define       R154           0x9A
+#define       R157           0x9D
+#define       R192           0xC0
+#define       R193           0xC1
+#define       R229           0xE5
+
+/* LCD color */
+#define White          0xFFFF
+#define Black          0x0000
+#define Grey           0xF7DE
+#define Blue           0x001F
+#define Blue2          0x051F
+#define Red            0xF800
+#define Magenta        0xF81F
+#define Green          0x07E0
+#define Cyan           0x7FFF
+#define Yellow         0xFFE0
+
+
+static u16 DeviceCode;
+
+/* Private typedef -----------------------------------------------------------*/
+typedef struct
+{
+    vu16 LCD_REG;  /* 0x00 */
+    vu16 reserve1; /* 0x02 */
+    vu16 reserve2; /* 0x04 */
+    vu16 reserve3; /* 0x08 */
+    vu16 LCD_RAM;
+} LCD_ili9320_TypeDef;
+
+/* LCD is connected to the FSMC_Bank1_NOR/SRAM4 and NE4 is used as ship select signal */
+#define LCD_ili9320_BASE    ((u32)(0x60000000 | 0x04000000))
+#define LCD                 ((LCD_ili9320_TypeDef *) LCD_ili9320_BASE)
+
+#if 0
+static void ili9320_Delay(vu32 nCount)
+{
+    for (; nCount != 0; nCount--);
+}
+#endif
+
+static void LCD_CtrlLinesConfig(void)
+{
+    GPIO_InitTypeDef GPIO_InitStructure;
+
+    /* Enable FSMC, GPIOD, GPIOE, GPIOF, GPIOG and AFIO clocks */
+    RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);
+
+    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE |
+                           RCC_APB2Periph_GPIOF | RCC_APB2Periph_GPIOG |
+                           RCC_APB2Periph_AFIO, ENABLE);
+
+    /* Set PD.00(D2), PD.01(D3), PD.04(NOE), PD.05(NWE), PD.08(D13), PD.09(D14),
+       PD.10(D15), PD.14(D0), PD.15(D1) as alternate
+       function push pull */
+    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_4 | GPIO_Pin_5 |
+                                  GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_14 |
+                                  GPIO_Pin_15;
+    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
+    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
+    GPIO_Init(GPIOD, &GPIO_InitStructure);
+
+    /* Set PE.07(D4), PE.08(D5), PE.09(D6), PE.10(D7), PE.11(D8), PE.12(D9), PE.13(D10),
+       PE.14(D11), PE.15(D12) as alternate function push pull */
+    GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_6 | GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 |
+                                   GPIO_Pin_11 | GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 |
+                                   GPIO_Pin_15;
+    GPIO_Init(GPIOE, &GPIO_InitStructure);
+
+    GPIO_WriteBit(GPIOE, GPIO_Pin_6, Bit_SET);
+    /* Set PF.00(A0 (RS)) as alternate function push pull */
+    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_2;
+    GPIO_Init(GPIOF, &GPIO_InitStructure);
+
+    /* Set PG.12(NE4 (LCD/CS)) as alternate function push pull - CE3(LCD /CS) */
+    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
+    GPIO_Init(GPIOG, &GPIO_InitStructure);
+}
+
+/*******************************************************************************
+* Function Name  : LCD_FSMCConfig
+* Description    : Configures the Parallel interface (FSMC) for LCD(Parallel mode)
+* Input          : None
+* Output         : None
+* Return         : None
+*******************************************************************************/
+void LCD_FSMCConfig(void)
+{
+    FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure;
+    FSMC_NORSRAMTimingInitTypeDef  p;
+
+    /*-- FSMC Configuration ------------------------------------------------------*/
+    /*----------------------- SRAM Bank 4 ----------------------------------------*/
+    /* FSMC_Bank1_NORSRAM4 configuration */
+    p.FSMC_AddressSetupTime = 0;
+    p.FSMC_AddressHoldTime = 0;
+    p.FSMC_DataSetupTime = 2;
+    p.FSMC_BusTurnAroundDuration = 0;
+    p.FSMC_CLKDivision = 0;
+    p.FSMC_DataLatency = 0;
+    p.FSMC_AccessMode = FSMC_AccessMode_A;
+
+    /* Color LCD configuration ------------------------------------
+       LCD configured as follow:
+          - Data/Address MUX = Disable
+          - Memory Type = SRAM
+          - Data Width = 16bit
+          - Write Operation = Enable
+          - Extended Mode = Enable
+          - Asynchronous Wait = Disable */
+    FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM2;
+    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_ExtendedMode = FSMC_ExtendedMode_Disable;
+//  FSMC_NORSRAMInitStructure.FSMC_AsyncWait = FSMC_AsyncWait_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
+    FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p;
+    FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;
+
+    FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);
+
+    /* BANK 4 (of NOR/SRAM Bank 1~4) is enabled */
+    FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM2, ENABLE);
+}
+
+
+void LCD_X_Init(void)
+{
+    /* Configure the LCD Control pins --------------------------------------------*/
+    LCD_CtrlLinesConfig();
+
+    /* Configure the FSMC Parallel interface -------------------------------------*/
+    LCD_FSMCConfig();
+}
+
+
+/*******************************************************************************
+* Function Name  : LCD_WriteReg
+* Description    : Writes to the selected LCD register.
+* Input          : - LCD_Reg: address of the selected register.
+*                  - LCD_RegValue: value to write to the selected register.
+* Output         : None
+* Return         : None
+*******************************************************************************/
+void LCD_WriteReg(u8 LCD_Reg,u16 LCD_RegValue)
+{
+    /* Write 16-bit Index, then Write Reg */
+    LCD->LCD_REG = LCD_Reg;
+    /* Write 16-bit Reg */
+    LCD->LCD_RAM = LCD_RegValue;
+}
+
+/*******************************************************************************
+* Function Name  : LCD_ReadReg
+* Description    : Reads the selected LCD Register.
+* Input          : None
+* Output         : None
+* Return         : LCD Register Value.
+*******************************************************************************/
+u16 LCD_ReadReg(u8 LCD_Reg)
+{
+    /* Write 16-bit Index (then Read Reg) */
+    LCD->LCD_REG = LCD_Reg;
+    /* Read 16-bit Reg */
+    return (LCD->LCD_RAM);
+}
+
+/*******************************************************************************
+* Function Name  : LCD_WriteRAM_Prepare
+* Description    : Prepare to write to the LCD RAM.
+* Input          : None
+* Output         : None
+* Return         : None
+*******************************************************************************/
+void LCD_WriteRAM_Prepare(void)
+{
+    LCD->LCD_REG = R34;
+}
+
+/*******************************************************************************
+* Function Name  : LCD_WriteRAM
+* Description    : Writes to the LCD RAM.
+* Input          : - RGB_Code: the pixel color in RGB mode (5-6-5).
+* Output         : None
+* Return         : None
+*******************************************************************************/
+void LCD_WriteRAM(u16 RGB_Code)
+{
+    /* Write 16-bit GRAM Reg */
+    LCD->LCD_RAM = RGB_Code;
+}
+
+/*******************************************************************************
+* Function Name  : LCD_ReadRAM
+* Description    : Reads the LCD RAM.
+* Input          : None
+* Output         : None
+* Return         : LCD RAM Value.
+*******************************************************************************/
+u16 LCD_ReadRAM(void)
+{
+    //u16 dummy;
+    /* Write 16-bit Index (then Read Reg) */
+    LCD->LCD_REG = R34; /* Select GRAM Reg */
+    /* Read 16-bit Reg */
+    //dummy = LCD->LCD_RAM;
+    return LCD->LCD_RAM;
+}
+
+/*******************************************************************************
+* Function Name  : LCD_SetCursor
+* Description    : Sets the cursor position.
+* Input          : - Xpos: specifies the X position.
+*                  - Ypos: specifies the Y position.
+* Output         : None
+* Return         : None
+*******************************************************************************/
+
+
+void LCD_SetCursor(u16 Xpos, u16 Ypos)
+{
+    LCD_WriteReg(0x06,Ypos>>8);
+    LCD_WriteReg(0x07,Ypos);
+
+    LCD_WriteReg(0x02,Xpos>>8);
+    LCD_WriteReg(0x03,Xpos);
+}
+
+
+void Delay(u32 nCount)
+{
+    u32 TimingDelay;
+    while (nCount--)
+    {
+        for (TimingDelay=0;TimingDelay<10000;TimingDelay++);
+    }
+}
+
+void ili9320_Initializtion(void)
+{
+    /*****************************
+    **    硬件连接说明          **
+    ** STM32         ili9320    **
+    ** PE0~15 <----> DB0~15     **
+    ** PD15   <----> nRD        **
+    ** PD14   <----> RS         **
+    ** PD13   <----> nWR        **
+    ** PD12   <----> nCS        **
+    ** PD11   <----> nReset     **
+    ** PC0    <----> BK_LED     **
+    ******************************/
+    u16 i;
+    LCD_X_Init();
+
+    {
+        GPIO_InitTypeDef GPIO_InitStructure;
+
+        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOF,ENABLE);
+
+        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
+        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;
+        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
+        GPIO_Init(GPIOF,&GPIO_InitStructure);
+    }
+    GPIO_ResetBits(GPIOF, GPIO_Pin_10);
+    Delay(5);
+    GPIO_SetBits(GPIOF, GPIO_Pin_10);
+    Delay(5);
+
+    DeviceCode = LCD_ReadReg(0x0000);
+    if (DeviceCode==0x9325||DeviceCode==0x9328)
+    {
+        LCD_WriteReg(0x00e7,0x0010);
+        LCD_WriteReg(0x0000,0x0001);  			        //start internal osc
+        LCD_WriteReg(0x0001,0x0100);
+        LCD_WriteReg(0x0002,0x0700); 				    //power on sequence
+        /* [5:4]-ID~ID0 [3]-AM-1垂直-0水平 */
+        LCD_WriteReg(0x0003,(1<<12)|(1<<5)|(0<<4) | (1<<3) );
+        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); 				//0f3c
+        LCD_WriteReg(0x000f,0x0000);
+        //Power On sequence //
+        LCD_WriteReg(0x0010,0x0000);
+        LCD_WriteReg(0x0011,0x0007);
+        LCD_WriteReg(0x0012,0x0000);
+        LCD_WriteReg(0x0013,0x0000);
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+        LCD_WriteReg(0x0010,0x1590);
+        LCD_WriteReg(0x0011,0x0227);
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+        LCD_WriteReg(0x0012,0x009c);
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+        LCD_WriteReg(0x0013,0x1900);
+        LCD_WriteReg(0x0029,0x0023);
+        LCD_WriteReg(0x002b,0x000e);
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+        LCD_WriteReg(0x0020,0x0000);
+        LCD_WriteReg(0x0021,0x0000);
+///////////////////////////////////////////////////////
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+        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);
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+        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);
+    }
+    #if 0
+    else if (DeviceCode==0x9320||DeviceCode==0x9300)
+    {
+        LCD_WriteReg(0x00,0x0000);
+        LCD_WriteReg(0x01,0x0100);	//Driver Output Contral.
+        LCD_WriteReg(0x02,0x0700);	//LCD Driver Waveform Contral.
+//		LCD_WriteReg(0x03,0x1030);	//Entry Mode Set.
+        LCD_WriteReg(0x03,0x1018);	//Entry Mode Set.
+
+        LCD_WriteReg(0x04,0x0000);	//Scalling Contral.
+        LCD_WriteReg(0x08,0x0202);	//Display Contral 2.(0x0207)
+        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 1.(0x0000)
+        LCD_WriteReg(0x0d,0x0000);	//Frame Maker Position.
+        LCD_WriteReg(0x0f,0x0000);	//Extern Display Interface Contral 2.
+
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+        LCD_WriteReg(0x07,0x0101);	//Display Contral.
+        for (i=50000;i>0;i--);
+        for (i=50000;i>0;i--);
+
+        LCD_WriteReg(0x10,(1<<12)|(0<<8)|(1<<7)|(1<<6)|(0<<4));	//Power Control 1.(0x16b0)
+        LCD_WriteReg(0x11,0x0007);								//Power Control 2.(0x0001)
+        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);	//(0x0173)
+    }
+    else if (DeviceCode==0x9331)
+    {
+        LCD_WriteReg(0x00E7, 0x1014);
+        LCD_WriteReg(0x0001, 0x0100); // set SS and SM bit   0x0100
+        LCD_WriteReg(0x0002, 0x0200); // set 1 line inversion
+        LCD_WriteReg(0x0003, 0x1030); // set GRAM write direction and BGR=1.     0x1030
+        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
+        ili9320_Delay(200); // Dis-charge capacitor power voltage
+        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]
+        ili9320_Delay(50); // Delay 50ms
+        LCD_WriteReg(0x0012, 0x000C); // Internal reference voltage= Vci;
+        ili9320_Delay(50); // Delay 50ms
+        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
+        ili9320_Delay(50); // Delay 50ms
+        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);
+        ili9320_Delay(50);
+        LCD_WriteReg(0x0007,0x0061);
+        ili9320_Delay(50);
+        LCD_WriteReg(0x0007,0x0133);  // 262K color and display ON
+        ili9320_Delay(50);
+    }
+    else if (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);//70
+
+
+        //  RAM WRITE DATA MASK
+        LCD_WriteReg(0x0f,0x0000);
+        //  RAM WRITE DATA MASK
+        LCD_WriteReg(0x0b,0x5308);
+
+        LCD_WriteReg(0x0c,0x0003);
+
+        LCD_WriteReg(0x0d,0x000a);
+
+        LCD_WriteReg(0x0e,0x2e00);  //0030
+
+        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);	 //0007
+
+        LCD_WriteReg(0x31,0x0104);	   //0203
+
+        LCD_WriteReg(0x32,0x0100);		//0001
+
+        LCD_WriteReg(0x33,0x0305);	  //0007
+
+        LCD_WriteReg(0x34,0x0505);	  //0007
+
+        LCD_WriteReg(0x35,0x0305);		 //0407
+
+        LCD_WriteReg(0x36,0x0707);		 //0407
+
+        LCD_WriteReg(0x37,0x0300);		  //0607
+
+        LCD_WriteReg(0x3a,0x1200);		 //0106
+
+        LCD_WriteReg(0x3b,0x0800);
+
+        LCD_WriteReg(0x07,0x0033);
+    }
+    else if (DeviceCode==0x1505)
+    {
+        // second release on 3/5  ,luminance is acceptable,water wave appear during camera preview
+        LCD_WriteReg(0x0007,0x0000);
+        ili9320_Delay(5);
+        LCD_WriteReg(0x0012,0x011C);//0x011A   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); //0x0707
+        LCD_WriteReg(0x0032,0x0603);
+        LCD_WriteReg(0x0033,0x0700);
+        LCD_WriteReg(0x0034,0x0202);
+        LCD_WriteReg(0x0035,0x0002); //?0x0606
+        LCD_WriteReg(0x0036,0x1F0F);
+        LCD_WriteReg(0x0037,0x0707); //0x0f0f  0x0105
+        LCD_WriteReg(0x0038,0x0000);
+        LCD_WriteReg(0x0039,0x0000);
+        LCD_WriteReg(0x003A,0x0707);
+        LCD_WriteReg(0x003B,0x0000); //0x0303
+        LCD_WriteReg(0x003C,0x0007); //?0x0707
+        LCD_WriteReg(0x003D,0x0000); //0x1313//0x1f08
+        ili9320_Delay(5);
+        LCD_WriteReg(0x0007,0x0001);
+        LCD_WriteReg(0x0017,0x0001);   //Power supply startup enable
+        ili9320_Delay(5);
+
+        //power control//
+        LCD_WriteReg(0x0010,0x17A0);
+        LCD_WriteReg(0x0011,0x0217); //reference voltage VC[2:0]   Vciout = 1.00*Vcivl
+        LCD_WriteReg(0x0012,0x011E);//0x011c  //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); //0x0001F  Vcomh = VCM1[4:0]*Vreg1out    gate source voltage??
+        LCD_WriteReg(0x0012,0x013E); // 0x013C  power supply on
+        //Coordinates Control//
+        LCD_WriteReg(0x0050,0x0000);//0x0e00
+        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); //0x0010 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);
+        ili9320_Delay(20);
+        LCD_WriteReg(0x0007,0x0061);
+        ili9320_Delay(20);
+        LCD_WriteReg(0x0007,0x0173);
+        ili9320_Delay(20);
+    }
+    else if (DeviceCode==0x8989)
+    {
+        LCD_WriteReg(0x0000,0x0001);
+        ili9320_Delay(50000);  //打开晶振
+        LCD_WriteReg(0x0003,0xA8A4);
+        ili9320_Delay(50000);   //0xA8A4
+        LCD_WriteReg(0x000C,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x000D,0x080C);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x000E,0x2B00);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x001E,0x00B0);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0001,0x2B3F);
+        ili9320_Delay(50000);   //驱动输出控制320*240  0x6B3F
+        LCD_WriteReg(0x0002,0x0600);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0010,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0011,0x6070);
+        ili9320_Delay(50000);        //0x4030           //定义数据格式  16位色 		横屏 0x6058
+        LCD_WriteReg(0x0005,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0006,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0016,0xEF1C);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0017,0x0003);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0007,0x0233);
+        ili9320_Delay(50000);        //0x0233
+        LCD_WriteReg(0x000B,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x000F,0x0000);
+        ili9320_Delay(50000);        //扫描开始地址
+        LCD_WriteReg(0x0041,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0042,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0048,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0049,0x013F);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x004A,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x004B,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0044,0xEF00);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0045,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0046,0x013F);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0030,0x0707);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0031,0x0204);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0032,0x0204);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0033,0x0502);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0034,0x0507);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0035,0x0204);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0036,0x0204);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0037,0x0502);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x003A,0x0302);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x003B,0x0302);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0023,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0024,0x0000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x0025,0x8000);
+        ili9320_Delay(50000);
+        LCD_WriteReg(0x004f,0);        //行首址0
+        LCD_WriteReg(0x004e,0);        //列首址0
+    }
+    else if (DeviceCode==0x7783)
+    {
+        // Start Initial Sequence
+        LCD_WriteReg(0x00FF,0x0001);
+        LCD_WriteReg(0x00F3,0x0008);
+        LCD_WriteReg(0x0001,0x0100);
+        LCD_WriteReg(0x0002,0x0700);
+        LCD_WriteReg(0x0003,0x1030);  //0x1030
+        LCD_WriteReg(0x0008,0x0302);
+        LCD_WriteReg(0x0008,0x0207);
+        LCD_WriteReg(0x0009,0x0000);
+        LCD_WriteReg(0x000A,0x0000);
+        LCD_WriteReg(0x0010,0x0000);  //0x0790
+        LCD_WriteReg(0x0011,0x0005);
+        LCD_WriteReg(0x0012,0x0000);
+        LCD_WriteReg(0x0013,0x0000);
+        ili9320_Delay(50);
+        LCD_WriteReg(0x0010,0x12B0);
+        ili9320_Delay(50);
+        LCD_WriteReg(0x0011,0x0007);
+        ili9320_Delay(50);
+        LCD_WriteReg(0x0012,0x008B);
+        ili9320_Delay(50);
+        LCD_WriteReg(0x0013,0x1700);
+        ili9320_Delay(50);
+        LCD_WriteReg(0x0029,0x0022);
+
+        //################# void Gamma_Set(void) ####################//
+        LCD_WriteReg(0x0030,0x0000);
+        LCD_WriteReg(0x0031,0x0707);
+        LCD_WriteReg(0x0032,0x0505);
+        LCD_WriteReg(0x0035,0x0107);
+        LCD_WriteReg(0x0036,0x0008);
+        LCD_WriteReg(0x0037,0x0000);
+        LCD_WriteReg(0x0038,0x0202);
+        LCD_WriteReg(0x0039,0x0106);
+        LCD_WriteReg(0x003C,0x0202);
+        LCD_WriteReg(0x003D,0x0408);
+        ili9320_Delay(50);
+
+
+        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(0x0090,0x0033);
+        LCD_WriteReg(0x002B,0x000B);
+        //LCD_WriteReg(0x0007,0x0133);
+        ili9320_Delay(50);
+    }
+    #endif
+    for (i=50000;i>0;i--);
+    ili9320_Clear(White);
+}
+
+/****************************************************************************
+* 名    称:void ili9320_SetCursor(u16 x,u16 y)
+* 功    能:设置屏幕座标
+* 入口参数:x      行座标
+*           y      列座标
+* 出口参数:无
+* 说    明:
+* 调用方法:ili9320_SetCursor(10,10);
+****************************************************************************/
+__inline void ili9320_SetCursor(u16 x,u16 y)
+{
+    LCD_WriteReg(0x0020,x); /* 0-239 */
+    LCD_WriteReg(0x0021,y); /* 0-319 */
+}
+
+/****************************************************************************
+* 名    称:void ili9320_SetWindows(u16 StartX,u16 StartY,u16 EndX,u16 EndY)
+* 功    能:设置窗口区域
+* 入口参数:StartX     行起始座标
+*           StartY     列起始座标
+*           EndX       行结束座标
+*           EndY       列结束座标
+* 出口参数:无
+* 说    明:
+* 调用方法:ili9320_SetWindows(0,0,100,100);
+****************************************************************************/
+__inline void ili9320_SetWindows(u16 StartX,u16 StartY,u16 EndX,u16 EndY)
+{
+    ili9320_SetCursor(StartX,StartY);
+    LCD_WriteReg(0x0050, StartX);
+    LCD_WriteReg(0x0052, StartY);
+    LCD_WriteReg(0x0051, EndX);
+    LCD_WriteReg(0x0053, EndY);
+}
+
+/****************************************************************************
+* 名    称:void ili9320_Clear(u16 dat)
+* 功    能:将屏幕填充成指定的颜色,如清屏,则填充 0xffff
+* 入口参数:dat      填充值
+* 出口参数:无
+* 说    明:
+* 调用方法:ili9320_Clear(0xffff);
+****************************************************************************/
+void ili9320_Clear(u16 Color)
+{
+    u32 index=0;
+    ili9320_SetCursor(0,0);
+    LCD_WriteRAM_Prepare(); /* Prepare to write GRAM */
+    for (index=0;index<76800;index++)
+    {
+        LCD->LCD_RAM=Color;
+    }
+}
+
+/****************************************************************************
+* 名    称:u16 ili9320_GetPoint(u16 x,u16 y)
+* 功    能:获取指定座标的颜色值
+* 入口参数:x      行座标
+*           y      列座标
+* 出口参数:当前座标颜色值
+* 说    明:
+* 调用方法:i=ili9320_GetPoint(10,10);
+****************************************************************************/
+u16 ili9320_GetPoint(u16 x,u16 y)
+{
+    ili9320_SetCursor(x,y);
+    return (ili9320_BGR2RGB(LCD_ReadRAM()));
+}
+/****************************************************************************
+* 名    称:void ili9320_SetPoint(u16 x,u16 y,u16 point)
+* 功    能:在指定座标画点
+* 入口参数:x      行座标
+*           y      列座标
+*           point  点的颜色
+* 出口参数:无
+* 说    明:
+* 调用方法:ili9320_SetPoint(10,10,0x0fe0);
+****************************************************************************/
+void ili9320_SetPoint(u16 x,u16 y,u16 point)
+{
+    if ( (x>320)||(y>240) ) return;
+    ili9320_SetCursor(x,y);
+
+    LCD_WriteRAM_Prepare();
+    LCD_WriteRAM(point);
+}
+
+/****************************************************************************
+* 名    称:void ili9320_DrawPicture(u16 StartX,u16 StartY,u16 EndX,u16 EndY,u16 *pic)
+* 功    能:在指定座标范围显示一副图片
+* 入口参数:StartX     行起始座标
+*           StartY     列起始座标
+*           EndX       行结束座标
+*           EndY       列结束座标
+            pic        图片头指针
+* 出口参数:无
+* 说    明:图片取模格式为水平扫描,16位颜色模式
+* 调用方法:ili9320_DrawPicture(0,0,100,100,(u16*)demo);
+****************************************************************************/
+void ili9320_DrawPicture(u16 StartX,u16 StartY,u16 EndX,u16 EndY,u16 *pic)
+{
+    u16  i;
+    ili9320_SetWindows(StartX,StartY,EndX,EndY);
+    ili9320_SetCursor(StartX,StartY);
+
+    LCD_WriteRAM_Prepare();
+    for (i=0;i<(EndX*EndY);i++)
+    {
+        LCD_WriteRAM(*pic++);
+    }
+}
+
+
+/****************************************************************************
+* 名    称:u16 ili9320_BGR2RGB(u16 c)
+* 功    能:RRRRRGGGGGGBBBBB 改为 BBBBBGGGGGGRRRRR 格式
+* 入口参数:c      BRG 颜色值
+* 出口参数:RGB 颜色值
+* 说    明:内部函数调用
+* 调用方法:
+****************************************************************************/
+u16 ili9320_BGR2RGB(u16 c)
+{
+    u16  r, g, b, rgb;
+
+    b = (c>>0)  & 0x1f;
+    g = (c>>5)  & 0x3f;
+    r = (c>>11) & 0x1f;
+
+    rgb =  (b<<11) + (g<<5) + (r<<0);
+
+    return( rgb );
+}

+ 15 - 0
bsp/stm32_radio/ili9325/ili9320.h

@@ -0,0 +1,15 @@
+#ifndef ILI9320_H_INCLUDED
+#define ILI9320_H_INCLUDED
+
+extern void ili9320_Initializtion(void);
+extern void ili9320_SetCursor(u16 x,u16 y);
+extern void ili9320_Clear(u16 Color);
+
+extern u16 ili9320_BGR2RGB(u16 c);
+
+extern void LCD_WriteRAM_Prepare(void);
+extern void LCD_WriteRAM(u16 RGB_Code);
+extern u16 LCD_ReadRAM(void);
+extern void LCD_WriteReg(u8 LCD_Reg,u16 LCD_RegValue);
+
+#endif

+ 258 - 87
bsp/stm32_radio/lcd.c

@@ -1,11 +1,25 @@
 #include "stm32f10x.h"
 #include "rtthread.h"
-#include "fmt0371/FMT0371.h"
 #include <rtgui/rtgui.h>
 #include <rtgui/driver.h>
 #include <rtgui/rtgui_server.h>
 #include <rtgui/rtgui_system.h>
 
+#define lcd_hw_version       1
+/*
+1 FMT0371
+2 ILI9325
+*/
+
+#if (lcd_hw_version == 1)
+#include "fmt0371/FMT0371.h"
+#endif
+
+#if (lcd_hw_version == 2)
+#include "ili9325/ili9320.h"
+#endif
+
+rt_err_t rt_hw_lcd_init(void);
 void rt_hw_lcd_update(rtgui_rect_t *rect);
 rt_uint8_t * rt_hw_lcd_get_framebuffer(void);
 void rt_hw_lcd_set_pixel(rtgui_color_t *c, rt_base_t x, rt_base_t y);
@@ -16,45 +30,75 @@ void rt_hw_lcd_draw_raw_hline(rt_uint8_t *pixels, rt_base_t x1, rt_base_t x2, rt
 
 struct rtgui_graphic_driver _rtgui_lcd_driver =
 {
-	"lcd",
-	2,
-	240,
-	320,
-	rt_hw_lcd_update,
-	rt_hw_lcd_get_framebuffer,
-	rt_hw_lcd_set_pixel,
-	rt_hw_lcd_get_pixel,
-	rt_hw_lcd_draw_hline,
-	rt_hw_lcd_draw_vline,
-	rt_hw_lcd_draw_raw_hline
+    "lcd",
+    2,
+    240,
+    320,
+    rt_hw_lcd_update,
+    rt_hw_lcd_get_framebuffer,
+    rt_hw_lcd_set_pixel,
+    rt_hw_lcd_get_pixel,
+    rt_hw_lcd_draw_hline,
+    rt_hw_lcd_draw_vline,
+    rt_hw_lcd_draw_raw_hline
 };
 
+extern  void   info_init(void);
+extern  void   player_init(void);
+void radio_rtgui_init(void)
+{
+    rtgui_rect_t rect;
+
+    rtgui_system_server_init();
+
+    /* register dock panel */
+    rect.x1 = 0;
+    rect.y1 = 0;
+    rect.x2 = 240;
+    rect.y2 = 25;
+    rtgui_panel_register("info", &rect);
+
+    /* register main panel */
+    rect.x1 = 0;
+    rect.y1 = 25;
+    rect.x2 = 320;
+    rect.y2 = 320;
+    rtgui_panel_register("main", &rect);
+    rtgui_panel_set_default_focused("main");
+
+    rt_hw_lcd_init();
+
+    info_init();
+    player_init();
+}
+
+#if (lcd_hw_version == 1)
 void rt_hw_lcd_update(rtgui_rect_t *rect)
 {
-	/* nothing for none-DMA mode driver */
+    /* nothing for none-DMA mode driver */
 }
 
 rt_uint8_t * rt_hw_lcd_get_framebuffer(void)
 {
-	return RT_NULL; /* no framebuffer driver */
+    return RT_NULL; /* no framebuffer driver */
 }
 
 void rt_hw_lcd_set_pixel(rtgui_color_t *c, rt_base_t x, rt_base_t y)
 {
     unsigned short p;
 
-	/* get color pixel */
-	p = rtgui_color_to_565p(*c);
+    /* get color pixel */
+    p = rtgui_color_to_565p(*c);
 
-	/* set X point */
+    /* set X point */
     LCD_ADDR = 0x02;
     LCD_DATA = x;
 
-	/* set Y point */
+    /* set Y point */
     LCD_ADDR = 0x03;
     LCD_DATA16(y);
 
-	/* write pixel */
+    /* write pixel */
     LCD_ADDR = 0x0E;
     LCD_DATA16(p);
 }
@@ -63,92 +107,93 @@ void rt_hw_lcd_get_pixel(rtgui_color_t *c, rt_base_t x, rt_base_t y)
 {
     unsigned short p;
 
-	/* set X point */
+    /* set X point */
     LCD_ADDR = 0x02;
     LCD_DATA = x;
 
-	/* set Y point */
+    /* set Y point */
     LCD_ADDR = 0x03;
     LCD_DATA16( y );
 
-	/* read pixel */
-	LCD_ADDR = 0x0F;
-	LCD_DATA16_READ(p);
+    /* read pixel */
+    LCD_ADDR = 0x0F;
+    LCD_DATA16_READ(p);
 
-	*c = rtgui_color_from_565p(p);
+    *c = rtgui_color_from_565p(p);
 }
 
 void rt_hw_lcd_draw_hline(rtgui_color_t *c, rt_base_t x1, rt_base_t x2, rt_base_t y)
 {
     unsigned short p;
 
-	/* get color pixel */
-	p = rtgui_color_to_565p(*c);
+    /* get color pixel */
+    p = rtgui_color_to_565p(*c);
 
-	/* set X point */
+    /* set X point */
     LCD_ADDR = 0x02;
     LCD_DATA = x1;
 
-	/* set Y point */
+    /* set Y point */
     LCD_ADDR = 0x03;
     LCD_DATA16( y );
 
-	/* write pixel */
+    /* write pixel */
     LCD_ADDR = 0x0E;
-	while (x1 < x2)
-	{
-		LCD_DATA16(p);
-		x1 ++;
-	}
+    while (x1 < x2)
+    {
+        LCD_DATA16(p);
+        x1 ++;
+    }
 }
 
 void rt_hw_lcd_draw_vline(rtgui_color_t *c, rt_base_t x, rt_base_t y1, rt_base_t y2)
 {
     unsigned short p;
 
-	/* get color pixel */
-	p = rtgui_color_to_565p(*c);
+    /* get color pixel */
+    p = rtgui_color_to_565p(*c);
 
-	/* set X point */
+    /* set X point */
     LCD_ADDR = 0x02;
     LCD_DATA = x;
 
-	while(y1 < y2)
-	{
-		/* set Y point */
-		LCD_ADDR = 0x03;
-		LCD_DATA16( y1 );
+    while (y1 < y2)
+    {
+        /* set Y point */
+        LCD_ADDR = 0x03;
+        LCD_DATA16( y1 );
 
-		/* write pixel */
-		LCD_ADDR = 0x0E;
-		LCD_DATA16(p);
+        /* write pixel */
+        LCD_ADDR = 0x0E;
+        LCD_DATA16(p);
 
-		y1 ++;
-	}
+        y1 ++;
+    }
 }
 
 void rt_hw_lcd_draw_raw_hline(rt_uint8_t *pixels, rt_base_t x1, rt_base_t x2, rt_base_t y)
 {
     rt_uint16_t *ptr;
 
-	/* get pixel */
-	ptr = (rt_uint16_t*) pixels;
+    /* get pixel */
+    ptr = (rt_uint16_t*) pixels;
 
-	/* set X point */
+    /* set X point */
     LCD_ADDR = 0x02;
     LCD_DATA = x1;
 
-	/* set Y point */
+    /* set Y point */
     LCD_ADDR = 0x03;
     LCD_DATA16( y );
 
-	/* write pixel */
+    /* write pixel */
     LCD_ADDR = 0x0E;
-	while (x1 < x2)
-	{
-		LCD_DATA16(*ptr);
-		x1 ++; ptr ++;
-	}
+    while (x1 < x2)
+    {
+        LCD_DATA16(*ptr);
+        x1 ++;
+        ptr ++;
+    }
 }
 
 rt_err_t rt_hw_lcd_init(void)
@@ -166,60 +211,186 @@ rt_err_t rt_hw_lcd_init(void)
     ftm0371_init();
 
 #ifndef DRIVER_TEST
-	/* add lcd driver into graphic driver */
-	rtgui_graphic_driver_add(&_rtgui_lcd_driver);
+    /* add lcd driver into graphic driver */
+    rtgui_graphic_driver_add(&_rtgui_lcd_driver);
 #endif
 
-	return RT_EOK;
+    return RT_EOK;
 }
 
-void radio_rtgui_init()
+#include <finsh.h>
+
+void hline(rt_base_t x1, rt_base_t x2, rt_base_t y, rt_uint32_t pixel)
 {
-	rtgui_rect_t rect;
+    rt_hw_lcd_draw_hline(&pixel, x1, x2, y);
+}
+FINSH_FUNCTION_EXPORT(hline, draw a hline);
 
-	rtgui_system_server_init();
+void vline(int x, int y1, int y2, rt_uint32_t pixel)
+{
+    rt_hw_lcd_draw_vline(&pixel, x, y1, y2);
+}
+FINSH_FUNCTION_EXPORT(vline, draw a vline);
 
-	/* register dock panel */
-	rect.x1 = 0;
-	rect.y1 = 0;
-	rect.x2 = 240;
-	rect.y2 = 25;
-	rtgui_panel_register("info", &rect);
+void cls()
+{
+    rt_size_t index;
+    rtgui_color_t white 	= RTGUI_RGB(0xff, 0xff, 0xff);
 
-	/* register main panel */
-	rect.x1 = 0;
-	rect.y1 = 25;
-	rect.x2 = 320;
-	rect.y2 = 320;
-	rtgui_panel_register("main", &rect);
-	rtgui_panel_set_default_focused("main");
+    for (index = 0; index < 320; index ++)
+        rt_hw_lcd_draw_hline(&white, 0, 240, index);
+}
+FINSH_FUNCTION_EXPORT(cls, clear screen);
+#endif
 
-	rt_hw_lcd_init();
+#if (lcd_hw_version == 2)
+void rt_hw_lcd_update(rtgui_rect_t *rect)
+{
+    /* nothing for none-DMA mode driver */
+}
 
-	info_init();
-	player_init();
+rt_uint8_t * rt_hw_lcd_get_framebuffer(void)
+{
+    return RT_NULL; /* no framebuffer driver */
+}
+
+/*  设置像素点 颜色,X,Y */
+void rt_hw_lcd_set_pixel(rtgui_color_t *c, rt_base_t x, rt_base_t y)
+{
+    unsigned short p;
+
+    if ( (x>320)||(y>240) ) return;
+
+    /* get color pixel */
+    p = rtgui_color_to_565p(*c);
+    ili9320_SetCursor(x,y);
+
+    LCD_WriteRAM_Prepare();
+    LCD_WriteRAM(p);
+}
+
+/* 获取像素点颜色 */
+void rt_hw_lcd_get_pixel(rtgui_color_t *c, rt_base_t x, rt_base_t y)
+{
+    unsigned short p;
+
+    ili9320_SetCursor(x,y);
+    //if (DeviceCode==0x7783)
+    //{
+    //    p = (LCD_ReadRAM());
+    //}
+    //else
+    //{
+    p = (ili9320_BGR2RGB(LCD_ReadRAM()));
+    //}
+    *c = rtgui_color_from_565p(p);
+}
+
+/* 画水平线 */
+void rt_hw_lcd_draw_hline(rtgui_color_t *c, rt_base_t x1, rt_base_t x2, rt_base_t y)
+{
+    unsigned short p;
+
+    /* get color pixel */
+    p = rtgui_color_to_565p(*c);
+
+    /* [5:4]-ID~ID0 [3]-AM-1垂直-0水平 */
+    LCD_WriteReg(0x0003,(1<<12)|(1<<5)|(0<<4) | (0<<3) );
+
+    ili9320_SetCursor(x1, y);
+    LCD_WriteRAM_Prepare(); /* Prepare to write GRAM */
+    while (x1 < x2)
+    {
+        //LCD_WriteRAM_Prepare(); /* Prepare to write GRAM */
+        LCD_WriteRAM(p);
+        x1++;
+        //ili9320_SetCursor(x1, y);
+    }
+}
+
+/* 垂直线 */
+void rt_hw_lcd_draw_vline(rtgui_color_t *c, rt_base_t x, rt_base_t y1, rt_base_t y2)
+{
+    unsigned short p;
+
+    /* get color pixel */
+    p = rtgui_color_to_565p(*c);
+
+    /* [5:4]-ID~ID0 [3]-AM-1垂直-0水平 */
+    LCD_WriteReg(0x0003,(1<<12)|(1<<5)|(0<<4) | (1<<3) );
+
+    ili9320_SetCursor(x, y1);
+    LCD_WriteRAM_Prepare(); /* Prepare to write GRAM */
+    while (y1 < y2)
+    {
+        //LCD_WriteRAM_Prepare(); /* Prepare to write GRAM */
+        LCD_WriteRAM(p);
+        y1++;
+        //ili9320_SetCursor(x, y1);
+    }
+}
+
+/* ?? */
+void rt_hw_lcd_draw_raw_hline(rt_uint8_t *pixels, rt_base_t x1, rt_base_t x2, rt_base_t y)
+{
+    rt_uint16_t *ptr;
+
+    /* get pixel */
+    ptr = (rt_uint16_t*) pixels;
+
+    /* [5:4]-ID~ID0 [3]-AM-1垂直-0水平 */
+    //LCD_WriteReg(0x0003,(1<<12)|(1<<5)|(0<<4) | (0<<3) );
+
+    ili9320_SetCursor(x1, y);
+    LCD_WriteRAM_Prepare(); /* Prepare to write GRAM */
+    while (x1 < x2)
+    {
+        LCD_WriteRAM_Prepare(); /* Prepare to write GRAM */
+        LCD_WriteRAM( *ptr );
+        x1 ++;
+        ptr ++;
+        ili9320_SetCursor(x1, y);
+    }
+}
+
+rt_err_t rt_hw_lcd_init(void)
+{
+    GPIO_InitTypeDef GPIO_InitStructure;
+
+    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOF,ENABLE);
+    GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_9;
+    GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_Out_PP;
+    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
+    GPIO_Init(GPIOF,&GPIO_InitStructure);
+    GPIO_SetBits(GPIOF,GPIO_Pin_9);
+
+    ili9320_Initializtion();
+
+#ifndef DRIVER_TEST
+    /* add lcd driver into graphic driver */
+    rtgui_graphic_driver_add(&_rtgui_lcd_driver);
+#endif
+
+    return RT_EOK;
 }
 
 #include <finsh.h>
 
 void hline(rt_base_t x1, rt_base_t x2, rt_base_t y, rt_uint32_t pixel)
 {
-	rt_hw_lcd_draw_hline(&pixel, x1, x2, y);
+    rt_hw_lcd_draw_hline(&pixel, x1, x2, y);
 }
 FINSH_FUNCTION_EXPORT(hline, draw a hline);
 
 void vline(int x, int y1, int y2, rt_uint32_t pixel)
 {
-	rt_hw_lcd_draw_vline(&pixel, x, y1, y2);
+    rt_hw_lcd_draw_vline(&pixel, x, y1, y2);
 }
 FINSH_FUNCTION_EXPORT(vline, draw a vline);
 
 void cls()
 {
-	rt_size_t index;
-	rtgui_color_t white 	= RTGUI_RGB(0xff, 0xff, 0xff);
-
-	for(index = 0; index < 320; index ++)
-		rt_hw_lcd_draw_hline(&white, 0, 240, index);
+    ili9320_Clear(0xF800);
 }
 FINSH_FUNCTION_EXPORT(cls, clear screen);
+#endif

+ 176 - 175
bsp/stm32_radio/project.Opt

@@ -25,9 +25,9 @@ GRPOPT 10,(RTGUI),0,0,0
 OPTFFF 1,1,5,0,0,0,0,0,<.\rtconfig.h><rtconfig.h> 
 OPTFFF 1,2,5,0,0,0,0,0,<.\board.h><board.h> 
 OPTFFF 1,3,5,0,0,0,0,0,<.\stm32f10x_conf.h><stm32f10x_conf.h> 
-OPTFFF 1,4,1,0,0,0,0,0,<.\application.c><application.c> 
+OPTFFF 1,4,1,251658240,0,0,0,0,<.\application.c><application.c> 
 OPTFFF 1,5,1,0,0,0,0,0,<.\board.c><board.c> 
-OPTFFF 1,6,1,0,0,0,0,0,<.\startup.c><startup.c> 
+OPTFFF 1,6,1,268435458,0,1,25,0,<.\startup.c><startup.c> { 44,0,0,0,2,0,0,0,3,0,0,0,255,255,255,255,255,255,255,255,252,255,255,255,226,255,255,255,22,0,0,0,29,0,0,0,12,4,0,0,124,1,0,0 }
 OPTFFF 1,7,1,0,0,0,0,0,<.\stm32f10x_it.c><stm32f10x_it.c> 
 OPTFFF 1,8,1,0,0,0,0,0,<.\usart.c><usart.c> 
 OPTFFF 1,9,1,402653184,0,0,0,0,<.\sdcard.c><sdcard.c> 
@@ -37,185 +37,185 @@ OPTFFF 1,12,1,889192448,0,0,0,0,<.\fsmc_nand.c><fsmc_nand.c>
 OPTFFF 1,13,1,0,0,0,0,0,<.\fsmc_sram.c><fsmc_sram.c> 
 OPTFFF 1,14,1,0,0,0,0,0,<.\fmt0371\fmt0371.c><fmt0371.c> 
 OPTFFF 1,15,1,0,0,0,0,0,<.\http.c><http.c> 
-OPTFFF 1,16,1,0,0,0,0,0,<.\lcd.c><lcd.c> 
-OPTFFF 1,17,1,16777216,0,401,410,0,<.\mp3.c><mp3.c> { 44,0,0,0,0,0,0,0,1,0,0,0,255,255,255,255,255,255,255,255,252,255,255,255,226,255,255,255,22,0,0,0,29,0,0,0,164,2,0,0,145,1,0,0 }
+OPTFFF 1,16,1,402653184,0,0,0,0,<.\lcd.c><lcd.c> 
+OPTFFF 1,17,1,16777216,0,0,0,0,<.\mp3.c><mp3.c> 
 OPTFFF 1,18,1,369098752,0,0,0,0,<.\wav.c><wav.c> 
 OPTFFF 1,19,1,0,0,0,0,0,<.\netbuffer.c><netbuffer.c> 
 OPTFFF 1,20,1,0,0,0,0,0,<.\key.c><key.c> 
-OPTFFF 1,21,1,553648128,0,0,0,0,<.\info.c><info.c> 
+OPTFFF 1,21,1,0,0,0,0,0,<.\info.c><info.c> 
 OPTFFF 1,22,1,0,0,0,0,0,<.\filelist.c><filelist.c> 
 OPTFFF 1,23,1,0,0,0,0,0,<.\device_info.c><device_info.c> 
 OPTFFF 1,24,1,0,0,0,0,0,<.\listview.c><listview.c> 
 OPTFFF 1,25,1,0,0,0,0,0,<.\wm8753.c><wm8753.c> 
-OPTFFF 1,26,1,3,0,481,487,0,<.\player_ui.c><player_ui.c> { 44,0,0,0,2,0,0,0,3,0,0,0,255,255,255,255,255,255,255,255,252,255,255,255,226,255,255,255,0,0,0,0,0,0,0,0,186,2,0,0,218,0,0,0 }
-OPTFFF 1,27,1,268435456,0,1,1,0,<.\player_bg.c><player_bg.c> { 44,0,0,0,0,0,0,0,1,0,0,0,255,255,255,255,255,255,255,255,252,255,255,255,226,255,255,255,66,0,0,0,87,0,0,0,252,2,0,0,49,1,0,0 }
+OPTFFF 1,26,1,0,0,0,0,0,<.\player_ui.c><player_ui.c> 
+OPTFFF 1,27,1,0,0,0,0,0,<.\player_bg.c><player_bg.c> 
 OPTFFF 1,28,1,0,0,0,0,0,<.\wm8978.c><wm8978.c> 
 OPTFFF 1,29,1,469762048,0,0,0,0,<.\play_list.c><play_list.c> 
-OPTFFF 2,30,1,0,0,0,0,0,<..\..\src\clock.c><clock.c> 
-OPTFFF 2,31,1,0,0,0,0,0,<..\..\src\idle.c><idle.c> 
-OPTFFF 2,32,1,0,0,0,0,0,<..\..\src\ipc.c><ipc.c> 
-OPTFFF 2,33,1,0,0,0,0,0,<..\..\src\mempool.c><mempool.c> 
-OPTFFF 2,34,1,0,0,0,0,0,<..\..\src\mem.c><mem.c> 
-OPTFFF 2,35,1,0,0,0,0,0,<..\..\src\object.c><object.c> 
-OPTFFF 2,36,1,0,0,0,0,0,<..\..\src\scheduler.c><scheduler.c> 
-OPTFFF 2,37,1,285212672,0,0,0,0,<..\..\src\thread.c><thread.c> 
-OPTFFF 2,38,1,0,0,0,0,0,<..\..\src\timer.c><timer.c> 
-OPTFFF 2,39,1,0,0,0,0,0,<..\..\src\irq.c><irq.c> 
-OPTFFF 2,40,1,0,0,0,0,0,<..\..\src\kservice.c><kservice.c> 
-OPTFFF 2,41,1,0,0,0,0,0,<..\..\src\device.c><device.c> 
-OPTFFF 2,42,1,0,0,0,0,0,<..\..\src\slab.c><slab.c> 
-OPTFFF 3,43,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\stack.c><stack.c> 
-OPTFFF 3,44,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\interrupt.c><interrupt.c> 
-OPTFFF 3,45,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\cpu.c><cpu.c> 
-OPTFFF 3,46,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\serial.c><serial.c> 
-OPTFFF 3,47,2,0,0,0,0,0,<..\..\libcpu\arm\stm32\context_rvds.S><context_rvds.S> 
-OPTFFF 3,48,2,0,0,13,19,0,<..\..\libcpu\arm\stm32\start_rvds.s><start_rvds.s> { 44,0,0,0,0,0,0,0,1,0,0,0,255,255,255,255,255,255,255,255,252,255,255,255,226,255,255,255,88,0,0,0,116,0,0,0,1,3,0,0,232,1,0,0 }
-OPTFFF 3,49,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\fault.c><fault.c> 
-OPTFFF 3,50,2,0,0,0,0,0,<..\..\libcpu\arm\stm32\fault_rvds.S><fault_rvds.S> 
-OPTFFF 4,51,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\misc.c><misc.c> 
-OPTFFF 4,52,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_adc.c><stm32f10x_adc.c> 
-OPTFFF 4,53,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_bkp.c><stm32f10x_bkp.c> 
-OPTFFF 4,54,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_can.c><stm32f10x_can.c> 
-OPTFFF 4,55,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_crc.c><stm32f10x_crc.c> 
-OPTFFF 4,56,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_dac.c><stm32f10x_dac.c> 
-OPTFFF 4,57,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_dbgmcu.c><stm32f10x_dbgmcu.c> 
-OPTFFF 4,58,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_dma.c><stm32f10x_dma.c> 
-OPTFFF 4,59,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_exti.c><stm32f10x_exti.c> 
-OPTFFF 4,60,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_flash.c><stm32f10x_flash.c> 
-OPTFFF 4,61,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_fsmc.c><stm32f10x_fsmc.c> 
-OPTFFF 4,62,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_gpio.c><stm32f10x_gpio.c> 
-OPTFFF 4,63,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_i2c.c><stm32f10x_i2c.c> 
-OPTFFF 4,64,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_iwdg.c><stm32f10x_iwdg.c> 
-OPTFFF 4,65,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_pwr.c><stm32f10x_pwr.c> 
-OPTFFF 4,66,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_rcc.c><stm32f10x_rcc.c> 
-OPTFFF 4,67,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_rtc.c><stm32f10x_rtc.c> 
-OPTFFF 4,68,1,16777216,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_sdio.c><stm32f10x_sdio.c> 
-OPTFFF 4,69,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_spi.c><stm32f10x_spi.c> 
-OPTFFF 4,70,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_tim.c><stm32f10x_tim.c> 
-OPTFFF 4,71,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_usart.c><stm32f10x_usart.c> 
-OPTFFF 4,72,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_wwdg.c><stm32f10x_wwdg.c> 
-OPTFFF 5,73,1,0,0,0,0,0,<.\Libraries\CMSIS\Core\CM3\core_cm3.c><core_cm3.c> 
-OPTFFF 5,74,1,0,0,0,0,0,<.\Libraries\CMSIS\Core\CM3\system_stm32f10x.c><system_stm32f10x.c> 
-OPTFFF 6,75,1,0,0,0,0,0,<..\..\finsh\finsh_compiler.c><finsh_compiler.c> 
-OPTFFF 6,76,1,0,0,0,0,0,<..\..\finsh\finsh_error.c><finsh_error.c> 
-OPTFFF 6,77,1,0,0,0,0,0,<..\..\finsh\finsh_heap.c><finsh_heap.c> 
-OPTFFF 6,78,1,0,0,0,0,0,<..\..\finsh\finsh_init.c><finsh_init.c> 
-OPTFFF 6,79,1,0,0,0,0,0,<..\..\finsh\finsh_node.c><finsh_node.c> 
-OPTFFF 6,80,1,0,0,0,0,0,<..\..\finsh\finsh_ops.c><finsh_ops.c> 
-OPTFFF 6,81,1,0,0,0,0,0,<..\..\finsh\finsh_parser.c><finsh_parser.c> 
-OPTFFF 6,82,1,0,0,0,0,0,<..\..\finsh\finsh_token.c><finsh_token.c> 
-OPTFFF 6,83,1,0,0,0,0,0,<..\..\finsh\finsh_var.c><finsh_var.c> 
-OPTFFF 6,84,1,0,0,0,0,0,<..\..\finsh\finsh_vm.c><finsh_vm.c> 
-OPTFFF 6,85,1,0,0,0,0,0,<..\..\finsh\shell.c><shell.c> 
-OPTFFF 6,86,1,0,0,0,0,0,<..\..\finsh\symbol.c><symbol.c> 
-OPTFFF 6,87,1,285212672,0,0,0,0,<..\..\finsh\cmd.c><cmd.c> 
-OPTFFF 7,88,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_init.c><dfs_init.c> 
-OPTFFF 7,89,1,503316480,0,0,0,0,<..\..\filesystem\dfs\src\dfs_fs.c><dfs_fs.c> 
-OPTFFF 7,90,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_raw.c><dfs_raw.c> 
-OPTFFF 7,91,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_util.c><dfs_util.c> 
-OPTFFF 7,92,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_posix.c><dfs_posix.c> 
-OPTFFF 7,93,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\dir.c><dir.c> 
-OPTFFF 7,94,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\fat.c><fat.c> 
-OPTFFF 7,95,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\file.c><file.c> 
-OPTFFF 7,96,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\fs.c><fs.c> 
-OPTFFF 7,97,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\ls.c><ls.c> 
-OPTFFF 7,98,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\time.c><time.c> 
-OPTFFF 7,99,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\ui.c><ui.c> 
-OPTFFF 7,100,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\plibc.c><plibc.c> 
-OPTFFF 7,101,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\efs.c><efs.c> 
-OPTFFF 7,102,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\extract.c><extract.c> 
-OPTFFF 7,103,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\partition.c><partition.c> 
-OPTFFF 7,104,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_cache.c><dfs_cache.c> 
-OPTFFF 8,105,1,0,0,0,0,0,<..\..\net\lwip\src\core\dhcp.c><dhcp.c> 
-OPTFFF 8,106,1,0,0,0,0,0,<..\..\net\lwip\src\core\dns.c><dns.c> 
-OPTFFF 8,107,1,0,0,0,0,0,<..\..\net\lwip\src\core\init.c><init.c> 
-OPTFFF 8,108,1,0,0,0,0,0,<..\..\net\lwip\src\core\netif.c><netif.c> 
-OPTFFF 8,109,1,0,0,0,0,0,<..\..\net\lwip\src\core\pbuf.c><pbuf.c> 
-OPTFFF 8,110,1,0,0,0,0,0,<..\..\net\lwip\src\core\raw.c><raw.c> 
-OPTFFF 8,111,1,0,0,0,0,0,<..\..\net\lwip\src\core\stats.c><stats.c> 
-OPTFFF 8,112,1,0,0,0,0,0,<..\..\net\lwip\src\core\sys.c><sys.c> 
-OPTFFF 8,113,1,0,0,0,0,0,<..\..\net\lwip\src\core\tcp.c><tcp.c> 
-OPTFFF 8,114,1,0,0,0,0,0,<..\..\net\lwip\src\core\tcp_in.c><tcp_in.c> 
-OPTFFF 8,115,1,0,0,0,0,0,<..\..\net\lwip\src\core\tcp_out.c><tcp_out.c> 
-OPTFFF 8,116,1,0,0,0,0,0,<..\..\net\lwip\src\core\udp.c><udp.c> 
-OPTFFF 8,117,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\autoip.c><autoip.c> 
-OPTFFF 8,118,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\icmp.c><icmp.c> 
-OPTFFF 8,119,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\igmp.c><igmp.c> 
-OPTFFF 8,120,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\inet.c><inet.c> 
-OPTFFF 8,121,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\inet_chksum.c><inet_chksum.c> 
-OPTFFF 8,122,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\ip.c><ip.c> 
-OPTFFF 8,123,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\ip_addr.c><ip_addr.c> 
-OPTFFF 8,124,1,285212672,0,0,0,0,<..\..\net\lwip\src\core\ipv4\ip_frag.c><ip_frag.c> 
-OPTFFF 8,125,1,0,0,0,0,0,<..\..\net\lwip\src\core\snmp\msg_in.c><msg_in.c> 
-OPTFFF 8,126,1,0,0,0,0,0,<..\..\net\lwip\src\core\snmp\msg_out.c><msg_out.c> 
-OPTFFF 8,127,1,0,0,0,0,0,<..\..\net\lwip\src\api\api_lib.c><api_lib.c> 
-OPTFFF 8,128,1,50331648,0,0,0,0,<..\..\net\lwip\src\api\api_msg.c><api_msg.c> 
-OPTFFF 8,129,1,0,0,0,0,0,<..\..\net\lwip\src\api\err.c><err.c> 
-OPTFFF 8,130,1,0,0,0,0,0,<..\..\net\lwip\src\api\netbuf.c><netbuf.c> 
-OPTFFF 8,131,1,0,0,0,0,0,<..\..\net\lwip\src\api\netdb.c><netdb.c> 
-OPTFFF 8,132,1,0,0,0,0,0,<..\..\net\lwip\src\api\netifapi.c><netifapi.c> 
-OPTFFF 8,133,1,0,0,0,0,0,<..\..\net\lwip\src\api\tcpip.c><tcpip.c> 
-OPTFFF 8,134,1,0,0,0,0,0,<..\..\net\lwip\src\netif\etharp.c><etharp.c> 
-OPTFFF 8,135,1,150994944,0,0,0,0,<..\..\net\lwip\src\netif\ethernetif.c><ethernetif.c> 
-OPTFFF 8,136,1,0,0,0,0,0,<..\..\net\lwip\src\netif\loopif.c><loopif.c> 
-OPTFFF 8,137,1,285212672,0,0,0,0,<..\..\net\lwip\src\arch\sys_arch_init.c><sys_arch_init.c> 
-OPTFFF 8,138,1,0,0,0,0,0,<..\..\net\lwip\src\arch\sys_arch.c><sys_arch.c> 
-OPTFFF 8,139,1,0,0,0,0,0,<..\..\net\lwip\src\api\sockets.c><sockets.c> 
-OPTFFF 8,140,1,0,0,0,0,0,<..\..\net\lwip\src\core\memp_tiny.c><memp_tiny.c> 
-OPTFFF 9,141,1,402653184,0,0,0,0,<.\mp3\mp3dec.c><mp3dec.c> 
-OPTFFF 9,142,1,0,0,0,0,0,<.\mp3\mp3tabs.c><mp3tabs.c> 
-OPTFFF 9,143,1,0,0,0,0,0,<.\mp3\real\bitstream.c><bitstream.c> 
-OPTFFF 9,144,1,83886080,0,0,0,0,<.\mp3\real\buffers.c><buffers.c> 
-OPTFFF 9,145,1,0,0,0,0,0,<.\mp3\real\dct32.c><dct32.c> 
-OPTFFF 9,146,1,0,0,0,0,0,<.\mp3\real\dequant.c><dequant.c> 
-OPTFFF 9,147,1,0,0,0,0,0,<.\mp3\real\dqchan.c><dqchan.c> 
-OPTFFF 9,148,1,0,0,0,0,0,<.\mp3\real\huffman.c><huffman.c> 
-OPTFFF 9,149,1,0,0,0,0,0,<.\mp3\real\hufftabs.c><hufftabs.c> 
-OPTFFF 9,150,1,0,0,0,0,0,<.\mp3\real\imdct.c><imdct.c> 
-OPTFFF 9,151,1,0,0,0,0,0,<.\mp3\real\scalfact.c><scalfact.c> 
-OPTFFF 9,152,1,0,0,0,0,0,<.\mp3\real\stproc.c><stproc.c> 
-OPTFFF 9,153,1,0,0,0,0,0,<.\mp3\real\subband.c><subband.c> 
-OPTFFF 9,154,1,0,0,0,0,0,<.\mp3\real\trigtabs.c><trigtabs.c> 
-OPTFFF 9,155,2,0,0,0,0,0,<.\mp3\real\arm\asmpoly_thumb2.s><asmpoly_thumb2.s> 
-OPTFFF 9,156,2,0,0,0,0,0,<.\mp3\real\arm\asmmisc.s><asmmisc.s> 
-OPTFFF 10,157,1,0,0,0,0,0,<..\..\rtgui\common\rtgui_object.c><rtgui_object.c> 
-OPTFFF 10,158,1,0,0,0,0,0,<..\..\rtgui\common\rtgui_system.c><rtgui_system.c> 
-OPTFFF 10,159,1,318767104,0,0,0,0,<..\..\rtgui\common\rtgui_theme.c><rtgui_theme.c> 
-OPTFFF 10,160,1,0,0,0,0,0,<..\..\rtgui\common\asc12font.c><asc12font.c> 
-OPTFFF 10,161,1,402653184,0,0,0,0,<..\..\rtgui\common\asc16font.c><asc16font.c> 
-OPTFFF 10,162,1,0,0,0,0,0,<..\..\rtgui\common\color.c><color.c> 
-OPTFFF 10,163,1,603979776,0,0,0,0,<..\..\rtgui\common\dc.c><dc.c> 
-OPTFFF 10,164,1,0,0,0,0,0,<..\..\rtgui\common\dc_buffer.c><dc_buffer.c> 
-OPTFFF 10,165,1,0,0,0,0,0,<..\..\rtgui\common\dc_hw.c><dc_hw.c> 
-OPTFFF 10,166,1,16777216,0,0,0,0,<..\..\rtgui\common\filerw.c><filerw.c> 
-OPTFFF 10,167,1,0,0,0,0,0,<..\..\rtgui\common\font.c><font.c> 
-OPTFFF 10,168,1,0,0,0,0,0,<..\..\rtgui\common\image.c><image.c> 
-OPTFFF 10,169,1,0,0,0,0,0,<..\..\rtgui\common\image_xpm.c><image_xpm.c> 
-OPTFFF 10,170,1,0,0,0,0,0,<..\..\rtgui\common\image_hdc.c><image_hdc.c> 
-OPTFFF 10,171,1,0,0,0,0,0,<..\..\rtgui\common\region.c><region.c> 
-OPTFFF 10,172,1,100663296,0,0,0,0,<..\..\rtgui\server\server.c><server.c> 
-OPTFFF 10,173,1,0,0,0,0,0,<..\..\rtgui\server\driver.c><driver.c> 
-OPTFFF 10,174,1,335544320,0,0,0,0,<..\..\rtgui\server\panel.c><panel.c> 
-OPTFFF 10,175,1,0,0,0,0,0,<..\..\rtgui\widgets\widget.c><widget.c> 
-OPTFFF 10,176,1,16777216,0,0,0,0,<..\..\rtgui\widgets\window.c><window.c> 
-OPTFFF 10,177,1,0,0,0,0,0,<..\..\rtgui\widgets\workbench.c><workbench.c> 
-OPTFFF 10,178,1,0,0,0,0,0,<..\..\rtgui\widgets\view.c><view.c> 
-OPTFFF 10,179,1,0,0,0,0,0,<..\..\rtgui\widgets\box.c><box.c> 
-OPTFFF 10,180,1,0,0,0,0,0,<..\..\rtgui\widgets\button.c><button.c> 
-OPTFFF 10,181,1,0,0,0,0,0,<..\..\rtgui\widgets\container.c><container.c> 
-OPTFFF 10,182,1,0,0,0,0,0,<..\..\rtgui\widgets\iconbox.c><iconbox.c> 
-OPTFFF 10,183,1,0,0,0,0,0,<..\..\rtgui\widgets\label.c><label.c> 
-OPTFFF 10,184,1,0,0,0,0,0,<..\..\rtgui\widgets\textbox.c><textbox.c> 
-OPTFFF 10,185,1,0,0,0,0,0,<..\..\rtgui\widgets\title.c><title.c> 
-OPTFFF 10,186,1,67108864,0,0,0,0,<..\..\rtgui\widgets\toplevel.c><toplevel.c> 
-OPTFFF 10,187,1,0,0,0,0,0,<..\..\rtgui\server\mouse.c><mouse.c> 
-OPTFFF 10,188,1,0,0,0,0,0,<..\..\rtgui\server\topwin.c><topwin.c> 
-OPTFFF 10,189,1,0,0,0,0,0,<..\..\rtgui\common\caret.c><caret.c> 
-OPTFFF 10,190,1,0,0,0,0,0,<..\..\rtgui\common\font_hz_file.c><font_hz_file.c> 
-OPTFFF 10,191,1,0,0,0,0,0,<..\..\rtgui\common\hz16font.c><hz16font.c> 
-OPTFFF 10,192,1,0,0,0,0,0,<..\..\rtgui\common\hz12font.c><hz12font.c> 
+OPTFFF 1,30,1,0,0,0,0,0,<.\ili9325\ili9320.c><ili9320.c> 
+OPTFFF 2,31,1,0,0,0,0,0,<..\..\src\clock.c><clock.c> 
+OPTFFF 2,32,1,0,0,0,0,0,<..\..\src\idle.c><idle.c> 
+OPTFFF 2,33,1,0,0,0,0,0,<..\..\src\ipc.c><ipc.c> 
+OPTFFF 2,34,1,0,0,0,0,0,<..\..\src\mempool.c><mempool.c> 
+OPTFFF 2,35,1,0,0,0,0,0,<..\..\src\mem.c><mem.c> 
+OPTFFF 2,36,1,0,0,0,0,0,<..\..\src\object.c><object.c> 
+OPTFFF 2,37,1,0,0,0,0,0,<..\..\src\scheduler.c><scheduler.c> 
+OPTFFF 2,38,1,0,0,0,0,0,<..\..\src\thread.c><thread.c> 
+OPTFFF 2,39,1,0,0,0,0,0,<..\..\src\timer.c><timer.c> 
+OPTFFF 2,40,1,0,0,0,0,0,<..\..\src\irq.c><irq.c> 
+OPTFFF 2,41,1,0,0,0,0,0,<..\..\src\kservice.c><kservice.c> 
+OPTFFF 2,42,1,0,0,0,0,0,<..\..\src\device.c><device.c> 
+OPTFFF 2,43,1,0,0,0,0,0,<..\..\src\slab.c><slab.c> 
+OPTFFF 3,44,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\stack.c><stack.c> 
+OPTFFF 3,45,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\interrupt.c><interrupt.c> 
+OPTFFF 3,46,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\cpu.c><cpu.c> 
+OPTFFF 3,47,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\serial.c><serial.c> 
+OPTFFF 3,48,2,0,0,0,0,0,<..\..\libcpu\arm\stm32\context_rvds.S><context_rvds.S> 
+OPTFFF 3,49,2,385875968,0,0,0,0,<..\..\libcpu\arm\stm32\start_rvds.s><start_rvds.s> 
+OPTFFF 3,50,1,0,0,0,0,0,<..\..\libcpu\arm\stm32\fault.c><fault.c> 
+OPTFFF 3,51,2,0,0,0,0,0,<..\..\libcpu\arm\stm32\fault_rvds.S><fault_rvds.S> 
+OPTFFF 4,52,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\misc.c><misc.c> 
+OPTFFF 4,53,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_adc.c><stm32f10x_adc.c> 
+OPTFFF 4,54,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_bkp.c><stm32f10x_bkp.c> 
+OPTFFF 4,55,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_can.c><stm32f10x_can.c> 
+OPTFFF 4,56,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_crc.c><stm32f10x_crc.c> 
+OPTFFF 4,57,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_dac.c><stm32f10x_dac.c> 
+OPTFFF 4,58,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_dbgmcu.c><stm32f10x_dbgmcu.c> 
+OPTFFF 4,59,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_dma.c><stm32f10x_dma.c> 
+OPTFFF 4,60,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_exti.c><stm32f10x_exti.c> 
+OPTFFF 4,61,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_flash.c><stm32f10x_flash.c> 
+OPTFFF 4,62,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_fsmc.c><stm32f10x_fsmc.c> 
+OPTFFF 4,63,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_gpio.c><stm32f10x_gpio.c> 
+OPTFFF 4,64,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_i2c.c><stm32f10x_i2c.c> 
+OPTFFF 4,65,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_iwdg.c><stm32f10x_iwdg.c> 
+OPTFFF 4,66,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_pwr.c><stm32f10x_pwr.c> 
+OPTFFF 4,67,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_rcc.c><stm32f10x_rcc.c> 
+OPTFFF 4,68,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_rtc.c><stm32f10x_rtc.c> 
+OPTFFF 4,69,1,16777216,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_sdio.c><stm32f10x_sdio.c> 
+OPTFFF 4,70,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_spi.c><stm32f10x_spi.c> 
+OPTFFF 4,71,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_tim.c><stm32f10x_tim.c> 
+OPTFFF 4,72,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_usart.c><stm32f10x_usart.c> 
+OPTFFF 4,73,1,0,0,0,0,0,<.\Libraries\STM32F10x_StdPeriph_Driver\src\stm32f10x_wwdg.c><stm32f10x_wwdg.c> 
+OPTFFF 5,74,1,0,0,0,0,0,<.\Libraries\CMSIS\Core\CM3\core_cm3.c><core_cm3.c> 
+OPTFFF 5,75,1,0,0,0,0,0,<.\Libraries\CMSIS\Core\CM3\system_stm32f10x.c><system_stm32f10x.c> 
+OPTFFF 6,76,1,0,0,0,0,0,<..\..\finsh\finsh_compiler.c><finsh_compiler.c> 
+OPTFFF 6,77,1,0,0,0,0,0,<..\..\finsh\finsh_error.c><finsh_error.c> 
+OPTFFF 6,78,1,0,0,0,0,0,<..\..\finsh\finsh_heap.c><finsh_heap.c> 
+OPTFFF 6,79,1,0,0,0,0,0,<..\..\finsh\finsh_init.c><finsh_init.c> 
+OPTFFF 6,80,1,0,0,0,0,0,<..\..\finsh\finsh_node.c><finsh_node.c> 
+OPTFFF 6,81,1,0,0,0,0,0,<..\..\finsh\finsh_ops.c><finsh_ops.c> 
+OPTFFF 6,82,1,0,0,0,0,0,<..\..\finsh\finsh_parser.c><finsh_parser.c> 
+OPTFFF 6,83,1,0,0,0,0,0,<..\..\finsh\finsh_token.c><finsh_token.c> 
+OPTFFF 6,84,1,0,0,0,0,0,<..\..\finsh\finsh_var.c><finsh_var.c> 
+OPTFFF 6,85,1,0,0,0,0,0,<..\..\finsh\finsh_vm.c><finsh_vm.c> 
+OPTFFF 6,86,1,0,0,0,0,0,<..\..\finsh\shell.c><shell.c> 
+OPTFFF 6,87,1,0,0,0,0,0,<..\..\finsh\symbol.c><symbol.c> 
+OPTFFF 6,88,1,285212672,0,0,0,0,<..\..\finsh\cmd.c><cmd.c> 
+OPTFFF 7,89,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_init.c><dfs_init.c> 
+OPTFFF 7,90,1,503316480,0,0,0,0,<..\..\filesystem\dfs\src\dfs_fs.c><dfs_fs.c> 
+OPTFFF 7,91,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_raw.c><dfs_raw.c> 
+OPTFFF 7,92,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_util.c><dfs_util.c> 
+OPTFFF 7,93,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_posix.c><dfs_posix.c> 
+OPTFFF 7,94,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\dir.c><dir.c> 
+OPTFFF 7,95,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\fat.c><fat.c> 
+OPTFFF 7,96,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\file.c><file.c> 
+OPTFFF 7,97,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\fs.c><fs.c> 
+OPTFFF 7,98,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\ls.c><ls.c> 
+OPTFFF 7,99,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\time.c><time.c> 
+OPTFFF 7,100,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\fs\vfat\ui.c><ui.c> 
+OPTFFF 7,101,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\plibc.c><plibc.c> 
+OPTFFF 7,102,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\efs.c><efs.c> 
+OPTFFF 7,103,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\extract.c><extract.c> 
+OPTFFF 7,104,1,0,0,0,0,0,<..\..\filesystem\dfs\filesystems\efsl\src\base\partition.c><partition.c> 
+OPTFFF 7,105,1,0,0,0,0,0,<..\..\filesystem\dfs\src\dfs_cache.c><dfs_cache.c> 
+OPTFFF 8,106,1,0,0,0,0,0,<..\..\net\lwip\src\core\dhcp.c><dhcp.c> 
+OPTFFF 8,107,1,0,0,0,0,0,<..\..\net\lwip\src\core\dns.c><dns.c> 
+OPTFFF 8,108,1,0,0,0,0,0,<..\..\net\lwip\src\core\init.c><init.c> 
+OPTFFF 8,109,1,0,0,0,0,0,<..\..\net\lwip\src\core\netif.c><netif.c> 
+OPTFFF 8,110,1,0,0,0,0,0,<..\..\net\lwip\src\core\pbuf.c><pbuf.c> 
+OPTFFF 8,111,1,0,0,0,0,0,<..\..\net\lwip\src\core\raw.c><raw.c> 
+OPTFFF 8,112,1,0,0,0,0,0,<..\..\net\lwip\src\core\stats.c><stats.c> 
+OPTFFF 8,113,1,0,0,0,0,0,<..\..\net\lwip\src\core\sys.c><sys.c> 
+OPTFFF 8,114,1,0,0,0,0,0,<..\..\net\lwip\src\core\tcp.c><tcp.c> 
+OPTFFF 8,115,1,0,0,0,0,0,<..\..\net\lwip\src\core\tcp_in.c><tcp_in.c> 
+OPTFFF 8,116,1,0,0,0,0,0,<..\..\net\lwip\src\core\tcp_out.c><tcp_out.c> 
+OPTFFF 8,117,1,0,0,0,0,0,<..\..\net\lwip\src\core\udp.c><udp.c> 
+OPTFFF 8,118,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\autoip.c><autoip.c> 
+OPTFFF 8,119,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\icmp.c><icmp.c> 
+OPTFFF 8,120,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\igmp.c><igmp.c> 
+OPTFFF 8,121,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\inet.c><inet.c> 
+OPTFFF 8,122,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\inet_chksum.c><inet_chksum.c> 
+OPTFFF 8,123,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\ip.c><ip.c> 
+OPTFFF 8,124,1,0,0,0,0,0,<..\..\net\lwip\src\core\ipv4\ip_addr.c><ip_addr.c> 
+OPTFFF 8,125,1,285212672,0,0,0,0,<..\..\net\lwip\src\core\ipv4\ip_frag.c><ip_frag.c> 
+OPTFFF 8,126,1,0,0,0,0,0,<..\..\net\lwip\src\core\snmp\msg_in.c><msg_in.c> 
+OPTFFF 8,127,1,0,0,0,0,0,<..\..\net\lwip\src\core\snmp\msg_out.c><msg_out.c> 
+OPTFFF 8,128,1,0,0,0,0,0,<..\..\net\lwip\src\api\api_lib.c><api_lib.c> 
+OPTFFF 8,129,1,50331648,0,0,0,0,<..\..\net\lwip\src\api\api_msg.c><api_msg.c> 
+OPTFFF 8,130,1,0,0,0,0,0,<..\..\net\lwip\src\api\err.c><err.c> 
+OPTFFF 8,131,1,0,0,0,0,0,<..\..\net\lwip\src\api\netbuf.c><netbuf.c> 
+OPTFFF 8,132,1,0,0,0,0,0,<..\..\net\lwip\src\api\netdb.c><netdb.c> 
+OPTFFF 8,133,1,0,0,0,0,0,<..\..\net\lwip\src\api\netifapi.c><netifapi.c> 
+OPTFFF 8,134,1,0,0,0,0,0,<..\..\net\lwip\src\api\tcpip.c><tcpip.c> 
+OPTFFF 8,135,1,0,0,0,0,0,<..\..\net\lwip\src\netif\etharp.c><etharp.c> 
+OPTFFF 8,136,1,150994944,0,0,0,0,<..\..\net\lwip\src\netif\ethernetif.c><ethernetif.c> 
+OPTFFF 8,137,1,0,0,0,0,0,<..\..\net\lwip\src\netif\loopif.c><loopif.c> 
+OPTFFF 8,138,1,285212672,0,0,0,0,<..\..\net\lwip\src\arch\sys_arch_init.c><sys_arch_init.c> 
+OPTFFF 8,139,1,0,0,0,0,0,<..\..\net\lwip\src\arch\sys_arch.c><sys_arch.c> 
+OPTFFF 8,140,1,0,0,0,0,0,<..\..\net\lwip\src\api\sockets.c><sockets.c> 
+OPTFFF 8,141,1,0,0,0,0,0,<..\..\net\lwip\src\core\memp_tiny.c><memp_tiny.c> 
+OPTFFF 9,142,1,402653184,0,0,0,0,<.\mp3\mp3dec.c><mp3dec.c> 
+OPTFFF 9,143,1,0,0,0,0,0,<.\mp3\mp3tabs.c><mp3tabs.c> 
+OPTFFF 9,144,1,0,0,0,0,0,<.\mp3\real\bitstream.c><bitstream.c> 
+OPTFFF 9,145,1,83886080,0,0,0,0,<.\mp3\real\buffers.c><buffers.c> 
+OPTFFF 9,146,1,0,0,0,0,0,<.\mp3\real\dct32.c><dct32.c> 
+OPTFFF 9,147,1,0,0,0,0,0,<.\mp3\real\dequant.c><dequant.c> 
+OPTFFF 9,148,1,0,0,0,0,0,<.\mp3\real\dqchan.c><dqchan.c> 
+OPTFFF 9,149,1,0,0,0,0,0,<.\mp3\real\huffman.c><huffman.c> 
+OPTFFF 9,150,1,0,0,0,0,0,<.\mp3\real\hufftabs.c><hufftabs.c> 
+OPTFFF 9,151,1,0,0,0,0,0,<.\mp3\real\imdct.c><imdct.c> 
+OPTFFF 9,152,1,0,0,0,0,0,<.\mp3\real\scalfact.c><scalfact.c> 
+OPTFFF 9,153,1,0,0,0,0,0,<.\mp3\real\stproc.c><stproc.c> 
+OPTFFF 9,154,1,0,0,0,0,0,<.\mp3\real\subband.c><subband.c> 
+OPTFFF 9,155,1,0,0,0,0,0,<.\mp3\real\trigtabs.c><trigtabs.c> 
+OPTFFF 9,156,2,0,0,0,0,0,<.\mp3\real\arm\asmpoly_thumb2.s><asmpoly_thumb2.s> 
+OPTFFF 9,157,2,0,0,0,0,0,<.\mp3\real\arm\asmmisc.s><asmmisc.s> 
+OPTFFF 10,158,1,0,0,0,0,0,<..\..\rtgui\common\rtgui_object.c><rtgui_object.c> 
+OPTFFF 10,159,1,0,0,0,0,0,<..\..\rtgui\common\rtgui_system.c><rtgui_system.c> 
+OPTFFF 10,160,1,318767104,0,0,0,0,<..\..\rtgui\common\rtgui_theme.c><rtgui_theme.c> 
+OPTFFF 10,161,1,0,0,0,0,0,<..\..\rtgui\common\asc12font.c><asc12font.c> 
+OPTFFF 10,162,1,402653184,0,0,0,0,<..\..\rtgui\common\asc16font.c><asc16font.c> 
+OPTFFF 10,163,1,0,0,0,0,0,<..\..\rtgui\common\color.c><color.c> 
+OPTFFF 10,164,1,603979776,0,0,0,0,<..\..\rtgui\common\dc.c><dc.c> 
+OPTFFF 10,165,1,0,0,0,0,0,<..\..\rtgui\common\dc_buffer.c><dc_buffer.c> 
+OPTFFF 10,166,1,0,0,0,0,0,<..\..\rtgui\common\dc_hw.c><dc_hw.c> 
+OPTFFF 10,167,1,16777216,0,0,0,0,<..\..\rtgui\common\filerw.c><filerw.c> 
+OPTFFF 10,168,1,0,0,0,0,0,<..\..\rtgui\common\font.c><font.c> 
+OPTFFF 10,169,1,0,0,0,0,0,<..\..\rtgui\common\image.c><image.c> 
+OPTFFF 10,170,1,0,0,0,0,0,<..\..\rtgui\common\image_xpm.c><image_xpm.c> 
+OPTFFF 10,171,1,0,0,0,0,0,<..\..\rtgui\common\image_hdc.c><image_hdc.c> 
+OPTFFF 10,172,1,0,0,0,0,0,<..\..\rtgui\common\region.c><region.c> 
+OPTFFF 10,173,1,100663296,0,0,0,0,<..\..\rtgui\server\server.c><server.c> 
+OPTFFF 10,174,1,0,0,0,0,0,<..\..\rtgui\server\driver.c><driver.c> 
+OPTFFF 10,175,1,335544320,0,0,0,0,<..\..\rtgui\server\panel.c><panel.c> 
+OPTFFF 10,176,1,0,0,0,0,0,<..\..\rtgui\widgets\widget.c><widget.c> 
+OPTFFF 10,177,1,16777216,0,0,0,0,<..\..\rtgui\widgets\window.c><window.c> 
+OPTFFF 10,178,1,0,0,0,0,0,<..\..\rtgui\widgets\workbench.c><workbench.c> 
+OPTFFF 10,179,1,0,0,0,0,0,<..\..\rtgui\widgets\view.c><view.c> 
+OPTFFF 10,180,1,0,0,0,0,0,<..\..\rtgui\widgets\box.c><box.c> 
+OPTFFF 10,181,1,0,0,0,0,0,<..\..\rtgui\widgets\button.c><button.c> 
+OPTFFF 10,182,1,0,0,0,0,0,<..\..\rtgui\widgets\container.c><container.c> 
+OPTFFF 10,183,1,0,0,0,0,0,<..\..\rtgui\widgets\iconbox.c><iconbox.c> 
+OPTFFF 10,184,1,0,0,0,0,0,<..\..\rtgui\widgets\label.c><label.c> 
+OPTFFF 10,185,1,0,0,0,0,0,<..\..\rtgui\widgets\textbox.c><textbox.c> 
+OPTFFF 10,186,1,0,0,0,0,0,<..\..\rtgui\widgets\title.c><title.c> 
+OPTFFF 10,187,1,67108864,0,0,0,0,<..\..\rtgui\widgets\toplevel.c><toplevel.c> 
+OPTFFF 10,188,1,0,0,0,0,0,<..\..\rtgui\server\mouse.c><mouse.c> 
+OPTFFF 10,189,1,0,0,0,0,0,<..\..\rtgui\server\topwin.c><topwin.c> 
+OPTFFF 10,190,1,0,0,0,0,0,<..\..\rtgui\common\caret.c><caret.c> 
+OPTFFF 10,191,1,0,0,0,0,0,<..\..\rtgui\common\font_hz_file.c><font_hz_file.c> 
+OPTFFF 10,192,1,0,0,0,0,0,<..\..\rtgui\common\hz16font.c><hz16font.c> 
+OPTFFF 10,193,1,0,0,0,0,0,<..\..\rtgui\common\hz12font.c><hz12font.c> 
 
-ExtF <E:\Projects\opensvn\rt-thread\google\bsp\stm32_radio\player_ui.h> 13,29,0,{ 44,0,0,0,0,0,0,0,1,0,0,0,255,255,255,255,255,255,255,255,252,255,255,255,226,255,255,255,66,0,0,0,87,0,0,0,208,2,0,0,203,1,0,0 }
 
 TARGOPT 1, (RT-Thread STM32 Radio)
  ADSCLK=8000000
@@ -229,12 +229,13 @@ TARGOPT 1, (RT-Thread STM32 Radio)
   OPTAX 255
   OPTDL (SARMCM3.DLL)()(DARMSTM.DLL)(-pSTM32F103ZE)(SARMCM3.DLL)()(TARMSTM.DLL)(-pSTM32F103ZE)
   OPTDBG 48118,7,()()()()()()()()()() (Segger\JL2CM3.dll)()()()
+  OPTKEY 0,(DLGDARM)((1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(100=-1,-1,-1,-1,0)(110=-1,-1,-1,-1,0)(111=-1,-1,-1,-1,0)(1011=-1,-1,-1,-1,0)(180=-1,-1,-1,-1,0)(120=-1,-1,-1,-1,0)(121=-1,-1,-1,-1,0)(122=-1,-1,-1,-1,0)(123=-1,-1,-1,-1,0)(124=-1,-1,-1,-1,0)(125=-1,-1,-1,-1,0)(126=-1,-1,-1,-1,0)(140=-1,-1,-1,-1,0)(240=-1,-1,-1,-1,0)(190=-1,-1,-1,-1,0)(200=-1,-1,-1,-1,0)(170=-1,-1,-1,-1,0)(130=-1,-1,-1,-1,0)(131=-1,-1,-1,-1,0)(132=-1,-1,-1,-1,0)(133=-1,-1,-1,-1,0)(160=-1,-1,-1,-1,0)(161=-1,-1,-1,-1,0)(162=-1,-1,-1,-1,0)(210=-1,-1,-1,-1,0)(211=-1,-1,-1,-1,0)(220=-1,-1,-1,-1,0)(221=-1,-1,-1,-1,0)(230=-1,-1,-1,-1,0)(234=-1,-1,-1,-1,0)(231=-1,-1,-1,-1,0)(232=-1,-1,-1,-1,0)(233=-1,-1,-1,-1,0)(150=-1,-1,-1,-1,0)(151=-1,-1,-1,-1,0))
   OPTKEY 0,(DLGTARM)((1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(100=-1,-1,-1,-1,0)(110=-1,-1,-1,-1,0)(111=-1,-1,-1,-1,0)(1011=60,91,584,445,0)(180=-1,-1,-1,-1,0)(120=-1,-1,-1,-1,0)(121=-1,-1,-1,-1,0)(122=-1,-1,-1,-1,0)(123=-1,-1,-1,-1,0)(124=-1,-1,-1,-1,0)(125=-1,-1,-1,-1,0)(126=-1,-1,-1,-1,0)(140=-1,-1,-1,-1,0)(240=-1,-1,-1,-1,0)(190=-1,-1,-1,-1,0)(200=-1,-1,-1,-1,0)(170=-1,-1,-1,-1,0)(130=-1,-1,-1,-1,0)(131=-1,-1,-1,-1,0)(132=-1,-1,-1,-1,0)(133=-1,-1,-1,-1,0)(160=-1,-1,-1,-1,0)(161=-1,-1,-1,-1,0)(162=-1,-1,-1,-1,0)(210=-1,-1,-1,-1,0)(211=-1,-1,-1,-1,0)(220=-1,-1,-1,-1,0)(221=-1,-1,-1,-1,0)(230=-1,-1,-1,-1,0)(231=-1,-1,-1,-1,0)(232=-1,-1,-1,-1,0)(233=-1,-1,-1,-1,0)(150=-1,-1,-1,-1,0)(151=-1,-1,-1,-1,0))
-  OPTKEY 0,(ARMDBGFLAGS)()
+  OPTKEY 0,(ARMDBGFLAGS)(-T0)
   OPTKEY 0,(DLGUARM)((105=150,189,819,540,0)(106=-1,-1,-1,-1,0)(107=-1,-1,-1,-1,0))
-  OPTKEY 0,(JL2CM3)(-U20090110 -O718 -S8 -C0 -JU1 -JI127.0.0.1 -JP0 -N00("ARM CoreSight SW-DP") -D00(00000000) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO27 -FD20000000 -FC800 -FN1 -FF0STM32F10x_512 -FS08000000 -FL080000)
-  OPTBB 0,0,129,1,134329636,0,0,0,0,1,<application.c>()()
-  OPTBB 1,0,3051,1,134335826,0,0,0,0,1,<sdcard.c>()()
+  OPTKEY 0,(JL2CM3)(-U11111117 -O718 -S10 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -N00("ARM CoreSight SW-DP") -D00(1BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8004 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TRE0 -FO27 -FD20000000 -FC800 -FN1 -FF0STM32F10x_512 -FS08000000 -FL080000)
+  OPTBB 0,0,72,1,134329864,0,0,0,0,1,<application.c>()()
+  OPTBB 1,0,151,1,134324618,0,0,0,0,1,<application.c>()()
   OPTWA 0,1,(_mp)
   OPTWA 1,1,(tinfo,0x0A)
   OPTMM 1,8,(text)

+ 1 - 0
bsp/stm32_radio/project.Uv2

@@ -43,6 +43,7 @@ File 1,1,<.\player_ui.c><player_ui.c>
 File 1,1,<.\player_bg.c><player_bg.c>
 File 1,1,<.\wm8978.c><wm8978.c>
 File 1,1,<.\play_list.c><play_list.c>
+File 1,1,<.\ili9325\ili9320.c><ili9320.c>
 File 2,1,<..\..\src\clock.c><clock.c>
 File 2,1,<..\..\src\idle.c><idle.c>
 File 2,1,<..\..\src\ipc.c><ipc.c>