e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync/* $Id$ */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync/** @file
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * VBox Context state saving/loading used by VM snapshot
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync/*
c7814cf6e1240a519cbec0441e033d0e2470ed00vboxsync * Copyright (C) 2008-2013 Oracle Corporation
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * available from http://www.virtualbox.org. This file is free software;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * you can redistribute it and/or modify it under the terms of the GNU
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * General Public License (GPL) as published by the Free Software
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#include "state.h"
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync#include "state_internals.h"
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#include "state/cr_statetypes.h"
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#include "state/cr_texture.h"
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#include "cr_mem.h"
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync#include "cr_string.h"
f11a163be74ca22a873fc5437f7e2cbf6ab7a564vboxsync#include "cr_pixeldata.h"
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync#include <stdio.h>
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#include <iprt/assert.h>
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#include <iprt/types.h>
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#include <iprt/err.h>
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#include <VBox/err.h>
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync/* @todo
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * We have two ways of saving/loading states.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * First which is being used atm, just pure saving/loading of structures.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * The drawback is we have to deal with all the pointers around those structures,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * we'd have to update this code if we'd change state tracking.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * On the bright side it's fast, though it's not really needed as it's not that often operation.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * It could also worth to split those functions into appropriate parts,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * similar to the way context creation is being done.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * Second way would be to implement full dispatch api table and substitute diff_api during saving/loading.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * Then if we implement that api in a similar way to packer/unpacker with a change to store/load
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * via provided pSSM handle instead of pack buffer,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * saving state could be done by simple diffing against empty "dummy" context.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * Restoring state in such case would look like unpacking commands from pSSM instead of network buffer.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * This would be slower (who cares) but most likely will not require any code changes to support in future.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * We will reduce amount of saved data as we'd save only changed state parts, but I doubt it'd be that much.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * It could be done for the first way as well, but requires tons of bit checks.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateAllocAndSSMR3GetMem(PSSMHANDLE pSSM, void **pBuffer, size_t cbBuffer)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pSSM && pBuffer && cbBuffer>0);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *pBuffer = crAlloc(cbBuffer);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!*pBuffer)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return SSMR3GetMem(pSSM, *pBuffer, cbBuffer);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#define SHCROGL_GET_STRUCT_PART(_pPtr, _type, _from, _to) do { \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, &(_pPtr)->_from, RT_OFFSETOF(_type, _to) - RT_OFFSETOF(_type, _from)); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync } while (0)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#define SHCROGL_GET_STRUCT_TAIL(_pPtr, _type, _from) do { \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, &(_pPtr)->_from, sizeof (_type) - RT_OFFSETOF(_type, _from)); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync } while (0)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#define SHCROGL_GET_STRUCT_HEAD(_pPtr, _type, _to) do { \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, (_pPtr), RT_OFFSETOF(_type, _to)); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync } while (0)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#define SHCROGL_CUT_FIELD_ALIGNMENT_SIZE(_type, _prevField, _field) (RT_OFFSETOF(_type, _field) - RT_OFFSETOF(_type, _prevField) - RT_SIZEOFMEMB(_type, _prevField))
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#define SHCROGL_CUT_FIELD_ALIGNMENT(_type, _prevField, _field) do { \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync const int32_t cbAlignment = SHCROGL_CUT_FIELD_ALIGNMENT_SIZE(_type, _prevField, _field) ; \
72045adcc823bc894f97f9a51d4e4b48b5ce0e39vboxsync /*AssertCompile(SHCROGL_CUT_FIELD_ALIGNMENT_SIZE(_type, _prevField, _field) >= 0 && SHCROGL_CUT_FIELD_ALIGNMENT_SIZE(_type, _prevField, _field) < sizeof (void*));*/ \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync if (cbAlignment) { \
72045adcc823bc894f97f9a51d4e4b48b5ce0e39vboxsync rc = SSMR3Skip(pSSM, cbAlignment); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync } \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync } while (0)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#define SHCROGL_ROUNDBOUND(_v, _b) (((_v) + ((_b) - 1)) & ~((_b) - 1))
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#define SHCROGL_ALIGNTAILSIZE(_v, _b) (SHCROGL_ROUNDBOUND((_v),(_b)) - (_v))
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#define SHCROGL_CUT_FOR_OLD_TYPE_TO_ENSURE_ALIGNMENT_SIZE(_type, _field, _oldFieldType, _nextFieldAllignment) (SHCROGL_ALIGNTAILSIZE(((RT_OFFSETOF(_type, _field) + sizeof (_oldFieldType))), (_nextFieldAllignment)))
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#define SHCROGL_CUT_FOR_OLD_TYPE_TO_ENSURE_ALIGNMENT(_type, _field, _oldFieldType, _nextFieldAllignment) do { \
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync const int32_t cbAlignment = SHCROGL_CUT_FOR_OLD_TYPE_TO_ENSURE_ALIGNMENT_SIZE(_type, _field, _oldFieldType, _nextFieldAllignment); \
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync /*AssertCompile(SHCROGL_CUT_TAIL_ALIGNMENT_SIZE(_type, _lastField) >= 0 && SHCROGL_CUT_TAIL_ALIGNMENT_SIZE(_type, _lastField) < sizeof (void*));*/ \
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync if (cbAlignment) { \
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = SSMR3Skip(pSSM, cbAlignment); \
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync } \
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync } while (0)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#define SHCROGL_CUT_TAIL_ALIGNMENT_SIZE(_type, _lastField) (sizeof (_type) - RT_OFFSETOF(_type, _lastField) - RT_SIZEOFMEMB(_type, _lastField))
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#define SHCROGL_CUT_TAIL_ALIGNMENT(_type, _lastField) do { \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync const int32_t cbAlignment = SHCROGL_CUT_TAIL_ALIGNMENT_SIZE(_type, _lastField); \
72045adcc823bc894f97f9a51d4e4b48b5ce0e39vboxsync /*AssertCompile(SHCROGL_CUT_TAIL_ALIGNMENT_SIZE(_type, _lastField) >= 0 && SHCROGL_CUT_TAIL_ALIGNMENT_SIZE(_type, _lastField) < sizeof (void*));*/ \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync if (cbAlignment) { \
72045adcc823bc894f97f9a51d4e4b48b5ce0e39vboxsync rc = SSMR3Skip(pSSM, cbAlignment); \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync } \
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync } while (0)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(CRTextureObj *pTexture, PSSMHANDLE pSSM)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync uint32_t cbObj = RT_OFFSETOF(CRTextureObj, ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync cbObj = ((cbObj + sizeof (void*) - 1) & ~(sizeof (void*) - 1));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pTexture, cbObj);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync /* just make all bits are used so that we fall back to the pre-ctxUsage behavior,
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync * i.e. all shared resources will be destructed on last shared context termination */
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync FILLDIRTY(pTexture->ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadTextureUnit_v_BEFORE_CTXUSAGE_BITS(CRTextureUnit *t, PSSMHANDLE pSSM)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_GET_STRUCT_HEAD(t, CRTextureUnit, Saved1D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->Saved1D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureUnit, Saved1D, Saved2D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->Saved2D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureUnit, Saved2D, Saved3D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->Saved3D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#ifdef CR_ARB_texture_cube_map
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureUnit, Saved3D, SavedCubeMap);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->SavedCubeMap, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD SavedCubeMap
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#else
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD Saved3D
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#endif
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#ifdef CR_NV_texture_rectangle
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureUnit, SHCROGL_INTERNAL_LAST_FIELD, SavedRect);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->SavedRect, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# undef SHCROGL_INTERNAL_LAST_FIELD
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD SavedRect
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#endif
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_TAIL_ALIGNMENT(CRTextureUnit, SHCROGL_INTERNAL_LAST_FIELD);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#undef SHCROGL_INTERNAL_LAST_FIELD
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsyncstatic int crStateLoadStencilPoint_v_37(CRPointState *pPoint, PSSMHANDLE pSSM)
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync{
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync int rc = VINF_SUCCESS;
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_HEAD(pPoint, CRPointState, spriteCoordOrigin);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync pPoint->spriteCoordOrigin = (GLfloat)GL_UPPER_LEFT;
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync return rc;
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync}
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsyncstatic int32_t crStateLoadStencilState_v_33(CRStencilState *s, PSSMHANDLE pSSM)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync{
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync CRStencilState_v_33 stencilV33;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync int32_t rc = SSMR3GetMem(pSSM, &stencilV33, sizeof (stencilV33));
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->stencilTest = stencilV33.stencilTest;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->stencilTwoSideEXT = GL_FALSE;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->activeStencilFace = GL_FRONT;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->clearValue = stencilV33.clearValue;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->writeMask = stencilV33.writeMask;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].func = stencilV33.func;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].mask = stencilV33.mask;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].ref = stencilV33.ref;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].fail = stencilV33.fail;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].passDepthFail = stencilV33.passDepthFail;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].passDepthPass = stencilV33.passDepthPass;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_BACK] = s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT];
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync crStateStencilBufferInit(&s->buffers[CRSTATE_STENCIL_BUFFER_ID_TWO_SIDE_BACK]);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync return VINF_SUCCESS;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync}
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadTextureState_v_BEFORE_CTXUSAGE_BITS(CRTextureState *t, PSSMHANDLE pSSM)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync GLint i;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->base1D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, base1D, base2D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->base2D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->base3D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, base2D, base3D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#ifdef CR_ARB_texture_cube_map
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, base3D, baseCubeMap);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->baseCubeMap, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD baseCubeMap
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#else
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD base3D
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#endif
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#ifdef CR_NV_texture_rectangle
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, SHCROGL_INTERNAL_LAST_FIELD, baseRect);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->baseRect, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# undef SHCROGL_INTERNAL_LAST_FIELD
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD baseRect
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#endif
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, SHCROGL_INTERNAL_LAST_FIELD, proxy1D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->proxy1D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#undef SHCROGL_INTERNAL_LAST_FIELD
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, proxy1D, proxy2D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->proxy2D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, proxy2D, proxy3D);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->proxy3D, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#ifdef CR_ARB_texture_cube_map
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, proxy3D, proxyCubeMap);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->proxyCubeMap, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD proxyCubeMap
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#else
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD proxy3D
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#endif
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#ifdef CR_NV_texture_rectangle
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, SHCROGL_INTERNAL_LAST_FIELD, proxyRect);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(&t->proxyRect, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# undef SHCROGL_INTERNAL_LAST_FIELD
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# define SHCROGL_INTERNAL_LAST_FIELD proxyRect
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync#endif
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRTextureState, SHCROGL_INTERNAL_LAST_FIELD, curTextureUnit);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync# undef SHCROGL_INTERNAL_LAST_FIELD
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_GET_STRUCT_PART(t, CRTextureState, curTextureUnit, unit);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync for (i = 0; i < CR_MAX_TEXTURE_UNITS; ++i)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureUnit_v_BEFORE_CTXUSAGE_BITS(&t->unit[i], pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_TAIL_ALIGNMENT(CRTextureState, unit);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync return VINF_SUCCESS;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync}
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsyncstatic int32_t crStateStencilBufferStack_v_33(CRStencilBufferStack *s, PSSMHANDLE pSSM)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync{
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync CRStencilBufferStack_v_33 stackV33;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync int32_t rc = SSMR3GetMem(pSSM, &stackV33, sizeof (stackV33));
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->stencilTest = stackV33.stencilTest;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->stencilTwoSideEXT = GL_FALSE;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->activeStencilFace = GL_FRONT;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->clearValue = stackV33.clearValue;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->writeMask = stackV33.writeMask;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].func = stackV33.func;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].mask = stackV33.mask;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].ref = stackV33.ref;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].fail = stackV33.fail;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].passDepthFail = stackV33.passDepthFail;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT].passDepthPass = stackV33.passDepthPass;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_BACK] = s->buffers[CRSTATE_STENCIL_BUFFER_ID_FRONT];
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_TWO_SIDE_BACK].func = GL_ALWAYS;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_TWO_SIDE_BACK].mask = 0xFFFFFFFF;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_TWO_SIDE_BACK].ref = 0;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_TWO_SIDE_BACK].fail = GL_KEEP;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_TWO_SIDE_BACK].passDepthFail = GL_KEEP;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync s->buffers[CRSTATE_STENCIL_BUFFER_ID_TWO_SIDE_BACK].passDepthPass = GL_KEEP;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync return VINF_SUCCESS;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync}
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsyncstatic int32_t crStateLoadAttribState_v_33(CRAttribState *t, PSSMHANDLE pSSM)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync{
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync int32_t i, rc;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_HEAD(t, CRAttribState, stencilBufferStack);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync for (i = 0; i < CR_MAX_ATTRIB_STACK_DEPTH; ++i)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync {
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = crStateStencilBufferStack_v_33(&t->stencilBufferStack[i], pSSM);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync }
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_TAIL(t, CRAttribState, textureStackDepth);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadTextureStack_v_BEFORE_CTXUSAGE_BITS(CRTextureStack *t, PSSMHANDLE pSSM)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t i, rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_GET_STRUCT_HEAD(t, CRTextureStack, unit);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync for (i = 0; i < CR_MAX_TEXTURE_UNITS; ++i)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureUnit_v_BEFORE_CTXUSAGE_BITS(&t->unit[i], pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_CUT_TAIL_ALIGNMENT(CRTextureStack, unit);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadAttribState_v_BEFORE_CTXUSAGE_BITS(CRAttribState *t, PSSMHANDLE pSSM)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t i, rc;
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_HEAD(t, CRAttribState, stencilBufferStack);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync for (i = 0; i < CR_MAX_ATTRIB_STACK_DEPTH; ++i)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync {
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = crStateStencilBufferStack_v_33(&t->stencilBufferStack[i], pSSM);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync }
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_PART(t, CRAttribState, textureStackDepth, textureStack);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync for (i = 0; i < CR_MAX_ATTRIB_STACK_DEPTH; ++i)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureStack_v_BEFORE_CTXUSAGE_BITS(&t->textureStack[i], pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync SHCROGL_GET_STRUCT_TAIL(t, CRAttribState, transformStackDepth);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadTextureObj(CRTextureObj *pTexture, PSSMHANDLE pSSM, uint32_t u32Version)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync if (u32Version == SHCROGL_SSM_VERSION_BEFORE_CTXUSAGE_BITS)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return crStateLoadTextureObj_v_BEFORE_CTXUSAGE_BITS(pTexture, pSSM);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pTexture, sizeof (*pTexture));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadBufferObject(CRBufferObject *pBufferObj, PSSMHANDLE pSSM, uint32_t u32Version)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync if (u32Version == SHCROGL_SSM_VERSION_BEFORE_CTXUSAGE_BITS)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync uint32_t cbObj = RT_OFFSETOF(CRBufferObject, ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync cbObj = ((cbObj + sizeof (void*) - 1) & ~(sizeof (void*) - 1));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pBufferObj, cbObj);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync /* just make all bits are used so that we fall back to the pre-ctxUsage behavior,
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync * i.e. all shared resources will be destructed on last shared context termination */
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync FILLDIRTY(pBufferObj->ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync else
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pBufferObj, sizeof(*pBufferObj));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadFramebufferObject(CRFramebufferObject *pFBO, PSSMHANDLE pSSM, uint32_t u32Version)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync if (u32Version == SHCROGL_SSM_VERSION_BEFORE_CTXUSAGE_BITS)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync uint32_t cbObj = RT_OFFSETOF(CRFramebufferObject, ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync cbObj = ((cbObj + sizeof (void*) - 1) & ~(sizeof (void*) - 1));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pFBO, cbObj);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync /* just make all bits are used so that we fall back to the pre-ctxUsage behavior,
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync * i.e. all shared resources will be destructed on last shared context termination */
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync FILLDIRTY(pFBO->ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync else
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pFBO, sizeof(*pFBO));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncstatic int32_t crStateLoadRenderbufferObject(CRRenderbufferObject *pRBO, PSSMHANDLE pSSM, uint32_t u32Version)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync{
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync int32_t rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync if (u32Version == SHCROGL_SSM_VERSION_BEFORE_CTXUSAGE_BITS)
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync uint32_t cbObj = RT_OFFSETOF(CRRenderbufferObject, ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync cbObj = ((cbObj + sizeof (void*) - 1) & ~(sizeof (void*) - 1));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pRBO, cbObj);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync /* just make all bits are used so that we fall back to the pre-ctxUsage behavior,
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync * i.e. all shared resources will be destructed on last shared context termination */
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync FILLDIRTY(pRBO->ctxUsage);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync else
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync {
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = SSMR3GetMem(pSSM, pRBO, sizeof(*pRBO));
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync AssertRCReturn(rc, rc);
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync }
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync return rc;
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync}
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateSaveTextureObjData(CRTextureObj *pTexture, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, face, i;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync GLint bound = 0;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pTexture && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crDebug("crStateSaveTextureObjData %u. START", pTexture->id);
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (face = 0; face < 6; face++) {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pTexture->level[face]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync for (i = 0; i < CR_MAX_MIPMAP_LEVELS; i++) {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRTextureLevel *ptl = &(pTexture->level[face][i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, ptl, sizeof(*ptl));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (ptl->img)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(ptl->bytes);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, ptl->img, ptl->bytes);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#ifdef CR_STATE_NO_TEXTURE_IMAGE_STORE
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync /* Note, this is not a bug.
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync * Even with CR_STATE_NO_TEXTURE_IMAGE_STORE defined, it's possible that ptl->img!=NULL.
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync * For ex. we're saving snapshot right after it was loaded
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync * and some context hasn't been used by the guest application yet
dfd5d06c9f004de9f61904c9d1185bca70969c6avboxsync * (pContext->shared->bTexResyncNeeded==GL_TRUE).
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync */
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync else if (ptl->bytes)
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync {
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync char *pImg;
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync GLenum target;
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync if (!bound)
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync GLenum getEnum;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindTexture(pTexture->target, pTexture->hwid);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync bound = 1;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync /* osx nvidia drivers seem to have a bug that 1x1 TEXTURE_2D texture becmes inaccessible for some reason
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync * saw that for 1x1 dummy textures generated by wine
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync * to avoid crashes we skip texture data save if that is the case */
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync switch (pTexture->target)
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync case GL_TEXTURE_1D:
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync getEnum = GL_TEXTURE_BINDING_1D;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync break;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync case GL_TEXTURE_2D:
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync getEnum = GL_TEXTURE_BINDING_2D;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync break;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync case GL_TEXTURE_3D:
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync getEnum = GL_TEXTURE_BINDING_3D;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync break;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync case GL_TEXTURE_RECTANGLE_ARB:
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync getEnum = GL_TEXTURE_BINDING_RECTANGLE_ARB;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync break;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync case GL_TEXTURE_CUBE_MAP_ARB:
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync getEnum = GL_TEXTURE_BINDING_CUBE_MAP_ARB;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync break;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync default:
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync crWarning("unknown texture target: 0x%x", pTexture->target);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync getEnum = 0;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync break;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync }
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync if (getEnum)
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync GLint curTex;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync diff_api.GetIntegerv(getEnum, &curTex);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync if (curTex != pTexture->hwid)
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync crWarning("texture not bound properly: expected %d, but was %d. Texture state data: target(0x%x), id(%d), w(%d), h(%d)",
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync pTexture->hwid, curTex,
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync pTexture->target,
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync pTexture->id,
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync ptl->width,
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync ptl->height);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync bound = -1;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync }
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync }
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync }
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync if (pTexture->target!=GL_TEXTURE_CUBE_MAP_ARB)
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync {
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync target = pTexture->target;
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync }
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync else
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync {
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync target = GL_TEXTURE_CUBE_MAP_POSITIVE_X + face;
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync }
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync#ifdef DEBUG
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync pImg = crAlloc(ptl->bytes+4);
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync#else
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync pImg = crAlloc(ptl->bytes);
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync#endif
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync if (!pImg) return VERR_NO_MEMORY;
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync#ifdef DEBUG
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync *(int*)((char*)pImg+ptl->bytes) = 0xDEADDEAD;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync#endif
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync if (bound > 0)
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync#ifdef DEBUG
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync GLint w,h=0;
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync crDebug("get image: compressed %i, face %i, level %i, width %i, height %i, bytes %i",
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync ptl->compressed, face, i, ptl->width, ptl->height, ptl->bytes);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync diff_api.GetTexLevelParameteriv(target, i, GL_TEXTURE_WIDTH, &w);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync diff_api.GetTexLevelParameteriv(target, i, GL_TEXTURE_HEIGHT, &h);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync if (w!=ptl->width || h!=ptl->height)
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync crWarning("!!!tex size mismatch %i, %i!!!", w, h);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync }
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync }
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync#endif
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync /*@todo: ugly workaround for crashes inside ati driver,
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync * they overwrite their own allocated memory in cases where texlevel >=4
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync and width or height <=2.
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync */
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync if (i<4 || (ptl->width>2 && ptl->height>2))
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync if (!ptl->compressed)
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync diff_api.GetTexImage(target, i, ptl->format, ptl->type, pImg);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync }
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync else
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync diff_api.GetCompressedTexImageARB(target, i, pImg);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync }
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync }
56602ba12f2388501d594c83fbbf77b4b16f8f4fvboxsync }
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync else
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync {
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync crMemset(pImg, 0, ptl->bytes);
b703ad1c64ab0297ac689f4511855cedde6332b6vboxsync }
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync#ifdef DEBUG
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync if (*(int*)((char*)pImg+ptl->bytes) != 0xDEADDEAD)
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync {
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync crWarning("Texture is bigger than expected!!!");
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync }
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync#endif
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync rc = SSMR3PutMem(pSSM, pImg, ptl->bytes);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync crFree(pImg);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync AssertRCReturn(rc, rc);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync }
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crDebug("crStateSaveTextureObjData %u. END", pTexture->id);
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateLoadTextureObjData(CRTextureObj *pTexture, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, face, i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pTexture && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (face = 0; face < 6; face++) {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pTexture->level[face]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
51e7ffc68ae0a6122fcfdc746905b6c7dae2c610vboxsync for (i = 0; i < CR_MAX_MIPMAP_LEVELS; i++) {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRTextureLevel *ptl = &(pTexture->level[face][i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(!ptl->img);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, ptl, sizeof(*ptl));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (ptl->img)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(ptl->bytes);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync ptl->img = crAlloc(ptl->bytes);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!ptl->img) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, ptl->img, ptl->bytes);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#ifdef CR_STATE_NO_TEXTURE_IMAGE_STORE
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync /* Same story as in crStateSaveTextureObjData */
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync else if (ptl->bytes)
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync {
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync ptl->img = crAlloc(ptl->bytes);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync if (!ptl->img) return VERR_NO_MEMORY;
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync rc = SSMR3GetMem(pSSM, ptl->img, ptl->bytes);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync AssertRCReturn(rc, rc);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync }
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crStateTextureInitTextureFormat(ptl, ptl->internalFormat);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic void crStateSaveSharedTextureCB(unsigned long key, void *data1, void *data2)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRTextureObj *pTexture = (CRTextureObj *) data1;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pTexture && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pTexture, sizeof(*pTexture));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(pTexture, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateSaveMatrixStack(CRMatrixStack *pStack, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return SSMR3PutMem(pSSM, pStack->stack, sizeof(CRmatrix) * pStack->maxDepth);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateLoadMatrixStack(CRMatrixStack *pStack, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pStack && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, pStack->stack, sizeof(CRmatrix) * pStack->maxDepth);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* fixup stack top pointer */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pStack->top = &pStack->stack[pStack->depth];
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateSaveTextureObjPtr(CRTextureObj *pTexture, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Current texture pointer can't be NULL for real texture unit states,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync * but it could be NULL for unused attribute stack depths.
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pTexture)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync return SSMR3PutU32(pSSM, pTexture->id);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync else
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateLoadTextureObjPtr(CRTextureObj **pTexture, CRContext *pContext, GLenum target, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync uint32_t texName;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* We're loading attrib stack with unused state */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!*pTexture)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetU32(pSSM, &texName);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (texName)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *pTexture = (CRTextureObj *) crHashtableSearch(pContext->shared->textureTable, texName);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync else
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync switch (target)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync case GL_TEXTURE_1D:
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *pTexture = &(pContext->texture.base1D);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync break;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync case GL_TEXTURE_2D:
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *pTexture = &(pContext->texture.base2D);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync break;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_OPENGL_VERSION_1_2
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync case GL_TEXTURE_3D:
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *pTexture = &(pContext->texture.base3D);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync break;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_texture_cube_map
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync case GL_TEXTURE_CUBE_MAP_ARB:
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *pTexture = &(pContext->texture.baseCubeMap);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync break;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_NV_texture_rectangle
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync case GL_TEXTURE_RECTANGLE_NV:
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *pTexture = &(pContext->texture.baseRect);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync break;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync default:
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crError("LoadTextureObjPtr: Unknown texture target %d", target);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateSaveTexUnitCurrentTexturePtrs(CRTextureUnit *pTexUnit, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjPtr(pTexUnit->currentTexture1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjPtr(pTexUnit->currentTexture2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjPtr(pTexUnit->currentTexture3D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_texture_cube_map
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjPtr(pTexUnit->currentTextureCubeMap, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_NV_texture_rectangle
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjPtr(pTexUnit->currentTextureRect, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateLoadTexUnitCurrentTexturePtrs(CRTextureUnit *pTexUnit, CRContext *pContext, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjPtr(&pTexUnit->currentTexture1D, pContext, GL_TEXTURE_1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjPtr(&pTexUnit->currentTexture2D, pContext, GL_TEXTURE_1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjPtr(&pTexUnit->currentTexture3D, pContext, GL_TEXTURE_2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_texture_cube_map
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjPtr(&pTexUnit->currentTextureCubeMap, pContext, GL_TEXTURE_CUBE_MAP_ARB, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_NV_texture_rectangle
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjPtr(&pTexUnit->currentTextureRect, pContext, GL_TEXTURE_RECTANGLE_NV, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crSateSaveEvalCoeffs1D(CREvaluator1D *pEval, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<GLEVAL_TOT; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pEval[i].coeff)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pEval[i].coeff, pEval[i].order * gleval_sizes[i] * sizeof(GLfloat));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crSateSaveEvalCoeffs2D(CREvaluator2D *pEval, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<GLEVAL_TOT; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pEval[i].coeff)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pEval[i].coeff, pEval[i].uorder * pEval[i].vorder * gleval_sizes[i] * sizeof(GLfloat));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crSateLoadEvalCoeffs1D(CREvaluator1D *pEval, GLboolean bReallocMem, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync size_t size;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<GLEVAL_TOT; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pEval[i].coeff)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync size = pEval[i].order * gleval_sizes[i] * sizeof(GLfloat);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (bReallocMem)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pEval[i].coeff = (GLfloat*) crAlloc(size);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!pEval[i].coeff) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, pEval[i].coeff, size);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crSateLoadEvalCoeffs2D(CREvaluator2D *pEval, GLboolean bReallocMem, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync size_t size;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<GLEVAL_TOT; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pEval[i].coeff)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync size = pEval[i].uorder * pEval[i].vorder * gleval_sizes[i] * sizeof(GLfloat);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (bReallocMem)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pEval[i].coeff = (GLfloat*) crAlloc(size);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!pEval[i].coeff) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, pEval[i].coeff, size);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic void crStateCopyEvalPtrs1D(CREvaluator1D *pDst, CREvaluator1D *pSrc)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<GLEVAL_TOT; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[i].coeff = pSrc[i].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /*
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_VERTEX_3-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_VERTEX_3-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_VERTEX_4-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_VERTEX_4-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_INDEX-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_INDEX-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_COLOR_4-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_COLOR_4-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_NORMAL-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_NORMAL-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_TEXTURE_COORD_1-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_TEXTURE_COORD_1-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_TEXTURE_COORD_2-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_TEXTURE_COORD_2-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_TEXTURE_COORD_3-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_TEXTURE_COORD_3-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP1_TEXTURE_COORD_4-GL_MAP1_COLOR_4].coeff = pSrc[GL_MAP1_TEXTURE_COORD_4-GL_MAP1_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic void crStateCopyEvalPtrs2D(CREvaluator2D *pDst, CREvaluator2D *pSrc)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<GLEVAL_TOT; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[i].coeff = pSrc[i].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /*
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_VERTEX_3-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_VERTEX_3-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_VERTEX_4-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_VERTEX_4-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_INDEX-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_INDEX-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_COLOR_4-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_COLOR_4-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_NORMAL-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_NORMAL-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_TEXTURE_COORD_1-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_TEXTURE_COORD_1-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_TEXTURE_COORD_2-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_TEXTURE_COORD_2-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_TEXTURE_COORD_3-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_TEXTURE_COORD_3-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pDst[GL_MAP2_TEXTURE_COORD_4-GL_MAP2_COLOR_4].coeff = pSrc[GL_MAP2_TEXTURE_COORD_4-GL_MAP2_COLOR_4].coeff;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic void crStateSaveBufferObjectCB(unsigned long key, void *data1, void *data2)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRBufferObject *pBufferObj = (CRBufferObject *) data1;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pBufferObj && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pBufferObj, sizeof(*pBufferObj));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pBufferObj->data)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync /*We could get here even though retainBufferData is false on host side, in case when we're taking snapshot
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync after state load and before this context was ever made current*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pBufferObj->size>0);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pBufferObj->data, pBufferObj->size);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync else if (pBufferObj->id!=0 && pBufferObj->size>0)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindBufferARB(GL_ARRAY_BUFFER_ARB, pBufferObj->hwid);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync pBufferObj->pointer = diff_api.MapBufferARB(GL_ARRAY_BUFFER_ARB, GL_READ_ONLY_ARB);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync rc = SSMR3PutMem(pSSM, &pBufferObj->pointer, sizeof(pBufferObj->pointer));
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync CRASSERT(rc == VINF_SUCCESS);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync if (pBufferObj->pointer)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync rc = SSMR3PutMem(pSSM, pBufferObj->pointer, pBufferObj->size);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync CRASSERT(rc == VINF_SUCCESS);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync diff_api.UnmapBufferARB(GL_ARRAY_BUFFER_ARB);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync pBufferObj->pointer = NULL;
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic void crStateSaveProgramCB(unsigned long key, void *data1, void *data2)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRProgram *pProgram = (CRProgram *) data1;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRProgramSymbol *pSymbol;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pProgram && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pProgram, sizeof(*pProgram));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pProgram->string)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pProgram->length);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pProgram->string, pProgram->length);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (pSymbol = pProgram->symbolTable; pSymbol; pSymbol=pSymbol->next)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pSymbol, sizeof(*pSymbol));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pSymbol->name)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pSymbol->cbName>0);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pSymbol->name, pSymbol->cbName);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(rc == VINF_SUCCESS);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsyncstatic void crStateSaveFramebuffersCB(unsigned long key, void *data1, void *data2)
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync{
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync CRFramebufferObject *pFBO = (CRFramebufferObject*) data1;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync int32_t rc;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync CRASSERT(rc == VINF_SUCCESS);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync rc = SSMR3PutMem(pSSM, pFBO, sizeof(*pFBO));
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync CRASSERT(rc == VINF_SUCCESS);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync}
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsyncstatic void crStateSaveRenderbuffersCB(unsigned long key, void *data1, void *data2)
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync{
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync CRRenderbufferObject *pRBO = (CRRenderbufferObject*) data1;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync int32_t rc;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync CRASSERT(rc == VINF_SUCCESS);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync rc = SSMR3PutMem(pSSM, pRBO, sizeof(*pRBO));
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync CRASSERT(rc == VINF_SUCCESS);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync}
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncstatic int32_t crStateLoadProgram(CRProgram **ppProgram, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRProgramSymbol **ppSymbol;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync unsigned long key;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* we're loading default vertex or pixel program*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (*ppProgram)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (key!=0) return VERR_SSM_UNEXPECTED_DATA;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync else
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *ppProgram = (CRProgram*) crAlloc(sizeof(CRProgram));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!ppProgram) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (key==0) return VERR_SSM_UNEXPECTED_DATA;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, *ppProgram, sizeof(**ppProgram));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if ((*ppProgram)->string)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT((*ppProgram)->length);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync (*ppProgram)->string = crAlloc((*ppProgram)->length);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!(*ppProgram)->string) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, (void*) (*ppProgram)->string, (*ppProgram)->length);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (ppSymbol = &(*ppProgram)->symbolTable; *ppSymbol; ppSymbol=&(*ppSymbol)->next)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync *ppSymbol = crAlloc(sizeof(CRProgramSymbol));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!ppSymbol) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, *ppSymbol, sizeof(**ppSymbol));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if ((*ppSymbol)->name)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT((*ppSymbol)->cbName>0);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync (*ppSymbol)->name = crAlloc((*ppSymbol)->cbName);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!(*ppSymbol)->name) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, (void*) (*ppSymbol)->name, (*ppSymbol)->cbName);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsyncstatic void crStateSaveString(const char *pStr, PSSMHANDLE pSSM)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync{
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t len;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t rc;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (pStr)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync len = crStrlen(pStr)+1;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutS32(pSSM, len);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutMem(pSSM, pStr, len*sizeof(*pStr));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync else
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutS32(pSSM, 0);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync}
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsyncstatic char* crStateLoadString(PSSMHANDLE pSSM)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync{
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t len, rc;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync char* pStr = NULL;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetS32(pSSM, &len);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (len!=0)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pStr = crAlloc(len*sizeof(*pStr));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, pStr, len*sizeof(*pStr));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync return pStr;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync}
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsyncstatic void crStateSaveGLSLShaderCB(unsigned long key, void *data1, void *data2)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync{
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRGLSLShader *pShader = (CRGLSLShader*) data1;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t rc;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutMem(pSSM, pShader, sizeof(*pShader));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (pShader->source)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crStateSaveString(pShader->source, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync else
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync GLint sLen=0;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync GLchar *source=NULL;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync diff_api.GetShaderiv(pShader->hwid, GL_SHADER_SOURCE_LENGTH, &sLen);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (sLen>0)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync source = (GLchar*) crAlloc(sLen);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync diff_api.GetShaderSource(pShader->hwid, sLen, NULL, source);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crStateSaveString(source, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (source) crFree(source);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync}
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsyncstatic CRGLSLShader* crStateLoadGLSLShader(PSSMHANDLE pSSM)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync{
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRGLSLShader *pShader;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t rc;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync unsigned long key;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pShader = crAlloc(sizeof(*pShader));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (!pShader) return NULL;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, pShader, sizeof(*pShader));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pShader->source = crStateLoadString(pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync return pShader;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync}
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsyncstatic void crStateSaveGLSLShaderKeyCB(unsigned long key, void *data1, void *data2)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync{
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRGLSLShader *pShader = (CRGLSLShader*) data1;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t rc;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync}
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsyncstatic void crStateSaveGLSLProgramAttribs(CRGLSLProgramState *pState, PSSMHANDLE pSSM)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync{
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync GLuint i;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t rc;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (i=0; i<pState->cAttribs; ++i)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutMem(pSSM, &pState->pAttribs[i].index, sizeof(pState->pAttribs[i].index));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crStateSaveString(pState->pAttribs[i].name, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync}
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsyncstatic void crStateSaveGLSLProgramCB(unsigned long key, void *data1, void *data2)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync{
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRGLSLProgram *pProgram = (CRGLSLProgram*) data1;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync PSSMHANDLE pSSM = (PSSMHANDLE) data2;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync int32_t rc;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync uint32_t ui32;
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync GLint maxUniformLen, activeUniforms=0, uniformsCount=0, i, j;
841fc232dfd102207563580ef5b2875edb98e305vboxsync GLchar *name = NULL;
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync GLenum type;
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync GLint size, location;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutMem(pSSM, &key, sizeof(key));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutMem(pSSM, pProgram, sizeof(*pProgram));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync ui32 = crHashtableNumElements(pProgram->currentState.attachedShaders);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutU32(pSSM, ui32);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableWalk(pProgram->currentState.attachedShaders, crStateSaveGLSLShaderKeyCB, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (pProgram->activeState.attachedShaders)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync ui32 = crHashtableNumElements(pProgram->activeState.attachedShaders);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutU32(pSSM, ui32);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableWalk(pProgram->currentState.attachedShaders, crStateSaveGLSLShaderCB, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crStateSaveGLSLProgramAttribs(&pProgram->currentState, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crStateSaveGLSLProgramAttribs(&pProgram->activeState, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync diff_api.GetProgramiv(pProgram->hwid, GL_ACTIVE_UNIFORM_MAX_LENGTH, &maxUniformLen);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync diff_api.GetProgramiv(pProgram->hwid, GL_ACTIVE_UNIFORMS, &activeUniforms);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
28471851c9621fb51b7968142cce9791928d65d1vboxsync if (!maxUniformLen)
28471851c9621fb51b7968142cce9791928d65d1vboxsync {
28471851c9621fb51b7968142cce9791928d65d1vboxsync if (activeUniforms)
28471851c9621fb51b7968142cce9791928d65d1vboxsync {
28471851c9621fb51b7968142cce9791928d65d1vboxsync crWarning("activeUniforms (%d), while maxUniformLen is zero", activeUniforms);
28471851c9621fb51b7968142cce9791928d65d1vboxsync activeUniforms = 0;
28471851c9621fb51b7968142cce9791928d65d1vboxsync }
28471851c9621fb51b7968142cce9791928d65d1vboxsync }
28471851c9621fb51b7968142cce9791928d65d1vboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync if (activeUniforms>0)
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync name = (GLchar *) crAlloc((maxUniformLen+8)*sizeof(GLchar));
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync if (!name)
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync crWarning("crStateSaveGLSLProgramCB: out of memory");
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync return;
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync }
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync }
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync for (i=0; i<activeUniforms; ++i)
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync diff_api.GetActiveUniform(pProgram->hwid, i, maxUniformLen, NULL, &size, &type, name);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync uniformsCount += size;
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync }
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync CRASSERT(uniformsCount>=activeUniforms);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync rc = SSMR3PutS32(pSSM, uniformsCount);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (activeUniforms>0)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync GLfloat fdata[16];
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync GLint idata[16];
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync char *pIndexStr=NULL;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (i=0; i<activeUniforms; ++i)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync diff_api.GetActiveUniform(pProgram->hwid, i, maxUniformLen, NULL, &size, &type, name);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync if (size>1)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync pIndexStr = crStrchr(name, '[');
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync if (!pIndexStr)
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync pIndexStr = name+crStrlen(name);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync for (j=0; j<size; ++j)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync if (size>1)
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync sprintf(pIndexStr, "[%i]", j);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync }
1949f98957df74949c101f6f2c97f5f7de38144avboxsync location = diff_api.GetUniformLocation(pProgram->hwid, name);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync rc = SSMR3PutMem(pSSM, &type, sizeof(type));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRASSERT(rc == VINF_SUCCESS);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync crStateSaveString(name, pSSM);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync if (crStateIsIntUniform(type))
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync diff_api.GetUniformiv(pProgram->hwid, location, &idata[0]);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync rc = SSMR3PutMem(pSSM, &idata[0], crStateGetUniformSize(type)*sizeof(idata[0]));
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync CRASSERT(rc == VINF_SUCCESS);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync }
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync else
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync {
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync diff_api.GetUniformfv(pProgram->hwid, location, &fdata[0]);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync rc = SSMR3PutMem(pSSM, &fdata[0], crStateGetUniformSize(type)*sizeof(fdata[0]));
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync CRASSERT(rc == VINF_SUCCESS);
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crFree(name);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync}
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsyncstatic int32_t crStateSaveClientPointer(CRVertexArrays *pArrays, int32_t index, PSSMHANDLE pSSM)
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync{
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync int32_t rc;
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync CRClientPointer *cp;
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync cp = crStateGetClientPointerByIndex(index, pArrays);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
62b78c74cd82e37969df9504671daaca2bb061b1vboxsync if (cp->buffer)
62b78c74cd82e37969df9504671daaca2bb061b1vboxsync rc = SSMR3PutU32(pSSM, cp->buffer->id);
62b78c74cd82e37969df9504671daaca2bb061b1vboxsync else
62b78c74cd82e37969df9504671daaca2bb061b1vboxsync rc = SSMR3PutU32(pSSM, 0);
62b78c74cd82e37969df9504671daaca2bb061b1vboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync AssertRCReturn(rc, rc);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync#ifdef CR_EXT_compiled_vertex_array
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync if (cp->locked)
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync {
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync CRASSERT(cp->p);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync rc = SSMR3PutMem(pSSM, cp->p, cp->stride*(pArrays->lockFirst+pArrays->lockCount));
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync AssertRCReturn(rc, rc);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync }
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync#endif
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync return VINF_SUCCESS;
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync}
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsyncstatic int32_t crStateLoadClientPointer(CRVertexArrays *pArrays, int32_t index, CRContext *pContext, PSSMHANDLE pSSM)
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync{
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync int32_t rc;
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync uint32_t ui;
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync CRClientPointer *cp;
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync cp = crStateGetClientPointerByIndex(index, pArrays);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync rc = SSMR3GetU32(pSSM, &ui);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync cp->buffer = ui==0 ? pContext->bufferobject.nullBuffer : crHashtableSearch(pContext->shared->buffersTable, ui);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
4ff9c17f67441ba055d522ae932fbe7fb47250a8vboxsync if (!cp->buffer)
4ff9c17f67441ba055d522ae932fbe7fb47250a8vboxsync {
4ff9c17f67441ba055d522ae932fbe7fb47250a8vboxsync crWarning("crStateLoadClientPointer: ui=%d loaded as NULL buffer!", ui);
4ff9c17f67441ba055d522ae932fbe7fb47250a8vboxsync }
4ff9c17f67441ba055d522ae932fbe7fb47250a8vboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync#ifdef CR_EXT_compiled_vertex_array
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync if (cp->locked)
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync {
d28dc67f08822d73f954174fab43e570131b54davboxsync rc = crStateAllocAndSSMR3GetMem(pSSM, (void**)&cp->p, cp->stride*(pArrays->lockFirst+pArrays->lockCount));
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync AssertRCReturn(rc, rc);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync }
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync#endif
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync return VINF_SUCCESS;
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync}
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsyncstatic int32_t crStateSaveCurrentBits(CRStateBits *pBits, PSSMHANDLE pSSM)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync{
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync int32_t rc, i;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits, sizeof(*pBits));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.v, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.n, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.c, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.s, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.i, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync for (i=0; i<CR_MAX_TEXTURE_UNITS; i++)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync {
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.t[i], GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync }
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.e, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.f, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync#ifdef CR_NV_vertex_program
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync for (i=0; i<CR_MAX_VERTEX_ATTRIBS; i++)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync {
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->client.a[i], GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync }
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync#endif
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3PutMem(pSSM, pBits->lighting.light, CR_MAX_LIGHTS*sizeof(pBits->lighting.light));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync return VINF_SUCCESS;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync}
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsyncstatic int32_t crStateLoadCurrentBits(CRStateBits *pBits, PSSMHANDLE pSSM)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync{
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync int32_t rc, i;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync CRClientBits client;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync CRLightingBits lighting;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync CRASSERT(pBits);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.v = pBits->client.v;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.n = pBits->client.n;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.c = pBits->client.c;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.s = pBits->client.s;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.i = pBits->client.i;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.e = pBits->client.e;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.f = pBits->client.f;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync for (i=0; i<CR_MAX_TEXTURE_UNITS; i++)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync {
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.t[i] = pBits->client.t[i];
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync }
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync#ifdef CR_NV_vertex_program
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync for (i=0; i<CR_MAX_VERTEX_ATTRIBS; i++)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync {
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync client.a[i] = pBits->client.a[i];
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync }
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync#endif
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync lighting.light = pBits->lighting.light;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits, sizeof(*pBits));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.v = client.v;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.v, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.n = client.n;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.n, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.c = client.c;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.c, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.s = client.s;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.s, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.i = client.i;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.i, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.e = client.e;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.e, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.f = client.f;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.f, GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync for (i=0; i<CR_MAX_TEXTURE_UNITS; i++)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync {
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.t[i] = client.t[i];
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.t[i], GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync }
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync#ifdef CR_NV_vertex_program
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync for (i=0; i<CR_MAX_VERTEX_ATTRIBS; i++)
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync {
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->client.a[i] = client.a[i];
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->client.a[i], GLCLIENT_BIT_ALLOC*sizeof(CRbitvalue));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync }
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync#endif
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync pBits->lighting.light = lighting.light;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync rc = SSMR3GetMem(pSSM, pBits->lighting.light, CR_MAX_LIGHTS*sizeof(pBits->lighting.light));
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync AssertRCReturn(rc, rc);
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync return VINF_SUCCESS;
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync}
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsyncstatic void crStateSaveKeysCB(unsigned long firstKey, unsigned long count, void *data)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync{
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync PSSMHANDLE pSSM = (PSSMHANDLE)data;
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync int rc;
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync CRASSERT(firstKey);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync CRASSERT(count);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = SSMR3PutU32(pSSM, firstKey);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync CRASSERT(RT_SUCCESS(rc));
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = SSMR3PutU32(pSSM, count);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync CRASSERT(RT_SUCCESS(rc));
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync}
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsyncstatic int32_t crStateSaveKeys(CRHashTable *pHash, PSSMHANDLE pSSM)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync{
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync crHashtableWalkKeys(pHash, crStateSaveKeysCB , pSSM);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync /* use null terminator */
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync SSMR3PutU32(pSSM, 0);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync return VINF_SUCCESS;
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync}
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
4252e037570a3c8d943552edb7858c9889aaca1dvboxsyncstatic int32_t crStateLoadKeys(CRHashTable *pHash, PSSMHANDLE pSSM, uint32_t u32Version)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync{
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync uint32_t u32Key, u32Count, i;
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync int rc;
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync for(;;)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = SSMR3GetU32(pSSM, &u32Key);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync if (!u32Key)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync return rc;
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = SSMR3GetU32(pSSM, &u32Count);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync CRASSERT(u32Count);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync if (u32Version > SHCROGL_SSM_VERSION_WITH_BUGGY_KEYS)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync for (i = u32Key; i < u32Count + u32Key; ++i)
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync {
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync GLboolean fIsNew = crHashtableAllocRegisterKey(pHash, i);
bda4b6d062e1dffc2d3fa9d4a851666903fdfd1dvboxsync#if 0 //def DEBUG_misha
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync CRASSERT(fIsNew);
bda4b6d062e1dffc2d3fa9d4a851666903fdfd1dvboxsync#endif
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync return rc;
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync}
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsyncint32_t crStateSaveContext(CRContext *pContext, PSSMHANDLE pSSM)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, i;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync uint32_t ui32, j;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync GLboolean bSaveShared = GL_TRUE;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pContext && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
28471851c9621fb51b7968142cce9791928d65d1vboxsync CRASSERT(pContext->client.attribStackDepth == 0);
28471851c9621fb51b7968142cce9791928d65d1vboxsync
7c465e80d0699fab71706c8a013a3327ec7034dcvboxsync /* this stuff is not used anymore, zero it up for sanity */
7c465e80d0699fab71706c8a013a3327ec7034dcvboxsync pContext->buffer.storedWidth = 0;
7c465e80d0699fab71706c8a013a3327ec7034dcvboxsync pContext->buffer.storedHeight = 0;
290d9ae9b95045c087215884b282b1130b99098avboxsync
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync CRASSERT(VBoxTlsRefIsFunctional(pContext));
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* make sure the gl error state is captured by our state mechanism to store the correct gl error value */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync crStateSyncHWErrorState(pContext);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = SSMR3PutMem(pSSM, pContext, sizeof (*pContext));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (crHashtableNumElements(pContext->shared->dlistTable)>0)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crWarning("Saving state with %d display lists, unsupported", crHashtableNumElements(pContext->shared->dlistTable));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (crHashtableNumElements(pContext->program.programHash)>0)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crDebug("Saving state with %d programs", crHashtableNumElements(pContext->program.programHash));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutS32(pSSM, pContext->shared->id);
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync AssertRCReturn(rc, rc);
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync rc = SSMR3PutS32(pSSM, crStateContextIsShared(pContext));
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync AssertRCReturn(rc, rc);
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (pContext->shared->refCount>1)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync bSaveShared = pContext->shared->saveCount==0;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync ++pContext->shared->saveCount;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (pContext->shared->saveCount == pContext->shared->refCount)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pContext->shared->saveCount=0;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save transform state */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->transform.clipPlane, sizeof(GLvectord)*CR_MAX_CLIP_PLANES);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->transform.clip, sizeof(GLboolean)*CR_MAX_CLIP_PLANES);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveMatrixStack(&pContext->transform.modelViewStack, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveMatrixStack(&pContext->transform.projectionStack, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveMatrixStack(&pContext->transform.colorStack, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_TEXTURE_UNITS ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveMatrixStack(&pContext->transform.textureStack[i], pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_PROGRAM_MATRICES ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveMatrixStack(&pContext->transform.programStack[i], pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save textures */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.base1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.base2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.base3D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.proxy1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.proxy2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.proxy3D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_texture_cube_map
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.baseCubeMap, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.proxyCubeMap, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_NV_texture_rectangle
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.baseRect, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTextureObjData(&pContext->texture.proxyRect, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save shared textures */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (bSaveShared)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync CRASSERT(pContext->shared && pContext->shared->textureTable);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = crStateSaveKeys(pContext->shared->textureTable, pSSM);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync ui32 = crHashtableNumElements(pContext->shared->textureTable);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutU32(pSSM, ui32);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableWalk(pContext->shared->textureTable, crStateSaveSharedTextureCB, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#ifdef CR_STATE_NO_TEXTURE_IMAGE_STORE
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync /* Restore previous texture bindings via diff_api */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (ui32)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync CRTextureUnit *pTexUnit;
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pTexUnit = &pContext->texture.unit[pContext->texture.curTextureUnit];
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindTexture(GL_TEXTURE_1D, pTexUnit->currentTexture1D->hwid);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindTexture(GL_TEXTURE_2D, pTexUnit->currentTexture2D->hwid);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindTexture(GL_TEXTURE_3D, pTexUnit->currentTexture3D->hwid);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#ifdef CR_ARB_texture_cube_map
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindTexture(GL_TEXTURE_CUBE_MAP_ARB, pTexUnit->currentTextureCubeMap->hwid);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#endif
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#ifdef CR_NV_texture_rectangle
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindTexture(GL_TEXTURE_RECTANGLE_NV, pTexUnit->currentTextureRect->hwid);
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#endif
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync#endif
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
0bebd3a2671042901f1fcceff14f8c58dd397478vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save current texture pointers */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<CR_MAX_TEXTURE_UNITS; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTexUnitCurrentTexturePtrs(&pContext->texture.unit[i], pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save lights */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pContext->lighting.light);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->lighting.light, CR_MAX_LIGHTS * sizeof(*pContext->lighting.light));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save attrib stack*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /*@todo could go up to used stack depth here?*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for ( i = 0 ; i < CR_MAX_ATTRIB_STACK_DEPTH ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.enableStack[i].clip)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->attrib.enableStack[i].clip,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxClipPlanes*sizeof(GLboolean));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.enableStack[i].light)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->attrib.enableStack[i].light,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxLights*sizeof(GLboolean));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.lightingStack[i].light)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->attrib.lightingStack[i].light,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxLights*sizeof(CRLight));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (j=0; j<pContext->limits.maxTextureUnits; ++j)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateSaveTexUnitCurrentTexturePtrs(&pContext->attrib.textureStack[i].unit[j], pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.transformStack[i].clip)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->attrib.transformStack[i].clip,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxClipPlanes*sizeof(GLboolean));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.transformStack[i].clipPlane)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutMem(pSSM, pContext->attrib.transformStack[i].clipPlane,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxClipPlanes*sizeof(GLvectord));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateSaveEvalCoeffs1D(pContext->attrib.evalStack[i].eval1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateSaveEvalCoeffs2D(pContext->attrib.evalStack[i].eval2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save evaluator coeffs */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateSaveEvalCoeffs1D(pContext->eval.eval1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateSaveEvalCoeffs2D(pContext->eval.eval2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_vertex_buffer_object
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save buffer objects */
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync if (bSaveShared)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = crStateSaveKeys(pContext->shared->buffersTable, pSSM);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync ui32 = bSaveShared? crHashtableNumElements(pContext->shared->buffersTable):0;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutU32(pSSM, ui32);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save default one*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crStateSaveBufferObjectCB(0, pContext->bufferobject.nullBuffer, pSSM);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (bSaveShared)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync /* Save all the rest */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableWalk(pContext->shared->buffersTable, crStateSaveBufferObjectCB, pSSM);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync /* Restore binding */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync diff_api.BindBufferARB(GL_ARRAY_BUFFER_ARB, pContext->bufferobject.arrayBuffer->hwid);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save pointers */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutU32(pSSM, pContext->bufferobject.arrayBuffer->id);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutU32(pSSM, pContext->bufferobject.elementsBuffer->id);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync#ifdef CR_ARB_pixel_buffer_object
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutU32(pSSM, pContext->bufferobject.packBuffer->id);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutU32(pSSM, pContext->bufferobject.unpackBuffer->id);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync AssertRCReturn(rc, rc);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync#endif
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync /* Save clint pointers and buffer bindings*/
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync for (i=0; i<CRSTATECLIENT_MAX_VERTEXARRAYS; ++i)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync rc = crStateSaveClientPointer(&pContext->client.array, i, pSSM);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync AssertRCReturn(rc, rc);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync crDebug("client.vertexArrayStackDepth %i", pContext->client.vertexArrayStackDepth);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync for (i=0; i<pContext->client.vertexArrayStackDepth; ++i)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync CRVertexArrays *pArray = &pContext->client.vertexArrayStack[i];
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync for (j=0; j<CRSTATECLIENT_MAX_VERTEXARRAYS; ++j)
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync {
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync rc = crStateSaveClientPointer(pArray, j, pSSM);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync AssertRCReturn(rc, rc);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync#endif /*CR_ARB_vertex_buffer_object*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save pixel/vertex programs */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync ui32 = crHashtableNumElements(pContext->program.programHash);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutU32(pSSM, ui32);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
ad27e1d5e48ca41245120c331cc88b50464813cevboxsync /* Save defaults programs */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crStateSaveProgramCB(0, pContext->program.defaultVertexProgram, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crStateSaveProgramCB(0, pContext->program.defaultFragmentProgram, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save all the rest */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crHashtableWalk(pContext->program.programHash, crStateSaveProgramCB, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Save Pointers */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutU32(pSSM, pContext->program.currentVertexProgram->id);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3PutU32(pSSM, pContext->program.currentFragmentProgram->id);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* This one is unused it seems*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(!pContext->program.errorString);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync#ifdef CR_EXT_framebuffer_object
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync /* Save FBOs */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (bSaveShared)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = crStateSaveKeys(pContext->shared->fbTable, pSSM);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync ui32 = crHashtableNumElements(pContext->shared->fbTable);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutU32(pSSM, ui32);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableWalk(pContext->shared->fbTable, crStateSaveFramebuffersCB, pSSM);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync rc = crStateSaveKeys(pContext->shared->rbTable, pSSM);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync ui32 = crHashtableNumElements(pContext->shared->rbTable);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3PutU32(pSSM, ui32);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableWalk(pContext->shared->rbTable, crStateSaveRenderbuffersCB, pSSM);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync rc = SSMR3PutU32(pSSM, pContext->framebufferobject.drawFB?pContext->framebufferobject.drawFB->id:0);
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync AssertRCReturn(rc, rc);
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync rc = SSMR3PutU32(pSSM, pContext->framebufferobject.readFB?pContext->framebufferobject.readFB->id:0);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync AssertRCReturn(rc, rc);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync rc = SSMR3PutU32(pSSM, pContext->framebufferobject.renderbuffer?pContext->framebufferobject.renderbuffer->id:0);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync AssertRCReturn(rc, rc);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync#endif
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync#ifdef CR_OPENGL_VERSION_2_0
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync /* Save GLSL related info */
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync ui32 = crHashtableNumElements(pContext->glsl.shaders);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutU32(pSSM, ui32);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableWalk(pContext->glsl.shaders, crStateSaveGLSLShaderCB, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync ui32 = crHashtableNumElements(pContext->glsl.programs);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutU32(pSSM, ui32);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableWalk(pContext->glsl.programs, crStateSaveGLSLProgramCB, pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3PutU32(pSSM, pContext->glsl.activeProgram?pContext->glsl.activeProgram->id:0);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync#endif
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsynctypedef struct _crFindSharedCtxParms {
f53ba2efceac1847585b2052ee98569305e9802dvboxsync PFNCRSTATE_CONTEXT_GET pfnCtxGet;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync CRContext *pSrcCtx, *pDstCtx;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync} crFindSharedCtxParms_t;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsyncstatic void crStateFindSharedCB(unsigned long key, void *data1, void *data2)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync{
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crFindSharedCtxParms_t *pParms = (crFindSharedCtxParms_t *) data2;
f53ba2efceac1847585b2052ee98569305e9802dvboxsync CRContext *pContext = pParms->pfnCtxGet(data1);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync (void) key;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (pContext!=pParms->pSrcCtx && pContext->shared->id==pParms->pSrcCtx->shared->id)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pParms->pDstCtx->shared = pContext->shared;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync}
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsyncint32_t crStateSaveGlobals(PSSMHANDLE pSSM)
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync{
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync /* don't need that for now */
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync#if 0
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync CRStateBits *pBits;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync int rc;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync CRASSERT(g_cContexts >= 1);
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync if (g_cContexts <= 1)
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync return VINF_SUCCESS;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync pBits = GetCurrentBits();
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#define CRSTATE_BITS_OP(_var, _size) \
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync rc = SSMR3PutMem(pSSM, (pBits->_var), _size); \
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync AssertRCReturn(rc, rc);
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#include "state_bits_globalop.h"
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#undef CRSTATE_BITS_OP
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync#endif
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync return VINF_SUCCESS;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync}
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsyncint32_t crStateLoadGlobals(PSSMHANDLE pSSM, uint32_t u32Version)
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync{
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync CRStateBits *pBits;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync int rc;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync CRASSERT(g_cContexts >= 1);
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync if (g_cContexts <= 1)
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync return VINF_SUCCESS;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync pBits = GetCurrentBits();
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync if (u32Version >= SHCROGL_SSM_VERSION_WITH_STATE_BITS)
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync {
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#define CRSTATE_BITS_OP(_var, _size) \
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync rc = SSMR3GetMem(pSSM, (pBits->_var), _size); \
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync if (u32Version < SHCROGL_SSM_VERSION_WITH_FIXED_STENCIL)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync {
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#define CRSTATE_BITS_OP_VERSION (SHCROGL_SSM_VERSION_WITH_FIXED_STENCIL - 1)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#define CRSTATE_BITS_OP_STENCIL_FUNC_V_33(_i, _var) do {} while (0)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#define CRSTATE_BITS_OP_STENCIL_OP_V_33(_i, _var) do {} while (0)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#include "state_bits_globalop.h"
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#undef CRSTATE_BITS_OP_VERSION
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#undef CRSTATE_BITS_OP_STENCIL_FUNC_V_33
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync#undef CRSTATE_BITS_OP_STENCIL_OP_V_33
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync }
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync else if (u32Version < SHCROGL_SSM_VERSION_WITH_SPRITE_COORD_ORIGIN)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync {
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync#define CRSTATE_BITS_OP_VERSION (SHCROGL_SSM_VERSION_WITH_SPRITE_COORD_ORIGIN - 1)
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#include "state_bits_globalop.h"
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync#undef CRSTATE_BITS_OP_VERSION
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync }
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync else
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync {
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync /* we do not put dirty bits to state anymore,
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync * nop */
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync//#include "state_bits_globalop.h"
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync }
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#undef CRSTATE_BITS_OP
28471851c9621fb51b7968142cce9791928d65d1vboxsync /* always dirty all bits */
28471851c9621fb51b7968142cce9791928d65d1vboxsync /* return VINF_SUCCESS; */
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync }
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#define CRSTATE_BITS_OP(_var, _size) FILLDIRTY(pBits->_var);
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#include "state_bits_globalop.h"
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync#undef CRSTATE_BITS_OP
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync return VINF_SUCCESS;
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync}
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e85b92d4df013df97a72864a412eb94eb3f70acevboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#define SLC_COPYPTR(ptr) pTmpContext->ptr = pContext->ptr
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#define SLC_ASSSERT_NULL_PTR(ptr) CRASSERT(!pContext->ptr)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsyncAssertCompile(VBOXTLSREFDATA_SIZE() <= CR_MAX_BITARRAY);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsyncAssertCompile(VBOXTLSREFDATA_STATE_INITIALIZED != 0);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsyncAssertCompile(RT_OFFSETOF(CRContext, shared) >= VBOXTLSREFDATA_OFFSET(CRContext) + VBOXTLSREFDATA_SIZE() + RT_SIZEOFMEMB(CRContext, bitid) + RT_SIZEOFMEMB(CRContext, neg_bitid));
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsyncint32_t crStateLoadContext(CRContext *pContext, CRHashTable * pCtxTable, PFNCRSTATE_CONTEXT_GET pfnCtxGet, PSSMHANDLE pSSM, uint32_t u32Version)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync{
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRContext* pTmpContext;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync int32_t rc, i, j;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync uint32_t uiNumElems, ui, k;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync unsigned long key;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync GLboolean bLoadShared = GL_TRUE;
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync GLenum err;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pContext && pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* This one is rather big for stack allocation and causes macs to crash */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pTmpContext = (CRContext*)crAlloc(sizeof(*pTmpContext));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!pTmpContext)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync CRASSERT(VBoxTlsRefIsFunctional(pContext));
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync if (u32Version <= SHCROGL_SSM_VERSION_WITH_INVALID_ERROR_STATE)
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync union {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync CRbitvalue bitid[CR_MAX_BITARRAY];
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync struct {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync VBOXTLSREFDATA
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync } tlsRef;
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync } bitid;
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* do not increment the saved state version due to VBOXTLSREFDATA addition to CRContext */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = SSMR3GetMem(pSSM, pTmpContext, VBOXTLSREFDATA_OFFSET(CRContext));
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync AssertRCReturn(rc, rc);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* VBox 4.1.8 had a bug that VBOXTLSREFDATA was also stored in the snapshot,
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync * thus the saved state data format was changed w/o changing the saved state version.
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync * here we determine whether the saved state contains VBOXTLSREFDATA, and if so, treat it accordingly */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = SSMR3GetMem(pSSM, &bitid, sizeof (bitid));
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync AssertRCReturn(rc, rc);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* the bitid array has one bit set only. this is why if bitid.tlsRef has both cTlsRefs
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync * and enmTlsRefState non-zero - this is definitely NOT a bit id and is a VBOXTLSREFDATA */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync if (bitid.tlsRef.enmTlsRefState == VBOXTLSREFDATA_STATE_INITIALIZED
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync && bitid.tlsRef.cTlsRefs)
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* VBOXTLSREFDATA is stored, skip it */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync crMemcpy(&pTmpContext->bitid, ((uint8_t*)&bitid) + VBOXTLSREFDATA_SIZE(), sizeof (bitid) - VBOXTLSREFDATA_SIZE());
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = SSMR3GetMem(pSSM, ((uint8_t*)&pTmpContext->bitid) + sizeof (pTmpContext->bitid) - VBOXTLSREFDATA_SIZE(), sizeof (pTmpContext->neg_bitid) + VBOXTLSREFDATA_SIZE());
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync AssertRCReturn(rc, rc);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync ui = VBOXTLSREFDATA_OFFSET(CRContext) + VBOXTLSREFDATA_SIZE() + sizeof (pTmpContext->bitid) + sizeof (pTmpContext->neg_bitid);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync ui = RT_OFFSETOF(CRContext, shared) - ui;
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync }
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync else
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* VBOXTLSREFDATA is NOT stored */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync crMemcpy(&pTmpContext->bitid, &bitid, sizeof (bitid));
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = SSMR3GetMem(pSSM, &pTmpContext->neg_bitid, sizeof (pTmpContext->neg_bitid));
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync AssertRCReturn(rc, rc);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* the pre-VBOXTLSREFDATA CRContext structure might have additional allignment bits before the CRContext::shared */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync ui = VBOXTLSREFDATA_OFFSET(CRContext) + sizeof (pTmpContext->bitid) + sizeof (pTmpContext->neg_bitid);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync ui &= (sizeof (void*) - 1);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync }
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync if (ui)
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync void* pTmp = NULL;
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = SSMR3GetMem(pSSM, &pTmp, ui);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync AssertRCReturn(rc, rc);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync }
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync if (u32Version == SHCROGL_SSM_VERSION_BEFORE_CTXUSAGE_BITS)
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, shared, attrib);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = crStateLoadAttribState_v_BEFORE_CTXUSAGE_BITS(&pTmpContext->attrib, pSSM);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync AssertRCReturn(rc, rc);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRContext, attrib, buffer);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, buffer, point);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync rc = crStateLoadStencilPoint_v_37(&pTmpContext->point, pSSM);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync AssertRCReturn(rc, rc);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, polygon, stencil);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = crStateLoadStencilState_v_33(&pTmpContext->stencil, pSSM);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_CUT_FOR_OLD_TYPE_TO_ENSURE_ALIGNMENT(CRContext, stencil, CRStencilState_v_33, sizeof (void*));
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = crStateLoadTextureState_v_BEFORE_CTXUSAGE_BITS(&pTmpContext->texture, pSSM);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync AssertRCReturn(rc, rc);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRContext, texture, transform);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync SHCROGL_GET_STRUCT_TAIL(pTmpContext, CRContext, transform);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync }
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync else
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync {
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, shared, attrib);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = crStateLoadAttribState_v_33(&pTmpContext->attrib, pSSM);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRContext, attrib, buffer);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, buffer, point);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync rc = crStateLoadStencilPoint_v_37(&pTmpContext->point, pSSM);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync AssertRCReturn(rc, rc);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, polygon, stencil);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = crStateLoadStencilState_v_33(&pTmpContext->stencil, pSSM);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_CUT_FOR_OLD_TYPE_TO_ENSURE_ALIGNMENT(CRContext, stencil, CRStencilState_v_33, sizeof (void*));
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_TAIL(pTmpContext, CRContext, texture);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync }
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync pTmpContext->error = GL_NO_ERROR; /* <- the error state contained some random error data here
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync * treat as no error */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync }
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync else if (u32Version < SHCROGL_SSM_VERSION_WITH_FIXED_STENCIL)
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync {
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_HEAD(pTmpContext, CRContext, attrib);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = crStateLoadAttribState_v_33(&pTmpContext->attrib, pSSM);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_CUT_FIELD_ALIGNMENT(CRContext, attrib, buffer);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, buffer, point);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync rc = crStateLoadStencilPoint_v_37(&pTmpContext->point, pSSM);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync AssertRCReturn(rc, rc);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_PART(pTmpContext, CRContext, polygon, stencil);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync rc = crStateLoadStencilState_v_33(&pTmpContext->stencil, pSSM);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync AssertRCReturn(rc, rc);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_CUT_FOR_OLD_TYPE_TO_ENSURE_ALIGNMENT(CRContext, stencil, CRStencilState_v_33, sizeof (void*));
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync SHCROGL_GET_STRUCT_TAIL(pTmpContext, CRContext, texture);
79664e45c3d7123821dcd5de01991c6de96b8794vboxsync }
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync else if (u32Version < SHCROGL_SSM_VERSION_WITH_SPRITE_COORD_ORIGIN)
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync {
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_HEAD(pTmpContext, CRContext, point);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync crStateLoadStencilPoint_v_37(&pTmpContext->point, pSSM);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync SHCROGL_GET_STRUCT_TAIL(pTmpContext, CRContext, polygon);
9d60c2d3e53e65bb430517a9b7335061bc508b09vboxsync }
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync else
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync rc = SSMR3GetMem(pSSM, pTmpContext, sizeof (*pTmpContext));
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync AssertRCReturn(rc, rc);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync }
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync /* preserve the error to restore it at the end of context creation,
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync * it should not normally change, but just in case it it changed */
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync err = pTmpContext->error;
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync /* we will later do crMemcpy from entire pTmpContext to pContext,
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync * for simplicity store the VBOXTLSREFDATA from the pContext to pTmpContext */
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync VBOXTLSREFDATA_COPY(pTmpContext, pContext);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync /* Deal with shared state */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crFindSharedCtxParms_t parms;
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync int32_t shared;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3GetS32(pSSM, &pContext->shared->id);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync rc = SSMR3GetS32(pSSM, &shared);
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync AssertRCReturn(rc, rc);
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pTmpContext->shared = NULL;
f53ba2efceac1847585b2052ee98569305e9802dvboxsync parms.pfnCtxGet = pfnCtxGet;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync parms.pSrcCtx = pContext;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync parms.pDstCtx = pTmpContext;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableWalk(pCtxTable, crStateFindSharedCB, &parms);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (pTmpContext->shared)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync CRASSERT(pContext->shared->refCount==1);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync bLoadShared = GL_FALSE;
7f3bb583c97fd6f88c66f0047f1cd465afffefb4vboxsync crStateFreeShared(pContext, pContext->shared);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pContext->shared = NULL;
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync pTmpContext->shared->refCount++;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync else
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync SLC_COPYPTR(shared);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync if (bLoadShared && shared)
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync {
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync crStateSetSharedContext(pTmpContext);
5ce760ff6b7c94fe0d0ef3c0252d4864e629462bvboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(flush_func);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(flush_arg);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* We're supposed to be loading into an empty context, so those pointers should be NULL */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for ( i = 0 ; i < CR_MAX_ATTRIB_STACK_DEPTH ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_ASSSERT_NULL_PTR(attrib.enableStack[i].clip);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_ASSSERT_NULL_PTR(attrib.enableStack[i].light);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_ASSSERT_NULL_PTR(attrib.lightingStack[i].light);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_ASSSERT_NULL_PTR(attrib.transformStack[i].clip);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_ASSSERT_NULL_PTR(attrib.transformStack[i].clipPlane);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (j=0; j<GLEVAL_TOT; ++j)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_ASSSERT_NULL_PTR(attrib.evalStack[i].eval1D[j].coeff);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_ASSSERT_NULL_PTR(attrib.evalStack[i].eval2D[j].coeff);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_vertex_buffer_object
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(bufferobject.nullBuffer);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync/*@todo, that should be removed probably as those should hold the offset values, so loading should be fine
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync but better check*/
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync#if 0
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync#ifdef CR_EXT_compiled_vertex_array
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.v.prevPtr);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.c.prevPtr);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.f.prevPtr);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.s.prevPtr);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.e.prevPtr);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.i.prevPtr);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.n.prevPtr);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_TEXTURE_UNITS ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.t[i].prevPtr);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync# ifdef CR_NV_vertex_program
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync for (i = 0; i < CR_MAX_VERTEX_ATTRIBS; i++)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.a[i].prevPtr);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync# endif
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync#endif
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync#ifdef CR_ARB_vertex_buffer_object
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync /*That just sets those pointers to NULL*/
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.v.buffer);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.c.buffer);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.f.buffer);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.s.buffer);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.e.buffer);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.i.buffer);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.n.buffer);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_TEXTURE_UNITS ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.t[i].buffer);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync# ifdef CR_NV_vertex_program
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync for (i = 0; i < CR_MAX_VERTEX_ATTRIBS; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync SLC_COPYPTR(client.array.a[i].buffer);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync# endif
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync#endif /*CR_ARB_vertex_buffer_object*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /*@todo CR_NV_vertex_program*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crStateCopyEvalPtrs1D(pTmpContext->eval.eval1D, pContext->eval.eval1D);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crStateCopyEvalPtrs2D(pTmpContext->eval.eval2D, pContext->eval.eval2D);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(feedback.buffer); /*@todo*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(selection.buffer); /*@todo*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(lighting.light);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /*This one could be tricky if we're loading snapshot on host with different GPU*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(limits.extensions);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#if CR_ARB_occlusion_query
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(occlusion.objects); /*@todo*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(program.errorString);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(program.programHash);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(program.defaultVertexProgram);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(program.defaultFragmentProgram);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Texture pointers */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<6; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.base1D.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.base2D.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.base3D.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.proxy1D.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.proxy2D.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.proxy3D.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_texture_cube_map
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.baseCubeMap.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.proxyCubeMap.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_NV_texture_rectangle
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.baseRect.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(texture.proxyRect.level[i]);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load transform state */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(transform.clipPlane);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(transform.clip);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Don't have to worry about pContext->transform.current as it'd be set in crStateSetCurrent call */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /*SLC_COPYPTR(transform.currentStack);*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(transform.modelViewStack.stack);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(transform.projectionStack.stack);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(transform.colorStack.stack);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_TEXTURE_UNITS ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(transform.textureStack[i].stack);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_PROGRAM_MATRICES ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync SLC_COPYPTR(transform.programStack[i].stack);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync#ifdef CR_OPENGL_VERSION_2_0
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync SLC_COPYPTR(glsl.shaders);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync SLC_COPYPTR(glsl.programs);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync#endif
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Have to preserve original context id */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pTmpContext->id == pContext->id);
ca2d9a827c7e0bf938937debeb7e98e9be1edd86vboxsync CRASSERT(VBOXTLSREFDATA_EQUAL(pContext, pTmpContext));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Copy ordinary state to real context */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crMemcpy(pContext, pTmpContext, sizeof(*pTmpContext));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crFree(pTmpContext);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pTmpContext = NULL;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Now deal with pointers */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load transform state */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, pContext->transform.clipPlane, sizeof(GLvectord)*CR_MAX_CLIP_PLANES);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, pContext->transform.clip, sizeof(GLboolean)*CR_MAX_CLIP_PLANES);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadMatrixStack(&pContext->transform.modelViewStack, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadMatrixStack(&pContext->transform.projectionStack, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadMatrixStack(&pContext->transform.colorStack, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_TEXTURE_UNITS ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadMatrixStack(&pContext->transform.textureStack[i], pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i = 0 ; i < CR_MAX_PROGRAM_MATRICES ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadMatrixStack(&pContext->transform.programStack[i], pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load Textures */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.base1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.base2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.base3D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.proxy1D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.proxy2D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.proxy3D, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_texture_cube_map
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.baseCubeMap, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.proxyCubeMap, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_NV_texture_rectangle
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.baseRect, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTextureObjData(&pContext->texture.proxyRect, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (bLoadShared)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync /* Load shared textures */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync CRASSERT(pContext->shared && pContext->shared->textureTable);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync if (u32Version >= SHCROGL_SSM_VERSION_WITH_ALLOCATED_KEYS)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync rc = crStateLoadKeys(pContext->shared->buffersTable, pSSM, u32Version);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3GetU32(pSSM, &uiNumElems);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync for (ui=0; ui<uiNumElems; ++ui)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync CRTextureObj *pTexture;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pTexture = (CRTextureObj *) crCalloc(sizeof(CRTextureObj));
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (!pTexture) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadTextureObj(pTexture, pSSM, u32Version);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pTexture->hwid = 0;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync /*allocate actual memory*/
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync for (i=0; i<6; ++i) {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pTexture->level[i] = (CRTextureLevel *) crCalloc(sizeof(CRTextureLevel) * CR_MAX_MIPMAP_LEVELS);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (!pTexture->level[i]) return VERR_NO_MEMORY;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = crStateLoadTextureObjData(pTexture, pSSM);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableAdd(pContext->shared->textureTable, key, pTexture);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load current texture pointers */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (i=0; i<CR_MAX_TEXTURE_UNITS; ++i)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTexUnitCurrentTexturePtrs(&pContext->texture.unit[i], pContext, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Mark textures for resending to GPU */
dfd5d06c9f004de9f61904c9d1185bca70969c6avboxsync pContext->shared->bTexResyncNeeded = GL_TRUE;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load lights */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pContext->lighting.light);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, pContext->lighting.light, CR_MAX_LIGHTS * sizeof(*pContext->lighting.light));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load attrib stack*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for ( i = 0 ; i < CR_MAX_ATTRIB_STACK_DEPTH ; i++)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.enableStack[i].clip)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
885ac2b8c00cb7f4878e9108f40e1a43ff756e35vboxsync rc = crStateAllocAndSSMR3GetMem(pSSM, (void**)&pContext->attrib.enableStack[i].clip,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxClipPlanes*sizeof(GLboolean));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.enableStack[i].light)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
885ac2b8c00cb7f4878e9108f40e1a43ff756e35vboxsync rc = crStateAllocAndSSMR3GetMem(pSSM, (void**)&pContext->attrib.enableStack[i].light,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxLights*sizeof(GLboolean));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.lightingStack[i].light)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
885ac2b8c00cb7f4878e9108f40e1a43ff756e35vboxsync rc = crStateAllocAndSSMR3GetMem(pSSM, (void**)&pContext->attrib.lightingStack[i].light,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxLights*sizeof(CRLight));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (k=0; k<pContext->limits.maxTextureUnits; ++k)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadTexUnitCurrentTexturePtrs(&pContext->attrib.textureStack[i].unit[k], pContext, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.transformStack[i].clip)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
885ac2b8c00cb7f4878e9108f40e1a43ff756e35vboxsync rc = crStateAllocAndSSMR3GetMem(pSSM, (void*)&pContext->attrib.transformStack[i].clip,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxClipPlanes*sizeof(GLboolean));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pContext->attrib.transformStack[i].clipPlane)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
885ac2b8c00cb7f4878e9108f40e1a43ff756e35vboxsync rc = crStateAllocAndSSMR3GetMem(pSSM, (void**)&pContext->attrib.transformStack[i].clipPlane,
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->limits.maxClipPlanes*sizeof(GLvectord));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateLoadEvalCoeffs1D(pContext->attrib.evalStack[i].eval1D, GL_TRUE, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateLoadEvalCoeffs2D(pContext->attrib.evalStack[i].eval2D, GL_TRUE, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load evaluator coeffs */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateLoadEvalCoeffs1D(pContext->eval.eval1D, GL_FALSE, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crSateLoadEvalCoeffs2D(pContext->eval.eval2D, GL_FALSE, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load buffer objects */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#ifdef CR_ARB_vertex_buffer_object
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync if (bLoadShared)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync if (u32Version >= SHCROGL_SSM_VERSION_WITH_ALLOCATED_KEYS)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync rc = crStateLoadKeys(pContext->shared->textureTable, pSSM, u32Version);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetU32(pSSM, &uiNumElems);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (ui=0; ui<=uiNumElems; ++ui) /*ui<=uiNumElems to load nullBuffer in same loop*/
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRBufferObject *pBufferObj;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* default one should be already allocated */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (key==0)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pBufferObj = pContext->bufferobject.nullBuffer;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!pBufferObj) return VERR_SSM_UNEXPECTED_DATA;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync else
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pBufferObj = (CRBufferObject *) crCalloc(sizeof(*pBufferObj));
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (!pBufferObj) return VERR_NO_MEMORY;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadBufferObject(pBufferObj, pSSM, u32Version);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pBufferObj->hwid = 0;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (pBufferObj->data)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRASSERT(pBufferObj->size>0);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pBufferObj->data = crAlloc(pBufferObj->size);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetMem(pSSM, pBufferObj->data, pBufferObj->size);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync else if (pBufferObj->id!=0 && pBufferObj->size>0)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync rc = SSMR3GetMem(pSSM, &pBufferObj->data, sizeof(pBufferObj->data));
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync AssertRCReturn(rc, rc);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync if (pBufferObj->data)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync pBufferObj->data = crAlloc(pBufferObj->size);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync rc = SSMR3GetMem(pSSM, pBufferObj->data, pBufferObj->size);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync AssertRCReturn(rc, rc);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync if (key!=0)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableAdd(pContext->shared->buffersTable, key, pBufferObj);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load pointers */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync#define CRS_GET_BO(name) (((name)==0) ? (pContext->bufferobject.nullBuffer) : crHashtableSearch(pContext->shared->buffersTable, name))
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync rc = SSMR3GetU32(pSSM, &ui);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync AssertRCReturn(rc, rc);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync pContext->bufferobject.arrayBuffer = CRS_GET_BO(ui);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync rc = SSMR3GetU32(pSSM, &ui);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync AssertRCReturn(rc, rc);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync pContext->bufferobject.elementsBuffer = CRS_GET_BO(ui);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync#ifdef CR_ARB_pixel_buffer_object
af8d59d05d72f134aeea62712f1286b369807d52vboxsync rc = SSMR3GetU32(pSSM, &ui);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync AssertRCReturn(rc, rc);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync pContext->bufferobject.packBuffer = CRS_GET_BO(ui);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync rc = SSMR3GetU32(pSSM, &ui);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync AssertRCReturn(rc, rc);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync pContext->bufferobject.unpackBuffer = CRS_GET_BO(ui);
af8d59d05d72f134aeea62712f1286b369807d52vboxsync#endif
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync#undef CRS_GET_BO
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync /* Load client pointers and array buffer bindings*/
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync for (i=0; i<CRSTATECLIENT_MAX_VERTEXARRAYS; ++i)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync rc = crStateLoadClientPointer(&pContext->client.array, i, pContext, pSSM);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync AssertRCReturn(rc, rc);
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync for (j=0; j<pContext->client.vertexArrayStackDepth; ++j)
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync {
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync CRVertexArrays *pArray = &pContext->client.vertexArrayStack[j];
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync for (i=0; i<CRSTATECLIENT_MAX_VERTEXARRAYS; ++i)
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync {
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync rc = crStateLoadClientPointer(pArray, i, pContext, pSSM);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync AssertRCReturn(rc, rc);
e42c49edebbc79edb6d87377bab6d879fdb602favboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync }
bf144aab354eaec8ee22b16b1c138f47f38b7244vboxsync
dfd5d06c9f004de9f61904c9d1185bca70969c6avboxsync pContext->shared->bVBOResyncNeeded = GL_TRUE;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync#endif
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load pixel/vertex programs */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetU32(pSSM, &uiNumElems);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
ad27e1d5e48ca41245120c331cc88b50464813cevboxsync /* Load defaults programs */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadProgram(&pContext->program.defaultVertexProgram, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadProgram(&pContext->program.defaultFragmentProgram, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load all the rest */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync for (ui=0; ui<uiNumElems; ++ui)
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync {
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync CRProgram *pProgram = NULL;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = crStateLoadProgram(&pProgram, pSSM);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync crHashtableAdd(pContext->program.programHash, pProgram->id, pProgram);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync //DIRTY(pProgram->dirtyProgram, pContext->neg_bitid);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync }
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Load Pointers */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetU32(pSSM, &ui);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->program.currentVertexProgram = ui==0 ? pContext->program.defaultVertexProgram
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync : crHashtableSearch(pContext->program.programHash, ui);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync rc = SSMR3GetU32(pSSM, &ui);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync AssertRCReturn(rc, rc);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->program.currentFragmentProgram = ui==0 ? pContext->program.defaultFragmentProgram
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync : crHashtableSearch(pContext->program.programHash, ui);
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync /* Mark programs for resending to GPU */
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync pContext->program.bResyncNeeded = GL_TRUE;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync#ifdef CR_EXT_framebuffer_object
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync /* Load FBOs */
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (bLoadShared)
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync {
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync if (u32Version >= SHCROGL_SSM_VERSION_WITH_ALLOCATED_KEYS)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync rc = crStateLoadKeys(pContext->shared->fbTable, pSSM, u32Version);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3GetU32(pSSM, &uiNumElems);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync for (ui=0; ui<uiNumElems; ++ui)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync CRFramebufferObject *pFBO;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pFBO = crAlloc(sizeof(*pFBO));
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (!pFBO) return VERR_NO_MEMORY;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadFramebufferObject(pFBO, pSSM, u32Version);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync Assert(key == pFBO->id);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableAdd(pContext->shared->fbTable, key, pFBO);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync if (u32Version >= SHCROGL_SSM_VERSION_WITH_ALLOCATED_KEYS)
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync {
4252e037570a3c8d943552edb7858c9889aaca1dvboxsync rc = crStateLoadKeys(pContext->shared->rbTable, pSSM, u32Version);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync AssertRCReturn(rc, rc);
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync }
bff361262f6f9bda1094fc5f754259b8e0404718vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3GetU32(pSSM, &uiNumElems);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync for (ui=0; ui<uiNumElems; ++ui)
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync {
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync CRRenderbufferObject *pRBO;
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync pRBO = crAlloc(sizeof(*pRBO));
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync if (!pRBO) return VERR_NO_MEMORY;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
b862944342504d1b9dddd6348d1a9048c72ba418vboxsync rc = crStateLoadRenderbufferObject(pRBO, pSSM, u32Version);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync AssertRCReturn(rc, rc);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync crHashtableAdd(pContext->shared->rbTable, key, pRBO);
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync }
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync }
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync rc = SSMR3GetU32(pSSM, &ui);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync AssertRCReturn(rc, rc);
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync pContext->framebufferobject.drawFB = ui==0 ? NULL
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync : crHashtableSearch(pContext->shared->fbTable, ui);
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync rc = SSMR3GetU32(pSSM, &ui);
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync AssertRCReturn(rc, rc);
061bebe04c5bfa05ed733d2a1204389c2a0c96a8vboxsync pContext->framebufferobject.readFB = ui==0 ? NULL
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync : crHashtableSearch(pContext->shared->fbTable, ui);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync rc = SSMR3GetU32(pSSM, &ui);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync AssertRCReturn(rc, rc);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync pContext->framebufferobject.renderbuffer = ui==0 ? NULL
c62d2520ac91e12cf4665c936f490dd2064152d3vboxsync : crHashtableSearch(pContext->shared->rbTable, ui);
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync /* Mark FBOs/RBOs for resending to GPU */
dfd5d06c9f004de9f61904c9d1185bca70969c6avboxsync pContext->shared->bFBOResyncNeeded = GL_TRUE;
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync#endif
bd810d58866067df322ea7f4a4627d9bdebb70d3vboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync#ifdef CR_OPENGL_VERSION_2_0
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync /* Load GLSL related info */
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetU32(pSSM, &uiNumElems);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (ui=0; ui<uiNumElems; ++ui)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRGLSLShader *pShader = crStateLoadGLSLShader(pSSM);
feec36ab53448184d62770ee208446b421a60a8cvboxsync GLboolean fNewKeyCheck;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (!pShader) return VERR_SSM_UNEXPECTED_DATA;
feec36ab53448184d62770ee208446b421a60a8cvboxsync fNewKeyCheck = crHashtableAllocRegisterKey(pContext->glsl.programs, pShader->id);
feec36ab53448184d62770ee208446b421a60a8cvboxsync CRASSERT(fNewKeyCheck);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableAdd(pContext->glsl.shaders, pShader->id, pShader);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetU32(pSSM, &uiNumElems);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (ui=0; ui<uiNumElems; ++ui)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRGLSLProgram *pProgram;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync uint32_t numShaders;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram = crAlloc(sizeof(*pProgram));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (!pProgram) return VERR_NO_MEMORY;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, pProgram, sizeof(*pProgram));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableAdd(pContext->glsl.programs, key, pProgram);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->currentState.attachedShaders = crAllocHashtable();
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetU32(pSSM, &numShaders);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (k=0; k<numShaders; ++k)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, &key, sizeof(key));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableAdd(pProgram->currentState.attachedShaders, key, crHashtableSearch(pContext->glsl.shaders, key));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (pProgram->activeState.attachedShaders)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->activeState.attachedShaders = crAllocHashtable();
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetU32(pSSM, &numShaders);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (k=0; k<numShaders; ++k)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync CRGLSLShader *pShader = crStateLoadGLSLShader(pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (!pShader) return VERR_SSM_UNEXPECTED_DATA;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync crHashtableAdd(pProgram->activeState.attachedShaders, pShader->id, pShader);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (pProgram->currentState.cAttribs)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->currentState.pAttribs = (CRGLSLAttrib*) crAlloc(pProgram->currentState.cAttribs*sizeof(CRGLSLAttrib));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (k=0; k<pProgram->currentState.cAttribs; ++k)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, &pProgram->currentState.pAttribs[k].index, sizeof(pProgram->currentState.pAttribs[k].index));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->currentState.pAttribs[k].name = crStateLoadString(pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (pProgram->activeState.cAttribs)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->activeState.pAttribs = (CRGLSLAttrib*) crAlloc(pProgram->activeState.cAttribs*sizeof(CRGLSLAttrib));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (k=0; k<pProgram->activeState.cAttribs; ++k)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, &pProgram->activeState.pAttribs[k].index, sizeof(pProgram->activeState.pAttribs[k].index));
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->activeState.pAttribs[k].name = crStateLoadString(pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
4a82b347bce2c97db4707d994221b4c20437b520vboxsync {
4a82b347bce2c97db4707d994221b4c20437b520vboxsync int32_t cUniforms;
4a82b347bce2c97db4707d994221b4c20437b520vboxsync rc = SSMR3GetS32(pSSM, &cUniforms);
4a82b347bce2c97db4707d994221b4c20437b520vboxsync pProgram->cUniforms = cUniforms;
4a82b347bce2c97db4707d994221b4c20437b520vboxsync AssertRCReturn(rc, rc);
4a82b347bce2c97db4707d994221b4c20437b520vboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (pProgram->cUniforms)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->pUniforms = crAlloc(pProgram->cUniforms*sizeof(CRGLSLUniform));
72a172086ef6c3efdad279eb727f64e760116300vboxsync if (!pProgram->pUniforms) return VERR_NO_MEMORY;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync for (k=0; k<pProgram->cUniforms; ++k)
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync size_t itemsize, datasize;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, &pProgram->pUniforms[k].type, sizeof(GLenum));
4ff9c17f67441ba055d522ae932fbe7fb47250a8vboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->pUniforms[k].name = crStateLoadString(pSSM);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
c697d02eb4ededad7e08b2c48428ddb56c844a0avboxsync if (crStateIsIntUniform(pProgram->pUniforms[k].type))
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync {
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync itemsize = sizeof(GLint);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync } else itemsize = sizeof(GLfloat);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync datasize = crStateGetUniformSize(pProgram->pUniforms[k].type)*itemsize;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pProgram->pUniforms[k].data = crAlloc(datasize);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync if (!pProgram->pUniforms[k].data) return VERR_NO_MEMORY;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetMem(pSSM, pProgram->pUniforms[k].data, datasize);
4ff9c17f67441ba055d522ae932fbe7fb47250a8vboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync }
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync rc = SSMR3GetU32(pSSM, &ui);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync AssertRCReturn(rc, rc);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pContext->glsl.activeProgram = ui==0 ? NULL
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync : crHashtableSearch(pContext->glsl.programs, ui);
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync /*Mark for resending to GPU*/
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync pContext->glsl.bResyncNeeded = GL_TRUE;
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync#endif
6e7c344fc7cdb580356704e8201207b394d367bbvboxsync
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync if (pContext->error != err)
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync {
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync crWarning("context error state changed on context restore, was 0x%x, but became 0x%x, resetting to its original value",
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync err, pContext->error);
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync pContext->error = err;
4e9f070a55a9ab37758f11adff5ca15d0498bcffvboxsync }
fdd5017195ab02e09ceefa312beaf5d538fdf2edvboxsync
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync return VINF_SUCCESS;
e0e0c19eefceaf5d4ec40f9466b58a771f50e799vboxsync}