Use DeviceRef and ContextRef when creating a new device and context

This commit is contained in:
Chris Robinson 2019-01-01 22:44:46 -08:00
parent 399dfca1e3
commit 88c2f11dcf

View File

@ -3409,10 +3409,6 @@ ALC_API ALCenum ALC_APIENTRY alcGetEnumValue(ALCdevice *device, const ALCchar *e
*/ */
ALC_API ALCcontext* ALC_APIENTRY alcCreateContext(ALCdevice *device, const ALCint *attrList) ALC_API ALCcontext* ALC_APIENTRY alcCreateContext(ALCdevice *device, const ALCint *attrList)
{ {
ALCcontext *ALContext;
ALfloat valf;
ALCenum err;
/* Explicitly hold the list lock while taking the StateLock in case the /* Explicitly hold the list lock while taking the StateLock in case the
* device is asynchronously destroyed, to ensure this new context is * device is asynchronously destroyed, to ensure this new context is
* properly cleaned up after being made. * properly cleaned up after being made.
@ -3430,22 +3426,20 @@ ALC_API ALCcontext* ALC_APIENTRY alcCreateContext(ALCdevice *device, const ALCin
dev->LastError.store(ALC_NO_ERROR); dev->LastError.store(ALC_NO_ERROR);
ALContext = new ALCcontext{dev.get()}; ContextRef ALContext{new ALCcontext{dev.get()}};
ALCdevice_IncRef(ALContext->Device); ALCdevice_IncRef(ALContext->Device);
if((err=UpdateDeviceParams(dev.get(), attrList)) != ALC_NO_ERROR) ALCenum err{UpdateDeviceParams(dev.get(), attrList)};
if(err != ALC_NO_ERROR)
{ {
alcSetError(dev.get(), err); alcSetError(dev.get(), err);
if(err == ALC_INVALID_DEVICE) if(err == ALC_INVALID_DEVICE)
aluHandleDisconnect(dev.get(), "Device update failure"); aluHandleDisconnect(dev.get(), "Device update failure");
statelock.unlock(); statelock.unlock();
delete ALContext;
ALContext = nullptr;
return nullptr; return nullptr;
} }
AllocateVoices(ALContext, 256, dev->NumAuxSends); AllocateVoices(ALContext.get(), 256, dev->NumAuxSends);
if(DefaultEffect.type != AL_EFFECT_NULL && dev->Type == Playback) if(DefaultEffect.type != AL_EFFECT_NULL && dev->Type == Playback)
{ {
@ -3459,8 +3453,9 @@ ALC_API ALCcontext* ALC_APIENTRY alcCreateContext(ALCdevice *device, const ALCin
} }
} }
InitContext(ALContext); InitContext(ALContext.get());
ALfloat valf{};
if(ConfigValueFloat(dev->DeviceName.c_str(), nullptr, "volume-adjust", &valf)) if(ConfigValueFloat(dev->DeviceName.c_str(), nullptr, "volume-adjust", &valf))
{ {
if(!std::isfinite(valf)) if(!std::isfinite(valf))
@ -3474,26 +3469,27 @@ ALC_API ALCcontext* ALC_APIENTRY alcCreateContext(ALCdevice *device, const ALCin
TRACE("volume-adjust gain: %f\n", ALContext->GainBoost); TRACE("volume-adjust gain: %f\n", ALContext->GainBoost);
} }
} }
UpdateListenerProps(ALContext); UpdateListenerProps(ALContext.get());
{ {
ALCcontext *head = dev->ContextList.load(); ALCcontext *head = dev->ContextList.load();
do { do {
ALContext->next.store(head, std::memory_order_relaxed); ALContext->next.store(head, std::memory_order_relaxed);
} while(!dev->ContextList.compare_exchange_weak(head, ALContext)); } while(!dev->ContextList.compare_exchange_weak(head, ALContext.get()));
ALCcontext_IncRef(ALContext.get());
} }
statelock.unlock(); statelock.unlock();
if(ALContext->DefaultSlot) if(ALContext->DefaultSlot)
{ {
if(InitializeEffect(ALContext, ALContext->DefaultSlot.get(), &DefaultEffect) == AL_NO_ERROR) if(InitializeEffect(ALContext.get(), ALContext->DefaultSlot.get(), &DefaultEffect) == AL_NO_ERROR)
UpdateEffectSlotProps(ALContext->DefaultSlot.get(), ALContext); UpdateEffectSlotProps(ALContext->DefaultSlot.get(), ALContext.get());
else else
ERR("Failed to initialize the default effect\n"); ERR("Failed to initialize the default effect\n");
} }
TRACE("Created context %p\n", ALContext); TRACE("Created context %p\n", ALContext.get());
return ALContext; return ALContext.get();
} }
/* alcDestroyContext /* alcDestroyContext
@ -3648,7 +3644,7 @@ ALC_API ALCdevice* ALC_APIENTRY alcOpenDevice(const ALCchar *deviceName)
)) ))
deviceName = nullptr; deviceName = nullptr;
auto device = al::make_unique<ALCdevice>(Playback); DeviceRef device{new ALCdevice{Playback}};
//Set output format //Set output format
device->FmtChans = DevFmtChannelsDefault; device->FmtChans = DevFmtChannelsDefault;
@ -3763,7 +3759,6 @@ ALC_API ALCdevice* ALC_APIENTRY alcOpenDevice(const ALCchar *deviceName)
BackendType::Playback); BackendType::Playback);
if(!device->Backend) if(!device->Backend)
{ {
device = nullptr;
alcSetError(nullptr, ALC_OUT_OF_MEMORY); alcSetError(nullptr, ALC_OUT_OF_MEMORY);
return nullptr; return nullptr;
} }
@ -3772,7 +3767,6 @@ ALC_API ALCdevice* ALC_APIENTRY alcOpenDevice(const ALCchar *deviceName)
ALCenum err{device->Backend->open(deviceName)}; ALCenum err{device->Backend->open(deviceName)};
if(err != ALC_NO_ERROR) if(err != ALC_NO_ERROR)
{ {
device = nullptr;
alcSetError(nullptr, err); alcSetError(nullptr, err);
return nullptr; return nullptr;
} }
@ -3813,10 +3807,11 @@ ALC_API ALCdevice* ALC_APIENTRY alcOpenDevice(const ALCchar *deviceName)
do { do {
device->next.store(head, std::memory_order_relaxed); device->next.store(head, std::memory_order_relaxed);
} while(!DeviceList.compare_exchange_weak(head, device.get())); } while(!DeviceList.compare_exchange_weak(head, device.get()));
ALCdevice_IncRef(device.get());
} }
TRACE("Created device %p, \"%s\"\n", device.get(), device->DeviceName.c_str()); TRACE("Created device %p, \"%s\"\n", device.get(), device->DeviceName.c_str());
return device.release(); return device.get();
} }
/* alcCloseDevice /* alcCloseDevice
@ -3892,14 +3887,13 @@ ALC_API ALCdevice* ALC_APIENTRY alcCaptureOpenDevice(const ALCchar *deviceName,
if(deviceName && (!deviceName[0] || strcasecmp(deviceName, alcDefaultName) == 0 || strcasecmp(deviceName, "openal-soft") == 0)) if(deviceName && (!deviceName[0] || strcasecmp(deviceName, alcDefaultName) == 0 || strcasecmp(deviceName, "openal-soft") == 0))
deviceName = nullptr; deviceName = nullptr;
auto device = al::make_unique<ALCdevice>(Capture); DeviceRef device{new ALCdevice{Capture}};
device->Frequency = frequency; device->Frequency = frequency;
device->Flags |= DEVICE_FREQUENCY_REQUEST; device->Flags |= DEVICE_FREQUENCY_REQUEST;
if(DecomposeDevFormat(format, &device->FmtChans, &device->FmtType) == AL_FALSE) if(DecomposeDevFormat(format, &device->FmtChans, &device->FmtType) == AL_FALSE)
{ {
device = nullptr;
alcSetError(nullptr, ALC_INVALID_ENUM); alcSetError(nullptr, ALC_INVALID_ENUM);
return nullptr; return nullptr;
} }
@ -3912,7 +3906,6 @@ ALC_API ALCdevice* ALC_APIENTRY alcCaptureOpenDevice(const ALCchar *deviceName,
BackendType::Capture); BackendType::Capture);
if(!device->Backend) if(!device->Backend)
{ {
device = nullptr;
alcSetError(nullptr, ALC_OUT_OF_MEMORY); alcSetError(nullptr, ALC_OUT_OF_MEMORY);
return nullptr; return nullptr;
} }
@ -3924,7 +3917,6 @@ ALC_API ALCdevice* ALC_APIENTRY alcCaptureOpenDevice(const ALCchar *deviceName,
ALCenum err{device->Backend->open(deviceName)}; ALCenum err{device->Backend->open(deviceName)};
if(err != ALC_NO_ERROR) if(err != ALC_NO_ERROR)
{ {
device = nullptr;
alcSetError(nullptr, err); alcSetError(nullptr, err);
return nullptr; return nullptr;
} }
@ -3934,10 +3926,11 @@ ALC_API ALCdevice* ALC_APIENTRY alcCaptureOpenDevice(const ALCchar *deviceName,
do { do {
device->next.store(head, std::memory_order_relaxed); device->next.store(head, std::memory_order_relaxed);
} while(!DeviceList.compare_exchange_weak(head, device.get())); } while(!DeviceList.compare_exchange_weak(head, device.get()));
ALCdevice_IncRef(device.get());
} }
TRACE("Created device %p, \"%s\"\n", device.get(), device->DeviceName.c_str()); TRACE("Created device %p, \"%s\"\n", device.get(), device->DeviceName.c_str());
return device.release(); return device.get();
} }
ALC_API ALCboolean ALC_APIENTRY alcCaptureCloseDevice(ALCdevice *device) ALC_API ALCboolean ALC_APIENTRY alcCaptureCloseDevice(ALCdevice *device)
@ -4056,7 +4049,7 @@ ALC_API ALCdevice* ALC_APIENTRY alcLoopbackOpenDeviceSOFT(const ALCchar *deviceN
return nullptr; return nullptr;
} }
auto device = al::make_unique<ALCdevice>(Loopback); DeviceRef device{new ALCdevice{Loopback}};
device->SourcesMax = 256; device->SourcesMax = 256;
device->AuxiliaryEffectSlotMax = 64; device->AuxiliaryEffectSlotMax = 64;
@ -4089,7 +4082,6 @@ ALC_API ALCdevice* ALC_APIENTRY alcLoopbackOpenDeviceSOFT(const ALCchar *deviceN
BackendType::Playback); BackendType::Playback);
if(!device->Backend) if(!device->Backend)
{ {
device = nullptr;
alcSetError(nullptr, ALC_OUT_OF_MEMORY); alcSetError(nullptr, ALC_OUT_OF_MEMORY);
return nullptr; return nullptr;
} }
@ -4102,10 +4094,11 @@ ALC_API ALCdevice* ALC_APIENTRY alcLoopbackOpenDeviceSOFT(const ALCchar *deviceN
do { do {
device->next.store(head, std::memory_order_relaxed); device->next.store(head, std::memory_order_relaxed);
} while(!DeviceList.compare_exchange_weak(head, device.get())); } while(!DeviceList.compare_exchange_weak(head, device.get()));
ALCdevice_IncRef(device.get());
} }
TRACE("Created device %p\n", device.get()); TRACE("Created device %p\n", device.get());
return device.release(); return device.get();
} }
/* alcIsRenderFormatSupportedSOFT /* alcIsRenderFormatSupportedSOFT