STM32—FSMC学习思考

     FSMC(灵活的静态存储器控制器)个人理解:主要作为外部存储器的控制器(LCD显示屏)。

     对于LCD显示屏有:RS = 0时,表示读写寄存器;RS = 1表示读写数据RAM。RS可以用FSMC_A中的一根地址线作为控制线。如何进行LCD的控制呢?

     看过STM32中文参考手册会知道:当存储数据可以设为8位或16位.

    当设置为16位时FSMC_A[24:0]对应HADDR[25:1] ,选择NOR/PSRAM的第一个存储区,并且使用FSMC_AN来控制LCD的RS引脚,我们发现,当外部存储器是16位时,硬件管脚FSMC_A0-FSMC_A24表示的是地址线HADDR1-HADDR25的值,所以我们要位移一下,HADDRN的值,实际会被反应到FSMC_AN-1这根IO来。则我们访问LCD显示RAM的基址为0x6002 0000,访问LCD寄存器的地址为:0x6000 0000。因为数据长度为16bit ,所以FSMC_A[24:0]对应HADDR[25:1]  所以显示RAM的基址=0x60000000+2^N*2=0x60000000+0x2 0000=0x60020000.

    设置为8位时FSMC_A[25:0]对应HADDR[25:0] ,关于RS值的位置与地址的换算则不需要位移。

你可能感兴趣的:(stm32学习笔记)