OpenEdv-开源电子网

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

IS62WV51216的寻址问题,原子哥请进

[复制链接]

5

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
56
金钱
56
注册时间
2015-1-23
在线时间
2 小时
发表于 2016-4-10 01:37:48 | 显示全部楼层 |阅读模式
1金钱
IS62WV51216不是只有19根地址线吗?为什能寻址1MB的内存它的地址线 2的19次方是512K,数据线是16位的,
但问题是编程的时候,比如说我是字节寻址,地址累加的时候,当程序中的地址超出512K时,即19位地址线全为1时,接下来的地址怎么表示?是不是要借用了其他信号?
如以下代码:
      #define Bank1_SRAM3_ADDR    ((u32)(0x68000000))        
           u32 i = 0;
      for(i=0;i<1024*1024;i++)
        {
           *(vu8*)(Bank1_SRAM3_ADDR+i) = 0x55;         
        
        }
上面的代码很明,只寻址了1M的空间,每次写1个字节。可以是超出了512K的址是怎么传达给 IS62WV51216芯片的?

最佳答案

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

你如果是以u8方式访问,每隔2个地址,才会让地址线加1的!!因为是16位数据!!通过UB/LB来使用高低字节。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-4-10 01:37:49 | 显示全部楼层
你如果是以u8方式访问,每隔2个地址,才会让地址线加1的!!因为是16位数据!!通过UB/LB来使用高低字节。
回复

使用道具 举报

9

主题

507

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3347
金钱
3347
注册时间
2013-4-10
在线时间
333 小时
发表于 2016-4-10 02:39:24 | 显示全部楼层
本帖最后由 likunxue 于 2016-4-10 02:41 编辑

光从电路硬来说, 超过了又从零开始, 从软件的角度看,是更高位的地址, 但哪个更高位的地址置1时对当前芯片无效,如果CPU不出错,哪你读也的值双从零地址开始增加

好比如,单个节字,只有8个位, 最大值255,也就0XFF, 如果你再加1 不就变成 256了 这时,数据向高位进0 低位全清零 再加,如果不管高位,你哪单字节是不是一直从0~ 255在从重变化?
回复

使用道具 举报

1

主题

3

帖子

0

精华

新手入门

积分
41
金钱
41
注册时间
2015-10-17
在线时间
3 小时
发表于 2016-4-16 19:40:09 | 显示全部楼层
原子哥是不是可以理解 2^19=512 个不同的地址线 实际管理的就是512*2个字节地址空间,只是通过UB/LB来使用高低字节,导致 字节地址*2=地址线*1  这样做有什么好处?--是不是可以减少硬件成本(地址线减少)
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-8 16:43

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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