免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1969 | 回复: 3

[内核入门] svc_entry 如何保存org r0的? [复制链接]

论坛徽章:
0
发表于 2013-07-23 13:00 |显示全部楼层
表红的3行:
r6 应该是-1,怎么变成org r0了。



149        .macro  svc_entry, stack_hole=0
150 UNWIND(.fnstart                )
151 UNWIND(.save {r0 - pc}         )
152        sub     sp, sp, #(S_FRAME_SIZE + \stack_hole - 4)
153#ifdef CONFIG_THUMB2_KERNEL
154 SPFIX( str     r0, [sp]        )       @ temporarily saved
155 SPFIX( mov     r0, sp          )
156 SPFIX( tst     r0, #4          )       @ test original stack alignment
157 SPFIX( ldr     r0, [sp]        )       @ restored
158#else
159 SPFIX( tst     sp, #4          )
160#endif
161 SPFIX( subeq   sp, sp, #4      )
162        stmia   sp, {r1 - r12}
163
164        ldmia   r0, {r3 - r5}
165        add     r7, sp, #S_SP - 4       @ here for interlock avoidance
166        mov     r6, #-1                 @  ""  ""      ""       ""
167        add     r2, sp, #(S_FRAME_SIZE + \stack_hole - 4)
168 SPFIX( addeq   r2, r2, #4      )
169        str     r3, [sp, #-4]!          @ save the "real" r0 copied
170                                        @ from the exception stack
171
172        mov     r3, lr
173
174        @
175        @ We are now ready to fill in the remaining blanks on the stack:
176        @
177        @  r2 - sp_svc
178        @  r3 - lr_svc
179        @  r4 - lr_<exception>, already fixed up for correct return/restart
180        @  r5 - spsr_<exception>
181        @  r6 - orig_r0 (see pt_regs definition in ptrace.h)
182        @
183        stmia   r7, {r2 - r6}
184
185#ifdef CONFIG_TRACE_IRQFLAGS
186        bl      trace_hardirqs_off
187#endif
188        .endm

论坛徽章:
0
发表于 2013-07-23 16:50 |显示全部楼层
我顶

论坛徽章:
0
发表于 2013-07-24 09:52 |显示全部楼层
blake326 发表于 2013-07-23 16:50
我顶



wo ye ding

论坛徽章:
0
发表于 2013-07-24 14:03 |显示全部楼层
回复 3# blake326


    代码的注释真是蛋疼。

    实际上pt_regs,  一共18个regs,r0-r15, cpsr, orig_r0
    r0-r15 保存的异常时的寄存器。这个r0保存异常时的r0,被后面的orig_r0名字给忽悠了。
         其中sp,lr是svc模式的sp,lr  
         pc是correct之后的异常lr.
    cpsr 是异常保存的spsr。
    orig_r0 是-1,这个值比较特殊,不知到什么作用。比较容易看把。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP