共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电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 | |
【我踩过的那些坑】电感选型错误导致的处理器连接不上被打赏50分 | |
【我踩过的那些坑】工作那些年踩过的记忆深刻的坑被打赏10分 | |
【我踩过的那些坑】DRC使用位置错误导致的问题被打赏100分 | |
我踩过的那些坑之混合OTL功放与落地音箱被打赏50分 |