IEMAllAImplC.cpp revision ae0f43c83076f2e5349ca6707a1d06b4d81d168f
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * IEM - Instruction Implementation in Assembly, portable C variant.
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * Copyright (C) 2011-2013 Oracle Corporation
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * available from http://www.virtualbox.org. This file is free software;
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * you can redistribute it and/or modify it under the terms of the GNU
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * General Public License (GPL) as published by the Free Software
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync/*******************************************************************************
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync* Header Files *
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync*******************************************************************************/
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync/*******************************************************************************
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync* Global Variables *
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync*******************************************************************************/
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * Parity calculation table.
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * The generator code:
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * #include <stdio.h>
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * int main()
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * unsigned b;
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * for (b = 0; b < 256; b++)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * int cOnes = ( b & 1)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * + ((b >> 1) & 1)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * + ((b >> 2) & 1)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * + ((b >> 3) & 1)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * + ((b >> 4) & 1)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * + ((b >> 5) & 1)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * + ((b >> 6) & 1)
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * + ((b >> 7) & 1);
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * printf(" /" "* %#04x = %u%u%u%u%u%u%u%ub *" "/ %s,\n",
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * (b >> 7) & 1,
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * (b >> 6) & 1,
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * (b >> 5) & 1,
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * (b >> 4) & 1,
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * (b >> 3) & 1,
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * (b >> 2) & 1,
3194da424708abdd288b28d96892b3a5f3f7df0bvboxsync * (b >> 1) & 1,
#ifdef RT_ARCH_X86
IEM_DECL_IMPL_DEF(void, iemAImpl_add_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_adc_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_sub_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_sbb_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_or_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_xor_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_and_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_xadd_u64_locked,(uint64_t *puDst, uint64_t *puReg, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_btc_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_btr_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
IEM_DECL_IMPL_DEF(void, iemAImpl_bts_u64_locked,(uint64_t *puDst, uint64_t uSrc, uint32_t *pfEFlags))
if (uSrc)
iBit = 0;
if (uSrc)
if (cShift)
if (cShift)
if (cShift)
if (cShift)
if (cShift)
if (cShift)
if (cShift)
IEM_DECL_IMPL_DEF(void, iemAImpl_shld_u64,(uint64_t *puDst, uint64_t uSrc, uint8_t cShift, uint32_t *pfEFlags))
if (cShift)
IEM_DECL_IMPL_DEF(void, iemAImpl_shrd_u64,(uint64_t *puDst, uint64_t uSrc, uint8_t cShift, uint32_t *pfEFlags))
if (cShift)
ASMNopPause();
IEM_DECL_IMPL_DEF(int, iemAImpl_mul_u64,(uint64_t *pu64RAX, uint64_t *pu64RDX, uint64_t u64Factor, uint32_t *pfEFlags))
AssertFailed();
IEM_DECL_IMPL_DEF(int, iemAImpl_imul_u64,(uint64_t *pu64RAX, uint64_t *pu64RDX, uint64_t u64Factor, uint32_t *pfEFlags))
AssertFailed();
AssertFailed();
IEM_DECL_IMPL_DEF(int, iemAImpl_div_u64,(uint64_t *pu64RAX, uint64_t *pu64RDX, uint64_t u64Divisor, uint32_t *pfEFlags))
AssertFailed();
IEM_DECL_IMPL_DEF(int, iemAImpl_idiv_u64,(uint64_t *pu64RAX, uint64_t *pu64RDX, uint64_t u64Divisor, uint32_t *pfEFlags))
AssertFailed();