当前位置:网站首页>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
边栏推荐
- 学 SQL 必须了解的 10 个高级概念
- 【逆向】脱壳后修复IAT并关闭ASLR
- CTF reverse entry question - dice
- Connect to LAN MySQL
- [ASM] introduction and use of bytecode operation classwriter class
- MySQL报错解决
- Pyspark operator processing spatial data full parsing (5): how to use spatial operation interface in pyspark
- Interpretation of Flink source code (II): Interpretation of jobgraph source code
- connection reset by peer
- C# WinForm中DataGridView单元格显示图片
猜你喜欢

PySpark算子处理空间数据全解析(5): 如何在PySpark里面使用空间运算接口

EasyRE WriteUp

Final review of information and network security (based on the key points given by the teacher)
![[reverse primary] Unique](/img/80/9fcef27863facc9066e48f221c6686.png)
[reverse primary] Unique

Integrated development management platform

复盘网鼎杯Re-Signal Writeup

Grafana 9 is officially released, which is easier to use and more cool!

【MySQL入门】第四话 · 和kiko一起探索MySQL中的运算符

JUnit unit test

Application service configurator (regular, database backup, file backup, remote backup)
随机推荐
Xin'an Second Edition; Chapter 11 learning notes on the principle and application of network physical isolation technology
自动答题 之 Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。
Grafana 9 is officially released, which is easier to use and more cool!
Wu Jun's trilogy insight (V) refusing fake workers
【逆向中级】跃跃欲试
虚拟机启动提示Probing EDD (edd=off to disable)错误
Akamai anti confusion
Akamai浅谈风控原理与解决方案
学 SQL 必须了解的 10 个高级概念
07 personal R & D products and promotion - human resources information management system
遠程代碼執行滲透測試——B模塊測試
2021-03-22 "display login screen during recovery" can't be canceled. The appearance of lock screen interface leads to the solution that the remotely connected virtual machine can't work normally
[mmdetection] solves the installation problem
Xin'an Second Edition: Chapter 25 mobile application security requirements analysis and security protection engineering learning notes
应用服务配置器(定时,数据库备份,文件备份,异地备份)
Xin'an Second Edition: Chapter 12 network security audit technology principle and application learning notes
Yarn: unable to load file d:\programfiles\nodejs\yarn PS1, because running scripts is prohibited on this system
Summary of study notes for 2022 soft exam information security engineer preparation
07个人研发的产品及推广-人力资源信息管理系统
【MySQL入门】第四话 · 和kiko一起探索MySQL中的运算符