[*] Binary protection state of libsCHL.so
No RELRO No Canary found NX disabled DSO No RPATH No RUNPATH No Symbols
[*] Function strcpy tear down of libsCHL.so
; assembly | /* r2dec pseudo code output */
| /* /logs/firmware/unblob_extracted/firmware_extract/6225984-11075644.jffs2_new_extract/lib/libsCHL.so @ 0x13c0 */
| #include <stdint.h>
|
; (fcn) fcn.000013c0 () | void fcn_000013c0 () {
0x000013c0 lui gp, 2 |
0x000013c4 addiu gp, gp, -0x48e0 |
0x000013c8 addu gp, gp, t9 | gp += t9;
0x000013cc addiu sp, sp, -0x30 |
0x000013d0 sw s3, 0x28(sp) | *(var_28h) = s3;
0x000013d4 lw s3, -0x7fe4(gp) | s3 = *((gp - 8185));
0x000013d8 sw gp, 0x10(sp) | *(var_10h) = gp;
0x000013dc sw ra, 0x2c(sp) | *(var_2ch) = ra;
0x000013e0 lbu v0, 0x4bc0(s3) | v0 = *((s3 + 19392));
0x000013e4 sw s2, 0x24(sp) | *(var_24h) = s2;
0x000013e8 sw s1, 0x20(sp) | *(var_20h) = s1;
0x000013ec sw s0, 0x1c(sp) | *(var_1ch) = s0;
0x000013f0 lw v0, -0x7f58(gp) | v0 = *((gp - 8150));
| if (v0 != 0) {
0x000013f4 bnez v0, 0x14ac | goto label_1;
| }
0x000013f8 lw v0, -0x7fe0(gp) | v0 = *((gp - 8184));
| if (v0 != 0) {
0x000013fc beqz v0, 0x1410 |
0x00001400 lw t9, -0x7f58(gp) | t9 = *((gp - 8150));
0x00001404 lw a0, (v0) | a0 = *(v0);
0x00001408 jalr t9 | t9 ();
0x0000140c lw gp, 0x10(sp) | gp = *(var_10h);
| }
0x00001410 lw s2, -0x7fe4(gp) | s2 = *((gp - 8185));
0x00001414 lw s0, -0x7fe4(gp) | s0 = *((gp - 8185));
0x00001418 lw s1, -0x7fdc(gp) | s1 = *((gp - 8183));
0x0000141c addiu s2, s2, 0x4adc | s2 += 0x4adc;
0x00001420 lw v0, 0x4bc4(s0) | v0 = *((s0 + 4849));
0x00001424 subu s1, s1, s2 | __asm ("subu s1, s1, s2");
0x00001428 sra s1, s1, 2 | s1 >>= 2;
0x0000142c addiu s1, s1, -1 | s1 += -1;
0x00001430 sltu v1, v0, s1 | v1 = (v0 < s1) ? 1 : 0;
0x00001434 lw t9, -0x7fd8(gp) | t9 = *((gp - 8182));
| if (v1 == 0) {
0x00001438 beqz v1, 0x1468 | goto label_2;
| }
| do {
0x0000143c addiu v0, v0, 1 | v0++;
0x00001440 sll v1, v0, 2 | v1 = v0 << 2;
0x00001444 addu v1, s2, v1 | v1 = s2 + v1;
0x00001448 lw t9, (v1) | t9 = *(v1);
0x0000144c sw v0, 0x4bc4(s0) | *((s0 + 4849)) = v0;
0x00001450 jalr t9 | t9 ();
0x00001454 lw v0, 0x4bc4(s0) | v0 = *((s0 + 4849));
0x00001458 sltu v1, v0, s1 | v1 = (v0 < s1) ? 1 : 0;
0x0000145c lw gp, 0x10(sp) | gp = *(var_10h);
0x00001460 bnez v1, 0x143c |
| } while (v1 != 0);
0x00001464 lw t9, -0x7fd8(gp) | t9 = *((gp - 8182));
| label_2:
0x00001468 addiu t9, t9, 0x1330 | t9 += entry0;
0x0000146c bal 0x1330 | entry0 ();
0x00001470 nop |
0x00001474 lw gp, 0x10(sp) | gp = *(var_10h);
0x00001478 lw v0, -0x7f84(gp) | v0 = *((gp - 8161));
0x0000147c lw a0, -0x7f90(gp) | a0 = *((gp - 8164));
| if (v0 == 0) {
0x00001480 beqz v0, 0x14c8 | goto label_3;
| }
0x00001484 lw v0, -0x7f80(gp) | v0 = *((gp - 8160));
| if (a0 == 0) {
0x00001488 beqz a0, 0x14cc | goto label_4;
| }
0x0000148c lb v0, (a0) | v0 = *(a0);
0x00001490 slti v0, v0, 2 | v0 = (v0 < 2) ? 1 : 0;
0x00001494 lw t9, -0x7f80(gp) | t9 = *((gp - 8160));
| if (v0 != 0) {
0x00001498 bnez v0, 0x14c8 | goto label_3;
| }
0x0000149c jalr t9 | t9 ();
0x000014a0 nop |
| do {
0x000014a4 addiu v0, zero, 1 | v0 = 1;
| label_0:
0x000014a8 sb v0, 0x4bc0(s3) | *((s3 + 19392)) = v0;
| label_1:
0x000014ac lw ra, 0x2c(sp) | ra = *(var_2ch);
0x000014b0 lw s3, 0x28(sp) | s3 = *(var_28h);
0x000014b4 lw s2, 0x24(sp) | s2 = *(var_24h);
0x000014b8 lw s1, 0x20(sp) | s1 = *(var_20h);
0x000014bc lw s0, 0x1c(sp) | s0 = *(var_1ch);
0x000014c0 addiu sp, sp, 0x30 |
0x000014c4 jr ra | return v0;
| label_3:
0x000014c8 lw v0, -0x7f80(gp) | v0 = *((gp - 8160));
| label_4:
0x000014cc lw a0, -0x7fd8(gp) | a0 = *((gp - 8182));
0x000014d0 beqz v0, 0x14a4 |
| } while (v0 == 0);
0x000014d4 lw t9, -0x7f80(gp) | t9 = *((gp - 8160));
0x000014d8 addiu a0, a0, 0x4ad0 | a0 += section..eh_frame;
0x000014dc jalr t9 | t9 ();
0x000014e0 addiu v0, zero, 1 | v0 = 1;
0x000014e4 b 0x14a8 | goto label_0;
| }
[*] Function strcpy used 1 times libsCHL.so