STM32 FSMC LCD 液晶的驱动—ILI9320
时间:12-03
来源:互联网
点击:
原来老早知道 STM32 具有
带4个片选的静态存储器控制器。支持CF卡、SRAM、PSRAM、NOR和NAND存储器
并行LCD接口,兼容8080/6800模式
这个其实就是FSMC
在这之前我一直使用IO口模拟8080时序感觉操作简单速度也很不错,而且ST官方上的FSMC的说明文档看得实在很晕找不到重点一直没试过FSMC。最近有机会尝试驱动驱动一块2.4的ILI9320由于要接线为了省力气直接使用了 FSMC的接法,顺便整理下写点东西出来。
我想使用12864液晶可能是每个会单片机的基本功了通常用个P0口发送8Bit数据在用一些控制线产生时钟信号,12864使用6800通信方式而小的彩色FTF 或CSTN屏流行8080通信方式,8080通信中,WR 产生写时钟 RD 产生读时钟 RS线标记传输的是数据还是命令,数据通常是8Bit 或16Bit的。比如:
void write_dat1(u16 data1)
{
LCD_RS = 1;
LCD_RD = 1;
LCD_CS = 0;
P0 = data1;
P1 = data1>>8;
LCD_WR = 0;
LCD_WR = 1;
LCD_CS = 1;
} 这是一个典型的8051用模拟IO的方式 实现8080通行下写数据函数。数据在WR的上升沿被送入。当然用STM32这样用模拟方式和LCD控制器通信也没什么问题。但是既然有个静态存储器控制器在而且据说还要快很多那又何乐不为呢。
FSMC会硬件的完成所有8080的通信时序将数据发送收取,配置好FSMC后对液晶的读写就变成了对某块内存的读写方便之极。比如使用FSMC后
//写16位数据函数
#defineBank1_LCD_D ((uint32_t)0x60020000) //disp Data ADDR
void LCD_WR_Data(unsigned intval)
{
*(__IO uint16_t *) (Bank1_LCD_D)= val;
}
这样实现了和51当中一样的目的,将数据写到0x60020000这块内存上这个数据就会被STM32 同过FSMC硬件的发送到液晶控制器,不用自己干预。可以理解为液晶控制器的数据入口被映射了0x60020000这块内存上。命令会到((uint32_t)0x60000000)。
用起来好用那如何配置呢?原先我就是觉得这麻烦放弃了..................
好了 在这用一个搞定FSMC的作为8080通信的全部配置。
/*-- FSMC Configuration ------------------------------------------------------*/
voidFSMC_LCD_Init(void)
{
FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;
FSMC_NORSRAMTimingInitTypeDef p;
/* FSMC_Bank1_NORSRAM1 timing configuration */
p.FSMC_AddressSetupTime = 0x01;/*地址建立时间期限*/
p.FSMC_AddressHoldTime = 0x00;/*地址的持续时间*/
p.FSMC_DataSetupTime = 0x05;/*设定数据时间期限*/
p.FSMC_BusTurnAroundDuration = 0x00;/*总线转向时间*/
p.FSMC_CLKDivision = 0x00;/*CLK时钟输出信号的HCLK周期数表示时间???*/
p.FSMC_DataLatency = 0x00;/*指定在获得第一个数据前的时钟周期*/
p.FSMC_AccessMode = FSMC_AccessMode_B;
FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1;/*指定的FSMC块*/
FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;/*地址和数据值不复用的数据总线*/
FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_NOR;/*外部存储器的类型*/
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;/*Enables or disables the Wrapped burst access mode for Flash*/
FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;/*启用指定的FSMC块的写操作*/
FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;/*扩展模式*/
FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;/*禁用写突发操作*/
FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p;
FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;
FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);
/* Enable FSMC Bank1_SRAM Bank */
FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE);
}
为啥要这样写??写成别的样子行不行???
FSMC有好几个块 每个块映射的内存也不一样当然不是只能写成这样。要想详细理解每个功能参数的意义要自己翻数据手册了,在这写不下,只要理解前边的timing configuration试讲时限的 后边的是管时序的。改改timing configuration中的参数能让时序完成的更快通信速度更快。
FSMC配置还后 液晶屏怎么连到单片机上?
/* GPIO Configuration */
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
/* Enable the FSMC AND GPIO Clock */
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC |
RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE , ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13; //
带4个片选的静态存储器控制器。支持CF卡、SRAM、PSRAM、NOR和NAND存储器
并行LCD接口,兼容8080/6800模式
这个其实就是FSMC
在这之前我一直使用IO口模拟8080时序感觉操作简单速度也很不错,而且ST官方上的FSMC的说明文档看得实在很晕找不到重点一直没试过FSMC。最近有机会尝试驱动驱动一块2.4的ILI9320由于要接线为了省力气直接使用了 FSMC的接法,顺便整理下写点东西出来。
我想使用12864液晶可能是每个会单片机的基本功了通常用个P0口发送8Bit数据在用一些控制线产生时钟信号,12864使用6800通信方式而小的彩色FTF 或CSTN屏流行8080通信方式,8080通信中,WR 产生写时钟 RD 产生读时钟 RS线标记传输的是数据还是命令,数据通常是8Bit 或16Bit的。比如:
void write_dat1(u16 data1)
{
LCD_RS = 1;
LCD_RD = 1;
LCD_CS = 0;
P0 = data1;
P1 = data1>>8;
LCD_WR = 0;
LCD_WR = 1;
LCD_CS = 1;
} 这是一个典型的8051用模拟IO的方式 实现8080通行下写数据函数。数据在WR的上升沿被送入。当然用STM32这样用模拟方式和LCD控制器通信也没什么问题。但是既然有个静态存储器控制器在而且据说还要快很多那又何乐不为呢。
FSMC会硬件的完成所有8080的通信时序将数据发送收取,配置好FSMC后对液晶的读写就变成了对某块内存的读写方便之极。比如使用FSMC后
//写16位数据函数
#defineBank1_LCD_D ((uint32_t)0x60020000) //disp Data ADDR
void LCD_WR_Data(unsigned intval)
{
*(__IO uint16_t *) (Bank1_LCD_D)= val;
}
这样实现了和51当中一样的目的,将数据写到0x60020000这块内存上这个数据就会被STM32 同过FSMC硬件的发送到液晶控制器,不用自己干预。可以理解为液晶控制器的数据入口被映射了0x60020000这块内存上。命令会到((uint32_t)0x60000000)。
用起来好用那如何配置呢?原先我就是觉得这麻烦放弃了..................
好了 在这用一个搞定FSMC的作为8080通信的全部配置。
/*-- FSMC Configuration ------------------------------------------------------*/
voidFSMC_LCD_Init(void)
{
FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;
FSMC_NORSRAMTimingInitTypeDef p;
/* FSMC_Bank1_NORSRAM1 timing configuration */
p.FSMC_AddressSetupTime = 0x01;/*地址建立时间期限*/
p.FSMC_AddressHoldTime = 0x00;/*地址的持续时间*/
p.FSMC_DataSetupTime = 0x05;/*设定数据时间期限*/
p.FSMC_BusTurnAroundDuration = 0x00;/*总线转向时间*/
p.FSMC_CLKDivision = 0x00;/*CLK时钟输出信号的HCLK周期数表示时间???*/
p.FSMC_DataLatency = 0x00;/*指定在获得第一个数据前的时钟周期*/
p.FSMC_AccessMode = FSMC_AccessMode_B;
FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1;/*指定的FSMC块*/
FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;/*地址和数据值不复用的数据总线*/
FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_NOR;/*外部存储器的类型*/
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;/*Enables or disables the Wrapped burst access mode for Flash*/
FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;/*启用指定的FSMC块的写操作*/
FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;/*扩展模式*/
FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;/*禁用写突发操作*/
FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p;
FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;
FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);
/* Enable FSMC Bank1_SRAM Bank */
FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE);
}
为啥要这样写??写成别的样子行不行???
FSMC有好几个块 每个块映射的内存也不一样当然不是只能写成这样。要想详细理解每个功能参数的意义要自己翻数据手册了,在这写不下,只要理解前边的timing configuration试讲时限的 后边的是管时序的。改改timing configuration中的参数能让时序完成的更快通信速度更快。
FSMC配置还后 液晶屏怎么连到单片机上?
/* GPIO Configuration */
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
/* Enable the FSMC AND GPIO Clock */
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC |
RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE , ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13; //
STM32FSMCLCD液晶ILI932 相关文章:
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)
- Windows CE 进程、线程和内存管理(二)(11-09)
鐏忓嫰顣舵稉鎾茬瑹閸╃顔勯弫娆戔柤閹恒劏宕�
- 妤傛ḿ楠囩亸鍕暥瀹搞儳鈻肩敮鍫濆悋閹存劕鐓跨拋顓熸殌缁嬪顨滅憗锟�
閸忋劍鏌熸担宥咁劅娑旂姴鐨犳0鎴滅瑩娑撴氨鐓$拠鍡礉閹绘劕宕岄惍鏂垮絺瀹搞儰缍旈懗钘夊閿涘苯濮幃銊ユ彥闁喐鍨氶梹澶歌礋娴兼ḿ顫呴惃鍕殸妫版垵浼愮粙瀣瑎...
- 娑擃厾楠囩亸鍕暥瀹搞儳鈻肩敮鍫濆悋閹存劕鐓跨拋顓熸殌缁嬪顨滅憗锟�
缁箖鈧拷30婢舵岸妫亸鍕暥閸╃顔勭拠鍓р柤閿涘奔绗撶€硅埖宸跨拠鎾呯礉閸斺晛顒熼崨妯烘彥闁喕鎻崚棰佺娑擃亜鎮庨弽鐓庣殸妫版垵浼愮粙瀣瑎閻ㄥ嫯顩﹀Ч锟�...
- Agilent ADS 閺佹瑥顒熼崺纭咁唲鐠囧墽鈻兼總妤勵棅
娑撴挸顔嶉幒鍫n嚦閿涘苯鍙忛棃銏n唹鐟欘枃DS閸氬嫮顫掗崝鐔诲厴閸滃苯浼愮粙瀣安閻㈩煉绱遍崝鈺傚亶閻€劍娓堕惌顓犳畱閺冨爼妫跨€涳缚绱癆DS...
- HFSS鐎涳缚绡勯崺纭咁唲鐠囧墽鈻兼總妤勵棅
鐠у嫭绻佹稉鎾愁啀閹哄牐顕抽敍灞藉弿闂堛垼顔夐幒鍦欶SS閻ㄥ嫬濮涢懗钘夋嫲鎼存梻鏁ら敍灞藉簻閸斺晜鍋嶉崗銊╂桨缁崵绮洪崷鏉款劅娑旂姵甯夐幓顡嶧SS...
- CST瀵邦喗灏濆銉ょ稊鐎广倕鐓跨拋顓熸殌缁嬪顨滅憗锟�
閺夊孩妲戝ú瀣╁瘜鐠佽绱濋崗銊╂桨鐠佸弶宸緾ST閸氬嫰銆嶉崝鐔诲厴閸滃苯浼愮粙瀣安閻㈩煉绱濋崝鈺傚亶韫囶偊鈧喕鍤滅€涳附甯夐幓顡塖T鐠佹崘顓告惔鏃傛暏...
- 鐏忓嫰顣堕崺铏诡攨閸╃顔勭拠鍓р柤
娑撳洣绗€妤傛ɑ銈奸獮鍐叉勾鐠у嚖绱濇潻娆庣昂鐠囧墽鈻兼稉杞扮稑閸︺劌鐨犳0鎴炲Η閺堫垶顣崺鐔枫亣鐏炴洘瀚甸懘姘剧礉閹垫挷绗呴崸姘杽閻ㄥ嫪绗撴稉姘唨绾偓...
- 瀵邦喗灏濈亸鍕暥濞村鍣洪幙宥勭稊閸╃顔勭拠鍓р柤閸氬牓娉�
鐠愵厺鎷遍崥鍫ユ肠閺囨潙鐤勯幆鐙呯礉缂冩垵鍨庨妴渚€顣剁拫鍙樺崕閵嗕胶銇氬▔銏犳珤閵嗕椒淇婇崣閿嬬爱閿涘本鍨滅憰浣圭壉閺嶉绨块柅锟�...
栏目分类