搜索
bottom↓
回复: 5

关于keil使用双DPTR的问题

[复制链接]

出0入0汤圆

发表于 2012-9-12 17:16:00 | 显示全部楼层 |阅读模式
      在keil编程时外扩512k的sram,现在要把数据memcpy到外部sram,如何对keil进行设置?具体要怎么实现?memcpy涉及双DPTR该如何运用?请大侠们帮忙啊!感激不尽!!
   补充:使用的mcu是AX11015,本身支持双DPTR。

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2012-9-13 09:04:48 | 显示全部楼层
Target设置项,有个use Multiple DPTR Register 的选项。打勾即可!

出0入0汤圆

 楼主| 发表于 2012-9-13 10:56:37 | 显示全部楼层
chinabn 发表于 2012-9-13 09:04
Target设置项,有个use Multiple DPTR Register 的选项。打勾即可!

     我是准备把512K的外部SRAM作为XDATA使用。
     是不是把外部sram作为一个整体sram来看,也就是说直接访问外部SRAM的整个512K的地址空间,但KEIL编译器一般默认定义的地址都是16位的,只能访问64K的空间。
     据我所知,要访问更大的空间,如果不分页,可以定义一个far类型的指向24位地址的指针,并且加入一个keil的lib文件夹中的XBANKING.A51文件来进行对超过64K地址空间的读写操作。
     那不知您们是怎么访问外部sram的?如何对超过64K的地址空间进行操作?

出0入0汤圆

发表于 2012-9-13 11:26:18 | 显示全部楼层
512K > 64K(最大寻址空间)
IO扩展XRAM地址空间即可。作为8个独立SRAM操作。
=======================
好像Keil支持XRAM Bank的外部切换定义,即内部编译器给你自动切换。具体没用过。
你可以查下Keil的范例。

出0入0汤圆

发表于 2012-9-14 00:54:05 | 显示全部楼层
chinabn 发表于 2012-9-13 09:04
Target设置项,有个use Multiple DPTR Register 的选项。打勾即可!

请问,是不是在Keil4版本后就没有这个选项了,我在我的软件里找不到这个

出0入0汤圆

发表于 2012-9-14 08:56:03 | 显示全部楼层
1 - AX11015好像本来就支持最大2M外部RAM空间寻址。
from keil
8051 based High-Speed SoC solution which provides TCP/IP and
10/100 Fast Ethernet MAC/PHY, 32 I/O Lines, 3 Timers/Counters,
5-Channel PCA, 3 UARTs, SPI and 1-wire, 512K Flash, 32K RAM.
Addresses up to 2MB external memory without bank selection.

2 - 只要Keil支持 AX11015此型号。就一定有 “use Multiple DPTR Register ” 的选项。
  查看是否选错型号.
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-19 15:26

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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