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

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

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
类似与libcpu中的cortex-m3将ARM内核相关的代码从BSP目录中分离出来, 主要为:
* M8 |8 |9 n" b- ^, Bstartup_xxx.S: ~/ o% s- c; f4 f( M6 N
- [) z8 t0 W& W) A) P# q
各个编译器对应的启动脚本,设置堆栈,第一级IRQ响应及中断结束时的thread切换。4 D' I& o0 L9 t6 _# l% u  H5 U
修改中移除了内核之外的寄存器操作,将初次禁止中断、SRAM remap等移动到了BSP/platform的rt_low_level_init.c中,调用其rt_low_level_init函数前设置了SVC模式的stack。. k0 T% u1 l  P  w; }4 h3 q
针对各个编译器增加了rt_low_level_xxx.inc asm 头文件,用于用户定义各个CPU模式下的stack。
0 b, }7 B8 m$ S5 f/ A4 W
3 h, ?- q, V1 ^( {' ktrap.c
! }: B$ A) q, A0 o" Q9 o6 O
) v" V* S$ B$ V" d/ w主要把查询IRQ中断向量号和确认响应中断两个函数从trap.c 移动到了interrupt.c 同时增加interrupt.h用于声明这两个函数。
  {5 y. o- N/ h- r0 e/ ]  v  Hrt_uint32_t rt_hw_interrupt_get_active(rt_uint32_t fiq_irq, rt_uint32_t id);" V1 n5 j1 Y$ t1 ?1 R8 h- B3 ^
void rt_hw_interrupt_ack(rt_uint32_t fiq_irq);
+ I" a% A$ l* `( @' j5 T9 i7 \2 o" D# f( q7 P4 V
cpuport.c及mmu.c
5 g! y; N& u; b% N; Y; M3 r/ t% M1 h5 f1 a
增加iar的asm部分。
* a( k- r8 ]8 B1 C- @
& c' {  b' c% O- ^: E) p% {遇到的问题:! O' l1 x+ W5 P6 |, O: \- K
# x9 d- N9 @. m. g
scons脚本中如何包含asm的include路径, 我暂时解决方案是直接在bsp顶层AFLAGS中加入’ -Iplatform’
% f1 G- r/ n2 r) p' e4 M原来libcpu/ARM926 thread切换的时候 会在stack中保存PC,LR, R12-R0,CPSR, SPSR, 但是参考libcpu/AM335x 则只保存PC,LR, R12-R0,SPSR,没有CPSR, 但是仿照修改的是时候会产生错误。
2 T; h  }$ K/ f+ W* F$ Y. O. }虽然iar/keil/gcc thread切换代码完全移植,但是只有keil下面的是稳定的,iar/gcc在运行60s左右都会自己重启。( J, E: B+ K, s, g

该用户从未签到

2#
发表于 2022-6-28 16:21 | 只看该作者
如果重启的时间一样的话,检查一下看门狗。" a3 l5 T2 R- a) g, I

该用户从未签到

3#
发表于 2022-6-28 16:50 | 只看该作者
github rebase 没用好,push的时候又把Grissiom的一个commit包进去了.
& f9 |7 C8 ?* n* H# e
  • TA的每日心情
    开心
    2023-6-2 15:15
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2022-6-28 19:10 | 只看该作者
    再看看别人是怎么说的
    % A) V: Z# ?  J" n% c6 _  @
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-6-18 17:23 , Processed in 0.093750 second(s), 23 queries , Gzip On.

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

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

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