From 589402e4275455caea6475a451b4d1d08da749bf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=98rjan=20Malde?= Date: Wed, 11 Nov 2020 23:20:05 +0100 Subject: groups/251.native_packages_lib.group: libsndfile: win32 sound out support MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Lucio Andrés Illanes Albornoz --- groups/251.native_packages_lib.group | 3 + patches/libsndfile-1.0.28.local.patch | 105 ++++++++++++++++++++++++++++++++++ 2 files changed, 108 insertions(+) create mode 100644 patches/libsndfile-1.0.28.local.patch diff --git a/groups/251.native_packages_lib.group b/groups/251.native_packages_lib.group index eade0f11..fc6a7f3b 100644 --- a/groups/251.native_packages_lib.group +++ b/groups/251.native_packages_lib.group @@ -164,6 +164,9 @@ libxslt libz libzip sdl1 sdl1_net sdl1_image sdl2 sdl2_image sdl2_ttf wolfssl")" : ${PKG_LIBSNDFILE_SHA256SUM:=1ff33929f042fa333aed1e8923aa628c3ee9e1eb85512686c55092d1e5a9dfa9}; : ${PKG_LIBSNDFILE_VERSION:=1.0.28}; : ${PKG_LIBSNDFILE_URL:=http://www.mega-nerd.com/libsndfile/files/libsndfile-${PKG_LIBSNDFILE_VERSION}.tar.gz}; +: ${PKG_LIBSNDFILE_CONFIGURE_ARGS_EXTRA:="--disable-alsa"}; +: ${PKG_LIBSNDFILE_CFLAGS_CONFIGURE_EXTRA:="-I${PREFIX_NATIVE}/include/w32api.ports -DWINAPI_ANSI_DEFAULT"}; +: ${PKG_LIBSNDFILE_LDFLAGS_CONFIGURE_EXTRA:="-L${PREFIX_NATIVE}/lib/w32lib -lkernel32 -lwinmm"}; : ${PKG_LIBSOLV_DEPENDS:="bzip2 libxml2 libz musl_compat rpm"}; : ${PKG_LIBSOLV_SHA256SUM:=153eb48814ffdbac396c98126037cf45c07e2b7087a61f86eb18a75ea1ab134b}; : ${PKG_LIBSOLV_VERSION:=0.6.34}; diff --git a/patches/libsndfile-1.0.28.local.patch b/patches/libsndfile-1.0.28.local.patch new file mode 100644 index 00000000..708ae2c7 --- /dev/null +++ b/patches/libsndfile-1.0.28.local.patch @@ -0,0 +1,105 @@ +diff -ru libsndfile-1.0.28.orig/programs/sndfile-play.c libsndfile-1.0.28/programs/sndfile-play.c +--- libsndfile-1.0.28.orig/programs/sndfile-play.c 2017-04-01 09:18:02.000000000 +0200 ++++ libsndfile-1.0.28/programs/sndfile-play.c 2020-11-11 13:46:51.824586591 +0100 +@@ -71,10 +71,31 @@ + #include + #include + +-#elif (OS_IS_WIN32 == 1) ++#elif (OS_IS_WIN32 == 1) || defined(__midipix__) ++ #include + #include + #include + ++#ifndef INFINITE ++#define INFINITE 0xffffffff ++#endif ++ ++#ifndef CALLBACK_FUNCTION ++#define CALLBACK_FUNCTION (uint32_t)0x00030000 ++#endif ++ ++#ifndef WAVE_MAPPER ++#define WAVE_MAPPER ((UINT)-1) ++#endif ++ ++#ifndef WAVE_FORMAT_PCM ++#define WAVE_FORMAT_PCM 1 ++#endif ++ ++#ifndef MM_WOM_DONE ++#define MM_WOM_DONE 0x3BD ++#endif ++ + #endif + + #define SIGNED_SIZEOF(x) ((int) sizeof (x)) +@@ -482,15 +503,16 @@ + ** point to data instead of short*. It plain sucks! + */ + +-#if (OS_IS_WIN32 == 1) ++#if (OS_IS_WIN32 == 1) || defined(__midipix__) + + #define WIN32_BUFFER_LEN (1 << 15) + ++static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER ; ++ + typedef struct + { HWAVEOUT hwave ; + WAVEHDR whdr [2] ; + +- CRITICAL_SECTION mutex ; /* to control access to BuffersInUSe */ + HANDLE Event ; /* signal that a buffer is free */ + + short buffer [WIN32_BUFFER_LEN / sizeof (short)] ; +@@ -524,9 +546,9 @@ + waveOutWrite (audio_data->hwave, (LPWAVEHDR) &(audio_data->whdr [audio_data->current]), sizeof (WAVEHDR)) ; + + /* count another buffer in use */ +- EnterCriticalSection (&audio_data->mutex) ; ++ pthread_mutex_lock (&mutex) ; + audio_data->BuffersInUse ++ ; +- LeaveCriticalSection (&audio_data->mutex) ; ++ pthread_mutex_unlock (&mutex) ; + + /* use the other buffer next time */ + audio_data->current = (audio_data->current + 1) % 2 ; +@@ -556,9 +578,9 @@ + + /* let main loop know a buffer is free */ + if (msg == MM_WOM_DONE) +- { EnterCriticalSection (&audio_data->mutex) ; ++ { pthread_mutex_lock (&mutex) ; + audio_data->BuffersInUse -- ; +- LeaveCriticalSection (&audio_data->mutex) ; ++ pthread_mutex_unlock (&mutex) ; + SetEvent (audio_data->Event) ; + } ; + +@@ -586,7 +608,6 @@ + audio_data.remaining = audio_data.sfinfo.frames * audio_data.sfinfo.channels ; + audio_data.current = 0 ; + +- InitializeCriticalSection (&audio_data.mutex) ; + audio_data.Event = CreateEvent (0, FALSE, FALSE, 0) ; + + wf.nChannels = audio_data.sfinfo.channels ; +@@ -655,8 +676,6 @@ + waveOutClose (audio_data.hwave) ; + audio_data.hwave = 0 ; + +- DeleteCriticalSection (&audio_data.mutex) ; +- + sf_close (audio_data.sndfile) ; + } ; + +@@ -848,7 +867,7 @@ + sndio_play (argc, argv) ; + #elif (defined (sun) && defined (unix)) + solaris_play (argc, argv) ; +-#elif (OS_IS_WIN32 == 1) ++#elif (OS_IS_WIN32 == 1) || defined(__midipix__) + win32_play (argc, argv) ; + #elif (defined (__MACH__) && defined (__APPLE__)) + printf ("OS X 10.8 and later have a new Audio API.\n") ; -- cgit v1.2.3