[*] Binary protection state of ble_advertise
Full RELRO Canary found NX disabled No PIE No RPATH No RUNPATH No Symbols
[*] Function popen tear down of ble_advertise
; assembly | /* r2dec pseudo code output */
| /* /logs/firmware/patool_extraction/DUMP/mtdblock8_unblob_extracted/mtdblock8_extract/0-9650176.squashfs_v4_le_extract/sbin/ble_advertise @ 0x403188 */
| #include <stdint.h>
|
; (fcn) sym.generic_run_cmd_char_ () | void generic_run_cmd_char_ () {
| /* generic_run_cmd(char*) */
0x00403188 lui gp, 2 |
0x0040318c addiu gp, gp, -0x5168 |
0x00403190 addu gp, gp, t9 | gp += t9;
0x00403194 addiu sp, sp, -0x78 |
0x00403198 sw ra, 0x74(sp) | *(var_74h) = ra;
0x0040319c sw fp, 0x70(sp) | *(var_70h) = fp;
0x004031a0 move fp, sp | fp = sp;
0x004031a4 sw gp, 0x10(sp) | *(var_10h) = gp;
0x004031a8 sw a0, 0x1c(fp) | *(arg_1ch) = a0;
0x004031ac lw t8, -0x7ec8(gp) | t8 = *((gp - 8114));
0x004031b0 lw t8, (t8) | t8 = *(t8);
0x004031b4 sw t8, 0x6c(fp) | *(arg_6ch) = t8;
0x004031b8 addiu v0, fp, 0x2c | v0 = fp + 0x2c;
0x004031bc addiu t8, zero, 0x40 | t8 = 0x40;
0x004031c0 move a0, v0 | a0 = v0;
0x004031c4 move a1, zero | a1 = 0;
0x004031c8 move a2, t8 | a2 = t8;
0x004031cc lw t8, -0x7f34(gp) | t8 = sym.imp.memset;
0x004031d0 move t9, t8 | t9 = t8;
0x004031d4 jalr t9 | t9 ();
0x004031d8 nop |
0x004031dc lw gp, 0x10(fp) | gp = *(arg_10h);
0x004031e0 sw zero, 0x24(fp) | *(arg_24h) = 0;
0x004031e4 sw zero, 0x28(fp) | *(arg_28h) = 0;
0x004031e8 lw t8, 0x1c(fp) | t8 = *(arg_1ch);
| if (t8 == 0) {
0x004031ec bnez t8, 0x403200 |
0x004031f0 nop |
0x004031f4 move t8, zero | t8 = 0;
0x004031f8 b 0x4032f4 | goto label_0;
0x004031fc nop |
| }
0x00403200 lw a0, 0x1c(fp) | a0 = *(arg_1ch);
0x00403204 lw t8, -0x7fdc(gp) | t8 = *(gp);
0x00403208 addiu a1, t8, 0x4f1c | a1 = t8 + 0x4f1c;
0x0040320c lw t8, -0x7f74(gp) | t8 = sym.imp.popen
0x00403210 move t9, t8 | t9 = t8;
0x00403214 jalr t9 | t9 ();
0x00403218 nop |
0x0040321c lw gp, 0x10(fp) | gp = *(arg_10h);
0x00403220 move t8, v0 | t8 = v0;
0x00403224 sw t8, 0x28(fp) | *(arg_28h) = t8;
0x00403228 lw t8, 0x28(fp) | t8 = *(arg_28h);
| if (t8 == 0) {
0x0040322c bnez t8, 0x403240 |
0x00403230 nop |
0x00403234 move t8, zero | t8 = 0;
0x00403238 b 0x4032f4 | goto label_0;
0x0040323c nop |
| }
0x00403240 b 0x4032a0 | goto label_1;
0x00403244 nop |
| do {
0x00403248 lw t8, 0x24(fp) | t8 = *(arg_24h);
| if (t8 == 0) {
0x0040324c bnez t8, 0x403280 |
0x00403250 nop |
0x00403254 addiu t8, fp, 0x2c | t8 = fp + 0x2c;
0x00403258 move a0, t8 | a0 = t8;
0x0040325c lw t8, -0x7f78(gp) | t8 = sym.imp.strdup;
0x00403260 move t9, t8 | t9 = t8;
0x00403264 jalr t9 | t9 ();
0x00403268 nop |
0x0040326c lw gp, 0x10(fp) | gp = *(arg_10h);
0x00403270 move t8, v0 | t8 = v0;
0x00403274 sw t8, 0x24(fp) | *(arg_24h) = t8;
0x00403278 b 0x4032a0 | goto label_1;
0x0040327c nop |
| }
0x00403280 addiu t8, fp, 0x2c | t8 = fp + 0x2c;
0x00403284 lw a0, 0x24(fp) | a0 = *(arg_24h);
0x00403288 move a1, t8 | a1 = t8;
0x0040328c lw t8, -0x7edc(gp) | t8 = sym.imp.strcat;
0x00403290 move t9, t8 | t9 = t8;
0x00403294 jalr t9 | t9 ();
0x00403298 nop |
0x0040329c lw gp, 0x10(fp) | gp = *(arg_10h);
| label_1:
0x004032a0 addiu t8, fp, 0x2c | t8 = fp + 0x2c;
0x004032a4 move a0, t8 | a0 = t8;
0x004032a8 addiu a1, zero, 0x40 | a1 = 0x40;
0x004032ac lw a2, 0x28(fp) | a2 = *(arg_28h);
0x004032b0 lw t8, -0x7f28(gp) | t8 = sym.imp.fgets;
0x004032b4 move t9, t8 | t9 = t8;
0x004032b8 jalr t9 | t9 ();
0x004032bc nop |
0x004032c0 lw gp, 0x10(fp) | gp = *(arg_10h);
0x004032c4 move t8, v0 | t8 = v0;
0x004032c8 sltu t8, zero, t8 | t8 = (0 < t8) ? 1 : 0;
0x004032cc andi t8, t8, 0xff | t8 &= 0xff;
0x004032d0 bnez t8, 0x403248 |
| } while (t8 != 0);
0x004032d4 nop |
0x004032d8 lw a0, 0x28(fp) | a0 = *(arg_28h);
0x004032dc lw t8, -0x7f04(gp) | t8 = sym.imp.pclose;
0x004032e0 move t9, t8 | t9 = t8;
0x004032e4 jalr t9 | t9 ();
0x004032e8 nop |
0x004032ec lw gp, 0x10(fp) | gp = *(arg_10h);
0x004032f0 lw t8, 0x24(fp) | t8 = *(arg_24h);
| label_0:
0x004032f4 move v0, t8 | v0 = t8;
0x004032f8 lw t8, -0x7ec8(gp) | t8 = *((gp - 8114));
0x004032fc lw v1, 0x6c(fp) | v1 = *(arg_6ch);
0x00403300 lw t8, (t8) | t8 = *(t8);
| if (v1 != t8) {
0x00403304 beq v1, t8, 0x40331c |
0x00403308 nop |
0x0040330c lw t8, -0x7f0c(gp) | t8 = sym.imp.__stack_chk_fail;
0x00403310 move t9, t8 | t9 = t8;
0x00403314 jalr t9 | t9 ();
0x00403318 nop |
| }
0x0040331c move sp, fp |
0x00403320 lw ra, 0x74(sp) | ra = *(var_74h);
0x00403324 lw fp, 0x70(sp) | fp = *(var_70h);
0x00403328 addiu sp, sp, 0x78 |
0x0040332c jr ra | return v1;
0x00403330 nop |
| }
[*] Function popen used 2 times ble_advertise