当前位置:网站首页>UCORE overview
UCORE overview
2022-07-03 16:45:00 【Focus on web0 years】
brief introduction
In this paper, the knowledge of the operating system is roughly studied according to the Muke materials
ucore Course documentation
Course address
lab Answer address
Some answers have questions , But it can be used for reference
The first order
CPU Initialization will be carried out after power on , Then read the first instruction in memory . Part of the memory is ROM、 Part of it is RAM. After power failure RAM Information will disappear , however ROM The content is always .
The first instruction to read is CS:IP Address to ( The value should be the default ), Just powered on CPU be in 16 In bit real mode , The addressing space size is 2 Of 20 Power (1MB),CS、IP All are 16 Bit .CS*16+IP(0xFFFF0) Is the address of the first instruction , meanwhile CS:IP To be in 2 Of 20 In the addressing space of the power . The first instruction is at the bottom 1MB In space . This first instruction and its following instructions are BIOS, It should provide some services , then CPU To access disk devices .
BIOS
BIOS Read boot sector from disk (512 byte ) Loader in , Write it to memory 0x7c00, then CS:IP Jump there and execute the loader (bootloader).
Say in detail ,BIOS Only run in real mode , It first checks the hardware , Perform device initialization . When repairing the computer , The display does not work , You can guess that there is a memory problem . because BIOS Check the memory first , It doesn't need to be checked later , Also don't start the system . Then check the inserted U disc 、 Disk or something . The information generated by inspection becomes BIOS data . although ROM The data will not disappear , But because the hardware inserted each time is different , therefore BIOS Will change these data . Finally, read the first sector of our disk .BIOS First read the main boot sector of the disk (512 byte ). Because the information provided by this thing can help us choose which operating system in the boot disk . Select and read the active partition according to the information of the primary boot sector ( Partition boot sector ). First execute the jump instruction of the partition boot sector , Jump to the startup code and start the loader .
Loader
The loader puts the disk's ucore Operating system data and code are loaded into memory , Jump to ucore Initial address . Give control to the operating system .
In detail , The loader will first read the boot configuration information from the file system , Based on this information, decide how to load the kernel , In this place, if we can get an option on the display ( Start menu ), It's good to change the parameters . Finally, skip to the kernel .

Not detailed enough
It's still rough to know these , If you write an actual program , Also based on CPU manual 、BIOS standard ( Where to read the first , Above is 0xFFFF0). So you still need to check a lot of information to write your own operating system .
System startup specification
BIOS
The hard disk partition table of the primary boot sector here has only four partition information , Information of each partition 16 byte (BIOS-MBR).BIOS-GPT Support more than four partitions .PXE It's network startup , Download data from the server to the disk to start , here BIOS There should be network download function ,BIOS It's complicated . What I said earlier is to start on the local disk .
UEFI
Start the operating system consistently on all platforms . Boot any system on the disk . For the sake of safety , Check whether the boot record is credible . Only read the boot record that meets the signature .
Check information
边栏推荐
- [solved] access denied for user 'root' @ 'localhost' (using password: yes)
- 执行脚本不认\r
- Leetcode binary search tree
- NLP四范式:范式一:非神经网络时代的完全监督学习(特征工程);范式二:基于神经网络的完全监督学习(架构工程);范式三:预训练,精调范式(目标工程);范式四:预训练,提示,预测范式(Prompt工程)
- Deep understanding of grouping sets statements in SQL
- Learn from me about the enterprise flutter project: simplified framework demo reference
- 于文文、胡夏等明星带你玩转派对 皮皮APP点燃你的夏日
- Recommendation of good books on learning QT programming
- 【LeetCode】94. Middle order traversal of binary tree
- Le zèbre a été identifié comme un chien, et la cause de l'erreur d'AI a été trouvée par Stanford
猜你喜欢

CC2530 common registers for ADC single channel conversion

QT串口ui设计和解决显示中文乱码

斑馬識別成狗,AI犯錯的原因被斯坦福找到了

跟我学企业级flutter项目:简化框架demo参考

Google Earth engine (GEE) - daymet v4: daily surface weather data set (1000m resolution) including data acquisition methods for each day

What is the difference between 14Cr1MoR container plate and 14Cr1MoR (H)? Chemical composition and performance analysis of 14Cr1MoR

【LeetCode】94. Middle order traversal of binary tree

The word backspace key cannot delete the selected text, so you can only press Delete

NLP four paradigms: paradigm 1: fully supervised learning in the era of non neural networks (Feature Engineering); Paradigm 2: fully supervised learning based on neural network (Architecture Engineeri

Web crawler knowledge day03
随机推荐
(补)双指针专题
What is the material of 13mnnimor? 13mnnimor steel plate for medium and low temperature pressure vessels
Learn from me about the enterprise flutter project: simplified framework demo reference
Mysql database DDL and DML
浅谈拉格朗日插值及其应用
于文文、胡夏等明星带你玩转派对 皮皮APP点燃你的夏日
CC2530 common registers for crystal oscillator settings
Netease UI automation test exploration: airtest+poco
Two sides of the evening: tell me about the bloom filter and cuckoo filter? Application scenario? I'm confused..
Recommendation of good books on learning QT programming
To resist 7-Zip, list "three sins"? Netizen: "is the third key?"
ThreeJS 第二篇:顶点概念、几何体结构
程序猿如何快速成长
[sword finger offer] 58 - I. flip the word order
Client does not support authentication protocol requested by server; consider upgrading MySQL client
执行脚本不认\r
消息队列消息丢失和消息重复发送的处理策略
爱可可AI前沿推介(7.3)
Golang anonymous function use
Unity project optimization case 1