root/headers/libs/x86emu/x86emu/prim_asm.h
/****************************************************************************
*
*                                               Realmode X86 Emulator Library
*
*               Copyright (C) 1996-1999 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 */