シェルコードの最も単純なアセンブリを書いているときに、このコードを書きました
BITS 64
global _start
section .data
_start:
;ssize_t write(int fd, const void *buf, size_t count);
;rax = 1
jmp poziv
vracajse:
xor rsi,rsi
pop rsi
xor rax,rax
mov al,1 ; were calling write
;The parameters are in rdi, rsi, rdx, r10, r8, r9. in that order
xor rdi,rdi ;
xor rcx,rcx ; need low 8 bytes dont want null in machine code
mov cl,1
mov edi,ecx ; edi =1 writing to stdout
xor rdx,rdx
mov dl,15 ; were writing 15 chars
syscall
poziv:
call vracajse
poruka:
.ascii "Pozdrav svete!\n"
次のエラーが発生しました
writing_2nd_try.nasm:28: error: parser: instruction expected
私のコード poruka: .ascii "Some string" は有効な命令 (ラベルとメッセージ) ではありませんが、それを db として記述すれば問題ありません。
(私にとって興味深いのは、 section .data の代わりに .section data を書き込むと、次のエラーが発生することです
writing_2nd_try.nasm:3: error: attempt to define a local label before any non-local labels
writing_2nd_try.nasm:3: error: parser: instruction expected
)
私はこれらすべてに少し慣れていませんが、自分が何をしているのか知っていると思いました。