Commit e9ebbfc0 authored by Robert Reif's avatar Robert Reif Committed by Alexandre Julliard

Now that reference counting is correct, there is no need to check if

the base object goes away.
parent 5cab2b35
...@@ -400,16 +400,6 @@ static DWORD WINAPI IDirectSoundBufferImpl_Release(LPDIRECTSOUNDBUFFER8 iface) { ...@@ -400,16 +400,6 @@ static DWORD WINAPI IDirectSoundBufferImpl_Release(LPDIRECTSOUNDBUFFER8 iface) {
} }
} }
if (This->ds3db) {
WARN("ds3db still has reference\n");
EnterCriticalSection(&(This->ds3db->lock));
This->ds3db->dsb = NULL;
LeaveCriticalSection(&(This->ds3db->lock));
}
if (This->iks)
IKsPropertySet_Release((LPKSPROPERTYSET)This->iks);
if (This->notifies != NULL) if (This->notifies != NULL)
HeapFree(GetProcessHeap(), 0, This->notifies); HeapFree(GetProcessHeap(), 0, This->notifies);
......
...@@ -342,7 +342,6 @@ struct IDirectSound3DBufferImpl ...@@ -342,7 +342,6 @@ struct IDirectSound3DBufferImpl
DWORD ref; DWORD ref;
/* IDirectSound3DBufferImpl fields */ /* IDirectSound3DBufferImpl fields */
IDirectSoundBufferImpl* dsb; IDirectSoundBufferImpl* dsb;
CRITICAL_SECTION lock;
}; };
HRESULT WINAPI IDirectSound3DBufferImpl_Create( HRESULT WINAPI IDirectSound3DBufferImpl_Create(
......
...@@ -397,7 +397,6 @@ static ULONG WINAPI IDirectSound3DBufferImpl_Release(LPDIRECTSOUND3DBUFFER iface ...@@ -397,7 +397,6 @@ static ULONG WINAPI IDirectSound3DBufferImpl_Release(LPDIRECTSOUND3DBUFFER iface
if (!ulReturn) { if (!ulReturn) {
This->dsb->ds3db = NULL; This->dsb->ds3db = NULL;
IDirectSoundBuffer_Release((LPDIRECTSOUNDBUFFER8)This->dsb); IDirectSoundBuffer_Release((LPDIRECTSOUNDBUFFER8)This->dsb);
DeleteCriticalSection(&(This->lock));
HeapFree(GetProcessHeap(),0,This); HeapFree(GetProcessHeap(),0,This);
TRACE("(%p) released\n",This); TRACE("(%p) released\n",This);
} }
...@@ -423,10 +422,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetAllParameters( ...@@ -423,10 +422,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetAllParameters(
return DSERR_INVALIDPARAM; return DSERR_INVALIDPARAM;
} }
if (This->dsb) { TRACE("returning: all parameters\n");
TRACE("returning: all parameters\n"); *lpDs3dBuffer = This->dsb->ds3db_ds3db;
*lpDs3dBuffer = This->dsb->ds3db_ds3db;
}
return DS_OK; return DS_OK;
} }
...@@ -436,12 +433,10 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeAngles( ...@@ -436,12 +433,10 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeAngles(
LPDWORD lpdwOutsideConeAngle) LPDWORD lpdwOutsideConeAngle)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Inside Cone Angle = %ld degrees; Outside Cone Angle = %ld degrees\n",
TRACE("returning: Inside Cone Angle = %ld degrees; Outside Cone Angle = %ld degrees\n", This->dsb->ds3db_ds3db.dwInsideConeAngle, This->dsb->ds3db_ds3db.dwOutsideConeAngle);
This->dsb->ds3db_ds3db.dwInsideConeAngle, This->dsb->ds3db_ds3db.dwOutsideConeAngle); *lpdwInsideConeAngle = This->dsb->ds3db_ds3db.dwInsideConeAngle;
*lpdwInsideConeAngle = This->dsb->ds3db_ds3db.dwInsideConeAngle; *lpdwOutsideConeAngle = This->dsb->ds3db_ds3db.dwOutsideConeAngle;
*lpdwOutsideConeAngle = This->dsb->ds3db_ds3db.dwOutsideConeAngle;
}
return DS_OK; return DS_OK;
} }
...@@ -450,13 +445,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOrientation( ...@@ -450,13 +445,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOrientation(
LPD3DVECTOR lpvConeOrientation) LPD3DVECTOR lpvConeOrientation)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Cone Orientation vector = (%f,%f,%f)\n",
TRACE("returning: Cone Orientation vector = (%f,%f,%f)\n", This->dsb->ds3db_ds3db.vConeOrientation.u1.x,
This->dsb->ds3db_ds3db.vConeOrientation.u1.x, This->dsb->ds3db_ds3db.vConeOrientation.u2.y,
This->dsb->ds3db_ds3db.vConeOrientation.u2.y, This->dsb->ds3db_ds3db.vConeOrientation.u3.z);
This->dsb->ds3db_ds3db.vConeOrientation.u3.z); *lpvConeOrientation = This->dsb->ds3db_ds3db.vConeOrientation;
*lpvConeOrientation = This->dsb->ds3db_ds3db.vConeOrientation;
}
return DS_OK; return DS_OK;
} }
...@@ -465,10 +458,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOutsideVolume( ...@@ -465,10 +458,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetConeOutsideVolume(
LPLONG lplConeOutsideVolume) LPLONG lplConeOutsideVolume)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Cone Outside Volume = %ld\n", This->dsb->ds3db_ds3db.lConeOutsideVolume);
TRACE("returning: Cone Outside Volume = %ld\n", This->dsb->ds3db_ds3db.lConeOutsideVolume); *lplConeOutsideVolume = This->dsb->ds3db_ds3db.lConeOutsideVolume;
*lplConeOutsideVolume = This->dsb->ds3db_ds3db.lConeOutsideVolume;
}
return DS_OK; return DS_OK;
} }
...@@ -477,10 +468,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMaxDistance( ...@@ -477,10 +468,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMaxDistance(
LPD3DVALUE lpfMaxDistance) LPD3DVALUE lpfMaxDistance)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Max Distance = %f\n", This->dsb->ds3db_ds3db.flMaxDistance);
TRACE("returning: Max Distance = %f\n", This->dsb->ds3db_ds3db.flMaxDistance); *lpfMaxDistance = This->dsb->ds3db_ds3db.flMaxDistance;
*lpfMaxDistance = This->dsb->ds3db_ds3db.flMaxDistance;
}
return DS_OK; return DS_OK;
} }
...@@ -489,10 +478,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMinDistance( ...@@ -489,10 +478,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMinDistance(
LPD3DVALUE lpfMinDistance) LPD3DVALUE lpfMinDistance)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Min Distance = %f\n", This->dsb->ds3db_ds3db.flMinDistance);
TRACE("returning: Min Distance = %f\n", This->dsb->ds3db_ds3db.flMinDistance); *lpfMinDistance = This->dsb->ds3db_ds3db.flMinDistance;
*lpfMinDistance = This->dsb->ds3db_ds3db.flMinDistance;
}
return DS_OK; return DS_OK;
} }
...@@ -501,10 +488,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMode( ...@@ -501,10 +488,8 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetMode(
LPDWORD lpdwMode) LPDWORD lpdwMode)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Mode = %ld\n", This->dsb->ds3db_ds3db.dwMode);
TRACE("returning: Mode = %ld\n", This->dsb->ds3db_ds3db.dwMode); *lpdwMode = This->dsb->ds3db_ds3db.dwMode;
*lpdwMode = This->dsb->ds3db_ds3db.dwMode;
}
return DS_OK; return DS_OK;
} }
...@@ -513,13 +498,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetPosition( ...@@ -513,13 +498,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetPosition(
LPD3DVECTOR lpvPosition) LPD3DVECTOR lpvPosition)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Position vector = (%f,%f,%f)\n",
TRACE("returning: Position vector = (%f,%f,%f)\n", This->dsb->ds3db_ds3db.vPosition.u1.x,
This->dsb->ds3db_ds3db.vPosition.u1.x, This->dsb->ds3db_ds3db.vPosition.u2.y,
This->dsb->ds3db_ds3db.vPosition.u2.y, This->dsb->ds3db_ds3db.vPosition.u3.z);
This->dsb->ds3db_ds3db.vPosition.u3.z); *lpvPosition = This->dsb->ds3db_ds3db.vPosition;
*lpvPosition = This->dsb->ds3db_ds3db.vPosition;
}
return DS_OK; return DS_OK;
} }
...@@ -528,13 +511,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetVelocity( ...@@ -528,13 +511,11 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_GetVelocity(
LPD3DVECTOR lpvVelocity) LPD3DVECTOR lpvVelocity)
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
if (This->dsb) { TRACE("returning: Velocity vector = (%f,%f,%f)\n",
TRACE("returning: Velocity vector = (%f,%f,%f)\n", This->dsb->ds3db_ds3db.vVelocity.u1.x,
This->dsb->ds3db_ds3db.vVelocity.u1.x, This->dsb->ds3db_ds3db.vVelocity.u2.y,
This->dsb->ds3db_ds3db.vVelocity.u2.y, This->dsb->ds3db_ds3db.vVelocity.u3.z);
This->dsb->ds3db_ds3db.vVelocity.u3.z); *lpvVelocity = This->dsb->ds3db_ds3db.vVelocity;
*lpvVelocity = This->dsb->ds3db_ds3db.vVelocity;
}
return DS_OK; return DS_OK;
} }
...@@ -558,22 +539,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetAllParameters( ...@@ -558,22 +539,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetAllParameters(
return status; return status;
} }
EnterCriticalSection(&This->lock); TRACE("setting: all parameters; dwApply = %ld\n", dwApply);
This->dsb->ds3db_ds3db = *lpcDs3dBuffer;
if (This->dsb) {
TRACE("setting: all parameters; dwApply = %ld\n", dwApply);
This->dsb->ds3db_ds3db = *lpcDs3dBuffer;
if (dwApply == DS3D_IMMEDIATE)
{
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
status = DS_OK;
} else
WARN("pointer no longer valid\n");
LeaveCriticalSection(&This->lock); if (dwApply == DS3D_IMMEDIATE)
{
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
status = DS_OK;
return status; return status;
} }
...@@ -587,15 +561,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeAngles( ...@@ -587,15 +561,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeAngles(
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: Inside Cone Angle = %ld; Outside Cone Angle = %ld; dwApply = %ld\n", TRACE("setting: Inside Cone Angle = %ld; Outside Cone Angle = %ld; dwApply = %ld\n",
dwInsideConeAngle, dwOutsideConeAngle, dwApply); dwInsideConeAngle, dwOutsideConeAngle, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.dwInsideConeAngle = dwInsideConeAngle;
This->dsb->ds3db_ds3db.dwInsideConeAngle = dwInsideConeAngle; This->dsb->ds3db_ds3db.dwOutsideConeAngle = dwOutsideConeAngle;
This->dsb->ds3db_ds3db.dwOutsideConeAngle = dwOutsideConeAngle; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -606,17 +578,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOrientation( ...@@ -606,17 +578,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOrientation(
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: Cone Orientation vector = (%f,%f,%f); dwApply = %ld\n", x, y, z, dwApply); TRACE("setting: Cone Orientation vector = (%f,%f,%f); dwApply = %ld\n", x, y, z, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.vConeOrientation.u1.x = x;
This->dsb->ds3db_ds3db.vConeOrientation.u1.x = x; This->dsb->ds3db_ds3db.vConeOrientation.u2.y = y;
This->dsb->ds3db_ds3db.vConeOrientation.u2.y = y; This->dsb->ds3db_ds3db.vConeOrientation.u3.z = z;
This->dsb->ds3db_ds3db.vConeOrientation.u3.z = z; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ This->dsb->ds3db_need_recalc = FALSE;
This->dsb->ds3db_need_recalc = FALSE; DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -627,15 +597,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOutsideVolume( ...@@ -627,15 +597,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetConeOutsideVolume(
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: ConeOutsideVolume = %ld; dwApply = %ld\n", lConeOutsideVolume, dwApply); TRACE("setting: ConeOutsideVolume = %ld; dwApply = %ld\n", lConeOutsideVolume, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.lConeOutsideVolume = lConeOutsideVolume;
This->dsb->ds3db_ds3db.lConeOutsideVolume = lConeOutsideVolume; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ This->dsb->ds3db_need_recalc = FALSE;
This->dsb->ds3db_need_recalc = FALSE; DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -646,15 +614,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMaxDistance( ...@@ -646,15 +614,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMaxDistance(
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: MaxDistance = %f; dwApply = %ld\n", fMaxDistance, dwApply); TRACE("setting: MaxDistance = %f; dwApply = %ld\n", fMaxDistance, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.flMaxDistance = fMaxDistance;
This->dsb->ds3db_ds3db.flMaxDistance = fMaxDistance; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ This->dsb->ds3db_need_recalc = FALSE;
This->dsb->ds3db_need_recalc = FALSE; DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -665,15 +631,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMinDistance( ...@@ -665,15 +631,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMinDistance(
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: MinDistance = %f; dwApply = %ld\n", fMinDistance, dwApply); TRACE("setting: MinDistance = %f; dwApply = %ld\n", fMinDistance, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.flMinDistance = fMinDistance;
This->dsb->ds3db_ds3db.flMinDistance = fMinDistance; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ This->dsb->ds3db_need_recalc = FALSE;
This->dsb->ds3db_need_recalc = FALSE; DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -684,15 +648,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMode( ...@@ -684,15 +648,13 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetMode(
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: Mode = %ld; dwApply = %ld\n", dwMode, dwApply); TRACE("setting: Mode = %ld; dwApply = %ld\n", dwMode, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.dwMode = dwMode;
This->dsb->ds3db_ds3db.dwMode = dwMode; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ This->dsb->ds3db_need_recalc = FALSE;
This->dsb->ds3db_need_recalc = FALSE; DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -703,17 +665,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetPosition( ...@@ -703,17 +665,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetPosition(
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: Position vector = (%f,%f,%f); dwApply = %ld\n", x, y, z, dwApply); TRACE("setting: Position vector = (%f,%f,%f); dwApply = %ld\n", x, y, z, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.vPosition.u1.x = x;
This->dsb->ds3db_ds3db.vPosition.u1.x = x; This->dsb->ds3db_ds3db.vPosition.u2.y = y;
This->dsb->ds3db_ds3db.vPosition.u2.y = y; This->dsb->ds3db_ds3db.vPosition.u3.z = z;
This->dsb->ds3db_ds3db.vPosition.u3.z = z; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ This->dsb->ds3db_need_recalc = FALSE;
This->dsb->ds3db_need_recalc = FALSE; DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -724,17 +684,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetVelocity( ...@@ -724,17 +684,15 @@ static HRESULT WINAPI IDirectSound3DBufferImpl_SetVelocity(
{ {
ICOM_THIS(IDirectSound3DBufferImpl,iface); ICOM_THIS(IDirectSound3DBufferImpl,iface);
TRACE("setting: Velocity vector = (%f,%f,%f); dwApply = %ld\n", x, y, z, dwApply); TRACE("setting: Velocity vector = (%f,%f,%f); dwApply = %ld\n", x, y, z, dwApply);
if (This->dsb) { This->dsb->ds3db_ds3db.vVelocity.u1.x = x;
This->dsb->ds3db_ds3db.vVelocity.u1.x = x; This->dsb->ds3db_ds3db.vVelocity.u2.y = y;
This->dsb->ds3db_ds3db.vVelocity.u2.y = y; This->dsb->ds3db_ds3db.vVelocity.u3.z = z;
This->dsb->ds3db_ds3db.vVelocity.u3.z = z; if (dwApply == DS3D_IMMEDIATE)
if (dwApply == DS3D_IMMEDIATE) {
{ This->dsb->ds3db_need_recalc = FALSE;
This->dsb->ds3db_need_recalc = FALSE; DSOUND_Mix3DBuffer(This->dsb);
DSOUND_Mix3DBuffer(This->dsb);
}
This->dsb->ds3db_need_recalc = TRUE;
} }
This->dsb->ds3db_need_recalc = TRUE;
return DS_OK; return DS_OK;
} }
...@@ -804,8 +762,6 @@ HRESULT WINAPI IDirectSound3DBufferImpl_Create( ...@@ -804,8 +762,6 @@ HRESULT WINAPI IDirectSound3DBufferImpl_Create(
ds3db->dsb->ds3db_need_recalc = TRUE; ds3db->dsb->ds3db_need_recalc = TRUE;
InitializeCriticalSection(&(ds3db->lock));
IDirectSoundBuffer_AddRef((LPDIRECTSOUNDBUFFER8)dsb); IDirectSoundBuffer_AddRef((LPDIRECTSOUNDBUFFER8)dsb);
*pds3db = ds3db; *pds3db = ds3db;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment