这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » 关于定义非cache区域起始地址的问题

共5条 1/1 1 跳转至

关于定义非cache区域起始地址的问题

菜鸟
2006-03-13 21:15:09     打赏
关于定义非cache区域起始地址的问题

dst=(unsigned int *)malloc(0x100);
rNCACHBE0= ((int)dst>>12) + ( (((int)dst>>12) +1)<<16 );



这个代码是定义非cache区域起始地址的,请问这个右移12位是什么意思?


还有在ARM里怎么把一个函数或变量定义在一个确切的ram位置上?




关键词: 关于     定义     cache     区域     起始     地址     问题    

菜鸟
2006-03-13 21:16:00     打赏
2楼

比如说怎么把ISR放在内部的SRAM里


菜鸟
2006-03-14 02:49:00     打赏
3楼

谢谢,关于sram的放置,我有所理解了,跟freescale的mcu的道理是一样的,我详细再看看应该能弄懂。

而关于rNCACHBE0是在做DMA处理时防止装载一些错误的数据而设置的,我的理解应该指的是DMA的目的地址,但是代码的移位操作最后到底得到的是一个什么数呢?而且三星所有这部分相关的代码都是这样写的,看来这是一个通用的表达式,但是就是不知道什么意思?


菜鸟
2006-03-14 02:50:00     打赏
4楼
还有为什么建议不要使malloc呢?

菜鸟
2006-03-16 19:49:00     打赏
5楼

好的,明白了,原来右移12位是这个意思,多谢阿


共5条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]