基于STM32f103zet6之使用FSMC驱动TFT

发布者:逍遥游侠最新更新时间:2021-03-04 来源: eefocus关键字:STM32f103zet6  FSMC  驱动TFT 手机看文章 扫描二维码
随时随地手机看文章

在完成IO驱动彩屏的试验后,就准备着手使用FSMC来驱动彩屏,先了解一下预备知识


一、所谓的FSMC机制


简单介绍FSMC在这篇博文里面很清楚,推荐一下http://blog.csdn.net/king_bingge/article/details/8718566


然后还有就是这篇学习笔记,也还行http://www.cnblogs.com/hduxyc/archive/2011/05/17/2048099.html


个人觉得有了这两篇博文再加上我们的参考手册足够搞定FSMC驱动彩屏了


二、FSMC之我见


开始只是谈到别人对FSMC的理解,注意这里只讨论FSMC控制TFT,也就是在FSMC的NORPSRAM模式控制LCD,所以我们以下的分析都是基于这种模式的。


1、我们之前通过使用GPIO来模拟8080/6800时序从而达到驱动彩屏的,同样需要明白的一点就是我们也只是使用FSMC来模拟8080/6800时序,只不过这个读写速度有些快(使用了总线嘛),仅此而已!如果不明白8080/6800时序是怎样的或许在这个文库里面能找到你想要的http://wenku.baidu.com/view/a8c98600cc1755270722083e.html


简单一点就是:8080是通过“读使能(RE)”和“写使能(WE)”两条控制线进行读写操作。 6800是通过“总使能(E)”和“读写选择(W/R)”两条控制线进行


2、那么了解到FSMC的三总线如下!


数据线:这个可以分为8位的和16位,这个不难理解,就是之指一次穿上红8位还是16位数据,我的是16位的,8位的有一个懒得用。


地址线:既然我们访问的外NOR FLASH,那么一定会有相应的地址线,那么这些地址线在哪里呢?肯定是通过GPIO引脚复用的。有A0 -- A23 24根,能够控制访问16M的空间,也就是一个子bank;


控制总线:它的控制总线只有三根:读使能信号,写使能信号,片选信号。所以这里和我们8080时序相比,少了复位信号线和数据/命令控制线,怎么办?继续看!


3、了解了FSMC会有这三总线的概念,那么接下来就是如何转化为我们需要的时序了。


对比一下FSMC访问外nor flash和8080访问时序如下




差别似乎很小是吧,简单说就是在数据/指令选择和复位信号上的区别。


4、在这里我们使用的软件方法来完善FSMC转化为8080的读写时序


在参考手册上的存储系统能找到,芯片留给我们外扩的存储器(NOR FLASH、PSRAM这类可直接寻址的器

件)地址是从0x60000000开始的,意思就是当我们访问0x60000000的时候,那就是相当于访问外部nor flash了(我们只讨论这种情况),那么他就会自动产生FSMC的时序


在这里,我们所需要添加的就是D/C选择信号,如何实现呢?我们是通过,一根地址线来实现的,当我们把A0多对应的GPIOF0(引脚默认复用)接到TFT的RS端,


然后执行访问0x60000000的指令,那么RS是否就是低电平选择为数据呢?又加入我们访问的地址是0x60000001的时候,那么RS是否就是高电平,从而选择的就是指令传送呢?答案当然是肯定的!所以我们就解决了这个问题,复位信号就更好解决了,直接和开发板的复位引脚接在一起就好了,就这么简单!


三、说了这么久的理论,来个实例分析更加形象了,首先硬件连线要明白


在原理图或者开发手册上面能够确定引脚复用问题


地址引脚:


(A0-A5 :PF0 - PF5) (A6-A9: F12-F15 ) (A10-A15:PG0-PG5)


(A16-A18:PD11-PD13) (A19-A22:PE3-PE6) (A23-PE2)


片选信号(NEx:PG12)因为我选择的是block4


写使能(NWR:PD5)


读使能(NOE:PD4)


至此控制引脚基本完成


下面就是数据引脚:


PD14-FSMC-D0 ----LCD-DB0

PD15-FSMC-D1 ----LCD-DB1

PD0-FSMC-D2 ----LCD-DB2

PD1-FSMC-D3 ----LCD-DB3

PE7-FSMC-D4 ----LCD-DB4

PE8-FSMC-D5 ----LCD-DB5

PE9-FSMC-D6 ----LCD-DB6

PE10-FSMC-D7 ----LCD-DB7

PE11-FSMC-D8 ----LCD-DB8

PE12-FSMC-D9 ----LCD-DB9

PE13-FSMC-D10 ----LCD-DB10

PE14-FSMC-D11 ----LCD-DB11

PE15-FSMC-D12 ----LCD-DB12

PD8-FSMC-D13 ----LCD-DB13

PD9-FSMC-D14 ----LCD-DB14

PD10-FSMC-D15 ----LCD-DB15


有了这些硬件连线是没有任何问题的


四、正式分析程序


1、硬件引脚配置函数




voidLCD_CtrlLinesConfig(void)


{


GPIO_InitTypeDefGPIO_InitStructure;


/*EnableFSMC,GPIOD,GPIOE,GPIOF,GPIOGandAFIOclocks*/


RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC,ENABLE);//使能FSMC




RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_GPIOE|


RCC_APB2Periph_GPIOF|RCC_APB2Periph_GPIOG|


RCC_APB2Periph_AFIO,ENABLE);


//IO口复用功能时钟


/*SetPD.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)asalternate


functionpushpull*/




/*D端口初始化*/


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);




/*E端口初始化*/


/*SetPE.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)asalternatefunctionpushpull*/




GPIO_InitStructure.GPIO_Pin=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_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;


GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP;


GPIO_Init(GPIOE,&GPIO_InitStructure);//将配置写入GPIOE管脚




/*A0地址线*/


GPIO_InitStructure.GPIO_Pin=GPIO_Pin_0;


GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;


GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP;


GPIO_Init(GPIOF,&GPIO_InitStructure);




/*SetPG.12(NE4(LCD/CS))asalternatefunctionpushpull-CE3(LCD/CS)*/


GPIO_InitStructure.GPIO_Pin=GPIO_Pin_12;


GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;


GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP;


GPIO_Init(GPIOG,&GPIO_InitStructure);


关键字:STM32f103zet6  FSMC  驱动TFT 引用地址:基于STM32f103zet6之使用FSMC驱动TFT

上一篇:基于STM32的FSMC接口驱动TFT彩屏
下一篇:旋转LED屏显示控制器设计方案

推荐阅读最新更新时间:2024-11-11 14:27

stm32f103zet6引脚图及引脚定义
  stm32f103zet6是一种嵌入式-微控制器的集成电路(IC),是由ST公司开发的STM32F1系列的其中一种,芯体尺寸是32位,速度是72MHz,程序存储器容量是256KB,程序存储器类型是FLASH,RAM容量是48K。   stm32f103zet6详细参数如下:      stm32f103zet6引脚图如下:   stm32f103zet6引脚定义如下:   1. I = 输入,O = 输出,S = 电源, HiZ = 高阻   2. FT:容忍5V   3. 有些功能仅在部分型号芯片中支持。   4. PC13,PC14和PC15引脚通过电源开关进行供电,而这个电源开关只能够吸
[单片机]
<font color='red'>stm32f103zet6</font>引脚图及引脚定义
stm32f103zet6如何识别flash大小
  在我们应用开发时,经常会有一些程序运行参数需要保存,如一些修正系数。这些数据的特点是:数量少而且不需要经常修改,但又不能定义为常量,因为每台设备可能不一样而且在以后还有修改的可能。将这类数据存在指定的位置,需要修改时直接修改存储位置的数值,需要使用时则直接读取,会是一种方便的做法。考虑到这些数据量比较少,使用专门的存储单元既不经济,也没有必要,而STM32F103内部的Flash容量较大,而且ST的库函数中还提供了基本的Flash操作函数,实现起来也比较方便。   以大容量产品STM32F103ZET为例,其Flash容量达到512K,可以将其中一部分用作数据存储。如下是大容量的Flash组织模式:     STM32的
[单片机]
<font color='red'>stm32f103zet6</font>如何识别flash大小
STM32直接驱动RGB接口的TFT数字彩屏
引言 随着工业技术的不断发展,人机界面的开发及应用空前火热,为了具有比较友好的人机界面,TFT数字彩屏被广泛的应用,但是TFT彩屏通常都不带有控制器,所以现在驱动彩屏的方案大致有2种: ①采用ARM9或者更高级别的平台,芯片上带有TFT控制器,可以直接挂接TFT数字屏。 ②采用低端CPU处理器平台,外加TFT控制器模块,再挂接TFT数字屏。 对于方案①来说,系统的复杂度会莫名地增加,再加上该类的平台中主MCU多为BGA封装,对于需求很多小量多样化产品的客户来说,较难以接受这样的方案;而 ②方案平白无故添加了一个LCD控制器。这两种方案无论哪一种都增加了硬件成本,本文提出了一种由STM32的FSMC总线直接挂载RGB接口屏的方案,直
[单片机]
STM32直接<font color='red'>驱动</font>RGB接口的<font color='red'>TFT</font>数字彩屏
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved