TCC89x的内存分布区域设置

时间:2022-08-22 17:50:35

//=====================================================================
//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文件夹之下。在讨论这个问题之前,我们先看看内存分配的大概领域,如图:

TCC89x的内存分布区域设置


 
     方框指的是每个范围领域的内容,如果方框为灰色,意味着这两个领域只有在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烧录系统的时候,会出错,其信息如图:


 

TCC89x的内存分布区域设置

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

 

     打开./Magellan/Src/LIB/SOC/NAND_DRV/nand_drv_v7.c文件,找到NAND_HIDDEN_0_PAGESIZE宏,其源代码如下:

 

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