为什么我不能在linux中用write方法调用来实现书写?

时间:2019-10-04 12:46:53

标签: assembly x86 fasm

第一件事:

format ELF

section '.text' executable

public _start
_start:
    ; OPENNIN FILE DESCRIPTOR FOR A PATH -->
    mov ebx, logfile
    mov eax, 5
    mov ecx, 64
    mov edx, 777o
    int 0x80

    ; JUNT `STRLEN` -->
    mov edi, ebx
    mov ebx, eax
    xor ecx, ecx
    not ecx
    xor eax, eax
    cld
    repne scasb
    not ecx

    ; WRITTING INTO THE FD'S FILE -->
    mov edx, ecx
    sub edi, edx
    mov ecx, edi
    lea edx, [edx]
    mov eax, 4
    int 0x80

    ; CLOSE DESCRIPTOR -->
    mov eax, 6
    int 0x80 

    ; EXIT -->
    mov eax, 1
    xor ebx, ebx
    int 0x80

section '.data' writeable

logfile db "#!@#$%$:",0

以上是我写到fasm中的代码。 在编译和运行这段代码时(这部分进行得很好,所以我将不再赘述。),我遇到了-> 我的文件已创建(并且命名为#!@#$%$: ...),但未写入任何文件。

我不明白为什么未将任何内容写入新文件的原因! 寄存器状态应如下所示: https://syscalls.kernelgrok.com/ 文件关闭正常。

发生这种情况的原因可能是什么?

1 个答案:

答案 0 :(得分:2)

使用strace(1)会立即告诉您原因:

$ strace ./test
execve("./test", ["./test"], 0x7ffef0f1b5f0 /* 72 vars */) = 0
strace: [ Process PID=32288 runs in 32 bit mode. ]
open("#!@#$%$:", O_RDONLY|O_CREAT, 0777) = 3
write(3, "#!@#$%$:\0", 9)               = -1 EBADF (Bad file descriptor)
close(3)                                = 0
exit(0)                                 = ?
+++ exited with 0 +++

请注意O_RDONLY|O_CREAT:您已将文件打开为只读状态,因此后续的write失败。