全面解析Linux 内核 3.10.x - 内核入口函数__kernel_entry

本文详细分析了Linux 3.10.x内核的入口函数__kernel_entry在head.S中的实现,讨论了全局指针寄存器gp、栈指针sp的角色,以及ehb指令的重要性。此外,还介绍了0号进程的来源、作用,以及内核栈和thread_info结构的关系。内容涉及进程切换、页表配置对线程信息的影响和内存布局。
摘要由CSDN通过智能技术生成

From: 全面解析Linux 内核 3.10.x - 本文章完全基于MIPS架构

找对了入口,才有可能找对出口 – 佚名

在前面几节内容中我简单将Linux ,以及Linux Kernel的概念做了总结,然后又将编译以及内核镜像也做了也总结! 从本节内容开始,我将真正的进入到内核代码中去!加油吧,Keven!
从上一节中我已经知道了vmlinux.lds链接文件中指定了内核的入口函数kernel_entry,此函数被定义在head.S文件中!,请跟着我去看看此函数到底做了什么!

1、head.S - kernel_entry

    NESTED(kernel_entry, 16, sp)            # kernel entry point

    kernel_entry_setup          # cpu specific setup

    setup_c0_status_pri

    /* We might not get launched at the address the kernel is linked to,
    so we jump there.  */
    PTR_LA  t0, 0f      #Loading 数字标号0中的地址
    jr  t0
0:
    PTR_LA      t0, __bss_start             #Loading __bss_start(0xffffffff80dc0000) 到 t0
    LONG_S      zero, (t0)                  #对0xffffffff80dc0000这个地址内容清零(清除bss)
    PTR_LA      t1, __bss_stop - LONGSIZE   #Loading __bss_stop(0xffffffff80dc0000 + 0x00cc2ac0 - unsinged(8)<0x40> 8*8) = 
                                            0xffffffff80106ae8 此地址就是kernel_entry函数地址 到 t1
1:
    PTR_ADDIU   t0, LONGSIZE                #t0 = t0 + LONGSIZE (64位操作) = 0xffffffff80dc0000 + 0x40
    LONG_S      zero, (t0)                  #清零地址内容
    bne     t0, t1, 1b                      #判断 t0 是否等于 t1,如果不等于到当前位置前面的第一个标号1,循环加到等于后,执行下面指令

                                # firmware arguments
    LONG_S      a0, fw_arg0     #子程序的前4个参数存到a0~a3中
    LONG_S      a1, fw_arg1
    LONG_S      a2, fw_arg2
    LONG_S      a3, fw_arg3

    MTC0        zero, CP0_CONTEXT           # clear context register 清除 寄存器CP0的$4,这个寄存器保存的是页表的起始地址 
    PTR_LA      $28, init_thread_union 		#将init_thread_union地址Loading $28中(Ps.$28是全局指针寄存器),关于全局指针见 Note 1:
    /* Set the SP after an empty pt_regs.  */
    PTR_LI      sp, _THREAD
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值