小编Aug*_*923的帖子

ARM64 缓冲区溢出 - 无法覆盖 $pc

这是源代码。

#include <stdlib.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>

void win()
{
  printf("code flow successfully changed\n");
}

int main(int argc, char **argv)
{
  char buffer[64];

  gets(buffer);
}
Run Code Online (Sandbox Code Playgroud)

main 的汇编代码

0x0000000000400604 <+0>:    stp x29, x30, [sp, #-96]!
0x0000000000400608 <+4>:    mov x29, sp
0x000000000040060c <+8>:    str w0, [sp, #28]
0x0000000000400610 <+12>:   str x1, [sp, #16]
0x0000000000400614 <+16>:   add x0, sp, #0x20
0x0000000000400618 <+20>:   bl  0x4004d0 <gets@plt>
0x000000000040061c <+24>:   mov w0, #0x0                    // #0
0x0000000000400620 <+28>:   ldp x29, x30, [sp], #96
0x0000000000400624 <+32>: …
Run Code Online (Sandbox Code Playgroud)

gdb arm buffer-overflow arm64

4
推荐指数
1
解决办法
46
查看次数

标签 统计

arm ×1

arm64 ×1

buffer-overflow ×1

gdb ×1