打印

询问一下关于STM32操作外部Ram的字节寻址的问题

[复制链接]
4935|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
chenlong828|  楼主 | 2010-7-8 11:38 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在项目中使用到STM32,由于内存不够用,通过FSMC连接了一块IS61LV25616的512K的SRAM,但是发现FSMC设置宽度为16BIT宽度后,我没有办法以字节为单位寻址,对内存的一次读写都必须是2byte。
想问一下stm32没有自动在内部用硬件做这样的处理么,比如在设置了外部储存为16bit宽度时,写入字节寻址的一个byte时读入2byte,然后自动与要写入的byte合并后再以16bit宽度写入外部ram .
还是说这些操作必须是用户在应用程序中通过程序实现的,因为如果只有程序实现的话,要是在开发过程中发现内存不够用而需要扩容内存,那么很有可能之前开发的代码所有字节访问地方都需要全部更改,否则就只能选择外部ram接口为8bit的。
还是有其他的解决方法?
沙发
香水城| | 2010-7-8 11:42 | 只看该作者
为什么没有办法以字节为单位寻址?你是怎么操作的?

使用特权

评论回复
板凳
chenlong828|  楼主 | 2010-7-8 11:49 | 只看该作者
我的fsmc的 设置如下
    p.FSMC_AddressSetupTime = 3;
  p.FSMC_AddressHoldTime = 3;
  p.FSMC_DataSetupTime = 3;
  p.FSMC_BusTurnAroundDuration = 0;
  p.FSMC_CLKDivision = 1;
  p.FSMC_DataLatency = 0;
  p.FSMC_AccessMode = FSMC_AccessMode_A;

  FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3;
  FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;
  FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM;
  FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;
  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_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_NORSRAM3, ENABLE);


在程序中我定义了一个很大的数组
#ifdef ExtRamOnbord
#define NETSENDFIFO_MAXLEN 131072
#else
#define NETSENDFIFO_MAXLEN 40960
#endif
static U8 NETSENDFIFO[NETSENDFIFO_MAXLEN];

然后在初始化代码中加入
        U32 i;
        for(i=0;i<NETSENDFIFO_MAXLEN;i++)
                NETSENDFIFO[i]=(u8)i;
在调试窗口中看到内存地址为0x68000000开始的地方,赋值NETSENDFIFO[1]的时候0x68000000和0x68000001都变成了0,赋值NETSENDFIFO[1]的时候这两个地址都变成了0x01,赋值NETSENDFIFO[2]的时候0x68000002和0x68000003都变成了0x02,赋值NETSENDFIFO[3]的时候0x68000002和0x68000003都变成了0x03,....执行完后0x68000000 开始的内存值从MDK的窗口看是0x01 0x01 0x03 0x03 0x05 0x05 。。。。

使用特权

评论回复
地板
香水城| | 2010-7-8 12:02 | 只看该作者
这种现象的确有问题。

你的硬件线路是怎么连接的?好像没有接NBL0和NBL1信号。

使用特权

评论回复
5
chenlong828|  楼主 | 2010-7-8 12:23 | 只看该作者
晕,果然没连,赶紧飞上去试试。。。谢谢谢谢

使用特权

评论回复
6
zhanggw| | 2010-8-13 15:22 | 只看该作者
我曾经也遇到怎么样的问题,但是我的NBL0和NBL1信号有接,A0没接,最后接上A0就好了

使用特权

评论回复
7
sinadz| | 2010-8-14 09:42 | 只看该作者
香主居然一眼就看出了楼主得哪里没接,实在是佩服

使用特权

评论回复
8
xsgy123| | 2010-8-14 10:00 | 只看该作者
能够从现象直接判别出硬件的连接问题,不知我何时能达到这种水平

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

0

主题

4

帖子

1

粉丝