git: d209d2416ffa - main - audio/openal-soft: Update to 1.23.1

From: Jason E. Hale <jhale_at_FreeBSD.org>
Date: Mon, 09 Sep 2024 09:15:43 UTC
The branch main has been updated by jhale:

URL: https://cgit.FreeBSD.org/ports/commit/?id=d209d2416ffa544abf5a2fcf36b963ed40b88265

commit d209d2416ffa544abf5a2fcf36b963ed40b88265
Author:     Jason E. Hale <jhale@FreeBSD.org>
AuthorDate: 2024-09-09 04:34:05 +0000
Commit:     Jason E. Hale <jhale@FreeBSD.org>
CommitDate: 2024-09-09 09:15:25 +0000

    audio/openal-soft: Update to 1.23.1
    
    Add PIPEWIRE and SIMD options.
    
    Add checks to disable CPU instruction sets that are opt-out by default
    and only consider the host builder. For example, disable SSE4.1 on an
    amd64 host building for an i386 target. Additional instruction sets can
    be enabled by setting CPUTYPE appropriately in /etc/make.conf or in its
    poudriere(8) counterpart.
---
 audio/openal-soft/Makefile                         |  50 ++-
 audio/openal-soft/distinfo                         |   8 +-
 .../openal-soft/files/patch-alc_backends_sndio.cpp | 447 ---------------------
 audio/openal-soft/pkg-plist                        |   4 +-
 4 files changed, 46 insertions(+), 463 deletions(-)

diff --git a/audio/openal-soft/Makefile b/audio/openal-soft/Makefile
index 976a38e7d926..be5dd2b36be0 100644
--- a/audio/openal-soft/Makefile
+++ b/audio/openal-soft/Makefile
@@ -1,12 +1,8 @@
 PORTNAME=	openal-soft
-PORTVERSION=	1.21.1
-PORTREVISION=	4
+PORTVERSION=	1.23.1
 CATEGORIES=	audio
 MASTER_SITES=	https://openal-soft.org/openal-releases/
 
-PATCH_SITES=	https://github.com/kcat/${PORTNAME}/commit/
-PATCHFILES+=	440b59704c82684786bf7e251b4882f2a12c4c06.patch:-p1
-
 MAINTAINER=	multimedia@FreeBSD.org
 COMMENT=	Software implementation of the OpenAL specification
 WWW=		https://openal-soft.org/
@@ -14,13 +10,15 @@ WWW=		https://openal-soft.org/
 LICENSE=	LGPL20+
 LICENSE_FILE=	${WRKSRC}/COPYING
 
-USES=		cmake compiler:c++14-lang tar:bzip2
+LIB_DEPENDS=	libdbus-1.so:devel/dbus
+
+USES=		cmake compiler:c++14-lang pkgconfig tar:bzip2
 USE_LDCONFIG=	yes
 
 CMAKE_ARGS=	-DCMAKE_INSTALL_DATADIR:STRING="${PREFIX}/etc"
+CMAKE_ON=	ALSOFT_BACKEND_WAVE
 CMAKE_OFF=	ALSOFT_BACKEND_ALSA ALSOFT_DLOPEN ALSOFT_EXAMPLES \
 		ALSOFT_REQUIRE_QSA ALSOFT_REQUIRE_SOLARIS
-CMAKE_ON=	ALSOFT_BACKEND_WAVE
 
 # do not link with librt and libdl.
 LDFLAGS+=	-Wl,--as-needed
@@ -28,9 +26,16 @@ LDFLAGS_i386=	-Wl,-z,notext
 
 PLIST_SUB=	SOVERSION=${PORTVERSION}
 
-OPTIONS_DEFINE=		CONFIG EXAMPLES JACK OSS PORTAUDIO PULSEAUDIO \
-			SDL SNDIO UTILS
+OPTIONS_DEFINE=		CONFIG EXAMPLES JACK OSS PIPEWIRE PORTAUDIO \
+			PULSEAUDIO SDL SNDIO UTILS
+OPTIONS_DEFINE_aarch64=	SIMD
+OPTIONS_DEFINE_amd64=	SIMD
+OPTIONS_DEFINE_i386=	SIMD
 OPTIONS_DEFAULT=	OSS UTILS
+OPTIONS_DEFAULT_aarch64=SIMD
+OPTIONS_DEFAULT_amd64=	SIMD
+OPTIONS_DEFAULT_i386=	SIMD
+
 OPTIONS_SUB=		yes
 
 CONFIG_DESC=	Install configuration utility (needs Qt 5)
@@ -46,13 +51,17 @@ JACK_CMAKE_BOOL=	ALSOFT_BACKEND_JACK ALSOFT_REQUIRE_JACK
 
 OSS_CMAKE_BOOL=	ALSOFT_BACKEND_OSS ALSOFT_REQUIRE_OSS
 
+PIPEWIRE_LIB_DEPENDS=	libpipewire-0.3.so:multimedia/pipewire
+PIPEWIRE_USES=		localbase:ldflags
+PIPEWIRE_CMAKE_BOOL=	ALSOFT_BACKEND_PIPEWIRE ALSOFT_REQUIRE_PIPEWIRE
+
 PORTAUDIO_LIB_DEPENDS=	libportaudio.so:audio/portaudio
 PORTAUDIO_CMAKE_BOOL=	ALSOFT_BACKEND_PORTAUDIO ALSOFT_REQUIRE_PORTAUDIO
 
 PULSEAUDIO_LIB_DEPENDS=	libpulse.so:audio/pulseaudio
 PULSEAUDIO_CMAKE_BOOL=	ALSOFT_BACKEND_PULSEAUDIO ALSOFT_REQUIRE_PULSEAUDIO
 
-SDL_USES=	localbase sdl
+SDL_USES=	sdl
 SDL_USE=	SDL=sdl2
 SDL_CMAKE_BOOL=	ALSOFT_BACKEND_SDL2 ALSOFT_REQUIRE_SDL2
 
@@ -64,6 +73,27 @@ UTILS_CMAKE_BOOL=	ALSOFT_UTILS
 
 .include <bsd.port.pre.mk>
 
+.if ${PORT_OPTIONS:MSIMD}
+.  if !${MACHINE_CPU:Msse}
+CMAKE_OFF+=	ALSOFT_CPUEXT_SSE
+.  endif
+.  if !${MACHINE_CPU:Msse2}
+CMAKE_OFF+=	ALSOFT_CPUEXT_SSE2
+.  endif
+.  if !${MACHINE_CPU:Msse3}
+CMAKE_OFF+=	ALSOFT_CPUEXT_SSE3
+.  endif
+.  if !${MACHINE_CPU:Msse41}
+CMAKE_OFF+=	ALSOFT_CPUEXT_SSE4_1
+.  endif
+.else
+CMAKE_OFF+=	ALSOFT_CPUEXT_NEON \
+		ALSOFT_CPUEXT_SSE \
+		ALSOFT_CPUEXT_SSE2 \
+		ALSOFT_CPUEXT_SSE3 \
+		ALSOFT_CPUEXT_SSE4_1
+.endif
+
 # The following is actually meant for lld 15.0 and later, but the ports
 # framework does not support LINKER_TYPE and LINKER_VERSION yet.
 .if ${COMPILER_TYPE} == "clang"
diff --git a/audio/openal-soft/distinfo b/audio/openal-soft/distinfo
index bc9ba9b48fc3..fb737cc2c331 100644
--- a/audio/openal-soft/distinfo
+++ b/audio/openal-soft/distinfo
@@ -1,5 +1,3 @@
-TIMESTAMP = 1723055526
-SHA256 (openal-soft-1.21.1.tar.bz2) = c8ad767e9a3230df66756a21cc8ebf218a9d47288f2514014832204e666af5d8
-SIZE (openal-soft-1.21.1.tar.bz2) = 524787
-SHA256 (440b59704c82684786bf7e251b4882f2a12c4c06.patch) = f2b5b7f307aa561e7b63ace43072c8a7cfaff74b6d67c260ee9ad848ea51f2d2
-SIZE (440b59704c82684786bf7e251b4882f2a12c4c06.patch) = 896
+TIMESTAMP = 1725772642
+SHA256 (openal-soft-1.23.1.tar.bz2) = 796f4b89134c4e57270b7f0d755f0fa3435b90da437b745160a49bd41c845b21
+SIZE (openal-soft-1.23.1.tar.bz2) = 699330
diff --git a/audio/openal-soft/files/patch-alc_backends_sndio.cpp b/audio/openal-soft/files/patch-alc_backends_sndio.cpp
deleted file mode 100644
index ca168aebdff5..000000000000
--- a/audio/openal-soft/files/patch-alc_backends_sndio.cpp
+++ /dev/null
@@ -1,447 +0,0 @@
---- alc/backends/sndio.cpp.orig	2021-02-04 19:09:06 UTC
-+++ alc/backends/sndio.cpp
-@@ -22,6 +22,7 @@
- 
- #include "backends/sndio.h"
- 
-+#include <poll.h>
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
-@@ -43,7 +44,12 @@ namespace {
- 
- static const char sndio_device[] = "SndIO Default";
- 
-+struct SioPar : public sio_par {
-+    SioPar() { sio_initpar(this); }
- 
-+    void clear() { sio_initpar(this); }
-+};
-+
- struct SndioPlayback final : public BackendBase {
-     SndioPlayback(ALCdevice *device) noexcept : BackendBase{device} { }
-     ~SndioPlayback() override;
-@@ -56,6 +62,7 @@ struct SndioPlayback final : public BackendBase {
-     void stop() override;
- 
-     sio_hdl *mSndHandle{nullptr};
-+    uint mFrameStep{};
- 
-     al::vector<al::byte> mBuffer;
- 
-@@ -74,39 +81,29 @@ SndioPlayback::~SndioPlayback()
- 
- int SndioPlayback::mixerProc()
- {
--    sio_par par;
--    sio_initpar(&par);
--    if(!sio_getpar(mSndHandle, &par))
--    {
--        mDevice->handleDisconnect("Failed to get device parameters");
--        return 1;
--    }
-+    const size_t frameStep{mFrameStep};
-+    const size_t frameSize{frameStep * mDevice->bytesFromFmt()};
- 
--    const size_t frameStep{par.pchan};
--    const size_t frameSize{frameStep * par.bps};
--
-     SetRTPriority();
-     althrd_setname(MIXER_THREAD_NAME);
- 
-     while(!mKillNow.load(std::memory_order_acquire)
-         && mDevice->Connected.load(std::memory_order_acquire))
-     {
--        al::byte *WritePtr{mBuffer.data()};
--        size_t len{mBuffer.size()};
-+        al::span<al::byte> buffer{mBuffer};
- 
--        mDevice->renderSamples(WritePtr, static_cast<uint>(len/frameSize), frameStep);
--        while(len > 0 && !mKillNow.load(std::memory_order_acquire))
-+        mDevice->renderSamples(buffer.data(), static_cast<uint>(buffer.size() / frameSize),
-+            frameStep);
-+        while(!buffer.empty() && !mKillNow.load(std::memory_order_acquire))
-         {
--            size_t wrote{sio_write(mSndHandle, WritePtr, len)};
-+            size_t wrote{sio_write(mSndHandle, buffer.data(), buffer.size())};
-             if(wrote == 0)
-             {
-                 ERR("sio_write failed\n");
-                 mDevice->handleDisconnect("Failed to write playback samples");
-                 break;
-             }
--
--            len -= wrote;
--            WritePtr += wrote;
-+            buffer = buffer.subspan(wrote);
-         }
-     }
- 
-@@ -131,26 +128,12 @@ void SndioPlayback::open(const char *name)
- 
- bool SndioPlayback::reset()
- {
--    sio_par par;
--    sio_initpar(&par);
-+    SioPar par;
- 
--    par.rate = mDevice->Frequency;
--    switch(mDevice->FmtChans)
-+    auto tryfmt = mDevice->FmtType;
-+retry_params:
-+    switch(tryfmt)
-     {
--    case DevFmtMono   : par.pchan = 1; break;
--    case DevFmtQuad   : par.pchan = 4; break;
--    case DevFmtX51Rear: // fall-through - "Similar to 5.1, except using rear channels instead of sides"
--    case DevFmtX51    : par.pchan = 6; break;
--    case DevFmtX61    : par.pchan = 7; break;
--    case DevFmtX71    : par.pchan = 8; break;
--
--    // fall back to stereo for Ambi3D
--    case DevFmtAmbi3D : // fall-through
--    case DevFmtStereo : par.pchan = 2; break;
--    }
--
--    switch(mDevice->FmtType)
--    {
-     case DevFmtByte:
-         par.bits = 8;
-         par.sig = 1;
-@@ -159,7 +142,6 @@ bool SndioPlayback::reset()
-         par.bits = 8;
-         par.sig = 0;
-         break;
--    case DevFmtFloat:
-     case DevFmtShort:
-         par.bits = 16;
-         par.sig = 1;
-@@ -168,6 +150,7 @@ bool SndioPlayback::reset()
-         par.bits = 16;
-         par.sig = 0;
-         break;
-+    case DevFmtFloat:
-     case DevFmtInt:
-         par.bits = 32;
-         par.sig = 1;
-@@ -177,70 +160,64 @@ bool SndioPlayback::reset()
-         par.sig = 0;
-         break;
-     }
-+    par.bps = SIO_BPS(par.bits);
-     par.le = SIO_LE_NATIVE;
-+    par.msb = 1;
- 
-+    par.rate = mDevice->Frequency;
-+    par.pchan = mDevice->channelsFromFmt();
-+
-     par.round = mDevice->UpdateSize;
-     par.appbufsz = mDevice->BufferSize - mDevice->UpdateSize;
-     if(!par.appbufsz) par.appbufsz = mDevice->UpdateSize;
- 
--    if(!sio_setpar(mSndHandle, &par) || !sio_getpar(mSndHandle, &par))
--    {
--        ERR("Failed to set device parameters\n");
--        return false;
--    }
-+    try {
-+        if(!sio_setpar(mSndHandle, &par))
-+            throw al::backend_exception{al::backend_error::DeviceError,
-+                "Failed to set device parameters"};
- 
--    if(par.bits != par.bps*8)
--    {
--        ERR("Padded samples not supported (%u of %u bits)\n", par.bits, par.bps*8);
--        return false;
--    }
--    if(par.le != SIO_LE_NATIVE)
--    {
--        ERR("Non-native-endian samples not supported (got %s-endian)\n",
--            par.le ? "little" : "big");
--        return false;
--    }
-+        par.clear();
-+        if(!sio_getpar(mSndHandle, &par))
-+            throw al::backend_exception{al::backend_error::DeviceError,
-+                "Failed to get device parameters"};
- 
--    mDevice->Frequency = par.rate;
--
--    if(par.pchan < 2)
--    {
--        if(mDevice->FmtChans != DevFmtMono)
--        {
--            WARN("Got %u channel for %s\n", par.pchan, DevFmtChannelsString(mDevice->FmtChans));
--            mDevice->FmtChans = DevFmtMono;
--        }
-+        if(par.bps > 1 && par.le != SIO_LE_NATIVE)
-+            throw al::backend_exception{al::backend_error::DeviceError,
-+                "%s-endian samples not supported", par.le ? "Little" : "Big"};
-+        if(par.bits < par.bps*8 && !par.msb)
-+            throw al::backend_exception{al::backend_error::DeviceError,
-+                "MSB-padded samples not supported (%u of %u bits)", par.bits, par.bps*8};
-+        if(par.pchan < 1)
-+            throw al::backend_exception{al::backend_error::DeviceError,
-+                "No playback channels on device"};
-     }
--    else if((par.pchan == 2 && mDevice->FmtChans != DevFmtStereo)
--        || par.pchan == 3
--        || (par.pchan == 4 && mDevice->FmtChans != DevFmtQuad)
--        || par.pchan == 5
--        || (par.pchan == 6 && mDevice->FmtChans != DevFmtX51 && mDevice->FmtChans != DevFmtX51Rear)
--        || (par.pchan == 7 && mDevice->FmtChans != DevFmtX61)
--        || (par.pchan == 8 && mDevice->FmtChans != DevFmtX71)
--        || par.pchan > 8)
--    {
--        WARN("Got %u channels for %s\n", par.pchan, DevFmtChannelsString(mDevice->FmtChans));
--        mDevice->FmtChans = DevFmtStereo;
-+    catch(al::backend_exception &e) {
-+        if(tryfmt == DevFmtShort)
-+            throw;
-+        par.clear();
-+        tryfmt = DevFmtShort;
-+        goto retry_params;
-     }
- 
--    if(par.bits == 8 && par.sig == 1)
--        mDevice->FmtType = DevFmtByte;
--    else if(par.bits == 8 && par.sig == 0)
--        mDevice->FmtType = DevFmtUByte;
--    else if(par.bits == 16 && par.sig == 1)
--        mDevice->FmtType = DevFmtShort;
--    else if(par.bits == 16 && par.sig == 0)
--        mDevice->FmtType = DevFmtUShort;
--    else if(par.bits == 32 && par.sig == 1)
--        mDevice->FmtType = DevFmtInt;
--    else if(par.bits == 32 && par.sig == 0)
--        mDevice->FmtType = DevFmtUInt;
-+    if(par.bps == 1)
-+        mDevice->FmtType = (par.sig==1) ? DevFmtByte : DevFmtUByte;
-+    else if(par.bps == 2)
-+        mDevice->FmtType = (par.sig==1) ? DevFmtShort : DevFmtUShort;
-+    else if(par.bps == 4)
-+        mDevice->FmtType = (par.sig==1) ? DevFmtInt : DevFmtUInt;
-     else
-+        throw al::backend_exception{al::backend_error::DeviceError,
-+            "Unhandled sample format: %s %u-bit", (par.sig?"signed":"unsigned"), par.bps*8};
-+
-+    mFrameStep = par.pchan;
-+    if(par.pchan != mDevice->channelsFromFmt())
-     {
--        ERR("Unhandled sample format: %s %u-bit\n", (par.sig?"signed":"unsigned"), par.bits);
--        return false;
-+        WARN("Got %u channel%s for %s\n", par.pchan, (par.pchan==1)?"":"s",
-+            DevFmtChannelsString(mDevice->FmtChans));
-+        if(par.pchan < 2) mDevice->FmtChans = DevFmtMono;
-+        else mDevice->FmtChans = DevFmtStereo;
-     }
-+    mDevice->Frequency = par.rate;
- 
-     setDefaultChannelOrder();
- 
-@@ -287,6 +264,11 @@ void SndioPlayback::stop()
- }
- 
- 
-+/* TODO: This could be improved by avoiding the ring buffer and record thread,
-+ * counting the available samples with the sio_onmove callback and reading
-+ * directly from the device. However, this depends on reasonable support for
-+ * capture buffer sizes apps may request.
-+ */
- struct SndioCapture final : public BackendBase {
-     SndioCapture(ALCdevice *device) noexcept : BackendBase{device} { }
-     ~SndioCapture() override;
-@@ -323,40 +305,65 @@ int SndioCapture::recordProc()
- 
-     const uint frameSize{mDevice->frameSizeFromFmt()};
- 
-+    int nfds_pre{sio_nfds(mSndHandle)};
-+    if(nfds_pre <= 0)
-+    {
-+        mDevice->handleDisconnect("Incorrect return value from sio_nfds(): %d", nfds_pre);
-+        return 1;
-+    }
-+
-+    auto fds = std::make_unique<pollfd[]>(static_cast<uint>(nfds_pre));
-+
-     while(!mKillNow.load(std::memory_order_acquire)
-         && mDevice->Connected.load(std::memory_order_acquire))
-     {
--        auto data = mRing->getWriteVector();
--        size_t todo{data.first.len + data.second.len};
--        if(todo == 0)
-+        /* Wait until there's some samples to read. */
-+        const int nfds{sio_pollfd(mSndHandle, fds.get(), POLLIN)};
-+        if(nfds <= 0)
-         {
--            static char junk[4096];
--            sio_read(mSndHandle, junk,
--                minz(sizeof(junk)/frameSize, mDevice->UpdateSize)*frameSize);
-+            mDevice->handleDisconnect("Failed to get polling fds: %d", nfds);
-+            break;
-+        }
-+        int pollres{::poll(fds.get(), static_cast<uint>(nfds), 2000)};
-+        if(pollres < 0)
-+        {
-+            if(errno == EINTR) continue;
-+            mDevice->handleDisconnect("Poll error: %s", strerror(errno));
-+            break;
-+        }
-+        if(pollres == 0)
-             continue;
-+
-+        const int revents{sio_revents(mSndHandle, fds.get())};
-+        if((revents&POLLHUP))
-+        {
-+            mDevice->handleDisconnect("Got POLLHUP from poll events");
-+            break;
-         }
-+        if(!(revents&POLLIN))
-+            continue;
- 
--        size_t total{0u};
--        data.first.len  *= frameSize;
--        data.second.len *= frameSize;
--        todo = minz(todo, mDevice->UpdateSize) * frameSize;
--        while(total < todo)
-+        auto data = mRing->getWriteVector();
-+        al::span<al::byte> buffer{data.first.buf, data.first.len*frameSize};
-+        while(!buffer.empty())
-         {
--            if(!data.first.len)
--                data.first = data.second;
-+            size_t got{sio_read(mSndHandle, buffer.data(), buffer.size())};
-+            if(got == 0) break;
- 
--            size_t got{sio_read(mSndHandle, data.first.buf, minz(todo-total, data.first.len))};
--            if(!got)
-+            mRing->writeAdvance(got / frameSize);
-+            buffer = buffer.subspan(got);
-+            if(buffer.empty())
-             {
--                mDevice->handleDisconnect("Failed to read capture samples");
--                break;
-+                data = mRing->getWriteVector();
-+                buffer = {data.first.buf, data.first.len*frameSize};
-             }
--
--            data.first.buf += got;
--            data.first.len -= got;
--            total += got;
-         }
--        mRing->writeAdvance(total / frameSize);
-+        if(buffer.empty())
-+        {
-+            /* Got samples to read, but no place to store it. Drop it. */
-+            static char junk[4096];
-+            sio_read(mSndHandle, junk, sizeof(junk) - (sizeof(junk)%frameSize));
-+        }
-     }
- 
-     return 0;
-@@ -371,76 +378,80 @@ void SndioCapture::open(const char *name)
-         throw al::backend_exception{al::backend_error::NoDevice, "Device name \"%s\" not found",
-             name};
- 
--    mSndHandle = sio_open(nullptr, SIO_REC, 0);
-+    mSndHandle = sio_open(nullptr, SIO_REC, true);
-     if(mSndHandle == nullptr)
-         throw al::backend_exception{al::backend_error::NoDevice, "Could not open backend device"};
- 
--    sio_par par;
--    sio_initpar(&par);
--
-+    SioPar par;
-     switch(mDevice->FmtType)
-     {
-     case DevFmtByte:
--        par.bps = 1;
-+        par.bits = 8;
-         par.sig = 1;
-         break;
-     case DevFmtUByte:
--        par.bps = 1;
-+        par.bits = 8;
-         par.sig = 0;
-         break;
-     case DevFmtShort:
--        par.bps = 2;
-+        par.bits = 16;
-         par.sig = 1;
-         break;
-     case DevFmtUShort:
--        par.bps = 2;
-+        par.bits = 16;
-         par.sig = 0;
-         break;
-     case DevFmtInt:
--        par.bps = 4;
-+        par.bits = 32;
-         par.sig = 1;
-         break;
-     case DevFmtUInt:
--        par.bps = 4;
-+        par.bits = 32;
-         par.sig = 0;
-         break;
-     case DevFmtFloat:
-         throw al::backend_exception{al::backend_error::DeviceError,
-             "%s capture samples not supported", DevFmtTypeString(mDevice->FmtType)};
-     }
--    par.bits = par.bps * 8;
-+    par.bps = SIO_BPS(par.bits);
-     par.le = SIO_LE_NATIVE;
--    par.msb = SIO_LE_NATIVE ? 0 : 1;
-+    par.msb = 1;
-     par.rchan = mDevice->channelsFromFmt();
-     par.rate = mDevice->Frequency;
- 
-     par.appbufsz = maxu(mDevice->BufferSize, mDevice->Frequency/10);
--    par.round = minu(par.appbufsz, mDevice->Frequency/40);
-+    par.round = minu(par.appbufsz/2, mDevice->Frequency/40);
- 
--    mDevice->UpdateSize = par.round;
--    mDevice->BufferSize = par.appbufsz;
--
-     if(!sio_setpar(mSndHandle, &par) || !sio_getpar(mSndHandle, &par))
-         throw al::backend_exception{al::backend_error::DeviceError,
-             "Failed to set device praameters"};
- 
--    if(par.bits != par.bps*8)
-+    if(par.bps > 1 && par.le != SIO_LE_NATIVE)
-         throw al::backend_exception{al::backend_error::DeviceError,
-+            "%s-endian samples not supported", par.le ? "Little" : "Big"};
-+    if(par.bits < par.bps*8 && !par.msb)
-+        throw al::backend_exception{al::backend_error::DeviceError,
-             "Padded samples not supported (got %u of %u bits)", par.bits, par.bps*8};
- 
--    if(!((mDevice->FmtType == DevFmtByte && par.bits == 8 && par.sig != 0)
--        || (mDevice->FmtType == DevFmtUByte && par.bits == 8 && par.sig == 0)
--        || (mDevice->FmtType == DevFmtShort && par.bits == 16 && par.sig != 0)
--        || (mDevice->FmtType == DevFmtUShort && par.bits == 16 && par.sig == 0)
--        || (mDevice->FmtType == DevFmtInt && par.bits == 32 && par.sig != 0)
--        || (mDevice->FmtType == DevFmtUInt && par.bits == 32 && par.sig == 0))
--        || mDevice->channelsFromFmt() != par.rchan || mDevice->Frequency != par.rate)
-+    auto match_fmt = [](DevFmtType fmttype, const sio_par &par) -> bool
-+    {
-+        return (fmttype == DevFmtByte && par.bps == 1 && par.sig != 0)
-+            || (fmttype == DevFmtUByte && par.bps == 1 && par.sig == 0)
-+            || (fmttype == DevFmtShort && par.bps == 2 && par.sig != 0)
-+            || (fmttype == DevFmtUShort && par.bps == 2 && par.sig == 0)
-+            || (fmttype == DevFmtInt && par.bps == 4 && par.sig != 0)
-+            || (fmttype == DevFmtUInt && par.bps == 4 && par.sig == 0);
-+    };
-+    if(!match_fmt(mDevice->FmtType, par) || mDevice->channelsFromFmt() != par.rchan
-+        || mDevice->Frequency != par.rate)
-         throw al::backend_exception{al::backend_error::DeviceError,
-             "Failed to set format %s %s %uhz, got %c%u %u-channel %uhz instead",
-             DevFmtTypeString(mDevice->FmtType), DevFmtChannelsString(mDevice->FmtChans),
--            mDevice->Frequency, par.sig?'s':'u', par.bits, par.rchan, par.rate};
-+            mDevice->Frequency, par.sig?'s':'u', par.bps*8, par.rchan, par.rate};
- 
-     mRing = RingBuffer::Create(mDevice->BufferSize, par.bps*par.rchan, false);
-+    mDevice->BufferSize = static_cast<uint>(mRing->writeSpace());
-+    mDevice->UpdateSize = par.round;
- 
-     setDefaultChannelOrder();
- 
diff --git a/audio/openal-soft/pkg-plist b/audio/openal-soft/pkg-plist
index ac89f5532261..962b634ed5b0 100644
--- a/audio/openal-soft/pkg-plist
+++ b/audio/openal-soft/pkg-plist
@@ -4,6 +4,7 @@
 %%ETCDIR%%/alsoftrc.sample
 %%ETCDIR%%/hrtf/Default HRTF.mhr
 %%ETCDIR%%/presets/3D7.1.ambdec
+%%ETCDIR%%/presets/hex-quad.ambdec
 %%ETCDIR%%/presets/hexagon.ambdec
 %%ETCDIR%%/presets/itu5.1-nocenter.ambdec
 %%ETCDIR%%/presets/itu5.1.ambdec
@@ -16,8 +17,9 @@ include/AL/alext.h
 include/AL/efx-creative.h
 include/AL/efx-presets.h
 include/AL/efx.h
-lib/cmake/OpenAL/OpenALConfig-%%CMAKE_BUILD_TYPE%%.cmake
 lib/cmake/OpenAL/OpenALConfig.cmake
+lib/cmake/OpenAL/OpenALTargets-%%CMAKE_BUILD_TYPE%%.cmake
+lib/cmake/OpenAL/OpenALTargets.cmake
 lib/libopenal.so
 lib/libopenal.so.1
 lib/libopenal.so.%%SOVERSION%%