OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4250|回复: 11

FSMC驱动8位显示屏 时序问题

[复制链接]

1

主题

5

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2016-5-20
在线时间
3 小时
发表于 2016-5-20 19:17:28 | 显示全部楼层 |阅读模式
5金钱
刚学FSMC,直接上手的F4,碰到点问题,希望大家看看。为什么只操作4次,却有8次读写呢??
stm32主频以降低到8M,逻辑分析仪是肯定能采到的
程序:
//#define LCD_RAM   *(vu16*)((u32)0x60020000)  //disp Data ADDR
#define LCD_RAM   *(vu16*)((u32)0x60010000)  //disp Data ADDR
#define LCD_REG   *(vu16*)((u32)0x60000000)         //disp Reg  ADDR


while(1)
        {
                        LCD_RAM = 0X01;
                        LCD_RAM = 0X02;
                        LCD_RAM = 0X04;
                        LCD_RAM = 0X08;
                        delay_us(1);
               
                        LCD_REG = 0X01;
                        LCD_REG = 0X02;
                        LCD_REG = 0X04;
                        LCD_REG = 0X08;
                        delay_us(1);
        }

配置:
void LCD_LineConf(void)
{
          GPIO_InitTypeDef GPIO_InitStructure;

          RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD | RCC_AHB1Periph_GPIOE , ENABLE);
          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_Mode = GPIO_Mode_AF;
          GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
          GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
          GPIO_InitStructure.GPIO_PuPd  = GPIO_PuPd_NOPULL;
          GPIO_Init(GPIOD, &GPIO_InitStructure);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource0, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource1, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource4, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource5, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource8, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource9, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource10, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource14, GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource15, GPIO_AF_FSMC);
          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_Init(GPIOE, &GPIO_InitStructure);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource7 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource8 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource9 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource10 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource11 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource12 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource13 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource14 , GPIO_AF_FSMC);
          GPIO_PinAFConfig(GPIOE, GPIO_PinSource15 , GPIO_AF_FSMC);
          GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;//(RS)
          GPIO_Init(GPIOD, &GPIO_InitStructure);  
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource11, GPIO_AF_FSMC);          
          GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;//(CS)
          GPIO_Init(GPIOD, &GPIO_InitStructure);
          GPIO_PinAFConfig(GPIOD, GPIO_PinSource7, GPIO_AF_FSMC);
}

void LCD_FSMCConf(void)
{
          FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure;
          FSMC_NORSRAMTimingInitTypeDef  p;

          RCC_AHB3PeriphClockCmd(RCC_AHB3Periph_FSMC, ENABLE);
          p.FSMC_AddressSetupTime = 4;
          p.FSMC_AddressHoldTime = 2;
          p.FSMC_DataSetupTime = 4;
          p.FSMC_BusTurnAroundDuration = 1;
          p.FSMC_CLKDivision = 1;
          p.FSMC_DataLatency = 2;
          p.FSMC_AccessMode = FSMC_AccessMode_A;
  FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1;
  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;
  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_WriteBurst = FSMC_WriteBurst_Disable;
          FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p;
          FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;
          FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);   
          FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE);
}





QQ截图20160520191306.png

最佳答案

查看完整内容[请看2#楼]

把这个: *(vu16*)((u32)0x60020000) 改成: *(vu8*)((u32)0x60020000) 试试,看看是不是这个问题导致的。 因为你要写u16数据进去,8位总线的时候,会分两次发送
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165508
金钱
165508
注册时间
2010-12-1
在线时间
2115 小时
发表于 2016-5-20 19:17:29 | 显示全部楼层
把这个:  *(vu16*)((u32)0x60020000)
改成:  *(vu8*)((u32)0x60020000)
试试,看看是不是这个问题导致的。
因为你要写u16数据进去,8位总线的时候,会分两次发送
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2016-5-20
在线时间
3 小时
 楼主| 发表于 2016-5-20 19:35:57 | 显示全部楼层
http://pan.baidu.com/s/1o8IkLDK  这是我的整个工程,帮我看看,不甚感激
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165508
金钱
165508
注册时间
2010-12-1
在线时间
2115 小时
发表于 2016-5-20 20:33:52 | 显示全部楼层
操作1次试试
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2016-5-20
在线时间
3 小时
 楼主| 发表于 2016-5-20 20:43:24 | 显示全部楼层

是2次

LCD_RAM = 0X01;               
delay_us(1);
LCD_REG = 0X01;                       
delay_us(1);

操作一次的时序

操作一次的时序
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165508
金钱
165508
注册时间
2010-12-1
在线时间
2115 小时
发表于 2016-5-20 21:21:29 | 显示全部楼层
while(1)
        {
                        LCD_RAM = 0X01;
                          delay_ms(10);

        }
试试这个代码
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2016-5-20
在线时间
3 小时
 楼主| 发表于 2016-5-20 21:44:21 | 显示全部楼层
本帖最后由 m986883511 于 2016-5-20 21:54 编辑
正点原子 发表于 2016-5-20 21:21
while(1)
        {
                        LCD_RAM = 0X01;

还是这样的,出现WR写两次

真的是好奇怪,如果我改成  FSMC_MemoryDataWidth_16b  ,操作我这个8位屏,高八位不用,地址写成0x60020000 ,其他的什么都没改,就成功驱动了TFT,然后看他的时序是只有一次的。
但我这个是八位屏,用16位就浪费了8个IO口了。

真的是搞不明白为什么写两次呢


QQ截图20160520214321.png
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165508
金钱
165508
注册时间
2010-12-1
在线时间
2115 小时
发表于 2016-5-21 20:12:20 | 显示全部楼层
m986883511 发表于 2016-5-20 21:44
还是这样的,出现WR写两次

真的是好奇怪,如果我改成  FSMC_MemoryDataWidth_16b  ,操作我这个8位屏 ...

我也觉得奇怪了,呵呵。
我同事也是调8位屏,发现用16位模式驱动好使,改成8位不行。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手入门

积分
14
金钱
14
注册时间
2016-5-20
在线时间
3 小时
 楼主| 发表于 2016-5-23 18:59:16 | 显示全部楼层
正点原子 发表于 2016-5-21 20:13
把这个:  *(vu16*)((u32)0x60020000)
改成:  *(vu8*)((u32)0x60020000)
试试,看看是不是这个问题导致 ...

员资格,太厉害了, 真的是这样,成功了。
本着论坛开源的宗旨,上传自己的工程。

LCD 8位FSMC.zip

5.3 MB, 下载次数: 199

keil工程

回复

使用道具 举报

3

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2015-12-26
在线时间
28 小时
发表于 2016-6-4 18:32:33 | 显示全部楼层
哈哈  这个问题我两年前也遇到过     不过我是用fsmc驱动ch375    直接把fsmc驱动16位液晶的直接复制过来    修改的时候没有注意导致浪费了两个小时才找到问题
回复

使用道具 举报

51

主题

214

帖子

0

精华

高级会员

Rank: 4

积分
561
金钱
561
注册时间
2011-4-11
在线时间
43 小时
发表于 2019-10-15 07:52:51 | 显示全部楼层
很棒的
回复

使用道具 举报

51

主题

214

帖子

0

精华

高级会员

Rank: 4

积分
561
金钱
561
注册时间
2011-4-11
在线时间
43 小时
发表于 2019-10-17 10:25:47 | 显示全部楼层
FSMC 8位,就是把RS 0和1地址搞清楚,把读写函数改成8位的就行,16位的拆成8位2次读写!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-16 18:28

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表