[*] Binary protection state of wpa_supplicant
Full RELRO Canary found NX enabled PIE enabled No RPATH No RUNPATH No Symbols
[*] Function strcpy tear down of wpa_supplicant
; assembly | /* r2dec pseudo code output */
| /* /logs/firmware/patool_extraction/rootfs.img_unblob_extracted/rootfs.img_extract/0-50593792.squashfs_v4_le_extract/usr/sbin/wpa_supplicant @ 0x289b4 */
| #include <stdint.h>
|
; (fcn) fcn.000289b4 () | void fcn_000289b4 (int16_t arg1) {
| int16_t var_0h;
| int16_t var_4h;
| int16_t var_ch;
| int16_t var_10h;
| int16_t var_14h;
| int16_t var_18h;
| int16_t var_1ch;
| r0 = arg1;
0x000289b4 blmi 0x1c3b378 | __asm ("blmi aav.0x0005ff60");
0x000289b8 push {r4, r5, r6, lr} |
0x000289ba mov r4, r0 | r4 = r0;
0x000289bc add r2, pc | r2 += pc;
0x000289be ldr r1, [pc, 0x1bc] |
0x000289c0 movs r5, 1 | r5 = 1;
0x000289c2 sub sp, 0x20 |
0x000289c4 strb.w r5, [r4, 0x54] | *((r4 + 0x54)) = r5;
0x000289c8 movs r0, 2 | r0 = 2;
0x000289ca ldr r3, [r2, r3] | r3 = *((r2 + r3));
0x000289cc add r1, pc | r1 = 0x5154e;
0x000289ce ldr r3, [r3] | r3 = *(r3);
0x000289d0 str r3, [sp, 0x1c] | var_1ch = r3;
0x000289d2 mov.w r3, 0 | r3 = 0;
0x000289d6 bl 0xe4b4 | fcn_0000e4b4 (r0, r1);
0x000289da ldr r3, [r4, 0x50] | r3 = *((r4 + 0x50));
0x000289dc movs r2, 5 | r2 = 5;
0x000289de str r2, [r4] | *(r4) = r2;
0x000289e0 cmp r3, 0 |
| if (r3 == 0) {
0x000289e2 beq.w 0x28b46 | goto label_3;
| }
0x000289e6 ldrd r0, r3, [r4, 0x58] | __asm ("ldrd r0, r3, [r4, 0x58]");
0x000289ea ldr r3, [r3, 0x14] | r3 = *((r3 + 0x14));
0x000289ec blx r3 | uint32_t (*r3)(uint32_t, uint32_t) (r0, r3);
0x000289ee ldr r3, [r4, 0x50] | r3 = *((r4 + 0x50));
0x000289f0 mov r6, r0 | r6 = r0;
0x000289f2 mov r1, r5 | r1 = r5;
0x000289f4 ldr r2, [r3] | r2 = *(r3);
| if (r2 == 0) {
0x000289f6 cbnz r2, 0x28a00 |
0x000289f8 ldr r1, [r3, 4] | r1 = *((r3 + 4));
0x000289fa subs r1, 0x11 | r1 -= 0x11;
0x000289fc it ne |
| if (r1 != 0x11) {
0x000289fe movne r1, 1 | r1 = 1;
| goto label_4;
| }
| }
| label_4:
0x00028a00 mov r0, r6 | r0 = r6;
0x00028a02 bl 0x407a4 | r0 = fcn_000407a4 (r0, r1);
| if (r0 == 0) {
0x00028a06 cbnz r0, 0x28a22 |
| label_0:
0x00028a08 ldr r2, [pc, 0x174] |
0x00028a0a ldr r3, [pc, 0x16c] | r3 = *(0x28b7a);
0x00028a0c add r2, pc | r2 = 0x51590;
0x00028a0e ldr r3, [r2, r3] | r3 = *(0x51590);
0x00028a10 ldr r2, [r3] | r2 = *(0x51590);
0x00028a12 ldr r3, [sp, 0x1c] | r3 = var_1ch;
0x00028a14 eors r2, r3 | r2 ^= r3;
0x00028a16 mov.w r3, 0 | r3 = 0;
| if (r2 != r3) {
0x00028a1a bne.w 0x28b6a | goto label_5;
| }
0x00028a1e add sp, 0x20 |
0x00028a20 pop {r4, r5, r6, pc} |
| }
0x00028a22 ldr r3, [r4, 0x14] | r3 = *((r4 + 0x14));
0x00028a24 movs r5, 0 | r5 = 0;
0x00028a26 ldrb.w r2, [r4, 0x2c] | r2 = *((r4 + 0x2c));
0x00028a2a ldr r1, [r4, 8] | r1 = *((r4 + 8));
0x00028a2c strd r3, r5, [sp, 0x14] | __asm ("strd r3, r5, [var_14h]");
0x00028a30 ldrb.w r3, [r4, 0x34] | r3 = *((r4 + 0x34));
0x00028a32 adds r0, 0x34 | r0 += 0x34;
0x00028a34 ldr r0, [r4, 0x38] | r0 = *((r4 + 0x38));
0x00028a36 strd r5, r1, [sp, 0xc] | __asm ("strd r5, r1, [var_ch]");
0x00028a3a strb.w r3, [sp, 0x18] | var_18h = r3;
0x00028a3e strb.w r2, [sp, 0xc] | var_ch = r2;
0x00028a42 bl 0xf0a8 | fcn_0000f0a8 (r0);
0x00028a46 ldr r1, [r4, 0x50] | r1 = *((r4 + 0x50));
0x00028a48 mov r3, r6 | r3 = r6;
0x00028a4a str r5, [r4, 0x38] | *((r4 + 0x38)) = r5;
0x00028a4c add r2, sp, 0xc | r2 += var_ch;
0x00028a4e mov r0, r4 | r0 = r4;
0x00028a50 ldr r5, [r1, 0x14] | r5 = *((r1 + 0x14));
0x00028a52 ldr r1, [r4, 0x60] | r1 = *((r4 + 0x60));
0x00028a54 blx r5 | uint32_t (*r5)(uint32_t, uint32_t, uint32_t, uint32_t) (r0, r1, r2, r3);
0x00028a56 ldrb.w r3, [sp, 0xc] | r3 = var_ch;
0x00028a5a str r0, [r4, 0x38] | *((r4 + 0x38)) = r0;
| if (r3 != 0) {
0x00028a5c cbnz r3, 0x28a74 | goto label_6;
| }
0x00028a5e ldr r2, [pc, 0x124] |
0x00028a60 add r2, pc | r2 = 0x515ea;
| do {
0x00028a62 ldr r3, [sp, 0x10] | r3 = var_10h;
0x00028a64 cmp r3, 4 |
| if (r3 > 4) {
0x00028a66 bhi.w 0x28b6e | goto label_7;
| }
| /* switch table (5 cases) at 0x28a6e */
0x00028a6a tbb [pc, r3] | __asm ("tbb [0x00028a70]");
| label_6:
0x00028a74 ldr r2, [pc, 0x110] |
0x00028a76 add r2, pc | r2 = 0x51602;
0x00028a78 b 0x28a62 |
| } while (1);
0x00028a7a ldr r3, [pc, 0x110] |
0x00028a7c add r3, pc | r3 = 0x5160e;
| label_1:
0x00028a7e ldr r1, [sp, 0x14] | r1 = var_14h;
0x00028a80 cmp r1, 1 |
| if (r1 == 1) {
0x00028a82 beq 0x28b40 | goto label_8;
| }
0x00028a84 cmp r1, 2 |
| if (r1 == 2) {
0x00028a86 beq 0x28b3a | goto label_9;
| }
0x00028a88 cmp r1, 0 |
| if (r1 == 0) {
0x00028a8a beq 0x28b34 | goto label_10;
| }
0x00028a8c ldr r5, [pc, 0x100] |
0x00028a8e add r5, pc | r5 = 0x51622;
| label_2:
0x00028a90 ldr r1, [pc, 0x100] |
0x00028a92 str r0, [sp, 4] | var_4h = r0;
0x00028a94 movs r0, 2 | r0 = 2;
0x00028a96 str r5, [sp] | *(sp) = r5;
0x00028a98 add r1, pc | r1 = 0x51630;
0x00028a9a bl 0xe4b4 | fcn_0000e4b4 (r0, r1);
0x00028a9e ldrb.w r5, [sp, 0xc] | r5 = var_ch;
0x00028aa2 strb.w r5, [r4, 0x2c] | *((r4 + 0x2c)) = r5;
0x00028aa6 cmp r5, 0 |
| if (r5 != 0) {
0x00028aa8 bne 0x28a08 | goto label_0;
| }
0x00028aaa ldrd r1, r2, [sp, 0x10] | __asm ("ldrd r1, r2, [var_14h]");
0x00028aae ldr r3, [r4, 0x50] | r3 = *((r4 + 0x50));
0x00028ab0 str r2, [r4, 0x14] | *((r4 + 0x14)) = r2;
0x00028ab2 ldr r2, [r3, 0x18] | r2 = *((r3 + 0x18));
0x00028ab4 str r1, [r4, 8] | *((r4 + 8)) = r1;
0x00028ab6 ldrb.w r1, [sp, 0x18] | r1 = var_18h;
0x00028aba strb.w r1, [r4, 0x34] | *((r4 + 0x34)) = r1;
0x00028abe cmp r2, 0 |
| if (r2 == 0) {
0x00028ac0 beq 0x28a08 | goto label_0;
| }
0x00028ac2 ldr r3, [r3, 0x1c] | r3 = *((r3 + 0x1c));
0x00028ac4 cmp r3, 0 |
| if (r3 == 0) {
0x00028ac6 beq 0x28a08 | goto label_0;
| }
0x00028ac8 ldr r1, [r4, 0x60] | r1 = *((r4 + 0x60));
0x00028aca mov r0, r4 | r0 = r4;
0x00028acc blx r2 | r0 = uint32_t (*r2)(uint32_t, uint32_t) (r0, r1);
0x00028ace cmp r0, 0 |
| if (r0 == 0) {
0x00028ad0 beq 0x28a08 | goto label_0;
| }
0x00028ad2 ldr r0, [r4, 0x40] | r0 = *((r4 + 0x40));
| if (r0 != 0) {
0x00028ad4 cbz r0, 0x28ade |
0x00028ad6 ldr r1, [r4, 0x44] | r1 = *((r4 + 0x44));
0x00028ad8 bl 0xe22c | fcn_0000e22c (r0);
0x00028adc str r5, [r4, 0x40] | *((r4 + 0x40)) = r5;
| }
0x00028ade ldr r3, [r4, 0x50] | r3 = *((r4 + 0x50));
0x00028ae0 add.w r2, r4, 0x44 | r2 = r4 + 0x44;
0x00028ae4 ldr r1, [r4, 0x60] | r1 = *((r4 + 0x60));
0x00028ae6 mov r0, r4 | r0 = r4;
0x00028ae8 ldr r3, [r3, 0x1c] | r3 = *((r3 + 0x1c));
0x00028aea blx r3 | uint32_t (*r3)(uint32_t, uint32_t, uint32_t, uint32_t) (r0, r1, r2, r3);
0x00028aec str r0, [r4, 0x40] | *((r4 + 0x40)) = r0;
0x00028aee ldr r0, [r4, 0x48] | r0 = *((r4 + 0x48));
0x00028af0 blx 0x62c8 | fcn_000062c8 ();
0x00028af4 ldr r3, [r4, 0x50] | r3 = *((r4 + 0x50));
0x00028af6 movs r2, 0 | r2 = 0;
0x00028af8 str r2, [r4, 0x48] | *((r4 + 0x48)) = r2;
0x00028afa ldr r3, [r3, 0x48] | r3 = *((r3 + 0x48));
0x00028afc cmp r3, 0 |
| if (r3 == 0) {
0x00028afe beq 0x28a08 | goto label_0;
| }
0x00028b00 ldr r1, [r4, 0x60] | r1 = *((r4 + 0x60));
0x00028b02 add.w r2, r4, 0x4c | r2 = r4 + 0x4c;
0x00028b04 lsls r4, r1, 9 | r4 = r1 << 9;
0x00028b06 mov r0, r4 | r0 = r4;
0x00028b08 blx r3 | uint32_t (*r3)(uint32_t, uint32_t, uint32_t) (r0, r1, r2);
0x00028b0a ldr r1, [pc, 0x8c] |
0x00028b0c mov r2, r0 | r2 = r0;
0x00028b0e str r0, [r4, 0x48] | *((r4 + 0x48)) = r0;
0x00028b10 movs r0, 2 | r0 = 2;
0x00028b12 ldr r3, [r4, 0x4c] | r3 = *((r4 + 0x4c));
0x00028b14 add r1, pc | r1 = 0x516b2;
0x00028b16 bl 0xe848 | fcn_0000e848 (r0, r1, r2, r3);
0x00028b1a b 0x28a08 | goto label_0;
0x00028b1c ldr r3, [pc, 0x7c] |
0x00028b1e add r3, pc | r3 = 0x516be;
0x00028b20 b 0x28a7e | goto label_1;
0x00028b22 ldr r3, [pc, 0x7c] |
0x00028b24 add r3, pc | r3 = 0x516ca;
0x00028b26 b 0x28a7e | goto label_1;
0x00028b28 ldr r3, [pc, 0x78] |
0x00028b2a add r3, pc | r3 = 0x516d2;
0x00028b2c b 0x28a7e | goto label_1;
0x00028b2e ldr r3, [pc, 0x78] |
0x00028b30 add r3, pc | r3 = 0x516de;
0x00028b32 b 0x28a7e | goto label_1;
| label_10:
0x00028b34 ldr r5, [pc, 0x74] |
0x00028b36 add r5, pc | r5 = 0x516e6;
0x00028b38 b 0x28a90 | goto label_2;
| label_9:
0x00028b3a ldr r5, [pc, 0x74] |
0x00028b3c add r5, pc | r5 = 0x516f2;
0x00028b3e b 0x28a90 | goto label_2;
| label_8:
0x00028b40 ldr r5, [pc, 0x70] |
0x00028b42 add r5, pc | r5 = 0x516fa;
0x00028b44 b 0x28a90 | goto label_2;
| label_3:
0x00028b46 ldr r2, [pc, 0x70] |
0x00028b48 ldr r3, [pc, 0x2c] | r3 = *(0x28b78);
0x00028b4a add r2, pc | r2 = 0x51708;
0x00028b4c ldr r3, [r2, r3] | r3 = *(0x51708);
0x00028b4e ldr r2, [r3] | r2 = *(0x51708);
0x00028b50 ldr r3, [sp, 0x1c] | r3 = var_1ch;
0x00028b52 eors r2, r3 | r2 ^= r3;
0x00028b54 mov.w r3, 0 | r3 = 0;
| if (r2 == r3) {
0x00028b58 bne 0x28b6a |
0x00028b5a ldr r1, [pc, 0x60] |
0x00028b5c movs r0, 4 | r0 = 4;
0x00028b5e add r1, pc | r1 = 0x51720;
0x00028b60 add sp, 0x20 |
0x00028b62 pop.w {r4, r5, r6, lr} |
0x00028b66 b.w 0xe4b4 | void (*0xe4b4)() ();
| }
| label_5:
0x00028b6a blx 0x6b24 | fcn_00006b24 ();
| label_7:
0x00028b6e ldr r3, [pc, 0x50] |
0x00028b70 add r3, pc | r3 = 0x51736;
0x00028b72 b 0x28a7e | goto label_1;
| }
[*] Function strcpy used 1 times wpa_supplicant