-
Notifications
You must be signed in to change notification settings - Fork 9
/
instructions_0F80.c
96 lines (89 loc) · 2.48 KB
/
instructions_0F80.c
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
#include <stdint.h>
#include "instruction_defs.h"
#include "emulator_functions.h"
/*
* Macro for jump with eflag.
* Replaces the matching text and ## concatenates strings.
* Defined until unescaped line break.
*/
#define DEFINE_NEAR_JX(flag, is_flag) \
void j##flag##32(Emulator * emu) \
{ \
int diff = is_flag(emu) ? get_sign_code32(emu, 2) : 0; \
emu->eip += (diff + 6); \
} \
void jn##flag##32(Emulator * emu) \
{ \
int diff = is_flag(emu) ? 0 : get_sign_code32(emu, 2); \
emu->eip += (diff + 6); \
}
/*
* jc | jnc
* Jumps near if carry (CF=1) | not carry (CF=0)
* 2 bytes: op code (0F 82 | 0F 83)
* 4 bytes: offset to jump
*/
DEFINE_NEAR_JX(c, is_carry)
/*
* jz | jnz
* Jumps near if zero (ZF=1) | not zero (ZF=0)
* 2 bytes: op code (0F 84 | 0F 85)
* 4 bytes: offset to jump
*/
DEFINE_NEAR_JX(z, is_zero)
/*
* jna | ja
* Jumps if not above (CF=1 or ZF=1) | above (CF=0 and ZF=0)
* 2 byte: op code (0F 86 | 0F 87)
* 4 bytes: offset to jump
*/
void jna32(Emulator *emu)
{
int diff = (is_carry(emu) || is_zero(emu)) ? get_sign_code32(emu, 2) : 0;
emu->eip += (diff + 6);
}
void ja32(Emulator *emu)
{
int diff = (!is_carry(emu) && !is_zero(emu)) ? get_sign_code32(emu, 2) : 0;
emu->eip += (diff + 6);
}
/*
* js | jns
* Jumps near if sign (SF=1) | not sign (SF=0)
* 2 bytes: op code (0F 88 | 0F 89)
* 4 bytes: offset to jump
*/
DEFINE_NEAR_JX(s, is_sign)
/*
* jge
* Jumps if greater or equal (SF=OF)
* 2 byte: op code (0F 8D)
* 4 bytes: offset to jump
*/
void jge32(Emulator *emu)
{
int diff = (is_sign(emu) == is_overflow(emu)) ? get_sign_code32(emu, 2) : 0;
emu->eip += (diff + 6);
}
/*
* jng
* Jumps if not greater (ZF=1 or SF!=OF)
* 2 byte: op code (0F 8E)
* 4 bytes: offset to jump
*/
void jng32(Emulator *emu)
{
int diff = (is_zero(emu) || (is_sign(emu) != is_overflow(emu))) ? get_sign_code32(emu, 2) : 0;
emu->eip += (diff + 6);
}
/*
* jg
* Jumps if greater (ZF=0 and SF=OF)
* 2 byte: op code (0F 8F)
* 4 bytes: offset to jump
*/
void jg32(Emulator *emu)
{
int diff = (!is_zero(emu) && (is_sign(emu) == is_overflow(emu))) ? get_sign_code32(emu, 2) : 0;
emu->eip += (diff + 6);
}