原创 FSMC初接触--分析MANLEY399学习板使用FSMC驱动LCM的方法

2008-10-20 21:04 3898 14 16 分类: MCU/ 嵌入式

FSMC应用要点(仅针对本标题)
  * RCC使能
    RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);
    FSMC的时钟直接来自AHB时钟, 也就是HCLK, 中间没有分频. 控制位是RCC_AHBENR中
    的FSMCEN位

    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE |
                           RCC_APB2Periph_GPIOF | RCC_APB2Periph_GPIOG |
                           RCC_APB2Periph_AFIO, ENABLE);
    GPIO端口和AFIO端口时钟来自APB2, 也就是PCLK2, 控制位是RCC_APB2ERN中的IOPxEN 和AFIOEN位

  * 端口设置
      /* Set
       PD.14(D0), PD.15(D1), PD.00(D2), PD.01(D3) -- LCM_D0..3,
         PD.04(NOE) -- LCM_RD,
         PD.05(NWE) -- LCM_WR
       as alternate function push pull */
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 |
                                  GPIO_Pin_1 |
                                  GPIO_Pin_4 |
                                  GPIO_Pin_5 |
                                  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) -- LCM_D4..7
       as alternate function push pull */
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 |
                                  GPIO_Pin_8 |
                                  GPIO_Pin_9 |
                                  GPIO_Pin_10;
    GPIO_Init(GPIOE, &GPIO_InitStructure);

      /* Set
       PF.00(A0) -- LCM_C/D
       as alternate function push pull */
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
    GPIO_Init(GPIOF, &GPIO_InitStructure);

      /* Set
       PG.12(NE4) -- LCD_CS
       as alternate function push pull*/
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;
    GPIO_Init(GPIOG, &GPIO_InitStructure);

    对于用于FSMC输出的信号线要设定为复用推挽输出模式(Alternate function push-    pull).
    对于用于FSMC输入的信号线要怎样设置目前还不清楚, 以后再说吧

    *FSMC自身设置


      FSMC自身设置有两块, 一块是控制方式设置, 是针对FSMC_DCR的设置, 另一块是读写时序设定, 是针对FSMC_DTR的设置.
    
    NORFLASH和PSRAM的操作时序设置
    


   FSMC_NORSRAMTimingInitTypeDef  p;

    p.FSMC_AddressSetupTime = 1;            /*ADDSET  地址建立时间*/
    p.FSMC_AddressHoldTime = 1;             /*ADDHOLD 地址保持时间*/
    p.FSMC_DataSetupTime = 20;               /*DATAST 数据建立时间*/
    p.FSMC_BusTurnAroundDuration = 0;   /*BUSTURN 总线返转时间*/
    p.FSMC_CLKDivision = 0;                    /*CLKDIV 时钟分频*/
    p.FSMC_DataLatency = 1;                     /*DATLAT 数据保持时间*/
    p.FSMC_AccessMode = FSMC_AccessMode_A; /*ACCMOD FSMC 访问模式*/
   


    下面这段是对控制方式的设置



    FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure;


    /*选择设置的BANK及片选信号*/
    FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM4;   


   


    /*设置是否数据地址总线分时复用*/


    FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable; 


    /*设置存储器类型*/
    FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM;


    /*设置数据宽度*/
    FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b;


    /*设置是否使用迸发访问模式(应该就是连续读写模式吧),*/
    FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;


    /*设置WAIT信号的有效电平*/


    FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;


    /*设置是否使用环回模式*/


    FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;


    /*设置WAIT信号有效时机*/
    FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;


    /*设定是否使能写操作*/
    FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;


    /*设定是否使用WAIT信号*/
    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); 

    FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM4, ENABLE);


    这些东西设定好后, 就可以像操作外设一样操作LCM接口了.


    通过参考手册知道, 在FSMC中, 将NOR/PSRAM第四片选信号的地址空间映射在0X6C000000开始 的16MB空间内, 由于C/D为高时操作LCM的数据寄存器, 为低时操作LCM的控制寄存器, 所以有下面的定义:


/*A0=0  -- cmd*/
#define LCD_Command  *((volatile unsigned char * )0x6c000000)
/*A0=1 -- data*/
#define LCD_Data  *((volatile unsigned char * )0x6c000001)


接下来就是对LCM的具体操作了, 就不在这里啰嗦了.




PARTNER CONTENT

文章评论2条评论)

登录后参与讨论

用户499006 2009-1-13 14:43

抱歉.我说错了.原来楼主用的是万利399的板子.144PIN的.不过100PIN要费点心思了. 我恰好也要用的FSMC挂3个器件LCD,并行DA以及NANDFLASH.用100脚的.片选部分,不够用因此NE1和A18,A19通过138分出3路.

用户499006 2009-1-13 12:01

楼主最后的地址线分配上好像有问题吧. 似乎命令/数据线左移BIT7之后任意1位吧. 最好的是A15之后.相对100PIN的MCU 或者我对您用的LCD不熟悉,说错了请批评!
相关推荐阅读
用户18170 2009-01-17 11:47
面向工控的学习板主控制部分已经完成
前段时间说的学习板已经于08年12月中旬将板画完了,一直忙,没时间整理,今天将其整理一下,发上来,由于众所周知的原因,目前资金奇紧,做板只能是无限期延后了。板上只集成了中心控制部分,外部隔离驱动都放在...
用户18170 2009-01-03 16:25
MOS管驱动产生的奇怪现象
在一个系统中通过一PMOS管(PA002)控制传感器电源,PMOS管的G极直接由单片机(ATMEGA169)的IO口控制,调试时发现一奇怪现象,在打开传感器电源时,单片机会出现复位,真是莫名其妙,反复...
用户18170 2008-11-13 15:12
一个完整的简单的工控板项目(基于AVR)
这段时间都在做一个新的项目,所以学习板就放了一段时间,新项目接近尾声,将项目的板照传上来给大家排砖,我会将原理图整理出来了,也传上来供大家参考指正,我想技术是要通过交流而不断进步的,所以我也真诚希望有...
用户18170 2008-10-24 11:54
基于MDK322和万利199开发版的USART实战训练项目
啥也不说了,有兴趣的自己看吧https://static.assets-stash.eet-china.com/album/old-resources/2008/10/24/6175dc52-3b3d...
用户18170 2008-10-18 12:28
触摸屏菜单实现及其它
在21IC中看到有人在探讨关于触摸屏上菜单实现的问题,附件是我在一个项目中的部分代码,里面有我自己设计的实现规则菜单的算法,所谓规则菜单就是批菜单的条目呈均匀的行列摆放,且每个条目在高度和宽度一样,这...
我要评论
2
14
关闭 站长推荐上一条 /3 下一条