逆向-beginners之字符串数组

#include <stdio.h>

const char * month[] = {

"January",

"February",

"March",

"April",

"May",

"June",

"July",

"August",

"September",

"October",

"November",

"December"

};

const char * get_month(int m)

{

return month[m];

}

void main()

{

printf("month=%s\n", get_month(9)); // month=October

}

#if 0

/*

* intel

*/

0000000000001149 <get_month>:

1149: f3 0f 1e fa endbr64

114d: 55 push %rbp

114e: 48 89 e5 mov %rsp,%rbp

1151: 89 7d fc mov %edi,-0x4(%rbp)

1154: 8b 45 fc mov -0x4(%rbp),%eax

1157: 48 98 cltq

1159: 48 8d 14 c5 00 00 00 lea 0x0(,%rax,8),%rdx // rdx=rax*8+0--> 9*8, 因是64bit,所以是8.

1160: 00

1161: 48 8d 05 b8 2e 00 00 lea 0x2eb8(%rip),%rax # 4020 <month> // 指向数据区

1168: 48 8b 04 02 mov (%rdx,%rax,1),%rax

116c: 5d pop %rbp

116d: c3 retq

000000000000116e <main>:

116e: f3 0f 1e fa endbr64

1172: 55 push %rbp

1173: 48 89 e5 mov %rsp,%rbp

1176: bf 09 00 00 00 mov $0x9,%edi

117b: e8 c9 ff ff ff callq 1149 <get_month>

1180: 48 89 c6 mov %rax,%rsi

1183: 48 8d 3d d0 0e 00 00 lea 0xed0(%rip),%rdi # 205a <_IO_stdin_used+0x5a>

118a: b8 00 00 00 00 mov $0x0,%eax

118f: e8 bc fe ff ff callq 1050 <printf@plt>

1194: 90 nop

1195: 5d pop %rbp

1196: c3 retq

1197: 66 0f 1f 84 00 00 00 nopw 0x0(%rax,%rax,1)

119e: 00 00

/*

* arm

*/

000000000040055c <get_month>:

40055c: d10043ff sub sp, sp, #0x10

400560: b9000fe0 str w0, [sp, #12]

400564: b0000080 adrp x0, 411000 <__libc_start_main@GLIBC_2.17>

400568: 9100c000 add x0, x0, #0x30 // 指向数据区

40056c: b9800fe1 ldrsw x1, [sp, #12]

400570: f8617800 ldr x0, [x0, x1, lsl #3]

400574: 910043ff add sp, sp, #0x10

400578: d65f03c0 ret

000000000040057c <main>:

40057c: a9bf7bfd stp x29, x30, [sp, #-16]!

400580: 910003fd mov x29, sp

400584: 52800120 mov w0, #0x9 // #9

400588: 97fffff5 bl 40055c <get_month>

40058c: aa0003e1 mov x1, x0

400590: 90000000 adrp x0, 400000 <_init-0x3e8>

400594: 911b6000 add x0, x0, #0x6d8

400598: 97ffffae bl 400450 <printf@plt>

40059c: d503201f nop

4005a0: a8c17bfd ldp x29, x30, [sp], #16

4005a4: d65f03c0 ret

#endif

相关推荐
Gofarlic_OMS12 小时前
UG/NX许可证管理高频技术问题解答汇编
java·大数据·运维·服务器·汇编·人工智能
iCxhust12 小时前
如何在汇编中修改CS:IP
汇编·单片机·嵌入式硬件·51单片机·微机原理
枷锁—sha1 天前
【CTFshow-pwn系列】03_栈溢出【pwn 073】详解:静态编译下的自动化 ROP 链构建
网络·汇编·笔记·安全·网络安全·自动化
wechatbot8883 天前
极客互动企业微信聚合聊天与接口能力全景展示
汇编·微信·企业微信·ipad
枷锁—sha3 天前
【CTFshow-pwn系列】03_栈溢出【pwn 072】详解:无字符串环境下的多级 Ret2Syscall 与 BSS 段注入
服务器·网络·汇编·笔记·安全·网络安全
iCxhust5 天前
8088汇编测试程序 (MASM/TASM) — 显示 “HELLO 8088!“ + “LCD1602 OK“
汇编·单片机·嵌入式硬件·51单片机·微机原理
lhbian6 天前
AI编程革命:Codex让脚本开发提速10倍
开发语言·汇编·jvm·c#
wechatbot8887 天前
企业微信全场景消息发送接口开发实现及接口调用
java·汇编·微信·企业微信
wechatbot8888 天前
企业微信 iPad 协议接口全功能开发实战
汇编·人工智能·ios·微信·企业微信·ipad
techdashen8 天前
Rust 1.88 终于稳定了裸函数:写汇编不再需要那堆样板代码
汇编·rust