免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2015 | 回复: 2
打印 上一主题 下一主题

[内存管理] arm的内核栈地址保存在哪里? [复制链接]

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-08-15 17:26 |只看该作者 |倒序浏览
arm的内核栈地址保存在哪里?
是不是也象x86那样有个类似tss的东东保存内核栈地址

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
2 [报告]
发表于 2016-08-16 09:19 |只看该作者
这种问题看看 entry.S 就可以自己得出答案了
值得注意的是, arm64 架构可以配置为不同的 EL 使用各自的栈。
所以 kernel 完全可以不保存栈,切入内核直接使用内核的 sp_el1,切入用户使用 sp_el0.

论坛徽章:
0
3 [报告]
发表于 2016-08-16 11:10 |只看该作者
arm使用sp保存堆栈指针,arm64支持4种异常模式el0~el3,el0对应用户模式,el1对应内核模式,每个异常模式可以有自己的sp: sp_el0~sp_el3;
也可以设置PSTATE.SP位,所有异常模式统一使用sp_el0;

补充个__switch_data代码,启动过程sp指向init_task栈地址:
__switch_data:
    .quad   __mmap_switched
    .quad   __bss_start         // x6
    .quad   __bss_stop          // x7
    ... ...
    .quad   init_thread_union + THREAD_START_SP // sp

__mmap_switched:
    // clear bss
    ldr x16, [x3]
    mov sp, x16
    ... ...
    b   start_kernel
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP