[*] Binary protection state of createsession.cgi

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


[*] Function printf tear down of createsession.cgi

    ; assembly                           | /* r2dec pseudo code output */
                                         | /* /logs/firmware/unblob_extracted/firmware_extract/4325012-58052244.squashfs_v4_le_extract/usr/html/axis-cgi/createsession.cgi @ 0xdd0 */
                                         | #include <stdint.h>
                                         |  
    ; (fcn) sym.purge_old_sessions ()    | void purge_old_sessions () {
    0x00000dd0 lui gp, 2                 |     
    0x00000dd4 addiu gp, gp, -0x6dc0     |     
    0x00000dd8 addu gp, gp, t9           |     gp += t9;
    0x00000ddc addiu sp, sp, -0x2b8      |     
    0x00000de0 sw ra, 0x2b4(sp)          |     *(var_2b4h) = ra;
    0x00000de4 sw fp, 0x2b0(sp)          |     *(var_2b0h) = fp;
    0x00000de8 sw s7, 0x2ac(sp)          |     *(var_2ach) = s7;
    0x00000dec sw s6, 0x2a8(sp)          |     *(var_2a8h) = s6;
    0x00000df0 sw s5, 0x2a4(sp)          |     *(var_2a4h) = s5;
    0x00000df4 sw s4, 0x2a0(sp)          |     *(var_2a0h) = s4;
    0x00000df8 sw s3, 0x29c(sp)          |     *(var_29ch) = s3;
    0x00000dfc sw s2, 0x298(sp)          |     *(var_298h) = s2;
    0x00000e00 sw s1, 0x294(sp)          |     *(var_294h) = s1;
    0x00000e04 sw s0, 0x290(sp)          |     *(var_290h) = s0;
    0x00000e08 move fp, sp               |     fp = sp;
    0x00000e0c sw gp, 0x10(sp)           |     *(var_10h) = gp;
    0x00000e10 lw v0, -0x7f4c(gp)        |     v0 = *((gp - 8147));
    0x00000e14 lw v0, (v0)               |     v0 = *(v0);
    0x00000e18 sw v0, 0x28c(fp)          |     *(arg_28ch) = v0;
    0x00000e1c lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00000e20 addiu a0, v0, 0x1de0      |     a0 = v0 + 0x1de0;
    0x00000e24 lw v0, -0x7f5c(gp)        |     v0 = sym.imp.getenv;
    0x00000e28 move t9, v0               |     t9 = v0;
    0x00000e2c jalr t9                   |     t9 ();
    0x00000e30 nop                       |     
    0x00000e34 lw gp, 0x10(fp)           |     gp = *(arg_10h);
                                         |     if (v0 != 0) {
    0x00000e38 beqz v0, 0xe64            |         
    0x00000e3c nop                       |         
    0x00000e40 lw v0, -0x7fd0(gp)        |         v0 = *((gp - 8180));
    0x00000e44 addiu a0, v0, 0x1de0      |         a0 = v0 + 0x1de0;
    0x00000e48 lw v0, -0x7f5c(gp)        |         v0 = sym.imp.getenv;
    0x00000e4c move t9, v0               |         t9 = v0;
    0x00000e50 jalr t9                   |         t9 ();
    0x00000e54 nop                       |         
    0x00000e58 lw gp, 0x10(fp)           |         gp = *(arg_10h);
    0x00000e5c b 0xe6c                   |         goto label_1;
    0x00000e60 nop                       |         
                                         |     }
    0x00000e64 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00000e68 addiu v0, v0, 0x1dec      |     v0 += 0x1dec;
                                         | label_1:
    0x00000e6c move a0, v0               |     a0 = v0;
    0x00000e70 lw v0, -0x7fa0(gp)        |     v0 = sym.imp.opendir;
    0x00000e74 move t9, v0               |     t9 = v0;
    0x00000e78 jalr t9                   |     t9 ();
    0x00000e7c nop                       |     
    0x00000e80 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x00000e84 sw v0, 0x28(fp)           |     *(arg_28h) = v0;
    0x00000e88 lw v0, 0x28(fp)           |     v0 = *(arg_28h);
                                         |     if (v0 == 0) {
    0x00000e8c beqz v0, 0x121c           |         goto label_2;
                                         |     }
    0x00000e90 nop                       |     
    0x00000e94 move v0, sp               |     v0 = sp;
    0x00000e98 sw v0, 0x1c(fp)           |     *(arg_1ch) = v0;
    0x00000e9c lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00000ea0 addiu a0, v0, 0x1de0      |     a0 = v0 + 0x1de0;
    0x00000ea4 lw v0, -0x7f5c(gp)        |     v0 = sym.imp.getenv;
    0x00000ea8 move t9, v0               |     t9 = v0;
    0x00000eac jalr t9                   |     t9 ();
    0x00000eb0 nop                       |     
    0x00000eb4 lw gp, 0x10(fp)           |     gp = *(arg_10h);
                                         |     if (v0 != 0) {
    0x00000eb8 beqz v0, 0xee4            |         
    0x00000ebc nop                       |         
    0x00000ec0 lw v0, -0x7fd0(gp)        |         v0 = *((gp - 8180));
    0x00000ec4 addiu a0, v0, 0x1de0      |         a0 = v0 + 0x1de0;
    0x00000ec8 lw v0, -0x7f5c(gp)        |         v0 = sym.imp.getenv;
    0x00000ecc move t9, v0               |         t9 = v0;
    0x00000ed0 jalr t9                   |         t9 ();
    0x00000ed4 nop                       |         
    0x00000ed8 lw gp, 0x10(fp)           |         gp = *(arg_10h);
    0x00000edc b 0xeec                   |         goto label_3;
    0x00000ee0 nop                       |         
                                         |     }
    0x00000ee4 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00000ee8 addiu v0, v0, 0x1dec      |     v0 += 0x1dec;
                                         | label_3:
    0x00000eec move a0, v0               |     a0 = v0;
    0x00000ef0 lw v0, -0x7f74(gp)        |     v0 = sym.imp.strlen;
    0x00000ef4 move t9, v0               |     t9 = v0;
    0x00000ef8 jalr t9                   |     t9 ();
    0x00000efc nop                       |     
    0x00000f00 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x00000f04 addiu v0, v0, 0x41        |     v0 += 0x41;
    0x00000f08 move v1, v0               |     v1 = v0;
    0x00000f0c addiu v1, v1, -1          |     v1 += -1;
    0x00000f10 sw v1, 0x2c(fp)           |     *(arg_2ch) = v1;
    0x00000f14 move s6, v0               |     s6 = v0;
    0x00000f18 move s7, zero             |     s7 = 0;
    0x00000f1c srl v1, s6, 0x1d          |     v1 = s6 >> 0x1d;
    0x00000f20 sll s3, s7, 3             |     s3 = s7 << 3;
    0x00000f24 or s3, v1, s3             |     s3 = v1 | s3;
    0x00000f28 sll s2, s6, 3             |     s2 = s6 << 3;
    0x00000f2c move s4, v0               |     s4 = v0;
    0x00000f30 move s5, zero             |     s5 = 0;
    0x00000f34 srl v1, s4, 0x1d          |     v1 = s4 >> 0x1d;
    0x00000f38 sll s1, s5, 3             |     s1 = s5 << 3;
    0x00000f3c or s1, v1, s1             |     s1 = v1 | s1;
    0x00000f40 sll s0, s4, 3             |     s0 = s4 << 3;
    0x00000f44 addiu v0, v0, 7           |     v0 += 7;
    0x00000f48 srl v0, v0, 3             |     v0 >>= 3;
    0x00000f4c sll v0, v0, 3             |     v0 <<= 3;
    0x00000f50 subu sp, sp, v0           |     
    0x00000f54 addiu v0, sp, 0x10        |     v0 = sp + 0x10;
    0x00000f58 addiu v0, v0, 0           |     v0 += 0;
    0x00000f5c sw v0, 0x30(fp)           |     *(arg_30h) = v0;
    0x00000f60 addiu v0, fp, 0x48        |     v0 = fp + 0x48;
    0x00000f64 move a0, v0               |     a0 = v0;
    0x00000f68 lw v0, -0x7f64(gp)        |     v0 = sym.imp.sysinfo;
    0x00000f6c move t9, v0               |     t9 = v0;
    0x00000f70 jalr t9                   |     t9 ();
    0x00000f74 nop                       |     
    0x00000f78 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x00000f7c b 0x11d8                  |     goto label_4;
    0x00000f80 nop                       |     
                                         | label_0:
    0x00000f84 lw v0, 0x34(fp)           |     v0 = *(arg_34h);
    0x00000f88 lb v1, 0xb(v0)            |     v1 = *((v0 + 11));
    0x00000f8c addiu v0, zero, 0x2e      |     v0 = 0x2e;
                                         |     if (v1 == v0) {
    0x00000f90 bne v1, v0, 0xfa0         |         
    0x00000f94 nop                       |         
    0x00000f98 b 0x11d8                  |         goto label_4;
    0x00000f9c nop                       |         
                                         |     }
    0x00000fa0 lw s0, 0x30(fp)           |     s0 = *(arg_30h);
    0x00000fa4 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00000fa8 addiu a0, v0, 0x1de0      |     a0 = v0 + 0x1de0;
    0x00000fac lw v0, -0x7f5c(gp)        |     v0 = sym.imp.getenv;
    0x00000fb0 move t9, v0               |     t9 = v0;
    0x00000fb4 jalr t9                   |     t9 ();
    0x00000fb8 nop                       |     
    0x00000fbc lw gp, 0x10(fp)           |     gp = *(arg_10h);
                                         |     if (v0 != 0) {
    0x00000fc0 beqz v0, 0xff0            |         
    0x00000fc4 nop                       |         
    0x00000fc8 lw v0, -0x7fd0(gp)        |         v0 = *((gp - 8180));
    0x00000fcc addiu a0, v0, 0x1de0      |         a0 = v0 + 0x1de0;
    0x00000fd0 lw v0, -0x7f5c(gp)        |         v0 = sym.imp.getenv;
    0x00000fd4 move t9, v0               |         t9 = v0;
    0x00000fd8 jalr t9                   |         t9 ();
    0x00000fdc nop                       |         
    0x00000fe0 lw gp, 0x10(fp)           |         gp = *(arg_10h);
    0x00000fe4 move v1, v0               |         v1 = v0;
    0x00000fe8 b 0xff8                   |         goto label_5;
    0x00000fec nop                       |         
                                         |     }
    0x00000ff0 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00000ff4 addiu v1, v0, 0x1dec      |     v1 = v0 + 0x1dec;
                                         | label_5:
    0x00000ff8 lw v0, 0x34(fp)           |     v0 = *(arg_34h);
    0x00000ffc addiu v0, v0, 0xb         |     v0 += 0xb;
    0x00001000 move a3, v0               |     a3 = v0;
    0x00001004 move a2, v1               |     a2 = v1;
    0x00001008 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x0000100c addiu a1, v0, 0x1e00      |     a1 = v0 + 0x1e00;
    0x00001010 move a0, s0               |     a0 = s0;
    0x00001014 lw v0, -0x7f90(gp)        |     v0 = sym.imp.sprintf
    0x00001018 move t9, v0               |     t9 = v0;
    0x0000101c jalr t9                   |     t9 ();
    0x00001020 nop                       |     
    0x00001024 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x00001028 lw v0, 0x30(fp)           |     v0 = *(arg_30h);
    0x0000102c move a1, zero             |     a1 = 0;
    0x00001030 move a0, v0               |     a0 = v0;
    0x00001034 lw v0, -0x7f6c(gp)        |     v0 = sym.imp.open;
    0x00001038 move t9, v0               |     t9 = v0;
    0x0000103c jalr t9                   |     t9 ();
    0x00001040 nop                       |     
    0x00001044 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x00001048 sw v0, 0x38(fp)           |     *(arg_38h) = v0;
    0x0000104c lw v0, 0x38(fp)           |     v0 = *(arg_38h);
                                         |     if (v0 == 0) {
    0x00001050 beqz v0, 0x11d8           |         goto label_4;
                                         |     }
    0x00001054 nop                       |     
    0x00001058 addiu v0, fp, 0x88        |     v0 = fp + 0x88;
    0x0000105c addiu a2, zero, 0x200     |     a2 = 0x200;
    0x00001060 move a1, v0               |     a1 = v0;
    0x00001064 lw a0, 0x38(fp)           |     a0 = *(arg_38h);
    0x00001068 lw v0, -0x7f40(gp)        |     v0 = sym.imp.read;
    0x0000106c move t9, v0               |     t9 = v0;
    0x00001070 jalr t9                   |     t9 ();
    0x00001074 nop                       |     
    0x00001078 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x0000107c sw v0, 0x3c(fp)           |     *(arg_3ch) = v0;
    0x00001080 lw a0, 0x38(fp)           |     a0 = *(arg_38h);
    0x00001084 lw v0, -0x7f98(gp)        |     v0 = sym.imp.close;
    0x00001088 move t9, v0               |     t9 = v0;
    0x0000108c jalr t9                   |     t9 ();
    0x00001090 nop                       |     
    0x00001094 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x00001098 lw v1, 0x3c(fp)           |     v1 = *(arg_3ch);
    0x0000109c addiu v0, zero, -1        |     v0 = -1;
                                         |     if (v1 == v0) {
    0x000010a0 beq v1, v0, 0x11d8        |         goto label_4;
                                         |     }
    0x000010a4 nop                       |     
    0x000010a8 addiu v0, fp, 0x88        |     v0 = fp + 0x88;
    0x000010ac sw v0, 0x24(fp)           |     *(arg_24h) = v0;
    0x000010b0 addiu v0, fp, 0x88        |     v0 = fp + 0x88;
    0x000010b4 sw v0, 0x20(fp)           |     *(arg_20h) = v0;
    0x000010b8 lw v0, 0x3c(fp)           |     v0 = *(arg_3ch);
    0x000010bc addiu v1, fp, 0x290       |     v1 = fp + 0x290;
    0x000010c0 addu v0, v1, v0           |     v0 = v1 + v0;
    0x000010c4 sb zero, -0x208(v0)       |     *((v0 - 520)) = 0;
    0x000010c8 b 0x11b0                  |     goto label_6;
    0x000010cc nop                       |     
                                         |     do {
    0x000010d0 addiu a1, zero, 0xa       |         a1 = 0xa;
    0x000010d4 lw a0, 0x24(fp)           |         a0 = *(arg_24h);
    0x000010d8 lw v0, -0x7f70(gp)        |         v0 = sym.imp.strchr;
    0x000010dc move t9, v0               |         t9 = v0;
    0x000010e0 jalr t9                   |         t9 ();
    0x000010e4 nop                       |         
    0x000010e8 lw gp, 0x10(fp)           |         gp = *(arg_10h);
    0x000010ec sw v0, 0x40(fp)           |         *(arg_40h) = v0;
    0x000010f0 lw v0, 0x40(fp)           |         v0 = *(arg_40h);
                                         |         if (v0 != 0) {
    0x000010f4 beqz v0, 0x1110           |             
    0x000010f8 nop                       |             
    0x000010fc lw v0, 0x40(fp)           |             v0 = *(arg_40h);
    0x00001100 sb zero, (v0)             |             *(v0) = 0;
    0x00001104 lw v0, 0x40(fp)           |             v0 = *(arg_40h);
    0x00001108 addiu v0, v0, 1           |             v0++;
    0x0000110c sw v0, 0x20(fp)           |             *(arg_20h) = v0;
                                         |         }
    0x00001110 addiu a2, zero, 8         |         a2 = 8;
    0x00001114 lw v0, -0x7fd0(gp)        |         v0 = *((gp - 8180));
    0x00001118 addiu a1, v0, 0x1e08      |         a1 = v0 + str.VALIDTO;
    0x0000111c lw a0, 0x24(fp)           |         a0 = *(arg_24h);
    0x00001120 lw v0, -0x7f50(gp)        |         v0 = sym.imp.memcmp;
    0x00001124 move t9, v0               |         t9 = v0;
    0x00001128 jalr t9                   |         t9 ();
    0x0000112c nop                       |         
    0x00001130 lw gp, 0x10(fp)           |         gp = *(arg_10h);
                                         |         if (v0 == 0) {
    0x00001134 bnez v0, 0x11a8           |             
    0x00001138 nop                       |             
    0x0000113c lw v0, 0x24(fp)           |             v0 = *(arg_24h);
    0x00001140 addiu v0, v0, 8           |             v0 += 8;
    0x00001144 move a0, v0               |             a0 = v0;
    0x00001148 lw v0, -0x7f80(gp)        |             v0 = sym.imp.atol;
    0x0000114c move t9, v0               |             t9 = v0;
    0x00001150 jalr t9                   |             t9 ();
    0x00001154 nop                       |             
    0x00001158 lw gp, 0x10(fp)           |             gp = *(arg_10h);
    0x0000115c sw v0, 0x44(fp)           |             *(arg_44h) = v0;
    0x00001160 lw v0, 0x44(fp)           |             v0 = *(arg_44h);
                                         |             if (v0 == 0) {
    0x00001164 beqz v0, 0x11d4           |                 goto label_7;
                                         |             }
    0x00001168 nop                       |             
    0x0000116c lw v0, 0x48(fp)           |             v0 = *(arg_48h);
    0x00001170 move v1, v0               |             v1 = v0;
    0x00001174 lw v0, 0x44(fp)           |             v0 = *(arg_44h);
    0x00001178 sltu v0, v0, v1           |             v0 = (v0 < v1) ? 1 : 0;
                                         |             if (v0 == 0) {
    0x0000117c beqz v0, 0x11d4           |                 goto label_7;
                                         |             }
    0x00001180 nop                       |             
    0x00001184 lw v0, 0x30(fp)           |             v0 = *(arg_30h);
    0x00001188 move a0, v0               |             a0 = v0;
    0x0000118c lw v0, -0x7f58(gp)        |             v0 = sym.imp.unlink;
    0x00001190 move t9, v0               |             t9 = v0;
    0x00001194 jalr t9                   |             t9 ();
    0x00001198 nop                       |             
    0x0000119c lw gp, 0x10(fp)           |             gp = *(arg_10h);
    0x000011a0 b 0x11d4                  |             goto label_7;
    0x000011a4 nop                       |             
                                         |         }
    0x000011a8 lw v0, 0x20(fp)           |         v0 = *(arg_20h);
    0x000011ac sw v0, 0x24(fp)           |         *(arg_24h) = v0;
                                         | label_6:
    0x000011b0 lw v0, 0x24(fp)           |         v0 = *(arg_24h);
    0x000011b4 lb v0, (v0)               |         v0 = *(v0);
                                         |         if (v0 == 0) {
    0x000011b8 beqz v0, 0x11d8           |             goto label_4;
                                         |         }
    0x000011bc nop                       |         
    0x000011c0 lw v0, 0x20(fp)           |         v0 = *(arg_20h);
    0x000011c4 bnez v0, 0x10d0           |         
                                         |     } while (v0 != 0);
    0x000011c8 nop                       |     
    0x000011cc b 0x11d8                  |     goto label_4;
    0x000011d0 nop                       |     
                                         | label_7:
    0x000011d4 nop                       |     
                                         | label_4:
    0x000011d8 lw a0, 0x28(fp)           |     a0 = *(arg_28h);
    0x000011dc lw v0, -0x7f88(gp)        |     v0 = sym.imp.readdir;
    0x000011e0 move t9, v0               |     t9 = v0;
    0x000011e4 jalr t9                   |     t9 ();
    0x000011e8 nop                       |     
    0x000011ec lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x000011f0 sw v0, 0x34(fp)           |     *(arg_34h) = v0;
    0x000011f4 lw v0, 0x34(fp)           |     v0 = *(arg_34h);
                                         |     if (v0 != 0) {
    0x000011f8 bnez v0, 0xf84            |         goto label_0;
                                         |     }
    0x000011fc nop                       |     
    0x00001200 lw a0, 0x28(fp)           |     a0 = *(arg_28h);
    0x00001204 lw v0, -0x7f9c(gp)        |     v0 = sym.imp.closedir;
    0x00001208 move t9, v0               |     t9 = v0;
    0x0000120c jalr t9                   |     t9 ();
    0x00001210 nop                       |     
    0x00001214 lw gp, 0x10(fp)           |     gp = *(arg_10h);
    0x00001218 lw sp, 0x1c(fp)           |     
                                         | label_2:
    0x0000121c nop                       |     
    0x00001220 lw v0, -0x7f4c(gp)        |     v0 = *((gp - 8147));
    0x00001224 lw v1, 0x28c(fp)          |     v1 = *(arg_28ch);
    0x00001228 lw v0, (v0)               |     v0 = *(v0);
                                         |     if (v1 != v0) {
    0x0000122c beq v1, v0, 0x1244        |         
    0x00001230 nop                       |         
    0x00001234 lw v0, -0x7f54(gp)        |         v0 = sym.imp.__stack_chk_fail;
    0x00001238 move t9, v0               |         t9 = v0;
    0x0000123c jalr t9                   |         t9 ();
    0x00001240 nop                       |         
                                         |     }
    0x00001244 move sp, fp               |     
    0x00001248 lw ra, 0x2b4(sp)          |     ra = *(var_2b4h);
    0x0000124c lw fp, 0x2b0(sp)          |     fp = *(var_2b0h);
    0x00001250 lw s7, 0x2ac(sp)          |     s7 = *(var_2ach);
    0x00001254 lw s6, 0x2a8(sp)          |     s6 = *(var_2a8h);
    0x00001258 lw s5, 0x2a4(sp)          |     s5 = *(var_2a4h);
    0x0000125c lw s4, 0x2a0(sp)          |     s4 = *(var_2a0h);
    0x00001260 lw s3, 0x29c(sp)          |     s3 = *(var_29ch);
    0x00001264 lw s2, 0x298(sp)          |     s2 = *(var_298h);
    0x00001268 lw s1, 0x294(sp)          |     s1 = *(var_294h);
    0x0000126c lw s0, 0x290(sp)          |     s0 = *(var_290h);
    0x00001270 addiu sp, sp, 0x2b8       |     
    0x00001274 jr ra                     |     return v0;
    0x00001278 nop                       |     
                                         | }
    ; assembly                           | /* r2dec pseudo code output */
                                         | /* /logs/firmware/unblob_extracted/firmware_extract/4325012-58052244.squashfs_v4_le_extract/usr/html/axis-cgi/createsession.cgi @ 0x1820 */
                                         | #include <stdint.h>
                                         |  
    ; (fcn) sym.write_session_file ()    | void write_session_file () {
    0x00001820 lui gp, 2                 |     
    0x00001824 addiu gp, gp, -0x7810     |     
    0x00001828 addu gp, gp, t9           |     gp += t9;
    0x0000182c addiu sp, sp, -0x2c8      |     
    0x00001830 sw ra, 0x2c4(sp)          |     *(var_2c4h) = ra;
    0x00001834 sw fp, 0x2c0(sp)          |     *(var_2c0h) = fp;
    0x00001838 sw s7, 0x2bc(sp)          |     *(var_2bch) = s7;
    0x0000183c sw s6, 0x2b8(sp)          |     *(var_2b8h) = s6;
    0x00001840 sw s5, 0x2b4(sp)          |     *(var_2b4h) = s5;
    0x00001844 sw s4, 0x2b0(sp)          |     *(var_2b0h) = s4;
    0x00001848 sw s3, 0x2ac(sp)          |     *(var_2ach) = s3;
    0x0000184c sw s2, 0x2a8(sp)          |     *(var_2a8h) = s2;
    0x00001850 sw s1, 0x2a4(sp)          |     *(var_2a4h) = s1;
    0x00001854 sw s0, 0x2a0(sp)          |     *(var_2a0h) = s0;
    0x00001858 move fp, sp               |     fp = sp;
    0x0000185c sw gp, 0x28(sp)           |     *(var_28h) = gp;
    0x00001860 sw a0, 0x3c(fp)           |     *(arg_3ch) = a0;
    0x00001864 sw a1, 0x38(fp)           |     *(arg_38h) = a1;
    0x00001868 sw a2, 0x2d0(fp)          |     *(arg_2d0h) = a2;
    0x0000186c sw a3, 0x2d4(fp)          |     *(arg_2d4h) = a3;
    0x00001870 lw v0, 0x2dc(fp)          |     v0 = *(arg_2dch);
    0x00001874 sw v0, 0x34(fp)           |     *(arg_34h) = v0;
    0x00001878 lw v0, -0x7f4c(gp)        |     v0 = *((gp - 8147));
    0x0000187c lw v0, (v0)               |     v0 = *(v0);
    0x00001880 sw v0, 0x29c(fp)          |     *(arg_29ch) = v0;
    0x00001884 move v0, sp               |     v0 = sp;
    0x00001888 sw v0, 0x30(fp)           |     *(arg_30h) = v0;
    0x0000188c lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00001890 addiu a0, v0, 0x1ed0      |     a0 = v0 + str.SESSION_DIR;
    0x00001894 lw v0, -0x7f5c(gp)        |     v0 = sym.imp.getenv;
    0x00001898 move t9, v0               |     t9 = v0;
    0x0000189c jalr t9                   |     t9 ();
    0x000018a0 nop                       |     
    0x000018a4 lw gp, 0x28(fp)           |     gp = *(arg_28h);
                                         |     if (v0 != 0) {
    0x000018a8 beqz v0, 0x18d4           |         
    0x000018ac nop                       |         
    0x000018b0 lw v0, -0x7fd0(gp)        |         v0 = *((gp - 8180));
    0x000018b4 addiu a0, v0, 0x1ed0      |         a0 = v0 + str.SESSION_DIR;
    0x000018b8 lw v0, -0x7f5c(gp)        |         v0 = sym.imp.getenv;
    0x000018bc move t9, v0               |         t9 = v0;
    0x000018c0 jalr t9                   |         t9 ();
    0x000018c4 nop                       |         
    0x000018c8 lw gp, 0x28(fp)           |         gp = *(arg_28h);
    0x000018cc b 0x18dc                  |         goto label_0;
    0x000018d0 nop                       |         
                                         |     }
    0x000018d4 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x000018d8 addiu v0, v0, 0x1edc      |     v0 += str._var_run_session_;
                                         | label_0:
    0x000018dc move a0, v0               |     a0 = v0;
    0x000018e0 lw v0, -0x7f74(gp)        |     v0 = sym.imp.strlen;
    0x000018e4 move t9, v0               |     t9 = v0;
    0x000018e8 jalr t9                   |     t9 ();
    0x000018ec nop                       |     
    0x000018f0 lw gp, 0x28(fp)           |     gp = *(arg_28h);
    0x000018f4 addiu v0, v0, 0x41        |     v0 += 0x41;
    0x000018f8 move v1, v0               |     v1 = v0;
    0x000018fc addiu v1, v1, -1          |     v1 += -1;
    0x00001900 sw v1, 0x44(fp)           |     *(arg_44h) = v1;
    0x00001904 move s6, v0               |     s6 = v0;
    0x00001908 move s7, zero             |     s7 = 0;
    0x0000190c srl v1, s6, 0x1d          |     v1 = s6 >> 0x1d;
    0x00001910 sll s3, s7, 3             |     s3 = s7 << 3;
    0x00001914 or s3, v1, s3             |     s3 = v1 | s3;
    0x00001918 sll s2, s6, 3             |     s2 = s6 << 3;
    0x0000191c move s4, v0               |     s4 = v0;
    0x00001920 move s5, zero             |     s5 = 0;
    0x00001924 srl v1, s4, 0x1d          |     v1 = s4 >> 0x1d;
    0x00001928 sll s1, s5, 3             |     s1 = s5 << 3;
    0x0000192c or s1, v1, s1             |     s1 = v1 | s1;
    0x00001930 sll s0, s4, 3             |     s0 = s4 << 3;
    0x00001934 addiu v0, v0, 7           |     v0 += 7;
    0x00001938 srl v0, v0, 3             |     v0 >>= 3;
    0x0000193c sll v0, v0, 3             |     v0 <<= 3;
    0x00001940 subu sp, sp, v0           |     
    0x00001944 addiu v0, sp, 0x28        |     v0 = sp + 0x28;
    0x00001948 addiu v0, v0, 0           |     v0 += 0;
    0x0000194c sw v0, 0x48(fp)           |     *(arg_48h) = v0;
    0x00001950 sw zero, 0x40(fp)         |     *(arg_40h) = 0;
    0x00001954 lw s0, 0x48(fp)           |     s0 = *(arg_48h);
    0x00001958 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x0000195c addiu a0, v0, 0x1ed0      |     a0 = v0 + str.SESSION_DIR;
    0x00001960 lw v0, -0x7f5c(gp)        |     v0 = sym.imp.getenv;
    0x00001964 move t9, v0               |     t9 = v0;
    0x00001968 jalr t9                   |     t9 ();
    0x0000196c nop                       |     
    0x00001970 lw gp, 0x28(fp)           |     gp = *(arg_28h);
                                         |     if (v0 != 0) {
    0x00001974 beqz v0, 0x19a0           |         
    0x00001978 nop                       |         
    0x0000197c lw v0, -0x7fd0(gp)        |         v0 = *((gp - 8180));
    0x00001980 addiu a0, v0, 0x1ed0      |         a0 = v0 + str.SESSION_DIR;
    0x00001984 lw v0, -0x7f5c(gp)        |         v0 = sym.imp.getenv;
    0x00001988 move t9, v0               |         t9 = v0;
    0x0000198c jalr t9                   |         t9 ();
    0x00001990 nop                       |         
    0x00001994 lw gp, 0x28(fp)           |         gp = *(arg_28h);
    0x00001998 b 0x19a8                  |         goto label_1;
    0x0000199c nop                       |         
                                         |     }
    0x000019a0 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x000019a4 addiu v0, v0, 0x1edc      |     v0 += str._var_run_session_;
                                         | label_1:
    0x000019a8 lw a3, 0x3c(fp)           |     a3 = *(arg_3ch);
    0x000019ac move a2, v0               |     a2 = v0;
    0x000019b0 lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x000019b4 addiu a1, v0, 0x1ef0      |     a1 = v0 + str._s_s;
    0x000019b8 move a0, s0               |     a0 = s0;
    0x000019bc lw v0, -0x7f90(gp)        |     v0 = sym.imp.sprintf
    0x000019c0 move t9, v0               |     t9 = v0;
    0x000019c4 jalr t9                   |     t9 ();
    0x000019c8 nop                       |     
    0x000019cc lw gp, 0x28(fp)           |     gp = *(arg_28h);
    0x000019d0 lw v0, 0x48(fp)           |     v0 = *(arg_48h);
    0x000019d4 addiu a2, zero, 0x180     |     a2 = 0x180;
    0x000019d8 addiu a1, zero, 0x301     |     a1 = 0x301;
    0x000019dc move a0, v0               |     a0 = v0;
    0x000019e0 lw v0, -0x7f6c(gp)        |     v0 = sym.imp.open;
    0x000019e4 move t9, v0               |     t9 = v0;
    0x000019e8 jalr t9                   |     t9 ();
    0x000019ec nop                       |     
    0x000019f0 lw gp, 0x28(fp)           |     gp = *(arg_28h);
    0x000019f4 sw v0, 0x4c(fp)           |     *(arg_4ch) = v0;
    0x000019f8 lw v1, 0x4c(fp)           |     v1 = *(arg_4ch);
    0x000019fc addiu v0, zero, -1        |     v0 = -1;
                                         |     if (v1 != v0) {
    0x00001a00 beq v1, v0, 0x1b0c        |         
    0x00001a04 nop                       |         
    0x00001a08 lw v0, 0x2d0(fp)          |         v0 = *(arg_2d0h);
                                         |         if (v0 == 0) {
    0x00001a0c bnez v0, 0x1a1c           |             
    0x00001a10 nop                       |             
    0x00001a14 addiu v0, zero, 0x1e      |             v0 = 0x1e;
    0x00001a18 sw v0, 0x2d0(fp)          |             *(arg_2d0h) = v0;
                                         |         }
    0x00001a1c addiu v0, fp, 0x58        |         v0 = fp + 0x58;
    0x00001a20 move a0, v0               |         a0 = v0;
    0x00001a24 lw v0, -0x7f64(gp)        |         v0 = sym.imp.sysinfo;
    0x00001a28 move t9, v0               |         t9 = v0;
    0x00001a2c jalr t9                   |         t9 ();
    0x00001a30 nop                       |         
    0x00001a34 lw gp, 0x28(fp)           |         gp = *(arg_28h);
    0x00001a38 lw v0, 0x58(fp)           |         v0 = *(arg_58h);
    0x00001a3c move v1, v0               |         v1 = v0;
    0x00001a40 lw v0, 0x2d0(fp)          |         v0 = *(arg_2d0h);
    0x00001a44 addu v0, v0, v1           |         v0 += v1;
    0x00001a48 sw v0, 0x50(fp)           |         *(arg_50h) = v0;
    0x00001a4c lw v0, 0x58(fp)           |         v0 = *(arg_58h);
    0x00001a50 addiu a0, fp, 0x98        |         a0 = fp + 0x98;
    0x00001a54 lw v1, 0x34(fp)           |         v1 = *(arg_34h);
    0x00001a58 sw v1, 0x24(sp)           |         *(var_24h) = v1;
    0x00001a5c lw v1, 0x2d8(fp)          |         v1 = *(arg_2d8h);
    0x00001a60 sw v1, 0x20(sp)           |         *(var_20h) = v1;
    0x00001a64 lw v1, 0x2d4(fp)          |         v1 = *(arg_2d4h);
    0x00001a68 sw v1, 0x1c(sp)           |         *(var_1ch) = v1;
    0x00001a6c lw v1, 0x50(fp)           |         v1 = *(arg_50h);
    0x00001a70 sw v1, 0x18(sp)           |         *(var_18h) = v1;
    0x00001a74 lw v1, 0x2d0(fp)          |         v1 = *(arg_2d0h);
    0x00001a78 sw v1, 0x14(sp)           |         *(var_14h) = v1;
    0x00001a7c sw v0, 0x10(sp)           |         *(var_10h) = v0;
    0x00001a80 lw a3, 0x38(fp)           |         a3 = *(arg_38h);
    0x00001a84 lw v0, -0x7fd0(gp)        |         v0 = *((gp - 8180));
    0x00001a88 addiu a2, v0, 0x1ef8      |         a2 = v0 + str.URL_s_nCREATED_lu_nVALIDTIME_lu_nVALIDTO_lu_nDURATION_lu_nREFRESH_lu_nPARAMETERS_s_n;
    0x00001a8c addiu a1, zero, 0x200     |         a1 = 0x200;
    0x00001a90 lw v0, -0x7f84(gp)        |         v0 = sym.imp.snprintf
    0x00001a94 move t9, v0               |         t9 = v0;
    0x00001a98 jalr t9                   |         t9 ();
    0x00001a9c nop                       |         
    0x00001aa0 lw gp, 0x28(fp)           |         gp = *(arg_28h);
    0x00001aa4 sw v0, 0x54(fp)           |         *(arg_54h) = v0;
    0x00001aa8 lw v0, 0x54(fp)           |         v0 = *(arg_54h);
    0x00001aac addiu v1, fp, 0x98        |         v1 = fp + 0x98;
    0x00001ab0 move a2, v0               |         a2 = v0;
    0x00001ab4 move a1, v1               |         a1 = v1;
    0x00001ab8 lw a0, 0x4c(fp)           |         a0 = *(arg_4ch);
    0x00001abc lw v0, -0x7f7c(gp)        |         v0 = sym.imp.write;
    0x00001ac0 move t9, v0               |         t9 = v0;
    0x00001ac4 jalr t9                   |         t9 ();
    0x00001ac8 nop                       |         
    0x00001acc lw gp, 0x28(fp)           |         gp = *(arg_28h);
    0x00001ad0 move v1, v0               |         v1 = v0;
    0x00001ad4 lw v0, 0x54(fp)           |         v0 = *(arg_54h);
                                         |         if (v0 != v1) {
    0x00001ad8 beq v0, v1, 0x1aec        |             
    0x00001adc nop                       |             
    0x00001ae0 lw v0, -0x7fd0(gp)        |             v0 = *((gp - 8180));
    0x00001ae4 addiu v0, v0, 0x1f54      |             v0 += str.ERROR:_Failed_to_write_sessioninfo;
    0x00001ae8 sw v0, 0x40(fp)           |             *(arg_40h) = v0;
                                         |         }
    0x00001aec lw a0, 0x4c(fp)           |         a0 = *(arg_4ch);
    0x00001af0 lw v0, -0x7f98(gp)        |         v0 = sym.imp.close;
    0x00001af4 move t9, v0               |         t9 = v0;
    0x00001af8 jalr t9                   |         t9 ();
    0x00001afc nop                       |         
    0x00001b00 lw gp, 0x28(fp)           |         gp = *(arg_28h);
    0x00001b04 b 0x1b18                  |         goto label_2;
    0x00001b08 nop                       |         
                                         |     }
    0x00001b0c lw v0, -0x7fd0(gp)        |     v0 = *((gp - 8180));
    0x00001b10 addiu v0, v0, 0x1f78      |     v0 += str.ERROR:_Failed_to_create_session;
    0x00001b14 sw v0, 0x40(fp)           |     *(arg_40h) = v0;
                                         | label_2:
    0x00001b18 lw v0, 0x40(fp)           |     v0 = *(arg_40h);
    0x00001b1c lw sp, 0x30(fp)           |     
    0x00001b20 lw v1, -0x7f4c(gp)        |     v1 = *((gp - 8147));
    0x00001b24 lw a0, 0x29c(fp)          |     a0 = *(arg_29ch);
    0x00001b28 lw v1, (v1)               |     v1 = *(v1);
                                         |     if (a0 != v1) {
    0x00001b2c beq a0, v1, 0x1b44        |         
    0x00001b30 nop                       |         
    0x00001b34 lw v0, -0x7f54(gp)        |         v0 = sym.imp.__stack_chk_fail;
    0x00001b38 move t9, v0               |         t9 = v0;
    0x00001b3c jalr t9                   |         t9 ();
    0x00001b40 nop                       |         
                                         |     }
    0x00001b44 move sp, fp               |     
    0x00001b48 lw ra, 0x2c4(sp)          |     ra = *(var_2c4h);
    0x00001b4c lw fp, 0x2c0(sp)          |     fp = *(var_2c0h);
    0x00001b50 lw s7, 0x2bc(sp)          |     s7 = *(var_2bch);
    0x00001b54 lw s6, 0x2b8(sp)          |     s6 = *(var_2b8h);
    0x00001b58 lw s5, 0x2b4(sp)          |     s5 = *(var_2b4h);
    0x00001b5c lw s4, 0x2b0(sp)          |     s4 = *(var_2b0h);
    0x00001b60 lw s3, 0x2ac(sp)          |     s3 = *(var_2ach);
    0x00001b64 lw s2, 0x2a8(sp)          |     s2 = *(var_2a8h);
    0x00001b68 lw s1, 0x2a4(sp)          |     s1 = *(var_2a4h);
    0x00001b6c lw s0, 0x2a0(sp)          |     s0 = *(var_2a0h);
    0x00001b70 addiu sp, sp, 0x2c8       |     
    0x00001b74 jr ra                     |     return v0;
    0x00001b78 nop                       |     
                                         | }

[*] Function printf used 4 times createsession.cgi