[*] Binary protection state of removesession.cgi

  
  	Full RELRO     Canary found      NX disabled  PIE enabled  No RPATH     No RUNPATH   No Symbols


[*] Function sprintf tear down of removesession.cgi

    ; assembly                               | /* r2dec pseudo code output */
                                             | /* /logs/firmware/unblob_extracted/firmware_extract/4325012-58052244.squashfs_v4_le_extract/usr/html/axis-cgi/removesession.cgi @ 0xb80 */
                                             | #include <stdint.h>
                                             |  
    ; (fcn) main ()                          | int32_t main () {
    0x00000b80 lui gp, 2                     |     
    0x00000b84 addiu gp, gp, -0x6b70         |     
    0x00000b88 addu gp, gp, t9               |     gp += t9;
    0x00000b8c addiu sp, sp, -0x78           |     
    0x00000b90 sw ra, 0x74(sp)               |     *(var_74h) = ra;
    0x00000b94 sw fp, 0x70(sp)               |     *(var_70h) = fp;
    0x00000b98 sw s7, 0x6c(sp)               |     *(var_6ch) = s7;
    0x00000b9c sw s6, 0x68(sp)               |     *(var_68h) = s6;
    0x00000ba0 sw s5, 0x64(sp)               |     *(var_64h) = s5;
    0x00000ba4 sw s4, 0x60(sp)               |     *(var_60h) = s4;
    0x00000ba8 sw s3, 0x5c(sp)               |     *(var_5ch) = s3;
    0x00000bac sw s2, 0x58(sp)               |     *(var_58h) = s2;
    0x00000bb0 sw s1, 0x54(sp)               |     *(var_54h) = s1;
    0x00000bb4 sw s0, 0x50(sp)               |     *(var_50h) = s0;
    0x00000bb8 move fp, sp                   |     fp = sp;
    0x00000bbc sw gp, 0x10(sp)               |     *(var_10h) = gp;
    0x00000bc0 sw a0, 0x78(fp)               |     *(arg_78h) = a0;
    0x00000bc4 sw a1, 0x1c(fp)               |     *(arg_1ch) = a1;
    0x00000bc8 lw v0, -0x7f6c(gp)            |     v0 = *((gp - 8155));
    0x00000bcc lw v0, (v0)                   |     v0 = *(v0);
    0x00000bd0 sw v0, 0x4c(fp)               |     *(arg_4ch) = v0;
    0x00000bd4 move v0, sp                   |     v0 = sp;
    0x00000bd8 sw v0, 0x18(fp)               |     *(arg_18h) = v0;
    0x00000bdc sw zero, 0x2c(fp)             |     *(arg_2ch) = 0;
    0x00000be0 sw zero, 0x28(fp)             |     *(arg_28h) = 0;
    0x00000be4 sw zero, 0x24(fp)             |     *(arg_24h) = 0;
    0x00000be8 lw v0, -0x7fd0(gp)            |     v0 = *((gp - 8180));
    0x00000bec addiu a0, v0, 0x1650          |     a0 = v0 + 0x1650;
    0x00000bf0 lw v0, -0x7f78(gp)            |     v0 = sym.imp.getenv;
    0x00000bf4 move t9, v0                   |     t9 = v0;
    0x00000bf8 jalr t9                       |     t9 ();
    0x00000bfc nop                           |     
    0x00000c00 lw gp, 0x10(fp)               |     gp = *(arg_10h);
                                             |     if (v0 != 0) {
    0x00000c04 beqz v0, 0xc30                |         
    0x00000c08 nop                           |         
    0x00000c0c lw v0, -0x7fd0(gp)            |         v0 = *((gp - 8180));
    0x00000c10 addiu a0, v0, 0x1650          |         a0 = v0 + 0x1650;
    0x00000c14 lw v0, -0x7f78(gp)            |         v0 = sym.imp.getenv;
    0x00000c18 move t9, v0                   |         t9 = v0;
    0x00000c1c jalr t9                       |         t9 ();
    0x00000c20 nop                           |         
    0x00000c24 lw gp, 0x10(fp)               |         gp = *(arg_10h);
    0x00000c28 b 0xc38                       |         goto label_0;
    0x00000c2c nop                           |         
                                             |     }
    0x00000c30 lw v0, -0x7fd0(gp)            |     v0 = *((gp - 8180));
    0x00000c34 addiu v0, v0, 0x165c          |     v0 += 0x165c;
                                             | label_0:
    0x00000c38 move a0, v0                   |     a0 = v0;
    0x00000c3c lw v0, -0x7f90(gp)            |     v0 = sym.imp.strlen;
    0x00000c40 move t9, v0                   |     t9 = v0;
    0x00000c44 jalr t9                       |     t9 ();
    0x00000c48 nop                           |     
    0x00000c4c lw gp, 0x10(fp)               |     gp = *(arg_10h);
    0x00000c50 addiu v0, v0, 0x41            |     v0 += 0x41;
    0x00000c54 move v1, v0                   |     v1 = v0;
    0x00000c58 addiu v1, v1, -1              |     v1 += -1;
    0x00000c5c sw v1, 0x34(fp)               |     *(arg_34h) = v1;
    0x00000c60 move s6, v0                   |     s6 = v0;
    0x00000c64 move s7, zero                 |     s7 = 0;
    0x00000c68 srl v1, s6, 0x1d              |     v1 = s6 >> 0x1d;
    0x00000c6c sll s3, s7, 3                 |     s3 = s7 << 3;
    0x00000c70 or s3, v1, s3                 |     s3 = v1 | s3;
    0x00000c74 sll s2, s6, 3                 |     s2 = s6 << 3;
    0x00000c78 move s4, v0                   |     s4 = v0;
    0x00000c7c move s5, zero                 |     s5 = 0;
    0x00000c80 srl v1, s4, 0x1d              |     v1 = s4 >> 0x1d;
    0x00000c84 sll s1, s5, 3                 |     s1 = s5 << 3;
    0x00000c88 or s1, v1, s1                 |     s1 = v1 | s1;
    0x00000c8c sll s0, s4, 3                 |     s0 = s4 << 3;
    0x00000c90 addiu v0, v0, 7               |     v0 += 7;
    0x00000c94 srl v0, v0, 3                 |     v0 >>= 3;
    0x00000c98 sll v0, v0, 3                 |     v0 <<= 3;
    0x00000c9c subu sp, sp, v0               |     
    0x00000ca0 addiu v0, sp, 0x10            |     v0 = sp + 0x10;
    0x00000ca4 addiu v0, v0, 0               |     v0 += 0;
    0x00000ca8 sw v0, 0x38(fp)               |     *(arg_38h) = v0;
    0x00000cac sw zero, 0x30(fp)             |     *(arg_30h) = 0;
    0x00000cb0 lw v0, -0x7fd0(gp)            |     v0 = *((gp - 8180));
    0x00000cb4 addiu a0, v0, 0x1670          |     a0 = v0 + str.QUERY_STRING;
    0x00000cb8 lw v0, -0x7f78(gp)            |     v0 = sym.imp.getenv;
    0x00000cbc move t9, v0                   |     t9 = v0;
    0x00000cc0 jalr t9                       |     t9 ();
    0x00000cc4 nop                           |     
    0x00000cc8 lw gp, 0x10(fp)               |     gp = *(arg_10h);
    0x00000ccc sw v0, 0x3c(fp)               |     *(arg_3ch) = v0;
    0x00000cd0 lw v0, -0x7fd0(gp)            |     v0 = *((gp - 8180));
    0x00000cd4 addiu a0, v0, 0x1680          |     a0 = v0 + str.Content_Type:_text_plain_r_n_r;
    0x00000cd8 lw v0, -0x7f7c(gp)            |     v0 = sym.imp.puts;
    0x00000cdc move t9, v0                   |     t9 = v0;
    0x00000ce0 jalr t9                       |     t9 ();
    0x00000ce4 nop                           |     
    0x00000ce8 lw gp, 0x10(fp)               |     gp = *(arg_10h);
    0x00000cec lw v0, 0x3c(fp)               |     v0 = *(arg_3ch);
                                             |     if (v0 == 0) {
    0x00000cf0 beqz v0, 0xeec                |         goto label_1;
                                             |     }
    0x00000cf4 nop                           |     
    0x00000cf8 lw v0, -0x7fd0(gp)            |     v0 = *((gp - 8180));
    0x00000cfc addiu a1, v0, 0x169c          |     a1 = v0 + str.sessionid;
    0x00000d00 lw a0, 0x3c(fp)               |     a0 = *(arg_3ch);
    0x00000d04 lw v0, -0x7f58(gp)            |     v0 = sym.imp.strstr;
    0x00000d08 move t9, v0                   |     t9 = v0;
    0x00000d0c jalr t9                       |     t9 ();
    0x00000d10 nop                           |     
    0x00000d14 lw gp, 0x10(fp)               |     gp = *(arg_10h);
    0x00000d18 sw v0, 0x40(fp)               |     *(arg_40h) = v0;
    0x00000d1c lw v0, 0x40(fp)               |     v0 = *(arg_40h);
                                             |     if (v0 == 0) {
    0x00000d20 beqz v0, 0xeec                |         goto label_1;
                                             |     }
    0x00000d24 nop                           |     
    0x00000d28 lw v0, 0x40(fp)               |     v0 = *(arg_40h);
    0x00000d2c addiu v0, v0, 0xa             |     v0 += 0xa;
    0x00000d30 sw v0, 0x40(fp)               |     *(arg_40h) = v0;
    0x00000d34 addiu a1, zero, 0x26          |     a1 = 0x26;
    0x00000d38 lw a0, 0x40(fp)               |     a0 = *(arg_40h);
    0x00000d3c lw v0, -0x7f8c(gp)            |     v0 = sym.imp.strchr;
    0x00000d40 move t9, v0                   |     t9 = v0;
    0x00000d44 jalr t9                       |     t9 ();
    0x00000d48 nop                           |     
    0x00000d4c lw gp, 0x10(fp)               |     gp = *(arg_10h);
    0x00000d50 sw v0, 0x44(fp)               |     *(arg_44h) = v0;
    0x00000d54 lw v0, 0x44(fp)               |     v0 = *(arg_44h);
                                             |     if (v0 != 0) {
    0x00000d58 beqz v0, 0xd68                |         
    0x00000d5c nop                           |         
    0x00000d60 lw v0, 0x44(fp)               |         v0 = *(arg_44h);
    0x00000d64 sb zero, (v0)                 |         *(v0) = 0;
                                             |     }
    0x00000d68 addiu a2, zero, -1            |     a2 = -1;
    0x00000d6c lw v0, -0x7fd0(gp)            |     v0 = *((gp - 8180));
    0x00000d70 addiu a1, v0, 0x16a8          |     a1 = v0 + 0x16a8;
    0x00000d74 lw a0, 0x40(fp)               |     a0 = *(arg_40h);
    0x00000d78 lw v0, -0x7f68(gp)            |     v0 = sym.imp.g_strsplit;
    0x00000d7c move t9, v0                   |     t9 = v0;
    0x00000d80 jalr t9                       |     t9 ();
    0x00000d84 nop                           |     
    0x00000d88 lw gp, 0x10(fp)               |     gp = *(arg_10h);
    0x00000d8c sw v0, 0x30(fp)               |     *(arg_30h) = v0;
    0x00000d90 b 0xed0                       |     goto label_2;
    0x00000d94 nop                           |     
                                             |     do {
    0x00000d98 lw v0, 0x24(fp)               |         v0 = *(arg_24h);
    0x00000d9c sll v0, v0, 2                 |         v0 <<= 2;
    0x00000da0 lw v1, 0x30(fp)               |         v1 = *(arg_30h);
    0x00000da4 addu v0, v1, v0               |         v0 = v1 + v0;
    0x00000da8 lw v0, (v0)                   |         v0 = *(v0);
    0x00000dac sw v0, 0x48(fp)               |         *(arg_48h) = v0;
    0x00000db0 lw a0, 0x48(fp)               |         a0 = *(arg_48h);
    0x00000db4 lw v0, -0x7fcc(gp)            |         v0 = sym.valid_sessionid;
    0x00000db8 move t9, v0                   |         t9 = v0;
    0x00000dbc bal 0xfd0                     |         sym_valid_sessionid ();
    0x00000dc0 nop                           |         
    0x00000dc4 lw gp, 0x10(fp)               |         gp = *(arg_10h);
                                             |         if (v0 != 0) {
    0x00000dc8 beqz v0, 0xebc                |             
    0x00000dcc nop                           |             
    0x00000dd0 lw s0, 0x38(fp)               |             s0 = *(arg_38h);
    0x00000dd4 lw v0, -0x7fd0(gp)            |             v0 = *((gp - 8180));
    0x00000dd8 addiu a0, v0, 0x1650          |             a0 = v0 + 0x1650;
    0x00000ddc lw v0, -0x7f78(gp)            |             v0 = sym.imp.getenv;
    0x00000de0 move t9, v0                   |             t9 = v0;
    0x00000de4 jalr t9                       |             t9 ();
    0x00000de8 nop                           |             
    0x00000dec lw gp, 0x10(fp)               |             gp = *(arg_10h);
                                             |             if (v0 != 0) {
    0x00000df0 beqz v0, 0xe1c                |                 
    0x00000df4 nop                           |                 
    0x00000df8 lw v0, -0x7fd0(gp)            |                 v0 = *((gp - 8180));
    0x00000dfc addiu a0, v0, 0x1650          |                 a0 = v0 + 0x1650;
    0x00000e00 lw v0, -0x7f78(gp)            |                 v0 = sym.imp.getenv;
    0x00000e04 move t9, v0                   |                 t9 = v0;
    0x00000e08 jalr t9                       |                 t9 ();
    0x00000e0c nop                           |                 
    0x00000e10 lw gp, 0x10(fp)               |                 gp = *(arg_10h);
    0x00000e14 b 0xe24                       |                 goto label_3;
    0x00000e18 nop                           |                 
                                             |             }
    0x00000e1c lw v0, -0x7fd0(gp)            |             v0 = *((gp - 8180));
    0x00000e20 addiu v0, v0, 0x165c          |             v0 += 0x165c;
                                             | label_3:
    0x00000e24 lw a3, 0x48(fp)               |             a3 = *(arg_48h);
    0x00000e28 move a2, v0                   |             a2 = v0;
    0x00000e2c lw v0, -0x7fd0(gp)            |             v0 = *((gp - 8180));
    0x00000e30 addiu a1, v0, 0x16ac          |             a1 = v0 + 0x16ac;
    0x00000e34 move a0, s0                   |             a0 = s0;
    0x00000e38 lw v0, -0x7fa8(gp)            |             v0 = sym.imp.sprintf
    0x00000e3c move t9, v0                   |             t9 = v0;
    0x00000e40 jalr t9                       |             t9 ();
    0x00000e44 nop                           |             
    0x00000e48 lw gp, 0x10(fp)               |             gp = *(arg_10h);
    0x00000e4c lw v0, 0x38(fp)               |             v0 = *(arg_38h);
    0x00000e50 move a0, v0                   |             a0 = v0;
    0x00000e54 lw v0, -0x7f74(gp)            |             v0 = sym.imp.unlink;
    0x00000e58 move t9, v0                   |             t9 = v0;
    0x00000e5c jalr t9                       |             t9 ();
    0x00000e60 nop                           |             
    0x00000e64 lw gp, 0x10(fp)               |             gp = *(arg_10h);
                                             |             if (v0 < 0) {
    0x00000e68 bgez v0, 0xea8                |                 
    0x00000e6c nop                           |                 
    0x00000e70 lw v0, -0x7fa0(gp)            |                 v0 = sym.imp.__errno_location;
    0x00000e74 move t9, v0                   |                 t9 = v0;
    0x00000e78 jalr t9                       |                 t9 ();
    0x00000e7c nop                           |                 
    0x00000e80 lw gp, 0x10(fp)               |                 gp = *(arg_10h);
    0x00000e84 lw v1, (v0)                   |                 v1 = *(v0);
    0x00000e88 addiu v0, zero, 2             |                 v0 = 2;
                                             |                 if (v1 == v0) {
    0x00000e8c beq v1, v0, 0xea8             |                     goto label_4;
                                             |                 }
    0x00000e90 nop                           |                 
    0x00000e94 lw v0, -0x7fd0(gp)            |                 v0 = *((gp - 8180));
    0x00000e98 addiu v0, v0, 0x16b4          |                 v0 += str.ERROR:_Failed_too_remove_session_id;
    0x00000e9c sw v0, 0x2c(fp)               |                 *(arg_2ch) = v0;
    0x00000ea0 b 0xeec                       |                 goto label_1;
    0x00000ea4 nop                           |                 
                                             |             }
                                             | label_4:
    0x00000ea8 lw v0, 0x24(fp)               |             v0 = *(arg_24h);
    0x00000eac addiu v0, v0, 1               |             v0++;
    0x00000eb0 sw v0, 0x24(fp)               |             *(arg_24h) = v0;
    0x00000eb4 b 0xed0                       |             goto label_2;
    0x00000eb8 nop                           |             
                                             |         }
    0x00000ebc lw v0, -0x7fd0(gp)            |         v0 = *((gp - 8180));
    0x00000ec0 addiu v0, v0, 0x16d8          |         v0 += str.ERROR:_Invalid_session_id;
    0x00000ec4 sw v0, 0x2c(fp)               |         *(arg_2ch) = v0;
    0x00000ec8 b 0xeec                       |         goto label_1;
    0x00000ecc nop                           |         
                                             | label_2:
    0x00000ed0 lw v0, 0x24(fp)               |         v0 = *(arg_24h);
    0x00000ed4 sll v0, v0, 2                 |         v0 <<= 2;
    0x00000ed8 lw v1, 0x30(fp)               |         v1 = *(arg_30h);
    0x00000edc addu v0, v1, v0               |         v0 = v1 + v0;
    0x00000ee0 lw v0, (v0)                   |         v0 = *(v0);
    0x00000ee4 bnez v0, 0xd98                |         
                                             |     } while (v0 != 0);
    0x00000ee8 nop                           |     
                                             | label_1:
    0x00000eec lw v0, 0x30(fp)               |     v0 = *(arg_30h);
                                             |     if (v0 != 0) {
    0x00000ef0 beqz v0, 0xf10                |         
    0x00000ef4 nop                           |         
    0x00000ef8 lw a0, 0x30(fp)               |         a0 = *(arg_30h);
    0x00000efc lw v0, -0x7fa4(gp)            |         v0 = sym.imp.g_strfreev;
    0x00000f00 move t9, v0                   |         t9 = v0;
    0x00000f04 jalr t9                       |         t9 ();
    0x00000f08 nop                           |         
    0x00000f0c lw gp, 0x10(fp)               |         gp = *(arg_10h);
                                             |     }
    0x00000f10 lw v0, 0x2c(fp)               |     v0 = *(arg_2ch);
                                             |     if (v0 != 0) {
    0x00000f14 beqz v0, 0xf4c                |         
    0x00000f18 nop                           |         
    0x00000f1c lw a1, 0x2c(fp)               |         a1 = *(arg_2ch);
    0x00000f20 lw v0, -0x7fd0(gp)            |         v0 = *((gp - 8180));
    0x00000f24 addiu a0, v0, 0x16f4          |         a0 = v0 + str._s_r_n;
    0x00000f28 lw v0, -0x7f64(gp)            |         v0 = sym.imp.printf;
    0x00000f2c move t9, v0                   |         t9 = v0;
    0x00000f30 jalr t9                       |         t9 ();
    0x00000f34 nop                           |         
    0x00000f38 lw gp, 0x10(fp)               |         gp = *(arg_10h);
    0x00000f3c addiu v0, zero, 1             |         v0 = 1;
    0x00000f40 sw v0, 0x28(fp)               |         *(arg_28h) = v0;
    0x00000f44 b 0xf68                       |         goto label_5;
    0x00000f48 nop                           |         
                                             |     }
    0x00000f4c lw v0, -0x7fd0(gp)            |     v0 = *((gp - 8180));
    0x00000f50 addiu a0, v0, 0x16fc          |     a0 = v0 + 0x16fc;
    0x00000f54 lw v0, -0x7f7c(gp)            |     v0 = sym.imp.puts;
    0x00000f58 move t9, v0                   |     t9 = v0;
    0x00000f5c jalr t9                       |     t9 ();
    0x00000f60 nop                           |     
    0x00000f64 lw gp, 0x10(fp)               |     gp = *(arg_10h);
                                             | label_5:
    0x00000f68 lw v0, 0x28(fp)               |     v0 = *(arg_28h);
    0x00000f6c lw sp, 0x18(fp)               |     
    0x00000f70 lw v1, -0x7f6c(gp)            |     v1 = *((gp - 8155));
    0x00000f74 lw a0, 0x4c(fp)               |     a0 = *(arg_4ch);
    0x00000f78 lw v1, (v1)                   |     v1 = *(v1);
                                             |     if (a0 != v1) {
    0x00000f7c beq a0, v1, 0xf94             |         
    0x00000f80 nop                           |         
    0x00000f84 lw v0, -0x7f70(gp)            |         v0 = sym.imp.__stack_chk_fail;
    0x00000f88 move t9, v0                   |         t9 = v0;
    0x00000f8c jalr t9                       |         t9 ();
    0x00000f90 nop                           |         
                                             |     }
    0x00000f94 move sp, fp                   |     
    0x00000f98 lw ra, 0x74(sp)               |     ra = *(var_74h);
    0x00000f9c lw fp, 0x70(sp)               |     fp = *(var_70h);
    0x00000fa0 lw s7, 0x6c(sp)               |     s7 = *(var_6ch);
    0x00000fa4 lw s6, 0x68(sp)               |     s6 = *(var_68h);
    0x00000fa8 lw s5, 0x64(sp)               |     s5 = *(var_64h);
    0x00000fac lw s4, 0x60(sp)               |     s4 = *(var_60h);
    0x00000fb0 lw s3, 0x5c(sp)               |     s3 = *(var_5ch);
    0x00000fb4 lw s2, 0x58(sp)               |     s2 = *(var_58h);
    0x00000fb8 lw s1, 0x54(sp)               |     s1 = *(var_54h);
    0x00000fbc lw s0, 0x50(sp)               |     s0 = *(var_50h);
    0x00000fc0 addiu sp, sp, 0x78            |     
    0x00000fc4 jr ra                         |     return v0;
    0x00000fc8 nop                           |     
                                             | }

[*] Function sprintf used 2 times removesession.cgi