OpenEdv-开源电子网

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

st32f407vgt6 FSMC驱动8位LCD,不能读写LCD存储器

[复制链接]

1

主题

4

帖子

0

精华

新手入门

积分
15
金钱
15
注册时间
2020-8-6
在线时间
5 小时
发表于 2020-8-7 16:51:32 | 显示全部楼层 |阅读模式
1金钱
近来用一块自己做的板子,用407zgt6板子实现显示功能,不能读取LCD的ID,用示波器测试观察发现在对LCD进行读写时,LCD的CS、C/D,RD,WR信号没有变化,也就是FSMC没有工作,LCD用的8位数据,PD11/FSMC_A16地址 命令数据选择。
主要部分程序如下,看看那位大神来指导一下
#define ST7789_REG        *(__IO uint16_t*)(((uint32_t)0x60000000))
#define ST7789_RAM        *(__IO uint16_t*)(((uint32_t)0x60020000))
SRAM_HandleTypeDef hsram1;
static void MX_FSMC_Init(void)
{
FSMC_NORSRAM_TimingTypeDef Timing;
FSMC_NORSRAM_TimingTypeDef ExtTiming;
  /**Perform the SRAM1 memory initialization sequence  */
hsram1.Instance = FSMC_NORSRAM_DEVICE;
hsram1.Extended = FSMC_NORSRAM_EXTENDED_DEVICE;
  /*hsram1.Init */
hsram1.Init.NSBank = FSMC_NORSRAM_BANK1;
hsram1.Init.DataAddressMux = FSMC_DATA_ADDRESS_MUX_DISABLE;
hsram1.Init.MemoryType = FSMC_MEMORY_TYPE_SRAM;
hsram1.Init.MemoryDataWidth = FSMC_NORSRAM_MEM_BUS_WIDTH_8;
hsram1.Init.BurstAccessMode = FSMC_BURST_ACCESS_MODE_DISABLE;
hsram1.Init.WaitSignalPolarity = FSMC_WAIT_SIGNAL_POLARITY_LOW;
hsram1.Init.WrapMode = FSMC_WRAP_MODE_DISABLE;
hsram1.Init.WaitSignalActive = FSMC_WAIT_TIMING_BEFORE_WS;
hsram1.Init.WriteOperation = FSMC_WRITE_OPERATION_ENABLE;
hsram1.Init.WaitSignal = FSMC_WAIT_SIGNAL_DISABLE;
hsram1.Init.ExtendedMode = FSMC_EXTENDED_MODE_ENABLE;
hsram1.Init.AsynchronousWait = FSMC_ASYNCHRONOUS_WAIT_DISABLE;
hsram1.Init.WriteBurst = FSMC_WRITE_BURST_DISABLE;
hsram1.Init.PageSize = FSMC_PAGE_SIZE_NONE;
  /*Timing */
Timing.AddressSetupTime = 15;
Timing.AddressHoldTime = 15;
Timing.DataSetupTime = 15;
Timing.BusTurnAroundDuration = 0;
Timing.CLKDivision = 0;
Timing.DataLatency = 0;
Timing.AccessMode = FSMC_ACCESS_MODE_A;
  /*ExtTiming */
ExtTiming.AddressSetupTime = 15;
ExtTiming.AddressHoldTime = 15;
ExtTiming.DataSetupTime = 15;
ExtTiming.BusTurnAroundDuration = 0;
ExtTiming.CLKDivision = 0;
ExtTiming.DataLatency = 0;
ExtTiming.AccessMode = FSMC_ACCESS_MODE_A;
  if(HAL_SRAM_Init(&hsram1, &Timing, &ExtTiming) != HAL_OK)
  {
   Error_Handler( );
  }
}
这是cube生成的fsmc初始化,俩便有些参数做过调整实验,也没有效果。
/* USER CODE BEGIN 4 */
void ST7789_WR_REG(vu16 regval)
{
   regval = regval;        
   ST7789_REG = regval;
}
void ST7789_WR_DATA(vu16 data)
{
    data = data;         
   ST7789_RAM = data;
}
uint8_t ST7789_RD_DATA(void)
{
   vu8 ram;  
   ram = ST7789_RAM;
   return ram;
}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2020-8-8 00:50:53 | 显示全部楼层
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手入门

积分
15
金钱
15
注册时间
2020-8-6
在线时间
5 小时
 楼主| 发表于 2020-8-8 08:00:24 | 显示全部楼层
8位数据位,将地址改为如下所示,现象一样,求各位大神来指导一下,急急急
define ST7789_REG        *(__IO uint8_t*)(((uint32_t)0x60000000))
#define ST7789_RAM        *(__IO uint8_t*)(((uint32_t)0x60010000))
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-4-30 17:55

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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