将语句汇编代码切换为c

时间:2015-10-28 01:39:44

标签: c assembly switch-statement reverse-engineering

我很难将汇编代码中的switch语句反向工程为C程序。

.file 
"switch_prob2-soln.c"
.text
.globl switch_prob
.type switch_prob, @function
switch_prob:
.LFB0:
.cfi_startproc
subq $60, %rsi
cmpq $5, %rsi
ja .L2
jmp *.L7(,%rsi,8)
.section .rodata
.align 8
.align 4
 .L7:
 .quad .L3
 .quad .L2
 .quad .L3
 .quad .L4
 .quad .L5
 .quad .L6
 .text
 .L3:
 leaq 0(,%rdi,8), %rax
 ret
 .L4:
 movq %rdi, %rax
 sarq $3, %rax
 ret
 .L5:
 movq %rdi, %rax
 salq $4, %rax
 subq %rdi, %rax
 movq %rax, %rdi
 .L6:
 imulq %rdi, %rdi
 .L2:
 leaq 75(%rdi), %rax
 ret
 .cfi_endproc
 .LFE0:
 .size switch_prob, .-switch_prob
  .ident "GCC: (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3"
 .section .note.GNU-stack,"",@progbits

这是我的基本C程序:

long switch_prob(long x, long n)
{
    long result = x;
    switch(n) {

 }
 return result;
 }

我要求的所有内容都是有用的建议。我知道我可以用-S或-O1编译。谢谢你的时间。

这是我的c代码在汇编中显示的内容 enter image description here

这是我的c代码

enter image description here

如果有人可以帮助我,那将是非常棒的,我试图让四边形显示 3 2 3 4 五 6

1 个答案:

答案 0 :(得分:1)

目前还不清楚你遇到了什么问题。我希望你知道它使用跳转表。

很明显,你有6个案例和一个默认案例,有一些共享代码。说明很简单,我相信你没有问题。

至于switch表达式本身,它只是由一条指令完成的一个简单的转换。

我尽量不放弃解决方案,毕竟你要求建议开始。你还需要更多提示吗?