/* $Id: bs3-cmn-ExtCtxInit.c 95371 2022-06-24 23:11:42Z vboxsync $ */ /** @file * BS3Kit - Bs3ExtCtxInit */ /* * Copyright (C) 2007-2022 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. * * The contents of this file may alternatively be used under the terms * of the Common Development and Distribution License Version 1.0 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the * VirtualBox OSE 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. */ /********************************************************************************************************************************* * Header Files * *********************************************************************************************************************************/ #include "bs3kit-template-header.h" #include #undef Bs3ExtCtxInit BS3_CMN_DEF(PBS3EXTCTX, Bs3ExtCtxInit,(PBS3EXTCTX pExtCtx, uint16_t cbExtCtx, uint64_t fFlags)) { Bs3MemSet(pExtCtx, 0, cbExtCtx); if (cbExtCtx >= RT_UOFFSETOF(BS3EXTCTX, Ctx) + sizeof(X86FXSTATE) + sizeof(X86XSAVEHDR)) { BS3_ASSERT(fFlags & XSAVE_C_X87); pExtCtx->enmMethod = BS3EXTCTXMETHOD_XSAVE; pExtCtx->Ctx.x.Hdr.bmXState = fFlags; /* Setting bit 6 (0x40) here as it kept sneaking in when loading/saving state in 16-bit and v8086 mode. */ pExtCtx->Ctx.x.x87.FCW = X86_FCW_RC_NEAREST | X86_FCW_PC_64 /* go figure:*/ | RT_BIT(6); pExtCtx->Ctx.x.x87.MXCSR = X86_MXCSR_RC_NEAREST; pExtCtx->Ctx.x.x87.MXCSR_MASK = 0xffff; } else if (cbExtCtx >= RT_UOFFSETOF(BS3EXTCTX, Ctx) + sizeof(X86FXSTATE)) { BS3_ASSERT(fFlags == 0); pExtCtx->enmMethod = BS3EXTCTXMETHOD_FXSAVE; pExtCtx->Ctx.x87.FCW = X86_FCW_RC_NEAREST | X86_FCW_PC_64 /* go figure:*/ | RT_BIT(6); pExtCtx->Ctx.x87.MXCSR = X86_MXCSR_RC_NEAREST; pExtCtx->Ctx.x87.MXCSR_MASK = 0xffff; } else { BS3_ASSERT(fFlags == 0); BS3_ASSERT(cbExtCtx >= RT_UOFFSETOF(BS3EXTCTX, Ctx) + sizeof(X86FPUSTATE)); pExtCtx->enmMethod = BS3EXTCTXMETHOD_ANCIENT; pExtCtx->Ctx.Ancient.FCW = X86_FCW_RC_NEAREST | X86_FCW_PC_64 /* go figure:*/ | RT_BIT(6); pExtCtx->Ctx.Ancient.FTW = UINT16_MAX; /* all registers empty */ } pExtCtx->cb = cbExtCtx; pExtCtx->u16Magic = BS3EXTCTX_MAGIC; pExtCtx->fXcr0Nominal = fFlags; pExtCtx->fXcr0Saved = fFlags; return pExtCtx; }