共2条
1/1 1 跳转至页
FALSH,RAM 关于FALSH、RAM空间的分段定义问题,急!!!
问
各位大侠请指教:我用的编译环境是Embedded Workbench 3.2,cpu:MSP430f449在LINK时我想把程序分为两个段,分别存储在指定的FALSH空间,还有把CONST 数据、堆栈、DATA也存储在制定的空间,我看了MSP430f449.XCL,觉得要解决我的问题,需要增加段的定义,怎么增加段,在那儿增加,希望各位大侠能帮我解决,谢谢!!!
答 1:
请不吝赐教,谢谢!!!
答 2:
我现在着急用,请各位大侠指点
答 3:
引用:
答 4:
非常感谢你!!!我是为了实现远程下载,我想把一部分程序作为驻留软件存放在FLASH的固定几个段,驻留软件不被其他任何程序修改,另一部分程序负责处理日常任务,也就是主程序,当他收到远程命令是要修改主程序时,程序需要条转到驻留程序,驻留程序实现接收远程下载的数据(既主程序),对存放主程序的FLASH段进行擦除和编程,实现远程更新主程序的功能,我在线等待你的指点,谢谢!!!
答 5:
还有就是,在远程修改主程序时CONST数据不能被改,也需要把他定义在固定的其他段。
答 6:
请问lsdfae03能帮我解决吗,本人不胜感激!!!
答 7:
-Z(CONST)DATA16_C=开始地址-FFDF,可以定义CONST的存放位置。
答 8:
谢谢你!!!请问LSDFAE10程序可以分为两部分存储到不同的段吗?
答 9:
去看看。
http://zoglab.vicp.net/bbs/viewthre...2&highlight=xcl 答 10: 非常感谢sky412,把程序分别存放在不同区域,是不是可以这样做
-Z(CODE)CODE_TAB=FF00-FFDF //将ROM FF00 至 FFDF 划作 CODE_TAB 区.
再在程序中用定义
#pragma memory=constseg(DATA_TAB)
void ClkIni(void)
{
SCFQCTL = 0X79; //N=121 输出DCOCLK = 4MHz
SCFI0 = 0X20 ; //不分频,DCOCLK 输出2.8~26.6MHz
SCFI1 = 0X00; //DCOx=0,MODx=0
FLL_CTL0 = 0XC0; //DCO output is not divided,DCO output is not divided,fault condition present SIGNAL
FLL_CTL1 = 0X10; //0: SMCLK = DCOCLK,2: MCLK = XT2CLK,0 XT2 is on
IE1 = 0X02; //The oscillator fault-interrupt enable bit (OFIE)
} //将 ClkIni函数定义到 ROM FF00开始的区域
#pragma memory = default
请问这样做是不是就把ClkIni函数定义到 ROM FF00开始的区域了? 答 11: 对数据分段、存放是没有问题。
但对程序分段存放,而且两个程序还要受控并且“驻留”永不被修改,而另外一个程序的内容是受“驻留程序”控制,可以修改内容,即修改程序,我试过感觉不好实现。
大家是否测试过?给点建议。 答 12: 函数 void f() "MYSEGMENT" 在lnkMSP430f449.xcl中加入 Z(CODE)MYSEGMENT=定位地址 答 13: 非常感激cool430及各位大侠,我用你介绍的方法修改后,make了一下,MSP430.map 文件出现了此段MYSEGMENT1 F000 - F07F 80 rel 1 这样是对的,但在MSP430.txt中有1100,FFE4,FFF0等段,和这些段的数据,但没有F000和他的数据,我还没有目标板,没有真正试,不知道这样的结果对吗?
另外,你有这方面的资料吗?麻烦给我一份吧,我的地址liyuxianghb126.com,谢谢!!!
http://zoglab.vicp.net/bbs/viewthre...2&highlight=xcl 答 10: 非常感谢sky412,把程序分别存放在不同区域,是不是可以这样做
-Z(CODE)CODE_TAB=FF00-FFDF //将ROM FF00 至 FFDF 划作 CODE_TAB 区.
再在程序中用定义
#pragma memory=constseg(DATA_TAB)
void ClkIni(void)
{
SCFQCTL = 0X79; //N=121 输出DCOCLK = 4MHz
SCFI0 = 0X20 ; //不分频,DCOCLK 输出2.8~26.6MHz
SCFI1 = 0X00; //DCOx=0,MODx=0
FLL_CTL0 = 0XC0; //DCO output is not divided,DCO output is not divided,fault condition present SIGNAL
FLL_CTL1 = 0X10; //0: SMCLK = DCOCLK,2: MCLK = XT2CLK,0 XT2 is on
IE1 = 0X02; //The oscillator fault-interrupt enable bit (OFIE)
} //将 ClkIni函数定义到 ROM FF00开始的区域
#pragma memory = default
请问这样做是不是就把ClkIni函数定义到 ROM FF00开始的区域了? 答 11: 对数据分段、存放是没有问题。
但对程序分段存放,而且两个程序还要受控并且“驻留”永不被修改,而另外一个程序的内容是受“驻留程序”控制,可以修改内容,即修改程序,我试过感觉不好实现。
大家是否测试过?给点建议。 答 12: 函数 void f() "MYSEGMENT" 在lnkMSP430f449.xcl中加入 Z(CODE)MYSEGMENT=定位地址 答 13: 非常感激cool430及各位大侠,我用你介绍的方法修改后,make了一下,MSP430.map 文件出现了此段MYSEGMENT1 F000 - F07F 80 rel 1 这样是对的,但在MSP430.txt中有1100,FFE4,FFF0等段,和这些段的数据,但没有F000和他的数据,我还没有目标板,没有真正试,不知道这样的结果对吗?
另外,你有这方面的资料吗?麻烦给我一份吧,我的地址liyuxianghb126.com,谢谢!!!
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |