XV6学习(一) bootloader的实现

bootloader作用

一句话描述: 加载内核到内存,建立内存空间的映射,将系统的控制权交给内核并且运行,PC的BIOS和bootloader分开了(先BIOS后bootloader),嵌入式一般一起集成到了bootloader

组成

XV6上的bootloader分为bootasm.Sbootmain.c

加载流程

bootasm.S

处理器在BIOS运行完成后运行bootasm.S,并且处于实模式(只能访问20位的地址空间1MB),有8个16位的寄存器可用,但是处理器需要发送的是20位的地址,因此地址的计算方式为segment:offset, segment由cs,es,ds,ss四个寄存器提供,bootasm.S的操作如下

.code16                       # Assemble for 16-bit mode
.globl start
start:cli                         # BIOS enabled interrupts; disable# Zero data segment registers DS, ES, and SS.xorw    %ax,%ax             # Set %ax to zeromovw    %ax,%ds             # -> Data Segmentmovw    %ax,%es             # -> Extra Segmentmovw    %ax,%ss             # -> Stack Segment

前面提到的地址计算方式中由于segment<<4 + offset中的segment和offset都是16位的,因此最大值为0xffff0 + 0xffff = 0x10ffef也即21位,因此bootasm.S需要激活第21位的地址线,这是通过IO端口的输出实现的(需要0x64口和0x60为0xd1和0xdf)
相应的代码如下

seta20.1:inb     $0x64,%al               # Wait for not busytestb   $0x2,%aljnz     seta20.1movb    $0xd1,%al               # 0xd1 -> port 0x64outb    %al,$0x64seta20.2:inb     $0x64,%al               # Wait for not busytestb   $0x2,%aljnz     seta20.2movb    $0xdf,%al               # 0xdf -> port 0x60outb    %al,$0x60

在激活了A20之后,需要转入到保护模式,指定临时的GDT代码如下,这里将cr0寄存器的数值或上了CR0_PE,打开了保护模式

lgdt    gdtdesc
movl    %cr0, %eax
orl     $CR0_PE, %eax
movl    %eax, %cr0

之后需要填充cs,寄存器的值,cs寄存器的值无法直接设置,使用ljmp汇编命令设置

ljmp    $(SEG_KCODE<<3), $start32start32:# Set up the protected-mode data segment registersmovw    $(SEG_KDATA<<3), %ax    # Our data segment selectormovw    %ax, %ds                # -> DS: Data Segmentmovw    %ax, %es                # -> ES: Extra Segmentmovw    %ax, %ss                # -> SS: Stack Segmentmovw    $0, %ax                 # Zero segments not ready for usemovw    %ax, %fs                # -> FSmovw    %ax, %gs                # -> GS# SEG_KCODE被定义成1,并且翻译成段选择子的意义之后代表着offset为0,选择gdt中的第一项

最后设置栈顶寄存器的值,这里直接设置成了$start,也即0x7c00(引导器自己的位置,栈向下生长至0x0000,会离引导器越来越远)最后调用bootmain,代码如下

 # Set up the stack pointer and call into C.movl    $start, %espcall    bootmain

bootmain.c

bootmain.c的作用就是从磁盘上加载内核的ELF的前4096个字节并且拷贝到0x10000处,代码如下

void
bootmain(void)
{struct elfhdr *elf;struct proghdr *ph, *eph;void (*entry)(void);uchar* pa;elf = (struct elfhdr*)0x10000;  // scratch space// Read 1st page off diskreadseg((uchar*)elf, 4096, 0);// Is this an ELF executable?if(elf->magic != ELF_MAGIC)return;  // let bootasm.S handle error// Load each program segment (ignores ph flags).ph = (struct proghdr*)((uchar*)elf + elf->phoff);eph = ph + elf->phnum;for(; ph < eph; ph++){pa = (uchar*)ph->paddr;readseg(pa, ph->filesz, ph->off);if(ph->memsz > ph->filesz)stosb(pa + ph->filesz, 0, ph->memsz - ph->filesz);}// Call the entry point from the ELF header.// Does not return!entry = (void(*)(void))(elf->entry);entry();
}

而entry.S的定义如下

entry:# Turn on page size extension for 4Mbyte pagesmovl    %cr4, %eaxorl     $(CR4_PSE), %eaxmovl    %eax, %cr4# Set page directorymovl    $(V2P_WO(entrypgdir)), %eaxmovl    %eax, %cr3# Turn on paging.movl    %cr0, %eaxorl     $(CR0_PG|CR0_WP), %eaxmovl    %eax, %cr0# Set up the stack pointer.movl $(stack + KSTACKSIZE), %esp# Jump to main(), and switch to executing at# high addresses. The indirect call is needed because# the assembler produces a PC-relative instruction# for a direct jump.mov $main, %eaxjmp *%eax

开启了分页并且跳转到了main函数开启了内核的运行

习题

问:基于扇区大小,文中提到的调用 readseg 的作用和 readseg((uchar*)0x100000, 0x1000, 0xb500) 的作用是相同的。实际上,这个草率的实现并不会导致错误。这是为什么呢?

答由于扇区为512字节大小,b500为512的整数倍,会被忽略

问:假设你希望 bootmain() 能把内核加载到 0x200000 而非 0x100000,于是你在 bootmain() 中把每个 ELF 段的 va 都加上了 0x100000。这样做是会导致错误发生的,请说明会发生什么错误。

答:
分页机制尚未被开启。在kernel.ld中指明了内核的paddr是0x00100000,kernel.asm中也有类似的定义,不能简单的这样设置

参考文献

https://th0ar.gitbooks.io/xv6-chinese/content/content/AppendixB.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/865646.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一文搞懂L1-L3业务流程体系分析,价值流、端到端流程、职能流程

今天我们聊聊业务流程体系分析这个话题。 业务流程的概念 业务流程是企业为实现目标而制定的一套系统化的工作方法。它由一系列有序的业务活动组成,按照既定规则将资源(输入)转化为有价值的结果(输出)。 在业务架构分析阶段,业务流程发挥着关键作用: • 明确业务运作的方…

[SSL/TLS/PKI] 基于`Let’s Encrypt`,获取免费SSL证书

缘起:云厂商卖的SSL证书太贵 概述:Let’s Encrypt 支持申请免费SSL证书的CA机构支持提供免费SSL证书的CA机构有:Let’s Encrypt ZeroSSL SSL For Free Cloudflare BuyPass AWS本文我们来试试 Let’s Encrypt 怎么用。https://letsencrypt.org/zh-cn/getting-started/Let’s …

.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservableT 和 IObserverT

在 Rx 中,数据流的生产和消费是通过 观察者模式(Observer Pattern) 实现的。这种模式定义了两种角色: - IObservable.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservable<T> 和 IObserver<T>引言:为什么我们调整了学习顺序? 在上一篇文章…

WebPack站点实战(一)

以下文章来源于一位不愿透露姓名的热心网友 ,作者不愿透露姓名的热心网友 文章配套B站视频,很多话语简略了,建议配着视频看。 地址:https://www.bilibili.com/video/BV13F411P7XB/ 开始之前了,简单过一下下面几个方法加深印象,便于更好理解加载器。也可以直接从webpack标…

CUDA概念

1.1.0f加个f,成单精度计算,不加会默认成double 2.快速指令:__add()加两个下划线 3.CUDA计算能力1.3以上才支持双精度,4.0往后支持双精度浮点计算 单精度浮点型(float )专指占用32位存储空间的单精度(single-precision )值。单精度在一些处理器上比双精度更快而且只占用…

12.09百度机器翻译SDK实验

一、实验要求百度机器翻译SDK实验(2024.11.15日完成) 任务一:下载配置百度翻译Java相关库及环境(占10%)。 任务二:了解百度翻译相关功能并进行总结,包括文本翻译-通用版和文本翻译-词典版(占20%)。 任务三:完成百度翻译相关功能代码并测试调用,要求可以实现…

弹性波动力学笔记(十)罗格里德斯公式推导

在应力计算中大量需要轴旋转公式计算,因此本笔记给出了罗格里德斯轴旋转公式Note: Derivation of the Rodriguez Formula In this Note, we will derive a formula for \(\mathbf{R}(\widehat{\mathbf{n}},\theta)\) . Consider the three dimensional rotation of a vecto…

【Java编程】JDK 源码好用的类方法

Java JDK 提供了丰富的工具类和方法,涵盖了字符串处理、集合操作、日期时间处理、文件操作等多个方面。熟练掌握这些工具类和方法,可以显著提高开发效率和代码质量。如果你有特定的需求或问题,欢迎随时提问

C++中调用C语言代码(extern “C”)

extern "C" 可以使我们在C++程序中调用C语言代码.extern "C"向程序编译器表明这段代码需要用C语言的方式编译。extern "C" { #include <stdio.h> void sayHello() { printf("Hello C\n"); }}int main() { sa…

Tita项目管理软件:管过程,管合同,两手抓

在这个日新月异的商业世界里,项目经理们时常面临重重挑战,而高效的协同作业、严谨的项目合同管理以及精准的回款把控,无疑是决定项目成败的关键要素。正是洞察到了这些需求,Tita项目管理软件应运而生,它以一站式的解决方案,助力项目经理们轻松驾驭项目的每一个环节。 一、…

快消零售的智胜之道:智能AI加速构建员工培训SOP策略

引言 在快节奏的快消零售行业中,员工的高效培训与标准化操作是提升服务质量、增强顾客满意度的关键。然而,传统培训方式往往耗时费力,效果难以保证。随着人工智能技术的不断发展,利用智能AI快速建立员工培训SOP(标准操作程序)已成为众多零售企业的新选择。本文将分享如何…

教育机构的智能跃迁:知识中台如何驱动转型与升级

引言 在数字化转型的浪潮中,教育机构正面临着前所未有的挑战与机遇。传统的教育模式已难以满足当前多元化、个性化的学习需求,而知识中台作为连接数据与业务的关键桥梁,正逐步成为教育机构实现智能转型的重要抓手。本文将探讨教育机构如何借助知识中台,通过智能化手段优化教…