gpt4 book ai didi

c - 如何从程序集 x86 中读取文件

转载 作者:行者123 更新时间:2023-11-30 17:01:25 24 4
gpt4 key购买 nike

我有一段 C 语言代码需要转换为汇编 x86。这是c代码:

int rb (FILE *f){
int s;
char c;
s = fr(&c, 1, 1, f);
if (s <= 0) return -1;
return (int)c;
}

到目前为止,我得到了这段汇编代码,它给我带来了段错误:

rb:
pushl %ebp
movl %esp,%ebp
pushl 8(%ebp)
pushl $1
pushl $1
leal 12(%ebp), %eax
pushl %eax
call fr
jz ng
jns ex
ng:
pushl $1
negl %eax
ex:
popl %ebp
ret

谁能帮我解决这个问题吗? :)

最佳答案

Gcc 和 Clang 都可以为您生成汇编。它可能并不总是很容易阅读,但这是如何做到的:

使您想要检查的代码片段可以无错误地编译。请注意,我已经更改了您的示例,以将指向整数的指针作为参数,因为在您的示例中,您在堆栈上声明了一个 char,然后返回它,即未定义的 Bahaviour。

创建一个名为 foo.c 的文件,其中包含以下内容:

#include <stdio.h>
extern size_t fr(void *restrict ptr, size_t size, size_t nitems, FILE *restrict stream);
int rb (FILE *f, int *c){
int s;
s = fr(c, 1, 1, f);
if (s <= 0) return -1;
return *c;
}

使用 S 标志将其编译为 gcc ie

gcc-5 -S -O0 -Wall -pedantic -std=c11 foo.c

打开以下文件foo.s

.text
.globl _rb
_rb:
LFB1:
pushq %rbp
LCFI0:
movq %rsp, %rbp
LCFI1:
subq $32, %rsp
movq %rdi, -24(%rbp)
movq %rsi, -32(%rbp)
movq -24(%rbp), %rdx
movq -32(%rbp), %rax
movq %rdx, %rcx
movl $1, %edx
movl $1, %esi
movq %rax, %rdi
call _fr
movl %eax, -4(%rbp)
cmpl $0, -4(%rbp)
jg L2
movl $-1, %eax
jmp L3
L2:
movq -32(%rbp), %rax
movl (%rax), %eax
L3:
leave
LCFI2:
ret
LFE1:
.section __TEXT,__eh_frame,coalesced,no_toc+strip_static_syms+live_support
....
.... snipped
....

现在您已经有了 x86 上您想要的代码的汇编程序。请注意,您可以使用各种选项来更改输出,特别是优化级别将极大地改变输出。

关于c - 如何从程序集 x86 中读取文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37080656/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com