Function Graph 0
Basic Block 0
Opcode: 55sub_804b6fa:
Opcode: 55push ebp
Opcode: 89 e5mov ebp, esp
Opcode: 53push ebx
Opcode: 57push edi
Opcode: 56push esi
Opcode: 81 ec 8c 00 00 00sub esp, data_8c {var_9c}
Opcode: 8b 45 24mov eax, dword [ebp+data_24 {arg_20}]
Opcode: 8b 4d 20mov ecx, dword [ebp+data_20 {arg_1c}]
Opcode: 8b 55 1cmov edx, dword [ebp+data_1c {arg_18}]
Opcode: f2 0f 10 45 14movsd xmm0, qword [ebp+data_14] {arg_10}
Opcode: 8b 75 10mov esi, dword [ebp+data_10 {arg_c}]
Opcode: 8b 7d 0cmov edi, dword [ebp+data_c {arg_8}]
Opcode: 8b 5d 08mov ebx, dword [ebp+data_8 {arg_4}]
Opcode: 0f 57 c9xorps xmm1, xmm1
Opcode: 89 5d f0mov dword [ebp-0x10 {var_14}], ebx
Opcode: 89 7d ecmov dword [ebp-0x14 {var_18}], edi
Opcode: 89 75 e8mov dword [ebp-0x18 {var_1c}], esi
Opcode: f2 0f 11 45 e0movsd qword [ebp-0x20], xmm0 {var_24}
Opcode: 89 55 dcmov dword [ebp-0x24 {var_28}], edx
Opcode: 89 4d d8mov dword [ebp-0x28 {var_2c}], ecx
Opcode: 89 45 d4mov dword [ebp-0x2c {var_30}], eax
Opcode: c7 45 d0 00 00 00 00mov dword [ebp-0x30 {var_34}], data_0
Opcode: c7 45 cc 00 00 00 00mov dword [ebp-0x34 {var_38}], data_0
Opcode: c6 45 cb 00mov byte [ebp-0x35 {var_39}], 0x0
Opcode: c7 45 c4 00 00 00 00mov dword [ebp-0x3c {var_40}], data_0
Opcode: 66 0f 2e 4d e0ucomisd xmm1, qword [ebp-0x20] {var_24}
Opcode: 0f 86 5c ff ff ffjbe 0x804b6b7
Basic Block 1
Opcode: 81 7d d8 00 00 00 00cmp dword [ebp-0x28 {var_2c}], data_0
Opcode: 0f 85 c5 fe ff ffjne 0x804b589
Basic Block 2
Opcode: f2 0f 10 45 e0movsd xmm0, qword [ebp-0x20] {var_24}
Opcode: f2 0f 10 0d d0 53 05 08movsd xmm1, qword [data_80553d0]
Opcode: 66 0f 57 c1xorpd xmm0, xmm1
Opcode: f2 0f 11 45 e0movsd qword [ebp-0x20], xmm0 {var_24}
Opcode: c6 45 cb 01mov byte [ebp-0x35 {var_39}], 0x1
Opcode: 83 45 d0 01add dword [ebp-0x30 {var_34}], data_1
Opcode: e9 39 ff ff ffjmp 0x804b6b7
Basic Block 3
Opcode: 8d 45 a4lea eax, [ebp-0x5c] {var_60}
Opcode: f2 0f 10 45 e0movsd xmm0, qword [ebp-0x20] {var_24}
Opcode: 8b 4d d8mov ecx, dword [ebp-0x28 {var_2c}]
Opcode: 88 camov dl, cl
Opcode: 8b 4d d4mov ecx, dword [ebp-0x2c {var_30}]
Opcode: f2 0f 11 04 24movsd qword [esp], xmm0 {var_9c}
Opcode: 0f b6 f2movzx esi, dl
Opcode: 89 74 24 08mov dword [esp+data_8 {var_94}], esi
Opcode: 89 44 24 0cmov dword [esp+data_c {var_90}], eax
Opcode: 89 4c 24 10mov dword [esp+data_10 {var_8c}], ecx
Opcode: e8 28 fe ff ffcall sub_804b3da
Opcode: 90nop
Opcode: 89 45 c4mov dword [ebp-0x3c {var_40}], eax
Basic Block 4
Opcode: b8 06 00 00 00mov eax, data_6
Opcode: 8d 4d a4lea ecx, [ebp-0x5c] {var_60}
Opcode: f2 0f 10 45 e0movsd xmm0, qword [ebp-0x20] {var_24}
Opcode: 8b 55 d4mov edx, dword [ebp-0x2c {var_30}]
Opcode: f2 0f 11 04 24movsd qword [esp], xmm0 {var_9c}
Opcode: c7 44 24 08 06 00 00 00mov dword [esp+data_8 {var_94}], data_6
Opcode: 89 4c 24 0cmov dword [esp+data_c {var_90}], ecx
Opcode: 89 54 24 10mov dword [esp+data_10 {var_8c}], edx
Opcode: 89 45 9cmov dword [ebp-0x64 {var_68}], eax
Opcode: e8 e9 fc ff ffcall sub_804b3da
Opcode: 90nop
Opcode: 89 45 c4mov dword [ebp-0x3c {var_40}], eax
Opcode: e9 bc fe ff ffjmp 0x804b5b6
Basic Block 5
Opcode: 8b 45 d4mov eax, dword [ebp-0x2c {var_30}]
Opcode: 25 01 00 00 00and eax, data_1
Opcode: 85 c0test eax, eax
Opcode: 75 4fjne 0x804b638
Basic Block 6
Opcode: 8b 45 d0mov eax, dword [ebp-0x30 {var_34}]
Opcode: 3b 45 dccmp eax, dword [ebp-0x24 {var_28}]
Opcode: 73 09jae 0x804b5db
Basic Block 7
Opcode: 8b 45 c4mov eax, dword [ebp-0x3c {var_40}]
Opcode: 8b 4d d0mov ecx, dword [ebp-0x30 {var_34}]
Opcode: 01 c1add ecx, eax
Opcode: 89 4d d0mov dword [ebp-0x30 {var_34}], ecx
Opcode: 81 7d dc 00 00 00 00cmp dword [ebp-0x24 {var_28}], data_0
Opcode: 7e 13jle 0x804b5dd
Basic Block 8
Opcode: 80 7d cb 00cmp byte [ebp-0x35 {var_39}], 0x0
Opcode: 74 2dje 0x804b66b
Basic Block 9
Opcode: 0f be 45 cbmovsx eax, byte [ebp-0x35 {var_39}]
Opcode: 85 c0test eax, eax
Opcode: 74 42je 0x804b633
Basic Block 10
Opcode: eb 00jmp 0x804b5dd
Basic Block 11
Opcode: 8b 45 dcmov eax, dword [ebp-0x24 {var_28}]
Opcode: 2b 45 d0sub eax, dword [ebp-0x30 {var_34}]
Opcode: 89 45 ccmov dword [ebp-0x34 {var_38}], eax
Basic Block 12
Opcode: c7 45 a0 00 00 00 00mov dword [ebp-0x60 {var_64}], data_0
Basic Block 13
Opcode: b8 2d 00 00 00mov eax, data_2d
Opcode: 8b 4d ecmov ecx, dword [ebp-0x14 {var_18}]
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 e8mov esi, dword [ebp-0x18 {var_1c}]
Opcode: 89 14 24mov dword [esp {var_9c}], edx
Opcode: c7 44 24 04 2d 00 00 00mov dword [esp+data_4 {var_98}], data_2d
Opcode: 89 74 24 08mov dword [esp+data_8 {var_94}], esi
Opcode: 89 45 8cmov dword [ebp-0x74 {var_78}], eax
Opcode: e8 46 00 00 00call sub_804b6a9
Opcode: 90nop
Opcode: 89 45 e8mov dword [ebp-0x18 {var_1c}], eax
Opcode: c6 45 cb 00mov byte [ebp-0x35 {var_39}], 0x0
Basic Block 14
Opcode: e9 81 46 00 00jmp 0x804fcb9
Basic Block 15
Opcode: 81 7d cc 00 00 00 00cmp dword [ebp-0x34 {var_38}], data_0
Opcode: 76 39jbe 0x804b633
Basic Block 16
Opcode: 8b 45 d4mov eax, dword [ebp-0x2c {var_30}]
Opcode: 25 01 00 00 00and eax, data_1
Opcode: 85 c0test eax, eax
Opcode: 0f 84 41 ff ff ffje 0x8049540
Basic Block 17
Opcode: 8b 45 ecmov eax, dword [ebp-0x14 {var_18}]
Opcode: 8b 4d f0mov ecx, dword [ebp-0x10 {var_14}]
Opcode: 8b 55 a0mov edx, dword [ebp-0x60 {var_64}]
Opcode: 0f be 54 15 a4movsx edx, byte [ebp+edx-0x5c] {var_4}
Opcode: 8b 75 e8mov esi, dword [ebp-0x18 {var_1c}]
Opcode: 89 0c 24mov dword [esp {var_9c}], ecx
Opcode: 89 54 24 04mov dword [esp+data_4 {var_98}], edx
Opcode: 89 74 24 08mov dword [esp+data_8 {var_94}], esi
Opcode: e8 f0 46 00 00call sub_804fd8f
Opcode: 90nop
Opcode: 89 45 e8mov dword [ebp-0x18 {var_1c}], eax
Opcode: 83 45 a0 01add dword [ebp-0x60 {var_64}], data_1
Opcode: eb c9jmp 0x804b672
Basic Block 18
Opcode: 8b 45 ccmov eax, dword [ebp-0x34 {var_38}]
Opcode: 89 c1mov ecx, eax
Opcode: 81 c1 ff ff ff ffadd ecx, 0xffffffff
Opcode: 89 4d ccmov dword [ebp-0x34 {var_38}], ecx
Opcode: 3d 00 00 00 00cmp eax, data_0
Opcode: 0f 86 d2 01 00 00jbe 0x804fea4
Basic Block 19
Opcode: 8b 45 d4mov eax, dword [ebp-0x2c {var_30}]
Opcode: 25 04 00 00 00and eax, data_4
Opcode: 85 c0test eax, eax
Opcode: 74 2dje 0x804b633
Basic Block 20
Opcode: 8b 45 e8mov eax, dword [ebp-0x18 {var_1c}]
Opcode: 81 c4 8c 00 00 00add esp, data_8c {var_10}
Opcode: 5epop esi
Opcode: 5fpop edi
Opcode: 5bpop ebx
Opcode: 5dpop ebp
Opcode: e9 2e ff ff ffjmp 0x8049480
Basic Block 21
Opcode: eb 00jmp 0x8049601
Basic Block 22
Opcode: 8b 45 a0mov eax, dword [ebp-0x60 {var_64}]
Opcode: 3b 45 c4cmp eax, dword [ebp-0x3c {var_40}]
Opcode: 0f 83 71 df ff ffjae 0x80495ef
Basic Block 23
Opcode: e9 8f b7 ff ffjmp 0x804b638
Basic Block 24
Opcode: 8b 45 d4mov eax, dword [ebp-0x2c {var_30}]
Opcode: 25 04 00 00 00and eax, data_4
Opcode: 85 c0test eax, eax
Opcode: 74 b0je 0x804fc8e
Basic Block 25
Opcode: b8 2d 00 00 00mov eax, data_2d
Opcode: 8b 4d ecmov ecx, dword [ebp-0x14 {var_18}]
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 e8mov esi, dword [ebp-0x18 {var_1c}]
Opcode: 89 14 24mov dword [esp {var_9c}], edx
Opcode: c7 44 24 04 2d 00 00 00mov dword [esp+data_4 {var_98}], data_2d
Opcode: 89 74 24 08mov dword [esp+data_8 {var_94}], esi
Opcode: 89 45 98mov dword [ebp-0x68 {var_6c}], eax
Opcode: e8 85 00 00 00call sub_804b6b0
Opcode: 90nop
Opcode: 89 45 e8mov dword [ebp-0x18 {var_1c}], eax
Opcode: c6 45 cb 00mov byte [ebp-0x35 {var_39}], 0x0
Basic Block 26
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 27
Opcode: 8b 45 ccmov eax, dword [ebp-0x34 {var_38}]
Opcode: 89 c1mov ecx, eax
Opcode: 81 c1 ff ff ff ffadd ecx, 0xffffffff
Opcode: 89 4d ccmov dword [ebp-0x34 {var_38}], ecx
Opcode: 3d 00 00 00 00cmp eax, data_0
Opcode: 0f 86 36 69 00 00jbe 0x804ff50
Basic Block 28
Opcode: b8 20 00 00 00mov eax, data_20
Opcode: 8b 4d ecmov ecx, dword [ebp-0x14 {var_18}]
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 e8mov esi, dword [ebp-0x18 {var_1c}]
Opcode: 89 14 24mov dword [esp {var_9c}], edx
Opcode: c7 44 24 04 20 00 00 00mov dword [esp+data_4 {var_98}], data_20
Opcode: 89 74 24 08mov dword [esp+data_8 {var_94}], esi
Opcode: 89 45 90mov dword [ebp-0x70 {var_74}], eax
Opcode: e8 2d fe ff ffcall sub_804fae0
Opcode: 90nop
Opcode: 89 45 e8mov dword [ebp-0x18 {var_1c}], eax
Basic Block 29
Opcode: b8 30 00 00 00mov eax, data_30
Opcode: 8b 4d ecmov ecx, dword [ebp-0x14 {var_18}]
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 e8mov esi, dword [ebp-0x18 {var_1c}]
Opcode: 89 14 24mov dword [esp {var_9c}], edx
Opcode: c7 44 24 04 30 00 00 00mov dword [esp+data_4 {var_98}], data_30
Opcode: 89 74 24 08mov dword [esp+data_8 {var_94}], esi
Opcode: 89 45 94mov dword [ebp-0x6c {var_70}], eax
Opcode: e8 66 fa ff ffcall sub_804f769
Opcode: 90nop
Opcode: 89 45 e8mov dword [ebp-0x18 {var_1c}], eax
Opcode: eb aejmp 0x804fcb7
Basic Block 30
Opcode: 59pop ecx
Opcode: 80 79 ff f4cmp byte [ecx-0x1], 0xf4
Opcode: 75 08jne 0x804b2e5
Basic Block 31
Opcode: c3retn
Basic Block 32
Opcode: e9 eb 95 ff ffjmp 0x8049540
Basic Block 33
Opcode: b8 20 00 00 00mov eax, data_20
Opcode: 8b 4d ecmov ecx, dword [ebp-0x14 {var_18}]
Opcode: 8b 55 f0mov edx, dword [ebp-0x10 {var_14}]
Opcode: 8b 75 e8mov esi, dword [ebp-0x18 {var_1c}]
Opcode: 89 14 24mov dword [esp {var_9c}], edx
Opcode: c7 44 24 04 20 00 00 00mov dword [esp+data_4 {var_98}], data_20
Opcode: 89 74 24 08mov dword [esp+data_8 {var_94}], esi
Opcode: 89 45 88mov dword [ebp-0x78 {var_7c}], eax
Opcode: e8 06 67 00 00call sub_804fd45
Opcode: 90nop
Opcode: 89 45 e8mov dword [ebp-0x18 {var_1c}], eax
Opcode: eb bcjmp 0x8049601
Basic Block 34
Opcode: eb 00jmp 0x804fcb9
Basic Block 35
Opcode: 81 f9 b8 4e 05 08cmp ecx, 0x8054eb8
Opcode: 74 47je 0x804b334
Basic Block 36
Opcode: 81 e1 ff ff ff 7fand ecx, 0x7fffffff
Opcode: ff e1jmp ecx
Basic Block 37
Opcode: db 6c 24 04fld tword [esp+data_4]
Opcode: e9 ca 0d 00 00jmp 0x804c107
Basic Block 38
Opcode: 81 f9 db 98 04 08cmp ecx, sub_804e14e-0x4873
Opcode: 74 48je 0x804b33d
Basic Block 39
Opcode: d9 eafldl2e
Opcode: de c9fmulp st1, st0
Opcode: e9 a5 f2 ff ffjmp 0x804b3b5
Basic Block 40
Opcode: c7 45 fc ff ff ff ffmov dword [ebp-0x4], 0xffffffff
Opcode: e9 3d e9 ff ffjmp 0x8049c86
Basic Block 41
Opcode: 81 f9 d6 98 04 08cmp ecx, sub_804e14e-0x4878
Opcode: 74 4cje 0x804b349
Basic Block 42
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 43
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 44
Opcode: e9 31 e9 ff ffjmp 0x8049c7f
Basic Block 45
Opcode: 81 f9 fa 85 04 08cmp ecx, sub_8049761-0x1167
Opcode: 74 49je 0x804b34e
Basic Block 46
Opcode: c7 45 fc 00 00 00 00mov dword [ebp-0x4], data_0
Basic Block 47
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 48
Opcode: 81 f9 f5 85 04 08cmp ecx, sub_8049761-0x116c
Opcode: 74 66je 0x804b373
Basic Block 49
Opcode: eb eajmp 0x804b35f
Basic Block 50
Opcode: 81 f9 f0 85 04 08cmp ecx, sub_8049761-0x1171
Opcode: 74 60je 0x804b375
Basic Block 51
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 52
Opcode: eb e8jmp 0x804b35f
Basic Block 53
Opcode: 81 f9 c2 85 04 08cmp ecx, sub_8049761-0x119f
Opcode: 74 5aje 0x804b377
Basic Block 54
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 55
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 56
Opcode: 81 f9 bd 85 04 08cmp ecx, sub_8049761-0x11a4
Opcode: 74 70je 0x804b395
Basic Block 57
Opcode: eb 09jmp 0x8049038
Basic Block 58
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 59
Opcode: eb cajmp 0x804b35f
Basic Block 60
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 61
Opcode: eb c8jmp 0x804b35f
Basic Block 62
Opcode: 81 f9 8f 85 04 08cmp ecx, sub_8049761-0x11d2
Opcode: 74 6aje 0x804b397
Basic Block 63
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 64
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 65
Opcode: b8 01 00 00 00mov eax, data_1
Opcode: cd 80int 0x80
Opcode: cd 80{ Does not return }
Basic Block 66
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 67
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 68
Opcode: eb aajmp 0x804b35f
Basic Block 69
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