aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Alc/ALc.c7
-rw-r--r--Alc/panning.cpp25
-rw-r--r--OpenAL32/Include/alMain.h2
3 files changed, 23 insertions, 11 deletions
diff --git a/Alc/ALc.c b/Alc/ALc.c
index a483c94f..fc68236d 100644
--- a/Alc/ALc.c
+++ b/Alc/ALc.c
@@ -2429,7 +2429,7 @@ static void InitDevice(ALCdevice *device, enum DeviceType type)
device->ChannelDelay[i].Buffer = NULL;
}
- AL_STRING_INIT(device->HrtfName);
+ device->HrtfName = NULL;
VECTOR_INIT(device->HrtfList);
device->HrtfHandle = NULL;
device->Hrtf = NULL;
@@ -2493,7 +2493,8 @@ static ALCvoid FreeDevice(ALCdevice *device)
VECTOR_DEINIT(device->FilterList);
almtx_destroy(&device->FilterLock);
- AL_STRING_DEINIT(device->HrtfName);
+ al_free(device->HrtfName);
+ device->HrtfName = NULL;
FreeHrtfList(&device->HrtfList);
if(device->HrtfHandle)
Hrtf_DecRef(device->HrtfHandle);
@@ -3190,7 +3191,7 @@ ALC_API const ALCchar* ALC_APIENTRY alcGetString(ALCdevice *Device, ALCenum para
else
{
almtx_lock(&Device->BackendLock);
- value = (Device->HrtfHandle ? alstr_get_cstr(Device->HrtfName) : "");
+ value = ((Device->HrtfHandle && Device->HrtfName) ? Device->HrtfName : "");
almtx_unlock(&Device->BackendLock);
ALCdevice_DecRef(Device);
}
diff --git a/Alc/panning.cpp b/Alc/panning.cpp
index db476884..e39abab9 100644
--- a/Alc/panning.cpp
+++ b/Alc/panning.cpp
@@ -38,7 +38,9 @@
#include "bs2b.h"
-static const ALsizei FuMa2ACN[MAX_AMBI_COEFFS] = {
+namespace {
+
+constexpr ALsizei FuMa2ACN[MAX_AMBI_COEFFS] = {
0, /* W */
3, /* X */
1, /* Y */
@@ -56,11 +58,20 @@ static const ALsizei FuMa2ACN[MAX_AMBI_COEFFS] = {
15, /* P */
9, /* Q */
};
-static const ALsizei ACN2ACN[MAX_AMBI_COEFFS] = {
+constexpr ALsizei ACN2ACN[MAX_AMBI_COEFFS] = {
0, 1, 2, 3, 4, 5, 6, 7,
8, 9, 10, 11, 12, 13, 14, 15
};
+char *alstrdup(const_al_string str)
+{
+ const size_t len{alstr_length(str)};
+ char *ret{static_cast<char*>(al_calloc(DEF_ALIGN, len+1))};
+ memcpy(ret, alstr_get_cstr(str), len);
+ return ret;
+}
+
+} // namespace
void CalcAmbiCoeffs(const ALfloat y, const ALfloat z, const ALfloat x, const ALfloat spread,
ALfloat coeffs[MAX_AMBI_COEFFS])
@@ -931,7 +942,8 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf
al_free(device->Hrtf);
device->Hrtf = NULL;
device->HrtfHandle = NULL;
- alstr_clear(&device->HrtfName);
+ al_free(device->HrtfName);
+ device->HrtfName = NULL;
device->Render_Mode = NormalRender;
memset(&device->Dry.Ambi, 0, sizeof(device->Dry.Ambi));
@@ -1114,7 +1126,7 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf
if(hrtf && hrtf->sampleRate == device->Frequency)
{
device->HrtfHandle = hrtf;
- alstr_copy(&device->HrtfName, entry->name);
+ device->HrtfName = alstrdup(entry->name);
}
else if(hrtf)
Hrtf_DecRef(hrtf);
@@ -1127,7 +1139,7 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf
if(hrtf && hrtf->sampleRate == device->Frequency)
{
device->HrtfHandle = hrtf;
- alstr_copy(&device->HrtfName, entry->name);
+ device->HrtfName = alstrdup(entry->name);
}
else if(hrtf)
Hrtf_DecRef(hrtf);
@@ -1164,8 +1176,7 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf
}
TRACE("%s HRTF rendering enabled, using \"%s\"\n",
- ((device->Render_Mode == HrtfRender) ? "Full" : "Basic"),
- alstr_get_cstr(device->HrtfName)
+ ((device->Render_Mode == HrtfRender) ? "Full" : "Basic"), device->HrtfName
);
InitHrtfPanning(device);
return;
diff --git a/OpenAL32/Include/alMain.h b/OpenAL32/Include/alMain.h
index 9826c6b2..03d07c0d 100644
--- a/OpenAL32/Include/alMain.h
+++ b/OpenAL32/Include/alMain.h
@@ -656,7 +656,7 @@ struct ALCdevice_struct {
/* HRTF state and info */
struct DirectHrtfState *Hrtf;
- al_string HrtfName;
+ char *HrtfName;
struct Hrtf *HrtfHandle;
vector_EnumeratedHrtf HrtfList;
ALCenum HrtfStatus;