当前位置:网站首页>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 装饰器模式以及在NSQ中的使用
- Add color to the interface automation test framework and realize the enterprise wechat test report
- PHP CI (CodeIgniter) log level setting
- 2022 love analysis · panoramic report of digital manufacturers of state-owned enterprises
- QT serial port UI design and solution to display Chinese garbled code
- JSON 与 BSON 区别
- MySQL user management
- CC2530 common registers for port initialization
- Hong Kong Polytechnic University | data efficient reinforcement learning and adaptive optimal perimeter control of network traffic dynamics
- CC2530 common registers for timer 1
猜你喜欢
ThreeJS 第二篇:顶点概念、几何体结构
2022 love analysis · panoramic report of digital manufacturers of state-owned enterprises
斑馬識別成狗,AI犯錯的原因被斯坦福找到了
[combinatorics] non descending path problem (number of non descending paths with constraints)
Web crawler knowledge day03
Threejs Part 2: vertex concept, geometry structure
(补)双指针专题
PyTorch 1.12发布,正式支持苹果M1芯片GPU加速,修复众多Bug
Netease UI automation test exploration: airtest+poco
什么是质押池,如何进行质押呢?
随机推荐
Network security web penetration technology
Learn from me about the enterprise flutter project: simplified framework demo reference
Golang 匿名函数使用
How to set up SVN server on this machine
Custom plug-in construction and use of QT plug-in
Unreal_ Datatable implements ID self increment and sets rowname
Svn usage specification
Characteristic polynomial and constant coefficient homogeneous linear recurrence
Develop team OKR in the way of "crowdfunding"
Le zèbre a été identifié comme un chien, et la cause de l'erreur d'AI a été trouvée par Stanford
爱可可AI前沿推介(7.3)
What material is sa537cl2? Analysis of mechanical properties of American standard container plate
[combinatorics] recursive equation (outline of recursive equation content | definition of recursive equation | example description of recursive equation | Fibonacci Series)
JSON 与 BSON 区别
utfwry. Dat PHP, about ThinkPHP's method of IP location using utfwry address Library
Cocos Creator 2. X automatic packaging (build + compile)
2022爱分析· 国央企数字化厂商全景报告
Recommendation of good books on learning QT programming
Thread pool executes scheduled tasks
One article takes you to understand machine learning