64843258ce
Re-add patch 0001 to fix uClibc build, this patch was removed 2019: https://git.buildroot.net/buildroot/commit/?id=573d15b0790cfd2838cf0544ded79b415e20f5a7 Add two more patches from Alpine Linux to fix musl build. Add optional dependency to libexecinfo to provide execinfo.h. Add a patch that ensures an internal gettext symbol doesn't get used except on glibc and uclibc toolchains. Indeed, both glibc and uclibc provide the _nl_msg_cat_cntr variable, but not the musl implementation. Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
141 lines
4.2 KiB
Diff
141 lines
4.2 KiB
Diff
Fix musl build
|
|
|
|
Downloaded from
|
|
https://git.alpinelinux.org/aports/tree/community/vdr/musl-compat.patch
|
|
|
|
Signed-off-by: Bernd Kuhls <bernd.kuhls@t-online.de>
|
|
|
|
diff --git a/i18n.h b/i18n.h
|
|
index f8ad9de..b002bbf 100644
|
|
--- a/i18n.h
|
|
+++ b/i18n.h
|
|
@@ -46,7 +46,7 @@ const cStringList *I18nLanguages(void);
|
|
///< have an actual locale installed. The rest are just dummy entries
|
|
///< to allow having three letter language codes for other languages
|
|
///< that have no actual locale on this system.
|
|
-const char *I18nTranslate(const char *s, const char *Plugin = NULL) __attribute_format_arg__(1);
|
|
+const char *I18nTranslate(const char *s, const char *Plugin = NULL) __attribute__((__format_arg__ (1)));
|
|
///< Translates the given string (with optional Plugin context) into
|
|
///< the current language. If no translation is available, the original
|
|
///< string will be returned.
|
|
diff --git a/osd.c b/osd.c
|
|
index 524700a..ef975f5 100644
|
|
--- a/osd.c
|
|
+++ b/osd.c
|
|
@@ -12,7 +12,7 @@
|
|
#include <stdlib.h>
|
|
#include <sys/ioctl.h>
|
|
#include <sys/stat.h>
|
|
-#include <sys/unistd.h>
|
|
+#include <unistd.h>
|
|
#include "device.h"
|
|
#include "tools.h"
|
|
|
|
diff --git a/thread.c b/thread.c
|
|
index 47eb977..58dba43 100644
|
|
--- a/thread.c
|
|
+++ b/thread.c
|
|
@@ -155,7 +155,9 @@ cRwLock::cRwLock(bool PreferWriter)
|
|
writeLockThreadId = 0;
|
|
pthread_rwlockattr_t attr;
|
|
pthread_rwlockattr_init(&attr);
|
|
+#if defined(__GLIBC__)
|
|
pthread_rwlockattr_setkind_np(&attr, PreferWriter ? PTHREAD_RWLOCK_PREFER_WRITER_NP : PTHREAD_RWLOCK_PREFER_READER_NP);
|
|
+#endif
|
|
pthread_rwlock_init(&rwlock, &attr);
|
|
}
|
|
|
|
@@ -205,7 +207,7 @@ cMutex::cMutex(void)
|
|
locked = 0;
|
|
pthread_mutexattr_t attr;
|
|
pthread_mutexattr_init(&attr);
|
|
- pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK_NP);
|
|
+ pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
|
pthread_mutex_init(&mutex, &attr);
|
|
}
|
|
|
|
diff --git a/tools.c b/tools.c
|
|
index 754673d..fef9d2d 100644
|
|
--- a/tools.c
|
|
+++ b/tools.c
|
|
@@ -640,7 +640,7 @@ char *ReadLink(const char *FileName)
|
|
{
|
|
if (!FileName)
|
|
return NULL;
|
|
- char *TargetName = canonicalize_file_name(FileName);
|
|
+ char *TargetName = realpath(FileName, NULL);
|
|
if (!TargetName) {
|
|
if (errno == ENOENT) // file doesn't exist
|
|
TargetName = strdup(FileName);
|
|
@@ -1528,7 +1528,7 @@
|
|
struct dirent *cReadDir::Next(void)
|
|
{
|
|
if (directory) {
|
|
-#if !__GLIBC_PREREQ(2, 24) // readdir_r() is deprecated as of GLIBC 2.24
|
|
+#if __GLIBC__
|
|
while (readdir_r(directory, &u.d, &result) == 0 && result) {
|
|
#else
|
|
while ((result = readdir(directory)) != NULL) {
|
|
diff --git a/tools.h b/tools.h
|
|
index 73cca5a..03f5fd1 100644
|
|
--- a/tools.h
|
|
+++ b/tools.h
|
|
@@ -28,6 +28,16 @@
|
|
#include <sys/types.h>
|
|
#include "thread.h"
|
|
|
|
+#ifndef ACCESSPERMS
|
|
+# define ACCESSPERMS (S_IRWXU|S_IRWXG|S_IRWXO) /* 0777 */
|
|
+#endif
|
|
+#ifndef ALLPERMS
|
|
+# define ALLPERMS (S_ISUID|S_ISGID|S_ISVTX|S_IRWXU|S_IRWXG|S_IRWXO)/* 07777 */
|
|
+#endif
|
|
+#ifndef DEFFILEMODE
|
|
+# define DEFFILEMODE (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH)/* 0666*/
|
|
+#endif
|
|
+
|
|
typedef unsigned char uchar;
|
|
|
|
extern int SysLogLevel;
|
|
@@ -400,7 +410,7 @@
|
|
private:
|
|
DIR *directory;
|
|
struct dirent *result;
|
|
-#if !__GLIBC_PREREQ(2, 24) // readdir_r() is deprecated as of GLIBC 2.24
|
|
+#if __GLIBC__
|
|
union { // according to "The GNU C Library Reference Manual"
|
|
struct dirent d;
|
|
char b[offsetof(struct dirent, d_name) + NAME_MAX + 1];
|
|
@@ -738,7 +748,7 @@ public:
|
|
data[i] = T(0);
|
|
size = 0;
|
|
}
|
|
- void Sort(__compar_fn_t Compare)
|
|
+ void Sort(int (*Compare)(const void *, const void *))
|
|
{
|
|
qsort(data, size, sizeof(T), Compare);
|
|
}
|
|
diff --git a/vdr.c b/vdr.c
|
|
index 8a49471..c2a82aa 100644
|
|
--- a/vdr.c
|
|
+++ b/vdr.c
|
|
@@ -670,12 +670,18 @@ int main(int argc, char *argv[])
|
|
}
|
|
}
|
|
else if (Terminal) {
|
|
+#ifdef __GLIBC__
|
|
// Claim new controlling terminal
|
|
stdin = freopen(Terminal, "r", stdin);
|
|
stdout = freopen(Terminal, "w", stdout);
|
|
stderr = freopen(Terminal, "w", stderr);
|
|
HasStdin = true;
|
|
tcgetattr(STDIN_FILENO, &savedTm);
|
|
+#else
|
|
+ // stdin, stdout, stderr are declared FILE const* by musl C library
|
|
+ fprintf(stderr, "Option '-t' is only supported if VDR has been built against glibc.\n");
|
|
+ return 2;
|
|
+#endif
|
|
}
|
|
|
|
isyslog("VDR version %s started", VDRVERSION);
|