mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-09 19:58:55 +00:00
971 lines
33 KiB
C
971 lines
33 KiB
C
|
/****************************************************************************
|
||
|
*
|
||
|
* Realmode X86 Emulator Library
|
||
|
*
|
||
|
* Copyright (C) 1991-2004 SciTech Software, Inc.
|
||
|
* Copyright (C) David Mosberger-Tang
|
||
|
* Copyright (C) 1999 Egbert Eich
|
||
|
*
|
||
|
* ========================================================================
|
||
|
*
|
||
|
* Permission to use, copy, modify, distribute, and sell this software and
|
||
|
* its documentation for any purpose is hereby granted without fee,
|
||
|
* provided that the above copyright notice appear in all copies and that
|
||
|
* both that copyright notice and this permission notice appear in
|
||
|
* supporting documentation, and that the name of the authors not be used
|
||
|
* in advertising or publicity pertaining to distribution of the software
|
||
|
* without specific, written prior permission. The authors makes no
|
||
|
* representations about the suitability of this software for any purpose.
|
||
|
* It is provided "as is" without express or implied warranty.
|
||
|
*
|
||
|
* THE AUTHORS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||
|
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
||
|
* EVENT SHALL THE AUTHORS BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||
|
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||
|
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||
|
* PERFORMANCE OF THIS SOFTWARE.
|
||
|
*
|
||
|
* ========================================================================
|
||
|
*
|
||
|
* Language: Watcom C++ 10.6 or later
|
||
|
* Environment: Any
|
||
|
* Developer: Kendall Bennett
|
||
|
*
|
||
|
* Description: Inline assembler versions of the primitive operand
|
||
|
* functions for faster performance. At the moment this is
|
||
|
* x86 inline assembler, but these functions could be replaced
|
||
|
* with native inline assembler for each supported processor
|
||
|
* platform.
|
||
|
*
|
||
|
****************************************************************************/
|
||
|
|
||
|
#ifndef __X86EMU_PRIM_ASM_H
|
||
|
#define __X86EMU_PRIM_ASM_H
|
||
|
|
||
|
#ifdef __WATCOMC__
|
||
|
|
||
|
#ifndef VALIDATE
|
||
|
#define __HAVE_INLINE_ASSEMBLER__
|
||
|
#endif
|
||
|
|
||
|
u32 get_flags_asm(void);
|
||
|
#pragma aux get_flags_asm = \
|
||
|
"pushf" \
|
||
|
"pop eax" \
|
||
|
value [eax] \
|
||
|
modify exact [eax];
|
||
|
|
||
|
u16 aaa_word_asm(u32 * flags, u16 d);
|
||
|
#pragma aux aaa_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"aaa" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u16 aas_word_asm(u32 * flags, u16 d);
|
||
|
#pragma aux aas_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"aas" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u16 aad_word_asm(u32 * flags, u16 d);
|
||
|
#pragma aux aad_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"aad" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u16 aam_word_asm(u32 * flags, u8 d);
|
||
|
#pragma aux aam_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"aam" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u8 adc_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux adc_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"adc al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 adc_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux adc_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"adc ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 adc_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux adc_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"adc eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
u8 add_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux add_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"add al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 add_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux add_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"add ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 add_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux add_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"add eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
u8 and_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux and_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"and al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 and_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux and_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"and ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 and_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux and_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"and eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
u8 cmp_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux cmp_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"cmp al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 cmp_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux cmp_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"cmp ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 cmp_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux cmp_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"cmp eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
u8 daa_byte_asm(u32 * flags, u8 d);
|
||
|
#pragma aux daa_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"daa" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] \
|
||
|
value [al] \
|
||
|
modify exact [al];
|
||
|
|
||
|
u8 das_byte_asm(u32 * flags, u8 d);
|
||
|
#pragma aux das_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"das" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] \
|
||
|
value [al] \
|
||
|
modify exact [al];
|
||
|
|
||
|
u8 dec_byte_asm(u32 * flags, u8 d);
|
||
|
#pragma aux dec_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"dec al" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] \
|
||
|
value [al] \
|
||
|
modify exact [al];
|
||
|
|
||
|
u16 dec_word_asm(u32 * flags, u16 d);
|
||
|
#pragma aux dec_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"dec ax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u32 dec_long_asm(u32 * flags, u32 d);
|
||
|
#pragma aux dec_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"dec eax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] \
|
||
|
value [eax] \
|
||
|
modify exact [eax];
|
||
|
|
||
|
u8 inc_byte_asm(u32 * flags, u8 d);
|
||
|
#pragma aux inc_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"inc al" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] \
|
||
|
value [al] \
|
||
|
modify exact [al];
|
||
|
|
||
|
u16 inc_word_asm(u32 * flags, u16 d);
|
||
|
#pragma aux inc_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"inc ax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u32 inc_long_asm(u32 * flags, u32 d);
|
||
|
#pragma aux inc_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"inc eax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] \
|
||
|
value [eax] \
|
||
|
modify exact [eax];
|
||
|
|
||
|
u8 or_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux or_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"or al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 or_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux or_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"or ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 or_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux or_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"or eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
u8 neg_byte_asm(u32 * flags, u8 d);
|
||
|
#pragma aux neg_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"neg al" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] \
|
||
|
value [al] \
|
||
|
modify exact [al];
|
||
|
|
||
|
u16 neg_word_asm(u32 * flags, u16 d);
|
||
|
#pragma aux neg_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"neg ax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u32 neg_long_asm(u32 * flags, u32 d);
|
||
|
#pragma aux neg_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"neg eax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] \
|
||
|
value [eax] \
|
||
|
modify exact [eax];
|
||
|
|
||
|
u8 not_byte_asm(u32 * flags, u8 d);
|
||
|
#pragma aux not_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"not al" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] \
|
||
|
value [al] \
|
||
|
modify exact [al];
|
||
|
|
||
|
u16 not_word_asm(u32 * flags, u16 d);
|
||
|
#pragma aux not_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"not ax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] \
|
||
|
value [ax] \
|
||
|
modify exact [ax];
|
||
|
|
||
|
u32 not_long_asm(u32 * flags, u32 d);
|
||
|
#pragma aux not_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"not eax" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] \
|
||
|
value [eax] \
|
||
|
modify exact [eax];
|
||
|
|
||
|
u8 rcl_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux rcl_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rcl al,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [cl] \
|
||
|
value [al] \
|
||
|
modify exact [al cl];
|
||
|
|
||
|
u16 rcl_word_asm(u32 * flags, u16 d, u8 s);
|
||
|
#pragma aux rcl_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rcl ax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax cl];
|
||
|
|
||
|
u32 rcl_long_asm(u32 * flags, u32 d, u8 s);
|
||
|
#pragma aux rcl_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rcl eax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax cl];
|
||
|
|
||
|
u8 rcr_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux rcr_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rcr al,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [cl] \
|
||
|
value [al] \
|
||
|
modify exact [al cl];
|
||
|
|
||
|
u16 rcr_word_asm(u32 * flags, u16 d, u8 s);
|
||
|
#pragma aux rcr_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rcr ax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax cl];
|
||
|
|
||
|
u32 rcr_long_asm(u32 * flags, u32 d, u8 s);
|
||
|
#pragma aux rcr_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rcr eax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax cl];
|
||
|
|
||
|
u8 rol_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux rol_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rol al,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [cl] \
|
||
|
value [al] \
|
||
|
modify exact [al cl];
|
||
|
|
||
|
u16 rol_word_asm(u32 * flags, u16 d, u8 s);
|
||
|
#pragma aux rol_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rol ax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax cl];
|
||
|
|
||
|
u32 rol_long_asm(u32 * flags, u32 d, u8 s);
|
||
|
#pragma aux rol_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"rol eax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax cl];
|
||
|
|
||
|
u8 ror_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux ror_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"ror al,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [cl] \
|
||
|
value [al] \
|
||
|
modify exact [al cl];
|
||
|
|
||
|
u16 ror_word_asm(u32 * flags, u16 d, u8 s);
|
||
|
#pragma aux ror_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"ror ax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax cl];
|
||
|
|
||
|
u32 ror_long_asm(u32 * flags, u32 d, u8 s);
|
||
|
#pragma aux ror_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"ror eax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax cl];
|
||
|
|
||
|
u8 shl_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux shl_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shl al,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [cl] \
|
||
|
value [al] \
|
||
|
modify exact [al cl];
|
||
|
|
||
|
u16 shl_word_asm(u32 * flags, u16 d, u8 s);
|
||
|
#pragma aux shl_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shl ax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax cl];
|
||
|
|
||
|
u32 shl_long_asm(u32 * flags, u32 d, u8 s);
|
||
|
#pragma aux shl_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shl eax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax cl];
|
||
|
|
||
|
u8 shr_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux shr_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shr al,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [cl] \
|
||
|
value [al] \
|
||
|
modify exact [al cl];
|
||
|
|
||
|
u16 shr_word_asm(u32 * flags, u16 d, u8 s);
|
||
|
#pragma aux shr_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shr ax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax cl];
|
||
|
|
||
|
u32 shr_long_asm(u32 * flags, u32 d, u8 s);
|
||
|
#pragma aux shr_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shr eax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax cl];
|
||
|
|
||
|
u8 sar_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux sar_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sar al,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [cl] \
|
||
|
value [al] \
|
||
|
modify exact [al cl];
|
||
|
|
||
|
u16 sar_word_asm(u32 * flags, u16 d, u8 s);
|
||
|
#pragma aux sar_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sar ax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax cl];
|
||
|
|
||
|
u32 sar_long_asm(u32 * flags, u32 d, u8 s);
|
||
|
#pragma aux sar_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sar eax,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax cl];
|
||
|
|
||
|
u16 shld_word_asm(u32 * flags, u16 d, u16 fill, u8 s);
|
||
|
#pragma aux shld_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shld ax,dx,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [dx] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax dx cl];
|
||
|
|
||
|
u32 shld_long_asm(u32 * flags, u32 d, u32 fill, u8 s);
|
||
|
#pragma aux shld_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shld eax,edx,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [edx] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax edx cl];
|
||
|
|
||
|
u16 shrd_word_asm(u32 * flags, u16 d, u16 fill, u8 s);
|
||
|
#pragma aux shrd_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shrd ax,dx,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [dx] [cl] \
|
||
|
value [ax] \
|
||
|
modify exact [ax dx cl];
|
||
|
|
||
|
u32 shrd_long_asm(u32 * flags, u32 d, u32 fill, u8 s);
|
||
|
#pragma aux shrd_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"shrd eax,edx,cl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [edx] [cl] \
|
||
|
value [eax] \
|
||
|
modify exact [eax edx cl];
|
||
|
|
||
|
u8 sbb_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux sbb_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sbb al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 sbb_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux sbb_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sbb ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 sbb_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux sbb_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sbb eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
u8 sub_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux sub_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sub al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 sub_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux sub_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sub ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 sub_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux sub_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"sub eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
void test_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux test_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"test al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
void test_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux test_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"test ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
void test_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux test_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"test eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
u8 xor_byte_asm(u32 * flags, u8 d, u8 s);
|
||
|
#pragma aux xor_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"xor al,bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [al] [bl] \
|
||
|
value [al] \
|
||
|
modify exact [al bl];
|
||
|
|
||
|
u16 xor_word_asm(u32 * flags, u16 d, u16 s);
|
||
|
#pragma aux xor_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"xor ax,bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [ax] [bx] \
|
||
|
value [ax] \
|
||
|
modify exact [ax bx];
|
||
|
|
||
|
u32 xor_long_asm(u32 * flags, u32 d, u32 s);
|
||
|
#pragma aux xor_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"xor eax,ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
parm [edi] [eax] [ebx] \
|
||
|
value [eax] \
|
||
|
modify exact [eax ebx];
|
||
|
|
||
|
void imul_byte_asm(u32 * flags, u16 * ax, u8 d, u8 s);
|
||
|
#pragma aux imul_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"imul bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],ax" \
|
||
|
parm [edi] [esi] [al] [bl] \
|
||
|
modify exact [esi ax bl];
|
||
|
|
||
|
void imul_word_asm(u32 * flags, u16 * ax, u16 * dx, u16 d, u16 s);
|
||
|
#pragma aux imul_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"imul bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],ax" \
|
||
|
"mov [ecx],dx" \
|
||
|
parm [edi] [esi] [ecx] [ax] [bx]\
|
||
|
modify exact [esi edi ax bx dx];
|
||
|
|
||
|
void imul_long_asm(u32 * flags, u32 * eax, u32 * edx, u32 d, u32 s);
|
||
|
#pragma aux imul_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"imul ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],eax" \
|
||
|
"mov [ecx],edx" \
|
||
|
parm [edi] [esi] [ecx] [eax] [ebx] \
|
||
|
modify exact [esi edi eax ebx edx];
|
||
|
|
||
|
void mul_byte_asm(u32 * flags, u16 * ax, u8 d, u8 s);
|
||
|
#pragma aux mul_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"mul bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],ax" \
|
||
|
parm [edi] [esi] [al] [bl] \
|
||
|
modify exact [esi ax bl];
|
||
|
|
||
|
void mul_word_asm(u32 * flags, u16 * ax, u16 * dx, u16 d, u16 s);
|
||
|
#pragma aux mul_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"mul bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],ax" \
|
||
|
"mov [ecx],dx" \
|
||
|
parm [edi] [esi] [ecx] [ax] [bx]\
|
||
|
modify exact [esi edi ax bx dx];
|
||
|
|
||
|
void mul_long_asm(u32 * flags, u32 * eax, u32 * edx, u32 d, u32 s);
|
||
|
#pragma aux mul_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"mul ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],eax" \
|
||
|
"mov [ecx],edx" \
|
||
|
parm [edi] [esi] [ecx] [eax] [ebx] \
|
||
|
modify exact [esi edi eax ebx edx];
|
||
|
|
||
|
void idiv_byte_asm(u32 * flags, u8 * al, u8 * ah, u16 d, u8 s);
|
||
|
#pragma aux idiv_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"idiv bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],al" \
|
||
|
"mov [ecx],ah" \
|
||
|
parm [edi] [esi] [ecx] [ax] [bl]\
|
||
|
modify exact [esi edi ax bl];
|
||
|
|
||
|
void idiv_word_asm(u32 * flags, u16 * ax, u16 * dx, u16 dlo, u16 dhi, u16 s);
|
||
|
#pragma aux idiv_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"idiv bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],ax" \
|
||
|
"mov [ecx],dx" \
|
||
|
parm [edi] [esi] [ecx] [ax] [dx] [bx]\
|
||
|
modify exact [esi edi ax dx bx];
|
||
|
|
||
|
void idiv_long_asm(u32 * flags, u32 * eax, u32 * edx, u32 dlo, u32 dhi, u32 s);
|
||
|
#pragma aux idiv_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"idiv ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],eax" \
|
||
|
"mov [ecx],edx" \
|
||
|
parm [edi] [esi] [ecx] [eax] [edx] [ebx]\
|
||
|
modify exact [esi edi eax edx ebx];
|
||
|
|
||
|
void div_byte_asm(u32 * flags, u8 * al, u8 * ah, u16 d, u8 s);
|
||
|
#pragma aux div_byte_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"div bl" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],al" \
|
||
|
"mov [ecx],ah" \
|
||
|
parm [edi] [esi] [ecx] [ax] [bl]\
|
||
|
modify exact [esi edi ax bl];
|
||
|
|
||
|
void div_word_asm(u32 * flags, u16 * ax, u16 * dx, u16 dlo, u16 dhi, u16 s);
|
||
|
#pragma aux div_word_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"div bx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],ax" \
|
||
|
"mov [ecx],dx" \
|
||
|
parm [edi] [esi] [ecx] [ax] [dx] [bx]\
|
||
|
modify exact [esi edi ax dx bx];
|
||
|
|
||
|
void div_long_asm(u32 * flags, u32 * eax, u32 * edx, u32 dlo, u32 dhi, u32 s);
|
||
|
#pragma aux div_long_asm = \
|
||
|
"push [edi]" \
|
||
|
"popf" \
|
||
|
"div ebx" \
|
||
|
"pushf" \
|
||
|
"pop [edi]" \
|
||
|
"mov [esi],eax" \
|
||
|
"mov [ecx],edx" \
|
||
|
parm [edi] [esi] [ecx] [eax] [edx] [ebx]\
|
||
|
modify exact [esi edi eax edx ebx];
|
||
|
|
||
|
#endif
|
||
|
|
||
|
#endif /* __X86EMU_PRIM_ASM_H */
|