[*] Binary protection state of libapr-1.so.0.7.0

  
  	Full RELRO     Canary found      NX enabled   DSO          No RPATH     No RUNPATH   No Symbols


[*] Function system tear down of libapr-1.so.0.7.0

    ; assembly                                                   | /* r2dec pseudo code output */
                                                                 | /* /logs/firmware/patool_extraction/rootfs.img_unblob_extracted/rootfs.img_extract/0-50593792.squashfs_v4_le_extract/usr/lib/libapr-1.so.0.7.0 @ 0x1cee0 */
                                                                 | #include <stdint.h>
                                                                 |  
                                                                 | #define BIT_MASK(t,v) ((t)(-((v)!= 0)))&(((t)-1)>>((sizeof(t)*CHAR_BIT)-(v)))
                                                                 | uint32_t rotate_right32 (uint32_t value, uint32_t count) {
                                                                 |     const uint32_t mask = (CHAR_BIT * sizeof (value)) - 1;
                                                                 |     count &= mask;
                                                                 |     return (value >> count) | (value << (-count & mask));
                                                                 | }
                                                                 | #define SWAP32(n) ((uint32_t) (((n & 0x000000ff) << 24) | \
                                                                 |                                ((n & 0x0000ff00) <<  8) | \
                                                                 |                                ((n & 0x00ff0000) >>  8) | \
                                                                 |                                ((n & 0xff000000) >> 24)))
                                                                 |  
    ; (fcn) sym.apr__SHA256_Transform ()                         | void apr_SHA256_Transform (int16_t arg1, int16_t arg2) {
                                                                 |     int16_t var_0h;
                                                                 |     int16_t var_4h;
                                                                 |     int16_t var_8h;
                                                                 |     int16_t var_ch;
                                                                 |     int16_t var_10h;
                                                                 |     int16_t var_14h;
                                                                 |     int16_t var_18h;
                                                                 |     int16_t var_1ch;
                                                                 |     r0 = arg1;
                                                                 |     r1 = arg2;
    0x0001cee0 push {r0, r1, sb, sl, lr}                         |     
    0x0001cee4 ldr r7, [pc, 0x3c0]                               |     r7 = *(0x1d2a8);
    0x0001cee6 mov fp, r1                                        |     
    0x0001cee8 ldrd r6, r1, [r3, 0x10]                           |     __asm ("ldrd r6, r1, [r3, 0x10]");
    0x0001ceec sub sp, 0x24                                      |     
    0x0001ceee mov r7, r0                                        |     r7 = r0;
    0x0001cef0 ldr r2, [pc, 0x1d8]                               |     
    0x0001cef2 str r1, [sp, 8]                                   |     var_8h = r1;
    0x0001cef4 ldr r1, [r3, 0x18]                                |     r1 = *((r3 + 0x18));
    0x0001cef6 ldr.w sl, [r3, 0x1c]                              |     sl = *((r3 + 0x1c));
    0x0001cefa add r2, pc                                        |     r2 = 0x39fca;
    0x0001cefc ldr r5, [r0, 4]                                   |     r5 = *((r0 + 4));
    0x0001cefe add.w ip, r2, 0x20                                |     
    0x0001cf02 ldr r4, [r7], 0x28                                |     r4 = *(r7);
                                                                 |     r7 += 0x28;
    0x0001cf06 adds r2, 0x5c                                     |     r2 += 0x5c;
    0x0001cf08 str r0, [sp, 0x1c]                                |     var_1ch = r0;
    0x0001cf0a ldrd r0, sb, [r0, 8]                              |     __asm ("ldrd r0, sb, [r0, 8]");
    0x0001cf0e str r1, [sp, 4]                                   |     var_4h = r1;
    0x0001cf10 mov r1, r3                                        |     r1 = r3;
    0x0001cf12 movw r3, 0x2f98                                   |     
    0x0001cf16 add.w r8, r1, 0x24                                |     r8 = r1 + 0x24;
    0x0001cf1a movt r3, 0x428a                                   |     r3 = 0x428a2f98;
    0x0001cf1e str.w r8, [sp]                                    |     __asm ("str.w r8, [sp]");
    0x0001cf22 mov lr, r0                                        |     lr = r0;
    0x0001cf24 ldr.w r8, [sp, 4]                                 |     r8 = var_4h;
    0x0001cf28 str r2, [sp, 0x10]                                |     var_10h = r2;
    0x0001cf2a str.w fp, [sp, 4]                                 |     __asm ("str.w fp, [var_4h]");
    0x0001cf2e mov fp, sl                                        |     
    0x0001cf30 str r7, [sp, 0x14]                                |     var_14h = r7;
    0x0001cf32 ldr.w sl, [sp, 8]                                 |     sl = var_8h;
    0x0001cf36 str r3, [sp, 0xc]                                 |     var_ch = r3;
    0x0001cf38 b 0x1cf4c                                         |     
                                                                 |     while (r3 != ip) {
    0x0001cf3a ldr r3, [ip, 4]!                                  |         r3 = *((ip += 4));
    0x0001cf3e mov r8, sl                                        |         r8 = sl;
    0x0001cf40 mov lr, r5                                        |         lr = r5;
    0x0001cf42 mov sl, r6                                        |         sl = r6;
    0x0001cf44 mov r5, r4                                        |         r5 = r4;
    0x0001cf46 mov r6, r0                                        |         r6 = r0;
    0x0001cf48 mov r4, r2                                        |         r4 = r2;
    0x0001cf4a str r3, [sp, 0xc]                                 |         var_ch = r3;
    0x0001cf4c ldr r2, [sp, 4]                                   |         r2 = var_4h;
    0x0001cf4e and.w r3, r6, sl                                  |         r3 = r6 & sl;
    0x0001cf52 ldr r1, [sp]                                      |         r1 = *(sp);
    0x0001cf54 bic.w r0, r8, r6                                  |         r0 = BIT_MASK (r8, r6);
    0x0001cf58 eors r0, r3                                       |         r0 ^= r3;
    0x0001cf5a ldr r3, [sp, 0xc]                                 |         r3 = var_ch;
    0x0001cf5c ldr r7, [r2], 4                                   |         r7 = *(r2);
                                                                 |         r2 += 4;
    0x0001cf60 str r2, [sp, 4]                                   |         var_4h = r2;
    0x0001cf62 ror.w r2, r6, 0xb                                 |         r2 = rotate_right32 (r6, 11);
    0x0001cf66 rev r7, r7                                        |         r7 = SWAP32 (r7);
    0x0001cf68 eor.w r2, r2, r6, ror 6                           |         r2 ^= (r6 >>> 6);
    0x0001cf6c str r7, [r1, 4]!                                  |         *((r1 += 4)) = r7;
    0x0001cf70 str r1, [sp]                                      |         *(sp) = r1;
    0x0001cf72 ror.w r1, r4, 0xd                                 |         r1 = rotate_right32 (r4, 13);
    0x0001cf76 eor.w r2, r2, r6, ror 25                          |         r2 ^= (r6 >>> 25);
    0x0001cf7a eor.w r1, r1, r4, ror 2                           |         r1 ^= (r4 >>> 2);
    0x0001cf7e add r2, r0                                        |         r2 += r0;
    0x0001cf80 add r2, r7                                        |         r2 += r7;
    0x0001cf82 eor.w r1, r1, r4, ror 22                          |         r1 ^= (r4 >>> 22);
    0x0001cf86 add r2, fp                                        |         r2 += fp;
    0x0001cf88 add r2, r3                                        |         r2 += r3;
    0x0001cf8a eor.w r3, r5, lr                                  |         r3 = r5 ^ lr;
    0x0001cf8e ands r3, r4                                       |         r3 &= r4;
    0x0001cf90 and.w r7, r5, lr                                  |         r7 = r5 & lr;
    0x0001cf94 eors r3, r7                                       |         r3 ^= r7;
    0x0001cf96 add.w r0, sb, r2                                  |         r0 = sb + r2;
    0x0001cf9a add r3, r1                                        |         r3 += r1;
    0x0001cf9c mov fp, r8                                        |         
    0x0001cf9e add r2, r3                                        |         r2 += r3;
    0x0001cfa0 ldr r3, [sp, 0x10]                                |         r3 = var_10h;
    0x0001cfa2 mov sb, lr                                        |         sb = lr;
    0x0001cfa4 cmp r3, ip                                        |         
    0x0001cfa6 bne 0x1cf3a                                       |         
                                                                 |     }
    0x0001cfa8 ldr r3, [pc, 0x124]                               |     
    0x0001cfaa ldr r7, [sp, 0x14]                                |     r7 = var_14h;
    0x0001cfac str.w r8, [sp, 4]                                 |     __asm ("str.w r8, [var_4h]");
    0x0001cfb0 mov.w r8, 0x10                                    |     r8 = 0x10;
    0x0001cfb4 add r3, pc                                        |     r3 = 0x3a088;
    0x0001cfb6 strd sl, lr, [sp, 8]                              |     __asm ("strd sl, lr, [var_8h]");
    0x0001cfba adds r3, 0x60                                     |     r3 += 0x60;
    0x0001cfbc str r4, [sp]                                      |     *(sp) = r4;
    0x0001cfbe str r3, [sp, 0x18]                                |     var_18h = r3;
    0x0001cfc0 movw r3, 0x69c1                                   |     
    0x0001cfc4 movt r3, 0xe49b                                   |     r3 = 0xe49b69c1;
    0x0001cfc8 str r6, [sp, 0x10]                                |     var_10h = r6;
    0x0001cfca str r3, [sp, 0x14]                                |     var_14h = r3;
    0x0001cfcc b 0x1cfe4                                         |     
                                                                 |     while (r5 != r0) {
    0x0001cfce ldr r3, [sp, 0x18]                                |         r3 = var_18h;
    0x0001cfd0 mov r5, r6                                        |         r5 = r6;
    0x0001cfd2 str r2, [sp]                                      |         *(sp) = r2;
    0x0001cfd4 str r0, [sp, 0x10]                                |         var_10h = r0;
    0x0001cfd6 mov r0, r1                                        |         r0 = r1;
    0x0001cfd8 ldr r2, [r3, 4]!                                  |         r2 = *((r3 += 4));
    0x0001cfdc str r4, [sp, 8]                                   |         var_8h = r4;
    0x0001cfde strd r2, r3, [sp, 0x14]                           |         __asm ("strd r2, r3, [var_14h]");
    0x0001cfe2 mov r2, lr                                        |         r2 = lr;
    0x0001cfe4 add.w sb, r8, 1                                   |         sb = r8 + 1;
    0x0001cfe8 add.w r1, r8, 0xe                                 |         r1 = r8 + 0xe;
    0x0001cfec and r3, sb, 0xf                                   |         r3 = sb & 0xf;
    0x0001cff0 and r1, r1, 0xf                                   |         r1 &= 0xf;
    0x0001cff4 ldr.w r3, [r7, r3, lsl 2]                         |         offset_0 = r3 << 2;
                                                                 |         r3 = *((r7 + offset_0));
    0x0001cff8 and sl, r8, 0xf                                   |         sl = r8 & 0xf;
    0x0001cffc ldr.w fp, [r7, r1, lsl 2]                         |         offset_1 = r1 << 2;
                                                                 |         fp = *((r7 + offset_1));
    0x0001d000 cmp.w sb, 0x40                                    |         
    0x0001d004 ldr.w r6, [r7, sl, lsl 2]                         |         offset_2 = sl << 2;
                                                                 |         r6 = *((r7 + offset_2));
    0x0001d008 ldr r4, [sp, 0x10]                                |         r4 = var_10h;
    0x0001d00a ror.w lr, r3, 0x12                                |         lr = rotate_right32 (r3, 18);
    0x0001d00e ror.w ip, fp, 0x13                                |         ip = rotate_right32 (fp, 19);
    0x0001d012 eor.w lr, lr, r3, ror 7                           |         lr ^= (r3 >>> 7);
    0x0001d016 eor.w ip, ip, fp, ror 17                          |         
    0x0001d01a eor.w lr, lr, r3, lsr 3                           |         lr ^= (r3 >> 3);
    0x0001d01e add.w r3, r8, 9                                   |         r3 = r8 + 9;
    0x0001d022 and r3, r3, 0xf                                   |         r3 &= 0xf;
    0x0001d026 eor.w ip, ip, fp, lsr 10                          |         
    0x0001d02a ldr.w r1, [r7, r3, lsl 2]                         |         offset_3 = r3 << 2;
                                                                 |         r1 = *((r7 + offset_3));
    0x0001d02e ror.w r3, r0, 0xb                                 |         r3 = rotate_right32 (r0, 11);
    0x0001d032 mov r8, sb                                        |         r8 = sb;
    0x0001d034 eor.w r3, r3, r0, ror 6                           |         r3 ^= (r0 >>> 6);
    0x0001d038 add r1, r6                                        |         r1 += r6;
    0x0001d03a ldr r6, [sp, 8]                                   |         r6 = var_8h;
    0x0001d03c add r1, lr                                        |         r1 += lr;
    0x0001d03e eor.w r3, r3, r0, ror 25                          |         r3 ^= (r0 >>> 25);
    0x0001d042 add r1, ip                                        |         r1 += ip;
    0x0001d044 ror.w ip, r2, 0xd                                 |         ip = rotate_right32 (r2, 13);
    0x0001d048 bic.w lr, r6, r0                                  |         lr = BIT_MASK (r6, r0);
    0x0001d04c str.w r1, [r7, sl, lsl 2]                         |         __asm ("str.w r1, [r7, sl, lsl 2]");
    0x0001d050 and.w sl, r0, r4                                  |         sl = r0 & r4;
    0x0001d054 eor.w ip, ip, r2, ror 2                           |         
    0x0001d058 eor.w lr, lr, sl                                  |         lr ^= sl;
    0x0001d05c add r3, lr                                        |         r3 += lr;
    0x0001d05e eor.w ip, ip, r2, ror 22                          |         
    0x0001d062 add r3, r1                                        |         r3 += r1;
    0x0001d064 ldr r1, [sp, 4]                                   |         r1 = var_4h;
    0x0001d066 str r6, [sp, 4]                                   |         var_4h = r6;
    0x0001d068 ldr r6, [sp]                                      |         r6 = *(sp);
    0x0001d06a add r3, r1                                        |         r3 += r1;
    0x0001d06c ldr r1, [sp, 0x14]                                |         r1 = var_14h;
    0x0001d06e eor.w lr, r6, r5                                  |         lr = r6 ^ r5;
    0x0001d070 lsrs r5, r0, 0x18                                 |         r5 = r0 >> 0x18;
    0x0001d072 and.w sl, r6, r5                                  |         sl = r6 & r5;
    0x0001d076 add r3, r1                                        |         r3 += r1;
    0x0001d078 and.w lr, lr, r2                                  |         lr &= r2;
    0x0001d07c ldr r1, [sp, 0xc]                                 |         r1 = var_ch;
    0x0001d07e eor.w lr, lr, sl                                  |         lr ^= sl;
    0x0001d082 add lr, ip                                        |         lr += ip;
    0x0001d084 str r5, [sp, 0xc]                                 |         var_ch = r5;
    0x0001d086 add lr, r3                                        |         lr += r3;
    0x0001d088 add r1, r3                                        |         r1 += r3;
    0x0001d08a bne 0x1cfce                                       |         
                                                                 |     }
    0x0001d08c ldr r7, [sp, 0x1c]                                |     r7 = var_1ch;
    0x0001d08e ldr r4, [sp]                                      |     r4 = *(sp);
    0x0001d090 ldr r6, [sp, 0x10]                                |     r6 = var_10h;
    0x0001d092 ldr r3, [r7]                                      |     r3 = *(r7);
    0x0001d094 add r3, lr                                        |     r3 += lr;
    0x0001d096 str r3, [r7]                                      |     *(r7) = r3;
    0x0001d098 ldr r3, [r7, 4]                                   |     r3 = *((r7 + 4));
    0x0001d09a add r3, r2                                        |     r3 += r2;
    0x0001d09c ldr r2, [r7, 0x18]                                |     r2 = *((r7 + 0x18));
    0x0001d09e str r3, [r7, 4]                                   |     *((r7 + 4)) = r3;
    0x0001d0a0 ldr r3, [r7, 8]                                   |     r3 = *((r7 + 8));
    0x0001d0a2 add r6, r2                                        |     r6 += r2;
    0x0001d0a4 str r6, [r7, 0x18]                                |     *((r7 + 0x18)) = r6;
    0x0001d0a6 add r3, r4                                        |     r3 += r4;
    0x0001d0a8 str r3, [r7, 8]                                   |     *((r7 + 8)) = r3;
    0x0001d0aa ldr r3, [r7, 0xc]                                 |     r3 = *((r7 + 0xc));
    0x0001d0ac add r3, r5                                        |     r3 += r5;
    0x0001d0ae str r3, [r7, 0xc]                                 |     *((r7 + 0xc)) = r3;
    0x0001d0b0 ldr r3, [r7, 0x10]                                |     r3 = *((r7 + 0x10));
    0x0001d0b2 add r3, r1                                        |     r3 += r1;
    0x0001d0b4 ldr r1, [sp, 8]                                   |     r1 = var_8h;
    0x0001d0b6 str r3, [r7, 0x10]                                |     *((r7 + 0x10)) = r3;
    0x0001d0b8 ldr r3, [r7, 0x14]                                |     r3 = *((r7 + 0x14));
    0x0001d0ba add r3, r0                                        |     r3 += r0;
    0x0001d0bc str r3, [r7, 0x14]                                |     *((r7 + 0x14)) = r3;
    0x0001d0be ldr r3, [r7, 0x1c]                                |     r3 = *((r7 + 0x1c));
    0x0001d0c0 add r3, r1                                        |     r3 += r1;
    0x0001d0c2 str r3, [r7, 0x1c]                                |     *((r7 + 0x1c)) = r3;
    0x0001d0c4 add sp, 0x24                                      |     
    0x0001d0c6 pop.w {r4, r5, r6, r7, r8, sb, sl, fp, pc}        |     
                                                                 | }
    ; assembly                                                       | /* r2dec pseudo code output */
                                                                     | /* /logs/firmware/patool_extraction/rootfs.img_unblob_extracted/rootfs.img_extract/0-50593792.squashfs_v4_le_extract/usr/lib/libapr-1.so.0.7.0 @ 0x17db4 */
                                                                     | #include <stdint.h>
                                                                     |  
    ; (fcn) sym.apr_pool_clear ()                                    | void apr_pool_clear (int16_t arg_0h, int16_t arg_4h, int16_t arg_10h, int16_t arg1, int16_t arg2) {
                                                                     |     r0 = arg1;
                                                                     |     r1 = arg2;
    0x00017db4 push.w {r3, r4, r5, r6, r7, r8, sb, sl, fp, lr}       |     
    0x00017db8 mov r4, r0                                            |     r4 = r0;
    0x00017dba ldr r3, [r0, 0x38]                                    |     r3 = *(arg_0hx38);
                                                                     |     if (r3 == 0) {
    0x00017dbc cbz r3, 0x17dce                                       |         goto label_4;
                                                                     |     }
                                                                     |     do {
    0x00017dbe ldr r1, [r3]                                          |         r1 = *(r3);
    0x00017dc0 ldr r2, [r3, 8]                                       |         r2 = *((r3 + 8));
    0x00017dc2 str r1, [r4, 0x38]                                    |         *((r4 + 0x38)) = r1;
    0x00017dc4 ldr r0, [r3, 4]                                       |         r0 = *((r3 + 4));
    0x00017dc6 blx r2                                                |         uint32_t (*r2)(uint32_t, uint32_t, uint32_t) (r0, r1, r2);
    0x00017dc8 ldr r3, [r4, 0x38]                                    |         r3 = *((r4 + 0x38));
    0x00017dca cmp r3, 0                                             |         
    0x00017dcc bne 0x17dbe                                           |         
                                                                     |     } while (r3 != 0);
                                                                     | label_4:
    0x00017dce ldr r0, [r4, 4]                                       |     r0 = *((r4 + 4));
    0x00017dd0 movs r3, 0                                            |     r3 = 0;
    0x00017dd2 str r3, [r4, 0x38]                                    |     *((r4 + 0x38)) = r3;
                                                                     |     if (r0 == 0) {
    0x00017dd4 cbz r0, 0x17dee                                       |         goto label_5;
                                                                     |     }
                                                                     |     do {
    0x00017dd6 blx 0xa780                                            |         fcn_0000a780 ();
    0x00017dda ldr r0, [r4, 4]                                       |         r0 = *((r4 + 4));
    0x00017ddc cmp r0, 0                                             |         
    0x00017dde bne 0x17dd6                                           |         
                                                                     |     } while (r0 != 0);
    0x00017de0 ldr r3, [r4, 0x10]                                    |     r3 = *((r4 + 0x10));
                                                                     |     if (r3 == 0) {
    0x00017de2 cbz r3, 0x17df4                                       |         goto label_6;
                                                                     |     }
                                                                     |     do {
    0x00017de4 ldr r1, [r3]                                          |         r1 = *(r3);
    0x00017de6 ldr r2, [r3, 8]                                       |         r2 = *((r3 + 8));
    0x00017de8 str r1, [r4, 0x10]                                    |         *((r4 + 0x10)) = r1;
    0x00017dea ldr r0, [r3, 4]                                       |         r0 = *((r3 + 4));
    0x00017dec blx r2                                                |         uint32_t (*r2)(uint32_t, uint32_t, uint32_t) (r0, r1, r2);
                                                                     | label_5:
    0x00017dee ldr r3, [r4, 0x10]                                    |         r3 = *((r4 + 0x10));
    0x00017df0 cmp r3, 0                                             |         
    0x00017df2 bne 0x17de4                                           |         
                                                                     |     } while (r3 != 0);
                                                                     | label_6:
    0x00017df4 ldr r0, [r4, 0x1c]                                    |     r0 = *((r4 + 0x1c));
    0x00017df6 movs r3, 0                                            |     r3 = 0;
    0x00017df8 strd r3, r3, [r4, 0x10]                               |     __asm ("strd r3, r3, [r4, 0x10]");
                                                                     |     if (r0 != 0) {
    0x00017dfc cbz r0, 0x17e02                                       |         
    0x00017dfe bl 0x17760                                            |         fcn_00017760 (r0);
                                                                     |     }
    0x00017e02 ldrd fp, r1, [r4, 0x30]                               |     __asm ("ldrd fp, r1, [r4, 0x30]");
    0x00017e06 movs r3, 0                                            |     r3 = 0;
    0x00017e08 str r3, [r4, 0x1c]                                    |     *((r4 + 0x1c)) = r3;
    0x00017e0a str r3, [r4, 0x24]                                    |     *((r4 + 0x24)) = r3;
    0x00017e0c ldr.w r2, [fp]                                        |     r2 = *(fp);
    0x00017e10 str.w fp, [r4, 0x2c]                                  |     __asm ("str.w fp, [r4, 0x2c]");
    0x00017e14 str.w r1, [fp, 0x10]                                  |     __asm ("str.w r1, [arg_10h]");
    0x00017e18 cmp fp, r2                                            |     
                                                                     |     if (fp == r2) {
    0x00017e1a beq 0x17ea0                                           |         goto label_7;
                                                                     |     }
    0x00017e1c ldr r7, [r4, 0x18]                                    |     r7 = *((r4 + 0x18));
    0x00017e1e ldr.w r2, [fp, 4]                                     |     r2 = *(arg_4h);
    0x00017e22 ldr.w r8, [r7, 0xc]                                   |     r8 = *((r7 + 0xc));
    0x00017e26 str r3, [r2]                                          |     *(r2) = r3;
    0x00017e28 ldr.w r5, [fp]                                        |     r5 = *(fp);
    0x00017e2c cmp.w r8, 0                                           |     
                                                                     |     if (r8 != 0) {
    0x00017e30 beq 0x17e3c                                           |         
    0x00017e32 mov r0, r8                                            |         r0 = r8;
    0x00017e34 blx 0xa268                                            |         fcn_0000a268 ();
    0x00017e38 ldr.w r8, [r7, 0xc]                                   |         r8 = *((r7 + 0xc));
                                                                     |     }
    0x00017e3c ldrd sb, r0, [r7]                                     |     __asm ("ldrd sb, r0, [r7]");
    0x00017e40 movs r4, 0                                            |     r4 = 0;
    0x00017e42 ldr r1, [r7, 8]                                       |     r1 = *((r7 + 8));
                                                                     |     do {
                                                                     | label_1:
    0x00017e44 mov r3, r5                                            |         r3 = r5;
    0x00017e46 ldr r5, [r5]                                          |         r5 = *(r5);
    0x00017e48 ldr r2, [r3, 8]                                       |         r2 = *((r3 + 8));
    0x00017e4a add.w ip, r2, 1                                       |         
                                                                     |         if (r0 == 0) {
    0x00017e4e cbz r0, 0x17ea4                                       |             goto label_8;
                                                                     |         }
    0x00017e50 cmp r1, ip                                            |         
    0x00017e52 itt lo                                                |         
                                                                     |         if (r1 >= ip) {
    0x00017e54 strlo r4, [r3]                                        |             *(r3) = r4;
                                                                     |         }
                                                                     |         if (r1 >= ip) {
    0x00017e56 movlo r4, r3                                          |             r4 = r3;
                                                                     |         }
                                                                     |         if (r1 > ip) {
    0x00017e58 blo 0x17e78                                           |             
    0x00017e5a cmp r2, 0x13                                          |             
                                                                     |             if (r2 > 0x13) {
    0x00017e5c bhi 0x17ee0                                           |                 goto label_9;
                                                                     |             }
    0x00017e5e add.w lr, r7, r2, lsl 2                               |             lr = r7 + (r2 << 2);
    0x00017e62 ldr.w sl, [lr, 0x14]                                  |             sl = *((lr + 0x14));
    0x00017e66 str.w sl, [r3]                                        |             __asm ("str.w sl, [r3]");
    0x00017e6a cmp.w sl, 0                                           |             
                                                                     |             if (sl == 0) {
    0x00017e6e beq 0x17ee8                                           |                 goto label_10;
                                                                     |             }
    0x00017e70 str.w r3, [lr, 0x14]                                  |             __asm ("str.w r3, [lr, 0x14]");
                                                                     | label_0:
    0x00017e74 subs r1, 1                                            |             r1--;
    0x00017e76 subs r1, r1, r2                                       |             r1 -= r2;
                                                                     |         }
    0x00017e78 cmp r5, 0                                             |         
    0x00017e7a bne 0x17e44                                           |         
                                                                     |     } while (r5 != 0);
                                                                     | label_2:
    0x00017e7c str.w sb, [r7]                                        |     __asm ("str.w sb, [r7]");
    0x00017e80 str r1, [r7, 8]                                       |     *((r7 + 8)) = r1;
    0x00017e82 cmp.w r8, 0                                           |     
                                                                     |     if (r8 != 0) {
    0x00017e86 beq 0x17e8e                                           |         
    0x00017e88 mov r0, r8                                            |         r0 = r8;
    0x00017e8a blx 0xacfc                                            |         fcn_0000acfc ();
                                                                     |     }
                                                                     |     if (r4 == 0) {
    0x00017e8e cbz r4, 0x17e9c                                       |         goto label_11;
                                                                     |     }
                                                                     |     do {
    0x00017e90 mov r0, r4                                            |         r0 = r4;
    0x00017e92 ldr r4, [r4]                                          |         r4 = *(r4);
    0x00017e94 blx 0x9c34                                            |         fcn_00009c34 ();
    0x00017e98 cmp r4, 0                                             |         
    0x00017e9a bne 0x17e90                                           |         
                                                                     |     } while (r4 != 0);
                                                                     | label_11:
    0x00017e9c strd fp, fp, [fp]                                     |     __asm ("strd fp, fp, [fp]");
                                                                     | label_7:
    0x00017ea0 pop.w {r3, r4, r5, r6, r7, r8, sb, sl, fp, pc}        |     
                                                                     | label_8:
    0x00017ea4 cmp r2, 0x13                                          |     
                                                                     |     if (r2 > 0x13) {
    0x00017ea6 bhi 0x17ecc                                           |         goto label_12;
                                                                     |     }
    0x00017ea8 add.w lr, r7, r2, lsl 2                               |     lr = r7 + (r2 << 2);
    0x00017eac ldr.w sl, [lr, 0x14]                                  |     sl = *((lr + 0x14));
    0x00017eb0 str.w sl, [r3]                                        |     __asm ("str.w sl, [r3]");
    0x00017eb4 cmp.w sl, 0                                           |     
                                                                     |     if (sl == 0) {
    0x00017eb8 beq 0x17ee8                                           |         goto label_10;
                                                                     |     }
                                                                     | label_3:
    0x00017eba cmp r1, ip                                            |     
    0x00017ebc str.w r3, [lr, 0x14]                                  |     __asm ("str.w r3, [lr, 0x14]");
    0x00017ec0 it lo                                                 |     
                                                                     |     if (r1 < ip) {
    0x00017ec2 movlo r1, 0                                           |         r1 = 0;
                                                                     |         goto label_13;
                                                                     |     }
                                                                     |     if (r1 >= ip) {
                                                                     | label_13:
    0x00017ec4 bhs 0x17e74                                           |         goto label_0;
                                                                     |     }
    0x00017ec6 cmp r5, 0                                             |     
                                                                     |     if (r5 != 0) {
    0x00017ec8 bne 0x17e44                                           |         goto label_1;
                                                                     |     }
    0x00017eca b 0x17e7c                                             |     goto label_2;
                                                                     | label_12:
    0x00017ecc ldr r6, [r7, 0x14]                                    |     r6 = *((r7 + 0x14));
    0x00017ece cmp r1, ip                                            |     
    0x00017ed0 it lo                                                 |     
                                                                     |     if (r1 >= ip) {
    0x00017ed2 movlo r1, r0                                          |         r1 = r0;
                                                                     |     }
    0x00017ed4 str r6, [r3]                                          |     *(r3) = r6;
    0x00017ed6 str r3, [r7, 0x14]                                    |     *((r7 + 0x14)) = r3;
                                                                     |     if (r1 >= ip) {
    0x00017ed8 bhs 0x17e74                                           |         goto label_0;
                                                                     |     }
    0x00017eda cmp r5, 0                                             |     
                                                                     |     if (r5 != 0) {
    0x00017edc bne 0x17e44                                           |         goto label_1;
                                                                     |     }
    0x00017ede b 0x17e7c                                             |     goto label_2;
                                                                     | label_9:
    0x00017ee0 ldr r6, [r7, 0x14]                                    |     r6 = *((r7 + 0x14));
    0x00017ee2 str r6, [r3]                                          |     *(r3) = r6;
    0x00017ee4 str r3, [r7, 0x14]                                    |     *((r7 + 0x14)) = r3;
    0x00017ee6 b 0x17e74                                             |     goto label_0;
                                                                     | label_10:
    0x00017ee8 cmp sb, r2                                            |     
    0x00017eea it lo                                                 |     
                                                                     |     if (sb >= r2) {
    0x00017eec movlo sb, r2                                          |         sb = r2;
                                                                     |     }
    0x00017eee b 0x17eba                                             |     goto label_3;
                                                                     | }
    ; assembly                               | /* r2dec pseudo code output */
                                             | /* /logs/firmware/patool_extraction/rootfs.img_unblob_extracted/rootfs.img_extract/0-50593792.squashfs_v4_le_extract/usr/lib/libapr-1.so.0.7.0 @ 0x18648 */
                                             | #include <stdint.h>
                                             |  
    ; (fcn) sym.apr_pool_clear_debug ()      | void apr_pool_clear_debug () {
                                             |     do {
    0x00009d34 bx pc                         |         return void (*pc)() ();
    0x00018648 b.w 0x9d34                    |         
                                             |     } while (1);
                                             | }

[*] Function system used 1 times libapr-1.so.0.7.0