找回密码
 注册
关于网站域名变更的通知
查看: 241|回复: 3
打印 上一主题 下一主题

有没有什么方法可以把ARM926从AT91SAM9260BSP中分离出来呢?

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2022-6-28 15:35 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
类似与libcpu中的cortex-m3将ARM内核相关的代码从BSP目录中分离出来, 主要为:
; v& ?( ?  D. e5 L% dstartup_xxx.S
% a1 }; P, ^# q2 ^
5 D- _; a9 D3 O% A/ L  q1 w各个编译器对应的启动脚本,设置堆栈,第一级IRQ响应及中断结束时的thread切换。" b" ]! W  j. \* ^7 w
修改中移除了内核之外的寄存器操作,将初次禁止中断、SRAM remap等移动到了BSP/platform的rt_low_level_init.c中,调用其rt_low_level_init函数前设置了SVC模式的stack。6 C& Q, H& ^; ^: B/ _
针对各个编译器增加了rt_low_level_xxx.inc asm 头文件,用于用户定义各个CPU模式下的stack。0 a7 Z* ?1 ^) \/ }- |

3 \8 n; A6 o, M; ]$ [1 ntrap.c+ _' Y3 t, p9 F/ z

6 g/ Z* }* d- m3 i9 @" i) a) D主要把查询IRQ中断向量号和确认响应中断两个函数从trap.c 移动到了interrupt.c 同时增加interrupt.h用于声明这两个函数。4 g% O' ^) P9 _2 n/ Q# y) K
rt_uint32_t rt_hw_interrupt_get_active(rt_uint32_t fiq_irq, rt_uint32_t id);
% O, o2 Z/ u; S, b# N# yvoid rt_hw_interrupt_ack(rt_uint32_t fiq_irq);
& y( \) f" W& P: q) o3 R
- w. j( v* v- Vcpuport.c及mmu.c
2 b/ C9 t: o* x  c& ^) R& v; E! c/ g6 ]% V
增加iar的asm部分。  J1 W3 j8 L8 K1 z& \/ }8 h
2 Z, r5 S# k9 S5 E/ U) M% G
遇到的问题:
, T- k, G) r) t1 I) T$ y
% x% H2 l8 a* S' Iscons脚本中如何包含asm的include路径, 我暂时解决方案是直接在bsp顶层AFLAGS中加入’ -Iplatform’
% ?8 E# V5 r. X, o+ I. h原来libcpu/ARM926 thread切换的时候 会在stack中保存PC,LR, R12-R0,CPSR, SPSR, 但是参考libcpu/AM335x 则只保存PC,LR, R12-R0,SPSR,没有CPSR, 但是仿照修改的是时候会产生错误。5 o7 f3 b" ]3 u& ~' _9 M6 G$ T
虽然iar/keil/gcc thread切换代码完全移植,但是只有keil下面的是稳定的,iar/gcc在运行60s左右都会自己重启。4 ^2 ?  H* @# m4 o2 }

该用户从未签到

2#
发表于 2022-6-28 16:21 | 只看该作者
如果重启的时间一样的话,检查一下看门狗。" @! w# ^( J, j

该用户从未签到

3#
发表于 2022-6-28 16:50 | 只看该作者
github rebase 没用好,push的时候又把Grissiom的一个commit包进去了.
8 ^) C' L1 T" |- e/ t
  • TA的每日心情
    开心
    2023-6-2 15:15
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2022-6-28 19:10 | 只看该作者
    再看看别人是怎么说的! }, b" ~1 t7 P5 F# p' y: }$ ]
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-23 20:59 , Processed in 0.156250 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表