- Mastering Assembly Programming
- Alexey Lyashko
- 215字
- 2021-08-20 10:23:33
The Linux Assembly template (32-bit)
On Linux, although files on disc are divided into sections, executables in memory are divided into code and data segments. The following is our template for the ELF 32-bit executable for Linux:
; File: src/template_lin.asm
; Just as in the Windows template - we tell the assembler which type
; of output we expect.
; In this case it is 32-bit executable ELF
format ELF executable
; Tell the assembler where the entry point is
entry _start
; On *nix based systems, when in memory, the space is arranged into
; segments, rather than in sections, therefore, we define
; two segments:
; Code segment (executable segment)
segment readable executable
; Here is our entry point
_start:
; Set return value to 0
xor ebx, ebx
mov eax, ebx
; Set eax to 1 - 32-bit Linux SYS_exit system call number
inc eax
; Call kernel
int 0x80
; Data segment
segment readable writeable
db 0
; As you see, there is no import/export segment here. The structure
; of an ELF executable/object file will be covered in more detail
; in chapters 8 and 9
As was mentioned in the preceding code, these two templates will be used as a starting point for any code we will write in this book.
推薦閱讀
- LabVIEW程序設計基礎與應用
- C語言程序設計(第2版)
- RTC程序設計:實時音視頻權威指南
- Learn Scala Programming
- Instant QlikView 11 Application Development
- C語言從入門到精通(第4版)
- 面向對象程序設計(Java版)
- Quarkus實踐指南:構建新一代的Kubernetes原生Java微服務
- 算法訓練營:提高篇(全彩版)
- Scala編程實戰(原書第2版)
- C語言程序設計
- Internet of Things with ESP8266
- Python Machine Learning Blueprints:Intuitive data projects you can relate to
- 零基礎學C++(升級版)
- Learning ECMAScript 6