//=====================================================================
//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的大小即可。