当前位置:网站首页>Kernel link script parsing
Kernel link script parsing
2022-07-06 17:39:00 【Wzzzzzzx】
The original text can be found in Kernel link script parsing Check out , Subsequent updates will be updated to Personal blog
The specific code can be seen in Warehouse , Here, choose a few to talk about .
Output architecture
OUTPUT_ARCH This command is used to specify the system architecture of the output file , What we use here is riscv.
entry point
ENTRY Defines the entry point of the program ,xv6 The default entry point for is _entry. The entry point code is entry.S Inside .
Position counter
Get into SECTIONS after , The default initial address of the current program is 0x0. Here with Linux The file system of , use “.” To represent the current address . The name of this symbol is Position counter (location counter), Indicates the following paragraph / The memory address corresponding to the variable . This means that if you give it directly “.” assignment , It is equivalent to switching the working directory , The relative position of subsequent segments will change .
Here is a simple example
SECTIONS
{
. = 0x10000;
.text : { *(.text) }
. = 0x8000000;
.data : { *(.data) }
.bss : { *(.bss) }
}
Get into SECTIONS after , The position counter will be set to 0x10000, So the linker will .text The address of is set to 0x10000. complete .text After setting , The position counter will be changed to 0x8000000,.data The address of will be set to 0x8000000. turn .bss When , It will follow .data paragraph , At this time, the value of the position counter is 0x8000000 add .data The size of the segment .
xv6 Initial address setting
As soon as you enter SECTIONS The script will set the current initial path to 0x80000000. The teacher said in class that this address is qemu Approved address , The first instruction that must be placed is it . Book 2.6 section The saying is 0x0 To 0x80000000 This address is used to place IO equipment , So the address of the first instruction must be 0x80000000.
Segment content parsing
.text : {
*(.text .text.*)
. = ALIGN(0x1000);
_trampoline = .;
*(trampsec)
. = ALIGN(0x1000);
ASSERT(. - _trampoline == 0x1000, "error: trampoline larger than one page");
PROVIDE(etext = .);
}
The segment settings of the kernel are similar , So look at one .text That's all right. .
.text The first expression of the segment *(.text .text.*), Among them * The wildcard . It represents .text and .text.* Segments are placed in the output file .text In the paragraph .
Then there are orders ALIGN(exp), This command will return the position counter to align to the next exp Address of boundary , It does not modify the value of the position counter .
PROVIDE This order is similar to GCC Medium attribute((weak)). Now we only need to understand it simply as defining a symbol .
remainder _trampoline and trampsec The chapter of the page table will cover , Then you can go and understand .
Reference resources
边栏推荐
- Akamai talking about risk control principles and Solutions
- Re signal writeup
- About selenium starting Chrome browser flash back
- 06 products and promotion developed by individuals - code statistical tools
- PySpark算子处理空间数据全解析(5): 如何在PySpark里面使用空间运算接口
- 全网最全tcpdump和Wireshark抓包实践
- C WinForm series button easy to use
- JVM 垃圾回收器之Serial SerialOld ParNew
- 02个人研发的产品及推广-短信平台
- Huawei certified cloud computing hica
猜你喜欢

Interpretation of Flink source code (II): Interpretation of jobgraph source code

The problem of "syntax error" when uipath executes insert statement is solved

The NTFS format converter (convert.exe) is missing from the current system

List集合数据移除(List.subList.clear)

Vscode matches and replaces the brackets

连接局域网MySql

About selenium starting Chrome browser flash back
![[reverse intermediate] eager to try](/img/5a/568533850ddfd1c41117da0df50e20.png)
[reverse intermediate] eager to try

PySpark算子处理空间数据全解析(4): 先说说空间运算

C#版Selenium操作Chrome全屏模式显示(F11)
随机推荐
C version selenium operation chrome full screen mode display (F11)
Flink analysis (II): analysis of backpressure mechanism
EasyRE WriteUp
Program counter of JVM runtime data area
Pyspark operator processing spatial data full parsing (4): let's talk about spatial operations first
【逆向中级】跃跃欲试
List集合数据移除(List.subList.clear)
Flink parsing (IV): recovery mechanism
远程代码执行渗透测试——B模块测试
03个人研发的产品及推广-计划服务配置器V3.0
Remote code execution penetration test - B module test
Learn the wisdom of investment Masters
Redis快速入门
Example of batch update statement combining update and inner join in SQL Server
Development and practice of lightweight planning service tools
Junit单元测试
04 products and promotion developed by individuals - data push tool
DataGridView scroll bar positioning in C WinForm
JVM garbage collector part 1
Wordcloud colormap color set and custom colors