/* $Id: bs3-cpu-instr-2.c 106061 2024-09-16 14:03:52Z vboxsync $ */ /** @file * BS3Kit - bs3-cpu-instr-2, 16-bit C code. */ /* * Copyright (C) 2007-2024 Oracle and/or its affiliates. * * This file is part of VirtualBox base platform packages, as * available from https://www.virtualbox.org. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation, in version 3 of the * License. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see . * * The contents of this file may alternatively be used under the terms * of the Common Development and Distribution License Version 1.0 * (CDDL), a copy of it is provided in the "COPYING.CDDL" file included * in the VirtualBox distribution, in which case the provisions of the * CDDL are applicable instead of those of the GPL. * * You may elect to license modified versions of this file under the * terms and conditions of either the GPL or the CDDL or both. * * SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0 */ /********************************************************************************************************************************* * Header Files * *********************************************************************************************************************************/ #include /********************************************************************************************************************************* * Internal Functions * *********************************************************************************************************************************/ BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_and); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_or); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_xor); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_test); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_add); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_adc); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_sub); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_sbb); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_cmp); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_bt); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_btc); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_btr); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_bts); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_shl); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_shr); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_sar); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_rol); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_ror); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_rcl); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_rcr); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_mul); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_imul); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_div); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_idiv); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_bsf_tzcnt); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_bsr_lzcnt); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_andn); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_bextr); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_blsr); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_blsmsk); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_blsi); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_bzhi); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_pdep); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_pext); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_rorx); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_shlx); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_sarx); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_shrx); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_mulx); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_popcnt); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_crc32); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_adcx_adox); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_movbe); BS3TESTMODE_PROTOTYPES_CMN(bs3CpuInstr2_cmpxchg8b); BS3TESTMODE_PROTOTYPES_CMN_64(bs3CpuInstr2_cmpxchg16b); BS3TESTMODE_PROTOTYPES_CMN_64(bs3CpuInstr2_wrfsbase); BS3TESTMODE_PROTOTYPES_CMN_64(bs3CpuInstr2_wrgsbase); BS3TESTMODE_PROTOTYPES_CMN_64(bs3CpuInstr2_rdfsbase); BS3TESTMODE_PROTOTYPES_CMN_64(bs3CpuInstr2_rdgsbase); /********************************************************************************************************************************* * Global Variables * *********************************************************************************************************************************/ static const BS3TESTMODEENTRY g_aModeTests[] = { #if 1 /*ndef DEBUG_bird*/ # define ALL_TESTS #endif #if defined(ALL_TESTS) BS3TESTMODEENTRY_CMN("and", bs3CpuInstr2_and), BS3TESTMODEENTRY_CMN("or", bs3CpuInstr2_or), BS3TESTMODEENTRY_CMN("xor", bs3CpuInstr2_xor), BS3TESTMODEENTRY_CMN("test", bs3CpuInstr2_test), #endif #if defined(ALL_TESTS) BS3TESTMODEENTRY_CMN("add", bs3CpuInstr2_add), BS3TESTMODEENTRY_CMN("adc", bs3CpuInstr2_adc), BS3TESTMODEENTRY_CMN("sub", bs3CpuInstr2_sub), BS3TESTMODEENTRY_CMN("sbb", bs3CpuInstr2_sbb), BS3TESTMODEENTRY_CMN("cmp", bs3CpuInstr2_cmp), #endif #if defined(ALL_TESTS) BS3TESTMODEENTRY_CMN("bt", bs3CpuInstr2_bt), BS3TESTMODEENTRY_CMN("btc", bs3CpuInstr2_btc), BS3TESTMODEENTRY_CMN("btr", bs3CpuInstr2_btr), BS3TESTMODEENTRY_CMN("bts", bs3CpuInstr2_bts), #endif #if defined(ALL_TESTS) BS3TESTMODEENTRY_CMN("shl", bs3CpuInstr2_shl), BS3TESTMODEENTRY_CMN("shr", bs3CpuInstr2_shr), BS3TESTMODEENTRY_CMN("sar", bs3CpuInstr2_sar), # if 0/** @todo temporarily disabled till the flag handling in immediate variants have been solved on Intel. */ BS3TESTMODEENTRY_CMN("rol", bs3CpuInstr2_rol), BS3TESTMODEENTRY_CMN("ror", bs3CpuInstr2_ror), # endif BS3TESTMODEENTRY_CMN("rcl", bs3CpuInstr2_rcl), BS3TESTMODEENTRY_CMN("rcr", bs3CpuInstr2_rcr), #endif #if defined(ALL_TESTS) BS3TESTMODEENTRY_CMN("mul", bs3CpuInstr2_mul), BS3TESTMODEENTRY_CMN("imul", bs3CpuInstr2_imul), BS3TESTMODEENTRY_CMN("div", bs3CpuInstr2_div), BS3TESTMODEENTRY_CMN("idiv", bs3CpuInstr2_idiv), #endif #if defined(ALL_TESTS) /* BSF/BSR (386+) & TZCNT/LZCNT (BMI1,ABM) */ BS3TESTMODEENTRY_CMN("bsf/tzcnt", bs3CpuInstr2_bsf_tzcnt), BS3TESTMODEENTRY_CMN("bsr/lzcnt", bs3CpuInstr2_bsr_lzcnt), #endif #if defined(ALL_TESTS) /* BMI1 */ BS3TESTMODEENTRY_CMN("andn", bs3CpuInstr2_andn), BS3TESTMODEENTRY_CMN("bextr", bs3CpuInstr2_bextr), BS3TESTMODEENTRY_CMN("blsr", bs3CpuInstr2_blsr), BS3TESTMODEENTRY_CMN("blsmsk", bs3CpuInstr2_blsmsk), BS3TESTMODEENTRY_CMN("blsi", bs3CpuInstr2_blsi), #endif #if defined(ALL_TESTS) /* BMI2 */ BS3TESTMODEENTRY_CMN("bzhi", bs3CpuInstr2_bzhi), BS3TESTMODEENTRY_CMN("pdep", bs3CpuInstr2_pdep), BS3TESTMODEENTRY_CMN("pext", bs3CpuInstr2_pext), BS3TESTMODEENTRY_CMN("rorx", bs3CpuInstr2_rorx), BS3TESTMODEENTRY_CMN("shlx", bs3CpuInstr2_shlx), BS3TESTMODEENTRY_CMN("sarx", bs3CpuInstr2_sarx), BS3TESTMODEENTRY_CMN("shrx", bs3CpuInstr2_shrx), BS3TESTMODEENTRY_CMN("mulx", bs3CpuInstr2_mulx), #endif #if defined(ALL_TESTS) BS3TESTMODEENTRY_CMN("popcnt", bs3CpuInstr2_popcnt), /* Intel: POPCNT; AMD: ABM */ BS3TESTMODEENTRY_CMN("crc32", bs3CpuInstr2_crc32), /* SSE4.2 */ BS3TESTMODEENTRY_CMN("adcx/adox", bs3CpuInstr2_adcx_adox), /* ADX */ BS3TESTMODEENTRY_CMN("movbe", bs3CpuInstr2_movbe), /* MOVBE */ BS3TESTMODEENTRY_CMN("cmpxchg8b", bs3CpuInstr2_cmpxchg8b), #endif #if defined(ALL_TESTS) BS3TESTMODEENTRY_CMN_64("cmpxchg16b", bs3CpuInstr2_cmpxchg16b), BS3TESTMODEENTRY_CMN_64("wrfsbase", bs3CpuInstr2_wrfsbase), BS3TESTMODEENTRY_CMN_64("wrgsbase", bs3CpuInstr2_wrgsbase), BS3TESTMODEENTRY_CMN_64("rdfsbase", bs3CpuInstr2_rdfsbase), BS3TESTMODEENTRY_CMN_64("rdgsbase", bs3CpuInstr2_rdgsbase), #endif }; BS3_DECL(void) Main_rm() { Bs3InitAll_rm(); Bs3TestInit("bs3-cpu-instr-2"); Bs3TestDoModes_rm(g_aModeTests, RT_ELEMENTS(g_aModeTests)); Bs3TestTerm(); }