完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我有一个PIC24FJ1024GB610,我有一个Bootloader,占用0x7FFF。我从0x8000运行代码,如果我的代码越过0x10000边界,它不再是功能性的。编译器建议我使用大的代码模型来存储模型。有没有人知道我需要做什么特别的事情来跨越这个边界?我知道我的链接器文件是好的,因为我能够运行一个较小的应用程序启用中断。我们已经使用了一个大约5年前编写的Bootloader,我们已经将它移植到PIC24和PIC18的许多版本中,但是现在我们需要额外的空间PIC24FJ1024GB610。我使用IDE MPLAB X(V3.51)和XC16(V1.30)。
以上来自于百度翻译 以下为原文 I have a PIC24FJ1024GB610 and I have a bootloader that takes up 0x7fff. I run code from 0x80000 if my code crosses the 0x10000 boundary it is no longer functional. The compiler suggested that I use large Code model for the Memory Model. Does anyone know if I need to do anything special to cross this boundary? I know my linker files are ok because I was able to run a smaller application with interrupts enabled. We have been using a bootloader we have written about 5 years ago and we have ported it to many versions of the PIC24 and PIC18 but now we needed the extra space the PIC24FJ1024GB610 has. I am using IDE MPLAB X (v3.51) and XC16 (v1.30) |
|
相关推荐
2个回答
|
|
FJ在它的一些指令/向量中有局限性,它只允许访问底部64K。为了在某些应用中超过这个限制,“内存模型”克服了这个限制。EP有额外的指令来解决(大多数)这些问题。虽然你有一个工作引导程序,但是你(特别是PIC24FJ…)想定位引导加载程序“高”。对不起,这里使用的是PC术语。只需从内存加载程序的顶部开始占用内存即可。复位向量JMP可以访问任何地址。应用程序空间保持不变,不管是否与引导加载程序一起使用。希望这有助于…Yorky
以上来自于百度翻译 以下为原文 The FJ has limitations in some of its instructions/vectors that only allows access to the bottom 64K. To access above this limit in some applications, the 'memory model' overcomes this limitation. The EP has additional instructions that solve (most of) these issues. Although you have a working bootloader, have you (especially for PIC24FJ..) thought of locating the bootloader 'high'. Sorry using PC terminology here. Just start occupying memory from the top of memory for the bootloader. The reset vector JMP can access any address. The application space remains identical irrespective of use with bootloader or not.. Hope this assists.. T Yorky |
|
|
|
对,如果编译器知道它不超过64K,编译器可以生成非常高效的OP代码。因此,你必须通过选择大模型来通知编译器在你的情况下使用效率较低的操作码。移动引导加载程序是一个非常好的建议。我认为引导加载程序必须在大模型中编译,但是除非超过64K的Flash,否则你的应用程序可以停留在小模型中。
以上来自于百度翻译 以下为原文 Right, the compiler can generate very efficient op-codes if it knows that it will not exceed 64K. So one has to inform the compiler to use less efficient opcodes in your situation by choosing the large model. Moving the boot loader high is a very good suggestion. I think the boot loader will have to be compiled in the large model, but your app can stay in the small model unless it exceeds 64K of flash. |
|
|
|
只有小组成员才能发言,加入小组>>
5160 浏览 9 评论
1998 浏览 8 评论
1927 浏览 10 评论
请问是否能把一个ADC值转换成两个字节用来设置PWM占空比?
3170 浏览 3 评论
请问电源和晶体值之间有什么关系吗?PIC在正常条件下运行4MHz需要多少电压?
2225 浏览 5 评论
727浏览 1评论
612浏览 1评论
有偿咨询,关于MPLAB X IPE烧录PIC32MX所遇到的问题
501浏览 1评论
PIC Kit3出现目标设备ID(00000000)与预期的设备ID(02c20000)不匹配。是什么原因
626浏览 0评论
524浏览 0评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-22 07:47 , Processed in 1.324071 second(s), Total 79, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号