完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我试图在裸机设置中基于ARM Cortex R52的周期精确模型运行内部基准测试。我使用GCC 7.2.1编译并建立了基准测试-gcc版本7.2.1 20170904(发行版)[ARM / embedded-7-branch版本255204](用于ARM嵌入式处理器的GNU工具7-2017-q4-major。 newlib并将-specs = nosys.specs传递给链接器。我有一些基本的启动代码,用于为异常设置矢量表并初始化缓存,TCM等。 一旦代码执行到达__start(或_mainCRTStartup)(在crt.o中),则在执行以下指令后执行一条指令时,将发生“非法异常返回”: msr CPSR_c,#209;0xd1 上面的说明是为每种模式设置SP的部分内容。该指令尝试更改为FIQ模式。从我从ARMv8和ARMv8-R体系结构手册中可以了解到,在系统管理程序模式下尝试修改CPSR的模式位是非法的。甚至Cortex R52手册也建议从EL2(Hyp。)更改为EL1(FIQ等)的方法稍有不同。根据R52手册,处理器处于Hypervisor模式且未重置。 我的问题是这是错误还是我使用的是错误版本的newlib。我是否应该在跳转到__start之前切换到EL1模式?如果是,这是否意味着我需要自己为虚拟机监控程序模式设置SP和(还有堆栈限制?)? |
|
相关推荐
1个回答
|
|
得到了“非法异常返回AArch32状态”异常,而不是该异常本身就是非法的。
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
迅为RK3568开发板EMMC镜像导出打包update.img
403 浏览 0 评论
飞凌嵌入式-ELFBOARD 硬件知识分享-ELF 2电源电路讲解
1004 浏览 0 评论
1713 浏览 0 评论
飞凌嵌入式ElfBoard ELF 1板卡-mfgtools烧录流程介绍之烧写所需镜像
1511 浏览 0 评论
飞凌嵌入式ElfBoard ELF 1板卡-mfgtools烧录流程之烧写方法
956 浏览 0 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-26 13:00 , Processed in 0.475953 second(s), Total 40, Slave 35 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号