TCC89x的内存分布区域设置

//=====================================================================
//TITLE:
// TCC89x的内存分布区域设置
//AUTHOR:
// norains
//DATE:
// Friday 7-January-2011
//Environment:
// Visual Studio 2005
// TCC89x Magellan V1.9.1
//=====================================================================

对于TCC89x而言,如何正确设置内存分布区域是一件很重要的事情。当然,如果你开发的产品和官方的EVB一致,也不会超过官方的范围,那么你一切皆可安心,直接采用默认设置即可。但如果不是,那么你就必须要自己手动更改了。

TCC89x的内存设置在magellan.bib文件,而该文件在BSP包Magellan的Files文件夹之下。在讨论这个问题之前,我们先看看内存分配的大概领域,如图:



方框指的是每个范围领域的内容,如果方框为灰色,意味着这两个领域只有在XIP模式下才有效。而红色的字体,对应magellan.bib文件中相应的宏,表示需要需要设置的数值。从图中可以看出,需要设置的数值分为两个,一个是起始地址,另一个则是大小。

Telechips原厂的magellan.bib文件末尾给出了一种计算这些数值的方法,只不过这方法是针对从零开始的状况,对于我们只需要修改某些数值的使用者而言,无疑显得稍有繁琐。其实回过头来说,一般magellan.bib文件我们并不需要大的修改,最常见的是由于添加的组件太多,导致编译的NK比规定的范围要大,这时候才需要对magellan.bib文件进行修正。

结合我们的所给的例图,修改NK的大小很简单。NKSTART数值维持不动,我们只是将NKLEN扩大。而NKLEN增大以后,就会影响到RAMSTART和RAMLEN的取值,而这两个数值在原有的基础上修改也是很简单的事情。

对于新的RAMSTART,其计算方法如下:
RAMSTART(new) = NKSTART + NKLEN(new)

新的RAMLEN,计算方式也大同小异,如下:
RAMLEN(new) = DDRAWST - RAMSTART(new)

这里需要注意一个问题,就是NKLEN超过33M的话,虽然可以编译成功,但用FWDN烧录系统的时候,会出错,其信息如图:


从图中的信息告诉我们,Kernel空间不够,无法烧录NK.ROM!那是不是意味着我们的NK只能少于33M呢?当然不是。不过,为了支持超过33M的大小,我们必须修改相应的代码。

打开./Magellan/Src/LIB/SOC/NAND_DRV/nand_drv_v7.c文件,找到NAND_HIDDEN_0_PAGESIZE宏,其源代码如下:
#define NAND_HIDDEN_0_PAGESIZE (33/*MB*/*1024*2) #define NAND_HIDDEN_1_PAGESIZE (3/*MB*/*1024*2) // for LOGO #define NAND_HIDDEN_2_PAGESIZE (2/*MB*/*1024*2) #define NAND_HIDDEN_3_PAGESIZE (3/*MB*/*1024*2)

聪明的读者可能已经想到,如果需要NK支持更大的容量,只需要更改NAND_HIDDEN_0_PAGESIZE宏即可。原来的大小是33,你可以选择36,甚至更多,只要能容得下你NK的大小即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值