1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147
| #include <iostream> #include <stdio.h> #include <windows.h>
using namespace std; unsigned char ida_chars[] = { 0x0A, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x0C, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x21, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x09, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x51, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x24, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x0C, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x25, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x36, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x41, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x25, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x09, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x41, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x0C, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x22, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x3F, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x34, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x32, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x72, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x33, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x18, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0xA7, 0xFF, 0xFF, 0xFF, 0x07, 0x00, 0x00, 0x00, 0x31, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0xF1, 0xFF, 0xFF, 0xFF, 0x07, 0x00, 0x00, 0x00, 0x28, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x84, 0xFF, 0xFF, 0xFF, 0x07, 0x00, 0x00, 0x00, 0xC1, 0xFF, 0xFF, 0xFF, 0x07, 0x00, 0x00, 0x00, 0x1E, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x7A, 0x00, 0x00, 0x00 }; unsigned char opcode[114] = {0}; unsigned char input[1024] = "jcskanbcjkasbncjkascbnjksac"; int main() { for(size_t i = 0; i< 456; i++) { memcpy(&opcode[i], &ida_chars[i*4], 4); } int result; char v4; int v5; int v6; int v7; int v8; int v9;
v9 = 0; v8 = 0; v7 = 0; v6 = 0; v5 = 0; while ( 1 ) { result = v9; if ( v9 >= 114 ) return result; switch ( opcode[v9] ) { case 1: input[v6 + 100] = v4; printf("%x\t#1\tinput[v6(%d) + 100](%d) = v4(%d);\n",v9,v6,input[v6+100],v4); ++v9; ++v6; ++v8; break; case 2: v4 = opcode[v9 + 1] + input[v8]; printf("%x\t#2\tv4(%d) = opcode[v9(%d) + 1](%d) + input[v8(%d)](%d);\n",v9,v4,v9,opcode[v9+1],v8,input[v8]); v9 += 2; break; case 3: v4 = input[v8] - LOBYTE(opcode[v9 + 1]); printf("%x\t#3\tv4(%d) = input[v8(%d)](%d) - LOBYTE(opcode[v9(%d) + 1](%d));\n",v9,v4,v8,input[v8],v9,opcode[v9+1]); v9 += 2; break; case 4: v4 = opcode[v9 + 1] ^ input[v8]; printf("%x\t#4\tv4(%d) = opcode[v9(%d) + 1](%d) ^ input[v8(%d)](%d);\n",v9,v4,v9,opcode[v9+1],v8,input[v8]); v9 += 2; break; case 5: v4 = opcode[v9 + 1] * input[v8]; printf("%x\t#4\tv4(%d) = opcode[v9(%d) + 1](%d) * input[v8(%d)](%d);\n",v9,v4,v9,opcode[v9+1],v8,input[v8]); v9 += 2; break; case 6: ++v9; break; case 7: if ( input[v7 + 100] != opcode[v9 + 1] ) { printf("%x\t#7\tinput[v7(%d) + 100](%d) != opcode[v9(%d) + 1](%d)\n",v9,v7,input[v7+100],v9,opcode[v9+1]); printf("what a shame...\n"); } ++v7; v9 += 2; break; case 8: input[v5] = v4; printf("%x\t#8\tinput[v5(%d)](%d) = v4(%d);\n",v9,v5,input[v5],v4); ++v9; ++v5; break; case 10: ++v9; break; case 11: v4 = input[v8] - 1; printf("%x\t#11\tv4(%d) = input[v8(%d)](%d) - 1;\n",v9,v4,v8,input[v8]); ++v9; break; case 12: v4 = input[v8] + 1; printf("%x\t#11\tv4(%d) = input[v8(%d)](%d) + 1;\n",v9,v4,v8,input[v8]); ++v9; break; default: continue; } } }
|