当前位置:网站首页>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
边栏推荐
- Learn the wisdom of investment Masters
- Total / statistics function of MySQL
- 05 personal R & D products and promotion - data synchronization tool
- Huawei certified cloud computing hica
- 基于Infragistics.Document.Excel导出表格的类
- About selenium starting Chrome browser flash back
- 【逆向中级】跃跃欲试
- [CISCN 2021 华南赛区]rsa Writeup
- Wu Jun's trilogy experience (VII) the essence of Commerce
- Uipath browser performs actions in the new tab
猜你喜欢

Program counter of JVM runtime data area

CTF reverse entry question - dice

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

当前系统缺少NTFS格式转换器(convert.exe)

Selenium test of automatic answer runs directly in the browser, just like real users.
![[reverse] repair IAT and close ASLR after shelling](/img/83/1c77e24e9430fb7ea775169a794a28.png)
[reverse] repair IAT and close ASLR after shelling

07 personal R & D products and promotion - human resources information management system

February database ranking: how long can Oracle remain the first?

Display picture of DataGridView cell in C WinForm

Development and practice of lightweight planning service tools
随机推荐
Solrcloud related commands
C # nanoframework lighting and key esp32
February database ranking: how long can Oracle remain the first?
华为认证云计算HICA
02个人研发的产品及推广-短信平台
Distributed (consistency protocol) leader election (dotnext.net.cluster implements raft election)
[CISCN 2021 华南赛区]rsa Writeup
【MySQL入门】第三话 · MySQL中常见的数据类型
PySpark算子处理空间数据全解析(4): 先说说空间运算
About selenium starting Chrome browser flash back
Wu Jun's trilogy insight (V) refusing fake workers
【MMdetection】一文解决安装问题
C version selenium operation chrome full screen mode display (F11)
Interpretation of Flink source code (II): Interpretation of jobgraph source code
C# NanoFramework 点灯和按键 之 ESP32
PostgreSQL 14.2, 13.6, 12.10, 11.15 and 10.20 releases
Automatic operation and maintenance sharp weapon ansible Playbook
JVM 垃圾回收器之Garbage First
Deploy flask project based on LNMP
Grafana 9 is officially released, which is easier to use and more cool!