当前位置: 首页 > news >正文

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

相关文章:

  • spring bean的scope
  • J-Link的RTT功能实践
  • MVVM for silverlight
  • sort()的多种用法
  • 产品生产环节的一些名词
  • 生活随笔-为知笔记发布博客到博客园
  • 对你有用的名言集锦
  • 探究adroid活动
  • animation中的steps()逐帧动画
  • asm goto与JUMP_LABEL
  • 巧用工具制作视频截图索引文件
  • 进程遍历模块遍历
  • Linux inode耗尽导致图片/文件无法上传
  • 人生好比挤地铁(地铁育新站)
  • PowerDesinger12.5破解中文版-资源共享与安装介绍
  • C# 免费离线人脸识别 2.0 Demo
  • CEF与代理
  • ES学习笔记(12)--Symbol
  • FineReport中如何实现自动滚屏效果
  • github从入门到放弃(1)
  • Git初体验
  • Go 语言编译器的 //go: 详解
  • interface和setter,getter
  • iOS高仿微信项目、阴影圆角渐变色效果、卡片动画、波浪动画、路由框架等源码...
  • js 实现textarea输入字数提示
  • niucms就是以城市为分割单位,在上面 小区/乡村/同城论坛+58+团购
  • PaddlePaddle-GitHub的正确打开姿势
  • SwizzleMethod 黑魔法
  • 关于 Cirru Editor 存储格式
  • 关于extract.autodesk.io的一些说明
  • 来,膜拜下android roadmap,强大的执行力
  • 利用jquery编写加法运算验证码
  • 面试总结JavaScript篇
  • 十年未变!安全,谁之责?(下)
  • 使用API自动生成工具优化前端工作流
  • 使用权重正则化较少模型过拟合
  • 我感觉这是史上最牛的防sql注入方法类
  • 一份游戏开发学习路线
  • 以太坊客户端Geth命令参数详解
  • 主流的CSS水平和垂直居中技术大全
  • 《TCP IP 详解卷1:协议》阅读笔记 - 第六章
  • Python 之网络式编程
  • 测评:对于写作的人来说,Markdown是你最好的朋友 ...
  • 如何在 Intellij IDEA 更高效地将应用部署到容器服务 Kubernetes ...
  • ​ ​Redis(五)主从复制:主从模式介绍、配置、拓扑(一主一从结构、一主多从结构、树形主从结构)、原理(复制过程、​​​​​​​数据同步psync)、总结
  • ​Spring Boot 分片上传文件
  • ​sqlite3 --- SQLite 数据库 DB-API 2.0 接口模块​
  • # Swust 12th acm 邀请赛# [ E ] 01 String [题解]
  • # Swust 12th acm 邀请赛# [ K ] 三角形判定 [题解]
  • #13 yum、编译安装与sed命令的使用
  • #define,static,const,三种常量的区别
  • (02)vite环境变量配置
  • (04)odoo视图操作
  • (2)MFC+openGL单文档框架glFrame
  • (39)STM32——FLASH闪存