当前位置:网站首页>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
边栏推荐
- Golang decorator mode and its use in NSQ
- Preventing/catching “IllegalArgumentException: parameter must be a descendant of this view” error
- What is the difference between 14Cr1MoR container plate and 14Cr1MoR (H)? Chemical composition and performance analysis of 14Cr1MoR
- Data driving of appium framework for mobile terminal automated testing
- MySQL user management
- Threejs Part 2: vertex concept, geometry structure
- Aike AI frontier promotion (7.3)
- Daily code 300 lines learning notes day 10
- Cocos Creator 2. X automatic packaging (build + compile)
- How programming apes grow rapidly
猜你喜欢

Add color to the interface automation test framework and realize the enterprise wechat test report

What is the pledge pool and how to pledge?

IDEA-配置插件

斑马识别成狗,AI犯错的原因被斯坦福找到了

拼夕夕二面:说说布隆过滤器与布谷鸟过滤器?应用场景?我懵了。。

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

NSQ source code installation and operation process

Le zèbre a été identifié comme un chien, et la cause de l'erreur d'AI a été trouvée par Stanford

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

关于学习Qt编程的好书精品推荐
随机推荐
[combinatorics] polynomial theorem (polynomial theorem | polynomial theorem proof | polynomial theorem inference 1 item number is the number of non negative integer solutions | polynomial theorem infe
中南大学|通过探索理解: 发现具有深度强化学习的可解释特征
Record windows10 installation tensorflow-gpu2.4.0
Two sides of the evening: tell me about the bloom filter and cuckoo filter? Application scenario? I'm confused..
美团一面:为什么线程崩溃崩溃不会导致 JVM 崩溃
Idea configuration plug-in
Register in PHP_ Globals parameter settings
Client does not support authentication protocol requested by server; consider upgrading MySQL client
MySQL Basics
线程池执行定时任务
Svn usage specification
Golang 匿名函数使用
What material is sa537cl1? Sa537cl1 corresponds to the national standard material
[combinatorics] recursive equation (outline of recursive equation content | definition of recursive equation | example description of recursive equation | Fibonacci Series)
斑马识别成狗,AI犯错的原因被斯坦福找到了
【剑指 Offer 】57 - II. 和为s的连续正数序列
PHP CI(CodeIgniter)log级别设置
Détails du contrôle de la congestion TCP | 3. Espace de conception
NSQ source code installation and operation process
Pytorch 1.12 was released, officially supporting Apple M1 chip GPU acceleration and repairing many bugs