我正在尝试在 ArchLinux 下的第一个 Raspberry Pi 上执行存储在数组中的机器代码。我已经在 x86 下完成了它,但是在 ARMv6 下我无法理解我做错了什么。问题是数组中的代码无关紧要,执行第一条指令后它总是会崩溃。在 gcc 5.2.0 下禁用 Thumb interworking 编译代码。
这是我用于测试的代码:
#include <stdio.h>
char shellcode[] = {
0x04, 0xb0, 0x2d, 0xe5, // push {r11}
0x00, 0xb0, 0x8d, 0xe2, // add r11, sp, #0
0x00, 0x00, 0xa0, 0xe1, // nop
0x00, 0x00, 0xa0, 0xe1, // nop
0x00, 0x00, 0xa0, 0xe1, // nop
0x00, 0xd0, 0x4b, 0xe2, // sub sp, r11, #0
0x04, 0xb0, 0x9d, 0xe4, // pop {r11}
0x1e, 0xff, 0x2f, 0xe1 // bx lr
};
void shellcode2() {
asm("mov r0, r0");
asm("mov r0, r0");
}
typedef void (*entry_t)();
int main() {
entry_t entry = (entry_t)(shellcode);
entry();
return 0;
}
机器代码取自shellcode2
函数反汇编,我不知道这样做是否正确,但问题是即使 shellcode 中的第一条指令是 nop - 它也会崩溃。
Program received signal SIGSEGV, Segmentation fault.
0x00020704 in shellcode ()
(gdb) disas /r
Dump of assembler code for function shellcode:
=> 0x00020704 <+0>: 04 b0 2d e5 push {r11} ; (str r11, [sp, #-4]!)
0x00020708 <+4>: 00 b0 8d e2 add r11, sp, #0
0x0002070c <+8>: 00 00 a0 e1 nop ; (mov r0, r0)
0x00020710 <+12>: 00 00 a0 e1 nop ; (mov r0, r0)
0x00020714 <+16>: 00 00 a0 e1 nop ; (mov r0, r0)
0x00020718 <+20>: 00 d0 4b e2 sub sp, r11, #0
0x0002071c <+24>: 04 b0 9d e4 pop {r11} ; (ldr r11, [sp], #4)
0x00020720 <+28>: 1e ff 2f e1 bx lr
End of assembler dump.
我错过了什么或者只是在 ARMv6 上做错了吗?如果有人能指出我正确的方向,我将不胜感激。
提前致谢。