toolchain/musl: add version 0.9.15, remove older versions (still broken, but closer...
authorFelix Fietkau <nbd@openwrt.org>
Mon, 24 Feb 2014 21:10:11 +0000 (21:10 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Mon, 24 Feb 2014 21:10:11 +0000 (21:10 +0000)
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
SVN-Revision: 39750

26 files changed:
toolchain/musl/Config.in
toolchain/musl/Config.version
toolchain/musl/Makefile
toolchain/musl/common.mk
toolchain/musl/patches-0.9.10/000-install_portability.patch [deleted file]
toolchain/musl/patches-0.9.10/100-wchar_include.patch [deleted file]
toolchain/musl/patches-0.9.10/110-bsd_ether_h.patch [deleted file]
toolchain/musl/patches-0.9.10/120-in_h_are_4_equal_parenthesis.patch [deleted file]
toolchain/musl/patches-0.9.10/130-syslog_log_upto_parenthesis.patch [deleted file]
toolchain/musl/patches-0.9.11/000-install_portability.patch [deleted file]
toolchain/musl/patches-0.9.11/100-wchar_include.patch [deleted file]
toolchain/musl/patches-0.9.11/120-in_h_are_4_equal_parenthesis.patch [deleted file]
toolchain/musl/patches-0.9.11/130-syslog_log_upto_parenthesis.patch [deleted file]
toolchain/musl/patches-0.9.15/100-in_h_are_4_equal_parenthesis.patch [new file with mode: 0644]
toolchain/musl/patches-0.9.15/110-syslog_log_upto_parenthesis.patch [new file with mode: 0644]
toolchain/musl/patches-0.9.15/120-add_glob_onlydir.patch [new file with mode: 0644]
toolchain/musl/patches-0.9.8/001-bsd_ether_h.patch [deleted file]
toolchain/musl/patches-0.9.8/002-no_mips_fpu.patch [deleted file]
toolchain/musl/patches-0.9.8/003-in_h_are_4_equal_parenthesis.patch [deleted file]
toolchain/musl/patches-0.9.8/004-wchar_include.patch [deleted file]
toolchain/musl/patches-0.9.8/005-install_portability.patch [deleted file]
toolchain/musl/patches-0.9.9/001-arm_shared_libs_regression_fix.patch [deleted file]
toolchain/musl/patches-0.9.9/002-bsd_ether_h.patch [deleted file]
toolchain/musl/patches-0.9.9/003-in_h_are_4_equal_parenthesis.patch [deleted file]
toolchain/musl/patches-0.9.9/004-wchar_include.patch [deleted file]
toolchain/musl/patches-0.9.9/005-install_portability.patch [deleted file]

index 6bc7cce..d75c206 100644 (file)
@@ -4,25 +4,13 @@ choice
        prompt "musl Version"
        depends on TOOLCHAINOPTS && USE_MUSL
        depends on BROKEN
-       default MUSL_USE_VERSION_0_9_8
+       default MUSL_USE_VERSION_0_9_15
        help
          Select the version of musl you wish to use.
 
-       config MUSL_USE_VERSION_0_9_8
-               select MUSL_VERSION_0_9_8
-               bool "musl 0.9.8"
-
-       config MUSL_USE_VERSION_0_9_9
-               select MUSL_VERSION_0_9_9
-               bool "musl 0.9.9"
-
-       config MUSL_USE_VERSION_0_9_10
-               select MUSL_VERSION_0_9_10
-               bool "musl 0.9.10"
-
-       config MUSL_USE_VERSION_0_9_11
-               select MUSL_VERSION_0_9_11
-               bool "musl 0.9.11"
+       config MUSL_USE_VERSION_0_9_15
+               select MUSL_VERSION_0_9_15
+               bool "musl 0.9.15"
 
 endchoice
 
index b936cb2..b88bf65 100644 (file)
@@ -3,22 +3,10 @@ if USE_MUSL
 config MUSL_VERSION
        string
        depends on USE_MUSL
-       default "0.9.8"         if MUSL_VERSION_0_9_8
-       default "0.9.9"         if MUSL_VERSION_0_9_9
-       default "0.9.10"        if MUSL_VERSION_0_9_10
-       default "0.9.11"        if MUSL_VERSION_0_9_11
+       default "0.9.15"        if MUSL_VERSION_0_9_15
 
-config MUSL_VERSION_0_9_8
+config MUSL_VERSION_0_9_15
        default y if !TOOLCHAINOPTS
        bool
 
-config MUSL_VERSION_0_9_9
-       bool
-
-config MUSL_VERSION_0_9_10
-       bool
-
-config MUSL_VERSION_0_9_11
-       bool
-
 endif
index f95bb05..66b874e 100644 (file)
@@ -7,6 +7,10 @@ HOST_STAMP_INSTALLED:=$(TOOLCHAIN_DIR)/stamp/.musl_installed
 
 HOST_BUILD_PARALLEL:=1
 
+MUSL_MAKEOPTS = -C $(HOST_BUILD_DIR) \
+       DESTDIR="$(TOOLCHAIN_DIR)/" \
+       LIBCC="$(subst libgcc.a,libgcc_initial.a,$(shell $(TARGET_CC) -print-libgcc-file-name))"
+
 define Host/SetToolchainInfo
        $(SED) 's,^\(LIBC_TYPE\)=.*,\1=$(PKG_NAME),' $(TOOLCHAIN_DIR)/info.mk
        $(SED) 's,^\(LIBC_URL\)=.*,\1=http://www.musl-libc.org/,' $(TOOLCHAIN_DIR)/info.mk
@@ -15,12 +19,12 @@ define Host/SetToolchainInfo
 endef
 
 define Host/Compile
-       $(MAKE) $(HOST_JOBS) -C $(HOST_BUILD_DIR) all
+       $(MAKE) $(HOST_JOBS) $(MUSL_MAKEOPTS) all
 endef
 
 define Host/Install
        $(call Host/SetToolchainInfo)
-       $(MAKE) -C $(HOST_BUILD_DIR) DESTDIR="$(TOOLCHAIN_DIR)/" install
+       $(MAKE) $(MUSL_MAKEOPTS) DESTDIR="$(TOOLCHAIN_DIR)/" install
 endef
 
 $(eval $(call HostBuild))
index 4f8baec..538ad27 100644 (file)
@@ -9,18 +9,12 @@ include $(INCLUDE_DIR)/target.mk
 
 PKG_NAME:=musl
 PKG_VERSION:=$(call qstrip,$(CONFIG_MUSL_VERSION))
-PKG_RELEASE=$(PKG_SOURCE_VERSION)
+PKG_RELEASE=1
 
-PKG_SOURCE_VERSION_0.9.8:=e6dcebd5efa2d390f0a24dc11444024e9fd1990c
-PKG_SOURCE_VERSION_0.9.9:=a57ac9bf64ba202bd94d1b81bddd93b850c7b9d6
-PKG_SOURCE_VERSION_0.9.10:=7bec92e793d4b8a349796848cf43c7329b0f2ed0
-PKG_SOURCE_VERSION_0.9.11:=6688a778b0419eab32e715f269319248edee9da5
+PKG_SOURCE_MD5SUM_0.9.15:=06f590a38c85722ee9343db2416425f4
 
-PKG_SOURCE_PROTO:=git
-PKG_SOURCE_URL:=git://git.musl-libc.org/musl
-PKG_SOURCE_SUBDIR=$(PKG_NAME)-$(PKG_VERSION)
-PKG_SOURCE_VERSION:=$(PKG_SOURCE_VERSION_$(PKG_VERSION))
-PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION)-$(PKG_SOURCE_VERSION).tar.gz
+PKG_SOURCE_URL:=http://www.musl-libc.org/releases
+PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
 LIBC_SO_VERSION:=$(PKG_VERSION)
 PATCH_DIR:=$(PATH_PREFIX)/patches-$(PKG_VERSION)
 CONFIG_DIR:=$(PATH_PREFIX)/config-$(PKG_VERSION)
diff --git a/toolchain/musl/patches-0.9.10/000-install_portability.patch b/toolchain/musl/patches-0.9.10/000-install_portability.patch
deleted file mode 100644 (file)
index 3e018c6..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
---- a/Makefile
-+++ b/Makefile
-@@ -116,16 +116,20 @@ tools/musl-gcc: config.mak
-       chmod +x $@
- $(DESTDIR)$(bindir)/%: tools/%
--      install -D $< $@
-+      mkdir -p $(dir $@)
-+      install $< $@
- $(DESTDIR)$(libdir)/%.so: lib/%.so
--      install -D -m 755 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 755 $< $@
- $(DESTDIR)$(libdir)/%: lib/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(includedir)/%: include/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(LDSO_PATHNAME): $(DESTDIR)$(syslibdir)
-       ln -sf $(libdir)/libc.so $@ || true
diff --git a/toolchain/musl/patches-0.9.10/100-wchar_include.patch b/toolchain/musl/patches-0.9.10/100-wchar_include.patch
deleted file mode 100644 (file)
index 2f36ae5..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
---- a/arch/arm/bits/alltypes.h.sh
-+++ b/arch/arm/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF unsigned wchar_t;
---- a/arch/i386/bits/alltypes.h.sh
-+++ b/arch/i386/bits/alltypes.h.sh
-@@ -25,6 +25,7 @@ TYPEDEF __builtin_va_list va_list;
- #else
- TYPEDEF struct __va_list * va_list;
- #endif
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- #ifdef __WCHAR_TYPE__
---- a/arch/microblaze/bits/alltypes.h.sh
-+++ b/arch/microblaze/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/mips/bits/alltypes.h.sh
-+++ b/arch/mips/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/powerpc/bits/alltypes.h.sh
-+++ b/arch/powerpc/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF long wchar_t;
---- a/arch/x86_64/bits/alltypes.h.sh
-+++ b/arch/x86_64/bits/alltypes.h.sh
-@@ -20,6 +20,7 @@ TYPEDEF unsigned long size_t;
- TYPEDEF long ssize_t;
- TYPEDEF long ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
diff --git a/toolchain/musl/patches-0.9.10/110-bsd_ether_h.patch b/toolchain/musl/patches-0.9.10/110-bsd_ether_h.patch
deleted file mode 100644 (file)
index 61faf79..0000000
+++ /dev/null
@@ -1,196 +0,0 @@
---- /dev/null
-+++ b/include/netinet/ether.h
-@@ -0,0 +1,10 @@
-+#ifndef _NETINET_ETHER_H
-+#define _NETINET_ETHER_H
-+
-+char  *ether_ntoa(const struct ether_addr *);
-+struct        ether_addr *ether_aton(const char *);
-+int   ether_ntohost(char *, const struct ether_addr *);
-+int   ether_hostton(const char *, struct ether_addr *);
-+int   ether_line(const char *, struct ether_addr *, char *);
-+
-+#endif /* !_NETINET_ETHER_H */
---- /dev/null
-+++ b/src/network/ethers.c
-@@ -0,0 +1,180 @@
-+/* Origin NetBSD: src/lib/libc/net/ethers.c */
-+
-+/*
-+ * ethers(3N) a la Sun.
-+ *
-+ * Written by Roland McGrath <roland@...b.com> 10/14/93.
-+ * Public domain.
-+ *
-+ * port for musl by Abdoulaye Walsimou GAYE <awg@...toolkit.org> 2012/10/15
-+ */
-+
-+#define _BSD_SOURCE
-+#include <net/ethernet.h>
-+#include <netinet/ether.h>
-+
-+#include <sys/param.h>
-+#include <assert.h>
-+#include <errno.h>
-+#include <paths.h>
-+#include <stdio.h>
-+#include <stdlib.h>
-+#include <string.h>
-+
-+#ifndef _PATH_ETHERS
-+#define _PATH_ETHERS "/etc/ethers"
-+#endif
-+
-+/*
-+ * ether_ntoa():
-+ * This function converts this structure into an ASCII string of the form
-+ * ``xx:xx:xx:xx:xx:xx'', consisting of 6 hexadecimal numbers separated
-+ * by colons.  It returns a pointer to a static buffer that is reused for
-+ * each call.
-+ */
-+char *ether_ntoa(const struct ether_addr *e)
-+{
-+      static char a[18];
-+
-+      assert(e != NULL);
-+
-+      (void) snprintf(a, sizeof a, "%02x:%02x:%02x:%02x:%02x:%02x",
-+          e->ether_addr_octet[0], e->ether_addr_octet[1],
-+          e->ether_addr_octet[2], e->ether_addr_octet[3],
-+          e->ether_addr_octet[4], e->ether_addr_octet[5]);
-+      return a;
-+}
-+
-+/*
-+ * ether_aton():
-+ * This function converts an ASCII string of the same form and to a structure
-+ * containing the 6 octets of the address.  It returns a pointer to a
-+ * static structure that is reused for each call.
-+ */
-+struct ether_addr *ether_aton(const char *s)
-+{
-+      static struct ether_addr n;
-+      unsigned int i[6];
-+
-+      assert(s != NULL);
-+
-+      if (sscanf(s, " %x:%x:%x:%x:%x:%x ", &i[0], &i[1],
-+          &i[2], &i[3], &i[4], &i[5]) == 6) {
-+              n.ether_addr_octet[0] = (unsigned char)i[0];
-+              n.ether_addr_octet[1] = (unsigned char)i[1];
-+              n.ether_addr_octet[2] = (unsigned char)i[2];
-+              n.ether_addr_octet[3] = (unsigned char)i[3];
-+              n.ether_addr_octet[4] = (unsigned char)i[4];
-+              n.ether_addr_octet[5] = (unsigned char)i[5];
-+              return &n;
-+      }
-+      return NULL;
-+}
-+
-+/*
-+ * ether_ntohost():
-+ * This function interrogates the data base mapping host names to Ethernet
-+ * addresses, /etc/ethers.
-+ * It looks up the given Ethernet address and writes the associated host name
-+ * into the character buffer passed.
-+ * It returns zero if it finds the requested host name and -1 if not.
-+ */
-+int ether_ntohost(char *hostname, const struct ether_addr *e)
-+{
-+      FILE *f;
-+      char *p;
-+      size_t len;
-+      struct ether_addr try;
-+
-+      assert(hostname != NULL);
-+      assert(e != NULL);
-+
-+      f = fopen(_PATH_ETHERS, "r");
-+      if (f == NULL)
-+              return -1;
-+      while ((p = fgetln(f, &len)) != NULL) {
-+              if (p[len - 1] != '\n')
-+                      continue;               /* skip lines w/o \n */
-+              p[--len] = '\0';
-+              if (ether_line(p, &try, hostname) == 0 &&
-+                  memcmp(&try, e, sizeof try) == 0) {
-+                      (void)fclose(f);
-+                      return 0;
-+              }
-+      }
-+      (void)fclose(f);
-+      errno = ENOENT;
-+      return -1;
-+}
-+
-+/*
-+ * ether_hostton():
-+ * This function interrogates the data base mapping host names to Ethernet
-+ * addresses, /etc/ethers.
-+ * It looks up the given host name and writes the associated Ethernet address
-+ * into the structure passed.
-+ * It returns zero if it finds the requested address and -1 if not.
-+ */
-+int ether_hostton(const char *hostname, struct ether_addr *e)
-+{
-+      FILE *f;
-+      char *p;
-+      size_t len;
-+      char try[MAXHOSTNAMELEN + 1];
-+
-+      assert(hostname != NULL);
-+      assert(e != NULL);
-+
-+      f = fopen(_PATH_ETHERS, "r");
-+      if (f==NULL)
-+              return -1;
-+
-+      while ((p = fgetln(f, &len)) != NULL) {
-+              if (p[len - 1] != '\n')
-+                      continue;               /* skip lines w/o \n */
-+              p[--len] = '\0';
-+              if (ether_line(p, e, try) == 0 && strcmp(hostname, try) == 0) {
-+                      (void)fclose(f);
-+                      return 0;
-+              }
-+      }
-+      (void)fclose(f);
-+      errno = ENOENT;
-+      return -1;
-+}
-+
-+/*
-+ * ether_line():
-+ * This function parses a line from the /etc/ethers file and fills in the passed
-+ * ``struct ether_addr'' and character buffer with the Ethernet address and host
-+ * name on the line.
-+ * It returns zero if the line was successfully parsed and -1 if not.
-+ */
-+int ether_line(const char *l, struct ether_addr *e, char *hostname)
-+{
-+      unsigned int i[6];
-+
-+#define S2(arg) #arg
-+#define S1(arg) S2(arg)
-+      static const char fmt[] = " %x:%x:%x:%x:%x:%x"
-+          " %" S1(MAXHOSTNAMELEN) "s\n";
-+#undef S2
-+#undef S1
-+
-+      assert(l != NULL);
-+      assert(e != NULL);
-+      assert(hostname != NULL);
-+
-+      if (sscanf(l, fmt,
-+          &i[0], &i[1], &i[2], &i[3], &i[4], &i[5], hostname) == 7) {
-+              e->ether_addr_octet[0] = (unsigned char)i[0];
-+              e->ether_addr_octet[1] = (unsigned char)i[1];
-+              e->ether_addr_octet[2] = (unsigned char)i[2];
-+              e->ether_addr_octet[3] = (unsigned char)i[3];
-+              e->ether_addr_octet[4] = (unsigned char)i[4];
-+              e->ether_addr_octet[5] = (unsigned char)i[5];
-+              return 0;
-+      }
-+      errno = EINVAL;
-+      return -1;
-+}
diff --git a/toolchain/musl/patches-0.9.10/120-in_h_are_4_equal_parenthesis.patch b/toolchain/musl/patches-0.9.10/120-in_h_are_4_equal_parenthesis.patch
deleted file mode 100644 (file)
index 8b5dbd4..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/include/netinet/in.h
-+++ b/include/netinet/in.h
-@@ -146,7 +146,7 @@ uint16_t ntohs(uint16_t);
-         (IN6_IS_ADDR_MULTICAST(a) && ((((uint8_t *) (a))[1] & 0xf) == 0xe))
- #define __ARE_4_EQUAL(a,b) \
--      (!( 0[a]-0[b] | 1[a]-1[b] | 2[a]-2[b] | 3[a]-3[b] ))
-+      (!( (0[a]-0[b]) | (1[a]-1[b]) | (2[a]-2[b]) | (3[a]-3[b]) ))
- #define IN6_ARE_ADDR_EQUAL(a,b) \
-       __ARE_4_EQUAL((const uint32_t *)(a), (const uint32_t *)(b))
diff --git a/toolchain/musl/patches-0.9.10/130-syslog_log_upto_parenthesis.patch b/toolchain/musl/patches-0.9.10/130-syslog_log_upto_parenthesis.patch
deleted file mode 100644 (file)
index 840dd40..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/include/syslog.h
-+++ b/include/syslog.h
-@@ -21,7 +21,7 @@ extern "C" {
- #define       LOG_MAKEPRI(f, p) (((f)<<3)|(p))
- #define LOG_MASK(p) (1<<(p))
--#define LOG_UPTO(p) ((1<<(p)+1)-1)
-+#define LOG_UPTO(p) ((1<<((p)+1))-1)
- #define LOG_KERN     (0<<3)
- #define LOG_USER     (1<<3)
diff --git a/toolchain/musl/patches-0.9.11/000-install_portability.patch b/toolchain/musl/patches-0.9.11/000-install_portability.patch
deleted file mode 100644 (file)
index 43c4351..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
---- a/Makefile
-+++ b/Makefile
-@@ -116,16 +116,20 @@
-       chmod +x $@
- $(DESTDIR)$(bindir)/%: tools/%
--      install -D $< $@
-+      mkdir -p $(dir $@)
-+      install $< $@
- $(DESTDIR)$(libdir)/%.so: lib/%.so
--      install -D -m 755 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 755 $< $@
- $(DESTDIR)$(libdir)/%: lib/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(includedir)/%: include/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(LDSO_PATHNAME): $(DESTDIR)$(syslibdir)
-       ln -sf $(libdir)/libc.so $@ || true
diff --git a/toolchain/musl/patches-0.9.11/100-wchar_include.patch b/toolchain/musl/patches-0.9.11/100-wchar_include.patch
deleted file mode 100644 (file)
index 5d78ced..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
---- a/arch/arm/bits/alltypes.h.sh
-+++ b/arch/arm/bits/alltypes.h.sh
-@@ -22,6 +22,7 @@
- TYPEDEF __builtin_va_list va_list;
- TYPEDEF __builtin_va_list __isoc_va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF unsigned wchar_t;
---- a/arch/i386/bits/alltypes.h.sh
-+++ b/arch/i386/bits/alltypes.h.sh
-@@ -27,6 +27,7 @@
- TYPEDEF struct __va_list * va_list;
- TYPEDEF struct __va_list * __isoc_va_list;
- #endif
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- #ifdef __WCHAR_TYPE__
---- a/arch/microblaze/bits/alltypes.h.sh
-+++ b/arch/microblaze/bits/alltypes.h.sh
-@@ -22,6 +22,7 @@
- TYPEDEF __builtin_va_list va_list;
- TYPEDEF __builtin_va_list __isoc_va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/mips/bits/alltypes.h.sh
-+++ b/arch/mips/bits/alltypes.h.sh
-@@ -22,6 +22,7 @@
- TYPEDEF __builtin_va_list va_list;
- TYPEDEF __builtin_va_list __isoc_va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/powerpc/bits/alltypes.h.sh
-+++ b/arch/powerpc/bits/alltypes.h.sh
-@@ -22,6 +22,7 @@
- TYPEDEF __builtin_va_list va_list;
- TYPEDEF __builtin_va_list __isoc_va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF long wchar_t;
---- a/arch/x86_64/bits/alltypes.h.sh
-+++ b/arch/x86_64/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@
- TYPEDEF long ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
- TYPEDEF __builtin_va_list __isoc_va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
diff --git a/toolchain/musl/patches-0.9.11/120-in_h_are_4_equal_parenthesis.patch b/toolchain/musl/patches-0.9.11/120-in_h_are_4_equal_parenthesis.patch
deleted file mode 100644 (file)
index 8b5dbd4..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/include/netinet/in.h
-+++ b/include/netinet/in.h
-@@ -146,7 +146,7 @@ uint16_t ntohs(uint16_t);
-         (IN6_IS_ADDR_MULTICAST(a) && ((((uint8_t *) (a))[1] & 0xf) == 0xe))
- #define __ARE_4_EQUAL(a,b) \
--      (!( 0[a]-0[b] | 1[a]-1[b] | 2[a]-2[b] | 3[a]-3[b] ))
-+      (!( (0[a]-0[b]) | (1[a]-1[b]) | (2[a]-2[b]) | (3[a]-3[b]) ))
- #define IN6_ARE_ADDR_EQUAL(a,b) \
-       __ARE_4_EQUAL((const uint32_t *)(a), (const uint32_t *)(b))
diff --git a/toolchain/musl/patches-0.9.11/130-syslog_log_upto_parenthesis.patch b/toolchain/musl/patches-0.9.11/130-syslog_log_upto_parenthesis.patch
deleted file mode 100644 (file)
index 840dd40..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/include/syslog.h
-+++ b/include/syslog.h
-@@ -21,7 +21,7 @@ extern "C" {
- #define       LOG_MAKEPRI(f, p) (((f)<<3)|(p))
- #define LOG_MASK(p) (1<<(p))
--#define LOG_UPTO(p) ((1<<(p)+1)-1)
-+#define LOG_UPTO(p) ((1<<((p)+1))-1)
- #define LOG_KERN     (0<<3)
- #define LOG_USER     (1<<3)
diff --git a/toolchain/musl/patches-0.9.15/100-in_h_are_4_equal_parenthesis.patch b/toolchain/musl/patches-0.9.15/100-in_h_are_4_equal_parenthesis.patch
new file mode 100644 (file)
index 0000000..b77f650
--- /dev/null
@@ -0,0 +1,11 @@
+--- a/include/netinet/in.h
++++ b/include/netinet/in.h
+@@ -149,7 +149,7 @@ uint16_t ntohs(uint16_t);
+         (IN6_IS_ADDR_MULTICAST(a) && ((((uint8_t *) (a))[1] & 0xf) == 0xe))
+ #define __ARE_4_EQUAL(a,b) \
+-      (!( 0[a]-0[b] | 1[a]-1[b] | 2[a]-2[b] | 3[a]-3[b] ))
++      (!( (0[a]-0[b]) | (1[a]-1[b]) | (2[a]-2[b]) | (3[a]-3[b]) ))
+ #define IN6_ARE_ADDR_EQUAL(a,b) \
+       __ARE_4_EQUAL((const uint32_t *)(a), (const uint32_t *)(b))
diff --git a/toolchain/musl/patches-0.9.15/110-syslog_log_upto_parenthesis.patch b/toolchain/musl/patches-0.9.15/110-syslog_log_upto_parenthesis.patch
new file mode 100644 (file)
index 0000000..840dd40
--- /dev/null
@@ -0,0 +1,11 @@
+--- a/include/syslog.h
++++ b/include/syslog.h
+@@ -21,7 +21,7 @@ extern "C" {
+ #define       LOG_MAKEPRI(f, p) (((f)<<3)|(p))
+ #define LOG_MASK(p) (1<<(p))
+-#define LOG_UPTO(p) ((1<<(p)+1)-1)
++#define LOG_UPTO(p) ((1<<((p)+1))-1)
+ #define LOG_KERN     (0<<3)
+ #define LOG_USER     (1<<3)
diff --git a/toolchain/musl/patches-0.9.15/120-add_glob_onlydir.patch b/toolchain/musl/patches-0.9.15/120-add_glob_onlydir.patch
new file mode 100644 (file)
index 0000000..db0bc22
--- /dev/null
@@ -0,0 +1,11 @@
+--- a/include/glob.h
++++ b/include/glob.h
+@@ -31,6 +31,8 @@ void globfree(glob_t *);
+ #define GLOB_NOESCAPE 0x40
+ #define       GLOB_PERIOD   0x80
++#define GLOB_ONLYDIR  0x100
++
+ #define GLOB_NOSPACE 1
+ #define GLOB_ABORTED 2
+ #define GLOB_NOMATCH 3
diff --git a/toolchain/musl/patches-0.9.8/001-bsd_ether_h.patch b/toolchain/musl/patches-0.9.8/001-bsd_ether_h.patch
deleted file mode 100644 (file)
index be3a021..0000000
+++ /dev/null
@@ -1,219 +0,0 @@
-Date: Sat, 20 Oct 2012 22:15:44 +0200
-From: Abdoulaye Walsimou Gaye <awg@...toolkit.org>
-To: musl@...ts.openwall.com
-Cc: Abdoulaye Walsimou Gaye <awg@...toolkit.org>
-Subject: [PATCH 3/4] Import BSD functions defined in <netinet/ether.h> from NetBSD
-
-Signed-off-by: Abdoulaye Walsimou Gaye <awg@...toolkit.org>
----
- include/netinet/ether.h |   14 ++++
- src/network/ethers.c    |  180 +++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 194 insertions(+)
- create mode 100644 include/netinet/ether.h
- create mode 100644 src/network/ethers.c
-
-diff --git a/include/netinet/ether.h b/include/netinet/ether.h
-new file mode 100644
-index 0000000..44c614e
---- /dev/null
-+++ b/include/netinet/ether.h
-@@ -0,0 +1,10 @@
-+#ifndef _NETINET_ETHER_H
-+#define _NETINET_ETHER_H
-+
-+char  *ether_ntoa(const struct ether_addr *);
-+struct        ether_addr *ether_aton(const char *);
-+int   ether_ntohost(char *, const struct ether_addr *);
-+int   ether_hostton(const char *, struct ether_addr *);
-+int   ether_line(const char *, struct ether_addr *, char *);
-+
-+#endif /* !_NETINET_ETHER_H */
-diff --git a/src/network/ethers.c b/src/network/ethers.c
-new file mode 100644
-index 0000000..8014581
---- /dev/null
-+++ b/src/network/ethers.c
-@@ -0,0 +1,180 @@
-+/* Origin NetBSD: src/lib/libc/net/ethers.c */
-+
-+/*
-+ * ethers(3N) a la Sun.
-+ *
-+ * Written by Roland McGrath <roland@...b.com> 10/14/93.
-+ * Public domain.
-+ *
-+ * port for musl by Abdoulaye Walsimou GAYE <awg@...toolkit.org> 2012/10/15
-+ */
-+
-+#define _BSD_SOURCE
-+#include <net/ethernet.h>
-+#include <netinet/ether.h>
-+
-+#include <sys/param.h>
-+#include <assert.h>
-+#include <errno.h>
-+#include <paths.h>
-+#include <stdio.h>
-+#include <stdlib.h>
-+#include <string.h>
-+
-+#ifndef _PATH_ETHERS
-+#define _PATH_ETHERS "/etc/ethers"
-+#endif
-+
-+/*
-+ * ether_ntoa():
-+ * This function converts this structure into an ASCII string of the form
-+ * ``xx:xx:xx:xx:xx:xx'', consisting of 6 hexadecimal numbers separated
-+ * by colons.  It returns a pointer to a static buffer that is reused for
-+ * each call.
-+ */
-+char *ether_ntoa(const struct ether_addr *e)
-+{
-+      static char a[18];
-+
-+      assert(e != NULL);
-+
-+      (void) snprintf(a, sizeof a, "%02x:%02x:%02x:%02x:%02x:%02x",
-+          e->ether_addr_octet[0], e->ether_addr_octet[1],
-+          e->ether_addr_octet[2], e->ether_addr_octet[3],
-+          e->ether_addr_octet[4], e->ether_addr_octet[5]);
-+      return a;
-+}
-+
-+/*
-+ * ether_aton():
-+ * This function converts an ASCII string of the same form and to a structure
-+ * containing the 6 octets of the address.  It returns a pointer to a
-+ * static structure that is reused for each call.
-+ */
-+struct ether_addr *ether_aton(const char *s)
-+{
-+      static struct ether_addr n;
-+      unsigned int i[6];
-+
-+      assert(s != NULL);
-+
-+      if (sscanf(s, " %x:%x:%x:%x:%x:%x ", &i[0], &i[1],
-+          &i[2], &i[3], &i[4], &i[5]) == 6) {
-+              n.ether_addr_octet[0] = (unsigned char)i[0];
-+              n.ether_addr_octet[1] = (unsigned char)i[1];
-+              n.ether_addr_octet[2] = (unsigned char)i[2];
-+              n.ether_addr_octet[3] = (unsigned char)i[3];
-+              n.ether_addr_octet[4] = (unsigned char)i[4];
-+              n.ether_addr_octet[5] = (unsigned char)i[5];
-+              return &n;
-+      }
-+      return NULL;
-+}
-+
-+/*
-+ * ether_ntohost():
-+ * This function interrogates the data base mapping host names to Ethernet
-+ * addresses, /etc/ethers.
-+ * It looks up the given Ethernet address and writes the associated host name
-+ * into the character buffer passed.
-+ * It returns zero if it finds the requested host name and -1 if not.
-+ */
-+int ether_ntohost(char *hostname, const struct ether_addr *e)
-+{
-+      FILE *f;
-+      char *p;
-+      size_t len;
-+      struct ether_addr try;
-+
-+      assert(hostname != NULL);
-+      assert(e != NULL);
-+
-+      f = fopen(_PATH_ETHERS, "r");
-+      if (f == NULL)
-+              return -1;
-+      while ((p = fgetln(f, &len)) != NULL) {
-+              if (p[len - 1] != '\n')
-+                      continue;               /* skip lines w/o \n */
-+              p[--len] = '\0';
-+              if (ether_line(p, &try, hostname) == 0 &&
-+                  memcmp(&try, e, sizeof try) == 0) {
-+                      (void)fclose(f);
-+                      return 0;
-+              }
-+      }
-+      (void)fclose(f);
-+      errno = ENOENT;
-+      return -1;
-+}
-+
-+/*
-+ * ether_hostton():
-+ * This function interrogates the data base mapping host names to Ethernet
-+ * addresses, /etc/ethers.
-+ * It looks up the given host name and writes the associated Ethernet address
-+ * into the structure passed.
-+ * It returns zero if it finds the requested address and -1 if not.
-+ */
-+int ether_hostton(const char *hostname, struct ether_addr *e)
-+{
-+      FILE *f;
-+      char *p;
-+      size_t len;
-+      char try[MAXHOSTNAMELEN + 1];
-+
-+      assert(hostname != NULL);
-+      assert(e != NULL);
-+
-+      f = fopen(_PATH_ETHERS, "r");
-+      if (f==NULL)
-+              return -1;
-+
-+      while ((p = fgetln(f, &len)) != NULL) {
-+              if (p[len - 1] != '\n')
-+                      continue;               /* skip lines w/o \n */
-+              p[--len] = '\0';
-+              if (ether_line(p, e, try) == 0 && strcmp(hostname, try) == 0) {
-+                      (void)fclose(f);
-+                      return 0;
-+              }
-+      }
-+      (void)fclose(f);
-+      errno = ENOENT;
-+      return -1;
-+}
-+
-+/*
-+ * ether_line():
-+ * This function parses a line from the /etc/ethers file and fills in the passed
-+ * ``struct ether_addr'' and character buffer with the Ethernet address and host
-+ * name on the line.
-+ * It returns zero if the line was successfully parsed and -1 if not.
-+ */
-+int ether_line(const char *l, struct ether_addr *e, char *hostname)
-+{
-+      unsigned int i[6];
-+
-+#define S2(arg) #arg
-+#define S1(arg) S2(arg)
-+      static const char fmt[] = " %x:%x:%x:%x:%x:%x"
-+          " %" S1(MAXHOSTNAMELEN) "s\n";
-+#undef S2
-+#undef S1
-+
-+      assert(l != NULL);
-+      assert(e != NULL);
-+      assert(hostname != NULL);
-+
-+      if (sscanf(l, fmt,
-+          &i[0], &i[1], &i[2], &i[3], &i[4], &i[5], hostname) == 7) {
-+              e->ether_addr_octet[0] = (unsigned char)i[0];
-+              e->ether_addr_octet[1] = (unsigned char)i[1];
-+              e->ether_addr_octet[2] = (unsigned char)i[2];
-+              e->ether_addr_octet[3] = (unsigned char)i[3];
-+              e->ether_addr_octet[4] = (unsigned char)i[4];
-+              e->ether_addr_octet[5] = (unsigned char)i[5];
-+              return 0;
-+      }
-+      errno = EINVAL;
-+      return -1;
-+}
--- 
-1.7.9.5
-
diff --git a/toolchain/musl/patches-0.9.8/002-no_mips_fpu.patch b/toolchain/musl/patches-0.9.8/002-no_mips_fpu.patch
deleted file mode 100644 (file)
index 92af325..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-diff -urN musl-0.9.7/src/setjmp/mips/longjmp.s musl-0.9.7.new/src/setjmp/mips/longjmp.s
---- musl-0.9.7/src/setjmp/mips/longjmp.s       2012-11-23 17:03:07.000000000 +0100
-+++ musl-0.9.7.new/src/setjmp/mips/longjmp.s   2012-11-23 21:52:57.353668480 +0100
-@@ -10,21 +10,7 @@
-       bne     $2, $0, 1f
-       nop
-       addu    $2, $2, 1
--1:    lw      $8,  48($4)
--      ctc1    $8,  $31
--      lwc1    $20, 56($4)
--      lwc1    $21, 60($4)
--      lwc1    $22, 64($4)
--      lwc1    $23, 68($4)
--      lwc1    $24, 72($4)
--      lwc1    $25, 76($4)
--      lwc1    $26, 80($4)
--      lwc1    $27, 84($4)
--      lwc1    $28, 88($4)
--      lwc1    $29, 92($4)
--      lwc1    $30, 96($4)
--      lwc1    $31, 100($4)
--      lw      $ra,  0($4)
-+1:    lw      $ra,  0($4)
-       lw      $sp,  4($4)
-       lw      $16,  8($4)
-       lw      $17, 12($4)
-diff -urN musl-0.9.7/src/setjmp/mips/setjmp.s musl-0.9.7.new/src/setjmp/mips/setjmp.s
---- musl-0.9.7/src/setjmp/mips/setjmp.s        2012-11-23 17:03:07.000000000 +0100
-+++ musl-0.9.7.new/src/setjmp/mips/setjmp.s    2012-11-23 21:52:33.713667876 +0100
-@@ -21,19 +21,5 @@
-       sw      $23, 36($4)
-       sw      $30, 40($4)
-       sw      $28, 44($4)
--      cfc1    $8, $31
--      sw      $8,  48($4)
--      swc1    $20, 56($4)
--      swc1    $21, 60($4)
--      swc1    $22, 64($4)
--      swc1    $23, 68($4)
--      swc1    $24, 72($4)
--      swc1    $25, 76($4)
--      swc1    $26, 80($4)
--      swc1    $27, 84($4)
--      swc1    $28, 88($4)
--      swc1    $29, 92($4)
--      swc1    $30, 96($4)
--      swc1    $31, 100($4)
-       jr      $ra
-       li      $2, 0
diff --git a/toolchain/musl/patches-0.9.8/003-in_h_are_4_equal_parenthesis.patch b/toolchain/musl/patches-0.9.8/003-in_h_are_4_equal_parenthesis.patch
deleted file mode 100644 (file)
index 41aaf5d..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-diff -urN musl-0.9.8/include/netinet/in.h musl-0.9.8.new/include/netinet/in.h
---- musl-0.9.8/include/netinet/in.h    2013-01-25 14:14:07.000000000 +0100
-+++ musl-0.9.8.new/include/netinet/in.h        2013-01-29 21:43:46.843051396 +0100
-@@ -141,7 +141,7 @@
-         (IN6_IS_ADDR_MULTICAST(a) && ((((uint8_t *) (a))[1] & 0xf) == 0xe))
- #define __ARE_4_EQUAL(a,b) \
--      (!( 0[a]-0[b] | 1[a]-1[b] | 2[a]-2[b] | 3[a]-3[b] ))
-+      (!( (0[a]-0[b]) | (1[a]-1[b]) | (2[a]-2[b]) | (3[a]-3[b]) ))
- #define IN6_ARE_ADDR_EQUAL(a,b) \
-       __ARE_4_EQUAL((const uint32_t *)(a), (const uint32_t *)(b))
diff --git a/toolchain/musl/patches-0.9.8/004-wchar_include.patch b/toolchain/musl/patches-0.9.8/004-wchar_include.patch
deleted file mode 100644 (file)
index 2f36ae5..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
---- a/arch/arm/bits/alltypes.h.sh
-+++ b/arch/arm/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF unsigned wchar_t;
---- a/arch/i386/bits/alltypes.h.sh
-+++ b/arch/i386/bits/alltypes.h.sh
-@@ -25,6 +25,7 @@ TYPEDEF __builtin_va_list va_list;
- #else
- TYPEDEF struct __va_list * va_list;
- #endif
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- #ifdef __WCHAR_TYPE__
---- a/arch/microblaze/bits/alltypes.h.sh
-+++ b/arch/microblaze/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/mips/bits/alltypes.h.sh
-+++ b/arch/mips/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/powerpc/bits/alltypes.h.sh
-+++ b/arch/powerpc/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF long wchar_t;
---- a/arch/x86_64/bits/alltypes.h.sh
-+++ b/arch/x86_64/bits/alltypes.h.sh
-@@ -20,6 +20,7 @@ TYPEDEF unsigned long size_t;
- TYPEDEF long ssize_t;
- TYPEDEF long ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
diff --git a/toolchain/musl/patches-0.9.8/005-install_portability.patch b/toolchain/musl/patches-0.9.8/005-install_portability.patch
deleted file mode 100644 (file)
index 3e018c6..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
---- a/Makefile
-+++ b/Makefile
-@@ -116,16 +116,20 @@ tools/musl-gcc: config.mak
-       chmod +x $@
- $(DESTDIR)$(bindir)/%: tools/%
--      install -D $< $@
-+      mkdir -p $(dir $@)
-+      install $< $@
- $(DESTDIR)$(libdir)/%.so: lib/%.so
--      install -D -m 755 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 755 $< $@
- $(DESTDIR)$(libdir)/%: lib/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(includedir)/%: include/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(LDSO_PATHNAME): $(DESTDIR)$(syslibdir)
-       ln -sf $(libdir)/libc.so $@ || true
diff --git a/toolchain/musl/patches-0.9.9/001-arm_shared_libs_regression_fix.patch b/toolchain/musl/patches-0.9.9/001-arm_shared_libs_regression_fix.patch
deleted file mode 100644 (file)
index c6bfac8..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-From d432b2c057fc64256645422382c2f7e32c45b3cc Mon Sep 17 00:00:00 2001
-From: Rich Felker <dalias@aerifal.cx>
-Date: Sun, 03 Feb 2013 06:26:33 +0000
-Subject: fix regression that made shared libs crash on arm
-
----
-diff --git a/crt/arm/crti.s b/crt/arm/crti.s
-index 2f658b7..35ae6ae 100644
---- a/crt/arm/crti.s
-+++ b/crt/arm/crti.s
-@@ -5,6 +5,8 @@ _init:
- .weak __fini_array_start
- .weak __fini_array_end
-+.hidden __fini_array_start
-+.hidden __fini_array_end
- .section .fini
- .global _fini
-diff --git a/crt/arm/crtn.s b/crt/arm/crtn.s
-index 928e068..eb0e883 100644
---- a/crt/arm/crtn.s
-+++ b/crt/arm/crtn.s
-@@ -1,5 +1,7 @@
- .weak __init_array_start
- .weak __init_array_end
-+.hidden __init_array_start
-+.hidden __init_array_end
- .section .init
-       adr lr, 1f
---
-cgit v0.9.0.3-65-g4555
diff --git a/toolchain/musl/patches-0.9.9/002-bsd_ether_h.patch b/toolchain/musl/patches-0.9.9/002-bsd_ether_h.patch
deleted file mode 100644 (file)
index be3a021..0000000
+++ /dev/null
@@ -1,219 +0,0 @@
-Date: Sat, 20 Oct 2012 22:15:44 +0200
-From: Abdoulaye Walsimou Gaye <awg@...toolkit.org>
-To: musl@...ts.openwall.com
-Cc: Abdoulaye Walsimou Gaye <awg@...toolkit.org>
-Subject: [PATCH 3/4] Import BSD functions defined in <netinet/ether.h> from NetBSD
-
-Signed-off-by: Abdoulaye Walsimou Gaye <awg@...toolkit.org>
----
- include/netinet/ether.h |   14 ++++
- src/network/ethers.c    |  180 +++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 194 insertions(+)
- create mode 100644 include/netinet/ether.h
- create mode 100644 src/network/ethers.c
-
-diff --git a/include/netinet/ether.h b/include/netinet/ether.h
-new file mode 100644
-index 0000000..44c614e
---- /dev/null
-+++ b/include/netinet/ether.h
-@@ -0,0 +1,10 @@
-+#ifndef _NETINET_ETHER_H
-+#define _NETINET_ETHER_H
-+
-+char  *ether_ntoa(const struct ether_addr *);
-+struct        ether_addr *ether_aton(const char *);
-+int   ether_ntohost(char *, const struct ether_addr *);
-+int   ether_hostton(const char *, struct ether_addr *);
-+int   ether_line(const char *, struct ether_addr *, char *);
-+
-+#endif /* !_NETINET_ETHER_H */
-diff --git a/src/network/ethers.c b/src/network/ethers.c
-new file mode 100644
-index 0000000..8014581
---- /dev/null
-+++ b/src/network/ethers.c
-@@ -0,0 +1,180 @@
-+/* Origin NetBSD: src/lib/libc/net/ethers.c */
-+
-+/*
-+ * ethers(3N) a la Sun.
-+ *
-+ * Written by Roland McGrath <roland@...b.com> 10/14/93.
-+ * Public domain.
-+ *
-+ * port for musl by Abdoulaye Walsimou GAYE <awg@...toolkit.org> 2012/10/15
-+ */
-+
-+#define _BSD_SOURCE
-+#include <net/ethernet.h>
-+#include <netinet/ether.h>
-+
-+#include <sys/param.h>
-+#include <assert.h>
-+#include <errno.h>
-+#include <paths.h>
-+#include <stdio.h>
-+#include <stdlib.h>
-+#include <string.h>
-+
-+#ifndef _PATH_ETHERS
-+#define _PATH_ETHERS "/etc/ethers"
-+#endif
-+
-+/*
-+ * ether_ntoa():
-+ * This function converts this structure into an ASCII string of the form
-+ * ``xx:xx:xx:xx:xx:xx'', consisting of 6 hexadecimal numbers separated
-+ * by colons.  It returns a pointer to a static buffer that is reused for
-+ * each call.
-+ */
-+char *ether_ntoa(const struct ether_addr *e)
-+{
-+      static char a[18];
-+
-+      assert(e != NULL);
-+
-+      (void) snprintf(a, sizeof a, "%02x:%02x:%02x:%02x:%02x:%02x",
-+          e->ether_addr_octet[0], e->ether_addr_octet[1],
-+          e->ether_addr_octet[2], e->ether_addr_octet[3],
-+          e->ether_addr_octet[4], e->ether_addr_octet[5]);
-+      return a;
-+}
-+
-+/*
-+ * ether_aton():
-+ * This function converts an ASCII string of the same form and to a structure
-+ * containing the 6 octets of the address.  It returns a pointer to a
-+ * static structure that is reused for each call.
-+ */
-+struct ether_addr *ether_aton(const char *s)
-+{
-+      static struct ether_addr n;
-+      unsigned int i[6];
-+
-+      assert(s != NULL);
-+
-+      if (sscanf(s, " %x:%x:%x:%x:%x:%x ", &i[0], &i[1],
-+          &i[2], &i[3], &i[4], &i[5]) == 6) {
-+              n.ether_addr_octet[0] = (unsigned char)i[0];
-+              n.ether_addr_octet[1] = (unsigned char)i[1];
-+              n.ether_addr_octet[2] = (unsigned char)i[2];
-+              n.ether_addr_octet[3] = (unsigned char)i[3];
-+              n.ether_addr_octet[4] = (unsigned char)i[4];
-+              n.ether_addr_octet[5] = (unsigned char)i[5];
-+              return &n;
-+      }
-+      return NULL;
-+}
-+
-+/*
-+ * ether_ntohost():
-+ * This function interrogates the data base mapping host names to Ethernet
-+ * addresses, /etc/ethers.
-+ * It looks up the given Ethernet address and writes the associated host name
-+ * into the character buffer passed.
-+ * It returns zero if it finds the requested host name and -1 if not.
-+ */
-+int ether_ntohost(char *hostname, const struct ether_addr *e)
-+{
-+      FILE *f;
-+      char *p;
-+      size_t len;
-+      struct ether_addr try;
-+
-+      assert(hostname != NULL);
-+      assert(e != NULL);
-+
-+      f = fopen(_PATH_ETHERS, "r");
-+      if (f == NULL)
-+              return -1;
-+      while ((p = fgetln(f, &len)) != NULL) {
-+              if (p[len - 1] != '\n')
-+                      continue;               /* skip lines w/o \n */
-+              p[--len] = '\0';
-+              if (ether_line(p, &try, hostname) == 0 &&
-+                  memcmp(&try, e, sizeof try) == 0) {
-+                      (void)fclose(f);
-+                      return 0;
-+              }
-+      }
-+      (void)fclose(f);
-+      errno = ENOENT;
-+      return -1;
-+}
-+
-+/*
-+ * ether_hostton():
-+ * This function interrogates the data base mapping host names to Ethernet
-+ * addresses, /etc/ethers.
-+ * It looks up the given host name and writes the associated Ethernet address
-+ * into the structure passed.
-+ * It returns zero if it finds the requested address and -1 if not.
-+ */
-+int ether_hostton(const char *hostname, struct ether_addr *e)
-+{
-+      FILE *f;
-+      char *p;
-+      size_t len;
-+      char try[MAXHOSTNAMELEN + 1];
-+
-+      assert(hostname != NULL);
-+      assert(e != NULL);
-+
-+      f = fopen(_PATH_ETHERS, "r");
-+      if (f==NULL)
-+              return -1;
-+
-+      while ((p = fgetln(f, &len)) != NULL) {
-+              if (p[len - 1] != '\n')
-+                      continue;               /* skip lines w/o \n */
-+              p[--len] = '\0';
-+              if (ether_line(p, e, try) == 0 && strcmp(hostname, try) == 0) {
-+                      (void)fclose(f);
-+                      return 0;
-+              }
-+      }
-+      (void)fclose(f);
-+      errno = ENOENT;
-+      return -1;
-+}
-+
-+/*
-+ * ether_line():
-+ * This function parses a line from the /etc/ethers file and fills in the passed
-+ * ``struct ether_addr'' and character buffer with the Ethernet address and host
-+ * name on the line.
-+ * It returns zero if the line was successfully parsed and -1 if not.
-+ */
-+int ether_line(const char *l, struct ether_addr *e, char *hostname)
-+{
-+      unsigned int i[6];
-+
-+#define S2(arg) #arg
-+#define S1(arg) S2(arg)
-+      static const char fmt[] = " %x:%x:%x:%x:%x:%x"
-+          " %" S1(MAXHOSTNAMELEN) "s\n";
-+#undef S2
-+#undef S1
-+
-+      assert(l != NULL);
-+      assert(e != NULL);
-+      assert(hostname != NULL);
-+
-+      if (sscanf(l, fmt,
-+          &i[0], &i[1], &i[2], &i[3], &i[4], &i[5], hostname) == 7) {
-+              e->ether_addr_octet[0] = (unsigned char)i[0];
-+              e->ether_addr_octet[1] = (unsigned char)i[1];
-+              e->ether_addr_octet[2] = (unsigned char)i[2];
-+              e->ether_addr_octet[3] = (unsigned char)i[3];
-+              e->ether_addr_octet[4] = (unsigned char)i[4];
-+              e->ether_addr_octet[5] = (unsigned char)i[5];
-+              return 0;
-+      }
-+      errno = EINVAL;
-+      return -1;
-+}
--- 
-1.7.9.5
-
diff --git a/toolchain/musl/patches-0.9.9/003-in_h_are_4_equal_parenthesis.patch b/toolchain/musl/patches-0.9.9/003-in_h_are_4_equal_parenthesis.patch
deleted file mode 100644 (file)
index 41aaf5d..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-diff -urN musl-0.9.8/include/netinet/in.h musl-0.9.8.new/include/netinet/in.h
---- musl-0.9.8/include/netinet/in.h    2013-01-25 14:14:07.000000000 +0100
-+++ musl-0.9.8.new/include/netinet/in.h        2013-01-29 21:43:46.843051396 +0100
-@@ -141,7 +141,7 @@
-         (IN6_IS_ADDR_MULTICAST(a) && ((((uint8_t *) (a))[1] & 0xf) == 0xe))
- #define __ARE_4_EQUAL(a,b) \
--      (!( 0[a]-0[b] | 1[a]-1[b] | 2[a]-2[b] | 3[a]-3[b] ))
-+      (!( (0[a]-0[b]) | (1[a]-1[b]) | (2[a]-2[b]) | (3[a]-3[b]) ))
- #define IN6_ARE_ADDR_EQUAL(a,b) \
-       __ARE_4_EQUAL((const uint32_t *)(a), (const uint32_t *)(b))
diff --git a/toolchain/musl/patches-0.9.9/004-wchar_include.patch b/toolchain/musl/patches-0.9.9/004-wchar_include.patch
deleted file mode 100644 (file)
index 2f36ae5..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
---- a/arch/arm/bits/alltypes.h.sh
-+++ b/arch/arm/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF unsigned wchar_t;
---- a/arch/i386/bits/alltypes.h.sh
-+++ b/arch/i386/bits/alltypes.h.sh
-@@ -25,6 +25,7 @@ TYPEDEF __builtin_va_list va_list;
- #else
- TYPEDEF struct __va_list * va_list;
- #endif
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- #ifdef __WCHAR_TYPE__
---- a/arch/microblaze/bits/alltypes.h.sh
-+++ b/arch/microblaze/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/mips/bits/alltypes.h.sh
-+++ b/arch/mips/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
---- a/arch/powerpc/bits/alltypes.h.sh
-+++ b/arch/powerpc/bits/alltypes.h.sh
-@@ -21,6 +21,7 @@ TYPEDEF int ssize_t;
- TYPEDEF int ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF long wchar_t;
---- a/arch/x86_64/bits/alltypes.h.sh
-+++ b/arch/x86_64/bits/alltypes.h.sh
-@@ -20,6 +20,7 @@ TYPEDEF unsigned long size_t;
- TYPEDEF long ssize_t;
- TYPEDEF long ptrdiff_t;
- TYPEDEF __builtin_va_list va_list;
-+#define __gnuc_va_list va_list
- #ifndef __cplusplus
- TYPEDEF int wchar_t;
diff --git a/toolchain/musl/patches-0.9.9/005-install_portability.patch b/toolchain/musl/patches-0.9.9/005-install_portability.patch
deleted file mode 100644 (file)
index 3e018c6..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
---- a/Makefile
-+++ b/Makefile
-@@ -116,16 +116,20 @@ tools/musl-gcc: config.mak
-       chmod +x $@
- $(DESTDIR)$(bindir)/%: tools/%
--      install -D $< $@
-+      mkdir -p $(dir $@)
-+      install $< $@
- $(DESTDIR)$(libdir)/%.so: lib/%.so
--      install -D -m 755 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 755 $< $@
- $(DESTDIR)$(libdir)/%: lib/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(includedir)/%: include/%
--      install -D -m 644 $< $@
-+      mkdir -p $(dir $@)
-+      install -m 644 $< $@
- $(DESTDIR)$(LDSO_PATHNAME): $(DESTDIR)$(syslibdir)
-       ln -sf $(libdir)/libc.so $@ || true