Function Graph 0
Basic Block 0
Opcode: 55sub_804973e:
Opcode: 55push ebp
Opcode: 89 e5mov ebp, esp
Opcode: 56push esi
Opcode: 83 ec 64sub esp, 0x64 {var_6c}
Opcode: 8b 45 08mov eax, dword [ebp+data_8 {arg_4}]
Opcode: 89 45 f8mov dword [ebp-0x8 {var_c}], eax
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: e8 69 23 00 00call sub_804babc
Opcode: 90nop
Opcode: 85 c0test eax, eax
Opcode: 0f 84 2e 0f 00 00je 0x804a68a
Basic Block 1
Opcode: b8 10 00 00 00mov eax, data_10
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: 89 45 ecmov dword [ebp-0x14 {var_18}], eax
Opcode: e8 8e e7 ff ffcall sub_8048e28
Opcode: 90nop
Opcode: 89 45 f4mov dword [ebp-0xc {var_10}], eax
Opcode: 8b 45 f8mov eax, dword [ebp-0x8 {var_c}]
Opcode: 8b 40 08mov eax, dword [eax+data_8]
Opcode: 0f b7 00movzx eax, word [eax]
Opcode: 05 02 00 00 00add eax, data_2
Opcode: 8b 4d f4mov ecx, dword [ebp-0xc {var_10}]
Opcode: 89 41 04mov dword [ecx+data_4], eax
Opcode: 8b 45 f8mov eax, dword [ebp-0x8 {var_c}]
Opcode: 8b 40 04mov eax, dword [eax+data_4]
Opcode: 0f b7 00movzx eax, word [eax]
Opcode: 05 02 00 00 00add eax, data_2
Opcode: 8b 4d f4mov ecx, dword [ebp-0xc {var_10}]
Opcode: 8b 51 04mov edx, dword [ecx+data_4]
Opcode: 01 c2add edx, eax
Opcode: 89 51 04mov dword [ecx+data_4], edx
Opcode: 8b 45 f4mov eax, dword [ebp-0xc {var_10}]
Opcode: 8b 48 04mov ecx, dword [eax+data_4]
Opcode: 81 c1 0f 00 00 00add ecx, 0xf
Opcode: 89 48 04mov dword [eax+data_4], ecx
Opcode: 8b 45 f4mov eax, dword [ebp-0xc {var_10}]
Opcode: 81 78 04 00 10 00 00cmp dword [eax+data_4], data_1000
Opcode: 0f 86 f7 e9 ff ffjbe 0x80490e1
Basic Block 2
Opcode: e9 af fb ff ffjmp 0x8049310
Basic Block 3
Opcode: 8b 45 f4mov eax, dword [ebp-0xc {var_10}]
Opcode: 8b 40 04mov eax, dword [eax+data_4]
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: e8 39 fd ff ffcall sub_8048e28
Opcode: 90nop
Opcode: b9 04 00 00 00mov ecx, data_4
Opcode: 8b 55 f4mov edx, dword [ebp-0xc {var_10}]
Opcode: 89 42 08mov dword [edx+data_8], eax
Opcode: 8b 45 f4mov eax, dword [ebp-0xc {var_10}]
Opcode: eb 0bjmp 0x804910b
Basic Block 4
Opcode: b8 e2 00 00 00mov eax, data_e2
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: 89 45 e8mov dword [ebp-0x18 {var_1c}], eax
Opcode: e8 01 f3 ff ffcall sub_80499fb
Opcode: 90nop
Opcode: 8d 45 f4lea eax, [ebp-0xc] {var_10}
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: e8 06 00 00 00call sub_804a70c
Opcode: 90nop
Opcode: e9 04 ec ff ffjmp 0x8049310
Basic Block 5
Opcode: 83 c4 64add esp, 0x64 {var_8}
Opcode: 5epop esi
Opcode: 5dpop ebp
Opcode: e9 66 01 00 00jmp 0x8049480
Basic Block 6
Opcode: 8b 40 08mov eax, dword [eax+data_8]
Opcode: 89 45 f0mov dword [ebp-0x10 {var_14}], eax
Opcode: 8b 55 f8mov edx, dword [ebp-0x8 {var_c}]
Opcode: 8b 12mov edx, dword [edx]
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: 89 54 24 04mov dword [esp+data_4 {var_68}], edx
Opcode: c7 44 24 08 04 00 00 00mov dword [esp+data_8 {var_64}], data_4
Opcode: 89 4d e4mov dword [ebp-0x1c {var_20}], ecx
Opcode: e8 6a ff ff ffcall sub_8049097
Opcode: 90nop
Opcode: b9 01 00 00 00mov ecx, data_1
Opcode: 83 45 f0 04add dword [ebp-0x10 {var_14}], data_4
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 f8mov esi, dword [ebp-0x8 {var_c}]
Opcode: 8b 36mov esi, dword [esi]
Opcode: 81 c6 04 00 00 00add esi, data_4
Opcode: 89 14 24mov dword [esp {var_6c}], edx
Opcode: 89 74 24 04mov dword [esp+data_4 {var_68}], esi
Opcode: c7 44 24 08 01 00 00 00mov dword [esp+data_8 {var_64}], data_1
Opcode: 89 45 e0mov dword [ebp-0x20 {var_24}], eax
Opcode: 89 4d dcmov dword [ebp-0x24 {var_28}], ecx
Opcode: e8 38 ff ff ffcall sub_8049097
Opcode: 90nop
Opcode: b9 01 00 00 00mov ecx, data_1
Opcode: 83 45 f0 01add dword [ebp-0x10 {var_14}], data_1
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 f8mov esi, dword [ebp-0x8 {var_c}]
Opcode: 8b 36mov esi, dword [esi]
Opcode: 81 c6 05 00 00 00add esi, data_5
Opcode: 89 14 24mov dword [esp {var_6c}], edx
Opcode: 89 74 24 04mov dword [esp+data_4 {var_68}], esi
Opcode: c7 44 24 08 01 00 00 00mov dword [esp+data_8 {var_64}], data_1
Opcode: 89 45 d8mov dword [ebp-0x28 {var_2c}], eax
Opcode: 89 4d d4mov dword [ebp-0x2c {var_30}], ecx
Opcode: e8 06 ff ff ffcall sub_8049097
Opcode: 90nop
Opcode: b9 01 00 00 00mov ecx, data_1
Opcode: 83 45 f0 01add dword [ebp-0x10 {var_14}], data_1
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 f8mov esi, dword [ebp-0x8 {var_c}]
Opcode: 8b 36mov esi, dword [esi]
Opcode: 81 c6 06 00 00 00add esi, data_6
Opcode: 89 14 24mov dword [esp {var_6c}], edx
Opcode: 89 74 24 04mov dword [esp+data_4 {var_68}], esi
Opcode: c7 44 24 08 01 00 00 00mov dword [esp+data_8 {var_64}], data_1
Opcode: 89 45 d0mov dword [ebp-0x30 {var_34}], eax
Opcode: 89 4d ccmov dword [ebp-0x34 {var_38}], ecx
Opcode: e8 d4 fe ff ffcall sub_8049097
Opcode: 90nop
Opcode: b9 08 00 00 00mov ecx, data_8
Opcode: 83 45 f0 01add dword [ebp-0x10 {var_14}], data_1
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 f8mov esi, dword [ebp-0x8 {var_c}]
Opcode: 8b 36mov esi, dword [esi]
Opcode: 81 c6 07 00 00 00add esi, data_7
Opcode: 89 14 24mov dword [esp {var_6c}], edx
Opcode: 89 74 24 04mov dword [esp+data_4 {var_68}], esi
Opcode: c7 44 24 08 08 00 00 00mov dword [esp+data_8 {var_64}], data_8
Opcode: 89 45 c8mov dword [ebp-0x38 {var_3c}], eax
Opcode: 89 4d c4mov dword [ebp-0x3c {var_40}], ecx
Opcode: e8 a2 fe ff ffcall sub_8049097
Opcode: 90nop
Opcode: b9 02 00 00 00mov ecx, data_2
Opcode: 83 45 f0 08add dword [ebp-0x10 {var_14}], data_8
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 f8mov esi, dword [ebp-0x8 {var_c}]
Opcode: 8b 76 04mov esi, dword [esi+data_4]
Opcode: 89 14 24mov dword [esp {var_6c}], edx
Opcode: 89 74 24 04mov dword [esp+data_4 {var_68}], esi
Opcode: c7 44 24 08 02 00 00 00mov dword [esp+data_8 {var_64}], data_2
Opcode: 89 45 c0mov dword [ebp-0x40 {var_44}], eax
Opcode: 89 4d bcmov dword [ebp-0x44 {var_48}], ecx
Opcode: e8 75 fe ff ffcall sub_8049097
Opcode: 90nop
Opcode: 83 45 f0 02add dword [ebp-0x10 {var_14}], data_2
Opcode: 8b 4d f8mov ecx, dword [ebp-0x8 {var_c}]
Opcode: 8b 49 04mov ecx, dword [ecx+data_4]
Opcode: 0f b7 09movzx ecx, word [ecx]
Opcode: 81 f9 00 00 00 00cmp ecx, data_0
Opcode: 89 45 b8mov dword [ebp-0x48 {var_4c}], eax
Opcode: 7e 3ajle 0x8049275
Basic Block 7
Opcode: 81 24 24 ff ff ff 7fand dword [esp], 0x7fffffff
Opcode: 8b 0c 24mov ecx, dword [esp]
Opcode: 80 39 90cmp byte [ecx], 0x90
Opcode: 0f 85 43 1e 00 00jne 0x804b2d6
Basic Block 8
Opcode: b8 02 00 00 00mov eax, data_2
Opcode: 8b 4d f0mov ecx, dword [ebp-0x10 {var_14}]
Opcode: 8b 55 f8mov edx, dword [ebp-0x8 {var_c}]
Opcode: 8b 52 08mov edx, dword [edx+data_8]
Opcode: 89 0c 24mov dword [esp {var_6c}], ecx
Opcode: 89 54 24 04mov dword [esp+data_4 {var_68}], edx
Opcode: c7 44 24 08 02 00 00 00mov dword [esp+data_8 {var_64}], data_2
Opcode: 89 45 b0mov dword [ebp-0x50 {var_54}], eax
Opcode: e8 fd fd ff ffcall sub_8049097
Opcode: 90nop
Opcode: 83 45 f0 02add dword [ebp-0x10 {var_14}], data_2
Opcode: 8b 4d f8mov ecx, dword [ebp-0x8 {var_c}]
Opcode: 8b 49 08mov ecx, dword [ecx+data_8]
Opcode: 0f b7 09movzx ecx, word [ecx]
Opcode: 81 f9 00 00 00 00cmp ecx, data_0
Opcode: 89 45 acmov dword [ebp-0x54 {var_58}], eax
Opcode: 7e 45jle 0x80492f8
Basic Block 9
Opcode: 8b 45 f0mov eax, dword [ebp-0x10 {var_14}]
Opcode: 8b 4d f8mov ecx, dword [ebp-0x8 {var_c}]
Opcode: 8b 49 04mov ecx, dword [ecx+data_4]
Opcode: 8b 49 04mov ecx, dword [ecx+data_4]
Opcode: 8b 55 f8mov edx, dword [ebp-0x8 {var_c}]
Opcode: 8b 52 04mov edx, dword [edx+data_4]
Opcode: 0f b7 12movzx edx, word [edx]
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: 89 4c 24 04mov dword [esp+data_4 {var_68}], ecx
Opcode: 89 54 24 08mov dword [esp+data_8 {var_64}], edx
Opcode: e8 37 fe ff ffcall sub_8049097
Opcode: 90nop
Opcode: 8b 4d f8mov ecx, dword [ebp-0x8 {var_c}]
Opcode: 8b 49 04mov ecx, dword [ecx+data_4]
Opcode: 0f b7 09movzx ecx, word [ecx]
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 01 caadd edx, ecx
Opcode: 89 55 f0mov dword [ebp-0x10 {var_14}], edx
Opcode: 89 45 b4mov dword [ebp-0x4c {var_50}], eax
Basic Block 10
Opcode: 59pop ecx
Opcode: 80 79 ff f4cmp byte [ecx-0x1], 0xf4
Opcode: 75 08jne 0x804b2e5
Basic Block 11
Opcode: c3retn
Basic Block 12
Opcode: 8b 45 f4mov eax, dword [ebp-0xc {var_10}]
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: e8 55 44 00 00call sub_804d758
Opcode: 90nop
Opcode: 8d 45 f4lea eax, [ebp-0xc] {var_10}
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: e8 fd 13 00 00call sub_804a70c
Opcode: 90nop
Basic Block 13
Opcode: 8b 45 f0mov eax, dword [ebp-0x10 {var_14}]
Opcode: 8b 4d f8mov ecx, dword [ebp-0x8 {var_c}]
Opcode: 8b 49 08mov ecx, dword [ecx+data_8]
Opcode: eb 09jmp 0x80492c7
Basic Block 14
Opcode: 81 f9 b8 4e 05 08cmp ecx, 0x8054eb8
Opcode: 74 47je 0x804b334
Basic Block 15
Opcode: 81 e1 ff ff ff 7fand ecx, 0x7fffffff
Opcode: ff e1jmp ecx
Basic Block 16
Opcode: 8b 49 04mov ecx, dword [ecx+data_4]
Opcode: 8b 55 f8mov edx, dword [ebp-0x8 {var_c}]
Opcode: 8b 52 08mov edx, dword [edx+data_8]
Opcode: 0f b7 12movzx edx, word [edx]
Opcode: 89 04 24mov dword [esp {var_6c}], eax
Opcode: 89 4c 24 04mov dword [esp+data_4 {var_68}], ecx
Opcode: 89 54 24 08mov dword [esp+data_8 {var_64}], edx
Opcode: e8 b4 fd ff ffcall sub_8049097
Opcode: 90nop
Opcode: 8b 4d f8mov ecx, dword [ebp-0x8 {var_c}]
Opcode: 8b 49 08mov ecx, dword [ecx+data_8]
Opcode: 0f b7 09movzx ecx, word [ecx]
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 01 caadd edx, ecx
Opcode: 89 55 f0mov dword [ebp-0x10 {var_14}], edx
Opcode: 89 45 a8mov dword [ebp-0x58 {var_5c}], eax
Basic Block 17
Opcode: db 6c 24 04fld tword [esp+data_4]
Opcode: e9 ca 0d 00 00jmp 0x804c107
Basic Block 18
Opcode: 81 f9 db 98 04 08cmp ecx, sub_804e14e-0x4873
Opcode: 74 48je 0x804b33d
Basic Block 19
Opcode: d9 eafldl2e
Opcode: de c9fmulp st1, st0
Opcode: e9 a5 f2 ff ffjmp 0x804b3b5
Basic Block 20
Opcode: c7 45 fc ff ff ff ffmov dword [ebp-0x4], 0xffffffff
Opcode: e9 3d e9 ff ffjmp 0x8049c86
Basic Block 21
Opcode: 81 f9 d6 98 04 08cmp ecx, sub_804e14e-0x4878
Opcode: 74 4cje 0x804b349
Basic Block 22
Opcode: d9 c0fld st0
Opcode: d9 fcfrndint
Opcode: dc e9fsub st1, st0
Opcode: d9 c9fxch st0, st1
Opcode: d9 f0f2xm1
Opcode: d9 e8fld1
Opcode: de c1faddp st1, st0
Opcode: d9 fdfscale
Opcode: dd d9fstp st1
Opcode: e9 b4 e0 ff ffjmp 0x8049480
Basic Block 23
Opcode: 8b 45 fcmov eax, dword [ebp-0x4]
Opcode: 81 c4 18 01 00 00add esp, 0x118
Opcode: 5dpop ebp
Opcode: e9 eb f7 ff ffjmp 0x8049480
Basic Block 24
Opcode: e9 31 e9 ff ffjmp 0x8049c7f
Basic Block 25
Opcode: 81 f9 fa 85 04 08cmp ecx, sub_8049761-0x1167
Opcode: 74 49je 0x804b34e
Basic Block 26
Opcode: c7 45 fc 00 00 00 00mov dword [ebp-0x4], data_0
Basic Block 27
Opcode: b8 ff ff ff ffmov eax, 0xffffffff
Opcode: 89 04 24mov dword [esp], eax
Opcode: 89 45 d4mov dword [ebp-0x2c], eax
Opcode: e8 88 0d 00 00call sub_804c0e6
Opcode: e8 88 0d 00 00{ Does not return }
Basic Block 28
Opcode: 81 f9 f5 85 04 08cmp ecx, sub_8049761-0x116c
Opcode: 74 66je 0x804b373
Basic Block 29
Opcode: eb eajmp 0x804b35f
Basic Block 30
Opcode: 81 f9 f0 85 04 08cmp ecx, sub_8049761-0x1171
Opcode: 74 60je 0x804b375
Basic Block 31
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 40 0cmov eax, dword [eax+data_c]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 d1 db ff ffcall sub_8048f3e
Opcode: 90nop
Opcode: e9 d7 e0 ff ffjmp 0x804944a
Basic Block 32
Opcode: eb e8jmp 0x804b35f
Basic Block 33
Opcode: 81 f9 c2 85 04 08cmp ecx, sub_8049761-0x119f
Opcode: 74 5aje 0x804b377
Basic Block 34
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 81 78 08 00 00 00 00cmp dword [eax+data_8], data_0
Opcode: 0f 84 d3 fb ff ffje 0x804902d
Basic Block 35
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 40 0cmov eax, dword [eax+data_c]
Opcode: 89 45 e4mov dword [ebp-0x1c], eax
Opcode: 85 c0test eax, eax
Opcode: 74 0fje 0x804b393
Basic Block 36
Opcode: 81 f9 bd 85 04 08cmp ecx, sub_8049761-0x11a4
Opcode: 74 70je 0x804b395
Basic Block 37
Opcode: eb 09jmp 0x8049038
Basic Block 38
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 40 08mov eax, dword [eax+data_8]
Opcode: 8b 40 04mov eax, dword [eax+data_4]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 d3 fa ff ffcall sub_8048f3e
Opcode: 90nop
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 40 08mov eax, dword [eax+data_8]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 c4 fa ff ffcall sub_8048f3e
Opcode: 90nop
Opcode: e9 ad fb ff ffjmp 0x804902d
Basic Block 39
Opcode: eb cajmp 0x804b35f
Basic Block 40
Opcode: 8b 45 e4mov eax, dword [ebp-0x1c]
Opcode: 8b 40 18mov eax, dword [eax+0x18]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 ac db ff ffcall sub_8048f3e
Opcode: 90nop
Basic Block 41
Opcode: eb c8jmp 0x804b35f
Basic Block 42
Opcode: 81 f9 8f 85 04 08cmp ecx, sub_8049761-0x11d2
Opcode: 74 6aje 0x804b397
Basic Block 43
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 81 78 04 00 00 00 00cmp dword [eax+data_4], data_0
Opcode: 74 bdje 0x8049001
Basic Block 44
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 40 0cmov eax, dword [eax+data_c]
Opcode: 89 45 e8mov dword [ebp-0x18], eax
Opcode: 85 c0test eax, eax
Opcode: 74 0fje 0x804b3b3
Basic Block 45
Opcode: b8 01 00 00 00mov eax, data_1
Opcode: cd 80int 0x80
Opcode: cd 80{ Does not return }
Basic Block 46
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 00mov eax, dword [eax]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 30 ff ff ffcall sub_8048f3e
Opcode: 90nop
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 24 ff ff ffcall sub_8048f3e
Opcode: 90nop
Opcode: 8b 45 fcmov eax, dword [ebp-0x4]
Opcode: c7 00 00 00 00 00mov dword [eax], data_0
Opcode: 83 c4 38add esp, 0x38
Opcode: 5dpop ebp
Opcode: e9 53 04 00 00jmp 0x8049480
Basic Block 47
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 40 04mov eax, dword [eax+data_4]
Opcode: 8b 40 04mov eax, dword [eax+data_4]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 e9 fe ff ffcall sub_8048f3e
Opcode: 90nop
Opcode: 8b 45 f8mov eax, dword [ebp-0x8]
Opcode: 8b 40 04mov eax, dword [eax+data_4]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 da fe ff ffcall sub_8048f3e
Opcode: 90nop
Opcode: eb 9ajmp 0x8049001
Basic Block 48
Opcode: eb aajmp 0x804b35f
Basic Block 49
Opcode: 8b 45 e8mov eax, dword [ebp-0x18]
Opcode: 8b 40 10mov eax, dword [eax+data_10]
Opcode: 89 04 24mov dword [esp], eax
Opcode: e8 8c db ff ffcall sub_8048f3e
Opcode: 90nop