soc/intel/ptl: Update ME specification version to 21
[coreboot.git] / src / device / oprom / x86emu / prim_ops.h
blob7230a71e5d6e44398f3ac89103f6e2952f930175
1 /****************************************************************************
3 * Realmode X86 Emulator Library
5 * Copyright (C) 1996-1999 SciTech Software, Inc.
6 * Copyright (C) David Mosberger-Tang
7 * Copyright (C) 1999 Egbert Eich
9 * ========================================================================
11 * Permission to use, copy, modify, distribute, and sell this software and
12 * its documentation for any purpose is hereby granted without fee,
13 * provided that the above copyright notice appear in all copies and that
14 * both that copyright notice and this permission notice appear in
15 * supporting documentation, and that the name of the authors not be used
16 * in advertising or publicity pertaining to distribution of the software
17 * without specific, written prior permission. The authors makes no
18 * representations about the suitability of this software for any purpose.
19 * It is provided "as is" without express or implied warranty.
21 * THE AUTHORS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
22 * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
23 * EVENT SHALL THE AUTHORS BE LIABLE FOR ANY SPECIAL, INDIRECT OR
24 * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
25 * USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
26 * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
27 * PERFORMANCE OF THIS SOFTWARE.
29 * ========================================================================
31 * Language: ANSI C
32 * Environment: Any
33 * Developer: Kendall Bennett
35 * Description: Header file for primitive operation functions.
37 ****************************************************************************/
39 #ifndef __X86EMU_PRIM_OPS_H
40 #define __X86EMU_PRIM_OPS_H
42 #include "prim_asm.h"
44 #ifdef __cplusplus
45 extern "C" { /* Use "C" linkage when in C++ mode */
46 #endif
48 u16 aaa_word (u16 d);
49 u16 aas_word (u16 d);
50 u16 aad_word (u16 d);
51 u16 aam_word (u8 d);
52 u8 adc_byte (u8 d, u8 s);
53 u16 adc_word (u16 d, u16 s);
54 u32 adc_long (u32 d, u32 s);
55 u8 add_byte (u8 d, u8 s);
56 u16 add_word (u16 d, u16 s);
57 u32 add_long (u32 d, u32 s);
58 u8 and_byte (u8 d, u8 s);
59 u16 and_word (u16 d, u16 s);
60 u32 and_long (u32 d, u32 s);
61 u8 cmp_byte (u8 d, u8 s);
62 u16 cmp_word (u16 d, u16 s);
63 u32 cmp_long (u32 d, u32 s);
64 u8 daa_byte (u8 d);
65 u8 das_byte (u8 d);
66 u8 dec_byte (u8 d);
67 u16 dec_word (u16 d);
68 u32 dec_long (u32 d);
69 u8 inc_byte (u8 d);
70 u16 inc_word (u16 d);
71 u32 inc_long (u32 d);
72 u8 or_byte (u8 d, u8 s);
73 u16 or_word (u16 d, u16 s);
74 u32 or_long (u32 d, u32 s);
75 u8 neg_byte (u8 s);
76 u16 neg_word (u16 s);
77 u32 neg_long (u32 s);
78 u8 not_byte (u8 s);
79 u16 not_word (u16 s);
80 u32 not_long (u32 s);
81 u8 rcl_byte (u8 d, u8 s);
82 u16 rcl_word (u16 d, u8 s);
83 u32 rcl_long (u32 d, u8 s);
84 u8 rcr_byte (u8 d, u8 s);
85 u16 rcr_word (u16 d, u8 s);
86 u32 rcr_long (u32 d, u8 s);
87 u8 rol_byte (u8 d, u8 s);
88 u16 rol_word (u16 d, u8 s);
89 u32 rol_long (u32 d, u8 s);
90 u8 ror_byte (u8 d, u8 s);
91 u16 ror_word (u16 d, u8 s);
92 u32 ror_long (u32 d, u8 s);
93 u8 shl_byte (u8 d, u8 s);
94 u16 shl_word (u16 d, u8 s);
95 u32 shl_long (u32 d, u8 s);
96 u8 shr_byte (u8 d, u8 s);
97 u16 shr_word (u16 d, u8 s);
98 u32 shr_long (u32 d, u8 s);
99 u8 sar_byte (u8 d, u8 s);
100 u16 sar_word (u16 d, u8 s);
101 u32 sar_long (u32 d, u8 s);
102 u16 shld_word (u16 d, u16 fill, u8 s);
103 u32 shld_long (u32 d, u32 fill, u8 s);
104 u16 shrd_word (u16 d, u16 fill, u8 s);
105 u32 shrd_long (u32 d, u32 fill, u8 s);
106 u8 sbb_byte (u8 d, u8 s);
107 u16 sbb_word (u16 d, u16 s);
108 u32 sbb_long (u32 d, u32 s);
109 u8 sub_byte (u8 d, u8 s);
110 u16 sub_word (u16 d, u16 s);
111 u32 sub_long (u32 d, u32 s);
112 void test_byte (u8 d, u8 s);
113 void test_word (u16 d, u16 s);
114 void test_long (u32 d, u32 s);
115 u8 xor_byte (u8 d, u8 s);
116 u16 xor_word (u16 d, u16 s);
117 u32 xor_long (u32 d, u32 s);
118 void imul_byte (u8 s);
119 void imul_word (u16 s);
120 void imul_long (u32 s);
121 void imul_long_direct(u32 *res_lo, u32* res_hi,u32 d, u32 s);
122 void mul_byte (u8 s);
123 void mul_word (u16 s);
124 void mul_long (u32 s);
125 void idiv_byte (u8 s);
126 void idiv_word (u16 s);
127 void idiv_long (u32 s);
128 void div_byte (u8 s);
129 void div_word (u16 s);
130 void div_long (u32 s);
131 void ins (int size);
132 void outs (int size);
133 u16 mem_access_word (int addr);
134 void push_word (u16 w);
135 void push_long (u32 w);
136 u16 pop_word (void);
137 u32 pop_long (void);
138 void x86emu_cpuid (void);
140 #if defined(__HAVE_INLINE_ASSEMBLER__) && !defined(PRIM_OPS_NO_REDEFINE_ASM)
142 #define aaa_word(d) aaa_word_asm(&M.x86.R_EFLG,d)
143 #define aas_word(d) aas_word_asm(&M.x86.R_EFLG,d)
144 #define aad_word(d) aad_word_asm(&M.x86.R_EFLG,d)
145 #define aam_word(d) aam_word_asm(&M.x86.R_EFLG,d)
146 #define adc_byte(d,s) adc_byte_asm(&M.x86.R_EFLG,d,s)
147 #define adc_word(d,s) adc_word_asm(&M.x86.R_EFLG,d,s)
148 #define adc_long(d,s) adc_long_asm(&M.x86.R_EFLG,d,s)
149 #define add_byte(d,s) add_byte_asm(&M.x86.R_EFLG,d,s)
150 #define add_word(d,s) add_word_asm(&M.x86.R_EFLG,d,s)
151 #define add_long(d,s) add_long_asm(&M.x86.R_EFLG,d,s)
152 #define and_byte(d,s) and_byte_asm(&M.x86.R_EFLG,d,s)
153 #define and_word(d,s) and_word_asm(&M.x86.R_EFLG,d,s)
154 #define and_long(d,s) and_long_asm(&M.x86.R_EFLG,d,s)
155 #define cmp_byte(d,s) cmp_byte_asm(&M.x86.R_EFLG,d,s)
156 #define cmp_word(d,s) cmp_word_asm(&M.x86.R_EFLG,d,s)
157 #define cmp_long(d,s) cmp_long_asm(&M.x86.R_EFLG,d,s)
158 #define daa_byte(d) daa_byte_asm(&M.x86.R_EFLG,d)
159 #define das_byte(d) das_byte_asm(&M.x86.R_EFLG,d)
160 #define dec_byte(d) dec_byte_asm(&M.x86.R_EFLG,d)
161 #define dec_word(d) dec_word_asm(&M.x86.R_EFLG,d)
162 #define dec_long(d) dec_long_asm(&M.x86.R_EFLG,d)
163 #define inc_byte(d) inc_byte_asm(&M.x86.R_EFLG,d)
164 #define inc_word(d) inc_word_asm(&M.x86.R_EFLG,d)
165 #define inc_long(d) inc_long_asm(&M.x86.R_EFLG,d)
166 #define or_byte(d,s) or_byte_asm(&M.x86.R_EFLG,d,s)
167 #define or_word(d,s) or_word_asm(&M.x86.R_EFLG,d,s)
168 #define or_long(d,s) or_long_asm(&M.x86.R_EFLG,d,s)
169 #define neg_byte(s) neg_byte_asm(&M.x86.R_EFLG,s)
170 #define neg_word(s) neg_word_asm(&M.x86.R_EFLG,s)
171 #define neg_long(s) neg_long_asm(&M.x86.R_EFLG,s)
172 #define not_byte(s) not_byte_asm(&M.x86.R_EFLG,s)
173 #define not_word(s) not_word_asm(&M.x86.R_EFLG,s)
174 #define not_long(s) not_long_asm(&M.x86.R_EFLG,s)
175 #define rcl_byte(d,s) rcl_byte_asm(&M.x86.R_EFLG,d,s)
176 #define rcl_word(d,s) rcl_word_asm(&M.x86.R_EFLG,d,s)
177 #define rcl_long(d,s) rcl_long_asm(&M.x86.R_EFLG,d,s)
178 #define rcr_byte(d,s) rcr_byte_asm(&M.x86.R_EFLG,d,s)
179 #define rcr_word(d,s) rcr_word_asm(&M.x86.R_EFLG,d,s)
180 #define rcr_long(d,s) rcr_long_asm(&M.x86.R_EFLG,d,s)
181 #define rol_byte(d,s) rol_byte_asm(&M.x86.R_EFLG,d,s)
182 #define rol_word(d,s) rol_word_asm(&M.x86.R_EFLG,d,s)
183 #define rol_long(d,s) rol_long_asm(&M.x86.R_EFLG,d,s)
184 #define ror_byte(d,s) ror_byte_asm(&M.x86.R_EFLG,d,s)
185 #define ror_word(d,s) ror_word_asm(&M.x86.R_EFLG,d,s)
186 #define ror_long(d,s) ror_long_asm(&M.x86.R_EFLG,d,s)
187 #define shl_byte(d,s) shl_byte_asm(&M.x86.R_EFLG,d,s)
188 #define shl_word(d,s) shl_word_asm(&M.x86.R_EFLG,d,s)
189 #define shl_long(d,s) shl_long_asm(&M.x86.R_EFLG,d,s)
190 #define shr_byte(d,s) shr_byte_asm(&M.x86.R_EFLG,d,s)
191 #define shr_word(d,s) shr_word_asm(&M.x86.R_EFLG,d,s)
192 #define shr_long(d,s) shr_long_asm(&M.x86.R_EFLG,d,s)
193 #define sar_byte(d,s) sar_byte_asm(&M.x86.R_EFLG,d,s)
194 #define sar_word(d,s) sar_word_asm(&M.x86.R_EFLG,d,s)
195 #define sar_long(d,s) sar_long_asm(&M.x86.R_EFLG,d,s)
196 #define shld_word(d,fill,s) shld_word_asm(&M.x86.R_EFLG,d,fill,s)
197 #define shld_long(d,fill,s) shld_long_asm(&M.x86.R_EFLG,d,fill,s)
198 #define shrd_word(d,fill,s) shrd_word_asm(&M.x86.R_EFLG,d,fill,s)
199 #define shrd_long(d,fill,s) shrd_long_asm(&M.x86.R_EFLG,d,fill,s)
200 #define sbb_byte(d,s) sbb_byte_asm(&M.x86.R_EFLG,d,s)
201 #define sbb_word(d,s) sbb_word_asm(&M.x86.R_EFLG,d,s)
202 #define sbb_long(d,s) sbb_long_asm(&M.x86.R_EFLG,d,s)
203 #define sub_byte(d,s) sub_byte_asm(&M.x86.R_EFLG,d,s)
204 #define sub_word(d,s) sub_word_asm(&M.x86.R_EFLG,d,s)
205 #define sub_long(d,s) sub_long_asm(&M.x86.R_EFLG,d,s)
206 #define test_byte(d,s) test_byte_asm(&M.x86.R_EFLG,d,s)
207 #define test_word(d,s) test_word_asm(&M.x86.R_EFLG,d,s)
208 #define test_long(d,s) test_long_asm(&M.x86.R_EFLG,d,s)
209 #define xor_byte(d,s) xor_byte_asm(&M.x86.R_EFLG,d,s)
210 #define xor_word(d,s) xor_word_asm(&M.x86.R_EFLG,d,s)
211 #define xor_long(d,s) xor_long_asm(&M.x86.R_EFLG,d,s)
212 #define imul_byte(s) imul_byte_asm(&M.x86.R_EFLG,&M.x86.R_AX,M.x86.R_AL,s)
213 #define imul_word(s) imul_word_asm(&M.x86.R_EFLG,&M.x86.R_AX,&M.x86.R_DX,M.x86.R_AX,s)
214 #define imul_long(s) imul_long_asm(&M.x86.R_EFLG,&M.x86.R_EAX,&M.x86.R_EDX,M.x86.R_EAX,s)
215 #define imul_long_direct(res_lo,res_hi,d,s) imul_long_asm(&M.x86.R_EFLG,res_lo,res_hi,d,s)
216 #define mul_byte(s) mul_byte_asm(&M.x86.R_EFLG,&M.x86.R_AX,M.x86.R_AL,s)
217 #define mul_word(s) mul_word_asm(&M.x86.R_EFLG,&M.x86.R_AX,&M.x86.R_DX,M.x86.R_AX,s)
218 #define mul_long(s) mul_long_asm(&M.x86.R_EFLG,&M.x86.R_EAX,&M.x86.R_EDX,M.x86.R_EAX,s)
219 #define idiv_byte(s) idiv_byte_asm(&M.x86.R_EFLG,&M.x86.R_AL,&M.x86.R_AH,M.x86.R_AX,s)
220 #define idiv_word(s) idiv_word_asm(&M.x86.R_EFLG,&M.x86.R_AX,&M.x86.R_DX,M.x86.R_AX,M.x86.R_DX,s)
221 #define idiv_long(s) idiv_long_asm(&M.x86.R_EFLG,&M.x86.R_EAX,&M.x86.R_EDX,M.x86.R_EAX,M.x86.R_EDX,s)
222 #define div_byte(s) div_byte_asm(&M.x86.R_EFLG,&M.x86.R_AL,&M.x86.R_AH,M.x86.R_AX,s)
223 #define div_word(s) div_word_asm(&M.x86.R_EFLG,&M.x86.R_AX,&M.x86.R_DX,M.x86.R_AX,M.x86.R_DX,s)
224 #define div_long(s) div_long_asm(&M.x86.R_EFLG,&M.x86.R_EAX,&M.x86.R_EDX,M.x86.R_EAX,M.x86.R_EDX,s)
226 #endif
228 #ifdef __cplusplus
229 } /* End of "C" linkage for C++ */
230 #endif
232 #endif /* __X86EMU_PRIM_OPS_H */