diff options
| author | Stefan Roese <sr@denx.de> | 2007-08-14 16:36:29 +0200 | 
|---|---|---|
| committer | Stefan Roese <sr@denx.de> | 2007-08-14 16:36:29 +0200 | 
| commit | 3b3bff4cbf2cb14f9a3e7d03f26ebab900efe4ae (patch) | |
| tree | fb66bf8861d9f78765160d734a438856f5317cdb /drivers/bios_emulator/include/x86emu/prim_asm.h | |
| parent | 4ce846ec59f36b85d6644a769690ad3feb667575 (diff) | |
| parent | 4ef35e53c693556c54b0c22d6f873de87bade253 (diff) | |
| download | olio-uboot-2014.01-3b3bff4cbf2cb14f9a3e7d03f26ebab900efe4ae.tar.xz olio-uboot-2014.01-3b3bff4cbf2cb14f9a3e7d03f26ebab900efe4ae.zip | |
Merge with git://www.denx.de/git/u-boot.git
Diffstat (limited to 'drivers/bios_emulator/include/x86emu/prim_asm.h')
| -rw-r--r-- | drivers/bios_emulator/include/x86emu/prim_asm.h | 970 | 
1 files changed, 970 insertions, 0 deletions
| diff --git a/drivers/bios_emulator/include/x86emu/prim_asm.h b/drivers/bios_emulator/include/x86emu/prim_asm.h new file mode 100644 index 000000000..4cb4cab5d --- /dev/null +++ b/drivers/bios_emulator/include/x86emu/prim_asm.h @@ -0,0 +1,970 @@ +/**************************************************************************** +* +*                       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 */ |