mirror of
https://github.com/0xAX/linux-insides.git
synced 2025-01-05 05:10:55 +00:00
Few Typos
This commit is contained in:
parent
4a827f63bc
commit
675751765b
@ -86,7 +86,7 @@ The `nm` util allows us to see the list of symbols from the given object file. I
|
|||||||
* `main` - the main function;
|
* `main` - the main function;
|
||||||
* `printf` - the function from the [glibc](https://en.wikipedia.org/wiki/GNU_C_Library) library. `main.c` does not know anything about it for now either.
|
* `printf` - the function from the [glibc](https://en.wikipedia.org/wiki/GNU_C_Library) library. `main.c` does not know anything about it for now either.
|
||||||
|
|
||||||
What can we understand from the output of `nm` so far? The `main.o` object file contains the local symbol `main` at address `0000000000000000` (it will be filled with correct address after is is linked), and two unresolved symbols. We can see all of this information in the disassembly output of the `main.o` object file:
|
What can we understand from the output of `nm` so far? The `main.o` object file contains the local symbol `main` at address `0000000000000000` (it will be filled with the correct address after it is linked), and two unresolved symbols. We can see all of this information in the disassembly output of the `main.o` object file:
|
||||||
|
|
||||||
```
|
```
|
||||||
$ objdump -S main.o
|
$ objdump -S main.o
|
||||||
@ -140,7 +140,7 @@ Relocation is the process of connecting symbolic references with symbolic defini
|
|||||||
19: 89 c6 mov %eax,%esi
|
19: 89 c6 mov %eax,%esi
|
||||||
```
|
```
|
||||||
|
|
||||||
Note the `e8 00 00 00 00` on the first line. The `e8` is the [opcode](https://en.wikipedia.org/wiki/Opcode) of the `call`, and the remainder of the line is a relative offset. So the `e8 00 00 00 00` contains a one-byte operation code followed by a four-byte address. Note that the `00 00 00 00` is 4-bytes. Why only 4-bytes if an address can be 8-bytes in a `x86_64` (64-bit) machine? Actually we compiled the `main.c` source code file with the `-mcmodel=small`! From the `gcc` man page:
|
Note the `e8 00 00 00 00` on the first line. The `e8` is the [opcode](https://en.wikipedia.org/wiki/Opcode) of the `call`, and the remainder of the line is a relative offset. So the `e8 00 00 00 00` contains a one-byte operation code followed by a four-byte address. Note that the `00 00 00 00` is 4-bytes. Why only 4-bytes if an address can be 8-bytes in a `x86_64` (64-bit) machine? Actually, we compiled the `main.c` source code file with the `-mcmodel=small`! From the `gcc` man page:
|
||||||
|
|
||||||
```
|
```
|
||||||
-mcmodel=small
|
-mcmodel=small
|
||||||
@ -148,7 +148,7 @@ Note the `e8 00 00 00 00` on the first line. The `e8` is the [opcode](https://en
|
|||||||
Generate code for the small code model: the program and its symbols must be linked in the lower 2 GB of the address space. Pointers are 64 bits. Programs can be statically or dynamically linked. This is the default code model.
|
Generate code for the small code model: the program and its symbols must be linked in the lower 2 GB of the address space. Pointers are 64 bits. Programs can be statically or dynamically linked. This is the default code model.
|
||||||
```
|
```
|
||||||
|
|
||||||
Of course we didn't pass this option to the `gcc` when we compiled the `main.c`, but it is the default. We know that our program will be linked in the lower 2 GB of the address space from the `gcc` manual extract above. Four bytes is therefore enough for this. So we have opcode of the `call` instruction and an unknown address. When we compile `main.c` with all its dependencies to an executable file, and then look at the factorial call we see:
|
Of course we didn't pass this option to the `gcc` when we compiled the `main.c`, but it is the default. We know that our program will be linked in the lower 2 GB of the address space from the `gcc` manual extract above. Four bytes is therefore enough for this. So we have the opcode of the `call` instruction and an unknown address. When we compile `main.c` with all its dependencies to an executable file, and then look at the factorial call, we see:
|
||||||
|
|
||||||
```
|
```
|
||||||
$ gcc main.c lib.c -o factorial | objdump -S factorial | grep factorial
|
$ gcc main.c lib.c -o factorial | objdump -S factorial | grep factorial
|
||||||
@ -201,7 +201,7 @@ So we add `0x18` and `0x5` to the address of the `call` instruction. The offset
|
|||||||
|
|
||||||
What we have seen in this section is the `relocation` process. This process assigns load addresses to the various parts of the program, adjusting the code and data in the program to reflect the assigned addresses.
|
What we have seen in this section is the `relocation` process. This process assigns load addresses to the various parts of the program, adjusting the code and data in the program to reflect the assigned addresses.
|
||||||
|
|
||||||
Ok, now that we know a little about linkers and relocation it is time to learn more about linkers by linking our object files.
|
Ok, now that we know a little about linkers and relocation, it is time to learn more about linkers by linking our object files.
|
||||||
|
|
||||||
GNU linker
|
GNU linker
|
||||||
-----------------
|
-----------------
|
||||||
|
Loading…
Reference in New Issue
Block a user