diff options
author | Chris Robinson <[email protected]> | 2017-04-06 13:00:29 -0700 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2017-04-06 13:00:29 -0700 |
commit | 338d61f9072bfb811266012c2a9c0a290cf353d1 (patch) | |
tree | 0ef0b218db261569105a782824c5bf50ea3a3067 /Alc/ALc.c | |
parent | 94f514ae5a0392f5f01f2b479d1d858af688ae24 (diff) |
Reference count HRTFs and unload them when unused
Diffstat (limited to 'Alc/ALc.c')
-rw-r--r-- | Alc/ALc.c | 11 |
1 files changed, 10 insertions, 1 deletions
@@ -2049,7 +2049,7 @@ static ALCenum UpdateDeviceParams(ALCdevice *device, const ALCint *attrList) if(hrtf_userreq == Hrtf_Enable || (hrtf_userreq != Hrtf_Disable && hrtf_appreq == Hrtf_Enable)) { - const struct Hrtf *hrtf = NULL; + struct Hrtf *hrtf = NULL; if(VECTOR_SIZE(device->HrtfList) == 0) { VECTOR_DEINIT(device->HrtfList); @@ -2068,6 +2068,9 @@ static ALCenum UpdateDeviceParams(ALCdevice *device, const ALCint *attrList) device->FmtChans = DevFmtStereo; device->Frequency = hrtf->sampleRate; device->Flags |= DEVICE_CHANNELS_REQUEST | DEVICE_FREQUENCY_REQUEST; + if(device->HrtfHandle) + Hrtf_DecRef(device->HrtfHandle); + device->HrtfHandle = hrtf; } else { @@ -2338,6 +2341,9 @@ static ALCvoid FreeDevice(ALCdevice *device) AL_STRING_DEINIT(device->HrtfName); FreeHrtfList(&device->HrtfList); + if(device->HrtfHandle) + Hrtf_DecRef(device->HrtfHandle); + device->HrtfHandle = NULL; al_free(device->Hrtf); device->Hrtf = NULL; @@ -3755,6 +3761,7 @@ ALC_API ALCdevice* ALC_APIENTRY alcOpenDevice(const ALCchar *deviceName) device->Bs2b = NULL; device->Uhj_Encoder = NULL; device->Hrtf = NULL; + device->HrtfHandle = NULL; VECTOR_INIT(device->HrtfList); AL_STRING_INIT(device->HrtfName); device->Render_Mode = NormalRender; @@ -4062,6 +4069,7 @@ ALC_API ALCdevice* ALC_APIENTRY alcCaptureOpenDevice(const ALCchar *deviceName, device->Type = Capture; device->Hrtf = NULL; + device->HrtfHandle = NULL; VECTOR_INIT(device->HrtfList); AL_STRING_INIT(device->HrtfName); @@ -4272,6 +4280,7 @@ ALC_API ALCdevice* ALC_APIENTRY alcLoopbackOpenDeviceSOFT(const ALCchar *deviceN device->Flags = 0; device->Hrtf = NULL; + device->HrtfHandle = NULL; VECTOR_INIT(device->HrtfList); AL_STRING_INIT(device->HrtfName); device->Bs2b = NULL; |