Changeset 105215 in vbox
- Timestamp:
- Jul 9, 2024 8:34:27 AM (7 months ago)
- Location:
- trunk/src/VBox/VMM
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/VMM/VMMAll/IEMAllAImplC.cpp
r105214 r105215 16178 16178 16179 16179 /** 16180 * SUBPD 16181 */ 16182 #ifdef IEM_WITHOUT_ASSEMBLY 16180 * [V]SUBPD 16181 */ 16183 16182 static uint32_t iemAImpl_subpd_u128_worker(PRTFLOAT64U pr64Res, uint32_t fMxcsr, PCRTFLOAT64U pr64Val1, PCRTFLOAT64U pr64Val2) 16184 16183 { … … 16195 16194 16196 16195 16196 #ifdef IEM_WITHOUT_ASSEMBLY 16197 16197 IEM_DECL_IMPL_DEF(uint32_t, iemAImpl_subpd_u128,(uint32_t uMxCsrIn, PX86XMMREG pResult, PCX86XMMREG puSrc1, PCX86XMMREG puSrc2)) 16198 16198 { … … 16201 16201 } 16202 16202 #endif 16203 16204 16205 IEM_DECL_IMPL_DEF(uint32_t, iemAImpl_vsubpd_u128_fallback,(uint32_t uMxCsrIn, PX86XMMREG pResult, PCX86XMMREG puSrc1, PCX86XMMREG puSrc2)) 16206 { 16207 return iemAImpl_subpd_u128_worker(&pResult->ar64[0], uMxCsrIn, &puSrc1->ar64[0], &puSrc2->ar64[0]) 16208 | iemAImpl_subpd_u128_worker(&pResult->ar64[1], uMxCsrIn, &puSrc1->ar64[1], &puSrc2->ar64[1]) 16209 | iemAImpl_subpd_u128_worker(&pResult->ar64[2], uMxCsrIn, &puSrc1->ar64[2], &puSrc2->ar64[2]) 16210 | iemAImpl_subpd_u128_worker(&pResult->ar64[3], uMxCsrIn, &puSrc1->ar64[3], &puSrc2->ar64[3]); 16211 } 16212 16213 16214 IEM_DECL_IMPL_DEF(uint32_t, iemAImpl_vsubpd_u256_fallback,(uint32_t uMxCsrIn, PX86YMMREG pResult, PCX86YMMREG puSrc1, PCX86YMMREG puSrc2)) 16215 { 16216 return iemAImpl_subpd_u128_worker(&pResult->ar64[0], uMxCsrIn, &puSrc1->ar64[0], &puSrc2->ar64[0]) 16217 | iemAImpl_subpd_u128_worker(&pResult->ar64[1], uMxCsrIn, &puSrc1->ar64[1], &puSrc2->ar64[1]) 16218 | iemAImpl_subpd_u128_worker(&pResult->ar64[2], uMxCsrIn, &puSrc1->ar64[2], &puSrc2->ar64[2]) 16219 | iemAImpl_subpd_u128_worker(&pResult->ar64[3], uMxCsrIn, &puSrc1->ar64[3], &puSrc2->ar64[3]) 16220 | iemAImpl_subpd_u128_worker(&pResult->ar64[4], uMxCsrIn, &puSrc1->ar64[4], &puSrc2->ar64[4]) 16221 | iemAImpl_subpd_u128_worker(&pResult->ar64[5], uMxCsrIn, &puSrc1->ar64[5], &puSrc2->ar64[5]) 16222 | iemAImpl_subpd_u128_worker(&pResult->ar64[6], uMxCsrIn, &puSrc1->ar64[6], &puSrc2->ar64[6]) 16223 | iemAImpl_subpd_u128_worker(&pResult->ar64[7], uMxCsrIn, &puSrc1->ar64[7], &puSrc2->ar64[7]); 16224 } 16203 16225 16204 16226 -
trunk/src/VBox/VMM/VMMAll/IEMAllInstVexMap1.cpp.h
r105214 r105215 2960 2960 2961 2961 /** Opcode VEX.66.0F 0x5c - vsubpd Vpd, Hpd, Wpd */ 2962 FNIEMOP_STUB(iemOp_vsubpd_Vpd_Hpd_Wpd); 2962 FNIEMOP_DEF(iemOp_vsubpd_Vpd_Hpd_Wpd) 2963 { 2964 IEMOP_MNEMONIC3(VEX_RVM, VSUBPD, vsubpd, Vpd, Hpd, Wpd, DISOPTYPE_HARMLESS | DISOPTYPE_X86_AVX, 0); 2965 IEMOPMEDIAF3_INIT_VARS( vsubpd); 2966 return FNIEMOP_CALL_1(iemOpCommonAvxAvx2_Vx_Hx_Wx, IEM_SELECT_HOST_OR_FALLBACK(fAvx, &s_Host, &s_Fallback)); 2967 } 2968 2969 2963 2970 /** Opcode VEX.F3.0F 0x5c - vsubss Vss, Hss, Wss */ 2964 2971 FNIEMOP_STUB(iemOp_vsubss_Vss_Hss_Wss); -
trunk/src/VBox/VMM/include/IEMInternal.h
r105214 r105215 4560 4560 FNIEMAIMPLFPAVXF3U128 iemAImpl_vmulpd_u128, iemAImpl_vmulpd_u128_fallback; 4561 4561 FNIEMAIMPLMEDIAF3U128 iemAImpl_vsubps_u128, iemAImpl_vsubps_u128_fallback; 4562 FNIEMAIMPL FPAVXF3U128 iemAImpl_vsubpd_u128, iemAImpl_vsubpd_u128_fallback;4562 FNIEMAIMPLMEDIAF3U128 iemAImpl_vsubpd_u128, iemAImpl_vsubpd_u128_fallback; 4563 4563 FNIEMAIMPLFPAVXF3U128 iemAImpl_vminps_u128, iemAImpl_vminps_u128_fallback; 4564 4564 FNIEMAIMPLFPAVXF3U128 iemAImpl_vminpd_u128, iemAImpl_vminpd_u128_fallback;
Note:
See TracChangeset
for help on using the changeset viewer.