完善资料让更多小伙伴认识你,还能领取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状态”异常,而不是该异常本身就是非法的。
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1495 浏览 1 评论
飞凌嵌入式ElfBoard ELF 1板卡-开发板适配之LED
794 浏览 0 评论
迅为RK3588开发板实时系统编译-Preemption系统/ Xenomai系统编译-编译Linux实时系统-单独编译1
474 浏览 0 评论
哇!5.2秒进入应用界面!Linux快速启动方案分享,基于全志T113-i国产平台
891 浏览 0 评论
飞凌嵌入式ElfBoard ELF 1板卡-移植前准备之git管理内核源码
581 浏览 0 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-27 00:07 , Processed in 0.668497 second(s), Total 73, Slave 57 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (威廉希尔官方网站 图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号