summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--mk/modules.mk2
-rw-r--r--mk/vars.mk5
-rw-r--r--package/MesaLib/Makefile2
-rw-r--r--package/MesaLib/patches/patch-src_gallium_auxiliary_util_u_debug_symbol_c26
-rw-r--r--package/MesaLib/patches/patch-src_glsl_strtod_c32
-rw-r--r--package/MesaLib/patches/patch-src_mesa_main_imports_c33
-rw-r--r--package/boost/Makefile2
-rw-r--r--package/fltk/Makefile4
-rw-r--r--package/jamvm/Makefile10
-rw-r--r--package/libnl/Makefile2
-rw-r--r--package/libnl/patches/patch-lib_addr_c16
-rw-r--r--package/libxml2/Makefile5
-rw-r--r--package/libxml2/patches/patch-configure11
-rw-r--r--package/mesa-demos/Makefile4
-rw-r--r--package/openafs/Makefile49
-rw-r--r--package/openafs/patches/patch-configure1183
-rw-r--r--package/openafs/patches/patch-configure-libafs1181
-rw-r--r--package/openafs/patches/patch-src_afs_afs_fetchstore_c12
-rw-r--r--package/openafs/patches/patch-src_afs_afs_memcache_c12
-rw-r--r--package/openafs/patches/patch-src_auth_userok_c10
-rw-r--r--package/openafs/patches/patch-src_comerr_Makefile_in38
-rw-r--r--package/openafs/patches/patch-src_comerr_error_table_y10
-rw-r--r--package/openafs/patches/patch-src_comerr_internal_h8
-rw-r--r--package/openafs/patches/patch-src_config_Makefile_config_in15
-rw-r--r--package/openafs/patches/patch-src_config_Makefile_in23
-rw-r--r--package/openafs/patches/patch-src_des_Makefile_in73
-rw-r--r--package/openafs/patches/patch-src_des_read_pssword_c52
-rw-r--r--package/openafs/patches/patch-src_libafs_MakefileProto_LINUX_in11
-rw-r--r--package/openafs/patches/patch-src_lwp_iomgr_c12
-rw-r--r--package/openafs/patches/patch-src_lwp_waitkey_c37
-rw-r--r--package/openafs/patches/patch-src_rx_rx_lwp_c10
-rw-r--r--package/openafs/patches/patch-src_rx_rx_trace_c10
-rw-r--r--package/openafs/patches/patch-src_rxgen_Makefile_in19
-rw-r--r--package/openafs/patches/patch-src_rxkad_rxkad_client_c10
-rw-r--r--package/openafs/patches/patch-src_shlibafsrpc_Makefile_in11
-rw-r--r--package/openafs/patches/patch-src_sys_glue_c12
-rw-r--r--package/openafs/src/src/comerr/internal.c22
-rw-r--r--package/rsync/Makefile2
-rw-r--r--package/rsync/patches/patch-Makefile_in11
-rw-r--r--package/uclibc++/Makefile2
-rw-r--r--package/uclibc++/patches/patch-include_unwind-cxx_h21
-rw-r--r--package/vte/Makefile37
-rw-r--r--target/arm/kernel.config.sharp-zaurus599
-rw-r--r--target/linux/config/Config.in.misc3
-rw-r--r--target/linux/patches/3.9.11/arm-spitz.patch27
-rw-r--r--target/ppc/kernel.config407
-rw-r--r--target/ppc64/kernel.config421
-rw-r--r--toolchain/binutils/patches/2.23.2/arm-whitespace.patch23
-rw-r--r--toolchain/gcc/Makefile4
-rw-r--r--toolchain/gcc/patches/4.7.3/musl-cross.patch36
-rw-r--r--toolchain/gcc/patches/4.7.3/ppc-uclibc-cmath.patch217
-rw-r--r--toolchain/musl/Makefile.inc4
-rw-r--r--toolchain/musl/patches/0.9.13/musl-git.patch8837
53 files changed, 4388 insertions, 9237 deletions
diff --git a/mk/modules.mk b/mk/modules.mk
index ca1bf178c..5722d9800 100644
--- a/mk/modules.mk
+++ b/mk/modules.mk
@@ -1204,7 +1204,7 @@ $(eval $(call KMOD_template,SND_BCM2835,snd-bcm2835,\
#,65))
$(eval $(call KMOD_template,USB_VIDEO_CLASS,usb-video-class,\
- $(MODULES_DIR)/kernel/drivers/media/video/uvc/uvcvideo \
+ $(MODULES_DIR)/kernel/drivers/media/usb/uvc/uvcvideo \
,70))
$(eval $(call KMOD_template,USB_GSPCA,usb-gspca,\
diff --git a/mk/vars.mk b/mk/vars.mk
index e22a46beb..5c291f604 100644
--- a/mk/vars.mk
+++ b/mk/vars.mk
@@ -99,7 +99,7 @@ TARGET_LD:= ${TARGET_COMPILER_PREFIX}ld
TARGET_CPPFLAGS:=
TARGET_CFLAGS:= $(TARGET_CFLAGS_ARCH) -fwrapv -fno-ident -fhonour-copts $(ADK_TARGET_ABI_CFLAGS)
-TARGET_CFLAGS_LIBC:= $(TARGET_CFLAGS_ARCH) -fwrapv -fno-ident -fhonour-copts $(TARGET_OPTIMIZATION) -fPIC
+TARGET_CFLAGS_LIBC:= $(TARGET_CFLAGS_ARCH) -fwrapv -fno-ident -fhonour-copts $(TARGET_OPTIMIZATION)
TARGET_CXXFLAGS:= $(TARGET_CFLAGS_ARCH) -fwrapv -fno-ident
TARGET_LDFLAGS:= -L$(STAGING_TARGET_DIR)/lib -L$(STAGING_TARGET_DIR)/usr/lib \
-Wl,-O2 -Wl,-rpath -Wl,/usr/lib \
@@ -167,7 +167,8 @@ TARGET_CONFIGURE_OPTS= PATH='${TARGET_PATH}' \
CC='$(TARGET_CC)' \
GCC='$(TARGET_CC)' \
CXX='$(TARGET_CXX)' \
- CROSS='$(TARGET_CROSS)'
+ CROSS='$(TARGET_CROSS)' \
+ ARCH=${ARCH}
HOST_CONFIGURE_OPTS= CC_FOR_BUILD='${CC_FOR_BUILD}' \
CPPFLAGS_FOR_BUILD='${CPPFLAGS_FOR_BUILD}' \
diff --git a/package/MesaLib/Makefile b/package/MesaLib/Makefile
index d62773bd3..008c4eb4f 100644
--- a/package/MesaLib/Makefile
+++ b/package/MesaLib/Makefile
@@ -5,7 +5,7 @@ include $(TOPDIR)/rules.mk
PKG_NAME:= MesaLib
PKG_VERSION:= 8.0.5
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= cda5d101f43b8784fa60bdeaca4056f2
PKG_DESCR:= MESA library
PKG_SECTION:= libs
diff --git a/package/MesaLib/patches/patch-src_gallium_auxiliary_util_u_debug_symbol_c b/package/MesaLib/patches/patch-src_gallium_auxiliary_util_u_debug_symbol_c
new file mode 100644
index 000000000..f1d92ca8c
--- /dev/null
+++ b/package/MesaLib/patches/patch-src_gallium_auxiliary_util_u_debug_symbol_c
@@ -0,0 +1,26 @@
+--- Mesa-8.0.5.orig/src/gallium/auxiliary/util/u_debug_symbol.c 2012-10-24 21:03:59.000000000 +0200
++++ Mesa-8.0.5/src/gallium/auxiliary/util/u_debug_symbol.c 2013-09-25 17:45:12.000000000 +0200
+@@ -151,23 +151,6 @@ debug_symbol_name_dbghelp(const void *ad
+ }
+ #endif
+
+-#ifdef __GLIBC__
+-#include <execinfo.h>
+-
+-/* This can only provide dynamic symbols, or binary offsets into a file.
+- *
+- * To fix this, post-process the output with tools/addr2line.sh
+- */
+-static INLINE void
+-debug_symbol_name_glibc(const void *addr, char* buf, unsigned size)
+-{
+- char** syms = backtrace_symbols((void**)&addr, 1);
+- strncpy(buf, syms[0], size);
+- buf[size - 1] = 0;
+- free(syms);
+-}
+-#endif
+-
+ void
+ debug_symbol_name(const void *addr, char* buf, unsigned size)
+ {
diff --git a/package/MesaLib/patches/patch-src_glsl_strtod_c b/package/MesaLib/patches/patch-src_glsl_strtod_c
new file mode 100644
index 000000000..ce6514dbb
--- /dev/null
+++ b/package/MesaLib/patches/patch-src_glsl_strtod_c
@@ -0,0 +1,32 @@
+--- Mesa-8.0.5.orig/src/glsl/strtod.c 2012-10-24 21:03:59.000000000 +0200
++++ Mesa-8.0.5/src/glsl/strtod.c 2013-09-25 17:34:06.000000000 +0200
+@@ -25,14 +25,6 @@
+
+
+ #include <stdlib.h>
+-
+-#ifdef _GNU_SOURCE
+-#include <locale.h>
+-#ifdef __APPLE__
+-#include <xlocale.h>
+-#endif
+-#endif
+-
+ #include "strtod.h"
+
+
+@@ -44,14 +36,5 @@
+ double
+ glsl_strtod(const char *s, char **end)
+ {
+-#if defined(_GNU_SOURCE) && !defined(__CYGWIN__) && !defined(__FreeBSD__) && \
+- !defined(__HAIKU__)
+- static locale_t loc = NULL;
+- if (!loc) {
+- loc = newlocale(LC_CTYPE_MASK, "C", NULL);
+- }
+- return strtod_l(s, end, loc);
+-#else
+ return strtod(s, end);
+-#endif
+ }
diff --git a/package/MesaLib/patches/patch-src_mesa_main_imports_c b/package/MesaLib/patches/patch-src_mesa_main_imports_c
new file mode 100644
index 000000000..10cbca86a
--- /dev/null
+++ b/package/MesaLib/patches/patch-src_mesa_main_imports_c
@@ -0,0 +1,33 @@
+--- Mesa-8.0.5.orig/src/mesa/main/imports.c 2012-10-24 21:03:59.000000000 +0200
++++ Mesa-8.0.5/src/mesa/main/imports.c 2013-09-25 17:41:11.000000000 +0200
+@@ -49,14 +49,6 @@
+ #include "mtypes.h"
+ #include "version.h"
+
+-#ifdef _GNU_SOURCE
+-#include <locale.h>
+-#ifdef __APPLE__
+-#include <xlocale.h>
+-#endif
+-#endif
+-
+-
+ #define MAXSTRING 4000 /* for vsnprintf() */
+
+ #ifdef WIN32
+@@ -766,14 +758,7 @@ _mesa_strdup( const char *s )
+ float
+ _mesa_strtof( const char *s, char **end )
+ {
+-#if defined(_GNU_SOURCE) && !defined(__CYGWIN__) && !defined(__FreeBSD__) && \
+- !defined(ANDROID) && !defined(__HAIKU__)
+- static locale_t loc = NULL;
+- if (!loc) {
+- loc = newlocale(LC_CTYPE_MASK, "C", NULL);
+- }
+- return strtof_l(s, end, loc);
+-#elif defined(_ISOC99_SOURCE) || (defined(_XOPEN_SOURCE) && _XOPEN_SOURCE >= 600)
++#if defined(_ISOC99_SOURCE) || (defined(_XOPEN_SOURCE) && _XOPEN_SOURCE >= 600)
+ return strtof(s, end);
+ #else
+ return (float)strtod(s, end);
diff --git a/package/boost/Makefile b/package/boost/Makefile
index 168b20070..271b2937c 100644
--- a/package/boost/Makefile
+++ b/package/boost/Makefile
@@ -15,7 +15,7 @@ PKG_SITES:= ${MASTER_SITE_SOURCEFORGE:=boost/}
DISTFILES:= boost_1_54_0.tar.gz
WRKDIST= ${WRKDIR}/${PKG_NAME}_1_54_0
-PKG_ARCH_DEPENDS:= !mips
+PKG_LIBC_DEPENDS:= eglibc glibc musl
PKG_SUBPKGS:= BOOST BOOST_DEV
PKGSD_BOOST_DEV:= boost header files
diff --git a/package/fltk/Makefile b/package/fltk/Makefile
index 8ac5c3c21..de5cb6459 100644
--- a/package/fltk/Makefile
+++ b/package/fltk/Makefile
@@ -5,7 +5,7 @@ include $(TOPDIR)/rules.mk
PKG_NAME:= fltk
PKG_VERSION:= 1.3.2
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= 9f7e707d4fb7a5a76f0f9b73ff70623d
PKG_DESCR:= fast light toolkit
PKG_SECTION:= libs
@@ -25,7 +25,7 @@ include $(TOPDIR)/mk/package.mk
$(eval $(call PKG_template,LIBFLTK,libfltk,$(PKG_VERSION)-${PKG_RELEASE},${PKG_DEPENDS},${PKG_DESCR},${PKG_SECTION}))
-LIBRARIES:=-nodefaultlibs -luClibc++ -lgcc -lm -lc
+LIBRARIES:=-nodefaultlibs -luClibc++ -lgcc -lgcc_s -lm -lc
ifeq ($(ADK_TOOLCHAIN_GCC_USE_SSP),y)
LIBRARIES+=-lssp -lssp_nonshared
endif
diff --git a/package/jamvm/Makefile b/package/jamvm/Makefile
index aeb37e177..da0b141af 100644
--- a/package/jamvm/Makefile
+++ b/package/jamvm/Makefile
@@ -5,7 +5,7 @@ include ${TOPDIR}/rules.mk
PKG_NAME:= jamvm
PKG_VERSION:= 1.5.4
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= 7654e9657691f5f09c4f481ed4686176
PKG_DESCR:= A Java Virtual Machine (JVM) implementation
PKG_SECTION:= lang
@@ -14,7 +14,7 @@ PKG_BUILDDEP:= libffi zlib
PKG_URL:= http://jamvm.sourceforge.net
PKG_SITES:= ${MASTER_SITE_SOURCEFORGE:=jamvm/}
-PKG_ARCH_DEPENDS:= !cris !mips !avr32
+PKG_ARCH_DEPENDS:= !cris !avr32
include ${TOPDIR}/mk/package.mk
@@ -24,6 +24,12 @@ BUILD_STYLE:= manual
INSTALL_STYLE:= manual
CONFIGURE_ARGS+= --enable-ffi
+ifeq ($(ARCH),mips)
+CONFIGURE_ARGS+= --disable-tls
+endif
+ifeq ($(ARCH),arm)
+CONFIGURE_ARGS+= --disable-tls
+endif
do-build:
${INSTALL_DIR} ${WRKINST}/usr/bin
diff --git a/package/libnl/Makefile b/package/libnl/Makefile
index fc40fd2ac..68b45bf0c 100644
--- a/package/libnl/Makefile
+++ b/package/libnl/Makefile
@@ -5,7 +5,7 @@ include ${TOPDIR}/rules.mk
PKG_NAME:= libnl
PKG_VERSION:= 3.2.22
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= 2e1c889494d274aca24ce5f6a748e66e
PKG_DESCR:= Netlink library
PKG_SECTION:= libs
diff --git a/package/libnl/patches/patch-lib_addr_c b/package/libnl/patches/patch-lib_addr_c
new file mode 100644
index 000000000..7e1622bc4
--- /dev/null
+++ b/package/libnl/patches/patch-lib_addr_c
@@ -0,0 +1,16 @@
+--- libnl-3.2.22.orig/lib/addr.c 2013-04-05 10:35:44.000000000 +0200
++++ libnl-3.2.22/lib/addr.c 2013-09-26 11:13:50.000000000 +0200
+@@ -33,6 +33,13 @@
+ #include <netlink/addr.h>
+ #include <linux/socket.h>
+
++#ifndef PF_RDS
++#define PF_RDS 21
++#endif
++#ifndef AF_RDS
++#define AF_RDS PF_RDS
++#endif
++
+ /* All this DECnet stuff is stolen from iproute2, thanks to whoever wrote
+ * this, probably Alexey. */
+ static inline uint16_t dn_ntohs(uint16_t addr)
diff --git a/package/libxml2/Makefile b/package/libxml2/Makefile
index 2ecd71dd5..602d2d551 100644
--- a/package/libxml2/Makefile
+++ b/package/libxml2/Makefile
@@ -5,7 +5,7 @@ include ${TOPDIR}/rules.mk
PKG_NAME:= libxml2
PKG_VERSION:= 2.9.1
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= 9c0cfef285d5c4a5c80d00904ddab380
PKG_DESCR:= XML C parser and toolkit
PKG_SECTION:= libs
@@ -63,6 +63,9 @@ CONFIGURE_ARGS+= --without-c14n \
--with-xptr \
--with-zlib
+pre-configure:
+ ${INSTALL_DIR} ${STAGING_DIR}/usr/lib/site-packages
+
libxml2-install:
${INSTALL_DIR} ${IDIR_LIBXML2}/usr/lib
${CP} ${WRKINST}/usr/lib/libxml2.so* ${IDIR_LIBXML2}/usr/lib
diff --git a/package/libxml2/patches/patch-configure b/package/libxml2/patches/patch-configure
index 13406bc62..2f9b3b5bf 100644
--- a/package/libxml2/patches/patch-configure
+++ b/package/libxml2/patches/patch-configure
@@ -1,5 +1,5 @@
--- libxml2-2.9.1.orig/configure 2013-04-19 09:36:11.000000000 +0200
-+++ libxml2-2.9.1/configure 2013-09-04 15:16:48.000000000 +0200
++++ libxml2-2.9.1/configure 2013-09-25 13:59:27.000000000 +0200
@@ -14010,17 +14010,17 @@ case ${host} in
esac
@@ -22,6 +22,15 @@
else
if test -x "$with_python/python.exe"
then
+@@ -14122,7 +14122,7 @@ fi
+ else
+ if test -d $with_python/lib/site-packages
+ then
+- PYTHON_SITE_PACKAGES=$with_python/lib/site-packages
++ PYTHON_SITE_PACKAGES=/usr/lib/python$PYTHON_VERSION/site-packages
+ else
+ PYTHON_SITE_PACKAGES=`$PYTHON -c "from distutils import sysconfig; print(sysconfig.get_python_lib())"`
+ fi
@@ -14148,7 +14148,7 @@ else
PYTHON_SUBDIR=
fi
diff --git a/package/mesa-demos/Makefile b/package/mesa-demos/Makefile
index 65506f4e7..a0ab20771 100644
--- a/package/mesa-demos/Makefile
+++ b/package/mesa-demos/Makefile
@@ -5,12 +5,12 @@ include $(TOPDIR)/rules.mk
PKG_NAME:= mesa-demos
PKG_VERSION:= 8.1.0
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= 4049d98dd4131212e2842b770f1b0fa5
PKG_DESCR:= MESA demo apps
PKG_SECTION:= misc
PKG_DEPENDS:= mesalib
-PKG_BUILDDEP:= MesaLib
+PKG_BUILDDEP:= MesaLib libglew
PKG_SITES:= ftp://ftp.freedesktop.org/pub/mesa/demos/${PKG_VERSION}/
PKG_SUBPKGS:= GLXINFO
diff --git a/package/openafs/Makefile b/package/openafs/Makefile
new file mode 100644
index 000000000..37b37980d
--- /dev/null
+++ b/package/openafs/Makefile
@@ -0,0 +1,49 @@
+# This file is part of the OpenADK project. OpenADK is copyrighted
+# material, please see the LICENCE file in the top-level directory.
+
+include $(TOPDIR)/rules.mk
+
+PKG_NAME:= openafs
+PKG_VERSION:= 1.6.5
+PKG_RELEASE:= 1
+PKG_MD5SUM:= e33e0b031760d4f90815d40b8ab3c540
+PKG_DESCR:= AFS implementation
+PKG_SECTION:= net/fs
+PKG_URL:= http://openafs.org
+PKG_SITES:= http://www.openafs.org/dl/openafs/${PKG_VERSION}/
+
+PKG_CFLINE_OPENAFS+= select ADK_KERNEL_KEYS
+
+DISTFILES:= ${PKG_NAME}-${PKG_VERSION}-src.tar.bz2
+
+include $(TOPDIR)/mk/package.mk
+
+$(eval $(call PKG_template,OPENAFS,openafs,$(PKG_VERSION)-${PKG_RELEASE},${PKG_DEPENDS},${PKG_DESCR},${PKG_SECTION}))
+
+XAKE_FLAGS+= GCC_HONOUR_COPTS=s
+CONFIGURE_ENV+= ac_cv_path_PATH_CPP=$(TARGET_CROSS)cpp
+CONFIGURE_ARGS:= --with-afs-sysname=$(ARCH)_linux26 \
+ --with-linux-kernel-headers=${LINUX_DIR} \
+ --disable-strip-binaries \
+ --disable-linux-syscall-probing
+
+openafs-install:
+ $(INSTALL_DIR) $(IDIR_OPENAFS)/usr/bin
+ $(INSTALL_DIR) $(IDIR_OPENAFS)/usr/lib
+ $(INSTALL_DIR) $(IDIR_OPENAFS)/usr/sbin
+ $(INSTALL_DIR) $(IDIR_OPENAFS)/usr/libexec/openafs
+ $(INSTALL_BIN) $(WRKINST)/usr/bin/* \
+ $(IDIR_OPENAFS)/usr/bin
+ $(INSTALL_BIN) $(WRKINST)/usr/sbin/* \
+ $(IDIR_OPENAFS)/usr/sbin
+ $(INSTALL_BIN) $(WRKINST)/usr/libexec/openafs/* \
+ $(IDIR_OPENAFS)/usr/libexec/openafs
+ $(CP) $(WRKINST)/usr/lib/*.so* \
+ $(IDIR_OPENAFS)/usr/lib
+ ${INSTALL_DIR} ${IDIR_OPENAFS}/etc/modules.d/
+ echo "libafs" > ${IDIR_OPENAFS}/etc/modules.d/90-libafs
+ ${INSTALL_DIR} ${IDIR_OPENAFS}/lib/modules/${KERNEL_VERSION}
+ $(CP) $(WRKINST)/usr/lib/openafs/libafs-${KERNEL_VERSION}.ko \
+ $(IDIR_OPENAFS)/lib/modules/${KERNEL_VERSION}/libafs.ko
+
+include ${TOPDIR}/mk/pkg-bottom.mk
diff --git a/package/openafs/patches/patch-configure b/package/openafs/patches/patch-configure
new file mode 100644
index 000000000..72205410d
--- /dev/null
+++ b/package/openafs/patches/patch-configure
@@ -0,0 +1,1183 @@
+--- openafs-1.6.5.orig/configure 2013-07-18 07:31:08.000000000 +0200
++++ openafs-1.6.5/configure 2013-09-23 21:55:38.235187280 +0200
+@@ -7258,7 +7258,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_is_uml=yes
+ else
+@@ -7590,8 +7590,8 @@ void conftest(void)
+
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+- echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ echo make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_linux_kbuild_requires_extra_cflags=no
+ else
+@@ -7664,7 +7664,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then :
+ else
+@@ -7750,7 +7750,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_config_h=yes
+ else
+@@ -7834,7 +7834,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_completion_h=yes
+ else
+@@ -7918,7 +7918,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_exportfs_h=yes
+ else
+@@ -8002,7 +8002,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_freezer_h=yes
+ else
+@@ -8086,7 +8086,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_key_type_h=yes
+ else
+@@ -8170,7 +8170,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_semaphore_h=yes
+ else
+@@ -8254,7 +8254,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_seq_file_h=yes
+ else
+@@ -8339,7 +8339,7 @@ struct vfs_path _test;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_type_struct_vfs_path_exists=yes
+ else
+@@ -8424,7 +8424,7 @@ struct address_space_operations _test; p
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_address_space_operations_has_write_begin=yes
+ else
+@@ -8509,7 +8509,7 @@ struct backing_dev_info _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_backing_dev_info_has_name=yes
+ else
+@@ -8594,7 +8594,7 @@ struct cred _test; printk("%x\n", &_test
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_cred_has_session_keyring=yes
+ else
+@@ -8679,7 +8679,7 @@ struct ctl_table _test; printk("%x\n", &
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_ctl_table_has_ctl_name=yes
+ else
+@@ -8764,7 +8764,7 @@ struct dentry_operations _test; printk("
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_dentry_operations_has_d_automount=yes
+ else
+@@ -8849,7 +8849,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_alloc_sem=yes
+ else
+@@ -8934,7 +8934,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_blkbits=yes
+ else
+@@ -9019,7 +9019,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_blksize=yes
+ else
+@@ -9104,7 +9104,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_mutex=yes
+ else
+@@ -9189,7 +9189,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_security=yes
+ else
+@@ -9274,7 +9274,7 @@ struct file_operations _test; printk("%x
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_file_operations_has_flock=yes
+ else
+@@ -9359,7 +9359,7 @@ struct file_operations _test; printk("%x
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_file_operations_has_sendfile=yes
+ else
+@@ -9444,7 +9444,7 @@ struct file_system_type _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_file_system_type_has_mount=yes
+ else
+@@ -9529,7 +9529,7 @@ struct filename _test; printk("%x\n", &_
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_filename_has_name=yes
+ else
+@@ -9614,7 +9614,7 @@ struct inode_operations _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_operations_has_truncate=yes
+ else
+@@ -9699,7 +9699,7 @@ struct key_type _test; printk("%x\n", &_
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_key_type_has_preparse=yes
+ else
+@@ -9784,7 +9784,7 @@ struct nameidata _test; printk("%x\n", &
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_nameidata_has_path=yes
+ else
+@@ -9869,7 +9869,7 @@ struct proc_dir_entry _test; printk("%x\
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_proc_dir_entry_has_owner=yes
+ else
+@@ -9954,7 +9954,7 @@ struct super_block _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_block_has_s_bdi=yes
+ else
+@@ -10039,7 +10039,7 @@ struct super_block _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_block_has_s_d_op=yes
+ else
+@@ -10124,7 +10124,7 @@ struct super_operations _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_operations_has_alloc_inode=yes
+ else
+@@ -10209,7 +10209,7 @@ struct super_operations _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_operations_has_evict_inode=yes
+ else
+@@ -10294,7 +10294,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_cred=yes
+ else
+@@ -10379,7 +10379,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_exit_state=yes
+ else
+@@ -10464,7 +10464,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_parent=yes
+ else
+@@ -10549,7 +10549,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_real_parent=yes
+ else
+@@ -10634,7 +10634,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_rlim=yes
+ else
+@@ -10719,7 +10719,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_sig=yes
+ else
+@@ -10804,7 +10804,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_sighand=yes
+ else
+@@ -10889,7 +10889,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_sigmask_lock=yes
+ else
+@@ -10974,7 +10974,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_tgid=yes
+ else
+@@ -11059,7 +11059,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_thread_info=yes
+ else
+@@ -11145,7 +11145,7 @@ struct task_struct _tsk; printk("%d\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_sched_struct_task_struct_has_signal_rlim=yes
+ else
+@@ -11230,7 +11230,7 @@ read_descriptor_t _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_read_descriptor_t_has_buf=yes
+ else
+@@ -11316,7 +11316,7 @@ bdi_init(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_bdi_init=yes
+ else
+@@ -11401,7 +11401,7 @@ struct page *_page;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_PageChecked=yes
+ else
+@@ -11488,7 +11488,7 @@ struct page *_page;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_PageFsMisc=yes
+ else
+@@ -11573,7 +11573,7 @@ clear_inode(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_clear_inode=yes
+ else
+@@ -11657,7 +11657,7 @@ struct timespec s;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_current_kernel_time=yes
+ else
+@@ -11741,7 +11741,7 @@ d_alloc_anon(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_alloc_anon=yes
+ else
+@@ -11824,7 +11824,7 @@ d_make_root(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_make_root=yes
+ else
+@@ -11907,7 +11907,7 @@ do_sync_read(NULL, NULL, 0, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_do_sync_read=yes
+ else
+@@ -11990,7 +11990,7 @@ pid_t p; find_task_by_pid(p);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_find_task_by_pid=yes
+ else
+@@ -12073,7 +12073,7 @@ generic_file_aio_read(NULL,NULL,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_generic_file_aio_read=yes
+ else
+@@ -12156,7 +12156,7 @@ grab_cache_page_write_begin(NULL, 0, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_grab_cache_page_write_begin=yes
+ else
+@@ -12239,7 +12239,7 @@ hlist_unhashed(0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_hlist_unhashed=yes
+ else
+@@ -12322,7 +12322,7 @@ i_size_read(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_size_read=yes
+ else
+@@ -12405,7 +12405,7 @@ inode_setattr(NULL, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_inode_setattr=yes
+ else
+@@ -12488,7 +12488,7 @@ kernel_setsockopt(NULL, 0, 0, NULL, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_kernel_setsockopt=yes
+ else
+@@ -12571,7 +12571,7 @@ page_follow_link(0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_page_follow_link=yes
+ else
+@@ -12654,7 +12654,7 @@ page_offset(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_page_offset=yes
+ else
+@@ -12737,7 +12737,7 @@ __pagevec_lru_add_file(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_pagevec_lru_add_file=yes
+ else
+@@ -12821,7 +12821,7 @@ path_lookup(NULL, 0, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_path_lookup=yes
+ else
+@@ -12905,7 +12905,7 @@ proc_create(NULL, 0, NULL, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_proc_create=yes
+ else
+@@ -12988,7 +12988,7 @@ rcu_read_lock();
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_rcu_read_lock=yes
+ else
+@@ -13071,7 +13071,7 @@ set_nlink(NULL, 1);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_set_nlink=yes
+ else
+@@ -13154,7 +13154,7 @@ splice_direct_to_actor(NULL,NULL,NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_splice_direct_to_actor=yes
+ else
+@@ -13237,7 +13237,7 @@ svc_addr_in(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_svc_addr_in=yes
+ else
+@@ -13320,7 +13320,7 @@ zero_user_segments(NULL, 0, 0, 0, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_zero_user_segments=yes
+ else
+@@ -13403,7 +13403,7 @@ void *address = &noop_fsync; printk("%p\
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_noop_fsync=yes
+ else
+@@ -13487,7 +13487,7 @@ kthread_run(NULL, NULL, "test");
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_kthread_run=yes
+ else
+@@ -13580,7 +13580,7 @@ extern ssize_t
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_aio_nonvector=yes
+ else
+@@ -13667,7 +13667,7 @@ struct proc_dir_entry *p = proc_root_fs;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_proc_root_fs=yes
+ else
+@@ -13756,7 +13756,7 @@ extern struct kmem_cache *
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kmem_cache_init=yes
+ else
+@@ -13845,7 +13845,7 @@ kmem_cache_t *k;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_kmem_cache_t=yes
+ else
+@@ -13930,7 +13930,7 @@ kmem_cache_create(NULL, 0, 0, 0, NULL, N
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kmem_cache_create_takes_dtor=yes
+ else
+@@ -14015,7 +14015,7 @@ void _ctor(void *v) { }; kmem_cache_crea
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kmem_cache_create_ctor_takes_void=yes
+ else
+@@ -14100,7 +14100,7 @@ struct path *p; d_path(p, NULL, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_d_path_takes_struct_path=yes
+ else
+@@ -14186,7 +14186,7 @@ struct export_operations _eops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_new_export_ops=yes
+ else
+@@ -14275,7 +14275,7 @@ struct inode _inode;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_inode_setattr_returns_int=yes
+ else
+@@ -14367,7 +14367,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_create_takes_nameidata=yes
+ else
+@@ -14460,7 +14460,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_lookup_takes_nameidata=yes
+ else
+@@ -14551,7 +14551,7 @@ struct inode _inode = {0};
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_permission_takes_flags=yes
+ else
+@@ -14641,7 +14641,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_permission_takes_nameidata=yes
+ else
+@@ -14734,7 +14734,7 @@ void *cookie;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_put_link_takes_cookie=yes
+ else
+@@ -14827,7 +14827,7 @@ struct dentry_operations _d_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_dop_d_delete_takes_const=yes
+ else
+@@ -14918,7 +14918,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_revalidate_takes_nameidata=yes
+ else
+@@ -15009,7 +15009,7 @@ fl_owner_t id;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_f_flush_takes_fl_owner_t=yes
+ else
+@@ -15100,7 +15100,7 @@ struct dentry _d;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_f_fsync_takes_dentry=yes
+ else
+@@ -15191,7 +15191,7 @@ loff_t start, end;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_f_fsync_takes_range=yes
+ else
+@@ -15284,7 +15284,7 @@ struct writeback_control _writeback_cont
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_a_writepage_takes_writeback_control=yes
+ else
+@@ -15376,7 +15376,7 @@ struct file_operations _fop;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_fs_struct_fop_has_splice=yes
+ else
+@@ -15463,7 +15463,7 @@ posix_lock_file(0,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kernel_posix_lock_file_wait_arg=yes
+ else
+@@ -15550,7 +15550,7 @@ struct file_lock *lock;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_posix_test_lock_returns_conflict=yes
+ else
+@@ -15639,7 +15639,7 @@ struct file_lock *lock;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_posix_test_lock_conflict_arg=yes
+ else
+@@ -15726,7 +15726,7 @@ sock_create(0,0,0,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kernel_sock_create_v=yes
+ else
+@@ -15816,7 +15816,7 @@ printk("%s", key_type_keyring.name);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_key_type_keyring=yes
+ else
+@@ -15906,7 +15906,7 @@ int i = KEYCTL_SESSION_TO_PARENT;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_session_to_parent=yes
+ else
+@@ -15992,7 +15992,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_linux_rhconfig=yes
+ else
+@@ -16081,7 +16081,7 @@ recalc_sigpending();
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_recalc_sigpending_takes_void=yes
+ else
+@@ -16169,7 +16169,7 @@ read_lock(&tasklist_lock);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_tasklist_lock=yes
+ else
+@@ -16257,7 +16257,7 @@ get_sb_nodev(0,0,0,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_get_sb_has_struct_vfsmount=yes
+ else
+@@ -16343,7 +16343,7 @@ extern int simple_statfs(struct dentry *
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_statfs_takes_dentry=yes
+ else
+@@ -16432,7 +16432,7 @@ refrigerator(PF_FREEZE);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_refrigerator_takes_pf_freeze=yes
+ else
+@@ -16527,7 +16527,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_try_to_freeze=yes
+ else
+@@ -16631,7 +16631,7 @@ request_key(NULL, NULL, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_keyring_support=yes
+ else
+@@ -16730,7 +16730,7 @@ struct task_struct *t=NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_key_alloc_needs_struct_task=yes
+ else
+@@ -16819,7 +16819,7 @@ struct cred *c = NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_key_alloc_needs_cred=yes
+ else
+@@ -16911,7 +16911,7 @@ INIT_WORK(w,f,i);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_init_work_has_data=yes
+ else
+@@ -17001,7 +17001,7 @@ ctl_table *t; register_sysctl_table (t);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_register_sysctl_table_noflag=yes
+ else
+@@ -17086,7 +17086,7 @@ printk("%p", &dcache_lock);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_dcache_lock=yes
+ else
+@@ -17173,7 +17173,7 @@ struct dentry _d;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_d_count_int=yes
+ else
+@@ -17262,7 +17262,7 @@ struct inode_operations _i_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_iop_mkdir_takes_umode_t=yes
+ else
+@@ -17352,7 +17352,7 @@ struct inode_operations _i_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_iop_create_takes_umode_t=yes
+ else
+@@ -17443,7 +17443,7 @@ struct export_operations _exp_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_export_op_encode_fh__takes_inodes=yes
+ else
+@@ -17532,7 +17532,7 @@ struct page *p = NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kma_atomic_takes_no_km_type=yes
+ else
+@@ -17619,7 +17619,7 @@ struct path p;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_dentry_open_takes_path=yes
+ else
+@@ -17707,7 +17707,7 @@ struct dentry *d = NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_d_alias_is_hlist=yes
+ else
+@@ -17798,7 +17798,7 @@ struct dentry *d = NULL, *cur;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_hlist_takes_no_node=yes
+ else
+@@ -17891,7 +17891,7 @@ struct inode _inode = {};
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_create_takes_bool=yes
+ else
+@@ -17983,7 +17983,7 @@ struct dentry_operations dops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_revalidate_takes_unsigned=yes
+ else
+@@ -18074,7 +18074,7 @@ struct inode_operations iops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_lookup_takes_unsigned=yes
+ else
+@@ -18175,7 +18175,7 @@ void *address = &init_mm; printk("%p\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_init_mm=yes
+ else
+@@ -18265,7 +18265,7 @@ void *address = &sys_chdir; printk("%p\n
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_sys_chdir=yes
+ else
+@@ -18350,7 +18350,7 @@ void *address = &sys_open; printk("%p\n"
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_sys_open=yes
+ else
+@@ -18458,7 +18458,7 @@ lose;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_config_smp=yes
+ else
+@@ -18570,7 +18570,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_kallsyms_address=yes
+ else
+@@ -18659,7 +18659,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_kallsyms_symbol=yes
+ else
+@@ -18748,7 +18748,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_sys_call_table=yes
+ else
+@@ -18837,7 +18837,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD ARCH=$ARCH CROSS_COMPILE=$CROSS M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_ia32_sys_call_table=yes
+ else
diff --git a/package/openafs/patches/patch-configure-libafs b/package/openafs/patches/patch-configure-libafs
new file mode 100644
index 000000000..e06be1f82
--- /dev/null
+++ b/package/openafs/patches/patch-configure-libafs
@@ -0,0 +1,1181 @@
+--- openafs-1.6.5.orig/configure-libafs 2013-07-18 07:31:09.000000000 +0200
++++ openafs-1.6.5/configure-libafs 2013-09-23 21:48:02.596915429 +0200
+@@ -6406,7 +6406,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_is_uml=yes
+ else
+@@ -6739,7 +6739,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_linux_kbuild_requires_extra_cflags=no
+ else
+@@ -6812,7 +6812,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then :
+ else
+@@ -6898,7 +6898,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_config_h=yes
+ else
+@@ -6982,7 +6982,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_completion_h=yes
+ else
+@@ -7066,7 +7066,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_exportfs_h=yes
+ else
+@@ -7150,7 +7150,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_freezer_h=yes
+ else
+@@ -7234,7 +7234,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_key_type_h=yes
+ else
+@@ -7318,7 +7318,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_semaphore_h=yes
+ else
+@@ -7402,7 +7402,7 @@ return;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_header_seq_file_h=yes
+ else
+@@ -7487,7 +7487,7 @@ struct vfs_path _test;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_type_struct_vfs_path_exists=yes
+ else
+@@ -7572,7 +7572,7 @@ struct address_space_operations _test; p
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_address_space_operations_has_write_begin=yes
+ else
+@@ -7657,7 +7657,7 @@ struct backing_dev_info _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_backing_dev_info_has_name=yes
+ else
+@@ -7742,7 +7742,7 @@ struct cred _test; printk("%x\n", &_test
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_cred_has_session_keyring=yes
+ else
+@@ -7827,7 +7827,7 @@ struct ctl_table _test; printk("%x\n", &
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_ctl_table_has_ctl_name=yes
+ else
+@@ -7912,7 +7912,7 @@ struct dentry_operations _test; printk("
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_dentry_operations_has_d_automount=yes
+ else
+@@ -7997,7 +7997,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_alloc_sem=yes
+ else
+@@ -8082,7 +8082,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_blkbits=yes
+ else
+@@ -8167,7 +8167,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_blksize=yes
+ else
+@@ -8252,7 +8252,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_mutex=yes
+ else
+@@ -8337,7 +8337,7 @@ struct inode _test; printk("%x\n", &_tes
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_has_i_security=yes
+ else
+@@ -8422,7 +8422,7 @@ struct file_operations _test; printk("%x
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_file_operations_has_flock=yes
+ else
+@@ -8507,7 +8507,7 @@ struct file_operations _test; printk("%x
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_file_operations_has_sendfile=yes
+ else
+@@ -8592,7 +8592,7 @@ struct file_system_type _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_file_system_type_has_mount=yes
+ else
+@@ -8677,7 +8677,7 @@ struct filename _test; printk("%x\n", &_
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_filename_has_name=yes
+ else
+@@ -8762,7 +8762,7 @@ struct inode_operations _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_inode_operations_has_truncate=yes
+ else
+@@ -8847,7 +8847,7 @@ struct key_type _test; printk("%x\n", &_
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_key_type_has_preparse=yes
+ else
+@@ -8932,7 +8932,7 @@ struct nameidata _test; printk("%x\n", &
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_nameidata_has_path=yes
+ else
+@@ -9017,7 +9017,7 @@ struct proc_dir_entry _test; printk("%x\
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_proc_dir_entry_has_owner=yes
+ else
+@@ -9102,7 +9102,7 @@ struct super_block _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_block_has_s_bdi=yes
+ else
+@@ -9187,7 +9187,7 @@ struct super_block _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_block_has_s_d_op=yes
+ else
+@@ -9272,7 +9272,7 @@ struct super_operations _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_operations_has_alloc_inode=yes
+ else
+@@ -9357,7 +9357,7 @@ struct super_operations _test; printk("%
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_super_operations_has_evict_inode=yes
+ else
+@@ -9442,7 +9442,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_cred=yes
+ else
+@@ -9527,7 +9527,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_exit_state=yes
+ else
+@@ -9612,7 +9612,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_parent=yes
+ else
+@@ -9697,7 +9697,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_real_parent=yes
+ else
+@@ -9782,7 +9782,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_rlim=yes
+ else
+@@ -9867,7 +9867,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_sig=yes
+ else
+@@ -9952,7 +9952,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_sighand=yes
+ else
+@@ -10037,7 +10037,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_sigmask_lock=yes
+ else
+@@ -10122,7 +10122,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_tgid=yes
+ else
+@@ -10207,7 +10207,7 @@ struct task_struct _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_struct_task_struct_has_thread_info=yes
+ else
+@@ -10293,7 +10293,7 @@ struct task_struct _tsk; printk("%d\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_sched_struct_task_struct_has_signal_rlim=yes
+ else
+@@ -10378,7 +10378,7 @@ read_descriptor_t _test; printk("%x\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_read_descriptor_t_has_buf=yes
+ else
+@@ -10464,7 +10464,7 @@ bdi_init(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_bdi_init=yes
+ else
+@@ -10549,7 +10549,7 @@ struct page *_page;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_PageChecked=yes
+ else
+@@ -10636,7 +10636,7 @@ struct page *_page;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_PageFsMisc=yes
+ else
+@@ -10721,7 +10721,7 @@ clear_inode(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_clear_inode=yes
+ else
+@@ -10805,7 +10805,7 @@ struct timespec s;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_current_kernel_time=yes
+ else
+@@ -10889,7 +10889,7 @@ d_alloc_anon(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_alloc_anon=yes
+ else
+@@ -10972,7 +10972,7 @@ d_make_root(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_make_root=yes
+ else
+@@ -11055,7 +11055,7 @@ do_sync_read(NULL, NULL, 0, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_do_sync_read=yes
+ else
+@@ -11138,7 +11138,7 @@ pid_t p; find_task_by_pid(p);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_find_task_by_pid=yes
+ else
+@@ -11221,7 +11221,7 @@ generic_file_aio_read(NULL,NULL,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_generic_file_aio_read=yes
+ else
+@@ -11304,7 +11304,7 @@ grab_cache_page_write_begin(NULL, 0, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_grab_cache_page_write_begin=yes
+ else
+@@ -11387,7 +11387,7 @@ hlist_unhashed(0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_hlist_unhashed=yes
+ else
+@@ -11470,7 +11470,7 @@ i_size_read(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_size_read=yes
+ else
+@@ -11553,7 +11553,7 @@ inode_setattr(NULL, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_inode_setattr=yes
+ else
+@@ -11636,7 +11636,7 @@ kernel_setsockopt(NULL, 0, 0, NULL, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_kernel_setsockopt=yes
+ else
+@@ -11719,7 +11719,7 @@ page_follow_link(0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_page_follow_link=yes
+ else
+@@ -11802,7 +11802,7 @@ page_offset(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_page_offset=yes
+ else
+@@ -11885,7 +11885,7 @@ __pagevec_lru_add_file(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_pagevec_lru_add_file=yes
+ else
+@@ -11969,7 +11969,7 @@ path_lookup(NULL, 0, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_path_lookup=yes
+ else
+@@ -12053,7 +12053,7 @@ proc_create(NULL, 0, NULL, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_proc_create=yes
+ else
+@@ -12136,7 +12136,7 @@ rcu_read_lock();
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_rcu_read_lock=yes
+ else
+@@ -12219,7 +12219,7 @@ set_nlink(NULL, 1);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_set_nlink=yes
+ else
+@@ -12302,7 +12302,7 @@ splice_direct_to_actor(NULL,NULL,NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_splice_direct_to_actor=yes
+ else
+@@ -12385,7 +12385,7 @@ svc_addr_in(NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_svc_addr_in=yes
+ else
+@@ -12468,7 +12468,7 @@ zero_user_segments(NULL, 0, 0, 0, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_zero_user_segments=yes
+ else
+@@ -12551,7 +12551,7 @@ void *address = &noop_fsync; printk("%p\
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_noop_fsync=yes
+ else
+@@ -12635,7 +12635,7 @@ kthread_run(NULL, NULL, "test");
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_kthread_run=yes
+ else
+@@ -12728,7 +12728,7 @@ extern ssize_t
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_aio_nonvector=yes
+ else
+@@ -12815,7 +12815,7 @@ struct proc_dir_entry *p = proc_root_fs;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_proc_root_fs=yes
+ else
+@@ -12904,7 +12904,7 @@ extern struct kmem_cache *
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kmem_cache_init=yes
+ else
+@@ -12993,7 +12993,7 @@ kmem_cache_t *k;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_kmem_cache_t=yes
+ else
+@@ -13078,7 +13078,7 @@ kmem_cache_create(NULL, 0, 0, 0, NULL, N
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kmem_cache_create_takes_dtor=yes
+ else
+@@ -13163,7 +13163,7 @@ void _ctor(void *v) { }; kmem_cache_crea
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kmem_cache_create_ctor_takes_void=yes
+ else
+@@ -13248,7 +13248,7 @@ struct path *p; d_path(p, NULL, 0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_d_path_takes_struct_path=yes
+ else
+@@ -13334,7 +13334,7 @@ struct export_operations _eops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_new_export_ops=yes
+ else
+@@ -13423,7 +13423,7 @@ struct inode _inode;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_inode_setattr_returns_int=yes
+ else
+@@ -13515,7 +13515,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_create_takes_nameidata=yes
+ else
+@@ -13608,7 +13608,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_lookup_takes_nameidata=yes
+ else
+@@ -13699,7 +13699,7 @@ struct inode _inode = {0};
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_permission_takes_flags=yes
+ else
+@@ -13789,7 +13789,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_permission_takes_nameidata=yes
+ else
+@@ -13882,7 +13882,7 @@ void *cookie;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_put_link_takes_cookie=yes
+ else
+@@ -13975,7 +13975,7 @@ struct dentry_operations _d_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_dop_d_delete_takes_const=yes
+ else
+@@ -14066,7 +14066,7 @@ struct nameidata _nameidata;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_revalidate_takes_nameidata=yes
+ else
+@@ -14157,7 +14157,7 @@ fl_owner_t id;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_f_flush_takes_fl_owner_t=yes
+ else
+@@ -14248,7 +14248,7 @@ struct dentry _d;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_f_fsync_takes_dentry=yes
+ else
+@@ -14339,7 +14339,7 @@ loff_t start, end;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_f_fsync_takes_range=yes
+ else
+@@ -14432,7 +14432,7 @@ struct writeback_control _writeback_cont
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_a_writepage_takes_writeback_control=yes
+ else
+@@ -14524,7 +14524,7 @@ struct file_operations _fop;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_fs_struct_fop_has_splice=yes
+ else
+@@ -14611,7 +14611,7 @@ posix_lock_file(0,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kernel_posix_lock_file_wait_arg=yes
+ else
+@@ -14698,7 +14698,7 @@ struct file_lock *lock;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_posix_test_lock_returns_conflict=yes
+ else
+@@ -14787,7 +14787,7 @@ struct file_lock *lock;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_posix_test_lock_conflict_arg=yes
+ else
+@@ -14874,7 +14874,7 @@ sock_create(0,0,0,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kernel_sock_create_v=yes
+ else
+@@ -14964,7 +14964,7 @@ printk("%s", key_type_keyring.name);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_key_type_keyring=yes
+ else
+@@ -15054,7 +15054,7 @@ int i = KEYCTL_SESSION_TO_PARENT;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_session_to_parent=yes
+ else
+@@ -15140,7 +15140,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_linux_rhconfig=yes
+ else
+@@ -15229,7 +15229,7 @@ recalc_sigpending();
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_recalc_sigpending_takes_void=yes
+ else
+@@ -15317,7 +15317,7 @@ read_lock(&tasklist_lock);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_tasklist_lock=yes
+ else
+@@ -15405,7 +15405,7 @@ get_sb_nodev(0,0,0,0,0);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_get_sb_has_struct_vfsmount=yes
+ else
+@@ -15491,7 +15491,7 @@ extern int simple_statfs(struct dentry *
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_statfs_takes_dentry=yes
+ else
+@@ -15580,7 +15580,7 @@ refrigerator(PF_FREEZE);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_refrigerator_takes_pf_freeze=yes
+ else
+@@ -15675,7 +15675,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_try_to_freeze=yes
+ else
+@@ -15779,7 +15779,7 @@ request_key(NULL, NULL, NULL);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_keyring_support=yes
+ else
+@@ -15878,7 +15878,7 @@ struct task_struct *t=NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_key_alloc_needs_struct_task=yes
+ else
+@@ -15967,7 +15967,7 @@ struct cred *c = NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_key_alloc_needs_cred=yes
+ else
+@@ -16059,7 +16059,7 @@ INIT_WORK(w,f,i);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_init_work_has_data=yes
+ else
+@@ -16149,7 +16149,7 @@ ctl_table *t; register_sysctl_table (t);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_register_sysctl_table_noflag=yes
+ else
+@@ -16234,7 +16234,7 @@ printk("%p", &dcache_lock);
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_have_dcache_lock=yes
+ else
+@@ -16321,7 +16321,7 @@ struct dentry _d;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_d_count_int=yes
+ else
+@@ -16410,7 +16410,7 @@ struct inode_operations _i_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_iop_mkdir_takes_umode_t=yes
+ else
+@@ -16500,7 +16500,7 @@ struct inode_operations _i_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_iop_create_takes_umode_t=yes
+ else
+@@ -16591,7 +16591,7 @@ struct export_operations _exp_ops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_export_op_encode_fh__takes_inodes=yes
+ else
+@@ -16680,7 +16680,7 @@ struct page *p = NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_kma_atomic_takes_no_km_type=yes
+ else
+@@ -16767,7 +16767,7 @@ struct path p;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_dentry_open_takes_path=yes
+ else
+@@ -16855,7 +16855,7 @@ struct dentry *d = NULL;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_d_alias_is_hlist=yes
+ else
+@@ -16946,7 +16946,7 @@ struct dentry *d = NULL, *cur;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_hlist_takes_no_node=yes
+ else
+@@ -17039,7 +17039,7 @@ struct inode _inode = {};
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_i_create_takes_bool=yes
+ else
+@@ -17131,7 +17131,7 @@ struct dentry_operations dops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_d_revalidate_takes_unsigned=yes
+ else
+@@ -17222,7 +17222,7 @@ struct inode_operations iops;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_func_lookup_takes_unsigned=yes
+ else
+@@ -17323,7 +17323,7 @@ void *address = &init_mm; printk("%p\n",
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_init_mm=yes
+ else
+@@ -17413,7 +17413,7 @@ void *address = &sys_chdir; printk("%p\n
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_sys_chdir=yes
+ else
+@@ -17498,7 +17498,7 @@ void *address = &sys_open; printk("%p\n"
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_sys_open=yes
+ else
+@@ -17606,7 +17606,7 @@ lose;
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_config_smp=yes
+ else
+@@ -17718,7 +17718,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_kallsyms_address=yes
+ else
+@@ -17807,7 +17807,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_kallsyms_symbol=yes
+ else
+@@ -17896,7 +17896,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_sys_call_table=yes
+ else
+@@ -17985,7 +17985,7 @@ void conftest(void)
+ MODULE_LICENSE("http://www.openafs.org/dl/license10.html");
+ _ACEOF
+ echo make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 &&
+- make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
++ make -C $LINUX_KERNEL_BUILD M=$SRCDIR_PARENT/conftest.dir ARCH=$ARCH CROSS_COMPILE=$CROSS modules KBUILD_VERBOSE=1 >&5 2>conftest.err &&
+ ! grep -i "WARNING: .* undefined!$" conftest.err >/dev/null 2>&1
+ then ac_cv_linux_exports_ia32_sys_call_table=yes
+ else
diff --git a/package/openafs/patches/patch-src_afs_afs_fetchstore_c b/package/openafs/patches/patch-src_afs_afs_fetchstore_c
new file mode 100644
index 000000000..451a816ed
--- /dev/null
+++ b/package/openafs/patches/patch-src_afs_afs_fetchstore_c
@@ -0,0 +1,12 @@
+--- openafs-1.6.5.orig/src/afs/afs_fetchstore.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/afs/afs_fetchstore.c 2013-09-24 21:45:15.436516310 +0200
+@@ -11,9 +11,6 @@
+ #include "afs/param.h"
+
+ #include "afs/sysincludes.h" /* Standard vendor system headers */
+-#ifndef AFS_LINUX22_ENV
+-#include "rpc/types.h"
+-#endif
+ #ifdef AFS_ALPHA_ENV
+ #undef kmem_alloc
+ #undef kmem_free
diff --git a/package/openafs/patches/patch-src_afs_afs_memcache_c b/package/openafs/patches/patch-src_afs_afs_memcache_c
new file mode 100644
index 000000000..b038400c8
--- /dev/null
+++ b/package/openafs/patches/patch-src_afs_afs_memcache_c
@@ -0,0 +1,12 @@
+--- openafs-1.6.5.orig/src/afs/afs_memcache.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/afs/afs_memcache.c 2013-09-24 21:44:42.988924231 +0200
+@@ -12,9 +12,6 @@
+
+
+ #include "afs/sysincludes.h" /* Standard vendor system headers */
+-#ifndef AFS_LINUX22_ENV
+-#include "rpc/types.h"
+-#endif
+ #include "afsincludes.h" /* Afs-based standard headers */
+ #include "afs/afs_stats.h" /* statistics */
+
diff --git a/package/openafs/patches/patch-src_auth_userok_c b/package/openafs/patches/patch-src_auth_userok_c
new file mode 100644
index 000000000..868a5b7f5
--- /dev/null
+++ b/package/openafs/patches/patch-src_auth_userok_c
@@ -0,0 +1,10 @@
+--- openafs-1.6.5.orig/src/auth/userok.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/auth/userok.c 2013-09-14 15:59:14.673703295 +0200
+@@ -19,6 +19,7 @@
+ #include <fcntl.h>
+ #include <io.h>
+ #else
++#include <fcntl.h>
+ #include <sys/file.h>
+ #include <netinet/in.h>
+ #include <netdb.h>
diff --git a/package/openafs/patches/patch-src_comerr_Makefile_in b/package/openafs/patches/patch-src_comerr_Makefile_in
new file mode 100644
index 000000000..a56308099
--- /dev/null
+++ b/package/openafs/patches/patch-src_comerr_Makefile_in
@@ -0,0 +1,38 @@
+--- openafs-1.6.5.orig/src/comerr/Makefile.in 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/comerr/Makefile.in 2013-09-09 06:25:16.479495215 +0200
+@@ -31,12 +31,12 @@ et_lex.lex.c: et_lex.lex.l
+ $(RM) -f et_lex.lex.c
+ $(LEX) -t $(srcdir)/et_lex.lex.l > et_lex.lex.c
+
+-compile_et: compile_et.o error_table.o
++compile_et: compile_et.o error_table.o internal.o
+ case $(SYS_NAME) in \
+ *_linux* | *_umlinux* ) \
+- ${CC} ${CFLAGS} -o compile_et compile_et.o error_table.o -L${TOP_LIBDIR} -lafsutil;; \
++ ${CC_FOR_BUILD} ${CFLAGS_FOR_BUILD} -o compile_et compile_et.o error_table.o internal.o ;; \
+ * ) \
+- ${CC} ${CFLAGS} -o compile_et compile_et.o error_table.o -L${TOP_LIBDIR} -lafsutil -ll;; \
++ ${CC} ${CFLAGS} -o compile_et compile_et.o error_table.o -L${TOP_LIBDIR} -ll;; \
+ esac
+
+ libafscom_err.a: error_msg.o et_name.o com_err.o AFS_component_version_number.o
+@@ -49,7 +49,10 @@ libafscom_err.a: error_msg.o et_name.o c
+ # so we need to add the source directory to the includes to pick up local headers.
+ #
+ error_table.o: error_table.c
+- $(CC) $(CFLAGS) -I${srcdir} @CFLAGS_NOUNUSED@ @CFLAGS_NOOLDSTYLE@ -c error_table.c
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -I${srcdir} @CFLAGS_NOUNUSED@ @CFLAGS_NOOLDSTYLE@ -c error_table.c
++
++internal.o: internal.c
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -I${srcdir} -c internal.c
+
+ #
+ # Installation targets
+@@ -85,6 +88,7 @@ test:
+ cd test; $(MAKE)
+
+ compile_et.o: AFS_component_version_number.c
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c compile_et.c -o compile_et.o
+ error_table.o: et_lex.lex.c
+
+ include ../config/Makefile.version
diff --git a/package/openafs/patches/patch-src_comerr_error_table_y b/package/openafs/patches/patch-src_comerr_error_table_y
new file mode 100644
index 000000000..ee9d84908
--- /dev/null
+++ b/package/openafs/patches/patch-src_comerr_error_table_y
@@ -0,0 +1,10 @@
+--- openafs-1.6.5.orig/src/comerr/error_table.y 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/comerr/error_table.y 2013-08-22 07:38:30.051905881 +0200
+@@ -20,7 +20,6 @@
+ #else
+ #include <sys/time.h>
+ #endif
+-#include <sys/timeb.h>
+ #include "error_table.h"
+ #include "mit-sipb-cr.h"
+
diff --git a/package/openafs/patches/patch-src_comerr_internal_h b/package/openafs/patches/patch-src_comerr_internal_h
new file mode 100644
index 000000000..d561fcdcb
--- /dev/null
+++ b/package/openafs/patches/patch-src_comerr_internal_h
@@ -0,0 +1,8 @@
+--- openafs-1.6.5.orig/src/comerr/internal.h 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/comerr/internal.h 2013-09-09 05:30:55.256494342 +0200
+@@ -9,3 +9,5 @@
+
+ extern void yyerror(const char *s);
+ extern char *xmalloc(unsigned int size);
++extern char *lcstring(char *d, char *s, int n);
++
diff --git a/package/openafs/patches/patch-src_config_Makefile_config_in b/package/openafs/patches/patch-src_config_Makefile_config_in
new file mode 100644
index 000000000..2f82768cc
--- /dev/null
+++ b/package/openafs/patches/patch-src_config_Makefile_config_in
@@ -0,0 +1,15 @@
+--- openafs-1.6.5.orig/src/config/Makefile.config.in 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/config/Makefile.config.in 2013-08-21 18:21:16.843244292 +0200
+@@ -134,8 +134,10 @@ SHELL = /bin/sh
+ COMMON_INCL=-I${TOP_OBJDIR}/src/config -I${TOP_INCDIR} -I${srcdir} -I.
+ COMMON_CFLAGS=${DBG} ${OPTMZ} ${COMMON_INCL} ${INCLUDE_LIBINTL}
+
+-CFLAGS=${COMMON_CFLAGS} ${XCFLAGS} ${ARCHFLAGS} $(CFLAGS_NOERROR)
+-LDFLAGS=${XLDFLAGS} ${ARCHFLAGS}
++CFLAGS?=
++CFLAGS+=${COMMON_CFLAGS} ${XCFLAGS} ${ARCHFLAGS} $(CFLAGS_NOERROR)
++LDFLAGS?=
++LDFLAGS+=${XLDFLAGS} ${ARCHFLAGS}
+
+ .c.o:
+ $(CCOBJ) $(CFLAGS) -c $<
diff --git a/package/openafs/patches/patch-src_config_Makefile_in b/package/openafs/patches/patch-src_config_Makefile_in
new file mode 100644
index 000000000..368290138
--- /dev/null
+++ b/package/openafs/patches/patch-src_config_Makefile_in
@@ -0,0 +1,23 @@
+--- openafs-1.6.5.orig/src/config/Makefile.in 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/config/Makefile.in 2013-09-22 20:18:38.673550739 +0200
+@@ -52,16 +52,16 @@ AFS_component_version_number.c: Makefile
+ # App build/install targets
+ #
+ config: config.o mc.o
+- $(CC) $(CFLAGS) -o config config.o mc.o
++ $(CC_FOR_BUILD) $(CFLAGS_FOR_BUILD) -o config config.o mc.o
+
+ mkvers: ${srcdir}/mkvers.c
+- $(CC) $(CFLAGS) -o mkvers ${srcdir}/mkvers.c
++ $(CC_FOR_BUILD) $(CFLAGS_FOR_BUILD) -o mkvers ${srcdir}/mkvers.c
+
+ mc.o: ${srcdir}/mc.c
+- $(CC) $(CFLAGS) -I. -c ${srcdir}/mc.c
++ $(CC_FOR_BUILD) $(CFLAGS_FOR_BUILD) -I. -c ${srcdir}/mc.c
+
+ config.o: ${srcdir}/config.c AFS_component_version_number.c
+- $(CC) $(CFLAGS) -I. -c ${srcdir}/config.c
++ $(CC_FOR_BUILD) $(CFLAGS_FOR_BUILD) -I. -c ${srcdir}/config.c
+
+ #
+ # Include installation targets
diff --git a/package/openafs/patches/patch-src_des_Makefile_in b/package/openafs/patches/patch-src_des_Makefile_in
new file mode 100644
index 000000000..6a039bbd0
--- /dev/null
+++ b/package/openafs/patches/patch-src_des_Makefile_in
@@ -0,0 +1,73 @@
+--- openafs-1.6.5.orig/src/des/Makefile.in 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/des/Makefile.in 2013-09-22 20:00:06.859528134 +0200
+@@ -106,31 +106,31 @@ libdes.a: ${OBJS} AFS_component_version_
+ $(RANLIB) libdes.a
+
+ make_ip: make_ip.o misc-i.o main.o
+- ${CC} make_ip.o misc-i.o main.o ${LDFLAGS} -o make_ip
++ ${CC_FOR_BUILD} make_ip.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_ip
+
+ make_fp: make_fp.o misc-i.o main.o
+- ${CC} make_fp.o misc-i.o main.o ${LDFLAGS} -o make_fp
++ ${CC_FOR_BUILD} make_fp.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_fp
+
+ make_odd: make_odd.o misc-i.o main.o
+- ${CC} make_odd.o misc-i.o main.o ${LDFLAGS} -o make_odd
++ ${CC_FOR_BUILD} make_odd.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_odd
+
+ make_s_table: make_s_table.o misc-i.o main.o
+- ${CC} make_s_table.o misc-i.o main.o ${LDFLAGS} -o make_s_table
++ ${CC_FOR_BUILD} make_s_table.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_s_table
+
+ make_p_table: make_p_table.o misc-i.o main.o
+- ${CC} make_p_table.o misc-i.o main.o ${LDFLAGS} -o make_p_table
++ ${CC_FOR_BUILD} make_p_table.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_p_table
+
+ make_keyperm: make_keyperm.o misc-i.o main.o
+- ${CC} make_keyperm.o misc-i.o main.o ${LDFLAGS} -o make_keyperm
++ ${CC_FOR_BUILD} make_keyperm.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_keyperm
+
+ make_e: make_e.o misc-i.o main.o
+- ${CC} make_e.o misc-i.o main.o ${LDFLAGS} -o make_e
++ ${CC_FOR_BUILD} make_e.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_e
+
+ make_p: make_p.o misc-i.o main.o
+- ${CC} make_p.o misc-i.o main.o ${LDFLAGS} -o make_p
++ ${CC_FOR_BUILD} make_p.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_p
+
+ make_s: make_s.o misc-i.o main.o
+- ${CC} make_s.o misc-i.o main.o ${LDFLAGS} -o make_s
++ ${CC_FOR_BUILD} make_s.o misc-i.o main.o ${LDFLAGS_FOR_BUILD} -o make_s
+
+ crypt.o: ${srcdir}/crypt.c
+ case ${SYS_NAME} in \
+@@ -172,17 +172,27 @@ fp.c: make_fp
+ INCLS=des.h des_prototypes.h mit-cpyright.h des_conf.h des_internal.h conf.h
+
+ make_keyperm.o: make_keyperm.c ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ make_ip.o: make_ip.c tables.h ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ make_fp.o: make_fp.c tables.h ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ make_p.o: make_p.c tables.h ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ make_s.o: make_s.c s_table.h ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ make_s_table.o: make_s_table.c tables.h ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ make_p_table.o: make_p_table.c tables.h ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ make_odd.o: make_odd.c ${INCLS}
+-misc.o: misc.c AFS_component_version_number.c ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ misc-i.o: misc.c ${INCLS}
+- ${CCOBJ} -c ${CFLAGS} -o misc-i.o ${srcdir}/misc.c
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c -o misc-i.o ${srcdir}/misc.c
++misc.o: misc.c AFS_component_version_number.c ${INCLS}
++ $(CC) ${COMMON_INCL} $(CFLAGS) -c $<
+ main.o: main.c ${INCLS}
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
+ key_sched.o: key_sched.c key_perm.h odd.h ${INCLS}
+ key_test.o: key_test.c ${INCLS}
+ testit.o: testit.c ${INCLS}
diff --git a/package/openafs/patches/patch-src_des_read_pssword_c b/package/openafs/patches/patch-src_des_read_pssword_c
new file mode 100644
index 000000000..7192a06f2
--- /dev/null
+++ b/package/openafs/patches/patch-src_des_read_pssword_c
@@ -0,0 +1,52 @@
+--- openafs-1.6.5.orig/src/des/read_pssword.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/des/read_pssword.c 2013-08-22 07:26:09.861211339 +0200
+@@ -53,6 +53,7 @@ static int intrupt;
+ #endif
+
+ #ifdef HAVE_TERMIOS_H
++#include <sys/ioctl.h>
+ #include <termios.h>
+ #endif
+
+@@ -115,7 +116,7 @@ des_read_password(des_cblock * k, char *
+ static void catch(int);
+ #endif
+
+-#if !defined(BSDUNIX) && (defined(AFS_AIX_ENV) || defined (AFS_HPUX_ENV) || defined(AFS_SGI_ENV) || defined(AFS_LINUX20_ENV))
++#if !defined(BSDUNIX) && (defined(AFS_AIX_ENV) || defined (AFS_HPUX_ENV) || defined(AFS_SGI_ENV))
+ #include <termio.h>
+ #endif
+
+@@ -148,7 +149,7 @@ des_read_pw_string(char *s, int maxa, ch
+ FILE *fi;
+ #else
+ #if defined (AFS_AIX_ENV) || defined (AFS_HPUX_ENV) || defined(AFS_SGI_ENV) || defined(AFS_LINUX20_ENV)
+- struct termio ttyb;
++ struct termios ttyb;
+ FILE *fi;
+ char savel, flags;
+ void (*sig) (int);
+@@ -227,12 +228,12 @@ des_read_pw_string(char *s, int maxa, ch
+ setbuf(fi, (char *)NULL);
+ sig = signal(SIGINT, catch);
+ intrupt = 0;
+- (void)ioctl(fileno(fi), TCGETA, &ttyb);
++ (void)ioctl(fileno(fi), TCGETS, &ttyb);
+ savel = ttyb.c_line;
+ ttyb.c_line = 0;
+ flags = ttyb.c_lflag;
+ ttyb.c_lflag &= ~(ECHO | ECHOE | ECHOK | ECHONL);
+- (void)ioctl(fileno(fi), TCSETAF, &ttyb);
++ (void)ioctl(fileno(fi), TCSETSF, &ttyb);
+ #else
+ #ifdef AFS_NT40_ENV
+ /* turn off console input echoing */
+@@ -335,7 +336,7 @@ des_read_pw_string(char *s, int maxa, ch
+ #if defined (AFS_AIX_ENV) /*|| defined (AFS_HPUX_ENV)*/ || defined(AFS_SGI_ENV) || defined(AFS_LINUX20_ENV)
+ ttyb.c_lflag = flags;
+ ttyb.c_line = savel;
+- (void)ioctl(fileno(fi), TCSETAW, &ttyb);
++ (void)ioctl(fileno(fi), TCSETSW, &ttyb);
+ (void)signal(SIGINT, sig);
+ if (fi != stdin)
+ (void)fclose(fi);
diff --git a/package/openafs/patches/patch-src_libafs_MakefileProto_LINUX_in b/package/openafs/patches/patch-src_libafs_MakefileProto_LINUX_in
new file mode 100644
index 000000000..c07f5993e
--- /dev/null
+++ b/package/openafs/patches/patch-src_libafs_MakefileProto_LINUX_in
@@ -0,0 +1,11 @@
+--- openafs-1.6.5.orig/src/libafs/MakefileProto.LINUX.in 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/libafs/MakefileProto.LINUX.in 2013-09-22 20:53:43.359091259 +0200
+@@ -340,7 +340,7 @@ ${LIBAFS} ${LIBAFS_MP} ${LIBAFS_EP} ${LI
+ .FORCE:
+ ${LINUX_LIBAFS_NAME}.ko afspag.ko: .FORCE
+ env EXTRA_CFLAGS="${EXTRA_CFLAGS}" @TOP_SRCDIR@/libafs/make_kbuild_makefile.pl ${KDIR} $@ @TOP_OBJDIR@/src/config/Makefile.config Makefile.afs Makefile.common
+- env EXTRA_CFLAGS="${EXTRA_CFLAGS}" $(MAKE) -C ${LINUX_KERNEL_BUILD} M=@TOP_OBJDIR@/src/libafs/${KDIR} modules 2>&1 | tee .makelog
++ env EXTRA_CFLAGS="${EXTRA_CFLAGS}" $(MAKE) -C ${LINUX_KERNEL_BUILD} ARCH=${ARCH} CROSS_COMPILE=${CROSS} M=@TOP_OBJDIR@/src/libafs/${KDIR} modules 2>&1 | tee .makelog
+ @if [ `grep ^WARNING .makelog | wc -l` -ne 0 ]; then \
+ echo Error: Undefined symbols in modules ; \
+ rm .makelog ; \
diff --git a/package/openafs/patches/patch-src_lwp_iomgr_c b/package/openafs/patches/patch-src_lwp_iomgr_c
new file mode 100644
index 000000000..c0b13db4f
--- /dev/null
+++ b/package/openafs/patches/patch-src_lwp_iomgr_c
@@ -0,0 +1,12 @@
+--- openafs-1.6.5.orig/src/lwp/iomgr.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/lwp/iomgr.c 2013-09-10 19:18:44.346172788 +0200
+@@ -57,9 +57,7 @@ extern void lwp_abort(void);
+ #include "timer.h"
+ #include <signal.h>
+ #include <errno.h>
+-#ifdef AFS_SUN5_ENV
+ #include <fcntl.h>
+-#endif
+
+ #if defined(USE_PTHREADS) || defined(USE_SOLARIS_THREADS)
+
diff --git a/package/openafs/patches/patch-src_lwp_waitkey_c b/package/openafs/patches/patch-src_lwp_waitkey_c
new file mode 100644
index 000000000..4cdc004a8
--- /dev/null
+++ b/package/openafs/patches/patch-src_lwp_waitkey_c
@@ -0,0 +1,37 @@
+--- openafs-1.6.5.orig/src/lwp/waitkey.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/lwp/waitkey.c 2013-09-10 20:04:09.315133972 +0200
+@@ -158,34 +158,6 @@ LWP_WaitForKeystroke(int seconds)
+ struct timeval twait;
+ struct timeval *tp = NULL;
+
+-#ifdef AFS_LINUX20_ENV
+- if (stdin->_IO_read_ptr < stdin->_IO_read_end)
+- return 1;
+-#else
+-#if defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
+-#if defined(AFS_DFBSD_ENV)
+- struct appx_sbuf {
+- unsigned char *_base;
+- int _size;
+- };
+- struct APPX_FILE
+- {
+- struct __FILE_public pub;
+- struct appx_sbuf _bf; /* the buffer (at least 1 byte, if !NULL) */
+- };
+- struct APPX_FILE *appx_stdin = (struct APPX_FILE *) stdin;
+- if (appx_stdin->_bf._size > 0)
+- return 1;
+-#else
+- if (stdin->_bf._size > 0)
+- return 1;
+-#endif
+-#else
+- if (stdin->_cnt > 0)
+- return 1;
+-#endif
+-#endif
+-
+ FD_ZERO(&rdfds);
+ FD_SET(fileno(stdin), &rdfds);
+
diff --git a/package/openafs/patches/patch-src_rx_rx_lwp_c b/package/openafs/patches/patch-src_rx_rx_lwp_c
new file mode 100644
index 000000000..9201c06c1
--- /dev/null
+++ b/package/openafs/patches/patch-src_rx_rx_lwp_c
@@ -0,0 +1,10 @@
+--- openafs-1.6.5.orig/src/rx/rx_lwp.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/rx/rx_lwp.c 2013-09-14 15:12:45.580963823 +0200
+@@ -28,6 +28,7 @@
+ #ifdef AFS_NT40_ENV
+ # include <winsock2.h>
+ #else
++# include <fcntl.h>
+ # include <unistd.h> /* select() prototype */
+ # include <sys/time.h> /* struct timeval, select() prototype */
+ # ifndef FD_SET
diff --git a/package/openafs/patches/patch-src_rx_rx_trace_c b/package/openafs/patches/patch-src_rx_rx_trace_c
new file mode 100644
index 000000000..93cbd9de7
--- /dev/null
+++ b/package/openafs/patches/patch-src_rx_rx_trace_c
@@ -0,0 +1,10 @@
+--- openafs-1.6.5.orig/src/rx/rx_trace.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/rx/rx_trace.c 2013-09-14 15:36:29.926860486 +0200
+@@ -26,6 +26,7 @@ main(int argc, char **argv)
+ #include <fcntl.h>
+ #include <io.h>
+ #else
++#include <fcntl.h>
+ #include <sys/file.h>
+ #include <unistd.h>
+ #endif
diff --git a/package/openafs/patches/patch-src_rxgen_Makefile_in b/package/openafs/patches/patch-src_rxgen_Makefile_in
new file mode 100644
index 000000000..bd0aa8c9a
--- /dev/null
+++ b/package/openafs/patches/patch-src_rxgen_Makefile_in
@@ -0,0 +1,19 @@
+--- openafs-1.6.5.orig/src/rxgen/Makefile.in 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/rxgen/Makefile.in 2013-09-10 20:57:38.854784594 +0200
+@@ -25,10 +25,14 @@ ${TOP_INCDIR}/afs/rxgen_consts.h: rxgen_
+ ${INSTALL_DATA} $? $@
+
+ rxgen: $(OBJS) AFS_component_version_number.c $(HDRS)
+- $(CC) $(CFLAGS) $(OBJS) $(XLIBS) -o $@
++ $(CC_FOR_BUILD) $(CFLAGS_FOR_BUILD) $(OBJS) $(XLIBS) -o $@
+
+ rpc_main.o: rpc_main.c
+- $(CCOBJ) $(CFLAGS) -c ${srcdir}/rpc_main.c -DPATH_CPP="\"$(PATH_CPP)\""
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c ${srcdir}/rpc_main.c -DPATH_CPP="\"$(PATH_CPP)\""
++
++.c.o:
++ $(CC_FOR_BUILD) ${COMMON_INCL} $(CFLAGS_FOR_BUILD) -c $<
++
+
+ #
+ # Install targets
diff --git a/package/openafs/patches/patch-src_rxkad_rxkad_client_c b/package/openafs/patches/patch-src_rxkad_rxkad_client_c
new file mode 100644
index 000000000..2149a128d
--- /dev/null
+++ b/package/openafs/patches/patch-src_rxkad_rxkad_client_c
@@ -0,0 +1,10 @@
+--- openafs-1.6.5.orig/src/rxkad/rxkad_client.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/rxkad/rxkad_client.c 2013-09-24 22:03:30.630747856 +0200
+@@ -37,7 +37,6 @@
+ #include "afs/sysincludes.h"
+ #endif /* !UKERNEL */
+ #ifndef AFS_LINUX22_ENV
+-#include "rpc/types.h"
+ #include "rx/xdr.h"
+ #endif
+ #include "rx/rx.h"
diff --git a/package/openafs/patches/patch-src_shlibafsrpc_Makefile_in b/package/openafs/patches/patch-src_shlibafsrpc_Makefile_in
new file mode 100644
index 000000000..c66781211
--- /dev/null
+++ b/package/openafs/patches/patch-src_shlibafsrpc_Makefile_in
@@ -0,0 +1,11 @@
+--- openafs-1.6.5.orig/src/shlibafsrpc/Makefile.in 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/shlibafsrpc/Makefile.in 2013-09-24 22:20:22.450027563 +0200
+@@ -404,7 +404,7 @@ syscall.o: ${SYS}/syscall.s
+ ${CC} ${CFLAGS} -c syscall.c;; \
+ *) \
+ $(PATH_CPP) ${SFLAGS} ${SYS}/syscall.s > syscall.ss; \
+- as $(ASFLAGS) -o syscall.o syscall.ss; \
++ ${AS} $(ASFLAGS) -o syscall.o syscall.ss; \
+ $(RM) syscall.ss;; \
+ esac
+
diff --git a/package/openafs/patches/patch-src_sys_glue_c b/package/openafs/patches/patch-src_sys_glue_c
new file mode 100644
index 000000000..a1bb43376
--- /dev/null
+++ b/package/openafs/patches/patch-src_sys_glue_c
@@ -0,0 +1,12 @@
+--- openafs-1.6.5.orig/src/sys/glue.c 2013-07-18 00:10:42.000000000 +0200
++++ openafs-1.6.5/src/sys/glue.c 2013-09-15 14:36:10.940304169 +0200
+@@ -20,9 +20,7 @@
+ #include <sys/ioctl.h>
+ #include <unistd.h>
+ #include <stdio.h>
+-#ifdef AFS_SUN5_ENV
+ #include <fcntl.h>
+-#endif
+ #include "afssyscalls.h"
+
+ #ifdef AFS_LINUX20_ENV
diff --git a/package/openafs/src/src/comerr/internal.c b/package/openafs/src/src/comerr/internal.c
new file mode 100644
index 000000000..8e0193d44
--- /dev/null
+++ b/package/openafs/src/src/comerr/internal.c
@@ -0,0 +1,22 @@
+/* Just like strncpy but shift-case in transit and forces null termination */
+char *
+lcstring(char *d, char *s, int n)
+{
+ char *original_d = d;
+ char c;
+
+ if ((s == 0) || (d == 0))
+ return 0; /* just to be safe */
+ while (n) {
+ c = *s++;
+ if (isupper(c))
+ c = tolower(c);
+ *d++ = c;
+ if (c == 0)
+ break; /* quit after transferring null */
+ if (--n == 0)
+ *(d - 1) = 0; /* make sure null terminated */
+ }
+ return original_d;
+}
+
diff --git a/package/rsync/Makefile b/package/rsync/Makefile
index 054a5d641..939a46fd1 100644
--- a/package/rsync/Makefile
+++ b/package/rsync/Makefile
@@ -5,7 +5,7 @@ include ${TOPDIR}/rules.mk
PKG_NAME:= rsync
PKG_VERSION:= 3.0.9
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= 5ee72266fe2c1822333c407e1761b92b
PKG_DESCR:= utility that provides fast incremental file transfer
PKG_SECTION:= net/misc
diff --git a/package/rsync/patches/patch-Makefile_in b/package/rsync/patches/patch-Makefile_in
new file mode 100644
index 000000000..f955b5016
--- /dev/null
+++ b/package/rsync/patches/patch-Makefile_in
@@ -0,0 +1,11 @@
+--- rsync-3.0.9.orig/Makefile.in 2011-03-26 18:01:37.000000000 +0100
++++ rsync-3.0.9/Makefile.in 2013-09-26 12:40:43.000000000 +0200
+@@ -146,7 +146,7 @@ configure.sh config.h.in: configure.ac a
+ else \
+ echo 'You may need to run:'; \
+ echo ' make reconfigure'; \
+- exit 1; \
++ exit 0; \
+ fi \
+ fi
+
diff --git a/package/uclibc++/Makefile b/package/uclibc++/Makefile
index 6c1097e19..c51819429 100644
--- a/package/uclibc++/Makefile
+++ b/package/uclibc++/Makefile
@@ -5,7 +5,7 @@ include ${TOPDIR}/rules.mk
PKG_NAME:= uClibc++
PKG_VERSION:= 0.2.4
-PKG_RELEASE:= 1
+PKG_RELEASE:= 2
PKG_MD5SUM:= 394c119363dd8b469fb898442a6764b8
PKG_DESCR:= A standard c++ library for embedded systems
PKG_SECTION:= libs
diff --git a/package/uclibc++/patches/patch-include_unwind-cxx_h b/package/uclibc++/patches/patch-include_unwind-cxx_h
new file mode 100644
index 000000000..a81d44cc7
--- /dev/null
+++ b/package/uclibc++/patches/patch-include_unwind-cxx_h
@@ -0,0 +1,21 @@
+http://git.uclibc.org/uClibc++/commit/?id=cf73cb907c03ca2fb22bfe7fe2f732c10714b9ad
+--- uClibc++-0.2.4.orig/include/unwind-cxx.h 2012-05-25 23:15:31.000000000 +0200
++++ uClibc++-0.2.4/include/unwind-cxx.h 2013-09-24 11:48:52.000000000 +0200
+@@ -173,6 +173,7 @@ extern std::unexpected_handler __unexpec
+
+ // This is the exception class we report -- "GNUCC++\0".
+ const _Unwind_Exception_Class __gxx_exception_class
++#ifndef __ARM_EABI_UNWINDER__
+ = ((((((((_Unwind_Exception_Class) 'G'
+ << 8 | (_Unwind_Exception_Class) 'N')
+ << 8 | (_Unwind_Exception_Class) 'U')
+@@ -181,6 +182,9 @@ const _Unwind_Exception_Class __gxx_exce
+ << 8 | (_Unwind_Exception_Class) '+')
+ << 8 | (_Unwind_Exception_Class) '+')
+ << 8 | (_Unwind_Exception_Class) '\0');
++#else
++= "GNUCC++";
++#endif
+
+ // GNU C++ personality routine, Version 0.
+ extern "C" _Unwind_Reason_Code __gxx_personality_v0
diff --git a/package/vte/Makefile b/package/vte/Makefile
deleted file mode 100644
index a37d8fab0..000000000
--- a/package/vte/Makefile
+++ /dev/null
@@ -1,37 +0,0 @@
-# This file is part of the OpenADK project. OpenADK is copyrighted
-# material, please see the LICENCE file in the top-level directory.
-
-include $(TOPDIR)/rules.mk
-
-PKG_NAME:= vte
-PKG_VERSION:= 0.25.1
-PKG_EXTRAVER:= 0.25
-PKG_RELEASE:= 1
-PKG_MD5SUM:= 415ba972ea60b8016b7a98019fa412b1
-PKG_DESCR:= an experimental terminal emulator widget
-PKG_SECTION:= libs
-PKG_BUILDDEP:= ncurses
-PKG_URL:= http://www.gnome.org/
-PKG_SITES:= http://ftp.gnome.org/pub/GNOME/sources/vte/$(PKG_EXTRAVER)/
-
-PKG_SUBPKGS:= VTE VTE_DEV
-
-include $(TOPDIR)/mk/package.mk
-
-$(eval $(call PKG_template,VTE,vte,$(PKG_VERSION)-${PKG_RELEASE},${PKG_DEPENDS},${PKG_DESCR},${PKG_SECTION}))
-$(eval $(call PKG_template,VTE_DEV,vte-dev,$(PKG_VERSION)-${PKG_RELEASE},${PKG_DEPENDS},${PKG_DESCR},${PKG_SECTION}))
-
-vte-install:
- $(INSTALL_DIR) $(IDIR_VTE)/usr/lib
- $(CP) $(WRKINST)/usr/lib/libvte*.so* $(IDIR_VTE)/usr/lib
- $(INSTALL_DIR) $(IDIR_VTE)/usr/bin
- $(INSTALL_BIN) $(WRKINST)/usr/bin/vte $(IDIR_VTE)/usr/bin
-
-vte-dev-install:
- $(INSTALL_DIR) $(IDIR_VTE_DEV)/usr/include
- $(CP) $(WRKINST)/usr/include/* $(IDIR_VTE_DEV)/usr/include
- $(INSTALL_DIR) $(IDIR_VTE_DEV)/usr/lib/pkgconfig
- $(CP) $(WRKINST)/usr/lib/pkgconfig/*.pc \
- $(IDIR_VTE_DEV)/usr/lib/pkgconfig
-
-include ${TOPDIR}/mk/pkg-bottom.mk
diff --git a/target/arm/kernel.config.sharp-zaurus b/target/arm/kernel.config.sharp-zaurus
index 65b6f94ad..d00ec0d36 100644
--- a/target/arm/kernel.config.sharp-zaurus
+++ b/target/arm/kernel.config.sharp-zaurus
@@ -1,39 +1,30 @@
#
-# Automatically generated make config: don't edit
-# Linux/arm 2.6.39 Kernel Configuration
-# Fri Sep 30 15:02:47 2011
+# Automatically generated file; DO NOT EDIT.
+# Linux/arm 3.9.11 Kernel Configuration
#
CONFIG_ARM=y
CONFIG_SYS_SUPPORTS_APM_EMULATION=y
-CONFIG_HAVE_SCHED_CLOCK=y
CONFIG_GENERIC_GPIO=y
-# CONFIG_ARCH_USES_GETTIMEOFFSET is not set
-CONFIG_GENERIC_CLOCKEVENTS=y
-CONFIG_KTIME_SCALAR=y
CONFIG_HAVE_PROC_CPU=y
CONFIG_STACKTRACE_SUPPORT=y
CONFIG_HAVE_LATENCYTOP_SUPPORT=y
CONFIG_LOCKDEP_SUPPORT=y
CONFIG_TRACE_IRQFLAGS_SUPPORT=y
-CONFIG_HARDIRQS_SW_RESEND=y
-CONFIG_GENERIC_IRQ_PROBE=y
CONFIG_RWSEM_GENERIC_SPINLOCK=y
CONFIG_ARCH_HAS_CPUFREQ=y
-CONFIG_ARCH_HAS_CPU_IDLE_WAIT=y
CONFIG_GENERIC_HWEIGHT=y
CONFIG_GENERIC_CALIBRATE_DELAY=y
CONFIG_NEED_DMA_MAP_STATE=y
CONFIG_ARCH_MTD_XIP=y
CONFIG_VECTORS_BASE=0xffff0000
-# CONFIG_ARM_PATCH_PHYS_VIRT is not set
+CONFIG_ARM_PATCH_PHYS_VIRT=y
+CONFIG_NEED_MACH_GPIO_H=y
CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
-CONFIG_CONSTRUCTORS=y
-CONFIG_HAVE_IRQ_WORK=y
+CONFIG_IRQ_WORK=y
#
# General setup
#
-CONFIG_EXPERIMENTAL=y
CONFIG_BROKEN_ON_SMP=y
CONFIG_INIT_ENV_ARG_LIMIT=32
CONFIG_CROSS_COMPILE=""
@@ -41,17 +32,18 @@ CONFIG_LOCALVERSION=""
# CONFIG_LOCALVERSION_AUTO is not set
CONFIG_HAVE_KERNEL_GZIP=y
CONFIG_HAVE_KERNEL_LZMA=y
+CONFIG_HAVE_KERNEL_XZ=y
CONFIG_HAVE_KERNEL_LZO=y
# CONFIG_KERNEL_GZIP is not set
CONFIG_KERNEL_LZMA=y
+# CONFIG_KERNEL_XZ is not set
# CONFIG_KERNEL_LZO is not set
+CONFIG_DEFAULT_HOSTNAME="(none)"
# CONFIG_SWAP is not set
CONFIG_SYSVIPC=y
CONFIG_SYSVIPC_SYSCTL=y
# CONFIG_POSIX_MQUEUE is not set
-# CONFIG_BSD_PROCESS_ACCT is not set
# CONFIG_FHANDLE is not set
-# CONFIG_TASKSTATS is not set
# CONFIG_AUDIT is not set
CONFIG_HAVE_GENERIC_HARDIRQS=y
@@ -59,21 +51,42 @@ CONFIG_HAVE_GENERIC_HARDIRQS=y
# IRQ subsystem
#
CONFIG_GENERIC_HARDIRQS=y
-CONFIG_HAVE_SPARSE_IRQ=y
+CONFIG_GENERIC_IRQ_PROBE=y
CONFIG_GENERIC_IRQ_SHOW=y
+CONFIG_HARDIRQS_SW_RESEND=y
CONFIG_SPARSE_IRQ=y
+CONFIG_KTIME_SCALAR=y
+CONFIG_GENERIC_CLOCKEVENTS=y
+CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
+
+#
+# Timers subsystem
+#
+CONFIG_TICK_ONESHOT=y
+CONFIG_NO_HZ=y
+# CONFIG_HIGH_RES_TIMERS is not set
+
+#
+# CPU/Task time and stats accounting
+#
+CONFIG_TICK_CPU_ACCOUNTING=y
+# CONFIG_BSD_PROCESS_ACCT is not set
+# CONFIG_TASKSTATS is not set
#
# RCU Subsystem
#
CONFIG_TINY_RCU=y
# CONFIG_PREEMPT_RCU is not set
-# CONFIG_RCU_TRACE is not set
+# CONFIG_RCU_STALL_COMMON is not set
# CONFIG_TREE_RCU_TRACE is not set
# CONFIG_IKCONFIG is not set
CONFIG_LOG_BUF_SHIFT=14
# CONFIG_CGROUPS is not set
+# CONFIG_CHECKPOINT_RESTORE is not set
# CONFIG_NAMESPACES is not set
+CONFIG_UIDGID_CONVERTED=y
+# CONFIG_UIDGID_STRICT_TYPE_CHECKS is not set
# CONFIG_SCHED_AUTOGROUP is not set
# CONFIG_SYSFS_DEPRECATED is not set
# CONFIG_RELAY is not set
@@ -82,6 +95,7 @@ CONFIG_CC_OPTIMIZE_FOR_SIZE=y
CONFIG_SYSCTL=y
CONFIG_ANON_INODES=y
CONFIG_EXPERT=y
+CONFIG_HAVE_UID16=y
# CONFIG_UID16 is not set
# CONFIG_SYSCTL_SYSCALL is not set
# CONFIG_KALLSYMS is not set
@@ -105,7 +119,6 @@ CONFIG_PERF_USE_VMALLOC=y
# Kernel Performance Events And Counters
#
# CONFIG_PERF_EVENTS is not set
-# CONFIG_PERF_COUNTERS is not set
# CONFIG_VM_EVENT_COUNTERS is not set
# CONFIG_COMPAT_BRK is not set
CONFIG_SLAB=y
@@ -114,11 +127,24 @@ CONFIG_SLAB=y
# CONFIG_PROFILING is not set
CONFIG_HAVE_OPROFILE=y
# CONFIG_KPROBES is not set
+# CONFIG_JUMP_LABEL is not set
+# CONFIG_HAVE_64BIT_ALIGNED_ACCESS is not set
CONFIG_HAVE_KPROBES=y
CONFIG_HAVE_KRETPROBES=y
+CONFIG_HAVE_ARCH_TRACEHOOK=y
+CONFIG_HAVE_DMA_ATTRS=y
+CONFIG_HAVE_DMA_CONTIGUOUS=y
+CONFIG_GENERIC_SMP_IDLE_THREAD=y
CONFIG_HAVE_REGS_AND_STACK_ACCESS_API=y
CONFIG_HAVE_CLK=y
CONFIG_HAVE_DMA_API_DEBUG=y
+CONFIG_HAVE_ARCH_JUMP_LABEL=y
+CONFIG_ARCH_WANT_IPC_PARSE_VERSION=y
+CONFIG_HAVE_ARCH_SECCOMP_FILTER=y
+CONFIG_MODULES_USE_ELF_REL=y
+CONFIG_CLONE_BACKWARDS=y
+CONFIG_OLD_SIGSUSPEND3=y
+CONFIG_OLD_SIGACTION=y
#
# GCOV-based kernel profiling
@@ -133,12 +159,36 @@ CONFIG_MODULE_UNLOAD=y
CONFIG_MODULE_FORCE_UNLOAD=y
# CONFIG_MODVERSIONS is not set
# CONFIG_MODULE_SRCVERSION_ALL is not set
+# CONFIG_MODULE_SIG is not set
CONFIG_BLOCK=y
# CONFIG_LBDAF is not set
# CONFIG_BLK_DEV_BSG is not set
+# CONFIG_BLK_DEV_BSGLIB is not set
# CONFIG_BLK_DEV_INTEGRITY is not set
#
+# Partition Types
+#
+CONFIG_PARTITION_ADVANCED=y
+# CONFIG_ACORN_PARTITION is not set
+# CONFIG_OSF_PARTITION is not set
+# CONFIG_AMIGA_PARTITION is not set
+# CONFIG_ATARI_PARTITION is not set
+# CONFIG_MAC_PARTITION is not set
+CONFIG_MSDOS_PARTITION=y
+# CONFIG_BSD_DISKLABEL is not set
+# CONFIG_MINIX_SUBPARTITION is not set
+# CONFIG_SOLARIS_X86_PARTITION is not set
+# CONFIG_UNIXWARE_DISKLABEL is not set
+# CONFIG_LDM_PARTITION is not set
+# CONFIG_SGI_PARTITION is not set
+# CONFIG_ULTRIX_PARTITION is not set
+# CONFIG_SUN_PARTITION is not set
+# CONFIG_KARMA_PARTITION is not set
+# CONFIG_EFI_PARTITION is not set
+# CONFIG_SYSV68_PARTITION is not set
+
+#
# IO Schedulers
#
CONFIG_IOSCHED_NOOP=y
@@ -147,98 +197,65 @@ CONFIG_IOSCHED_DEADLINE=y
CONFIG_DEFAULT_DEADLINE=y
# CONFIG_DEFAULT_NOOP is not set
CONFIG_DEFAULT_IOSCHED="deadline"
-# CONFIG_INLINE_SPIN_TRYLOCK is not set
-# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set
-# CONFIG_INLINE_SPIN_LOCK is not set
-# CONFIG_INLINE_SPIN_LOCK_BH is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQ is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set
-CONFIG_INLINE_SPIN_UNLOCK=y
-# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
CONFIG_INLINE_SPIN_UNLOCK_IRQ=y
-# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_READ_TRYLOCK is not set
-# CONFIG_INLINE_READ_LOCK is not set
-# CONFIG_INLINE_READ_LOCK_BH is not set
-# CONFIG_INLINE_READ_LOCK_IRQ is not set
-# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set
CONFIG_INLINE_READ_UNLOCK=y
-# CONFIG_INLINE_READ_UNLOCK_BH is not set
CONFIG_INLINE_READ_UNLOCK_IRQ=y
-# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_WRITE_TRYLOCK is not set
-# CONFIG_INLINE_WRITE_LOCK is not set
-# CONFIG_INLINE_WRITE_LOCK_BH is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQ is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set
CONFIG_INLINE_WRITE_UNLOCK=y
-# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
CONFIG_INLINE_WRITE_UNLOCK_IRQ=y
-# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set
-# CONFIG_MUTEX_SPIN_ON_OWNER is not set
CONFIG_FREEZER=y
#
# System Type
#
CONFIG_MMU=y
+# CONFIG_ARCH_MULTIPLATFORM is not set
# CONFIG_ARCH_INTEGRATOR is not set
# CONFIG_ARCH_REALVIEW is not set
# CONFIG_ARCH_VERSATILE is not set
-# CONFIG_ARCH_VEXPRESS is not set
# CONFIG_ARCH_AT91 is not set
-# CONFIG_ARCH_BCMRING is not set
-# CONFIG_ARCH_CLPS711X is not set
+# CONFIG_ARCH_BCM2708 is not set
+# CONFIG_ARCH_BCM2835 is not set
# CONFIG_ARCH_CNS3XXX is not set
+# CONFIG_ARCH_CLPS711X is not set
# CONFIG_ARCH_GEMINI is not set
+# CONFIG_ARCH_SIRF is not set
# CONFIG_ARCH_EBSA110 is not set
# CONFIG_ARCH_EP93XX is not set
# CONFIG_ARCH_FOOTBRIDGE is not set
-# CONFIG_ARCH_MXC is not set
# CONFIG_ARCH_MXS is not set
-# CONFIG_ARCH_STMP3XXX is not set
# CONFIG_ARCH_NETX is not set
# CONFIG_ARCH_H720X is not set
# CONFIG_ARCH_IOP13XX is not set
# CONFIG_ARCH_IOP32X is not set
# CONFIG_ARCH_IOP33X is not set
-# CONFIG_ARCH_IXP23XX is not set
-# CONFIG_ARCH_IXP2000 is not set
# CONFIG_ARCH_IXP4XX is not set
# CONFIG_ARCH_DOVE is not set
# CONFIG_ARCH_KIRKWOOD is not set
-# CONFIG_ARCH_LOKI is not set
-# CONFIG_ARCH_LPC32XX is not set
# CONFIG_ARCH_MV78XX0 is not set
# CONFIG_ARCH_ORION5X is not set
# CONFIG_ARCH_MMP is not set
# CONFIG_ARCH_KS8695 is not set
-# CONFIG_ARCH_NS9XXX is not set
# CONFIG_ARCH_W90X900 is not set
-# CONFIG_ARCH_NUC93X is not set
+# CONFIG_ARCH_LPC32XX is not set
# CONFIG_ARCH_TEGRA is not set
-# CONFIG_ARCH_PNX4008 is not set
CONFIG_ARCH_PXA=y
# CONFIG_ARCH_MSM is not set
# CONFIG_ARCH_SHMOBILE is not set
# CONFIG_ARCH_RPC is not set
# CONFIG_ARCH_SA1100 is not set
-# CONFIG_ARCH_S3C2410 is not set
+# CONFIG_ARCH_S3C24XX is not set
# CONFIG_ARCH_S3C64XX is not set
# CONFIG_ARCH_S5P64X0 is not set
-# CONFIG_ARCH_S5P6442 is not set
# CONFIG_ARCH_S5PC100 is not set
# CONFIG_ARCH_S5PV210 is not set
-# CONFIG_ARCH_EXYNOS4 is not set
+# CONFIG_ARCH_EXYNOS is not set
# CONFIG_ARCH_SHARK is not set
-# CONFIG_ARCH_TCC_926 is not set
# CONFIG_ARCH_U300 is not set
# CONFIG_ARCH_U8500 is not set
# CONFIG_ARCH_NOMADIK is not set
-# CONFIG_ARCH_DAVINCI is not set
-# CONFIG_ARCH_OMAP is not set
# CONFIG_PLAT_SPEAR is not set
-# CONFIG_ARCH_VT8500 is not set
+# CONFIG_ARCH_DAVINCI is not set
+# CONFIG_ARCH_OMAP1 is not set
# CONFIG_GPIO_PCA953X is not set
#
@@ -248,15 +265,14 @@ CONFIG_ARCH_PXA=y
#
# Intel/Marvell Dev Platforms (sorted by hardware release time)
#
+# CONFIG_MACH_PXA3XX_DT is not set
# CONFIG_ARCH_LUBBOCK is not set
# CONFIG_MACH_MAINSTONE is not set
# CONFIG_MACH_ZYLONITE300 is not set
# CONFIG_MACH_ZYLONITE320 is not set
# CONFIG_MACH_LITTLETON is not set
# CONFIG_MACH_TAVOREVB is not set
-# CONFIG_MACH_TAVOREVB3 is not set
# CONFIG_MACH_SAAR is not set
-# CONFIG_MACH_SAARB is not set
#
# Third Party Dev Platforms (sorted by vendor name)
@@ -315,10 +331,6 @@ CONFIG_PXA_SHARP_Cxx00=y
CONFIG_SHARPSL_PM=y
CONFIG_SHARPSL_PM_MAX1111=y
CONFIG_PXA_SSP=y
-
-#
-# System MMU
-#
CONFIG_PLAT_PXA=y
#
@@ -337,12 +349,15 @@ CONFIG_CPU_USE_DOMAINS=y
#
# Processor Features
#
+# CONFIG_ARCH_PHYS_ADDR_T_64BIT is not set
# CONFIG_ARM_THUMB is not set
# CONFIG_CPU_DCACHE_DISABLE is not set
+# CONFIG_CACHE_L2X0 is not set
CONFIG_ARM_L1_CACHE_SHIFT=5
+CONFIG_ARM_NR_BANKS=8
CONFIG_IWMMXT=y
CONFIG_XSCALE_PMU=y
-CONFIG_CPU_HAS_PMU=y
+CONFIG_MULTI_IRQ_HANDLER=y
CONFIG_SHARP_PARAM=y
CONFIG_SHARP_SCOOP=y
@@ -350,53 +365,53 @@ CONFIG_SHARP_SCOOP=y
# Bus support
#
# CONFIG_PCI_SYSCALL is not set
-# CONFIG_ARCH_SUPPORTS_MSI is not set
# CONFIG_PCCARD is not set
#
# Kernel Features
#
-CONFIG_TICK_ONESHOT=y
-CONFIG_NO_HZ=y
-# CONFIG_HIGH_RES_TIMERS is not set
-CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
CONFIG_VMSPLIT_3G=y
# CONFIG_VMSPLIT_2G is not set
# CONFIG_VMSPLIT_1G is not set
CONFIG_PAGE_OFFSET=0xC0000000
+CONFIG_ARCH_NR_GPIO=0
CONFIG_PREEMPT_NONE=y
# CONFIG_PREEMPT_VOLUNTARY is not set
# CONFIG_PREEMPT is not set
CONFIG_HZ=100
+# CONFIG_SCHED_HRTICK is not set
CONFIG_AEABI=y
# CONFIG_OABI_COMPAT is not set
# CONFIG_ARCH_SPARSEMEM_DEFAULT is not set
# CONFIG_ARCH_SELECT_MEMORY_MODEL is not set
+CONFIG_HAVE_ARCH_PFN_VALID=y
# CONFIG_HIGHMEM is not set
-CONFIG_SELECT_MEMORY_MODEL=y
-CONFIG_FLATMEM_MANUAL=y
CONFIG_FLATMEM=y
CONFIG_FLAT_NODE_MEM_MAP=y
CONFIG_HAVE_MEMBLOCK=y
+# CONFIG_HAVE_BOOTMEM_INFO_NODE is not set
CONFIG_PAGEFLAGS_EXTENDED=y
CONFIG_SPLIT_PTLOCK_CPUS=999999
# CONFIG_COMPACTION is not set
# CONFIG_PHYS_ADDR_T_64BIT is not set
CONFIG_ZONE_DMA_FLAG=0
-CONFIG_VIRT_TO_BUS=y
# CONFIG_KSM is not set
CONFIG_DEFAULT_MMAP_MIN_ADDR=4096
+CONFIG_CROSS_MEMORY_ATTACH=y
CONFIG_NEED_PER_CPU_KM=y
+# CONFIG_CLEANCACHE is not set
CONFIG_FORCE_MAX_ZONEORDER=11
CONFIG_ALIGNMENT_TRAP=y
# CONFIG_UACCESS_WITH_MEMCPY is not set
# CONFIG_SECCOMP is not set
# CONFIG_CC_STACKPROTECTOR is not set
-# CONFIG_DEPRECATED_PARAM_STRUCT is not set
#
# Boot options
#
+# CONFIG_USE_OF is not set
+CONFIG_ATAGS=y
+# CONFIG_DEPRECATED_PARAM_STRUCT is not set
CONFIG_ZBOOT_ROM_TEXT=0x0
CONFIG_ZBOOT_ROM_BSS=0x0
CONFIG_CMDLINE=""
@@ -404,13 +419,18 @@ CONFIG_CMDLINE=""
CONFIG_KEXEC=y
CONFIG_ATAGS_PROC=y
# CONFIG_CRASH_DUMP is not set
-# CONFIG_AUTO_ZRELADDR is not set
+CONFIG_AUTO_ZRELADDR=y
#
# CPU Power Management
#
+
+#
+# CPU Frequency scaling
+#
# CONFIG_CPU_FREQ is not set
# CONFIG_CPU_IDLE is not set
+# CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED is not set
#
# Floating point emulation
@@ -424,9 +444,11 @@ CONFIG_ATAGS_PROC=y
# Userspace binary formats
#
CONFIG_BINFMT_ELF=y
+CONFIG_ARCH_BINFMT_ELF_RANDOMIZE_PIE=y
CONFIG_HAVE_AOUT=y
# CONFIG_BINFMT_AOUT is not set
# CONFIG_BINFMT_MISC is not set
+CONFIG_COREDUMP=y
#
# Power management options
@@ -434,18 +456,25 @@ CONFIG_HAVE_AOUT=y
CONFIG_SUSPEND=y
CONFIG_SUSPEND_FREEZER=y
CONFIG_PM_SLEEP=y
+# CONFIG_PM_AUTOSLEEP is not set
+# CONFIG_PM_WAKELOCKS is not set
# CONFIG_PM_RUNTIME is not set
CONFIG_PM=y
# CONFIG_PM_DEBUG is not set
CONFIG_APM_EMULATION=y
+CONFIG_PM_CLK=y
+CONFIG_CPU_PM=y
CONFIG_ARCH_SUSPEND_POSSIBLE=y
+CONFIG_ARM_CPU_SUSPEND=y
CONFIG_NET=y
#
# Networking options
#
CONFIG_PACKET=y
+# CONFIG_PACKET_DIAG is not set
CONFIG_UNIX=y
+# CONFIG_UNIX_DIAG is not set
CONFIG_XFRM=y
# CONFIG_XFRM_USER is not set
# CONFIG_XFRM_SUB_POLICY is not set
@@ -492,6 +521,7 @@ CONFIG_IPV6_SIT=y
# CONFIG_IPV6_SIT_6RD is not set
CONFIG_IPV6_NDISC_NODETYPE=y
# CONFIG_IPV6_TUNNEL is not set
+# CONFIG_IPV6_GRE is not set
# CONFIG_IPV6_MULTIPLE_TABLES is not set
# CONFIG_IPV6_MROUTE is not set
# CONFIG_NETWORK_SECMARK is not set
@@ -511,13 +541,15 @@ CONFIG_IPV6_NDISC_NODETYPE=y
# CONFIG_ATALK is not set
# CONFIG_X25 is not set
# CONFIG_LAPB is not set
-# CONFIG_ECONET is not set
-# CONFIG_WAN_ROUTER is not set
# CONFIG_PHONET is not set
# CONFIG_IEEE802154 is not set
# CONFIG_NET_SCHED is not set
# CONFIG_DCB is not set
# CONFIG_BATMAN_ADV is not set
+# CONFIG_OPENVSWITCH is not set
+# CONFIG_VSOCKETS is not set
+CONFIG_BQL=y
+# CONFIG_BPF_JIT is not set
#
# Network testing
@@ -534,6 +566,8 @@ CONFIG_IPV6_NDISC_NODETYPE=y
# CONFIG_NET_9P is not set
# CONFIG_CAIF is not set
# CONFIG_CEPH_LIB is not set
+# CONFIG_NFC is not set
+CONFIG_HAVE_BPF_JIT=y
#
# Device Drivers
@@ -550,13 +584,68 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y
CONFIG_FW_LOADER=y
CONFIG_FIRMWARE_IN_KERNEL=y
CONFIG_EXTRA_FIRMWARE=""
+CONFIG_FW_LOADER_USER_HELPER=y
+# CONFIG_DEBUG_DRIVER is not set
+# CONFIG_DEBUG_DEVRES is not set
# CONFIG_SYS_HYPERVISOR is not set
+# CONFIG_GENERIC_CPU_DEVICES is not set
+# CONFIG_DMA_SHARED_BUFFER is not set
+# CONFIG_CMA is not set
+
+#
+# Bus devices
+#
# CONFIG_CONNECTOR is not set
# CONFIG_MTD is not set
# CONFIG_PARPORT is not set
# CONFIG_BLK_DEV is not set
+
+#
+# Misc devices
+#
# CONFIG_SENSORS_LIS3LV02D is not set
-# CONFIG_MISC_DEVICES is not set
+# CONFIG_AD525X_DPOT is not set
+# CONFIG_ATMEL_PWM is not set
+# CONFIG_ICS932S401 is not set
+# CONFIG_ATMEL_SSC is not set
+# CONFIG_ENCLOSURE_SERVICES is not set
+# CONFIG_APDS9802ALS is not set
+# CONFIG_ISL29003 is not set
+# CONFIG_ISL29020 is not set
+# CONFIG_SENSORS_TSL2550 is not set
+# CONFIG_SENSORS_BH1780 is not set
+# CONFIG_SENSORS_BH1770 is not set
+# CONFIG_SENSORS_APDS990X is not set
+# CONFIG_HMC6352 is not set
+# CONFIG_DS1682 is not set
+# CONFIG_TI_DAC7512 is not set
+# CONFIG_BMP085_I2C is not set
+# CONFIG_BMP085_SPI is not set
+# CONFIG_USB_SWITCH_FSA9480 is not set
+# CONFIG_LATTICE_ECP3_CONFIG is not set
+# CONFIG_C2PORT is not set
+
+#
+# EEPROM support
+#
+# CONFIG_EEPROM_AT24 is not set
+# CONFIG_EEPROM_AT25 is not set
+# CONFIG_EEPROM_LEGACY is not set
+# CONFIG_EEPROM_MAX6875 is not set
+# CONFIG_EEPROM_93CX6 is not set
+# CONFIG_EEPROM_93XX46 is not set
+
+#
+# Texas Instruments shared transport line discipline
+#
+# CONFIG_TI_ST is not set
+# CONFIG_SENSORS_LIS3_SPI is not set
+# CONFIG_SENSORS_LIS3_I2C is not set
+
+#
+# Altera FPGA firmware download module
+#
+# CONFIG_ALTERA_STAPL is not set
CONFIG_HAVE_IDE=y
# CONFIG_IDE is not set
@@ -571,8 +660,6 @@ CONFIG_SCSI_MOD=y
# CONFIG_ATA is not set
# CONFIG_MD is not set
# CONFIG_NETDEVICES is not set
-# CONFIG_ISDN is not set
-# CONFIG_PHONE is not set
#
# Input device support
@@ -581,6 +668,7 @@ CONFIG_INPUT=y
# CONFIG_INPUT_FF_MEMLESS is not set
# CONFIG_INPUT_POLLDEV is not set
# CONFIG_INPUT_SPARSEKMAP is not set
+# CONFIG_INPUT_MATRIXKMAP is not set
#
# Userland interfaces
@@ -610,9 +698,11 @@ CONFIG_INPUT=y
#
# Character devices
#
+CONFIG_TTY=y
CONFIG_VT=y
# CONFIG_CONSOLE_TRANSLATIONS is not set
CONFIG_VT_CONSOLE=y
+CONFIG_VT_CONSOLE_SLEEP=y
CONFIG_HW_CONSOLE=y
# CONFIG_VT_HW_CONSOLE_BINDING is not set
CONFIG_UNIX98_PTYS=y
@@ -620,6 +710,7 @@ CONFIG_UNIX98_PTYS=y
# CONFIG_LEGACY_PTYS is not set
# CONFIG_SERIAL_NONSTANDARD is not set
# CONFIG_N_GSM is not set
+# CONFIG_TRACE_SINK is not set
# CONFIG_DEVKMEM is not set
#
@@ -631,12 +722,14 @@ CONFIG_UNIX98_PTYS=y
# Non-8250 serial port support
#
# CONFIG_SERIAL_MAX3100 is not set
-# CONFIG_SERIAL_MAX3107 is not set
+# CONFIG_SERIAL_MAX310X is not set
# CONFIG_SERIAL_PXA is not set
+# CONFIG_SERIAL_SCCNXP is not set
# CONFIG_SERIAL_TIMBERDALE is not set
# CONFIG_SERIAL_ALTERA_JTAGUART is not set
# CONFIG_SERIAL_ALTERA_UART is not set
# CONFIG_SERIAL_IFX6X60 is not set
+# CONFIG_SERIAL_ARC is not set
# CONFIG_TTY_PRINTK is not set
# CONFIG_HVC_DCC is not set
# CONFIG_IPMI_HANDLER is not set
@@ -644,7 +737,7 @@ CONFIG_UNIX98_PTYS=y
# CONFIG_R3964 is not set
# CONFIG_RAW_DRIVER is not set
# CONFIG_TCG_TPM is not set
-# CONFIG_RAMOOPS is not set
+# CONFIG_BRCM_CHAR_DRIVERS is not set
CONFIG_I2C=y
CONFIG_I2C_BOARDINFO=y
# CONFIG_I2C_COMPAT is not set
@@ -667,7 +760,8 @@ CONFIG_I2C_BOARDINFO=y
#
# I2C system bus drivers (mostly embedded / system-on-chip)
#
-# CONFIG_I2C_DESIGNWARE is not set
+# CONFIG_I2C_CBUS_GPIO is not set
+# CONFIG_I2C_DESIGNWARE_PLATFORM is not set
# CONFIG_I2C_GPIO is not set
# CONFIG_I2C_OCORES is not set
# CONFIG_I2C_PCA_PLATFORM is not set
@@ -691,6 +785,7 @@ CONFIG_I2C_PXA=y
# CONFIG_I2C_DEBUG_ALGO is not set
# CONFIG_I2C_DEBUG_BUS is not set
CONFIG_SPI=y
+# CONFIG_SPI_DEBUG is not set
CONFIG_SPI_MASTER=y
#
@@ -700,8 +795,12 @@ CONFIG_SPI_MASTER=y
# CONFIG_SPI_BITBANG is not set
# CONFIG_SPI_GPIO is not set
# CONFIG_SPI_OC_TINY is not set
+# CONFIG_SPI_PXA2XX_PXADMA is not set
+CONFIG_SPI_PXA2XX_DMA=y
CONFIG_SPI_PXA2XX=y
# CONFIG_SPI_PXA2XX_PCI is not set
+# CONFIG_SPI_SC18IS602 is not set
+# CONFIG_SPI_XCOMM is not set
# CONFIG_SPI_XILINX is not set
# CONFIG_SPI_DESIGNWARE is not set
@@ -710,6 +809,7 @@ CONFIG_SPI_PXA2XX=y
#
# CONFIG_SPI_SPIDEV is not set
# CONFIG_SPI_TLE62X0 is not set
+# CONFIG_HSI is not set
#
# PPS support
@@ -719,15 +819,30 @@ CONFIG_SPI_PXA2XX=y
#
# PPS generators support
#
+
+#
+# PTP clock support
+#
+# CONFIG_PTP_1588_CLOCK is not set
+
+#
+# Enable PHYLIB and NETWORK_PHY_TIMESTAMPING to see the additional clocks.
+#
+# CONFIG_PTP_1588_CLOCK_PCH is not set
+CONFIG_ARCH_HAVE_CUSTOM_GPIO_H=y
CONFIG_ARCH_REQUIRE_GPIOLIB=y
+CONFIG_GPIO_DEVRES=y
CONFIG_GPIOLIB=y
+# CONFIG_DEBUG_GPIO is not set
# CONFIG_GPIO_SYSFS is not set
#
-# Memory mapped GPIO expanders:
+# Memory mapped GPIO drivers:
#
-# CONFIG_GPIO_BASIC_MMIO is not set
-# CONFIG_GPIO_IT8761E is not set
+# CONFIG_GPIO_GENERIC_PLATFORM is not set
+# CONFIG_GPIO_EM is not set
+CONFIG_GPIO_PXA=y
+# CONFIG_GPIO_TS5500 is not set
#
# I2C GPIO expanders:
@@ -757,18 +872,32 @@ CONFIG_GPIOLIB=y
#
# MODULbus GPIO expanders:
#
+
+#
+# USB GPIO expanders:
+#
# CONFIG_W1 is not set
CONFIG_POWER_SUPPLY=y
# CONFIG_POWER_SUPPLY_DEBUG is not set
CONFIG_PDA_POWER=y
CONFIG_APM_POWER=y
# CONFIG_TEST_POWER is not set
+# CONFIG_BATTERY_DS2780 is not set
+# CONFIG_BATTERY_DS2781 is not set
# CONFIG_BATTERY_DS2782 is not set
-# CONFIG_BATTERY_BQ20Z75 is not set
+# CONFIG_BATTERY_SBS is not set
# CONFIG_BATTERY_BQ27x00 is not set
# CONFIG_BATTERY_MAX17040 is not set
# CONFIG_BATTERY_MAX17042 is not set
+# CONFIG_CHARGER_MAX8903 is not set
+# CONFIG_CHARGER_LP8727 is not set
# CONFIG_CHARGER_GPIO is not set
+# CONFIG_CHARGER_BQ2415X is not set
+# CONFIG_CHARGER_SMB347 is not set
+# CONFIG_BATTERY_GOLDFISH is not set
+# CONFIG_POWER_RESET is not set
+# CONFIG_POWER_RESET_RESTART is not set
+# CONFIG_POWER_AVS is not set
CONFIG_HWMON=y
# CONFIG_HWMON_VID is not set
# CONFIG_HWMON_DEBUG_CHIP is not set
@@ -776,6 +905,7 @@ CONFIG_HWMON=y
#
# Native drivers
#
+# CONFIG_SENSORS_AD7314 is not set
# CONFIG_SENSORS_AD7414 is not set
# CONFIG_SENSORS_AD7418 is not set
# CONFIG_SENSORS_ADCXX is not set
@@ -785,6 +915,7 @@ CONFIG_HWMON=y
# CONFIG_SENSORS_ADM1029 is not set
# CONFIG_SENSORS_ADM1031 is not set
# CONFIG_SENSORS_ADM9240 is not set
+# CONFIG_SENSORS_ADT7410 is not set
# CONFIG_SENSORS_ADT7411 is not set
# CONFIG_SENSORS_ADT7462 is not set
# CONFIG_SENSORS_ADT7470 is not set
@@ -800,6 +931,7 @@ CONFIG_HWMON=y
# CONFIG_SENSORS_GL518SM is not set
# CONFIG_SENSORS_GL520SM is not set
# CONFIG_SENSORS_GPIO_FAN is not set
+# CONFIG_SENSORS_HIH6130 is not set
# CONFIG_SENSORS_IT87 is not set
# CONFIG_SENSORS_JC42 is not set
# CONFIG_SENSORS_LINEAGE is not set
@@ -821,10 +953,18 @@ CONFIG_HWMON=y
# CONFIG_SENSORS_LTC4245 is not set
# CONFIG_SENSORS_LTC4261 is not set
# CONFIG_SENSORS_LM95241 is not set
+# CONFIG_SENSORS_LM95245 is not set
CONFIG_SENSORS_MAX1111=y
+# CONFIG_SENSORS_MAX16065 is not set
# CONFIG_SENSORS_MAX1619 is not set
+# CONFIG_SENSORS_MAX1668 is not set
+# CONFIG_SENSORS_MAX197 is not set
# CONFIG_SENSORS_MAX6639 is not set
+# CONFIG_SENSORS_MAX6642 is not set
# CONFIG_SENSORS_MAX6650 is not set
+# CONFIG_SENSORS_MAX6697 is not set
+# CONFIG_SENSORS_MCP3021 is not set
+# CONFIG_SENSORS_NTC_THERMISTOR is not set
# CONFIG_SENSORS_PC87360 is not set
# CONFIG_SENSORS_PC87427 is not set
# CONFIG_SENSORS_PCF8591 is not set
@@ -835,14 +975,17 @@ CONFIG_SENSORS_MAX1111=y
# CONFIG_SENSORS_DME1737 is not set
# CONFIG_SENSORS_EMC1403 is not set
# CONFIG_SENSORS_EMC2103 is not set
+# CONFIG_SENSORS_EMC6W201 is not set
# CONFIG_SENSORS_SMSC47M1 is not set
# CONFIG_SENSORS_SMSC47M192 is not set
# CONFIG_SENSORS_SMSC47B397 is not set
-# CONFIG_SENSORS_SCH5627 is not set
+# CONFIG_SENSORS_SCH56XX_COMMON is not set
# CONFIG_SENSORS_ADS1015 is not set
# CONFIG_SENSORS_ADS7828 is not set
# CONFIG_SENSORS_ADS7871 is not set
# CONFIG_SENSORS_AMC6821 is not set
+# CONFIG_SENSORS_INA209 is not set
+# CONFIG_SENSORS_INA2XX is not set
# CONFIG_SENSORS_THMC50 is not set
# CONFIG_SENSORS_TMP102 is not set
# CONFIG_SENSORS_TMP401 is not set
@@ -857,6 +1000,7 @@ CONFIG_SENSORS_MAX1111=y
# CONFIG_SENSORS_W83L786NG is not set
# CONFIG_SENSORS_W83627HF is not set
# CONFIG_SENSORS_W83627EHF is not set
+# CONFIG_SENSORS_BCM2835 is not set
# CONFIG_THERMAL is not set
# CONFIG_WATCHDOG is not set
CONFIG_SSB_POSSIBLE=y
@@ -865,7 +1009,77 @@ CONFIG_SSB_POSSIBLE=y
# Sonics Silicon Backplane
#
# CONFIG_SSB is not set
-# CONFIG_MFD_SUPPORT is not set
+CONFIG_BCMA_POSSIBLE=y
+
+#
+# Broadcom specific AMBA
+#
+# CONFIG_BCMA is not set
+
+#
+# Multifunction device drivers
+#
+# CONFIG_MFD_CORE is not set
+# CONFIG_MFD_88PM860X is not set
+# CONFIG_MFD_88PM800 is not set
+# CONFIG_MFD_88PM805 is not set
+# CONFIG_MFD_SM501 is not set
+# CONFIG_MFD_ASIC3 is not set
+# CONFIG_MFD_TI_AM335X_TSCADC is not set
+# CONFIG_HTC_EGPIO is not set
+# CONFIG_HTC_PASIC3 is not set
+# CONFIG_HTC_I2CPLD is not set
+# CONFIG_MFD_LM3533 is not set
+# CONFIG_TPS6105X is not set
+# CONFIG_TPS65010 is not set
+# CONFIG_TPS6507X is not set
+# CONFIG_MFD_TPS65217 is not set
+# CONFIG_MFD_TPS6586X is not set
+# CONFIG_MFD_TPS65910 is not set
+# CONFIG_MFD_TPS65912_I2C is not set
+# CONFIG_MFD_TPS65912_SPI is not set
+# CONFIG_MFD_TPS80031 is not set
+# CONFIG_TWL4030_CORE is not set
+# CONFIG_TWL6040_CORE is not set
+# CONFIG_MFD_STMPE is not set
+# CONFIG_MFD_TC3589X is not set
+# CONFIG_MFD_TMIO is not set
+# CONFIG_MFD_T7L66XB is not set
+# CONFIG_MFD_SMSC is not set
+# CONFIG_MFD_TC6387XB is not set
+# CONFIG_MFD_TC6393XB is not set
+# CONFIG_PMIC_DA903X is not set
+# CONFIG_MFD_DA9052_SPI is not set
+# CONFIG_MFD_DA9052_I2C is not set
+# CONFIG_MFD_DA9055 is not set
+# CONFIG_PMIC_ADP5520 is not set
+# CONFIG_MFD_LP8788 is not set
+# CONFIG_MFD_MAX77686 is not set
+# CONFIG_MFD_MAX77693 is not set
+# CONFIG_MFD_MAX8907 is not set
+# CONFIG_MFD_MAX8925 is not set
+# CONFIG_MFD_MAX8997 is not set
+# CONFIG_MFD_MAX8998 is not set
+# CONFIG_MFD_SEC_CORE is not set
+# CONFIG_MFD_ARIZONA_I2C is not set
+# CONFIG_MFD_ARIZONA_SPI is not set
+# CONFIG_MFD_WM8400 is not set
+# CONFIG_MFD_WM831X_I2C is not set
+# CONFIG_MFD_WM831X_SPI is not set
+# CONFIG_MFD_WM8350_I2C is not set
+# CONFIG_MFD_WM8994 is not set
+# CONFIG_MFD_PCF50633 is not set
+# CONFIG_MFD_MC13XXX_SPI is not set
+# CONFIG_MFD_MC13XXX_I2C is not set
+# CONFIG_ABX500_CORE is not set
+# CONFIG_EZX_PCAP is not set
+# CONFIG_MFD_WL1273_CORE is not set
+# CONFIG_MFD_TPS65090 is not set
+# CONFIG_MFD_AAT2870_CORE is not set
+# CONFIG_MFD_RC5T583 is not set
+# CONFIG_MFD_PALMAS is not set
+# CONFIG_MFD_RETU is not set
+# CONFIG_MFD_AS3711 is not set
# CONFIG_REGULATOR is not set
# CONFIG_MEDIA_SUPPORT is not set
@@ -898,6 +1112,7 @@ CONFIG_FB_CFB_IMAGEBLIT=y
#
# Frame buffer hardware drivers
#
+# CONFIG_FB_BCM2708 is not set
# CONFIG_FB_S1D13XXX is not set
CONFIG_FB_PXA=y
# CONFIG_FB_PXA_OVERLAY is not set
@@ -906,29 +1121,34 @@ CONFIG_FB_PXA=y
# CONFIG_PXA3XX_GCU is not set
# CONFIG_FB_MBX is not set
# CONFIG_FB_W100 is not set
+# CONFIG_FB_GOLDFISH is not set
# CONFIG_FB_VIRTUAL is not set
# CONFIG_FB_METRONOME is not set
-# CONFIG_FB_MB862XX is not set
# CONFIG_FB_BROADSHEET is not set
+# CONFIG_FB_AUO_K190X is not set
+# CONFIG_EXYNOS_VIDEO is not set
CONFIG_BACKLIGHT_LCD_SUPPORT=y
CONFIG_LCD_CLASS_DEVICE=y
CONFIG_LCD_CORGI=y
# CONFIG_LCD_L4F00242T03 is not set
# CONFIG_LCD_LMS283GF05 is not set
# CONFIG_LCD_LTV350QV is not set
+# CONFIG_LCD_ILI9320 is not set
# CONFIG_LCD_TDO24M is not set
# CONFIG_LCD_VGG2432A4 is not set
# CONFIG_LCD_PLATFORM is not set
# CONFIG_LCD_S6E63M0 is not set
# CONFIG_LCD_LD9040 is not set
+# CONFIG_LCD_AMS369FG06 is not set
+# CONFIG_LCD_LMS501KF03 is not set
+# CONFIG_LCD_HX8357 is not set
CONFIG_BACKLIGHT_CLASS_DEVICE=y
CONFIG_BACKLIGHT_GENERIC=y
# CONFIG_BACKLIGHT_ADP8860 is not set
-
-#
-# Display device support
-#
-# CONFIG_DISPLAY_SUPPORT is not set
+# CONFIG_BACKLIGHT_ADP8870 is not set
+# CONFIG_BACKLIGHT_LM3630 is not set
+# CONFIG_BACKLIGHT_LM3639 is not set
+# CONFIG_BACKLIGHT_LP855X is not set
#
# Console display driver support
@@ -948,27 +1168,80 @@ CONFIG_FONT_8x16=y
# CONFIG_FONT_SUN8x16 is not set
# CONFIG_FONT_SUN12x22 is not set
# CONFIG_FONT_10x18 is not set
+CONFIG_FONT_AUTOSELECT=y
CONFIG_LOGO=y
# CONFIG_LOGO_LINUX_MONO is not set
# CONFIG_LOGO_LINUX_VGA16 is not set
CONFIG_LOGO_LINUX_CLUT224=y
# CONFIG_SOUND is not set
-# CONFIG_HID_SUPPORT is not set
+
+#
+# HID support
+#
+CONFIG_HID=y
+# CONFIG_HID_BATTERY_STRENGTH is not set
+# CONFIG_HIDRAW is not set
+# CONFIG_UHID is not set
+CONFIG_HID_GENERIC=y
+
+#
+# Special HID drivers
+#
+
+#
+# I2C HID support
+#
+# CONFIG_I2C_HID is not set
+CONFIG_USB_ARCH_HAS_OHCI=y
+# CONFIG_USB_ARCH_HAS_EHCI is not set
+# CONFIG_USB_ARCH_HAS_XHCI is not set
# CONFIG_USB_SUPPORT is not set
# CONFIG_MMC is not set
# CONFIG_MEMSTICK is not set
# CONFIG_NEW_LEDS is not set
-# CONFIG_NFC_DEVICES is not set
# CONFIG_ACCESSIBILITY is not set
+# CONFIG_EDAC is not set
CONFIG_RTC_LIB=y
# CONFIG_RTC_CLASS is not set
# CONFIG_DMADEVICES is not set
# CONFIG_AUXDISPLAY is not set
# CONFIG_UIO is not set
+
+#
+# Virtio drivers
+#
+# CONFIG_VIRTIO_MMIO is not set
+
+#
+# Microsoft Hyper-V guest support
+#
# CONFIG_STAGING is not set
CONFIG_CLKDEV_LOOKUP=y
#
+# Hardware Spinlock drivers
+#
+CONFIG_CLKSRC_MMIO=y
+# CONFIG_MAILBOX is not set
+CONFIG_IOMMU_SUPPORT=y
+
+#
+# Remoteproc drivers
+#
+# CONFIG_STE_MODEM_RPROC is not set
+
+#
+# Rpmsg drivers
+#
+# CONFIG_VIRT_DRIVERS is not set
+# CONFIG_PM_DEVFREQ is not set
+# CONFIG_EXTCON is not set
+# CONFIG_MEMORY is not set
+# CONFIG_IIO is not set
+# CONFIG_PWM is not set
+# CONFIG_IPACK_BUS is not set
+
+#
# File systems
#
CONFIG_EXT2_FS=y
@@ -1021,6 +1294,7 @@ CONFIG_PROC_SYSCTL=y
CONFIG_SYSFS=y
CONFIG_TMPFS=y
CONFIG_TMPFS_POSIX_ACL=y
+CONFIG_TMPFS_XATTR=y
# CONFIG_HUGETLB_PAGE is not set
# CONFIG_CONFIGFS_FS is not set
CONFIG_MISC_FILESYSTEMS=y
@@ -1039,10 +1313,12 @@ CONFIG_MISC_FILESYSTEMS=y
# CONFIG_OMFS_FS is not set
# CONFIG_HPFS_FS is not set
# CONFIG_QNX4FS_FS is not set
+# CONFIG_QNX6FS_FS is not set
# CONFIG_ROMFS_FS is not set
# CONFIG_PSTORE is not set
# CONFIG_SYSV_FS is not set
# CONFIG_UFS_FS is not set
+# CONFIG_F2FS_FS is not set
CONFIG_NETWORK_FILESYSTEMS=y
# CONFIG_NFS_FS is not set
# CONFIG_NFSD is not set
@@ -1051,28 +1327,6 @@ CONFIG_NETWORK_FILESYSTEMS=y
# CONFIG_NCP_FS is not set
# CONFIG_CODA_FS is not set
# CONFIG_AFS_FS is not set
-
-#
-# Partition Types
-#
-CONFIG_PARTITION_ADVANCED=y
-# CONFIG_ACORN_PARTITION is not set
-# CONFIG_OSF_PARTITION is not set
-# CONFIG_AMIGA_PARTITION is not set
-# CONFIG_ATARI_PARTITION is not set
-# CONFIG_MAC_PARTITION is not set
-CONFIG_MSDOS_PARTITION=y
-# CONFIG_BSD_DISKLABEL is not set
-# CONFIG_MINIX_SUBPARTITION is not set
-# CONFIG_SOLARIS_X86_PARTITION is not set
-# CONFIG_UNIXWARE_DISKLABEL is not set
-# CONFIG_LDM_PARTITION is not set
-# CONFIG_SGI_PARTITION is not set
-# CONFIG_ULTRIX_PARTITION is not set
-# CONFIG_SUN_PARTITION is not set
-# CONFIG_KARMA_PARTITION is not set
-# CONFIG_EFI_PARTITION is not set
-# CONFIG_SYSV68_PARTITION is not set
CONFIG_NLS=y
CONFIG_NLS_DEFAULT="iso8859-1"
# CONFIG_NLS_CODEPAGE_437 is not set
@@ -1112,6 +1366,17 @@ CONFIG_NLS_ISO8859_1=y
# CONFIG_NLS_ISO8859_15 is not set
# CONFIG_NLS_KOI8_R is not set
# CONFIG_NLS_KOI8_U is not set
+# CONFIG_NLS_MAC_ROMAN is not set
+# CONFIG_NLS_MAC_CELTIC is not set
+# CONFIG_NLS_MAC_CENTEURO is not set
+# CONFIG_NLS_MAC_CROATIAN is not set
+# CONFIG_NLS_MAC_CYRILLIC is not set
+# CONFIG_NLS_MAC_GAELIC is not set
+# CONFIG_NLS_MAC_GREEK is not set
+# CONFIG_NLS_MAC_ICELAND is not set
+# CONFIG_NLS_MAC_INUIT is not set
+# CONFIG_NLS_MAC_ROMANIAN is not set
+# CONFIG_NLS_MAC_TURKISH is not set
# CONFIG_NLS_UTF8 is not set
#
@@ -1124,32 +1389,81 @@ CONFIG_DEFAULT_MESSAGE_LOGLEVEL=4
CONFIG_FRAME_WARN=2048
CONFIG_MAGIC_SYSRQ=y
# CONFIG_STRIP_ASM_SYMS is not set
+# CONFIG_READABLE_ASM is not set
# CONFIG_UNUSED_SYMBOLS is not set
# CONFIG_DEBUG_FS is not set
# CONFIG_HEADERS_CHECK is not set
# CONFIG_DEBUG_SECTION_MISMATCH is not set
-# CONFIG_DEBUG_KERNEL is not set
-# CONFIG_HARDLOCKUP_DETECTOR is not set
-# CONFIG_SPARSE_RCU_POINTER is not set
+CONFIG_DEBUG_KERNEL=y
+# CONFIG_DEBUG_SHIRQ is not set
+# CONFIG_LOCKUP_DETECTOR is not set
+# CONFIG_PANIC_ON_OOPS is not set
+CONFIG_PANIC_ON_OOPS_VALUE=0
+# CONFIG_DETECT_HUNG_TASK is not set
+CONFIG_SCHED_DEBUG=y
+# CONFIG_SCHEDSTATS is not set
+# CONFIG_TIMER_STATS is not set
+# CONFIG_DEBUG_OBJECTS is not set
+# CONFIG_DEBUG_SLAB is not set
+CONFIG_HAVE_DEBUG_KMEMLEAK=y
+# CONFIG_DEBUG_KMEMLEAK is not set
+# CONFIG_DEBUG_RT_MUTEXES is not set
+# CONFIG_RT_MUTEX_TESTER is not set
+# CONFIG_DEBUG_SPINLOCK is not set
+# CONFIG_DEBUG_MUTEXES is not set
+# CONFIG_DEBUG_LOCK_ALLOC is not set
+# CONFIG_PROVE_LOCKING is not set
+# CONFIG_LOCK_STAT is not set
+# CONFIG_DEBUG_ATOMIC_SLEEP is not set
+# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
+# CONFIG_DEBUG_STACK_USAGE is not set
+# CONFIG_DEBUG_KOBJECT is not set
+# CONFIG_DEBUG_INFO is not set
+# CONFIG_DEBUG_VM is not set
+# CONFIG_DEBUG_WRITECOUNT is not set
# CONFIG_DEBUG_MEMORY_INIT is not set
+# CONFIG_DEBUG_LIST is not set
+# CONFIG_TEST_LIST_SORT is not set
+# CONFIG_DEBUG_SG is not set
+# CONFIG_DEBUG_NOTIFIERS is not set
+# CONFIG_DEBUG_CREDENTIALS is not set
CONFIG_FRAME_POINTER=y
-# CONFIG_SYSCTL_SYSCALL_CHECK is not set
+# CONFIG_BOOT_PRINTK_DELAY is not set
+
+#
+# RCU Debugging
+#
+# CONFIG_SPARSE_RCU_POINTER is not set
+# CONFIG_RCU_TORTURE_TEST is not set
+# CONFIG_RCU_TRACE is not set
+# CONFIG_BACKTRACE_SELF_TEST is not set
+# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
+# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
+# CONFIG_NOTIFIER_ERROR_INJECTION is not set
+# CONFIG_FAULT_INJECTION is not set
+# CONFIG_LATENCYTOP is not set
+# CONFIG_DEBUG_PAGEALLOC is not set
CONFIG_HAVE_FUNCTION_TRACER=y
CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
CONFIG_HAVE_DYNAMIC_FTRACE=y
CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
+CONFIG_HAVE_SYSCALL_TRACEPOINTS=y
CONFIG_HAVE_C_RECORDMCOUNT=y
CONFIG_TRACING_SUPPORT=y
# CONFIG_FTRACE is not set
+# CONFIG_RBTREE_TEST is not set
+# CONFIG_INTERVAL_TREE_TEST is not set
# CONFIG_DMA_API_DEBUG is not set
# CONFIG_ATOMIC64_SELFTEST is not set
# CONFIG_SAMPLES is not set
CONFIG_HAVE_ARCH_KGDB=y
+# CONFIG_KGDB is not set
# CONFIG_TEST_KSTRTOX is not set
# CONFIG_STRICT_DEVMEM is not set
# CONFIG_ARM_UNWIND is not set
# CONFIG_DEBUG_USER is not set
-# CONFIG_OC_ETM is not set
+# CONFIG_DEBUG_LL is not set
+CONFIG_DEBUG_LL_INCLUDE="mach/debug-macro.S"
#
# Security options
@@ -1165,8 +1479,11 @@ CONFIG_CRYPTO=y
#
# Crypto core or helper
#
+CONFIG_CRYPTO_ALGAPI=y
+CONFIG_CRYPTO_ALGAPI2=y
# CONFIG_CRYPTO_MANAGER is not set
# CONFIG_CRYPTO_MANAGER2 is not set
+# CONFIG_CRYPTO_USER is not set
# CONFIG_CRYPTO_GF128MUL is not set
# CONFIG_CRYPTO_NULL is not set
# CONFIG_CRYPTO_CRYPTD is not set
@@ -1202,6 +1519,7 @@ CONFIG_CRYPTO=y
# Digest
#
# CONFIG_CRYPTO_CRC32C is not set
+# CONFIG_CRYPTO_CRC32 is not set
# CONFIG_CRYPTO_GHASH is not set
# CONFIG_CRYPTO_MD4 is not set
# CONFIG_CRYPTO_MD5 is not set
@@ -1211,6 +1529,7 @@ CONFIG_CRYPTO=y
# CONFIG_CRYPTO_RMD256 is not set
# CONFIG_CRYPTO_RMD320 is not set
# CONFIG_CRYPTO_SHA1 is not set
+# CONFIG_CRYPTO_SHA1_ARM is not set
# CONFIG_CRYPTO_SHA256 is not set
# CONFIG_CRYPTO_SHA512 is not set
# CONFIG_CRYPTO_TGR192 is not set
@@ -1219,7 +1538,8 @@ CONFIG_CRYPTO=y
#
# Ciphers
#
-# CONFIG_CRYPTO_AES is not set
+CONFIG_CRYPTO_AES=y
+# CONFIG_CRYPTO_AES_ARM is not set
# CONFIG_CRYPTO_ANUBIS is not set
# CONFIG_CRYPTO_ARC4 is not set
# CONFIG_CRYPTO_BLOWFISH is not set
@@ -1249,25 +1569,29 @@ CONFIG_CRYPTO=y
# CONFIG_CRYPTO_USER_API_HASH is not set
# CONFIG_CRYPTO_USER_API_SKCIPHER is not set
# CONFIG_CRYPTO_HW is not set
-
-#
-# OCF Configuration
-#
-# CONFIG_OCF_OCF is not set
# CONFIG_BINARY_PRINTF is not set
#
# Library routines
#
CONFIG_BITREVERSE=y
-CONFIG_GENERIC_FIND_LAST_BIT=y
+CONFIG_GENERIC_STRNCPY_FROM_USER=y
+CONFIG_GENERIC_STRNLEN_USER=y
+CONFIG_GENERIC_PCI_IOMAP=y
+CONFIG_GENERIC_IO=y
# CONFIG_CRC_CCITT is not set
CONFIG_CRC16=y
# CONFIG_CRC_T10DIF is not set
# CONFIG_CRC_ITU_T is not set
CONFIG_CRC32=y
+# CONFIG_CRC32_SELFTEST is not set
+CONFIG_CRC32_SLICEBY8=y
+# CONFIG_CRC32_SLICEBY4 is not set
+# CONFIG_CRC32_SARWATE is not set
+# CONFIG_CRC32_BIT is not set
# CONFIG_CRC7 is not set
# CONFIG_LIBCRC32C is not set
+# CONFIG_CRC8 is not set
CONFIG_XZ_DEC=y
CONFIG_XZ_DEC_X86=y
CONFIG_XZ_DEC_POWERPC=y
@@ -1280,6 +1604,11 @@ CONFIG_XZ_DEC_BCJ=y
CONFIG_HAS_IOMEM=y
CONFIG_HAS_IOPORT=y
CONFIG_HAS_DMA=y
+CONFIG_DQL=y
CONFIG_NLATTR=y
CONFIG_GENERIC_ATOMIC64=y
+CONFIG_ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE=y
CONFIG_AVERAGE=y
+# CONFIG_CORDIC is not set
+# CONFIG_DDR is not set
+# CONFIG_VIRTUALIZATION is not set
diff --git a/target/linux/config/Config.in.misc b/target/linux/config/Config.in.misc
index 57b64d5e9..ea9bc5e5a 100644
--- a/target/linux/config/Config.in.misc
+++ b/target/linux/config/Config.in.misc
@@ -1,3 +1,6 @@
+config ADK_KERNEL_KEYS
+ boolean
+
config ADK_KERNEL_I2C
boolean
diff --git a/target/linux/patches/3.9.11/arm-spitz.patch b/target/linux/patches/3.9.11/arm-spitz.patch
new file mode 100644
index 000000000..aea848244
--- /dev/null
+++ b/target/linux/patches/3.9.11/arm-spitz.patch
@@ -0,0 +1,27 @@
+http://lists.infradead.org/pipermail/linux-arm-kernel/2013-September/198444.html
+
+diff -Nur linux-3.9.11.orig/arch/arm/common/sharpsl_param.c linux-3.9.11/arch/arm/common/sharpsl_param.c
+--- linux-3.9.11.orig/arch/arm/common/sharpsl_param.c 2013-07-21 02:16:17.000000000 +0200
++++ linux-3.9.11/arch/arm/common/sharpsl_param.c 2013-09-18 16:27:10.000000000 +0200
+@@ -26,6 +26,7 @@
+ #ifdef CONFIG_ARCH_SA1100
+ #define PARAM_BASE 0xe8ffc000
+ #else
++#include <asm/memory.h>
+ #define PARAM_BASE 0xa0000a00
+ #endif
+ #define MAGIC_CHG(a,b,c,d) ( ( d << 24 ) | ( c << 16 ) | ( b << 8 ) | a )
+@@ -41,7 +42,12 @@
+
+ void sharpsl_save_param(void)
+ {
+- memcpy(&sharpsl_param, (void *)PARAM_BASE, sizeof(struct sharpsl_param_info));
++#ifdef CONFIG_ARCH_SA1100
++ void *param_start = (void *)PARAM_BASE;
++#else
++ void *param_start = phys_to_virt(PARAM_BASE);
++#endif
++ memcpy(&sharpsl_param, param_start, sizeof(struct sharpsl_param_info));
+
+ if (sharpsl_param.comadj_keyword != COMADJ_MAGIC)
+ sharpsl_param.comadj=-1;
diff --git a/target/ppc/kernel.config b/target/ppc/kernel.config
index 42f6e73e2..d48da1856 100644
--- a/target/ppc/kernel.config
+++ b/target/ppc/kernel.config
@@ -1,7 +1,6 @@
#
-# Automatically generated make config: don't edit
-# Linux/powerpc 2.6.39 Kernel Configuration
-# Mon Sep 5 19:53:55 2011
+# Automatically generated file; DO NOT EDIT.
+# Linux/powerpc 3.9.11 Kernel Configuration
#
# CONFIG_PPC64 is not set
@@ -23,15 +22,13 @@ CONFIG_PPC_STD_MMU_32=y
# CONFIG_PPC_MM_SLICES is not set
CONFIG_PPC_HAVE_PMU_SUPPORT=y
# CONFIG_SMP is not set
+# CONFIG_PPC_DOORBELL is not set
CONFIG_PPC32=y
CONFIG_32BIT=y
CONFIG_WORD_SIZE=32
# CONFIG_ARCH_PHYS_ADDR_T_64BIT is not set
# CONFIG_ARCH_DMA_ADDR_T_64BIT is not set
CONFIG_MMU=y
-CONFIG_GENERIC_CMOS_UPDATE=y
-CONFIG_GENERIC_TIME_VSYSCALL=y
-CONFIG_GENERIC_CLOCKEVENTS=y
# CONFIG_HAVE_SETUP_PER_CPU_AREA is not set
# CONFIG_NEED_PER_CPU_EMBED_FIRST_CHUNK is not set
CONFIG_NR_IRQS=512
@@ -42,9 +39,6 @@ CONFIG_LOCKDEP_SUPPORT=y
CONFIG_RWSEM_XCHGADD_ALGORITHM=y
CONFIG_ARCH_HAS_ILOG2_U32=y
CONFIG_GENERIC_HWEIGHT=y
-CONFIG_GENERIC_FIND_NEXT_BIT=y
-CONFIG_GENERIC_FIND_BIT_LE=y
-# CONFIG_ARCH_NO_VIRT_TO_BUS is not set
CONFIG_PPC=y
CONFIG_EARLY_PRINTK=y
CONFIG_GENERIC_NVRAM=y
@@ -55,32 +49,31 @@ CONFIG_PPC_UDBG_16550=y
# CONFIG_GENERIC_TBSYNC is not set
CONFIG_AUDIT_ARCH=y
CONFIG_GENERIC_BUG=y
+# CONFIG_EPAPR_BOOT is not set
# CONFIG_DEFAULT_UIMAGE is not set
CONFIG_ARCH_HIBERNATION_POSSIBLE=y
# CONFIG_PPC_DCR_NATIVE is not set
# CONFIG_PPC_DCR_MMIO is not set
CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y
+CONFIG_ARCH_SUPPORTS_UPROBES=y
CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
-CONFIG_CONSTRUCTORS=y
-CONFIG_HAVE_IRQ_WORK=y
+CONFIG_IRQ_WORK=y
#
# General setup
#
-CONFIG_EXPERIMENTAL=y
CONFIG_BROKEN_ON_SMP=y
CONFIG_INIT_ENV_ARG_LIMIT=32
CONFIG_CROSS_COMPILE=""
CONFIG_LOCALVERSION=""
# CONFIG_LOCALVERSION_AUTO is not set
+CONFIG_DEFAULT_HOSTNAME="openadk"
# CONFIG_SWAP is not set
CONFIG_SYSVIPC=y
CONFIG_SYSVIPC_SYSCTL=y
CONFIG_POSIX_MQUEUE=y
CONFIG_POSIX_MQUEUE_SYSCTL=y
-# CONFIG_BSD_PROCESS_ACCT is not set
# CONFIG_FHANDLE is not set
-# CONFIG_TASKSTATS is not set
# CONFIG_AUDIT is not set
CONFIG_HAVE_GENERIC_HARDIRQS=y
@@ -88,23 +81,44 @@ CONFIG_HAVE_GENERIC_HARDIRQS=y
# IRQ subsystem
#
CONFIG_GENERIC_HARDIRQS=y
-CONFIG_HAVE_SPARSE_IRQ=y
CONFIG_GENERIC_IRQ_SHOW=y
CONFIG_GENERIC_IRQ_SHOW_LEVEL=y
-# CONFIG_SPARSE_IRQ is not set
+CONFIG_IRQ_DOMAIN=y
+CONFIG_IRQ_FORCED_THREADING=y
+CONFIG_SPARSE_IRQ=y
+CONFIG_GENERIC_TIME_VSYSCALL_OLD=y
+CONFIG_GENERIC_CLOCKEVENTS=y
+CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
+CONFIG_GENERIC_CMOS_UPDATE=y
+
+#
+# Timers subsystem
+#
+# CONFIG_NO_HZ is not set
+# CONFIG_HIGH_RES_TIMERS is not set
+
+#
+# CPU/Task time and stats accounting
+#
+CONFIG_TICK_CPU_ACCOUNTING=y
+# CONFIG_BSD_PROCESS_ACCT is not set
+# CONFIG_TASKSTATS is not set
#
# RCU Subsystem
#
CONFIG_TINY_RCU=y
# CONFIG_PREEMPT_RCU is not set
-# CONFIG_RCU_TRACE is not set
+# CONFIG_RCU_STALL_COMMON is not set
# CONFIG_TREE_RCU_TRACE is not set
CONFIG_IKCONFIG=y
CONFIG_IKCONFIG_PROC=y
CONFIG_LOG_BUF_SHIFT=15
# CONFIG_CGROUPS is not set
+# CONFIG_CHECKPOINT_RESTORE is not set
# CONFIG_NAMESPACES is not set
+CONFIG_UIDGID_CONVERTED=y
+# CONFIG_UIDGID_STRICT_TYPE_CHECKS is not set
# CONFIG_SCHED_AUTOGROUP is not set
# CONFIG_SYSFS_DEPRECATED is not set
# CONFIG_RELAY is not set
@@ -114,12 +128,14 @@ CONFIG_SYSCTL=y
CONFIG_ANON_INODES=y
CONFIG_EXPERT=y
CONFIG_SYSCTL_SYSCALL=y
+CONFIG_SYSCTL_EXCEPTION_TRACE=y
# CONFIG_KALLSYMS is not set
CONFIG_HOTPLUG=y
CONFIG_PRINTK=y
CONFIG_BUG=y
# CONFIG_ELF_CORE is not set
CONFIG_PCSPKR_PLATFORM=y
+CONFIG_HAVE_PCSPKR_PLATFORM=y
# CONFIG_BASE_FULL is not set
CONFIG_FUTEX=y
CONFIG_EPOLL=y
@@ -135,7 +151,6 @@ CONFIG_HAVE_PERF_EVENTS=y
# Kernel Performance Events And Counters
#
# CONFIG_PERF_EVENTS is not set
-# CONFIG_PERF_COUNTERS is not set
# CONFIG_VM_EVENT_COUNTERS is not set
# CONFIG_PCI_QUIRKS is not set
# CONFIG_COMPAT_BRK is not set
@@ -145,14 +160,26 @@ CONFIG_SLAB=y
# CONFIG_PROFILING is not set
CONFIG_HAVE_OPROFILE=y
# CONFIG_KPROBES is not set
+# CONFIG_JUMP_LABEL is not set
+# CONFIG_HAVE_64BIT_ALIGNED_ACCESS is not set
CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS=y
+CONFIG_ARCH_USE_BUILTIN_BSWAP=y
CONFIG_HAVE_IOREMAP_PROT=y
CONFIG_HAVE_KPROBES=y
CONFIG_HAVE_KRETPROBES=y
CONFIG_HAVE_ARCH_TRACEHOOK=y
CONFIG_HAVE_DMA_ATTRS=y
+CONFIG_GENERIC_SMP_IDLE_THREAD=y
CONFIG_HAVE_REGS_AND_STACK_ACCESS_API=y
CONFIG_HAVE_DMA_API_DEBUG=y
+CONFIG_HAVE_ARCH_JUMP_LABEL=y
+CONFIG_ARCH_HAVE_NMI_SAFE_CMPXCHG=y
+CONFIG_ARCH_WANT_IPC_PARSE_VERSION=y
+CONFIG_HAVE_MOD_ARCH_SPECIFIC=y
+CONFIG_MODULES_USE_ELF_RELA=y
+CONFIG_CLONE_BACKWARDS=y
+CONFIG_OLD_SIGSUSPEND=y
+CONFIG_OLD_SIGACTION=y
#
# GCOV-based kernel profiling
@@ -167,12 +194,22 @@ CONFIG_MODULE_UNLOAD=y
CONFIG_MODULE_FORCE_UNLOAD=y
# CONFIG_MODVERSIONS is not set
# CONFIG_MODULE_SRCVERSION_ALL is not set
+# CONFIG_MODULE_SIG is not set
CONFIG_BLOCK=y
# CONFIG_LBDAF is not set
# CONFIG_BLK_DEV_BSG is not set
+# CONFIG_BLK_DEV_BSGLIB is not set
# CONFIG_BLK_DEV_INTEGRITY is not set
#
+# Partition Types
+#
+# CONFIG_PARTITION_ADVANCED is not set
+CONFIG_MAC_PARTITION=y
+CONFIG_MSDOS_PARTITION=y
+CONFIG_EFI_PARTITION=y
+
+#
# IO Schedulers
#
CONFIG_IOSCHED_NOOP=y
@@ -181,36 +218,17 @@ CONFIG_IOSCHED_CFQ=y
CONFIG_DEFAULT_CFQ=y
# CONFIG_DEFAULT_NOOP is not set
CONFIG_DEFAULT_IOSCHED="cfq"
-# CONFIG_INLINE_SPIN_TRYLOCK is not set
-# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set
-# CONFIG_INLINE_SPIN_LOCK is not set
-# CONFIG_INLINE_SPIN_LOCK_BH is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQ is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set
-CONFIG_INLINE_SPIN_UNLOCK=y
-# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
CONFIG_INLINE_SPIN_UNLOCK_IRQ=y
-# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_READ_TRYLOCK is not set
-# CONFIG_INLINE_READ_LOCK is not set
-# CONFIG_INLINE_READ_LOCK_BH is not set
-# CONFIG_INLINE_READ_LOCK_IRQ is not set
-# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set
CONFIG_INLINE_READ_UNLOCK=y
-# CONFIG_INLINE_READ_UNLOCK_BH is not set
CONFIG_INLINE_READ_UNLOCK_IRQ=y
-# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_WRITE_TRYLOCK is not set
-# CONFIG_INLINE_WRITE_LOCK is not set
-# CONFIG_INLINE_WRITE_LOCK_BH is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQ is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set
CONFIG_INLINE_WRITE_UNLOCK=y
-# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
CONFIG_INLINE_WRITE_UNLOCK_IRQ=y
-# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set
-# CONFIG_MUTEX_SPIN_ON_OWNER is not set
# CONFIG_FREEZER is not set
+# CONFIG_PPC_XICS is not set
+# CONFIG_PPC_ICP_NATIVE is not set
+# CONFIG_PPC_ICP_HV is not set
+# CONFIG_PPC_ICS_RTAS is not set
+# CONFIG_GE_FPGA is not set
#
# Platform support
@@ -227,13 +245,17 @@ CONFIG_PPC_PMAC=y
# CONFIG_PPC_86xx is not set
# CONFIG_EMBEDDED6xx is not set
# CONFIG_AMIGAONE is not set
+# CONFIG_PPC_WSP is not set
# CONFIG_KVM_GUEST is not set
+# CONFIG_EPAPR_PARAVIRT is not set
CONFIG_PPC_NATIVE=y
CONFIG_PPC_OF_BOOT_TRAMPOLINE=y
# CONFIG_UDBG_RTAS_CONSOLE is not set
# CONFIG_IPIC is not set
CONFIG_MPIC=y
+# CONFIG_PPC_EPAPR_HV_PIC is not set
# CONFIG_MPIC_WEIRD is not set
+# CONFIG_MPIC_MSGR is not set
CONFIG_PPC_I8259=y
CONFIG_PPC_RTAS=y
CONFIG_RTAS_ERROR_LOGGING=y
@@ -243,9 +265,18 @@ CONFIG_PPC_RTAS_DAEMON=y
# CONFIG_MPIC_U3_HT_IRQS is not set
CONFIG_PPC_MPC106=y
# CONFIG_PPC_970_NAP is not set
-# CONFIG_PPC_INDIRECT_IO is not set
-# CONFIG_GENERIC_IOMAP is not set
+# CONFIG_PPC_P7_NAP is not set
+
+#
+# CPU Frequency scaling
+#
# CONFIG_CPU_FREQ is not set
+
+#
+# CPUIdle driver
+#
+# CONFIG_CPU_IDLE is not set
+# CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED is not set
CONFIG_PPC601_SYNC_FIX=y
# CONFIG_TAU is not set
# CONFIG_FSL_ULI1575 is not set
@@ -255,9 +286,6 @@ CONFIG_PPC601_SYNC_FIX=y
# Kernel options
#
CONFIG_HIGHMEM=y
-# CONFIG_NO_HZ is not set
-# CONFIG_HIGH_RES_TIMERS is not set
-CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
# CONFIG_HZ_100 is not set
CONFIG_HZ_250=y
# CONFIG_HZ_300 is not set
@@ -270,6 +298,7 @@ CONFIG_PREEMPT_NONE=y
CONFIG_BINFMT_ELF=y
# CONFIG_HAVE_AOUT is not set
# CONFIG_BINFMT_MISC is not set
+CONFIG_COREDUMP=y
# CONFIG_IOMMU_HELPER is not set
# CONFIG_SWIOTLB is not set
CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y
@@ -279,12 +308,11 @@ CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y
# CONFIG_CRASH_DUMP is not set
CONFIG_MAX_ACTIVE_REGIONS=32
CONFIG_ARCH_FLATMEM_ENABLE=y
-CONFIG_ARCH_POPULATES_NODE_MAP=y
-CONFIG_SELECT_MEMORY_MODEL=y
-CONFIG_FLATMEM_MANUAL=y
CONFIG_FLATMEM=y
CONFIG_FLAT_NODE_MEM_MAP=y
CONFIG_HAVE_MEMBLOCK=y
+CONFIG_HAVE_MEMBLOCK_NODE_MAP=y
+# CONFIG_HAVE_BOOTMEM_INFO_NODE is not set
CONFIG_PAGEFLAGS_EXTENDED=y
CONFIG_SPLIT_PTLOCK_CPUS=4
# CONFIG_COMPACTION is not set
@@ -295,7 +323,9 @@ CONFIG_BOUNCE=y
CONFIG_VIRT_TO_BUS=y
# CONFIG_KSM is not set
CONFIG_DEFAULT_MMAP_MIN_ADDR=4096
+CONFIG_CROSS_MEMORY_ATTACH=y
CONFIG_NEED_PER_CPU_KM=y
+# CONFIG_CLEANCACHE is not set
CONFIG_PPC_4K_PAGES=y
CONFIG_FORCE_MAX_ZONEORDER=11
CONFIG_CMDLINE_BOOL=y
@@ -320,12 +350,17 @@ CONFIG_PCI_SYSCALL=y
# CONFIG_PCIEPORTBUS is not set
CONFIG_ARCH_SUPPORTS_MSI=y
# CONFIG_PCI_MSI is not set
+# CONFIG_PCI_DEBUG is not set
+# CONFIG_PCI_REALLOC_ENABLE_AUTO is not set
# CONFIG_PCI_STUB is not set
# CONFIG_PCI_IOV is not set
+# CONFIG_PCI_PRI is not set
+# CONFIG_PCI_PASID is not set
# CONFIG_PCCARD is not set
# CONFIG_HOTPLUG_PCI is not set
# CONFIG_HAS_RAPIDIO is not set
# CONFIG_RAPIDIO is not set
+# CONFIG_NONSTATIC_KERNEL is not set
#
# Advanced setup
@@ -346,7 +381,10 @@ CONFIG_NET=y
# Networking options
#
CONFIG_PACKET=y
+# CONFIG_PACKET_DIAG is not set
CONFIG_UNIX=y
+# CONFIG_UNIX_DIAG is not set
+# CONFIG_XFRM_USER is not set
# CONFIG_NET_KEY is not set
CONFIG_INET=y
# CONFIG_IP_MULTICAST is not set
@@ -388,13 +426,14 @@ CONFIG_DEFAULT_TCP_CONG="cubic"
# CONFIG_ATALK is not set
# CONFIG_X25 is not set
# CONFIG_LAPB is not set
-# CONFIG_ECONET is not set
-# CONFIG_WAN_ROUTER is not set
# CONFIG_PHONET is not set
# CONFIG_IEEE802154 is not set
# CONFIG_NET_SCHED is not set
# CONFIG_DCB is not set
# CONFIG_BATMAN_ADV is not set
+# CONFIG_OPENVSWITCH is not set
+# CONFIG_VSOCKETS is not set
+CONFIG_BQL=y
#
# Network testing
@@ -417,6 +456,7 @@ CONFIG_WIRELESS=y
# CONFIG_NET_9P is not set
# CONFIG_CAIF is not set
# CONFIG_CEPH_LIB is not set
+# CONFIG_NFC is not set
#
# Device Drivers
@@ -431,7 +471,15 @@ CONFIG_DEVTMPFS_MOUNT=y
# CONFIG_STANDALONE is not set
# CONFIG_PREVENT_FIRMWARE_BUILD is not set
# CONFIG_FW_LOADER is not set
+# CONFIG_DEBUG_DRIVER is not set
+# CONFIG_DEBUG_DEVRES is not set
# CONFIG_SYS_HYPERVISOR is not set
+# CONFIG_GENERIC_CPU_DEVICES is not set
+# CONFIG_DMA_SHARED_BUFFER is not set
+
+#
+# Bus devices
+#
# CONFIG_CONNECTOR is not set
# CONFIG_MTD is not set
CONFIG_DTC=y
@@ -441,17 +489,44 @@ CONFIG_OF=y
# Device Tree and Open Firmware support
#
# CONFIG_PROC_DEVICETREE is not set
+# CONFIG_OF_SELFTEST is not set
CONFIG_OF_FLATTREE=y
CONFIG_OF_EARLY_FLATTREE=y
-CONFIG_OF_DYNAMIC=y
CONFIG_OF_ADDRESS=y
CONFIG_OF_IRQ=y
CONFIG_OF_DEVICE=y
CONFIG_OF_PCI=y
+CONFIG_OF_PCI_IRQ=y
# CONFIG_PARPORT is not set
# CONFIG_BLK_DEV is not set
+
+#
+# Misc devices
+#
# CONFIG_SENSORS_LIS3LV02D is not set
-# CONFIG_MISC_DEVICES is not set
+# CONFIG_PHANTOM is not set
+# CONFIG_INTEL_MID_PTI is not set
+# CONFIG_SGI_IOC4 is not set
+# CONFIG_TIFM_CORE is not set
+# CONFIG_ATMEL_SSC is not set
+# CONFIG_ENCLOSURE_SERVICES is not set
+# CONFIG_HP_ILO is not set
+# CONFIG_PCH_PHUB is not set
+# CONFIG_C2PORT is not set
+
+#
+# EEPROM support
+#
+# CONFIG_EEPROM_93CX6 is not set
+# CONFIG_CB710_CORE is not set
+
+#
+# Texas Instruments shared transport line discipline
+#
+
+#
+# Altera FPGA firmware download module
+#
CONFIG_HAVE_IDE=y
# CONFIG_IDE is not set
@@ -479,7 +554,6 @@ CONFIG_SCSI_DMA=y
# CONFIG_SCSI_CONSTANTS is not set
# CONFIG_SCSI_LOGGING is not set
# CONFIG_SCSI_SCAN_ASYNC is not set
-CONFIG_SCSI_WAIT_SCAN=m
#
# SCSI Transports
@@ -520,6 +594,7 @@ CONFIG_ATA_BMDMA=y
# SATA SFF controllers with BMDMA
#
# CONFIG_ATA_PIIX is not set
+# CONFIG_SATA_HIGHBANK is not set
# CONFIG_SATA_MV is not set
# CONFIG_SATA_NV is not set
# CONFIG_SATA_PROMISE is not set
@@ -535,7 +610,6 @@ CONFIG_ATA_BMDMA=y
#
# CONFIG_PATA_ALI is not set
# CONFIG_PATA_AMD is not set
-# CONFIG_PATA_ARASAN_CF is not set
# CONFIG_PATA_ARTOP is not set
# CONFIG_PATA_ATIIXP is not set
# CONFIG_PATA_ATP867X is not set
@@ -610,8 +684,6 @@ CONFIG_INPUT_ADBHID=y
# CONFIG_ANSLCD is not set
# CONFIG_PMAC_RACKMETER is not set
# CONFIG_NETDEVICES is not set
-# CONFIG_ISDN is not set
-# CONFIG_PHONE is not set
#
# Input device support
@@ -620,6 +692,7 @@ CONFIG_INPUT=y
# CONFIG_INPUT_FF_MEMLESS is not set
# CONFIG_INPUT_POLLDEV is not set
# CONFIG_INPUT_SPARSEKMAP is not set
+# CONFIG_INPUT_MATRIXKMAP is not set
#
# Userland interfaces
@@ -651,11 +724,13 @@ CONFIG_SERIO=y
# CONFIG_SERIO_XILINX_XPS_PS2 is not set
# CONFIG_SERIO_ALTERA_PS2 is not set
# CONFIG_SERIO_PS2MULT is not set
+# CONFIG_SERIO_ARC_PS2 is not set
# CONFIG_GAMEPORT is not set
#
# Character devices
#
+CONFIG_TTY=y
CONFIG_VT=y
# CONFIG_CONSOLE_TRANSLATIONS is not set
CONFIG_VT_CONSOLE=y
@@ -667,6 +742,8 @@ CONFIG_UNIX98_PTYS=y
# CONFIG_SERIAL_NONSTANDARD is not set
# CONFIG_NOZOMI is not set
# CONFIG_N_GSM is not set
+# CONFIG_TRACE_SINK is not set
+# CONFIG_PPC_EPAPR_HV_BYTECHAN is not set
# CONFIG_DEVKMEM is not set
#
@@ -685,12 +762,15 @@ CONFIG_SERIAL_PMACZILOG=y
CONFIG_SERIAL_PMACZILOG_TTYS=y
CONFIG_SERIAL_PMACZILOG_CONSOLE=y
# CONFIG_SERIAL_JSM is not set
+# CONFIG_SERIAL_SCCNXP is not set
# CONFIG_SERIAL_TIMBERDALE is not set
# CONFIG_SERIAL_ALTERA_JTAGUART is not set
# CONFIG_SERIAL_ALTERA_UART is not set
# CONFIG_SERIAL_PCH_UART is not set
+# CONFIG_SERIAL_XILINX_PS_UART is not set
+# CONFIG_SERIAL_ARC is not set
+# CONFIG_SERIAL_RP2 is not set
# CONFIG_TTY_PRINTK is not set
-# CONFIG_BRIQ_PANEL is not set
# CONFIG_HVC_RTAS is not set
# CONFIG_HVC_UDBG is not set
# CONFIG_IPMI_HANDLER is not set
@@ -701,9 +781,10 @@ CONFIG_SERIAL_PMACZILOG_CONSOLE=y
# CONFIG_RAW_DRIVER is not set
# CONFIG_TCG_TPM is not set
CONFIG_DEVPORT=y
-# CONFIG_RAMOOPS is not set
+# CONFIG_BRCM_CHAR_DRIVERS is not set
# CONFIG_I2C is not set
# CONFIG_SPI is not set
+# CONFIG_HSI is not set
#
# PPS support
@@ -713,10 +794,22 @@ CONFIG_DEVPORT=y
#
# PPS generators support
#
+
+#
+# PTP clock support
+#
+# CONFIG_PTP_1588_CLOCK is not set
+
+#
+# Enable PHYLIB and NETWORK_PHY_TIMESTAMPING to see the additional clocks.
+#
+# CONFIG_PTP_1588_CLOCK_PCH is not set
CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y
+CONFIG_GPIO_DEVRES=y
# CONFIG_GPIOLIB is not set
# CONFIG_W1 is not set
# CONFIG_POWER_SUPPLY is not set
+# CONFIG_POWER_AVS is not set
# CONFIG_HWMON is not set
# CONFIG_THERMAL is not set
# CONFIG_WATCHDOG is not set
@@ -726,7 +819,29 @@ CONFIG_SSB_POSSIBLE=y
# Sonics Silicon Backplane
#
# CONFIG_SSB is not set
-# CONFIG_MFD_SUPPORT is not set
+CONFIG_BCMA_POSSIBLE=y
+
+#
+# Broadcom specific AMBA
+#
+# CONFIG_BCMA is not set
+
+#
+# Multifunction device drivers
+#
+# CONFIG_MFD_CORE is not set
+# CONFIG_MFD_SM501 is not set
+# CONFIG_MFD_RTSX_PCI is not set
+# CONFIG_MFD_TI_AM335X_TSCADC is not set
+# CONFIG_HTC_PASIC3 is not set
+# CONFIG_MFD_TMIO is not set
+# CONFIG_ABX500_CORE is not set
+# CONFIG_LPC_SCH is not set
+# CONFIG_LPC_ICH is not set
+# CONFIG_MFD_RDC321X is not set
+# CONFIG_MFD_JANZ_CMODIO is not set
+# CONFIG_MFD_VX855 is not set
+# CONFIG_MFD_SYSCON is not set
# CONFIG_REGULATOR is not set
# CONFIG_MEDIA_SUPPORT is not set
@@ -736,37 +851,48 @@ CONFIG_SSB_POSSIBLE=y
# CONFIG_AGP is not set
# CONFIG_VGA_ARB is not set
# CONFIG_DRM is not set
-# CONFIG_STUB_POULSBO is not set
# CONFIG_VGASTATE is not set
# CONFIG_VIDEO_OUTPUT_CONTROL is not set
+# CONFIG_OF_DISPLAY_TIMING is not set
+# CONFIG_OF_VIDEOMODE is not set
# CONFIG_FB is not set
+# CONFIG_EXYNOS_VIDEO is not set
# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
#
-# Display device support
-#
-# CONFIG_DISPLAY_SUPPORT is not set
-
-#
# Console display driver support
#
CONFIG_VGA_CONSOLE=y
# CONFIG_VGACON_SOFT_SCROLLBACK is not set
CONFIG_DUMMY_CONSOLE=y
# CONFIG_SOUND is not set
-# CONFIG_HID_SUPPORT is not set
+
+#
+# HID support
+#
+CONFIG_HID=y
+# CONFIG_HIDRAW is not set
+# CONFIG_UHID is not set
+CONFIG_HID_GENERIC=y
+
+#
+# Special HID drivers
+#
+CONFIG_USB_ARCH_HAS_OHCI=y
+CONFIG_USB_ARCH_HAS_EHCI=y
+CONFIG_USB_ARCH_HAS_XHCI=y
# CONFIG_USB_SUPPORT is not set
# CONFIG_UWB is not set
# CONFIG_MMC is not set
# CONFIG_MEMSTICK is not set
# CONFIG_NEW_LEDS is not set
-# CONFIG_NFC_DEVICES is not set
# CONFIG_ACCESSIBILITY is not set
# CONFIG_INFINIBAND is not set
# CONFIG_EDAC is not set
CONFIG_RTC_LIB=y
CONFIG_RTC_CLASS=y
CONFIG_RTC_HCTOSYS=y
+CONFIG_RTC_SYSTOHC=y
CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
# CONFIG_RTC_DEBUG is not set
@@ -799,17 +925,60 @@ CONFIG_RTC_DRV_M48T59=y
# CONFIG_RTC_DRV_BQ4802 is not set
# CONFIG_RTC_DRV_RP5C01 is not set
# CONFIG_RTC_DRV_V3020 is not set
+# CONFIG_RTC_DRV_DS2404 is not set
#
# on-CPU RTC drivers
#
# CONFIG_RTC_DRV_GENERIC is not set
+# CONFIG_RTC_DRV_SNVS is not set
+
+#
+# HID Sensor RTC drivers
+#
# CONFIG_DMADEVICES is not set
# CONFIG_AUXDISPLAY is not set
# CONFIG_UIO is not set
+
+#
+# Virtio drivers
+#
+# CONFIG_VIRTIO_PCI is not set
+# CONFIG_VIRTIO_MMIO is not set
+
+#
+# Microsoft Hyper-V guest support
+#
# CONFIG_STAGING is not set
#
+# Hardware Spinlock drivers
+#
+CONFIG_I8253_LOCK=y
+CONFIG_CLKBLD_I8253=y
+# CONFIG_MAILBOX is not set
+CONFIG_IOMMU_SUPPORT=y
+CONFIG_OF_IOMMU=y
+
+#
+# Remoteproc drivers
+#
+# CONFIG_STE_MODEM_RPROC is not set
+
+#
+# Rpmsg drivers
+#
+# CONFIG_VIRT_DRIVERS is not set
+# CONFIG_PM_DEVFREQ is not set
+# CONFIG_EXTCON is not set
+# CONFIG_MEMORY is not set
+# CONFIG_IIO is not set
+# CONFIG_VME_BUS is not set
+# CONFIG_PWM is not set
+CONFIG_IRQCHIP=y
+# CONFIG_IPACK_BUS is not set
+
+#
# File systems
#
# CONFIG_EXT2_FS is not set
@@ -820,7 +989,7 @@ CONFIG_RTC_DRV_M48T59=y
# CONFIG_XFS_FS is not set
# CONFIG_BTRFS_FS is not set
# CONFIG_NILFS2_FS is not set
-CONFIG_FS_POSIX_ACL=y
+# CONFIG_FS_POSIX_ACL is not set
CONFIG_EXPORTFS=y
CONFIG_FILE_LOCKING=y
CONFIG_FSNOTIFY=y
@@ -860,17 +1029,11 @@ CONFIG_PROC_SYSCTL=y
CONFIG_SYSFS=y
CONFIG_TMPFS=y
# CONFIG_TMPFS_POSIX_ACL is not set
+# CONFIG_TMPFS_XATTR is not set
# CONFIG_HUGETLB_PAGE is not set
# CONFIG_CONFIGFS_FS is not set
# CONFIG_MISC_FILESYSTEMS is not set
# CONFIG_NETWORK_FILESYSTEMS is not set
-
-#
-# Partition Types
-#
-# CONFIG_PARTITION_ADVANCED is not set
-CONFIG_MAC_PARTITION=y
-CONFIG_MSDOS_PARTITION=y
# CONFIG_NLS is not set
# CONFIG_BINARY_PRINTF is not set
@@ -878,22 +1041,35 @@ CONFIG_MSDOS_PARTITION=y
# Library routines
#
CONFIG_BITREVERSE=y
-CONFIG_GENERIC_FIND_LAST_BIT=y
+CONFIG_GENERIC_STRNCPY_FROM_USER=y
+CONFIG_GENERIC_STRNLEN_USER=y
+CONFIG_GENERIC_PCI_IOMAP=y
+CONFIG_GENERIC_IO=y
# CONFIG_CRC_CCITT is not set
# CONFIG_CRC16 is not set
# CONFIG_CRC_T10DIF is not set
# CONFIG_CRC_ITU_T is not set
CONFIG_CRC32=y
+# CONFIG_CRC32_SELFTEST is not set
+CONFIG_CRC32_SLICEBY8=y
+# CONFIG_CRC32_SLICEBY4 is not set
+# CONFIG_CRC32_SARWATE is not set
+# CONFIG_CRC32_BIT is not set
# CONFIG_CRC7 is not set
# CONFIG_LIBCRC32C is not set
+# CONFIG_CRC8 is not set
# CONFIG_XZ_DEC is not set
# CONFIG_XZ_DEC_BCJ is not set
CONFIG_HAS_IOMEM=y
CONFIG_HAS_IOPORT=y
CONFIG_HAS_DMA=y
+CONFIG_DQL=y
CONFIG_NLATTR=y
CONFIG_GENERIC_ATOMIC64=y
+CONFIG_ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE=y
# CONFIG_AVERAGE is not set
+# CONFIG_CORDIC is not set
+# CONFIG_DDR is not set
#
# Kernel hacking
@@ -905,32 +1081,87 @@ CONFIG_DEFAULT_MESSAGE_LOGLEVEL=4
CONFIG_FRAME_WARN=1024
# CONFIG_MAGIC_SYSRQ is not set
# CONFIG_STRIP_ASM_SYMS is not set
+# CONFIG_READABLE_ASM is not set
# CONFIG_UNUSED_SYMBOLS is not set
# CONFIG_DEBUG_FS is not set
# CONFIG_HEADERS_CHECK is not set
# CONFIG_DEBUG_SECTION_MISMATCH is not set
-# CONFIG_DEBUG_KERNEL is not set
-# CONFIG_HARDLOCKUP_DETECTOR is not set
-# CONFIG_SPARSE_RCU_POINTER is not set
+CONFIG_DEBUG_KERNEL=y
+# CONFIG_DEBUG_SHIRQ is not set
+# CONFIG_LOCKUP_DETECTOR is not set
+# CONFIG_PANIC_ON_OOPS is not set
+CONFIG_PANIC_ON_OOPS_VALUE=0
+# CONFIG_DETECT_HUNG_TASK is not set
+CONFIG_SCHED_DEBUG=y
+# CONFIG_SCHEDSTATS is not set
+# CONFIG_TIMER_STATS is not set
+# CONFIG_DEBUG_OBJECTS is not set
+# CONFIG_DEBUG_SLAB is not set
+CONFIG_HAVE_DEBUG_KMEMLEAK=y
+# CONFIG_DEBUG_KMEMLEAK is not set
+# CONFIG_DEBUG_RT_MUTEXES is not set
+# CONFIG_RT_MUTEX_TESTER is not set
+# CONFIG_DEBUG_SPINLOCK is not set
+# CONFIG_DEBUG_MUTEXES is not set
+# CONFIG_DEBUG_LOCK_ALLOC is not set
+# CONFIG_PROVE_LOCKING is not set
+# CONFIG_LOCK_STAT is not set
+# CONFIG_DEBUG_ATOMIC_SLEEP is not set
+# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
+# CONFIG_DEBUG_STACK_USAGE is not set
+# CONFIG_DEBUG_KOBJECT is not set
+# CONFIG_DEBUG_HIGHMEM is not set
CONFIG_DEBUG_BUGVERBOSE=y
+# CONFIG_DEBUG_INFO is not set
+# CONFIG_DEBUG_VM is not set
+# CONFIG_DEBUG_WRITECOUNT is not set
# CONFIG_DEBUG_MEMORY_INIT is not set
-# CONFIG_SYSCTL_SYSCALL_CHECK is not set
+# CONFIG_DEBUG_LIST is not set
+# CONFIG_TEST_LIST_SORT is not set
+# CONFIG_DEBUG_SG is not set
+# CONFIG_DEBUG_NOTIFIERS is not set
+# CONFIG_DEBUG_CREDENTIALS is not set
+
+#
+# RCU Debugging
+#
+# CONFIG_SPARSE_RCU_POINTER is not set
+# CONFIG_RCU_TORTURE_TEST is not set
+# CONFIG_RCU_TRACE is not set
+# CONFIG_BACKTRACE_SELF_TEST is not set
+# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
+# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
+# CONFIG_NOTIFIER_ERROR_INJECTION is not set
+# CONFIG_FAULT_INJECTION is not set
+# CONFIG_LATENCYTOP is not set
+# CONFIG_DEBUG_PAGEALLOC is not set
CONFIG_HAVE_FUNCTION_TRACER=y
CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
CONFIG_HAVE_DYNAMIC_FTRACE=y
CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
+CONFIG_HAVE_SYSCALL_TRACEPOINTS=y
CONFIG_TRACING_SUPPORT=y
# CONFIG_FTRACE is not set
+# CONFIG_RBTREE_TEST is not set
+# CONFIG_INTERVAL_TREE_TEST is not set
# CONFIG_DMA_API_DEBUG is not set
# CONFIG_ATOMIC64_SELFTEST is not set
# CONFIG_SAMPLES is not set
CONFIG_HAVE_ARCH_KGDB=y
+# CONFIG_KGDB is not set
# CONFIG_TEST_KSTRTOX is not set
# CONFIG_PPC_DISABLE_WERROR is not set
CONFIG_PPC_WERROR=y
CONFIG_PRINT_STACK_DEPTH=64
+# CONFIG_DEBUG_STACKOVERFLOW is not set
+# CONFIG_CODE_PATCHING_SELFTEST is not set
+# CONFIG_FTR_FIXUP_SELFTEST is not set
+# CONFIG_MSI_BITMAP_SELFTEST is not set
+# CONFIG_XMON is not set
+# CONFIG_BDI_SWITCH is not set
CONFIG_BOOTX_TEXT=y
# CONFIG_PPC_EARLY_DEBUG is not set
+CONFIG_STRICT_DEVMEM=y
#
# Security options
@@ -946,8 +1177,11 @@ CONFIG_CRYPTO=y
#
# Crypto core or helper
#
+CONFIG_CRYPTO_ALGAPI=y
+CONFIG_CRYPTO_ALGAPI2=y
# CONFIG_CRYPTO_MANAGER is not set
# CONFIG_CRYPTO_MANAGER2 is not set
+# CONFIG_CRYPTO_USER is not set
# CONFIG_CRYPTO_GF128MUL is not set
# CONFIG_CRYPTO_NULL is not set
# CONFIG_CRYPTO_CRYPTD is not set
@@ -983,6 +1217,7 @@ CONFIG_CRYPTO=y
# Digest
#
# CONFIG_CRYPTO_CRC32C is not set
+# CONFIG_CRYPTO_CRC32 is not set
# CONFIG_CRYPTO_GHASH is not set
# CONFIG_CRYPTO_MD4 is not set
# CONFIG_CRYPTO_MD5 is not set
@@ -992,6 +1227,7 @@ CONFIG_CRYPTO=y
# CONFIG_CRYPTO_RMD256 is not set
# CONFIG_CRYPTO_RMD320 is not set
# CONFIG_CRYPTO_SHA1 is not set
+# CONFIG_CRYPTO_SHA1_PPC is not set
# CONFIG_CRYPTO_SHA256 is not set
# CONFIG_CRYPTO_SHA512 is not set
# CONFIG_CRYPTO_TGR192 is not set
@@ -1000,7 +1236,7 @@ CONFIG_CRYPTO=y
#
# Ciphers
#
-# CONFIG_CRYPTO_AES is not set
+CONFIG_CRYPTO_AES=y
# CONFIG_CRYPTO_ANUBIS is not set
# CONFIG_CRYPTO_ARC4 is not set
# CONFIG_CRYPTO_BLOWFISH is not set
@@ -1030,10 +1266,5 @@ CONFIG_CRYPTO=y
# CONFIG_CRYPTO_USER_API_HASH is not set
# CONFIG_CRYPTO_USER_API_SKCIPHER is not set
# CONFIG_CRYPTO_HW is not set
-
-#
-# OCF Configuration
-#
-# CONFIG_OCF_OCF is not set
# CONFIG_PPC_CLOCK is not set
# CONFIG_VIRTUALIZATION is not set
diff --git a/target/ppc64/kernel.config b/target/ppc64/kernel.config
index 64152ccf6..ac15f186a 100644
--- a/target/ppc64/kernel.config
+++ b/target/ppc64/kernel.config
@@ -1,7 +1,6 @@
#
-# Automatically generated make config: don't edit
-# Linux/powerpc 2.6.39 Kernel Configuration
-# Wed Aug 24 13:58:26 2011
+# Automatically generated file; DO NOT EDIT.
+# Linux/powerpc 3.9.11 Kernel Configuration
#
CONFIG_PPC64=y
@@ -10,28 +9,31 @@ CONFIG_PPC64=y
#
CONFIG_PPC_BOOK3S_64=y
# CONFIG_PPC_BOOK3E_64 is not set
+CONFIG_GENERIC_CPU=y
+# CONFIG_CELL_CPU is not set
+# CONFIG_POWER4_CPU is not set
+# CONFIG_POWER5_CPU is not set
+# CONFIG_POWER6_CPU is not set
+# CONFIG_POWER7_CPU is not set
CONFIG_PPC_BOOK3S=y
-# CONFIG_POWER4_ONLY is not set
CONFIG_POWER3=y
CONFIG_POWER4=y
# CONFIG_TUNE_CELL is not set
CONFIG_PPC_FPU=y
CONFIG_ALTIVEC=y
# CONFIG_VSX is not set
+# CONFIG_PPC_ICSWX is not set
CONFIG_PPC_STD_MMU=y
CONFIG_PPC_STD_MMU_64=y
# CONFIG_PPC_MM_SLICES is not set
-CONFIG_VIRT_CPU_ACCOUNTING=y
CONFIG_PPC_HAVE_PMU_SUPPORT=y
# CONFIG_SMP is not set
+# CONFIG_PPC_DOORBELL is not set
CONFIG_64BIT=y
CONFIG_WORD_SIZE=64
CONFIG_ARCH_PHYS_ADDR_T_64BIT=y
CONFIG_ARCH_DMA_ADDR_T_64BIT=y
CONFIG_MMU=y
-CONFIG_GENERIC_CMOS_UPDATE=y
-CONFIG_GENERIC_TIME_VSYSCALL=y
-CONFIG_GENERIC_CLOCKEVENTS=y
CONFIG_HAVE_SETUP_PER_CPU_AREA=y
CONFIG_NEED_PER_CPU_EMBED_FIRST_CHUNK=y
CONFIG_NR_IRQS=512
@@ -43,9 +45,6 @@ CONFIG_RWSEM_XCHGADD_ALGORITHM=y
CONFIG_ARCH_HAS_ILOG2_U32=y
CONFIG_ARCH_HAS_ILOG2_U64=y
CONFIG_GENERIC_HWEIGHT=y
-CONFIG_GENERIC_FIND_NEXT_BIT=y
-CONFIG_GENERIC_FIND_BIT_LE=y
-CONFIG_ARCH_NO_VIRT_TO_BUS=y
CONFIG_PPC=y
CONFIG_EARLY_PRINTK=y
CONFIG_COMPAT=y
@@ -57,6 +56,7 @@ CONFIG_PPC_OF=y
CONFIG_GENERIC_TBSYNC=y
CONFIG_AUDIT_ARCH=y
CONFIG_GENERIC_BUG=y
+# CONFIG_EPAPR_BOOT is not set
# CONFIG_DEFAULT_UIMAGE is not set
CONFIG_ARCH_HIBERNATION_POSSIBLE=y
CONFIG_ARCH_SUSPEND_POSSIBLE=y
@@ -64,27 +64,25 @@ CONFIG_ARCH_SUSPEND_POSSIBLE=y
# CONFIG_PPC_DCR_MMIO is not set
# CONFIG_PPC_OF_PLATFORM_PCI is not set
CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y
+CONFIG_ARCH_SUPPORTS_UPROBES=y
CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
-CONFIG_CONSTRUCTORS=y
-CONFIG_HAVE_IRQ_WORK=y
+CONFIG_IRQ_WORK=y
#
# General setup
#
-CONFIG_EXPERIMENTAL=y
CONFIG_BROKEN_ON_SMP=y
CONFIG_INIT_ENV_ARG_LIMIT=32
CONFIG_CROSS_COMPILE=""
CONFIG_LOCALVERSION=""
# CONFIG_LOCALVERSION_AUTO is not set
+CONFIG_DEFAULT_HOSTNAME="openadk"
# CONFIG_SWAP is not set
CONFIG_SYSVIPC=y
CONFIG_SYSVIPC_SYSCTL=y
CONFIG_POSIX_MQUEUE=y
CONFIG_POSIX_MQUEUE_SYSCTL=y
-# CONFIG_BSD_PROCESS_ACCT is not set
# CONFIG_FHANDLE is not set
-# CONFIG_TASKSTATS is not set
# CONFIG_AUDIT is not set
CONFIG_HAVE_GENERIC_HARDIRQS=y
@@ -92,23 +90,46 @@ CONFIG_HAVE_GENERIC_HARDIRQS=y
# IRQ subsystem
#
CONFIG_GENERIC_HARDIRQS=y
-CONFIG_HAVE_SPARSE_IRQ=y
CONFIG_GENERIC_IRQ_SHOW=y
CONFIG_GENERIC_IRQ_SHOW_LEVEL=y
-# CONFIG_SPARSE_IRQ is not set
+CONFIG_IRQ_DOMAIN=y
+CONFIG_IRQ_FORCED_THREADING=y
+CONFIG_SPARSE_IRQ=y
+CONFIG_GENERIC_TIME_VSYSCALL_OLD=y
+CONFIG_GENERIC_CLOCKEVENTS=y
+CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
+CONFIG_GENERIC_CMOS_UPDATE=y
+
+#
+# Timers subsystem
+#
+# CONFIG_NO_HZ is not set
+# CONFIG_HIGH_RES_TIMERS is not set
+
+#
+# CPU/Task time and stats accounting
+#
+CONFIG_VIRT_CPU_ACCOUNTING=y
+# CONFIG_TICK_CPU_ACCOUNTING is not set
+CONFIG_VIRT_CPU_ACCOUNTING_NATIVE=y
+# CONFIG_BSD_PROCESS_ACCT is not set
+# CONFIG_TASKSTATS is not set
#
# RCU Subsystem
#
CONFIG_TINY_RCU=y
# CONFIG_PREEMPT_RCU is not set
-# CONFIG_RCU_TRACE is not set
+# CONFIG_RCU_STALL_COMMON is not set
# CONFIG_TREE_RCU_TRACE is not set
CONFIG_IKCONFIG=y
CONFIG_IKCONFIG_PROC=y
CONFIG_LOG_BUF_SHIFT=15
# CONFIG_CGROUPS is not set
+# CONFIG_CHECKPOINT_RESTORE is not set
# CONFIG_NAMESPACES is not set
+CONFIG_UIDGID_CONVERTED=y
+# CONFIG_UIDGID_STRICT_TYPE_CHECKS is not set
# CONFIG_SCHED_AUTOGROUP is not set
# CONFIG_SYSFS_DEPRECATED is not set
# CONFIG_RELAY is not set
@@ -118,6 +139,7 @@ CONFIG_SYSCTL=y
CONFIG_ANON_INODES=y
CONFIG_EXPERT=y
CONFIG_SYSCTL_SYSCALL=y
+CONFIG_SYSCTL_EXCEPTION_TRACE=y
# CONFIG_KALLSYMS is not set
CONFIG_HOTPLUG=y
CONFIG_PRINTK=y
@@ -138,7 +160,6 @@ CONFIG_HAVE_PERF_EVENTS=y
# Kernel Performance Events And Counters
#
# CONFIG_PERF_EVENTS is not set
-# CONFIG_PERF_COUNTERS is not set
# CONFIG_VM_EVENT_COUNTERS is not set
# CONFIG_PCI_QUIRKS is not set
# CONFIG_COMPAT_BRK is not set
@@ -148,15 +169,30 @@ CONFIG_SLAB=y
# CONFIG_PROFILING is not set
CONFIG_HAVE_OPROFILE=y
# CONFIG_KPROBES is not set
+# CONFIG_JUMP_LABEL is not set
+# CONFIG_HAVE_64BIT_ALIGNED_ACCESS is not set
CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS=y
+CONFIG_ARCH_USE_BUILTIN_BSWAP=y
CONFIG_HAVE_SYSCALL_WRAPPERS=y
CONFIG_HAVE_IOREMAP_PROT=y
CONFIG_HAVE_KPROBES=y
CONFIG_HAVE_KRETPROBES=y
CONFIG_HAVE_ARCH_TRACEHOOK=y
CONFIG_HAVE_DMA_ATTRS=y
+CONFIG_GENERIC_SMP_IDLE_THREAD=y
CONFIG_HAVE_REGS_AND_STACK_ACCESS_API=y
CONFIG_HAVE_DMA_API_DEBUG=y
+CONFIG_HAVE_ARCH_JUMP_LABEL=y
+CONFIG_ARCH_HAVE_NMI_SAFE_CMPXCHG=y
+CONFIG_ARCH_WANT_IPC_PARSE_VERSION=y
+CONFIG_ARCH_WANT_COMPAT_IPC_PARSE_VERSION=y
+CONFIG_ARCH_WANT_OLD_COMPAT_IPC=y
+CONFIG_HAVE_VIRT_CPU_ACCOUNTING=y
+CONFIG_HAVE_MOD_ARCH_SPECIFIC=y
+CONFIG_MODULES_USE_ELF_RELA=y
+CONFIG_CLONE_BACKWARDS=y
+CONFIG_OLD_SIGSUSPEND=y
+CONFIG_COMPAT_OLD_SIGACTION=y
#
# GCOV-based kernel profiling
@@ -171,9 +207,19 @@ CONFIG_MODULE_UNLOAD=y
CONFIG_MODULE_FORCE_UNLOAD=y
# CONFIG_MODVERSIONS is not set
# CONFIG_MODULE_SRCVERSION_ALL is not set
+# CONFIG_MODULE_SIG is not set
CONFIG_BLOCK=y
# CONFIG_BLK_DEV_BSG is not set
+# CONFIG_BLK_DEV_BSGLIB is not set
# CONFIG_BLK_DEV_INTEGRITY is not set
+
+#
+# Partition Types
+#
+# CONFIG_PARTITION_ADVANCED is not set
+CONFIG_MAC_PARTITION=y
+CONFIG_MSDOS_PARTITION=y
+CONFIG_EFI_PARTITION=y
CONFIG_BLOCK_COMPAT=y
#
@@ -185,43 +231,24 @@ CONFIG_IOSCHED_CFQ=y
CONFIG_DEFAULT_CFQ=y
# CONFIG_DEFAULT_NOOP is not set
CONFIG_DEFAULT_IOSCHED="cfq"
-# CONFIG_INLINE_SPIN_TRYLOCK is not set
-# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set
-# CONFIG_INLINE_SPIN_LOCK is not set
-# CONFIG_INLINE_SPIN_LOCK_BH is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQ is not set
-# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set
-CONFIG_INLINE_SPIN_UNLOCK=y
-# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
CONFIG_INLINE_SPIN_UNLOCK_IRQ=y
-# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_READ_TRYLOCK is not set
-# CONFIG_INLINE_READ_LOCK is not set
-# CONFIG_INLINE_READ_LOCK_BH is not set
-# CONFIG_INLINE_READ_LOCK_IRQ is not set
-# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set
CONFIG_INLINE_READ_UNLOCK=y
-# CONFIG_INLINE_READ_UNLOCK_BH is not set
CONFIG_INLINE_READ_UNLOCK_IRQ=y
-# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set
-# CONFIG_INLINE_WRITE_TRYLOCK is not set
-# CONFIG_INLINE_WRITE_LOCK is not set
-# CONFIG_INLINE_WRITE_LOCK_BH is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQ is not set
-# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set
CONFIG_INLINE_WRITE_UNLOCK=y
-# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
CONFIG_INLINE_WRITE_UNLOCK_IRQ=y
-# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set
-# CONFIG_MUTEX_SPIN_ON_OWNER is not set
CONFIG_FREEZER=y
CONFIG_PPC_MSI_BITMAP=y
+# CONFIG_PPC_XICS is not set
+# CONFIG_PPC_ICP_NATIVE is not set
+# CONFIG_PPC_ICP_HV is not set
+# CONFIG_PPC_ICS_RTAS is not set
+# CONFIG_GE_FPGA is not set
#
# Platform support
#
+# CONFIG_PPC_POWERNV is not set
# CONFIG_PPC_PSERIES is not set
-# CONFIG_PPC_ISERIES is not set
CONFIG_PPC_PMAC=y
CONFIG_PPC_PMAC64=y
# CONFIG_PPC_MAPLE is not set
@@ -233,12 +260,16 @@ CONFIG_PPC_PMAC64=y
# CONFIG_PPC_CELLEB is not set
# CONFIG_PPC_CELL_QPACE is not set
# CONFIG_PQ2ADS is not set
+# CONFIG_PPC_WSP is not set
# CONFIG_KVM_GUEST is not set
+# CONFIG_EPAPR_PARAVIRT is not set
CONFIG_PPC_NATIVE=y
CONFIG_PPC_OF_BOOT_TRAMPOLINE=y
# CONFIG_IPIC is not set
CONFIG_MPIC=y
+# CONFIG_PPC_EPAPR_HV_PIC is not set
# CONFIG_MPIC_WEIRD is not set
+# CONFIG_MPIC_MSGR is not set
# CONFIG_PPC_I8259 is not set
CONFIG_U3_DART=y
# CONFIG_PPC_RTAS is not set
@@ -246,18 +277,24 @@ CONFIG_U3_DART=y
CONFIG_MPIC_U3_HT_IRQS=y
# CONFIG_PPC_MPC106 is not set
CONFIG_PPC_970_NAP=y
-# CONFIG_PPC_INDIRECT_IO is not set
-# CONFIG_GENERIC_IOMAP is not set
+# CONFIG_PPC_P7_NAP is not set
+
+#
+# CPU Frequency scaling
+#
# CONFIG_CPU_FREQ is not set
+
+#
+# CPUIdle driver
+#
+# CONFIG_CPU_IDLE is not set
+# CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED is not set
# CONFIG_FSL_ULI1575 is not set
# CONFIG_SIMPLE_GPIO is not set
#
# Kernel options
#
-# CONFIG_NO_HZ is not set
-# CONFIG_HIGH_RES_TIMERS is not set
-CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
# CONFIG_HZ_100 is not set
CONFIG_HZ_250=y
# CONFIG_HZ_300 is not set
@@ -271,6 +308,7 @@ CONFIG_BINFMT_ELF=y
CONFIG_COMPAT_BINFMT_ELF=y
# CONFIG_HAVE_AOUT is not set
# CONFIG_BINFMT_MISC is not set
+CONFIG_COREDUMP=y
CONFIG_IOMMU_HELPER=y
# CONFIG_SWIOTLB is not set
CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y
@@ -283,7 +321,6 @@ CONFIG_MAX_ACTIVE_REGIONS=256
CONFIG_ARCH_SELECT_MEMORY_MODEL=y
CONFIG_ARCH_FLATMEM_ENABLE=y
CONFIG_ARCH_SPARSEMEM_ENABLE=y
-CONFIG_ARCH_POPULATES_NODE_MAP=y
CONFIG_SYS_SUPPORTS_HUGETLBFS=y
CONFIG_SELECT_MEMORY_MODEL=y
CONFIG_FLATMEM_MANUAL=y
@@ -292,6 +329,8 @@ CONFIG_FLATMEM=y
CONFIG_FLAT_NODE_MEM_MAP=y
CONFIG_SPARSEMEM_VMEMMAP_ENABLE=y
CONFIG_HAVE_MEMBLOCK=y
+CONFIG_HAVE_MEMBLOCK_NODE_MAP=y
+# CONFIG_HAVE_BOOTMEM_INFO_NODE is not set
CONFIG_PAGEFLAGS_EXTENDED=y
CONFIG_SPLIT_PTLOCK_CPUS=4
# CONFIG_COMPACTION is not set
@@ -301,11 +340,14 @@ CONFIG_ZONE_DMA_FLAG=1
CONFIG_BOUNCE=y
# CONFIG_KSM is not set
CONFIG_DEFAULT_MMAP_MIN_ADDR=4096
+CONFIG_CROSS_MEMORY_ATTACH=y
CONFIG_NEED_PER_CPU_KM=y
+# CONFIG_CLEANCACHE is not set
# CONFIG_PPC_HAS_HASH_64K is not set
CONFIG_PPC_4K_PAGES=y
# CONFIG_PPC_64K_PAGES is not set
CONFIG_FORCE_MAX_ZONEORDER=13
+# CONFIG_PPC_DENORMALISATION is not set
CONFIG_CMDLINE_BOOL=y
CONFIG_CMDLINE="console=ttyS0,9600 console=tty0"
CONFIG_EXTRA_TARGETS=""
@@ -313,6 +355,8 @@ CONFIG_ARCH_WANTS_FREEZER_CONTROL=y
CONFIG_SUSPEND=y
CONFIG_SUSPEND_FREEZER=y
CONFIG_PM_SLEEP=y
+# CONFIG_PM_AUTOSLEEP is not set
+# CONFIG_PM_WAKELOCKS is not set
# CONFIG_PM_RUNTIME is not set
CONFIG_PM=y
# CONFIG_PM_DEBUG is not set
@@ -333,12 +377,17 @@ CONFIG_PCI_SYSCALL=y
# CONFIG_PCIEPORTBUS is not set
CONFIG_ARCH_SUPPORTS_MSI=y
CONFIG_PCI_MSI=y
+# CONFIG_PCI_DEBUG is not set
+# CONFIG_PCI_REALLOC_ENABLE_AUTO is not set
# CONFIG_PCI_STUB is not set
# CONFIG_PCI_IOV is not set
+# CONFIG_PCI_PRI is not set
+# CONFIG_PCI_PASID is not set
# CONFIG_PCCARD is not set
# CONFIG_HOTPLUG_PCI is not set
# CONFIG_HAS_RAPIDIO is not set
# CONFIG_RAPIDIO is not set
+# CONFIG_NONSTATIC_KERNEL is not set
# CONFIG_RELOCATABLE is not set
CONFIG_PAGE_OFFSET=0xc000000000000000
CONFIG_KERNEL_START=0xc000000000000000
@@ -349,7 +398,10 @@ CONFIG_NET=y
# Networking options
#
CONFIG_PACKET=y
+# CONFIG_PACKET_DIAG is not set
CONFIG_UNIX=y
+# CONFIG_UNIX_DIAG is not set
+# CONFIG_XFRM_USER is not set
# CONFIG_NET_KEY is not set
CONFIG_INET=y
# CONFIG_IP_MULTICAST is not set
@@ -391,13 +443,15 @@ CONFIG_DEFAULT_TCP_CONG="cubic"
# CONFIG_ATALK is not set
# CONFIG_X25 is not set
# CONFIG_LAPB is not set
-# CONFIG_ECONET is not set
-# CONFIG_WAN_ROUTER is not set
# CONFIG_PHONET is not set
# CONFIG_IEEE802154 is not set
# CONFIG_NET_SCHED is not set
# CONFIG_DCB is not set
# CONFIG_BATMAN_ADV is not set
+# CONFIG_OPENVSWITCH is not set
+# CONFIG_VSOCKETS is not set
+CONFIG_BQL=y
+# CONFIG_BPF_JIT is not set
#
# Network testing
@@ -420,6 +474,8 @@ CONFIG_WIRELESS=y
# CONFIG_NET_9P is not set
# CONFIG_CAIF is not set
# CONFIG_CEPH_LIB is not set
+# CONFIG_NFC is not set
+CONFIG_HAVE_BPF_JIT=y
#
# Device Drivers
@@ -434,7 +490,15 @@ CONFIG_DEVTMPFS_MOUNT=y
# CONFIG_STANDALONE is not set
# CONFIG_PREVENT_FIRMWARE_BUILD is not set
# CONFIG_FW_LOADER is not set
+# CONFIG_DEBUG_DRIVER is not set
+# CONFIG_DEBUG_DEVRES is not set
# CONFIG_SYS_HYPERVISOR is not set
+# CONFIG_GENERIC_CPU_DEVICES is not set
+# CONFIG_DMA_SHARED_BUFFER is not set
+
+#
+# Bus devices
+#
# CONFIG_CONNECTOR is not set
# CONFIG_MTD is not set
CONFIG_DTC=y
@@ -444,17 +508,44 @@ CONFIG_OF=y
# Device Tree and Open Firmware support
#
# CONFIG_PROC_DEVICETREE is not set
+# CONFIG_OF_SELFTEST is not set
CONFIG_OF_FLATTREE=y
CONFIG_OF_EARLY_FLATTREE=y
-CONFIG_OF_DYNAMIC=y
CONFIG_OF_ADDRESS=y
CONFIG_OF_IRQ=y
CONFIG_OF_DEVICE=y
CONFIG_OF_PCI=y
+CONFIG_OF_PCI_IRQ=y
# CONFIG_PARPORT is not set
# CONFIG_BLK_DEV is not set
+
+#
+# Misc devices
+#
# CONFIG_SENSORS_LIS3LV02D is not set
-# CONFIG_MISC_DEVICES is not set
+# CONFIG_PHANTOM is not set
+# CONFIG_INTEL_MID_PTI is not set
+# CONFIG_SGI_IOC4 is not set
+# CONFIG_TIFM_CORE is not set
+# CONFIG_ATMEL_SSC is not set
+# CONFIG_ENCLOSURE_SERVICES is not set
+# CONFIG_HP_ILO is not set
+# CONFIG_PCH_PHUB is not set
+# CONFIG_C2PORT is not set
+
+#
+# EEPROM support
+#
+# CONFIG_EEPROM_93CX6 is not set
+# CONFIG_CB710_CORE is not set
+
+#
+# Texas Instruments shared transport line discipline
+#
+
+#
+# Altera FPGA firmware download module
+#
CONFIG_HAVE_IDE=y
# CONFIG_IDE is not set
@@ -484,8 +575,6 @@ CONFIG_PMAC_SMU=y
# CONFIG_WINDFARM is not set
# CONFIG_PMAC_RACKMETER is not set
# CONFIG_NETDEVICES is not set
-# CONFIG_ISDN is not set
-# CONFIG_PHONE is not set
#
# Input device support
@@ -494,6 +583,7 @@ CONFIG_INPUT=y
# CONFIG_INPUT_FF_MEMLESS is not set
# CONFIG_INPUT_POLLDEV is not set
# CONFIG_INPUT_SPARSEKMAP is not set
+# CONFIG_INPUT_MATRIXKMAP is not set
#
# Userland interfaces
@@ -525,14 +615,17 @@ CONFIG_SERIO=y
# CONFIG_SERIO_XILINX_XPS_PS2 is not set
# CONFIG_SERIO_ALTERA_PS2 is not set
# CONFIG_SERIO_PS2MULT is not set
+# CONFIG_SERIO_ARC_PS2 is not set
# CONFIG_GAMEPORT is not set
#
# Character devices
#
+CONFIG_TTY=y
CONFIG_VT=y
# CONFIG_CONSOLE_TRANSLATIONS is not set
CONFIG_VT_CONSOLE=y
+CONFIG_VT_CONSOLE_SLEEP=y
CONFIG_HW_CONSOLE=y
# CONFIG_VT_HW_CONSOLE_BINDING is not set
CONFIG_UNIX98_PTYS=y
@@ -541,6 +634,8 @@ CONFIG_UNIX98_PTYS=y
# CONFIG_SERIAL_NONSTANDARD is not set
# CONFIG_NOZOMI is not set
# CONFIG_N_GSM is not set
+# CONFIG_TRACE_SINK is not set
+# CONFIG_PPC_EPAPR_HV_BYTECHAN is not set
# CONFIG_DEVKMEM is not set
#
@@ -558,10 +653,14 @@ CONFIG_SERIAL_PMACZILOG=y
CONFIG_SERIAL_PMACZILOG_TTYS=y
CONFIG_SERIAL_PMACZILOG_CONSOLE=y
# CONFIG_SERIAL_JSM is not set
+# CONFIG_SERIAL_SCCNXP is not set
# CONFIG_SERIAL_TIMBERDALE is not set
# CONFIG_SERIAL_ALTERA_JTAGUART is not set
# CONFIG_SERIAL_ALTERA_UART is not set
# CONFIG_SERIAL_PCH_UART is not set
+# CONFIG_SERIAL_XILINX_PS_UART is not set
+# CONFIG_SERIAL_ARC is not set
+# CONFIG_SERIAL_RP2 is not set
# CONFIG_TTY_PRINTK is not set
# CONFIG_HVC_UDBG is not set
# CONFIG_IPMI_HANDLER is not set
@@ -572,9 +671,10 @@ CONFIG_SERIAL_PMACZILOG_CONSOLE=y
# CONFIG_HANGCHECK_TIMER is not set
# CONFIG_TCG_TPM is not set
CONFIG_DEVPORT=y
-# CONFIG_RAMOOPS is not set
+# CONFIG_BRCM_CHAR_DRIVERS is not set
# CONFIG_I2C is not set
# CONFIG_SPI is not set
+# CONFIG_HSI is not set
#
# PPS support
@@ -584,10 +684,22 @@ CONFIG_DEVPORT=y
#
# PPS generators support
#
+
+#
+# PTP clock support
+#
+# CONFIG_PTP_1588_CLOCK is not set
+
+#
+# Enable PHYLIB and NETWORK_PHY_TIMESTAMPING to see the additional clocks.
+#
+# CONFIG_PTP_1588_CLOCK_PCH is not set
CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y
+CONFIG_GPIO_DEVRES=y
# CONFIG_GPIOLIB is not set
# CONFIG_W1 is not set
# CONFIG_POWER_SUPPLY is not set
+# CONFIG_POWER_AVS is not set
# CONFIG_HWMON is not set
# CONFIG_THERMAL is not set
# CONFIG_WATCHDOG is not set
@@ -597,7 +709,29 @@ CONFIG_SSB_POSSIBLE=y
# Sonics Silicon Backplane
#
# CONFIG_SSB is not set
-# CONFIG_MFD_SUPPORT is not set
+CONFIG_BCMA_POSSIBLE=y
+
+#
+# Broadcom specific AMBA
+#
+# CONFIG_BCMA is not set
+
+#
+# Multifunction device drivers
+#
+# CONFIG_MFD_CORE is not set
+# CONFIG_MFD_SM501 is not set
+# CONFIG_MFD_RTSX_PCI is not set
+# CONFIG_MFD_TI_AM335X_TSCADC is not set
+# CONFIG_HTC_PASIC3 is not set
+# CONFIG_MFD_TMIO is not set
+# CONFIG_ABX500_CORE is not set
+# CONFIG_LPC_SCH is not set
+# CONFIG_LPC_ICH is not set
+# CONFIG_MFD_RDC321X is not set
+# CONFIG_MFD_JANZ_CMODIO is not set
+# CONFIG_MFD_VX855 is not set
+# CONFIG_MFD_SYSCON is not set
# CONFIG_REGULATOR is not set
# CONFIG_MEDIA_SUPPORT is not set
@@ -607,9 +741,10 @@ CONFIG_SSB_POSSIBLE=y
# CONFIG_AGP is not set
# CONFIG_VGA_ARB is not set
# CONFIG_DRM is not set
-# CONFIG_STUB_POULSBO is not set
# CONFIG_VGASTATE is not set
# CONFIG_VIDEO_OUTPUT_CONTROL is not set
+# CONFIG_OF_DISPLAY_TIMING is not set
+# CONFIG_OF_VIDEOMODE is not set
CONFIG_FB=y
# CONFIG_FIRMWARE_EDID is not set
# CONFIG_FB_DDC is not set
@@ -643,6 +778,7 @@ CONFIG_FB_OF=y
# CONFIG_FB_S1D13XXX is not set
# CONFIG_FB_NVIDIA is not set
# CONFIG_FB_RIVA is not set
+# CONFIG_FB_I740 is not set
# CONFIG_FB_MATROX is not set
# CONFIG_FB_RADEON is not set
# CONFIG_FB_ATY128 is not set
@@ -660,18 +796,16 @@ CONFIG_FB_OF=y
# CONFIG_FB_PM3 is not set
# CONFIG_FB_CARMINE is not set
# CONFIG_FB_IBM_GXT4500 is not set
+# CONFIG_FB_GOLDFISH is not set
# CONFIG_FB_VIRTUAL is not set
# CONFIG_FB_METRONOME is not set
# CONFIG_FB_MB862XX is not set
# CONFIG_FB_BROADSHEET is not set
+# CONFIG_FB_AUO_K190X is not set
+# CONFIG_EXYNOS_VIDEO is not set
# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
#
-# Display device support
-#
-# CONFIG_DISPLAY_SUPPORT is not set
-
-#
# Console display driver support
#
CONFIG_VGA_CONSOLE=y
@@ -685,19 +819,33 @@ CONFIG_FONT_8x8=y
CONFIG_FONT_8x16=y
# CONFIG_LOGO is not set
# CONFIG_SOUND is not set
-# CONFIG_HID_SUPPORT is not set
+
+#
+# HID support
+#
+CONFIG_HID=y
+# CONFIG_HIDRAW is not set
+# CONFIG_UHID is not set
+CONFIG_HID_GENERIC=y
+
+#
+# Special HID drivers
+#
+CONFIG_USB_ARCH_HAS_OHCI=y
+CONFIG_USB_ARCH_HAS_EHCI=y
+CONFIG_USB_ARCH_HAS_XHCI=y
# CONFIG_USB_SUPPORT is not set
# CONFIG_UWB is not set
# CONFIG_MMC is not set
# CONFIG_MEMSTICK is not set
# CONFIG_NEW_LEDS is not set
-# CONFIG_NFC_DEVICES is not set
# CONFIG_ACCESSIBILITY is not set
# CONFIG_INFINIBAND is not set
# CONFIG_EDAC is not set
CONFIG_RTC_LIB=y
CONFIG_RTC_CLASS=y
CONFIG_RTC_HCTOSYS=y
+CONFIG_RTC_SYSTOHC=y
CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
# CONFIG_RTC_DEBUG is not set
@@ -730,17 +878,58 @@ CONFIG_RTC_DRV_M48T59=y
# CONFIG_RTC_DRV_BQ4802 is not set
# CONFIG_RTC_DRV_RP5C01 is not set
# CONFIG_RTC_DRV_V3020 is not set
+# CONFIG_RTC_DRV_DS2404 is not set
#
# on-CPU RTC drivers
#
# CONFIG_RTC_DRV_GENERIC is not set
+# CONFIG_RTC_DRV_SNVS is not set
+
+#
+# HID Sensor RTC drivers
+#
# CONFIG_DMADEVICES is not set
# CONFIG_AUXDISPLAY is not set
# CONFIG_UIO is not set
+
+#
+# Virtio drivers
+#
+# CONFIG_VIRTIO_PCI is not set
+# CONFIG_VIRTIO_MMIO is not set
+
+#
+# Microsoft Hyper-V guest support
+#
# CONFIG_STAGING is not set
#
+# Hardware Spinlock drivers
+#
+# CONFIG_MAILBOX is not set
+CONFIG_IOMMU_SUPPORT=y
+CONFIG_OF_IOMMU=y
+
+#
+# Remoteproc drivers
+#
+# CONFIG_STE_MODEM_RPROC is not set
+
+#
+# Rpmsg drivers
+#
+# CONFIG_VIRT_DRIVERS is not set
+# CONFIG_PM_DEVFREQ is not set
+# CONFIG_EXTCON is not set
+# CONFIG_MEMORY is not set
+# CONFIG_IIO is not set
+# CONFIG_VME_BUS is not set
+# CONFIG_PWM is not set
+CONFIG_IRQCHIP=y
+# CONFIG_IPACK_BUS is not set
+
+#
# File systems
#
# CONFIG_EXT2_FS is not set
@@ -752,7 +941,7 @@ CONFIG_RTC_DRV_M48T59=y
# CONFIG_GFS2_FS is not set
# CONFIG_BTRFS_FS is not set
# CONFIG_NILFS2_FS is not set
-CONFIG_FS_POSIX_ACL=y
+# CONFIG_FS_POSIX_ACL is not set
CONFIG_EXPORTFS=y
CONFIG_FILE_LOCKING=y
CONFIG_FSNOTIFY=y
@@ -792,18 +981,12 @@ CONFIG_PROC_SYSCTL=y
CONFIG_SYSFS=y
CONFIG_TMPFS=y
# CONFIG_TMPFS_POSIX_ACL is not set
+# CONFIG_TMPFS_XATTR is not set
# CONFIG_HUGETLBFS is not set
# CONFIG_HUGETLB_PAGE is not set
# CONFIG_CONFIGFS_FS is not set
# CONFIG_MISC_FILESYSTEMS is not set
# CONFIG_NETWORK_FILESYSTEMS is not set
-
-#
-# Partition Types
-#
-# CONFIG_PARTITION_ADVANCED is not set
-CONFIG_MAC_PARTITION=y
-CONFIG_MSDOS_PARTITION=y
# CONFIG_NLS is not set
# CONFIG_BINARY_PRINTF is not set
@@ -811,21 +994,34 @@ CONFIG_MSDOS_PARTITION=y
# Library routines
#
CONFIG_BITREVERSE=y
-CONFIG_GENERIC_FIND_LAST_BIT=y
+CONFIG_GENERIC_STRNCPY_FROM_USER=y
+CONFIG_GENERIC_STRNLEN_USER=y
+CONFIG_GENERIC_PCI_IOMAP=y
+CONFIG_GENERIC_IO=y
# CONFIG_CRC_CCITT is not set
# CONFIG_CRC16 is not set
# CONFIG_CRC_T10DIF is not set
# CONFIG_CRC_ITU_T is not set
CONFIG_CRC32=y
+# CONFIG_CRC32_SELFTEST is not set
+CONFIG_CRC32_SLICEBY8=y
+# CONFIG_CRC32_SLICEBY4 is not set
+# CONFIG_CRC32_SARWATE is not set
+# CONFIG_CRC32_BIT is not set
# CONFIG_CRC7 is not set
# CONFIG_LIBCRC32C is not set
+# CONFIG_CRC8 is not set
# CONFIG_XZ_DEC is not set
# CONFIG_XZ_DEC_BCJ is not set
CONFIG_HAS_IOMEM=y
CONFIG_HAS_IOPORT=y
CONFIG_HAS_DMA=y
+CONFIG_DQL=y
CONFIG_NLATTR=y
+CONFIG_ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE=y
# CONFIG_AVERAGE is not set
+# CONFIG_CORDIC is not set
+# CONFIG_DDR is not set
#
# Kernel hacking
@@ -837,32 +1033,85 @@ CONFIG_DEFAULT_MESSAGE_LOGLEVEL=4
CONFIG_FRAME_WARN=1024
# CONFIG_MAGIC_SYSRQ is not set
# CONFIG_STRIP_ASM_SYMS is not set
+# CONFIG_READABLE_ASM is not set
# CONFIG_UNUSED_SYMBOLS is not set
# CONFIG_DEBUG_FS is not set
# CONFIG_HEADERS_CHECK is not set
# CONFIG_DEBUG_SECTION_MISMATCH is not set
-# CONFIG_DEBUG_KERNEL is not set
-# CONFIG_HARDLOCKUP_DETECTOR is not set
-# CONFIG_SPARSE_RCU_POINTER is not set
+CONFIG_DEBUG_KERNEL=y
+# CONFIG_DEBUG_SHIRQ is not set
+# CONFIG_LOCKUP_DETECTOR is not set
+# CONFIG_PANIC_ON_OOPS is not set
+CONFIG_PANIC_ON_OOPS_VALUE=0
+# CONFIG_DETECT_HUNG_TASK is not set
+CONFIG_SCHED_DEBUG=y
+# CONFIG_SCHEDSTATS is not set
+# CONFIG_TIMER_STATS is not set
+# CONFIG_DEBUG_OBJECTS is not set
+# CONFIG_DEBUG_SLAB is not set
+CONFIG_HAVE_DEBUG_KMEMLEAK=y
+# CONFIG_DEBUG_KMEMLEAK is not set
+# CONFIG_DEBUG_RT_MUTEXES is not set
+# CONFIG_RT_MUTEX_TESTER is not set
+# CONFIG_DEBUG_SPINLOCK is not set
+# CONFIG_DEBUG_MUTEXES is not set
+# CONFIG_DEBUG_LOCK_ALLOC is not set
+# CONFIG_PROVE_LOCKING is not set
+# CONFIG_LOCK_STAT is not set
+# CONFIG_DEBUG_ATOMIC_SLEEP is not set
+# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
+# CONFIG_DEBUG_STACK_USAGE is not set
+# CONFIG_DEBUG_KOBJECT is not set
CONFIG_DEBUG_BUGVERBOSE=y
+# CONFIG_DEBUG_INFO is not set
+# CONFIG_DEBUG_VM is not set
+# CONFIG_DEBUG_WRITECOUNT is not set
# CONFIG_DEBUG_MEMORY_INIT is not set
-# CONFIG_SYSCTL_SYSCALL_CHECK is not set
+# CONFIG_DEBUG_LIST is not set
+# CONFIG_TEST_LIST_SORT is not set
+# CONFIG_DEBUG_SG is not set
+# CONFIG_DEBUG_NOTIFIERS is not set
+# CONFIG_DEBUG_CREDENTIALS is not set
+
+#
+# RCU Debugging
+#
+# CONFIG_SPARSE_RCU_POINTER is not set
+# CONFIG_RCU_TORTURE_TEST is not set
+# CONFIG_RCU_TRACE is not set
+# CONFIG_BACKTRACE_SELF_TEST is not set
+# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
+# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
+# CONFIG_NOTIFIER_ERROR_INJECTION is not set
+# CONFIG_FAULT_INJECTION is not set
+# CONFIG_LATENCYTOP is not set
+# CONFIG_DEBUG_PAGEALLOC is not set
CONFIG_HAVE_FUNCTION_TRACER=y
CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
CONFIG_HAVE_DYNAMIC_FTRACE=y
CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
+CONFIG_HAVE_SYSCALL_TRACEPOINTS=y
CONFIG_TRACING_SUPPORT=y
# CONFIG_FTRACE is not set
+# CONFIG_RBTREE_TEST is not set
+# CONFIG_INTERVAL_TREE_TEST is not set
# CONFIG_DMA_API_DEBUG is not set
# CONFIG_ATOMIC64_SELFTEST is not set
# CONFIG_SAMPLES is not set
CONFIG_HAVE_ARCH_KGDB=y
+# CONFIG_KGDB is not set
# CONFIG_TEST_KSTRTOX is not set
# CONFIG_PPC_DISABLE_WERROR is not set
CONFIG_PPC_WERROR=y
CONFIG_PRINT_STACK_DEPTH=64
+# CONFIG_DEBUG_STACKOVERFLOW is not set
+# CONFIG_CODE_PATCHING_SELFTEST is not set
+# CONFIG_FTR_FIXUP_SELFTEST is not set
+# CONFIG_MSI_BITMAP_SELFTEST is not set
+# CONFIG_XMON is not set
CONFIG_BOOTX_TEXT=y
# CONFIG_PPC_EARLY_DEBUG is not set
+CONFIG_STRICT_DEVMEM=y
#
# Security options
@@ -878,8 +1127,11 @@ CONFIG_CRYPTO=y
#
# Crypto core or helper
#
+CONFIG_CRYPTO_ALGAPI=y
+CONFIG_CRYPTO_ALGAPI2=y
# CONFIG_CRYPTO_MANAGER is not set
# CONFIG_CRYPTO_MANAGER2 is not set
+# CONFIG_CRYPTO_USER is not set
# CONFIG_CRYPTO_GF128MUL is not set
# CONFIG_CRYPTO_NULL is not set
# CONFIG_CRYPTO_CRYPTD is not set
@@ -915,6 +1167,7 @@ CONFIG_CRYPTO=y
# Digest
#
# CONFIG_CRYPTO_CRC32C is not set
+# CONFIG_CRYPTO_CRC32 is not set
# CONFIG_CRYPTO_GHASH is not set
# CONFIG_CRYPTO_MD4 is not set
# CONFIG_CRYPTO_MD5 is not set
@@ -924,6 +1177,7 @@ CONFIG_CRYPTO=y
# CONFIG_CRYPTO_RMD256 is not set
# CONFIG_CRYPTO_RMD320 is not set
# CONFIG_CRYPTO_SHA1 is not set
+# CONFIG_CRYPTO_SHA1_PPC is not set
# CONFIG_CRYPTO_SHA256 is not set
# CONFIG_CRYPTO_SHA512 is not set
# CONFIG_CRYPTO_TGR192 is not set
@@ -932,7 +1186,7 @@ CONFIG_CRYPTO=y
#
# Ciphers
#
-# CONFIG_CRYPTO_AES is not set
+CONFIG_CRYPTO_AES=y
# CONFIG_CRYPTO_ANUBIS is not set
# CONFIG_CRYPTO_ARC4 is not set
# CONFIG_CRYPTO_BLOWFISH is not set
@@ -962,10 +1216,5 @@ CONFIG_CRYPTO=y
# CONFIG_CRYPTO_USER_API_HASH is not set
# CONFIG_CRYPTO_USER_API_SKCIPHER is not set
# CONFIG_CRYPTO_HW is not set
-
-#
-# OCF Configuration
-#
-# CONFIG_OCF_OCF is not set
# CONFIG_PPC_CLOCK is not set
# CONFIG_VIRTUALIZATION is not set
diff --git a/toolchain/binutils/patches/2.23.2/arm-whitespace.patch b/toolchain/binutils/patches/2.23.2/arm-whitespace.patch
new file mode 100644
index 000000000..0bc560166
--- /dev/null
+++ b/toolchain/binutils/patches/2.23.2/arm-whitespace.patch
@@ -0,0 +1,23 @@
+diff -Nur binutils-2.23.2.orig/gas/config/tc-arm.c binutils-2.23.2/gas/config/tc-arm.c
+--- binutils-2.23.2.orig/gas/config/tc-arm.c 2013-03-25 09:06:21.000000000 +0100
++++ binutils-2.23.2/gas/config/tc-arm.c 2013-09-24 13:26:32.000000000 +0200
+@@ -885,6 +885,9 @@
+ static inline int
+ skip_past_char (char ** str, char c)
+ {
++ /* PR gas/14987: Allow for whitespace before the expected character. */
++ skip_whitespace (*str);
++
+ if (**str == c)
+ {
+ (*str)++;
+@@ -5168,6 +5171,9 @@
+ return PARSE_OPERAND_SUCCESS;
+ }
+
++ /* PR gas/14887: Allow for whitespace after the opening bracket. */
++ skip_whitespace (p);
++
+ if ((reg = arm_reg_parse (&p, REG_TYPE_RN)) == FAIL)
+ {
+ inst.error = _(reg_expected_msgs[REG_TYPE_RN]);
diff --git a/toolchain/gcc/Makefile b/toolchain/gcc/Makefile
index 2bc954347..5d00be19b 100644
--- a/toolchain/gcc/Makefile
+++ b/toolchain/gcc/Makefile
@@ -62,8 +62,12 @@ GCC_CONFOPTS+= --enable-tls
endif
ifeq ($(ARCH),powerpc)
+ifeq ($(ADK_TARGET_LIBC),musl)
GCC_CONFOPTS+= --disable-target-optspace --with-long-double-64 --enable-secureplt
else
+GCC_CONFOPTS+= --disable-target-optspace --with-long-double-128 --enable-secureplt
+endif
+else
GCC_CONFOPTS+= --enable-target-optspace
endif
diff --git a/toolchain/gcc/patches/4.7.3/musl-cross.patch b/toolchain/gcc/patches/4.7.3/musl-cross.patch
index bbba746b0..453ba9aec 100644
--- a/toolchain/gcc/patches/4.7.3/musl-cross.patch
+++ b/toolchain/gcc/patches/4.7.3/musl-cross.patch
@@ -386,37 +386,9 @@ diff -Nur gcc-4.7.3.orig/gcc/config/rs6000/linux64.h gcc-4.7.3/gcc/config/rs6000
#define LINK_OS_LINUX_SPEC32 "-m elf32ppclinux %{!shared: %{!static: \
-diff -Nur gcc-4.7.3.orig/gcc/config/rs6000/secureplt.h gcc-4.7.3/gcc/config/rs6000/secureplt.h
---- gcc-4.7.3.orig/gcc/config/rs6000/secureplt.h 2007-08-02 12:49:31.000000000 +0200
-+++ gcc-4.7.3/gcc/config/rs6000/secureplt.h 2013-09-16 15:39:43.000000000 +0200
-@@ -18,3 +18,4 @@
- <http://www.gnu.org/licenses/>. */
-
- #define CC1_SECURE_PLT_DEFAULT_SPEC "-msecure-plt"
-+#define LINK_SECURE_PLT_DEFAULT_SPEC "--secure-plt"
diff -Nur gcc-4.7.3.orig/gcc/config/rs6000/sysv4.h gcc-4.7.3/gcc/config/rs6000/sysv4.h
--- gcc-4.7.3.orig/gcc/config/rs6000/sysv4.h 2012-04-30 19:39:01.000000000 +0200
+++ gcc-4.7.3/gcc/config/rs6000/sysv4.h 2013-09-16 15:39:43.000000000 +0200
-@@ -566,6 +566,9 @@
- #ifndef CC1_SECURE_PLT_DEFAULT_SPEC
- #define CC1_SECURE_PLT_DEFAULT_SPEC ""
- #endif
-+#ifndef LINK_SECURE_PLT_DEFAULT_SPEC
-+#define LINK_SECURE_PLT_DEFAULT_SPEC ""
-+#endif
-
- /* Pass -G xxx to the compiler and set correct endian mode. */
- #define CC1_SPEC "%{G*} %(cc1_cpu) \
-@@ -626,7 +629,8 @@
- %{mlittle: --oformat elf32-powerpcle } %{mlittle-endian: --oformat elf32-powerpcle } \
- %{!mlittle: %{!mlittle-endian: %{!mbig: %{!mbig-endian: \
- %{mcall-i960-old: --oformat elf32-powerpcle} \
-- }}}}"
-+ }}}} \
-+%{!mbss-plt: %{!msecure-plt: %(link_secure_plt_default)}}"
-
- /* Any specific OS flags. */
- #define LINK_OS_SPEC "\
@@ -804,15 +808,18 @@
#define GLIBC_DYNAMIC_LINKER "/lib/ld.so.1"
@@ -439,14 +411,6 @@ diff -Nur gcc-4.7.3.orig/gcc/config/rs6000/sysv4.h gcc-4.7.3/gcc/config/rs6000/s
#define LINK_OS_LINUX_SPEC "-m elf32ppclinux %{!shared: %{!static: \
%{rdynamic:-export-dynamic} \
-@@ -938,6 +945,7 @@
- { "cc1_endian_little", CC1_ENDIAN_LITTLE_SPEC }, \
- { "cc1_endian_default", CC1_ENDIAN_DEFAULT_SPEC }, \
- { "cc1_secure_plt_default", CC1_SECURE_PLT_DEFAULT_SPEC }, \
-+ { "link_secure_plt_default", LINK_SECURE_PLT_DEFAULT_SPEC }, \
- { "cpp_os_ads", CPP_OS_ADS_SPEC }, \
- { "cpp_os_yellowknife", CPP_OS_YELLOWKNIFE_SPEC }, \
- { "cpp_os_mvme", CPP_OS_MVME_SPEC }, \
diff -Nur gcc-4.7.3.orig/gcc/config.gcc gcc-4.7.3/gcc/config.gcc
--- gcc-4.7.3.orig/gcc/config.gcc 2013-03-06 23:54:11.000000000 +0100
+++ gcc-4.7.3/gcc/config.gcc 2013-09-16 15:39:43.000000000 +0200
diff --git a/toolchain/gcc/patches/4.7.3/ppc-uclibc-cmath.patch b/toolchain/gcc/patches/4.7.3/ppc-uclibc-cmath.patch
new file mode 100644
index 000000000..0e64e8d0e
--- /dev/null
+++ b/toolchain/gcc/patches/4.7.3/ppc-uclibc-cmath.patch
@@ -0,0 +1,217 @@
+diff -Nur gcc-4.7.3.orig/libstdc++-v3/include/tr1/cmath gcc-4.7.3/libstdc++-v3/include/tr1/cmath
+--- gcc-4.7.3.orig/libstdc++-v3/include/tr1/cmath 2011-11-14 00:51:42.000000000 +0100
++++ gcc-4.7.3/libstdc++-v3/include/tr1/cmath 2013-09-22 20:13:54.000000000 +0200
+@@ -159,143 +159,213 @@
+ // functions
+ using ::acosh;
+ using ::acoshf;
++#ifdef __LONG_DOUBLE_128__
+ using ::acoshl;
++#endif
+
+ using ::asinh;
+ using ::asinhf;
++#ifdef __LONG_DOUBLE_128__
+ using ::asinhl;
++#endif
+
+ using ::atanh;
+ using ::atanhf;
++#ifdef __LONG_DOUBLE_128__
+ using ::atanhl;
++#endif
+
+ using ::cbrt;
+ using ::cbrtf;
++#ifdef __LONG_DOUBLE_128__
+ using ::cbrtl;
++#endif
+
+ using ::copysign;
+ using ::copysignf;
++#ifdef __LONG_DOUBLE_128__
+ using ::copysignl;
++#endif
+
+ using ::erf;
+ using ::erff;
++#ifdef __LONG_DOUBLE_128__
+ using ::erfl;
++#endif
+
+ using ::erfc;
+ using ::erfcf;
++#ifdef __LONG_DOUBLE_128__
+ using ::erfcl;
++#endif
+
+ using ::exp2;
+ using ::exp2f;
++#ifdef __LONG_DOUBLE_128__
+ using ::exp2l;
++#endif
+
+ using ::expm1;
+ using ::expm1f;
++#ifdef __LONG_DOUBLE_128__
+ using ::expm1l;
++#endif
+
+ using ::fdim;
+ using ::fdimf;
++#ifdef __LONG_DOUBLE_128__
+ using ::fdiml;
++#endif
+
+ using ::fma;
+ using ::fmaf;
++#ifdef __LONG_DOUBLE_128__
+ using ::fmal;
++#endif
+
+ using ::fmax;
+ using ::fmaxf;
++#ifdef __LONG_DOUBLE_128__
+ using ::fmaxl;
++#endif
+
+ using ::fmin;
+ using ::fminf;
++#ifdef __LONG_DOUBLE_128__
+ using ::fminl;
++#endif
+
+ using ::hypot;
+ using ::hypotf;
++#ifdef __LONG_DOUBLE_128__
+ using ::hypotl;
++#endif
+
+ using ::ilogb;
+ using ::ilogbf;
++#ifdef __LONG_DOUBLE_128__
+ using ::ilogbl;
++#endif
+
+ using ::lgamma;
+ using ::lgammaf;
++#ifdef __LONG_DOUBLE_128__
+ using ::lgammal;
++#endif
+
+ using ::llrint;
+ using ::llrintf;
++#ifdef __LONG_DOUBLE_128__
+ using ::llrintl;
++#endif
+
+ using ::llround;
+ using ::llroundf;
++#ifdef __LONG_DOUBLE_128__
+ using ::llroundl;
++#endif
+
+ using ::log1p;
+ using ::log1pf;
++#ifdef __LONG_DOUBLE_128__
+ using ::log1pl;
++#endif
+
+ using ::log2;
+ using ::log2f;
++#ifdef __LONG_DOUBLE_128__
+ using ::log2l;
++#endif
+
+ using ::logb;
+ using ::logbf;
++#ifdef __LONG_DOUBLE_128__
+ using ::logbl;
++#endif
+
+ using ::lrint;
+ using ::lrintf;
++#ifdef __LONG_DOUBLE_128__
+ using ::lrintl;
++#endif
+
+ using ::lround;
+ using ::lroundf;
++#ifdef __LONG_DOUBLE_128__
+ using ::lroundl;
++#endif
+
+ using ::nan;
+ using ::nanf;
++#ifdef __LONG_DOUBLE_128__
+ using ::nanl;
++#endif
+
+ using ::nearbyint;
+ using ::nearbyintf;
++#ifdef __LONG_DOUBLE_128__
+ using ::nearbyintl;
++#endif
+
+ using ::nextafter;
+ using ::nextafterf;
++#ifdef __LONG_DOUBLE_128__
+ using ::nextafterl;
++#endif
+
+ using ::nexttoward;
+ using ::nexttowardf;
++#ifdef __LONG_DOUBLE_128__
+ using ::nexttowardl;
++#endif
+
+ using ::remainder;
+ using ::remainderf;
++#ifdef __LONG_DOUBLE_128__
+ using ::remainderl;
++#endif
+
+ using ::remquo;
+ using ::remquof;
++#ifdef __LONG_DOUBLE_128__
+ using ::remquol;
++#endif
+
+ using ::rint;
+ using ::rintf;
++#ifdef __LONG_DOUBLE_128__
+ using ::rintl;
++#endif
+
+ using ::round;
+ using ::roundf;
++#ifdef __LONG_DOUBLE_128__
+ using ::roundl;
++#endif
+
+ using ::scalbln;
+ using ::scalblnf;
++#ifdef __LONG_DOUBLE_128__
+ using ::scalblnl;
++#endif
+
+ using ::scalbn;
+ using ::scalbnf;
++#ifdef __LONG_DOUBLE_128__
+ using ::scalbnl;
++#endif
+
+ using ::tgamma;
+ using ::tgammaf;
++#ifdef __LONG_DOUBLE_128__
+ using ::tgammal;
++#endif
+
+ using ::trunc;
+ using ::truncf;
++#ifdef __LONG_DOUBLE_128__
+ using ::truncl;
++#endif
+
+ #endif
+
diff --git a/toolchain/musl/Makefile.inc b/toolchain/musl/Makefile.inc
index 83dc75168..37bd7a981 100644
--- a/toolchain/musl/Makefile.inc
+++ b/toolchain/musl/Makefile.inc
@@ -2,8 +2,8 @@
# material, please see the LICENCE file in the top-level directory.
PKG_NAME:= musl
-PKG_VERSION:= 0.9.13
+PKG_VERSION:= 0.9.14
PKG_RELEASE:= 1
-PKG_MD5SUM:= 6af97d6157a2f4ee7a17af2316389fd7
+PKG_MD5SUM:= bfb685695aa942e64c63170589e575b2
PKG_SITES:= http://www.musl-libc.org/releases/
DISTFILES:= $(PKG_NAME)-$(PKG_VERSION).tar.gz
diff --git a/toolchain/musl/patches/0.9.13/musl-git.patch b/toolchain/musl/patches/0.9.13/musl-git.patch
deleted file mode 100644
index a6a87390f..000000000
--- a/toolchain/musl/patches/0.9.13/musl-git.patch
+++ /dev/null
@@ -1,8837 +0,0 @@
-diff -Nur musl-0.9.13/.gitignore musl-git/.gitignore
---- musl-0.9.13/.gitignore 1970-01-01 01:00:00.000000000 +0100
-+++ musl-git/.gitignore 2013-09-16 20:31:39.000000000 +0200
-@@ -0,0 +1,10 @@
-+*.o
-+*.lo
-+*.a
-+*.so
-+*.so.1
-+arch/*/bits/alltypes.h
-+config.mak
-+include/bits
-+tools/musl-gcc
-+lib/musl-gcc.specs
-diff -Nur musl-0.9.13/Makefile musl-git/Makefile
---- musl-0.9.13/Makefile 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/Makefile 2013-09-16 20:31:39.000000000 +0200
-@@ -157,7 +157,7 @@
- $(INSTALL) -D -m 644 $< $@
-
- $(DESTDIR)$(LDSO_PATHNAME): $(DESTDIR)$(libdir)/libc.so
-- $(INSTALL) -D -l $< $@ || true
-+ $(INSTALL) -D -l $(libdir)/libc.so $@ || true
-
- install-libs: $(ALL_LIBS:lib/%=$(DESTDIR)$(libdir)/%) $(if $(SHARED_LIBS),$(DESTDIR)$(LDSO_PATHNAME),)
-
-diff -Nur musl-0.9.13/arch/microblaze/bits/limits.h musl-git/arch/microblaze/bits/limits.h
---- musl-0.9.13/arch/microblaze/bits/limits.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/microblaze/bits/limits.h 2013-09-16 20:31:39.000000000 +0200
-@@ -1,6 +1,5 @@
- #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
- || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
--#define PAGE_SIZE 4096
- #define LONG_BIT 32
- #endif
-
-diff -Nur musl-0.9.13/arch/microblaze/reloc.h musl-git/arch/microblaze/reloc.h
---- musl-0.9.13/arch/microblaze/reloc.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/microblaze/reloc.h 2013-09-16 20:31:39.000000000 +0200
-@@ -49,7 +49,7 @@
- for (a+=c+1; *a; a++);
- for (a++; *a; a+=2) if (*a<20) t[*a] = a[1];
- base = (char *)t[AT_BASE];
-- if (!base) base = (char *)(t[AT_PHDR] & -4096);
-+ if (!base) base = (char *)(t[AT_PHDR] & -t[AT_PAGESZ]);
- for (a=dynv; *a; a+=2) if (*a<20) t[*a] = a[1];
- n = t[DT_RELASZ];
- for (a=(void *)(base+t[DT_RELA]); n; a+=3, n-=12)
-diff -Nur musl-0.9.13/arch/mips/bits/limits.h musl-git/arch/mips/bits/limits.h
---- musl-0.9.13/arch/mips/bits/limits.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/mips/bits/limits.h 2013-09-16 20:31:39.000000000 +0200
-@@ -1,6 +1,5 @@
- #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
- || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
--#define PAGE_SIZE 4096
- #define LONG_BIT 32
- #endif
-
-diff -Nur musl-0.9.13/arch/mips/bits/msg.h musl-git/arch/mips/bits/msg.h
---- musl-0.9.13/arch/mips/bits/msg.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/mips/bits/msg.h 2013-09-16 20:31:39.000000000 +0200
-@@ -1,12 +1,21 @@
- struct msqid_ds
- {
- struct ipc_perm msg_perm;
-+#if _MIPSEL || __MIPSEL || __MIPSEL__
- time_t msg_stime;
- int __unused1;
- time_t msg_rtime;
- int __unused2;
- time_t msg_ctime;
- int __unused3;
-+#else
-+ int __unused1;
-+ time_t msg_stime;
-+ int __unused2;
-+ time_t msg_rtime;
-+ int __unused3;
-+ time_t msg_ctime;
-+#endif
- unsigned long msg_cbytes;
- msgqnum_t msg_qnum;
- msglen_t msg_qbytes;
-diff -Nur musl-0.9.13/arch/mips/bits/shm.h musl-git/arch/mips/bits/shm.h
---- musl-0.9.13/arch/mips/bits/shm.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/mips/bits/shm.h 2013-09-16 20:31:39.000000000 +0200
-@@ -5,11 +5,8 @@
- struct ipc_perm shm_perm;
- size_t shm_segsz;
- time_t shm_atime;
-- int __unused1;
- time_t shm_dtime;
-- int __unused2;
- time_t shm_ctime;
-- int __unused3;
- pid_t shm_cpid;
- pid_t shm_lpid;
- unsigned long shm_nattch;
-diff -Nur musl-0.9.13/arch/mips/reloc.h musl-git/arch/mips/reloc.h
---- musl-0.9.13/arch/mips/reloc.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/mips/reloc.h 2013-09-16 20:31:39.000000000 +0200
-@@ -51,7 +51,7 @@
- for (a+=c+1; *a; a++);
- for (a++; *a; a+=2) if (*a<20) t[*a] = a[1];
- base = (char *)t[AT_BASE];
-- if (!base) base = (char *)(t[AT_PHDR] & -4096);
-+ if (!base) base = (char *)(t[AT_PHDR] & -t[AT_PAGESZ]);
- for (a=dynv; *a; a+=2) if (*a-0x70000000UL<20) t[*a&31] = a[1];
- n = t[DT_MIPS_LOCAL_GOTNO - 0x70000000];
- for (a=got; n; a++, n--) *a += (size_t)base;
-diff -Nur musl-0.9.13/arch/powerpc/bits/limits.h musl-git/arch/powerpc/bits/limits.h
---- musl-0.9.13/arch/powerpc/bits/limits.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/powerpc/bits/limits.h 2013-09-16 20:31:39.000000000 +0200
-@@ -1,6 +1,5 @@
- #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
- || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
--#define PAGE_SIZE 4096
- #define LONG_BIT 32
- #endif
-
-diff -Nur musl-0.9.13/arch/powerpc/reloc.h musl-git/arch/powerpc/reloc.h
---- musl-0.9.13/arch/powerpc/reloc.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/arch/powerpc/reloc.h 2013-09-16 20:31:39.000000000 +0200
-@@ -46,7 +46,7 @@
- for (a+=c+1; *a; a++);
- for (a++; *a; a+=2) if (*a<20) t[*a] = a[1];
- base = (char *)t[AT_BASE];
-- if (!base) base = (char *)(t[AT_PHDR] & -4096);
-+ if (!base) base = (char *)(t[AT_PHDR] & -t[AT_PAGESZ]);
- for (a=dynv; *a; a+=2) if (*a<20) t[*a] = a[1];
- n = t[DT_RELASZ];
- for (a=(void *)(base+t[DT_RELA]); n; a+=3, n-=12)
-diff -Nur musl-0.9.13/include/elf.h musl-git/include/elf.h
---- musl-0.9.13/include/elf.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/include/elf.h 2013-09-16 20:31:39.000000000 +0200
-@@ -105,6 +105,7 @@
- #define ELFOSABI_HPUX 1
- #define ELFOSABI_NETBSD 2
- #define ELFOSABI_LINUX 3
-+#define ELFOSABI_GNU 3
- #define ELFOSABI_SOLARIS 6
- #define ELFOSABI_AIX 7
- #define ELFOSABI_IRIX 8
-@@ -211,7 +212,11 @@
- #define EM_OPENRISC 92
- #define EM_ARC_A5 93
- #define EM_XTENSA 94
--#define EM_NUM 95
-+#define EM_AARCH64 183
-+#define EM_TILEPRO 188
-+#define EM_MICROBLAZE 189
-+#define EM_TILEGX 191
-+#define EM_NUM 192
- #define EM_ALPHA 0x9026
-
- #define EV_NONE 0
-@@ -487,6 +492,8 @@
- #define PT_HIPROC 0x7fffffff
-
-
-+#define PN_XNUM 0xffff
-+
-
- #define PF_X (1 << 0)
- #define PF_W (1 << 1)
-@@ -512,12 +519,31 @@
- #define NT_LWPSTATUS 16
- #define NT_LWPSINFO 17
- #define NT_PRFPXREG 20
-+#define NT_SIGINFO 0x53494749
-+#define NT_FILE 0x46494c45
- #define NT_PRXFPREG 0x46e62b7f
- #define NT_PPC_VMX 0x100
- #define NT_PPC_SPE 0x101
- #define NT_PPC_VSX 0x102
- #define NT_386_TLS 0x200
- #define NT_386_IOPERM 0x201
-+#define NT_X86_XSTATE 0x202
-+#define NT_S390_HIGH_GPRS 0x300
-+#define NT_S390_TIMER 0x301
-+#define NT_S390_TODCMP 0x302
-+#define NT_S390_TODPREG 0x303
-+#define NT_S390_CTRS 0x304
-+#define NT_S390_PREFIX 0x305
-+#define NT_S390_LAST_BREAK 0x306
-+#define NT_S390_SYSTEM_CALL 0x307
-+#define NT_S390_TDB 0x308
-+#define NT_ARM_VFP 0x400
-+#define NT_ARM_TLS 0x401
-+#define NT_ARM_HW_BREAK 0x402
-+#define NT_ARM_HW_WATCH 0x403
-+#define NT_METAG_CBUF 0x500
-+#define NT_METAG_RPIPE 0x501
-+#define NT_METAG_TLS 0x502
- #define NT_VERSION 1
-
-
-@@ -666,7 +692,15 @@
- #define DF_1_ENDFILTEE 0x00004000
- #define DF_1_DISPRELDNE 0x00008000
- #define DF_1_DISPRELPND 0x00010000
--
-+#define DF_1_NODIRECT 0x00020000
-+#define DF_1_IGNMULDEF 0x00040000
-+#define DF_1_NOKSYMS 0x00080000
-+#define DF_1_NOHDR 0x00100000
-+#define DF_1_EDITED 0x00200000
-+#define DF_1_NORELOC 0x00400000
-+#define DF_1_SYMINTPOSE 0x00800000
-+#define DF_1_GLOBAUDIT 0x01000000
-+#define DF_1_SINGLETON 0x02000000
-
- #define DTF_1_PARINIT 0x00000001
- #define DTF_1_CONFEXP 0x00000002
-@@ -832,6 +866,8 @@
-
- #define AT_RANDOM 25
-
-+#define AT_HWCAP2 26
-+
- #define AT_EXECFN 31
-
-
-@@ -979,6 +1015,7 @@
- #define R_386_TLS_DTPMOD32 35
- #define R_386_TLS_DTPOFF32 36
- #define R_386_TLS_TPOFF32 37
-+#define R_386_SIZE32 38
- #define R_386_TLS_GOTDESC 39
- #define R_386_TLS_DESC_CALL 40
- #define R_386_TLS_DESC 41
-@@ -1109,20 +1146,6 @@
- #define DT_SPARC_NUM 2
-
-
--
--#define HWCAP_SPARC_FLUSH 1
--#define HWCAP_SPARC_STBAR 2
--#define HWCAP_SPARC_SWAP 4
--#define HWCAP_SPARC_MULDIV 8
--#define HWCAP_SPARC_V9 16
--#define HWCAP_SPARC_ULTRA3 32
--#define HWCAP_SPARC_BLKINIT 64
--#define HWCAP_SPARC_N2 128
--
--
--
--
--
- #define EF_MIPS_NOREORDER 1
- #define EF_MIPS_PIC 2
- #define EF_MIPS_CPIC 4
-@@ -1139,9 +1162,10 @@
- #define EF_MIPS_ARCH_3 0x20000000
- #define EF_MIPS_ARCH_4 0x30000000
- #define EF_MIPS_ARCH_5 0x40000000
--#define EF_MIPS_ARCH_32 0x60000000
--#define EF_MIPS_ARCH_64 0x70000000
--
-+#define EF_MIPS_ARCH_32 0x50000000
-+#define EF_MIPS_ARCH_64 0x60000000
-+#define EF_MIPS_ARCH_32R2 0x70000000
-+#define EF_MIPS_ARCH_64R2 0x80000000
-
-
- #define E_MIPS_ARCH_1 0x00000000
-@@ -1149,8 +1173,8 @@
- #define E_MIPS_ARCH_3 0x20000000
- #define E_MIPS_ARCH_4 0x30000000
- #define E_MIPS_ARCH_5 0x40000000
--#define E_MIPS_ARCH_32 0x60000000
--#define E_MIPS_ARCH_64 0x70000000
-+#define E_MIPS_ARCH_32 0x50000000
-+#define E_MIPS_ARCH_64 0x60000000
-
-
-
-@@ -2020,7 +2044,8 @@
- #define EF_ARM_VFP_FLOAT 0x400
- #define EF_ARM_MAVERICK_FLOAT 0x800
-
--
-+#define EF_ARM_ABI_FLOAT_SOFT 0x200
-+#define EF_ARM_ABI_FLOAT_HARD 0x400
-
-
- #define EF_ARM_SYMSARESORTED 0x04
-@@ -2064,6 +2089,17 @@
- #define SHT_ARM_ATTRIBUTES (SHT_LOPROC + 3)
-
-
-+#define R_AARCH64_NONE 0
-+#define R_AARCH64_ABS64 257
-+#define R_AARCH64_ABS32 258
-+#define R_AARCH64_COPY 1024
-+#define R_AARCH64_GLOB_DAT 1025
-+#define R_AARCH64_JUMP_SLOT 1026
-+#define R_AARCH64_RELATIVE 1027
-+#define R_AARCH64_TLS_DTPMOD64 1028
-+#define R_AARCH64_TLS_DTPREL64 1029
-+#define R_AARCH64_TLS_TPREL64 1030
-+#define R_AARCH64_TLSDESC 1031
-
-
- #define R_ARM_NONE 0
-@@ -2079,7 +2115,7 @@
- #define R_ARM_THM_PC22 10
- #define R_ARM_THM_PC8 11
- #define R_ARM_AMP_VCALL9 12
--#define R_ARM_SWI24 13
-+#define R_ARM_TLS_DESC 13
- #define R_ARM_THM_SWI8 14
- #define R_ARM_XPC25 15
- #define R_ARM_THM_XPC22 16
-@@ -2094,12 +2130,78 @@
- #define R_ARM_GOTPC 25
- #define R_ARM_GOT32 26
- #define R_ARM_PLT32 27
-+#define R_ARM_CALL 28
-+#define R_ARM_JUMP24 29
-+#define R_ARM_THM_JUMP24 30
-+#define R_ARM_BASE_ABS 31
- #define R_ARM_ALU_PCREL_7_0 32
- #define R_ARM_ALU_PCREL_15_8 33
- #define R_ARM_ALU_PCREL_23_15 34
- #define R_ARM_LDR_SBREL_11_0 35
- #define R_ARM_ALU_SBREL_19_12 36
- #define R_ARM_ALU_SBREL_27_20 37
-+#define R_ARM_TARGET1 38
-+#define R_ARM_SBREL31 39
-+#define R_ARM_V4BX 40
-+#define R_ARM_TARGET2 41
-+#define R_ARM_PREL31 42
-+#define R_ARM_MOVW_ABS_NC 43
-+#define R_ARM_MOVT_ABS 44
-+#define R_ARM_MOVW_PREL_NC 45
-+#define R_ARM_MOVT_PREL 46
-+#define R_ARM_THM_MOVW_ABS_NC 47
-+#define R_ARM_THM_MOVT_ABS 48
-+#define R_ARM_THM_MOVW_PREL_NC 49
-+#define R_ARM_THM_MOVT_PREL 50
-+#define R_ARM_THM_JUMP19 51
-+#define R_ARM_THM_JUMP6 52
-+#define R_ARM_THM_ALU_PREL_11_0 53
-+#define R_ARM_THM_PC12 54
-+#define R_ARM_ABS32_NOI 55
-+#define R_ARM_REL32_NOI 56
-+#define R_ARM_ALU_PC_G0_NC 57
-+#define R_ARM_ALU_PC_G0 58
-+#define R_ARM_ALU_PC_G1_NC 59
-+#define R_ARM_ALU_PC_G1 60
-+#define R_ARM_ALU_PC_G2 61
-+#define R_ARM_LDR_PC_G1 62
-+#define R_ARM_LDR_PC_G2 63
-+#define R_ARM_LDRS_PC_G0 64
-+#define R_ARM_LDRS_PC_G1 65
-+#define R_ARM_LDRS_PC_G2 66
-+#define R_ARM_LDC_PC_G0 67
-+#define R_ARM_LDC_PC_G1 68
-+#define R_ARM_LDC_PC_G2 69
-+#define R_ARM_ALU_SB_G0_NC 70
-+#define R_ARM_ALU_SB_G0 71
-+#define R_ARM_ALU_SB_G1_NC 72
-+#define R_ARM_ALU_SB_G1 73
-+#define R_ARM_ALU_SB_G2 74
-+#define R_ARM_LDR_SB_G0 75
-+#define R_ARM_LDR_SB_G1 76
-+#define R_ARM_LDR_SB_G2 77
-+#define R_ARM_LDRS_SB_G0 78
-+#define R_ARM_LDRS_SB_G1 79
-+#define R_ARM_LDRS_SB_G2 80
-+#define R_ARM_LDC_SB_G0 81
-+#define R_ARM_LDC_SB_G1 82
-+#define R_ARM_LDC_SB_G2 83
-+#define R_ARM_MOVW_BREL_NC 84
-+#define R_ARM_MOVT_BREL 85
-+#define R_ARM_MOVW_BREL 86
-+#define R_ARM_THM_MOVW_BREL_NC 87
-+#define R_ARM_THM_MOVT_BREL 88
-+#define R_ARM_THM_MOVW_BREL 89
-+#define R_ARM_TLS_GOTDESC 90
-+#define R_ARM_TLS_CALL 91
-+#define R_ARM_TLS_DESCSEQ 92
-+#define R_ARM_THM_TLS_CALL 93
-+#define R_ARM_PLT32_ABS 94
-+#define R_ARM_GOT_ABS 95
-+#define R_ARM_GOT_PREL 96
-+#define R_ARM_GOT_BREL12 97
-+#define R_ARM_GOTOFF12 98
-+#define R_ARM_GOTRELAX 99
- #define R_ARM_GNU_VTENTRY 100
- #define R_ARM_GNU_VTINHERIT 101
- #define R_ARM_THM_PC11 102
-@@ -2113,7 +2215,15 @@
- #define R_ARM_TLS_IE32 107
-
- #define R_ARM_TLS_LE32 108
--
-+#define R_ARM_TLS_LDO12 109
-+#define R_ARM_TLS_LE12 110
-+#define R_ARM_TLS_IE12GP 111
-+#define R_ARM_ME_TOO 128
-+#define R_ARM_THM_TLS_DESCSEQ 129
-+#define R_ARM_THM_TLS_DESCSEQ16 129
-+#define R_ARM_THM_TLS_DESCSEQ32 130
-+#define R_ARM_THM_GOT_BREL12 131
-+#define R_ARM_IRELATIVE 160
- #define R_ARM_RXPC25 249
- #define R_ARM_RSBREL32 250
- #define R_ARM_THM_RPC22 251
-@@ -2421,15 +2531,21 @@
- #define R_X86_64_PC64 24
- #define R_X86_64_GOTOFF64 25
- #define R_X86_64_GOTPC32 26
--
-+#define R_X86_64_GOT64 27
-+#define R_X86_64_GOTPCREL64 28
-+#define R_X86_64_GOTPC64 29
-+#define R_X86_64_GOTPLT64 30
-+#define R_X86_64_PLTOFF64 31
-+#define R_X86_64_SIZE32 32
-+#define R_X86_64_SIZE64 33
-
- #define R_X86_64_GOTPC32_TLSDESC 34
- #define R_X86_64_TLSDESC_CALL 35
-
- #define R_X86_64_TLSDESC 36
- #define R_X86_64_IRELATIVE 37
--
--#define R_X86_64_NUM 38
-+#define R_X86_64_RELATIVE64 38
-+#define R_X86_64_NUM 39
-
-
-
-diff -Nur musl-0.9.13/include/limits.h musl-git/include/limits.h
---- musl-0.9.13/include/limits.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/include/limits.h 2013-09-16 20:31:39.000000000 +0200
-@@ -40,7 +40,9 @@
- || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE)
-
- #define PIPE_BUF 4096
-+#ifdef PAGE_SIZE
- #define PAGESIZE PAGE_SIZE
-+#endif
- #define FILESIZEBITS 64
- #define NAME_MAX 255
- #define SYMLINK_MAX 255
-diff -Nur musl-0.9.13/include/net/if_arp.h musl-git/include/net/if_arp.h
---- musl-0.9.13/include/net/if_arp.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/include/net/if_arp.h 2013-09-16 20:31:39.000000000 +0200
-@@ -52,6 +52,7 @@
- #define ARPHRD_ROSE 270
- #define ARPHRD_X25 271
- #define ARPHRD_HWX25 272
-+#define ARPHRD_CAN 280
- #define ARPHRD_PPP 512
- #define ARPHRD_CISCO 513
- #define ARPHRD_HDLC ARPHRD_CISCO
-@@ -84,7 +85,12 @@
- #define ARPHRD_IEEE80211_PRISM 802
- #define ARPHRD_IEEE80211_RADIOTAP 803
- #define ARPHRD_IEEE802154 804
--#define ARPHRD_IEEE802154_PHY 805
-+#define ARPHRD_IEEE802154_MONITOR 805
-+#define ARPHRD_PHONET 820
-+#define ARPHRD_PHONET_PIPE 821
-+#define ARPHRD_CAIF 822
-+#define ARPHRD_IP6GRE 823
-+#define ARPHRD_NETLINK 824
-
- #define ARPHRD_VOID 0xFFFF
- #define ARPHRD_NONE 0xFFFE
-diff -Nur musl-0.9.13/include/netinet/in.h musl-git/include/netinet/in.h
---- musl-0.9.13/include/netinet/in.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/include/netinet/in.h 2013-09-16 20:31:39.000000000 +0200
-@@ -91,10 +91,12 @@
- #define IPPROTO_NONE 59
- #define IPPROTO_DSTOPTS 60
- #define IPPROTO_MTP 92
-+#define IPPROTO_BEETPH 94
- #define IPPROTO_ENCAP 98
- #define IPPROTO_PIM 103
- #define IPPROTO_COMP 108
- #define IPPROTO_SCTP 132
-+#define IPPROTO_MH 135
- #define IPPROTO_UDPLITE 136
- #define IPPROTO_RAW 255
- #define IPPROTO_MAX 256
-diff -Nur musl-0.9.13/include/sys/ptrace.h musl-git/include/sys/ptrace.h
---- musl-0.9.13/include/sys/ptrace.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/include/sys/ptrace.h 2013-09-16 20:31:39.000000000 +0200
-@@ -37,6 +37,8 @@
- #define PTRACE_INTERRUPT 0x4207
- #define PTRACE_LISTEN 0x4208
- #define PTRACE_PEEKSIGINFO 0x4209
-+#define PTRACE_GETSIGMASK 0x420a
-+#define PTRACE_SETSIGMASK 0x420b
-
- #define PT_READ_I PTRACE_PEEKTEXT
- #define PT_READ_D PTRACE_PEEKDATA
-diff -Nur musl-0.9.13/include/sys/resource.h musl-git/include/sys/resource.h
---- musl-0.9.13/include/sys/resource.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/include/sys/resource.h 2013-09-16 20:31:39.000000000 +0200
-@@ -59,6 +59,9 @@
- #define prlimit64 prlimit
- #endif
-
-+#define PRIO_MIN (-20)
-+#define PRIO_MAX 20
-+
- #define PRIO_PROCESS 0
- #define PRIO_PGRP 1
- #define PRIO_USER 2
-diff -Nur musl-0.9.13/include/sys/socket.h musl-git/include/sys/socket.h
---- musl-0.9.13/include/sys/socket.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/include/sys/socket.h 2013-09-16 20:31:39.000000000 +0200
-@@ -199,6 +199,7 @@
- #define SO_NOFCS 43
- #define SO_LOCK_FILTER 44
- #define SO_SELECT_ERR_QUEUE 45
-+#define SO_BUSY_POLL 46
-
- #ifndef SOL_SOCKET
- #define SOL_SOCKET 1
-diff -Nur musl-0.9.13/include/wait.h musl-git/include/wait.h
---- musl-0.9.13/include/wait.h 1970-01-01 01:00:00.000000000 +0100
-+++ musl-git/include/wait.h 2013-09-16 20:31:39.000000000 +0200
-@@ -0,0 +1,2 @@
-+#warning redirecting incorrect #include <wait.h> to <sys/wait.h>
-+#include <sys/wait.h>
-diff -Nur musl-0.9.13/src/aio/aio_readwrite.c musl-git/src/aio/aio_readwrite.c
---- musl-0.9.13/src/aio/aio_readwrite.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/aio/aio_readwrite.c 2013-09-16 20:31:39.000000000 +0200
-@@ -2,8 +2,8 @@
- #include <fcntl.h>
- #include <errno.h>
- #include <unistd.h>
--#include <limits.h>
- #include "pthread_impl.h"
-+#include "libc.h"
-
- static void dummy(void)
- {
-diff -Nur musl-0.9.13/src/aio/lio_listio.c musl-git/src/aio/lio_listio.c
---- musl-0.9.13/src/aio/lio_listio.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/aio/lio_listio.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,9 +1,9 @@
- #include <aio.h>
- #include <errno.h>
--#include <limits.h>
- #include <unistd.h>
- #include <string.h>
- #include "pthread_impl.h"
-+#include "libc.h"
-
- struct lio_state {
- struct sigevent *sev;
-diff -Nur musl-0.9.13/src/conf/fpathconf.c musl-git/src/conf/fpathconf.c
---- musl-0.9.13/src/conf/fpathconf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/conf/fpathconf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -19,11 +19,11 @@
- [_PC_PRIO_IO] = -1,
- [_PC_SOCK_MAXBUF] = -1,
- [_PC_FILESIZEBITS] = FILESIZEBITS,
-- [_PC_REC_INCR_XFER_SIZE] = PAGE_SIZE,
-- [_PC_REC_MAX_XFER_SIZE] = PAGE_SIZE,
-- [_PC_REC_MIN_XFER_SIZE] = PAGE_SIZE,
-- [_PC_REC_XFER_ALIGN] = PAGE_SIZE,
-- [_PC_ALLOC_SIZE_MIN] = PAGE_SIZE,
-+ [_PC_REC_INCR_XFER_SIZE] = 4096,
-+ [_PC_REC_MAX_XFER_SIZE] = 4096,
-+ [_PC_REC_MIN_XFER_SIZE] = 4096,
-+ [_PC_REC_XFER_ALIGN] = 4096,
-+ [_PC_ALLOC_SIZE_MIN] = 4096,
- [_PC_SYMLINK_MAX] = SYMLINK_MAX,
- [_PC_2_SYMLINKS] = 1
- };
-diff -Nur musl-0.9.13/src/conf/sysconf.c musl-git/src/conf/sysconf.c
---- musl-0.9.13/src/conf/sysconf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/conf/sysconf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -3,6 +3,7 @@
- #include <errno.h>
- #include <sys/resource.h>
- #include "syscall.h"
-+#include "libc.h"
-
- #define VER (-2)
- #define OFLOW (-3)
-@@ -40,9 +41,9 @@
- [_SC_AIO_PRIO_DELTA_MAX] = 0, /* ?? */
- [_SC_DELAYTIMER_MAX] = _POSIX_DELAYTIMER_MAX,
- [_SC_MQ_OPEN_MAX] = -1,
-- [_SC_MQ_PRIO_MAX] = MQ_PRIO_MAX,
-+ [_SC_MQ_PRIO_MAX] = OFLOW,
- [_SC_VERSION] = VER,
-- [_SC_PAGE_SIZE] = PAGE_SIZE,
-+ [_SC_PAGE_SIZE] = OFLOW,
- [_SC_RTSIG_MAX] = 63, /* ?? */
- [_SC_SEM_NSEMS_MAX] = SEM_NSEMS_MAX,
- [_SC_SEM_VALUE_MAX] = OFLOW,
-@@ -221,6 +222,9 @@
- } else if (values[name] == OFLOW) {
- if (name == _SC_ARG_MAX) return ARG_MAX;
- if (name == _SC_SEM_VALUE_MAX) return SEM_VALUE_MAX;
-+ if (name == _SC_MQ_PRIO_MAX) return MQ_PRIO_MAX;
-+ /* name == _SC_PAGE_SIZE */
-+ return PAGE_SIZE;
- } else if (values[name] == CPUCNT) {
- unsigned char set[128] = {1};
- int i, cnt;
-diff -Nur musl-0.9.13/src/env/__libc_start_main.c musl-git/src/env/__libc_start_main.c
---- musl-0.9.13/src/env/__libc_start_main.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/env/__libc_start_main.c 2013-09-16 20:31:39.000000000 +0200
-@@ -26,6 +26,7 @@
- for (i=0; auxv[i]; i+=2) if (auxv[i]<AUX_CNT) aux[auxv[i]] = auxv[i+1];
- __hwcap = aux[AT_HWCAP];
- __sysinfo = aux[AT_SYSINFO];
-+ libc.page_size = aux[AT_PAGESZ];
-
- if (pn) {
- __progname = __progname_full = pn;
-diff -Nur musl-0.9.13/src/internal/libc.h musl-git/src/internal/libc.h
---- musl-0.9.13/src/internal/libc.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/internal/libc.h 2013-09-16 20:31:39.000000000 +0200
-@@ -3,6 +3,7 @@
-
- #include <stdlib.h>
- #include <stdio.h>
-+#include <limits.h>
-
- struct __libc {
- void *main_thread;
-@@ -14,10 +15,15 @@
- FILE *ofl_head;
- int ofl_lock[2];
- size_t tls_size;
-+ size_t page_size;
- };
-
- extern size_t __hwcap;
-
-+#ifndef PAGE_SIZE
-+#define PAGE_SIZE libc.page_size
-+#endif
-+
- #if !defined(__PIC__) || (100*__GNUC__+__GNUC_MINOR__ >= 303 && !defined(__PCC__))
-
- #ifdef __PIC__
-diff -Nur musl-0.9.13/src/internal/libm.h musl-git/src/internal/libm.h
---- musl-0.9.13/src/internal/libm.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/internal/libm.h 2013-09-16 20:31:39.000000000 +0200
-@@ -17,117 +17,115 @@
- #include <float.h>
- #include <math.h>
- #include <complex.h>
-+#include <endian.h>
-
--#include "longdbl.h"
--
--#include "libc.h"
--
--union fshape {
-- float value;
-- uint32_t bits;
-+#if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-+#elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384 && __BYTE_ORDER == __LITTLE_ENDIAN
-+union ldshape {
-+ long double f;
-+ struct {
-+ uint64_t m;
-+ uint16_t se;
-+ } i;
- };
--
--union dshape {
-- double value;
-- uint64_t bits;
-+#elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384 && __BYTE_ORDER == __LITTLE_ENDIAN
-+union ldshape {
-+ long double f;
-+ struct {
-+ uint64_t lo;
-+ uint32_t mid;
-+ uint16_t top;
-+ uint16_t se;
-+ } i;
-+ struct {
-+ uint64_t lo;
-+ uint64_t hi;
-+ } i2;
- };
-+#else
-+#error Unsupported long double representation
-+#endif
-
--#define FORCE_EVAL(x) do { \
-- if (sizeof(x) == sizeof(float)) { \
-- volatile float __x; \
-- __x = (x); \
-- } else if (sizeof(x) == sizeof(double)) { \
-- volatile double __x; \
-- __x = (x); \
-- } else { \
-- volatile long double __x; \
-- __x = (x); \
-- } \
-+#define FORCE_EVAL(x) do { \
-+ if (sizeof(x) == sizeof(float)) { \
-+ volatile float __x; \
-+ __x = (x); \
-+ } else if (sizeof(x) == sizeof(double)) { \
-+ volatile double __x; \
-+ __x = (x); \
-+ } else { \
-+ volatile long double __x; \
-+ __x = (x); \
-+ } \
- } while(0)
-
- /* Get two 32 bit ints from a double. */
--#define EXTRACT_WORDS(hi,lo,d) \
--do { \
-- union dshape __u; \
-- __u.value = (d); \
-- (hi) = __u.bits >> 32; \
-- (lo) = (uint32_t)__u.bits; \
--} while (0)
--
--/* Get a 64 bit int from a double. */
--#define EXTRACT_WORD64(i,d) \
--do { \
-- union dshape __u; \
-- __u.value = (d); \
-- (i) = __u.bits; \
-+#define EXTRACT_WORDS(hi,lo,d) \
-+do { \
-+ union {double f; uint64_t i;} __u; \
-+ __u.f = (d); \
-+ (hi) = __u.i >> 32; \
-+ (lo) = (uint32_t)__u.i; \
- } while (0)
-
- /* Get the more significant 32 bit int from a double. */
--#define GET_HIGH_WORD(i,d) \
--do { \
-- union dshape __u; \
-- __u.value = (d); \
-- (i) = __u.bits >> 32; \
-+#define GET_HIGH_WORD(hi,d) \
-+do { \
-+ union {double f; uint64_t i;} __u; \
-+ __u.f = (d); \
-+ (hi) = __u.i >> 32; \
- } while (0)
-
- /* Get the less significant 32 bit int from a double. */
--#define GET_LOW_WORD(i,d) \
--do { \
-- union dshape __u; \
-- __u.value = (d); \
-- (i) = (uint32_t)__u.bits; \
-+#define GET_LOW_WORD(lo,d) \
-+do { \
-+ union {double f; uint64_t i;} __u; \
-+ __u.f = (d); \
-+ (lo) = (uint32_t)__u.i; \
- } while (0)
-
- /* Set a double from two 32 bit ints. */
--#define INSERT_WORDS(d,hi,lo) \
--do { \
-- union dshape __u; \
-- __u.bits = ((uint64_t)(hi) << 32) | (uint32_t)(lo); \
-- (d) = __u.value; \
--} while (0)
--
--/* Set a double from a 64 bit int. */
--#define INSERT_WORD64(d,i) \
--do { \
-- union dshape __u; \
-- __u.bits = (i); \
-- (d) = __u.value; \
-+#define INSERT_WORDS(d,hi,lo) \
-+do { \
-+ union {double f; uint64_t i;} __u; \
-+ __u.i = ((uint64_t)(hi)<<32) | (uint32_t)(lo); \
-+ (d) = __u.f; \
- } while (0)
-
- /* Set the more significant 32 bits of a double from an int. */
--#define SET_HIGH_WORD(d,hi) \
--do { \
-- union dshape __u; \
-- __u.value = (d); \
-- __u.bits &= 0xffffffff; \
-- __u.bits |= (uint64_t)(hi) << 32; \
-- (d) = __u.value; \
-+#define SET_HIGH_WORD(d,hi) \
-+do { \
-+ union {double f; uint64_t i;} __u; \
-+ __u.f = (d); \
-+ __u.i &= 0xffffffff; \
-+ __u.i |= (uint64_t)(hi) << 32; \
-+ (d) = __u.f; \
- } while (0)
-
- /* Set the less significant 32 bits of a double from an int. */
--#define SET_LOW_WORD(d,lo) \
--do { \
-- union dshape __u; \
-- __u.value = (d); \
-- __u.bits &= 0xffffffff00000000ull; \
-- __u.bits |= (uint32_t)(lo); \
-- (d) = __u.value; \
-+#define SET_LOW_WORD(d,lo) \
-+do { \
-+ union {double f; uint64_t i;} __u; \
-+ __u.f = (d); \
-+ __u.i &= 0xffffffff00000000ull; \
-+ __u.i |= (uint32_t)(lo); \
-+ (d) = __u.f; \
- } while (0)
-
- /* Get a 32 bit int from a float. */
--#define GET_FLOAT_WORD(i,d) \
--do { \
-- union fshape __u; \
-- __u.value = (d); \
-- (i) = __u.bits; \
-+#define GET_FLOAT_WORD(w,d) \
-+do { \
-+ union {float f; uint32_t i;} __u; \
-+ __u.f = (d); \
-+ (w) = __u.i; \
- } while (0)
-
- /* Set a float from a 32 bit int. */
--#define SET_FLOAT_WORD(d,i) \
--do { \
-- union fshape __u; \
-- __u.bits = (i); \
-- (d) = __u.value; \
-+#define SET_FLOAT_WORD(d,w) \
-+do { \
-+ union {float f; uint32_t i;} __u; \
-+ __u.i = (w); \
-+ (d) = __u.f; \
- } while (0)
-
- /* fdlibm kernel functions */
-@@ -157,15 +155,4 @@
- long double __polevll(long double, const long double *, int);
- long double __p1evll(long double, const long double *, int);
-
--#if 0
--/* Attempt to get strict C99 semantics for assignment with non-C99 compilers. */
--#define STRICT_ASSIGN(type, lval, rval) do { \
-- volatile type __v = (rval); \
-- (lval) = __v; \
--} while (0)
--#else
--/* Should work with -fexcess-precision=standard (>=gcc-4.5) or -ffloat-store */
--#define STRICT_ASSIGN(type, lval, rval) ((lval) = (type)(rval))
--#endif
--
- #endif
-diff -Nur musl-0.9.13/src/internal/longdbl.h musl-git/src/internal/longdbl.h
---- musl-0.9.13/src/internal/longdbl.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/internal/longdbl.h 1970-01-01 01:00:00.000000000 +0100
-@@ -1,137 +0,0 @@
--#ifndef _LDHACK_H
--#define _LDHACK_H
--
--#include <float.h>
--#include <stdint.h>
--
--#if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
--#elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
--union ldshape {
-- long double value;
-- struct {
-- uint64_t m;
-- uint16_t exp:15;
-- uint16_t sign:1;
-- uint16_t pad;
-- } bits;
--};
--#elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
--union ldshape {
-- long double value;
-- struct {
-- uint64_t mlo;
-- uint64_t mhi:48;
-- uint16_t exp:15;
-- uint16_t sign:1;
-- } bits;
--};
--#else
--#error Unsupported long double representation
--#endif
--
--
--// FIXME: hacks to make freebsd+openbsd long double code happy
--
--// union and macros for freebsd
--
--#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
--
--union IEEEl2bits {
-- long double e;
-- struct {
-- uint32_t manl:32;
-- uint32_t manh:32;
-- uint32_t exp:15;
-- uint32_t sign:1;
-- uint32_t pad:16;
-- } bits;
-- struct {
-- uint64_t man:64;
-- uint32_t expsign:16;
-- uint32_t pad:16;
-- } xbits;
--};
--
--#define LDBL_MANL_SIZE 32
--#define LDBL_MANH_SIZE 32
--#define LDBL_NBIT (1ull << LDBL_MANH_SIZE-1)
--#undef LDBL_IMPLICIT_NBIT
--#define mask_nbit_l(u) ((u).bits.manh &= ~LDBL_NBIT)
--
--#elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
--/*
--// ld128 float.h
--//#define LDBL_MAX 1.189731495357231765085759326628007016E+4932L
--#define LDBL_MAX 0x1.ffffffffffffffffffffffffffffp+16383
--#define LDBL_MAX_EXP 16384
--#define LDBL_HAS_INFINITY 1
--//#define LDBL_MIN 3.362103143112093506262677817321752603E-4932L
--#define LDBL_MIN 0x1p-16382
--#define LDBL_HAS_QUIET_NAN 1
--#define LDBL_HAS_DENORM 1
--//#define LDBL_EPSILON 1.925929944387235853055977942584927319E-34L
--#define LDBL_EPSILON 0x1p-112
--#define LDBL_MANT_DIG 113
--#define LDBL_MIN_EXP (-16381)
--#define LDBL_MAX_10_EXP 4932
--#define LDBL_DENORM_MIN 0x0.0000000000000000000000000001p-16381
--#define LDBL_MIN_10_EXP (-4931)
--#define LDBL_DIG 33
--*/
--
--union IEEEl2bits {
-- long double e;
-- struct {
-- uint64_t manl:64;
-- uint64_t manh:48;
-- uint32_t exp:15;
-- uint32_t sign:1;
-- } bits;
-- struct {
-- uint64_t unused0:64;
-- uint64_t unused1:48;
-- uint32_t expsign:16;
-- } xbits;
--};
--
--#define LDBL_MANL_SIZE 64
--#define LDBL_MANH_SIZE 48
--#define LDBL_NBIT (1ull << LDBL_MANH_SIZE)
--#define LDBL_IMPLICIT_NBIT 1
--#define mask_nbit_l(u)
--
--#endif
--
--
--// macros for openbsd
--
--#define GET_LDOUBLE_WORDS(se,mh,ml, f) do{ \
-- union IEEEl2bits u; \
-- u.e = (f); \
-- (se) = u.xbits.expsign; \
-- (mh) = u.bits.manh; \
-- (ml) = u.bits.manl; \
--}while(0)
--
--#define SET_LDOUBLE_WORDS(f, se,mh,ml) do{ \
-- union IEEEl2bits u; \
-- u.xbits.expsign = (se); \
-- u.bits.manh = (mh); \
-- u.bits.manl = (ml); \
-- (f) = u.e; \
--}while(0)
--
--#define GET_LDOUBLE_EXP(se, f) do{ \
-- union IEEEl2bits u; \
-- u.e = (f); \
-- (se) = u.xbits.expsign; \
--}while(0)
--
--#define SET_LDOUBLE_EXP(f, se) do{ \
-- union IEEEl2bits u; \
-- u.e = (f); \
-- u.xbits.expsign = (se); \
-- (f) = u.e; \
--}while(0)
--
--#endif
-diff -Nur musl-0.9.13/src/ldso/dynlink.c musl-git/src/ldso/dynlink.c
---- musl-0.9.13/src/ldso/dynlink.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/ldso/dynlink.c 2013-09-16 20:31:39.000000000 +0200
-@@ -614,6 +614,8 @@
- sys_path = "";
- }
- fclose(f);
-+ } else if (errno != ENOENT) {
-+ sys_path = "";
- }
- }
- if (!sys_path) sys_path = "/lib:/usr/local/lib:/usr/lib";
-@@ -978,6 +980,7 @@
- env_preload = 0;
- libc.secure = 1;
- }
-+ libc.page_size = aux[AT_PAGESZ];
-
- /* If the dynamic linker was invoked as a program itself, AT_BASE
- * will not be set. In that case, we assume the base address is
-diff -Nur musl-0.9.13/src/legacy/getpagesize.c musl-git/src/legacy/getpagesize.c
---- musl-0.9.13/src/legacy/getpagesize.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/legacy/getpagesize.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,5 +1,5 @@
- #include <unistd.h>
--#include <limits.h>
-+#include "libc.h"
-
- int getpagesize(void)
- {
-diff -Nur musl-0.9.13/src/legacy/valloc.c musl-git/src/legacy/valloc.c
---- musl-0.9.13/src/legacy/valloc.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/legacy/valloc.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,6 +1,6 @@
- #define _BSD_SOURCE
- #include <stdlib.h>
--#include <limits.h>
-+#include "libc.h"
-
- void *valloc(size_t size)
- {
-diff -Nur musl-0.9.13/src/math/__cosl.c musl-git/src/math/__cosl.c
---- musl-0.9.13/src/math/__cosl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__cosl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,4 +1,5 @@
- /* origin: FreeBSD /usr/src/lib/msun/ld80/k_cosl.c */
-+/* origin: FreeBSD /usr/src/lib/msun/ld128/k_cosl.c */
- /*
- * ====================================================
- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-@@ -14,7 +15,8 @@
-
- #include "libm.h"
-
--#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
-+#if (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
-+#if LDBL_MANT_DIG == 64
- /*
- * ld80 version of __cos.c. See __cos.c for most comments.
- */
-@@ -43,7 +45,6 @@
- */
- static const long double
- C1 = 0.0416666666666666666136L; /* 0xaaaaaaaaaaaaaa9b.0p-68 */
--
- static const double
- C2 = -0.0013888888888888874, /* -0x16c16c16c16c10.0p-62 */
- C3 = 0.000024801587301571716, /* 0x1a01a01a018e22.0p-68 */
-@@ -51,13 +52,43 @@
- C5 = 0.0000000020876754400407278, /* 0x11eed8caaeccf1.0p-81 */
- C6 = -1.1470297442401303e-11, /* -0x19393412bd1529.0p-89 */
- C7 = 4.7383039476436467e-14; /* 0x1aac9d9af5c43e.0p-97 */
-+#define POLY(z) (z*(C1+z*(C2+z*(C3+z*(C4+z*(C5+z*(C6+z*C7)))))))
-+#elif LDBL_MANT_DIG == 113
-+/*
-+ * ld128 version of __cos.c. See __cos.c for most comments.
-+ */
-+/*
-+ * Domain [-0.7854, 0.7854], range ~[-1.80e-37, 1.79e-37]:
-+ * |cos(x) - c(x))| < 2**-122.0
-+ *
-+ * 113-bit precision requires more care than 64-bit precision, since
-+ * simple methods give a minimax polynomial with coefficient for x^2
-+ * that is 1 ulp below 0.5, but we want it to be precisely 0.5. See
-+ * above for more details.
-+ */
-+static const long double
-+C1 = 0.04166666666666666666666666666666658424671L,
-+C2 = -0.001388888888888888888888888888863490893732L,
-+C3 = 0.00002480158730158730158730158600795304914210L,
-+C4 = -0.2755731922398589065255474947078934284324e-6L,
-+C5 = 0.2087675698786809897659225313136400793948e-8L,
-+C6 = -0.1147074559772972315817149986812031204775e-10L,
-+C7 = 0.4779477332386808976875457937252120293400e-13L;
-+static const double
-+C8 = -0.1561920696721507929516718307820958119868e-15,
-+C9 = 0.4110317413744594971475941557607804508039e-18,
-+C10 = -0.8896592467191938803288521958313920156409e-21,
-+C11 = 0.1601061435794535138244346256065192782581e-23;
-+#define POLY(z) (z*(C1+z*(C2+z*(C3+z*(C4+z*(C5+z*(C6+z*(C7+ \
-+ z*(C8+z*(C9+z*(C10+z*C11)))))))))))
-+#endif
-
- long double __cosl(long double x, long double y)
- {
- long double hz,z,r,w;
-
- z = x*x;
-- r = z*(C1+z*(C2+z*(C3+z*(C4+z*(C5+z*(C6+z*C7))))));
-+ r = POLY(z);
- hz = 0.5*z;
- w = 1.0-hz;
- return w + (((1.0-w)-hz) + (z*r-x*y));
-diff -Nur musl-0.9.13/src/math/__fpclassify.c musl-git/src/math/__fpclassify.c
---- musl-0.9.13/src/math/__fpclassify.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__fpclassify.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,10 +1,11 @@
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- int __fpclassify(double x)
- {
-- union dshape u = { x };
-- int e = u.bits>>52 & 0x7ff;
-- if (!e) return u.bits<<1 ? FP_SUBNORMAL : FP_ZERO;
-- if (e==0x7ff) return u.bits<<12 ? FP_NAN : FP_INFINITE;
-+ union {double f; uint64_t i;} u = {x};
-+ int e = u.i>>52 & 0x7ff;
-+ if (!e) return u.i<<1 ? FP_SUBNORMAL : FP_ZERO;
-+ if (e==0x7ff) return u.i<<12 ? FP_NAN : FP_INFINITE;
- return FP_NORMAL;
- }
-diff -Nur musl-0.9.13/src/math/__fpclassifyf.c musl-git/src/math/__fpclassifyf.c
---- musl-0.9.13/src/math/__fpclassifyf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__fpclassifyf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,10 +1,11 @@
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- int __fpclassifyf(float x)
- {
-- union fshape u = { x };
-- int e = u.bits>>23 & 0xff;
-- if (!e) return u.bits<<1 ? FP_SUBNORMAL : FP_ZERO;
-- if (e==0xff) return u.bits<<9 ? FP_NAN : FP_INFINITE;
-+ union {float f; uint32_t i;} u = {x};
-+ int e = u.i>>23 & 0xff;
-+ if (!e) return u.i<<1 ? FP_SUBNORMAL : FP_ZERO;
-+ if (e==0xff) return u.i<<9 ? FP_NAN : FP_INFINITE;
- return FP_NORMAL;
- }
-diff -Nur musl-0.9.13/src/math/__fpclassifyl.c musl-git/src/math/__fpclassifyl.c
---- musl-0.9.13/src/math/__fpclassifyl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__fpclassifyl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -5,26 +5,28 @@
- #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
- int __fpclassifyl(long double x)
- {
-- union ldshape u = { x };
-- int e = u.bits.exp;
-- if (!e) {
-- if (u.bits.m >> 63) return FP_NAN;
-- else if (u.bits.m) return FP_SUBNORMAL;
-- else return FP_ZERO;
-- }
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-+ int msb = u.i.m>>63;
-+ if (!e && !msb)
-+ return u.i.m ? FP_SUBNORMAL : FP_ZERO;
-+ if (!msb)
-+ return FP_NAN;
- if (e == 0x7fff)
-- return u.bits.m & (uint64_t)-1>>1 ? FP_NAN : FP_INFINITE;
-- return u.bits.m & (uint64_t)1<<63 ? FP_NORMAL : FP_NAN;
-+ return u.i.m << 1 ? FP_NAN : FP_INFINITE;
-+ return FP_NORMAL;
- }
- #elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
- int __fpclassifyl(long double x)
- {
-- union ldshape u = { x };
-- int e = u.bits.exp;
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
- if (!e)
-- return u.bits.mlo | u.bits.mhi ? FP_SUBNORMAL : FP_ZERO;
-- if (e == 0x7fff)
-- return u.bits.mlo | u.bits.mhi ? FP_NAN : FP_INFINITE;
-+ return u.i2.lo | u.i2.hi ? FP_SUBNORMAL : FP_ZERO;
-+ if (e == 0x7fff) {
-+ u.i.se = 0;
-+ return u.i2.lo | u.i2.hi ? FP_NAN : FP_INFINITE;
-+ }
- return FP_NORMAL;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/__invtrigl.c musl-git/src/math/__invtrigl.c
---- musl-0.9.13/src/math/__invtrigl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__invtrigl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,7 +1,7 @@
-+#include <float.h>
- #include "__invtrigl.h"
-
- #if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
--
- static const long double
- pS0 = 1.66666666666666666631e-01L,
- pS1 = -4.16313987993683104320e-01L,
-@@ -28,4 +28,36 @@
- q = 1.0+z*(qS1+z*(qS2+z*(qS3+z*(qS4+z*qS5))));
- return p/q;
- }
-+#elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
-+static const long double
-+pS0 = 1.66666666666666666666666666666700314e-01L,
-+pS1 = -7.32816946414566252574527475428622708e-01L,
-+pS2 = 1.34215708714992334609030036562143589e+00L,
-+pS3 = -1.32483151677116409805070261790752040e+00L,
-+pS4 = 7.61206183613632558824485341162121989e-01L,
-+pS5 = -2.56165783329023486777386833928147375e-01L,
-+pS6 = 4.80718586374448793411019434585413855e-02L,
-+pS7 = -4.42523267167024279410230886239774718e-03L,
-+pS8 = 1.44551535183911458253205638280410064e-04L,
-+pS9 = -2.10558957916600254061591040482706179e-07L,
-+qS1 = -4.84690167848739751544716485245697428e+00L,
-+qS2 = 9.96619113536172610135016921140206980e+00L,
-+qS3 = -1.13177895428973036660836798461641458e+01L,
-+qS4 = 7.74004374389488266169304117714658761e+00L,
-+qS5 = -3.25871986053534084709023539900339905e+00L,
-+qS6 = 8.27830318881232209752469022352928864e-01L,
-+qS7 = -1.18768052702942805423330715206348004e-01L,
-+qS8 = 8.32600764660522313269101537926539470e-03L,
-+qS9 = -1.99407384882605586705979504567947007e-04L;
-+
-+const long double pio2_hi = 1.57079632679489661923132169163975140L;
-+const long double pio2_lo = 4.33590506506189051239852201302167613e-35L;
-+
-+long double __invtrigl_R(long double z)
-+{
-+ long double p, q;
-+ p = z*(pS0+z*(pS1+z*(pS2+z*(pS3+z*(pS4+z*(pS5+z*(pS6+z*(pS7+z*(pS8+z*pS9)))))))));
-+ q = 1.0+z*(qS1+z*(qS2+z*(qS3+z*(qS4+z*(qS5+z*(pS6+z*(pS7+z*(pS8+z*pS9))))))));
-+ return p/q;
-+}
- #endif
-diff -Nur musl-0.9.13/src/math/__invtrigl.h musl-git/src/math/__invtrigl.h
---- musl-0.9.13/src/math/__invtrigl.h 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__invtrigl.h 2013-09-16 20:31:39.000000000 +0200
-@@ -1,10 +1,6 @@
--#include <float.h>
--
--#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
- /* shared by acosl, asinl and atan2l */
- #define pio2_hi __pio2_hi
- #define pio2_lo __pio2_lo
- extern const long double pio2_hi, pio2_lo;
-
- long double __invtrigl_R(long double z);
--#endif
-diff -Nur musl-0.9.13/src/math/__rem_pio2.c musl-git/src/math/__rem_pio2.c
---- musl-0.9.13/src/math/__rem_pio2.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__rem_pio2.c 2013-09-16 20:31:39.000000000 +0200
-@@ -112,7 +112,7 @@
- uint32_t high;
- medium:
- /* Use a specialized rint() to get fn. Assume round-to-nearest. */
-- STRICT_ASSIGN(double, fn, x*invpio2 + 0x1.8p52);
-+ fn = x*invpio2 + 0x1.8p52;
- fn = fn - 0x1.8p52;
- // FIXME
- #ifdef HAVE_EFFICIENT_IRINT
-diff -Nur musl-0.9.13/src/math/__rem_pio2_large.c musl-git/src/math/__rem_pio2_large.c
---- musl-0.9.13/src/math/__rem_pio2_large.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__rem_pio2_large.c 2013-09-16 20:31:39.000000000 +0200
-@@ -415,7 +415,8 @@
- fw = 0.0;
- for (i=jz; i>=0; i--)
- fw += fq[i];
-- STRICT_ASSIGN(double,fw,fw);
-+ // TODO: drop excess precision here once double_t is used
-+ fw = (double)fw;
- y[0] = ih==0 ? fw : -fw;
- fw = fq[0]-fw;
- for (i=1; i<=jz; i++)
-diff -Nur musl-0.9.13/src/math/__rem_pio2f.c musl-git/src/math/__rem_pio2f.c
---- musl-0.9.13/src/math/__rem_pio2f.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__rem_pio2f.c 2013-09-16 20:31:39.000000000 +0200
-@@ -44,7 +44,7 @@
- /* 25+53 bit pi is good enough for medium size */
- if (ix < 0x4dc90fdb) { /* |x| ~< 2^28*(pi/2), medium size */
- /* Use a specialized rint() to get fn. Assume round-to-nearest. */
-- STRICT_ASSIGN(double, fn, x*invpio2 + 0x1.8p52);
-+ fn = x*invpio2 + 0x1.8p52;
- fn = fn - 0x1.8p52;
- // FIXME
- #ifdef HAVE_EFFICIENT_IRINT
-diff -Nur musl-0.9.13/src/math/__rem_pio2l.c musl-git/src/math/__rem_pio2l.c
---- musl-0.9.13/src/math/__rem_pio2l.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__rem_pio2l.c 2013-09-16 20:31:39.000000000 +0200
-@@ -13,15 +13,22 @@
- * Optimized by Bruce D. Evans.
- */
- #include "libm.h"
--#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
--/* ld80 version of __rem_pio2(x,y)
-+#if (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
-+/* ld80 and ld128 version of __rem_pio2(x,y)
- *
- * return the remainder of x rem pi/2 in y[0]+y[1]
- * use __rem_pio2_large() for large x
- */
-
--#define BIAS (LDBL_MAX_EXP - 1)
--
-+#if LDBL_MANT_DIG == 64
-+/* u ~< 0x1p25*pi/2 */
-+#define SMALL(u) (((u.i.se & 0x7fffU)<<16 | u.i.m>>48) < ((0x3fff + 25)<<16 | 0x921f>>1 | 0x8000))
-+#define TOINT 0x1.8p63
-+#define QUOBITS(x) ((uint32_t)(int32_t)x & 0x7fffffff)
-+#define ROUND1 22
-+#define ROUND2 61
-+#define NX 3
-+#define NY 2
- /*
- * invpio2: 64 bits of 2/pi
- * pio2_1: first 39 bits of pi/2
-@@ -32,60 +39,61 @@
- * pio2_3t: pi/2 - (pio2_1+pio2_2+pio2_3)
- */
- static const double
--two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */
- pio2_1 = 1.57079632679597125389e+00, /* 0x3FF921FB, 0x54444000 */
- pio2_2 = -1.07463465549783099519e-12, /* -0x12e7b967674000.0p-92 */
- pio2_3 = 6.36831716351370313614e-25; /* 0x18a2e037074000.0p-133 */
--
- static const long double
- invpio2 = 6.36619772367581343076e-01L, /* 0xa2f9836e4e44152a.0p-64 */
- pio2_1t = -1.07463465549719416346e-12L, /* -0x973dcb3b399d747f.0p-103 */
- pio2_2t = 6.36831716351095013979e-25L, /* 0xc51701b839a25205.0p-144 */
- pio2_3t = -2.75299651904407171810e-37L; /* -0xbb5bf6c7ddd660ce.0p-185 */
-+#elif LDBL_MANT_DIG == 113
-+/* u ~< 0x1p45*pi/2 */
-+#define SMALL(u) (((u.i.se & 0x7fffU)<<16 | u.i.top) < ((0x3fff + 45)<<16 | 0x921f))
-+#define TOINT 0x1.8p112
-+#define QUOBITS(x) ((uint32_t)(int64_t)x & 0x7fffffff)
-+#define ROUND1 51
-+#define ROUND2 119
-+#define NX 5
-+#define NY 3
-+static const long double
-+invpio2 = 6.3661977236758134307553505349005747e-01L, /* 0x145f306dc9c882a53f84eafa3ea6a.0p-113 */
-+pio2_1 = 1.5707963267948966192292994253909555e+00L, /* 0x1921fb54442d18469800000000000.0p-112 */
-+pio2_1t = 2.0222662487959507323996846200947577e-21L, /* 0x13198a2e03707344a4093822299f3.0p-181 */
-+pio2_2 = 2.0222662487959507323994779168837751e-21L, /* 0x13198a2e03707344a400000000000.0p-181 */
-+pio2_2t = 2.0670321098263988236496903051604844e-43L, /* 0x127044533e63a0105df531d89cd91.0p-254 */
-+pio2_3 = 2.0670321098263988236499468110329591e-43L, /* 0x127044533e63a0105e00000000000.0p-254 */
-+pio2_3t = -2.5650587247459238361625433492959285e-65L; /* -0x159c4ec64ddaeb5f78671cbfb2210.0p-327 */
-+#endif
-
- int __rem_pio2l(long double x, long double *y)
- {
-- union IEEEl2bits u,u1;
-+ union ldshape u,uz;
- long double z,w,t,r,fn;
-- double tx[3],ty[2];
-- int e0,ex,i,j,nx,n;
-- int16_t expsign;
--
-- u.e = x;
-- expsign = u.xbits.expsign;
-- ex = expsign & 0x7fff;
-- if (ex < BIAS + 25 || (ex == BIAS + 25 && u.bits.manh < 0xc90fdaa2)) {
-- union IEEEl2bits u2;
-- int ex1;
-+ double tx[NX],ty[NY];
-+ int ex,ey,n,i;
-
-- /* |x| ~< 2^25*(pi/2), medium size */
-- /* Use a specialized rint() to get fn. Assume round-to-nearest. */
-- fn = x*invpio2 + 0x1.8p63;
-- fn = fn - 0x1.8p63;
--// FIXME
--//#ifdef HAVE_EFFICIENT_IRINT
--// n = irint(fn);
--//#else
-- n = fn;
--//#endif
-+ u.f = x;
-+ ex = u.i.se & 0x7fff;
-+ if (SMALL(u)) {
-+ /* rint(x/(pi/2)), Assume round-to-nearest. */
-+ fn = x*invpio2 + TOINT - TOINT;
-+ n = QUOBITS(fn);
- r = x-fn*pio2_1;
-- w = fn*pio2_1t; /* 1st round good to 102 bit */
-- j = ex;
-+ w = fn*pio2_1t; /* 1st round good to 102/180 bits (ld80/ld128) */
- y[0] = r-w;
-- u2.e = y[0];
-- ex1 = u2.xbits.expsign & 0x7fff;
-- i = j-ex1;
-- if (i > 22) { /* 2nd iteration needed, good to 141 */
-+ u.f = y[0];
-+ ey = u.i.se & 0x7fff;
-+ if (ex - ey > ROUND1) { /* 2nd iteration needed, good to 141/248 (ld80/ld128) */
- t = r;
- w = fn*pio2_2;
- r = t-w;
- w = fn*pio2_2t-((t-r)-w);
- y[0] = r-w;
-- u2.e = y[0];
-- ex1 = u2.xbits.expsign & 0x7fff;
-- i = j-ex1;
-- if (i > 61) { /* 3rd iteration need, 180 bits acc */
-- t = r; /* will cover all possible cases */
-+ u.f = y[0];
-+ ey = u.i.se & 0x7fff;
-+ if (ex - ey > ROUND2) { /* 3rd iteration, good to 180/316 bits */
-+ t = r; /* will cover all possible cases (not verified for ld128) */
- w = fn*pio2_3;
- r = t-w;
- w = fn*pio2_3t-((t-r)-w);
-@@ -102,23 +110,26 @@
- y[0] = y[1] = x - x;
- return 0;
- }
-- /* set z = scalbn(|x|,ilogb(x)-23) */
-- u1.e = x;
-- e0 = ex - BIAS - 23; /* e0 = ilogb(|x|)-23; */
-- u1.xbits.expsign = ex - e0;
-- z = u1.e;
-- for (i=0; i<2; i++) {
-+ /* set z = scalbn(|x|,-ilogb(x)+23) */
-+ uz.f = x;
-+ uz.i.se = 0x3fff + 23;
-+ z = uz.f;
-+ for (i=0; i < NX - 1; i++) {
- tx[i] = (double)(int32_t)z;
-- z = (z-tx[i])*two24;
-+ z = (z-tx[i])*0x1p24;
- }
-- tx[2] = z;
-- nx = 3;
-- while (tx[nx-1] == 0.0)
-- nx--; /* skip zero term */
-- n = __rem_pio2_large(tx,ty,e0,nx,2);
-- r = (long double)ty[0] + ty[1];
-- w = ty[1] - (r - ty[0]);
-- if (expsign < 0) {
-+ tx[i] = z;
-+ while (tx[i] == 0)
-+ i--;
-+ n = __rem_pio2_large(tx, ty, ex-0x3fff-23, i+1, NY);
-+ w = ty[1];
-+ if (NY == 3)
-+ w += ty[2];
-+ r = ty[0] + w;
-+ /* TODO: for ld128 this does not follow the recommendation of the
-+ comments of __rem_pio2_large which seem wrong if |ty[0]| > |ty[1]+ty[2]| */
-+ w -= r - ty[0];
-+ if (u.i.se >> 15) {
- y[0] = -r;
- y[1] = -w;
- return -n;
-diff -Nur musl-0.9.13/src/math/__signbitl.c musl-git/src/math/__signbitl.c
---- musl-0.9.13/src/math/__signbitl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__signbitl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,11 +1,9 @@
- #include "libm.h"
-
--// FIXME: should be a macro
- #if (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- int __signbitl(long double x)
- {
- union ldshape u = {x};
--
-- return u.bits.sign;
-+ return u.i.se >> 15;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/__sinl.c musl-git/src/math/__sinl.c
---- musl-0.9.13/src/math/__sinl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__sinl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,4 +1,5 @@
- /* origin: FreeBSD /usr/src/lib/msun/ld80/k_sinl.c */
-+/* origin: FreeBSD /usr/src/lib/msun/ld128/k_sinl.c */
- /*
- * ====================================================
- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-@@ -13,7 +14,8 @@
-
- #include "libm.h"
-
--#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
-+#if (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
-+#if LDBL_MANT_DIG == 64
- /*
- * ld80 version of __sin.c. See __sin.c for most comments.
- */
-@@ -23,10 +25,8 @@
- *
- * See __cosl.c for more details about the polynomial.
- */
--
- static const long double
- S1 = -0.166666666666666666671L; /* -0xaaaaaaaaaaaaaaab.0p-66 */
--
- static const double
- S2 = 0.0083333333333333332, /* 0x11111111111111.0p-59 */
- S3 = -0.00019841269841269427, /* -0x1a01a01a019f81.0p-65 */
-@@ -35,6 +35,34 @@
- S6 = 1.6059006598854211e-10, /* 0x161242b90243b5.0p-85 */
- S7 = -7.6429779983024564e-13, /* -0x1ae42ebd1b2e00.0p-93 */
- S8 = 2.6174587166648325e-15; /* 0x179372ea0b3f64.0p-101 */
-+#define POLY(z) (S2+z*(S3+z*(S4+z*(S5+z*(S6+z*(S7+z*S8))))))
-+#elif LDBL_MANT_DIG == 113
-+/*
-+ * ld128 version of __sin.c. See __sin.c for most comments.
-+ */
-+/*
-+ * Domain [-0.7854, 0.7854], range ~[-1.53e-37, 1.659e-37]
-+ * |sin(x)/x - s(x)| < 2**-122.1
-+ *
-+ * See __cosl.c for more details about the polynomial.
-+ */
-+static const long double
-+S1 = -0.16666666666666666666666666666666666606732416116558L,
-+S2 = 0.0083333333333333333333333333333331135404851288270047L,
-+S3 = -0.00019841269841269841269841269839935785325638310428717L,
-+S4 = 0.27557319223985890652557316053039946268333231205686e-5L,
-+S5 = -0.25052108385441718775048214826384312253862930064745e-7L,
-+S6 = 0.16059043836821614596571832194524392581082444805729e-9L,
-+S7 = -0.76471637318198151807063387954939213287488216303768e-12L,
-+S8 = 0.28114572543451292625024967174638477283187397621303e-14L;
-+static const double
-+S9 = -0.82206352458348947812512122163446202498005154296863e-17,
-+S10 = 0.19572940011906109418080609928334380560135358385256e-19,
-+S11 = -0.38680813379701966970673724299207480965452616911420e-22,
-+S12 = 0.64038150078671872796678569586315881020659912139412e-25;
-+#define POLY(z) (S2+z*(S3+z*(S4+z*(S5+z*(S6+z*(S7+z*(S8+ \
-+ z*(S9+z*(S10+z*(S11+z*S12))))))))))
-+#endif
-
- long double __sinl(long double x, long double y, int iy)
- {
-@@ -42,7 +70,7 @@
-
- z = x*x;
- v = z*x;
-- r = S2+z*(S3+z*(S4+z*(S5+z*(S6+z*(S7+z*S8)))));
-+ r = POLY(z);
- if (iy == 0)
- return x+v*(S1+z*r);
- return x-((z*(0.5*y-v*r)-y)-v*S1);
-diff -Nur musl-0.9.13/src/math/__tanl.c musl-git/src/math/__tanl.c
---- musl-0.9.13/src/math/__tanl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/__tanl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,4 +1,5 @@
- /* origin: FreeBSD /usr/src/lib/msun/ld80/k_tanl.c */
-+/* origin: FreeBSD /usr/src/lib/msun/ld128/k_tanl.c */
- /*
- * ====================================================
- * Copyright 2004 Sun Microsystems, Inc. All Rights Reserved.
-@@ -12,7 +13,8 @@
-
- #include "libm.h"
-
--#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
-+#if (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
-+#if LDBL_MANT_DIG == 64
- /*
- * ld80 version of __tan.c. See __tan.c for most comments.
- */
-@@ -22,14 +24,12 @@
- *
- * See __cosl.c for more details about the polynomial.
- */
--
- static const long double
- T3 = 0.333333333333333333180L, /* 0xaaaaaaaaaaaaaaa5.0p-65 */
- T5 = 0.133333333333333372290L, /* 0x88888888888893c3.0p-66 */
- T7 = 0.0539682539682504975744L, /* 0xdd0dd0dd0dc13ba2.0p-68 */
- pio4 = 0.785398163397448309628L, /* 0xc90fdaa22168c235.0p-64 */
- pio4lo = -1.25413940316708300586e-20L; /* -0xece675d1fc8f8cbb.0p-130 */
--
- static const double
- T9 = 0.021869488536312216, /* 0x1664f4882cc1c2.0p-58 */
- T11 = 0.0088632355256619590, /* 0x1226e355c17612.0p-59 */
-@@ -44,6 +44,59 @@
- T29 = 0.0000078293456938132840, /* 0x106b59141a6cb3.0p-69 */
- T31 = -0.0000032609076735050182, /* -0x1b5abef3ba4b59.0p-71 */
- T33 = 0.0000023261313142559411; /* 0x13835436c0c87f.0p-71 */
-+#define RPOLY(w) (T5 + w * (T9 + w * (T13 + w * (T17 + w * (T21 + \
-+ w * (T25 + w * (T29 + w * T33)))))))
-+#define VPOLY(w) (T7 + w * (T11 + w * (T15 + w * (T19 + w * (T23 + \
-+ w * (T27 + w * T31))))))
-+#elif LDBL_MANT_DIG == 113
-+/*
-+ * ld128 version of __tan.c. See __tan.c for most comments.
-+ */
-+/*
-+ * Domain [-0.67434, 0.67434], range ~[-3.37e-36, 1.982e-37]
-+ * |tan(x)/x - t(x)| < 2**-117.8 (XXX should be ~1e-37)
-+ *
-+ * See __cosl.c for more details about the polynomial.
-+ */
-+static const long double
-+T3 = 0x1.5555555555555555555555555553p-2L,
-+T5 = 0x1.1111111111111111111111111eb5p-3L,
-+T7 = 0x1.ba1ba1ba1ba1ba1ba1ba1b694cd6p-5L,
-+T9 = 0x1.664f4882c10f9f32d6bbe09d8bcdp-6L,
-+T11 = 0x1.226e355e6c23c8f5b4f5762322eep-7L,
-+T13 = 0x1.d6d3d0e157ddfb5fed8e84e27b37p-9L,
-+T15 = 0x1.7da36452b75e2b5fce9ee7c2c92ep-10L,
-+T17 = 0x1.355824803674477dfcf726649efep-11L,
-+T19 = 0x1.f57d7734d1656e0aceb716f614c2p-13L,
-+T21 = 0x1.967e18afcb180ed942dfdc518d6cp-14L,
-+T23 = 0x1.497d8eea21e95bc7e2aa79b9f2cdp-15L,
-+T25 = 0x1.0b132d39f055c81be49eff7afd50p-16L,
-+T27 = 0x1.b0f72d33eff7bfa2fbc1059d90b6p-18L,
-+T29 = 0x1.5ef2daf21d1113df38d0fbc00267p-19L,
-+T31 = 0x1.1c77d6eac0234988cdaa04c96626p-20L,
-+T33 = 0x1.cd2a5a292b180e0bdd701057dfe3p-22L,
-+T35 = 0x1.75c7357d0298c01a31d0a6f7d518p-23L,
-+T37 = 0x1.2f3190f4718a9a520f98f50081fcp-24L,
-+pio4 = 0x1.921fb54442d18469898cc51701b8p-1L,
-+pio4lo = 0x1.cd129024e088a67cc74020bbea60p-116L;
-+static const double
-+T39 = 0.000000028443389121318352, /* 0x1e8a7592977938.0p-78 */
-+T41 = 0.000000011981013102001973, /* 0x19baa1b1223219.0p-79 */
-+T43 = 0.0000000038303578044958070, /* 0x107385dfb24529.0p-80 */
-+T45 = 0.0000000034664378216909893, /* 0x1dc6c702a05262.0p-81 */
-+T47 = -0.0000000015090641701997785, /* -0x19ecef3569ebb6.0p-82 */
-+T49 = 0.0000000029449552300483952, /* 0x194c0668da786a.0p-81 */
-+T51 = -0.0000000022006995706097711, /* -0x12e763b8845268.0p-81 */
-+T53 = 0.0000000015468200913196612, /* 0x1a92fc98c29554.0p-82 */
-+T55 = -0.00000000061311613386849674, /* -0x151106cbc779a9.0p-83 */
-+T57 = 1.4912469681508012e-10; /* 0x147edbdba6f43a.0p-85 */
-+#define RPOLY(w) (T5 + w * (T9 + w * (T13 + w * (T17 + w * (T21 + \
-+ w * (T25 + w * (T29 + w * (T33 + w * (T37 + w * (T41 + \
-+ w * (T45 + w * (T49 + w * (T53 + w * T57)))))))))))))
-+#define VPOLY(w) (T7 + w * (T11 + w * (T15 + w * (T19 + w * (T23 + \
-+ w * (T27 + w * (T31 + w * (T35 + w * (T39 + w * (T43 + \
-+ w * (T47 + w * (T51 + w * T55))))))))))))
-+#endif
-
- long double __tanl(long double x, long double y, int odd) {
- long double z, r, v, w, s, a, t;
-@@ -62,10 +115,8 @@
- }
- z = x * x;
- w = z * z;
-- r = T5 + w * (T9 + w * (T13 + w * (T17 + w * (T21 +
-- w * (T25 + w * (T29 + w * T33))))));
-- v = z * (T7 + w * (T11 + w * (T15 + w * (T19 + w * (T23 +
-- w * (T27 + w * T31))))));
-+ r = RPOLY(w);
-+ v = z * VPOLY(w);
- s = z * x;
- r = y + z * (s * (r + v) + y) + T3 * s;
- w = x + r;
-@@ -76,7 +127,6 @@
- }
- if (!odd)
- return w;
--
- /*
- * if allow error up to 2 ulp, simply return
- * -1.0 / (x+r) here
-diff -Nur musl-0.9.13/src/math/acoshf.c musl-git/src/math/acoshf.c
---- musl-0.9.13/src/math/acoshf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/acoshf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -3,14 +3,15 @@
- /* acosh(x) = log(x + sqrt(x*x-1)) */
- float acoshf(float x)
- {
-- union {float f; int32_t i;} u = {.f = x};
-+ union {float f; uint32_t i;} u = {x};
-+ uint32_t a = u.i & 0x7fffffff;
-
-- if (u.i < 0x3f800000+(1<<23))
-- /* x < 2, invalid if x < 1 or nan */
-+ if (a < 0x3f800000+(1<<23))
-+ /* |x| < 2, invalid if x < 1 or nan */
- /* up to 2ulp error in [1,1.125] */
- return log1pf(x-1 + sqrtf((x-1)*(x-1)+2*(x-1)));
-- if (u.i < 0x3f800000+(12<<23))
-- /* x < 0x1p12 */
-+ if (a < 0x3f800000+(12<<23))
-+ /* |x| < 0x1p12 */
- return logf(2*x - 1/(x+sqrtf(x*x-1)));
- /* x >= 0x1p12 */
- return logf(x) + 0.693147180559945309417232121458176568f;
-diff -Nur musl-0.9.13/src/math/acoshl.c musl-git/src/math/acoshl.c
---- musl-0.9.13/src/math/acoshl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/acoshl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -9,16 +9,14 @@
- /* acosh(x) = log(x + sqrt(x*x-1)) */
- long double acoshl(long double x)
- {
-- union {
-- long double f;
-- struct{uint64_t m; int16_t se; uint16_t pad;} i;
-- } u = {.f = x};
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-
-- if (u.i.se < 0x3fff + 1)
-- /* x < 2, invalid if x < 1 or nan */
-+ if (e < 0x3fff + 1)
-+ /* |x| < 2, invalid if x < 1 or nan */
- return log1pl(x-1 + sqrtl((x-1)*(x-1)+2*(x-1)));
-- if (u.i.se < 0x3fff + 32)
-- /* x < 0x1p32 */
-+ if (e < 0x3fff + 32)
-+ /* |x| < 0x1p32 */
- return logl(2*x - 1/(x+sqrtl(x*x-1)));
- return logl(x) + 0.693147180559945309417232121458176568L;
- }
-diff -Nur musl-0.9.13/src/math/acosl.c musl-git/src/math/acosl.c
---- musl-0.9.13/src/math/acosl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/acosl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -23,46 +23,45 @@
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- #include "__invtrigl.h"
-+#if LDBL_MANT_DIG == 64
-+#define CLEARBOTTOM(u) (u.i.m &= -1ULL << 32)
-+#elif LDBL_MANT_DIG == 113
-+#define CLEARBOTTOM(u) (u.i.lo = 0)
-+#endif
-
- long double acosl(long double x)
- {
-- union IEEEl2bits u;
-- long double z, w, s, c, df;
-- int16_t expsign, expt;
-- u.e = x;
-- expsign = u.xbits.expsign;
-- expt = expsign & 0x7fff;
-+ union ldshape u = {x};
-+ long double z, s, c, f;
-+ uint16_t e = u.i.se & 0x7fff;
-+
- /* |x| >= 1 or nan */
-- if (expt >= 0x3fff) {
-- if (expt == 0x3fff &&
-- ((u.bits.manh & ~LDBL_NBIT) | u.bits.manl) == 0) {
-- if (expsign > 0)
-- return 0; /* acos(1) = 0 */
-- return 2*pio2_hi + 0x1p-120f; /* acos(-1)= pi */
-- }
-- return 0/(x-x); /* acos(|x|>1) is NaN */
-+ if (e >= 0x3fff) {
-+ if (x == 1)
-+ return 0;
-+ if (x == -1)
-+ return 2*pio2_hi + 0x1p-120f;
-+ return 0/(x-x);
- }
- /* |x| < 0.5 */
-- if (expt < 0x3fff - 1) {
-- if (expt < 0x3fff - 65)
-- return pio2_hi + 0x1p-120f; /* x < 0x1p-65: acosl(x)=pi/2 */
-- return pio2_hi - (x - (pio2_lo - x * __invtrigl_R(x*x)));
-+ if (e < 0x3fff - 1) {
-+ if (e < 0x3fff - LDBL_MANT_DIG - 1)
-+ return pio2_hi + 0x1p-120f;
-+ return pio2_hi - (__invtrigl_R(x*x)*x - pio2_lo + x);
- }
- /* x < -0.5 */
-- if (expsign < 0) {
-- z = (1.0 + x) * 0.5;
-+ if (u.i.se >> 15) {
-+ z = (1 + x)*0.5;
- s = sqrtl(z);
-- w = __invtrigl_R(z) * s - pio2_lo;
-- return 2*(pio2_hi - (s + w));
-+ return 2*(pio2_hi - (__invtrigl_R(z)*s - pio2_lo + s));
- }
- /* x > 0.5 */
-- z = (1.0 - x) * 0.5;
-+ z = (1 - x)*0.5;
- s = sqrtl(z);
-- u.e = s;
-- u.bits.manl = 0;
-- df = u.e;
-- c = (z - df * df) / (s + df);
-- w = __invtrigl_R(z) * s + c;
-- return 2*(df + w);
-+ u.f = s;
-+ CLEARBOTTOM(u);
-+ f = u.f;
-+ c = (z - f*f)/(s + f);
-+ return 2*(__invtrigl_R(z)*s + c + f);
- }
- #endif
-diff -Nur musl-0.9.13/src/math/asinhl.c musl-git/src/math/asinhl.c
---- musl-0.9.13/src/math/asinhl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/asinhl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -9,10 +9,7 @@
- /* asinh(x) = sign(x)*log(|x|+sqrt(x*x+1)) ~= x - x^3/6 + o(x^5) */
- long double asinhl(long double x)
- {
-- union {
-- long double f;
-- struct{uint64_t m; uint16_t se; uint16_t pad;} i;
-- } u = {.f = x};
-+ union ldshape u = {x};
- unsigned e = u.i.se & 0x7fff;
- unsigned s = u.i.se >> 15;
-
-diff -Nur musl-0.9.13/src/math/asinl.c musl-git/src/math/asinl.c
---- musl-0.9.13/src/math/asinl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/asinl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -23,27 +23,29 @@
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- #include "__invtrigl.h"
--/* 0.95 */
--#define THRESH ((0xe666666666666666ULL>>(64-(LDBL_MANH_SIZE-1)))|LDBL_NBIT)
-+#if LDBL_MANT_DIG == 64
-+#define CLOSETO1(u) (u.i.m>>56 >= 0xf7)
-+#define CLEARBOTTOM(u) (u.i.m &= -1ULL << 32)
-+#elif LDBL_MANT_DIG == 113
-+#define CLOSETO1(u) (u.i.top >= 0xee00)
-+#define CLEARBOTTOM(u) (u.i.lo = 0)
-+#endif
-
- long double asinl(long double x)
- {
-- union IEEEl2bits u;
-- long double z,r,s;
-- uint16_t expsign, expt;
-+ union ldshape u = {x};
-+ long double z, r, s;
-+ uint16_t e = u.i.se & 0x7fff;
-+ int sign = u.i.se >> 15;
-
-- u.e = x;
-- expsign = u.xbits.expsign;
-- expt = expsign & 0x7fff;
-- if (expt >= 0x3fff) { /* |x| >= 1 or nan */
-- if (expt == 0x3fff &&
-- ((u.bits.manh&~LDBL_NBIT)|u.bits.manl) == 0)
-- /* asin(+-1)=+-pi/2 with inexact */
-+ if (e >= 0x3fff) { /* |x| >= 1 or nan */
-+ /* asin(+-1)=+-pi/2 with inexact */
-+ if (x == 1 || x == -1)
- return x*pio2_hi + 0x1p-120f;
- return 0/(x-x);
- }
-- if (expt < 0x3fff - 1) { /* |x| < 0.5 */
-- if (expt < 0x3fff - 32) { /* |x|<0x1p-32, asinl(x)=x */
-+ if (e < 0x3fff - 1) { /* |x| < 0.5 */
-+ if (e < 0x3fff - (LDBL_MANT_DIG+1)/2) {
- /* return x with inexact if x!=0 */
- FORCE_EVAL(x + 0x1p120f);
- return x;
-@@ -54,18 +56,16 @@
- z = (1.0 - fabsl(x))*0.5;
- s = sqrtl(z);
- r = __invtrigl_R(z);
-- if (u.bits.manh >= THRESH) { /* if |x| is close to 1 */
-+ if (CLOSETO1(u)) {
- x = pio2_hi - (2*(s+s*r)-pio2_lo);
- } else {
- long double f, c;
-- u.e = s;
-- u.bits.manl = 0;
-- f = u.e;
-- c = (z-f*f)/(s+f);
-+ u.f = s;
-+ CLEARBOTTOM(u);
-+ f = u.f;
-+ c = (z - f*f)/(s + f);
- x = 0.5*pio2_hi-(2*s*r - (pio2_lo-2*c) - (0.5*pio2_hi-2*f));
- }
-- if (expsign>>15)
-- return -x;
-- return x;
-+ return sign ? -x : x;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/atan2l.c musl-git/src/math/atan2l.c
---- musl-0.9.13/src/math/atan2l.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/atan2l.c 2013-09-16 20:31:39.000000000 +0200
-@@ -27,56 +27,50 @@
-
- long double atan2l(long double y, long double x)
- {
-- union IEEEl2bits ux, uy;
-+ union ldshape ux, uy;
- long double z;
-- int m;
-- uint16_t exptx, expsignx, expty, expsigny;
-+ int m, ex, ey;
-
- if (isnan(x) || isnan(y))
- return x+y;
- if (x == 1)
- return atanl(y);
-- uy.e = y;
-- expsigny = uy.xbits.expsign;
-- expty = expsigny & 0x7fff;
-- ux.e = x;
-- expsignx = ux.xbits.expsign;
-- exptx = expsignx & 0x7fff;
-- m = ((expsigny>>15)&1) | ((expsignx>>14)&2); /* 2*sign(x)+sign(y) */
--
-+ ux.f = x;
-+ uy.f = y;
-+ ex = ux.i.se & 0x7fff;
-+ ey = uy.i.se & 0x7fff;
-+ m = 2*(ux.i.se>>15) | uy.i.se>>15;
- if (y == 0) {
- switch(m) {
- case 0:
- case 1: return y; /* atan(+-0,+anything)=+-0 */
-- case 2: return 2*pio2_hi+0x1p-120f; /* atan(+0,-anything) = pi */
-- case 3: return -2*pio2_hi-0x1p-120f; /* atan(-0,-anything) =-pi */
-+ case 2: return 2*pio2_hi; /* atan(+0,-anything) = pi */
-+ case 3: return -2*pio2_hi; /* atan(-0,-anything) =-pi */
- }
- }
- if (x == 0)
-- return m&1 ? -pio2_hi-0x1p-120f : pio2_hi+0x1p-120f;
-- /* when x is INF */
-- if (exptx == 0x7fff) {
-- if (expty == 0x7fff) {
-+ return m&1 ? -pio2_hi : pio2_hi;
-+ if (ex == 0x7fff) {
-+ if (ey == 0x7fff) {
- switch(m) {
-- case 0: return pio2_hi*0.5+0x1p-120f; /* atan(+INF,+INF) */
-- case 1: return -pio2_hi*0.5-0x1p-120f; /* atan(-INF,+INF) */
-- case 2: return 1.5*pio2_hi+0x1p-120f; /* atan(+INF,-INF) */
-- case 3: return -1.5*pio2_hi-0x1p-120f; /* atan(-INF,-INF) */
-+ case 0: return pio2_hi/2; /* atan(+INF,+INF) */
-+ case 1: return -pio2_hi/2; /* atan(-INF,+INF) */
-+ case 2: return 1.5*pio2_hi; /* atan(+INF,-INF) */
-+ case 3: return -1.5*pio2_hi; /* atan(-INF,-INF) */
- }
- } else {
- switch(m) {
- case 0: return 0.0; /* atan(+...,+INF) */
- case 1: return -0.0; /* atan(-...,+INF) */
-- case 2: return 2*pio2_hi+0x1p-120f; /* atan(+...,-INF) */
-- case 3: return -2*pio2_hi-0x1p-120f; /* atan(-...,-INF) */
-+ case 2: return 2*pio2_hi; /* atan(+...,-INF) */
-+ case 3: return -2*pio2_hi; /* atan(-...,-INF) */
- }
- }
- }
-- /* when y is INF */
-- if (exptx+120 < expty || expty == 0x7fff)
-- return m&1 ? -pio2_hi-0x1p-120f : pio2_hi+0x1p-120f;
--
-- if ((m&2) && expty+120 < exptx) /* |y/x| tiny, x<0 */
-+ if (ex+120 < ey || ey == 0x7fff)
-+ return m&1 ? -pio2_hi : pio2_hi;
-+ /* z = atan(|y/x|) without spurious underflow */
-+ if ((m&2) && ey+120 < ex) /* |y/x| < 0x1p-120, x<0 */
- z = 0.0;
- else
- z = atanl(fabsl(y/x));
-diff -Nur musl-0.9.13/src/math/atanh.c musl-git/src/math/atanh.c
---- musl-0.9.13/src/math/atanh.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/atanh.c 2013-09-16 20:31:39.000000000 +0200
-@@ -6,16 +6,24 @@
- union {double f; uint64_t i;} u = {.f = x};
- unsigned e = u.i >> 52 & 0x7ff;
- unsigned s = u.i >> 63;
-+ double_t y;
-
- /* |x| */
- u.i &= (uint64_t)-1/2;
-- x = u.f;
-+ y = u.f;
-
- if (e < 0x3ff - 1) {
-- /* |x| < 0.5, up to 1.7ulp error */
-- x = 0.5*log1p(2*x + 2*x*x/(1-x));
-+ if (e < 0x3ff - 32) {
-+ /* handle underflow */
-+ if (e == 0)
-+ FORCE_EVAL((float)y);
-+ } else {
-+ /* |x| < 0.5, up to 1.7ulp error */
-+ y = 0.5*log1p(2*y + 2*y*y/(1-y));
-+ }
- } else {
-- x = 0.5*log1p(2*x/(1-x));
-+ /* avoid overflow */
-+ y = 0.5*log1p(2*(y/(1-y)));
- }
-- return s ? -x : x;
-+ return s ? -y : y;
- }
-diff -Nur musl-0.9.13/src/math/atanhf.c musl-git/src/math/atanhf.c
---- musl-0.9.13/src/math/atanhf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/atanhf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -5,16 +5,24 @@
- {
- union {float f; uint32_t i;} u = {.f = x};
- unsigned s = u.i >> 31;
-+ float_t y;
-
- /* |x| */
- u.i &= 0x7fffffff;
-- x = u.f;
-+ y = u.f;
-
- if (u.i < 0x3f800000 - (1<<23)) {
-- /* |x| < 0.5, up to 1.7ulp error */
-- x = 0.5f*log1pf(2*x + 2*x*x/(1-x));
-+ if (u.i < 0x3f800000 - (32<<23)) {
-+ /* handle underflow */
-+ if (u.i < (1<<23))
-+ FORCE_EVAL((float)(y*y));
-+ } else {
-+ /* |x| < 0.5, up to 1.7ulp error */
-+ y = 0.5f*log1pf(2*y + 2*y*y/(1-y));
-+ }
- } else {
-- x = 0.5f*log1pf(2*x/(1-x));
-+ /* avoid overflow */
-+ y = 0.5f*log1pf(2*(y/(1-y)));
- }
-- return s ? -x : x;
-+ return s ? -y : y;
- }
-diff -Nur musl-0.9.13/src/math/atanhl.c musl-git/src/math/atanhl.c
---- musl-0.9.13/src/math/atanhl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/atanhl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -9,10 +9,7 @@
- /* atanh(x) = log((1+x)/(1-x))/2 = log1p(2x/(1-x))/2 ~= x + x^3/3 + o(x^5) */
- long double atanhl(long double x)
- {
-- union {
-- long double f;
-- struct{uint64_t m; uint16_t se; uint16_t pad;} i;
-- } u = {.f = x};
-+ union ldshape u = {x};
- unsigned e = u.i.se & 0x7fff;
- unsigned s = u.i.se >> 15;
-
-@@ -20,11 +17,18 @@
- u.i.se = e;
- x = u.f;
-
-- if (e < 0x3fff - 1) {
-- /* |x| < 0.5, up to 1.7ulp error */
-- x = 0.5*log1pl(2*x + 2*x*x/(1-x));
-+ if (e < 0x3ff - 1) {
-+ if (e < 0x3ff - LDBL_MANT_DIG/2) {
-+ /* handle underflow */
-+ if (e == 0)
-+ FORCE_EVAL((float)x);
-+ } else {
-+ /* |x| < 0.5, up to 1.7ulp error */
-+ x = 0.5*log1pl(2*x + 2*x*x/(1-x));
-+ }
- } else {
-- x = 0.5*log1pl(2*x/(1-x));
-+ /* avoid overflow */
-+ x = 0.5*log1pl(2*(x/(1-x)));
- }
- return s ? -x : x;
- }
-diff -Nur musl-0.9.13/src/math/atanl.c musl-git/src/math/atanl.c
---- musl-0.9.13/src/math/atanl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/atanl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -23,6 +23,9 @@
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
-
-+#if LDBL_MANT_DIG == 64
-+#define EXPMAN(u) ((u.i.se & 0x7fff)<<8 | (u.i.m>>55 & 0xff))
-+
- static const long double atanhi[] = {
- 4.63647609000806116202e-01L,
- 7.85398163397448309628e-01L,
-@@ -64,32 +67,85 @@
- return aT[1] + x * (aT[3] + x * (aT[5] + x * (aT[7] +
- x * (aT[9] + x * aT[11]))));
- }
-+#elif LDBL_MANT_DIG == 113
-+#define EXPMAN(u) ((u.i.se & 0x7fff)<<8 | u.i.top>>8)
-+
-+const long double atanhi[] = {
-+ 4.63647609000806116214256231461214397e-01L,
-+ 7.85398163397448309615660845819875699e-01L,
-+ 9.82793723247329067985710611014666038e-01L,
-+ 1.57079632679489661923132169163975140e+00L,
-+};
-+
-+const long double atanlo[] = {
-+ 4.89509642257333492668618435220297706e-36L,
-+ 2.16795253253094525619926100651083806e-35L,
-+ -2.31288434538183565909319952098066272e-35L,
-+ 4.33590506506189051239852201302167613e-35L,
-+};
-+
-+const long double aT[] = {
-+ 3.33333333333333333333333333333333125e-01L,
-+ -1.99999999999999999999999999999180430e-01L,
-+ 1.42857142857142857142857142125269827e-01L,
-+ -1.11111111111111111111110834490810169e-01L,
-+ 9.09090909090909090908522355708623681e-02L,
-+ -7.69230769230769230696553844935357021e-02L,
-+ 6.66666666666666660390096773046256096e-02L,
-+ -5.88235294117646671706582985209643694e-02L,
-+ 5.26315789473666478515847092020327506e-02L,
-+ -4.76190476189855517021024424991436144e-02L,
-+ 4.34782608678695085948531993458097026e-02L,
-+ -3.99999999632663469330634215991142368e-02L,
-+ 3.70370363987423702891250829918659723e-02L,
-+ -3.44827496515048090726669907612335954e-02L,
-+ 3.22579620681420149871973710852268528e-02L,
-+ -3.03020767654269261041647570626778067e-02L,
-+ 2.85641979882534783223403715930946138e-02L,
-+ -2.69824879726738568189929461383741323e-02L,
-+ 2.54194698498808542954187110873675769e-02L,
-+ -2.35083879708189059926183138130183215e-02L,
-+ 2.04832358998165364349957325067131428e-02L,
-+ -1.54489555488544397858507248612362957e-02L,
-+ 8.64492360989278761493037861575248038e-03L,
-+ -2.58521121597609872727919154569765469e-03L,
-+};
-+
-+static long double T_even(long double x)
-+{
-+ return (aT[0] + x * (aT[2] + x * (aT[4] + x * (aT[6] + x * (aT[8] +
-+ x * (aT[10] + x * (aT[12] + x * (aT[14] + x * (aT[16] +
-+ x * (aT[18] + x * (aT[20] + x * aT[22])))))))))));
-+}
-+
-+static long double T_odd(long double x)
-+{
-+ return (aT[1] + x * (aT[3] + x * (aT[5] + x * (aT[7] + x * (aT[9] +
-+ x * (aT[11] + x * (aT[13] + x * (aT[15] + x * (aT[17] +
-+ x * (aT[19] + x * (aT[21] + x * aT[23])))))))))));
-+}
-+#endif
-
- long double atanl(long double x)
- {
-- union IEEEl2bits u;
-- long double w,s1,s2,z;
-+ union ldshape u = {x};
-+ long double w, s1, s2, z;
- int id;
-- uint16_t expsign, expt;
-- uint32_t expman;
-+ unsigned e = u.i.se & 0x7fff;
-+ unsigned sign = u.i.se >> 15;
-+ unsigned expman;
-
-- u.e = x;
-- expsign = u.xbits.expsign;
-- expt = expsign & 0x7fff;
-- if (expt >= 0x3fff + 65) { /* if |x| is large, atan(x)~=pi/2 */
-- if (expt == 0x7fff &&
-- ((u.bits.manh&~LDBL_NBIT)|u.bits.manl)!=0) /* NaN */
-- return x+x;
-- z = atanhi[3] + 0x1p-120f;
-- return expsign>>15 ? -z : z;
-+ if (e >= 0x3fff + LDBL_MANT_DIG + 1) { /* if |x| is large, atan(x)~=pi/2 */
-+ if (isnan(x))
-+ return x;
-+ return sign ? -atanhi[3] : atanhi[3];
- }
- /* Extract the exponent and the first few bits of the mantissa. */
-- /* XXX There should be a more convenient way to do this. */
-- expman = (expt << 8) | ((u.bits.manh >> (LDBL_MANH_SIZE - 9)) & 0xff);
-+ expman = EXPMAN(u);
- if (expman < ((0x3fff - 2) << 8) + 0xc0) { /* |x| < 0.4375 */
-- if (expt < 0x3fff - 32) { /* if |x| is small, atanl(x)~=x */
-+ if (e < 0x3fff - (LDBL_MANT_DIG+1)/2) { /* if |x| is small, atanl(x)~=x */
- /* raise underflow if subnormal */
-- if (expt == 0)
-+ if (e == 0)
- FORCE_EVAL((float)x);
- return x;
- }
-@@ -108,7 +164,7 @@
- if (expman < ((0x3fff + 1) << 8) + 0x38) { /* |x| < 2.4375 */
- id = 2;
- x = (x-1.5)/(1.0+1.5*x);
-- } else { /* 2.4375 <= |x| < 2^ATAN_CONST */
-+ } else { /* 2.4375 <= |x| */
- id = 3;
- x = -1.0/x;
- }
-@@ -123,6 +179,6 @@
- if (id < 0)
- return x - x*(s1+s2);
- z = atanhi[id] - ((x*(s1+s2) - atanlo[id]) - x);
-- return expsign>>15 ? -z : z;
-+ return sign ? -z : z;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/cbrt.c musl-git/src/math/cbrt.c
---- musl-0.9.13/src/math/cbrt.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/cbrt.c 2013-09-16 20:31:39.000000000 +0200
-@@ -15,7 +15,8 @@
- * Return cube root of x
- */
-
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- static const uint32_t
- B1 = 715094163, /* B1 = (1023-1023/3-0.03306235651)*2**20 */
-@@ -31,15 +32,10 @@
-
- double cbrt(double x)
- {
-- int32_t hx;
-- union dshape u;
-- double r,s,t=0.0,w;
-- uint32_t sign;
-- uint32_t high,low;
--
-- EXTRACT_WORDS(hx, low, x);
-- sign = hx & 0x80000000;
-- hx ^= sign;
-+ union {double f; uint64_t i;} u = {x};
-+ double_t r,s,t,w;
-+ uint32_t hx = u.i>>32 & 0x7fffffff;
-+
- if (hx >= 0x7ff00000) /* cbrt(NaN,INF) is itself */
- return x+x;
-
-@@ -59,14 +55,16 @@
- * division rounds towards minus infinity; this is also efficient.
- */
- if (hx < 0x00100000) { /* zero or subnormal? */
-- if ((hx|low) == 0)
-+ u.f = x*0x1p54;
-+ hx = u.i>>32 & 0x7fffffff;
-+ if (hx == 0)
- return x; /* cbrt(0) is itself */
-- SET_HIGH_WORD(t, 0x43500000); /* set t = 2**54 */
-- t *= x;
-- GET_HIGH_WORD(high, t);
-- INSERT_WORDS(t, sign|((high&0x7fffffff)/3+B2), 0);
-+ hx = hx/3 + B2;
- } else
-- INSERT_WORDS(t, sign|(hx/3+B1), 0);
-+ hx = hx/3 + B1;
-+ u.i &= 1ULL<<63;
-+ u.i |= (uint64_t)hx << 32;
-+ t = u.f;
-
- /*
- * New cbrt to 23 bits:
-@@ -76,7 +74,7 @@
- * has produced t such than |t/cbrt(x) - 1| ~< 1/32, and cubing this
- * gives us bounds for r = t**3/x.
- *
-- * Try to optimize for parallel evaluation as in k_tanf.c.
-+ * Try to optimize for parallel evaluation as in __tanf.c.
- */
- r = (t*t)*(t/x);
- t = t*((P0+r*(P1+r*P2))+((r*r)*r)*(P3+r*P4));
-@@ -91,9 +89,9 @@
- * 0.667; the error in the rounded t can be up to about 3 23-bit ulps
- * before the final error is larger than 0.667 ulps.
- */
-- u.value = t;
-- u.bits = (u.bits + 0x80000000) & 0xffffffffc0000000ULL;
-- t = u.value;
-+ u.f = t;
-+ u.i = (u.i + 0x80000000) & 0xffffffffc0000000ULL;
-+ t = u.f;
-
- /* one step Newton iteration to 53 bits with error < 0.667 ulps */
- s = t*t; /* t*t is exact */
-diff -Nur musl-0.9.13/src/math/cbrtf.c musl-git/src/math/cbrtf.c
---- musl-0.9.13/src/math/cbrtf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/cbrtf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -17,7 +17,8 @@
- * Return cube root of x
- */
-
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- static const unsigned
- B1 = 709958130, /* B1 = (127-127.0/3-0.03306235651)*2**23 */
-@@ -25,15 +26,10 @@
-
- float cbrtf(float x)
- {
-- double r,T;
-- float t;
-- int32_t hx;
-- uint32_t sign;
-- uint32_t high;
--
-- GET_FLOAT_WORD(hx, x);
-- sign = hx & 0x80000000;
-- hx ^= sign;
-+ double_t r,T;
-+ union {float f; uint32_t i;} u = {x};
-+ uint32_t hx = u.i & 0x7fffffff;
-+
- if (hx >= 0x7f800000) /* cbrt(NaN,INF) is itself */
- return x + x;
-
-@@ -41,28 +37,29 @@
- if (hx < 0x00800000) { /* zero or subnormal? */
- if (hx == 0)
- return x; /* cbrt(+-0) is itself */
-- SET_FLOAT_WORD(t, 0x4b800000); /* set t = 2**24 */
-- t *= x;
-- GET_FLOAT_WORD(high, t);
-- SET_FLOAT_WORD(t, sign|((high&0x7fffffff)/3+B2));
-+ u.f = x*0x1p24f;
-+ hx = u.i & 0x7fffffff;
-+ hx = hx/3 + B2;
- } else
-- SET_FLOAT_WORD(t, sign|(hx/3+B1));
-+ hx = hx/3 + B1;
-+ u.i &= 0x80000000;
-+ u.i |= hx;
-
- /*
- * First step Newton iteration (solving t*t-x/t == 0) to 16 bits. In
- * double precision so that its terms can be arranged for efficiency
- * without causing overflow or underflow.
- */
-- T = t;
-+ T = u.f;
- r = T*T*T;
-- T = T*((double)x+x+r)/(x+r+r);
-+ T = T*((double_t)x+x+r)/(x+r+r);
-
- /*
- * Second step Newton iteration to 47 bits. In double precision for
- * efficiency and accuracy.
- */
- r = T*T*T;
-- T = T*((double)x+x+r)/(x+r+r);
-+ T = T*((double_t)x+x+r)/(x+r+r);
-
- /* rounding to 24 bits is perfect in round-to-nearest mode */
- return T;
-diff -Nur musl-0.9.13/src/math/cbrtl.c musl-git/src/math/cbrtl.c
---- musl-0.9.13/src/math/cbrtl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/cbrtl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -23,58 +23,50 @@
- return cbrt(x);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#define BIAS (LDBL_MAX_EXP - 1)
- static const unsigned B1 = 709958130; /* B1 = (127-127.0/3-0.03306235651)*2**23 */
-
- long double cbrtl(long double x)
- {
-- union IEEEl2bits u, v;
-+ union ldshape u = {x}, v;
-+ union {float f; uint32_t i;} uft;
- long double r, s, t, w;
-- double dr, dt, dx;
-- float ft, fx;
-- uint32_t hx;
-- uint16_t expsign;
-- int k;
--
-- u.e = x;
-- expsign = u.xbits.expsign;
-- k = expsign & 0x7fff;
-+ double_t dr, dt, dx;
-+ float_t ft;
-+ int e = u.i.se & 0x7fff;
-+ int sign = u.i.se & 0x8000;
-
- /*
- * If x = +-Inf, then cbrt(x) = +-Inf.
- * If x = NaN, then cbrt(x) = NaN.
- */
-- if (k == BIAS + LDBL_MAX_EXP)
-+ if (e == 0x7fff)
- return x + x;
--
-- if (k == 0) {
-+ if (e == 0) {
-+ /* Adjust subnormal numbers. */
-+ u.f *= 0x1p120;
-+ e = u.i.se & 0x7fff;
- /* If x = +-0, then cbrt(x) = +-0. */
-- if ((u.bits.manh | u.bits.manl) == 0)
-+ if (e == 0)
- return x;
-- /* Adjust subnormal numbers. */
-- u.e *= 0x1.0p514;
-- k = u.bits.exp;
-- k -= BIAS + 514;
-- } else
-- k -= BIAS;
-- u.xbits.expsign = BIAS;
-- v.e = 1;
--
-- x = u.e;
-- switch (k % 3) {
-+ e -= 120;
-+ }
-+ e -= 0x3fff;
-+ u.i.se = 0x3fff;
-+ x = u.f;
-+ switch (e % 3) {
- case 1:
- case -2:
-- x = 2*x;
-- k--;
-+ x *= 2;
-+ e--;
- break;
- case 2:
- case -1:
-- x = 4*x;
-- k -= 2;
-+ x *= 4;
-+ e -= 2;
- break;
- }
-- v.xbits.expsign = (expsign & 0x8000) | (BIAS + k / 3);
-+ v.f = 1.0;
-+ v.i.se = sign | (0x3fff + e/3);
-
- /*
- * The following is the guts of s_cbrtf, with the handling of
-@@ -83,9 +75,9 @@
- */
-
- /* ~5-bit estimate: */
-- fx = x;
-- GET_FLOAT_WORD(hx, fx);
-- SET_FLOAT_WORD(ft, ((hx & 0x7fffffff) / 3 + B1));
-+ uft.f = x;
-+ uft.i = (uft.i & 0x7fffffff)/3 + B1;
-+ ft = uft.f;
-
- /* ~16-bit estimate: */
- dx = x;
-@@ -126,7 +118,7 @@
- r = (r-t)/(w+r); /* r-t is exact; w+r ~= 3*t */
- t = t+t*r; /* error <= 0.5 + 0.5/3 + epsilon */
-
-- t *= v.e;
-+ t *= v.f;
- return t;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/ceil.c musl-git/src/math/ceil.c
---- musl-0.9.13/src/math/ceil.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/ceil.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,82 +1,24 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_ceil.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * ceil(x)
-- * Return x rounded toward -inf to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to ceil(x).
-- */
--
- #include "libm.h"
-
--static const double huge = 1.0e300;
--
- double ceil(double x)
- {
-- int32_t i0,i1,j0;
-- uint32_t i,j;
-+ union {double f; uint64_t i;} u = {x};
-+ int e = u.i >> 52 & 0x7ff;
-+ double_t y;
-
-- EXTRACT_WORDS(i0, i1, x);
-- // FIXME signed shift
-- j0 = ((i0>>20)&0x7ff) - 0x3ff;
-- if (j0 < 20) {
-- if (j0 < 0) {
-- /* raise inexact if x != 0 */
-- if (huge+x > 0.0) {
-- if (i0 < 0) {
-- i0 = 0x80000000;
-- i1=0;
-- } else if ((i0|i1) != 0) {
-- i0=0x3ff00000;
-- i1=0;
-- }
-- }
-- } else {
-- i = 0x000fffff>>j0;
-- if (((i0&i)|i1) == 0) /* x is integral */
-- return x;
-- /* raise inexact flag */
-- if (huge+x > 0.0) {
-- if (i0 > 0)
-- i0 += 0x00100000>>j0;
-- i0 &= ~i;
-- i1 = 0;
-- }
-- }
-- } else if (j0 > 51) {
-- if (j0 == 0x400) /* inf or NaN */
-- return x+x;
-- return x; /* x is integral */
-- } else {
-- i = (uint32_t)0xffffffff>>(j0-20);
-- if ((i1&i) == 0)
-- return x; /* x is integral */
-- /* raise inexact flag */
-- if (huge+x > 0.0) {
-- if (i0 > 0) {
-- if (j0 == 20)
-- i0 += 1;
-- else {
-- j = i1 + (1<<(52-j0));
-- if (j < i1) /* got a carry */
-- i0 += 1;
-- i1 = j;
-- }
-- }
-- i1 &= ~i;
-- }
-+ if (e >= 0x3ff+52 || x == 0)
-+ return x;
-+ /* y = int(x) - x, where int(x) is an integer neighbor of x */
-+ if (u.i >> 63)
-+ y = (double)(x - 0x1p52) + 0x1p52 - x;
-+ else
-+ y = (double)(x + 0x1p52) - 0x1p52 - x;
-+ /* special case because of non-nearest rounding modes */
-+ if (e <= 0x3ff-1) {
-+ FORCE_EVAL(y);
-+ return u.i >> 63 ? -0.0 : 1;
- }
-- INSERT_WORDS(x, i0, i1);
-- return x;
-+ if (y < 0)
-+ return x + y + 1;
-+ return x + y;
- }
-diff -Nur musl-0.9.13/src/math/ceilf.c musl-git/src/math/ceilf.c
---- musl-0.9.13/src/math/ceilf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/ceilf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,54 +1,27 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_ceilf.c */
--/*
-- * Conversion to float by Ian Lance Taylor, Cygnus Support, ian@cygnus.com.
-- */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--
- #include "libm.h"
-
--static const float huge = 1.0e30;
--
- float ceilf(float x)
- {
-- int32_t i0,j0;
-- uint32_t i;
-+ union {float f; uint32_t i;} u = {x};
-+ int e = (int)(u.i >> 23 & 0xff) - 0x7f;
-+ uint32_t m;
-
-- GET_FLOAT_WORD(i0, x);
-- j0 = ((i0>>23)&0xff) - 0x7f;
-- if (j0 < 23) {
-- if (j0 < 0) {
-- /* raise inexact if x != 0 */
-- if (huge+x > 0.0f) {
-- if (i0 < 0)
-- i0 = 0x80000000;
-- else if(i0 != 0)
-- i0 = 0x3f800000;
-- }
-- } else {
-- i = 0x007fffff>>j0;
-- if ((i0&i) == 0)
-- return x; /* x is integral */
-- /* raise inexact flag */
-- if (huge+x > 0.0f) {
-- if (i0 > 0)
-- i0 += 0x00800000>>j0;
-- i0 &= ~i;
-- }
-- }
-+ if (e >= 23)
-+ return x;
-+ if (e >= 0) {
-+ m = 0x007fffff >> e;
-+ if ((u.i & m) == 0)
-+ return x;
-+ FORCE_EVAL(x + 0x1p120f);
-+ if (u.i >> 31 == 0)
-+ u.i += m;
-+ u.i &= ~m;
- } else {
-- if (j0 == 0x80) /* inf or NaN */
-- return x+x;
-- return x; /* x is integral */
-+ FORCE_EVAL(x + 0x1p120f);
-+ if (u.i >> 31)
-+ u.f = -0.0;
-+ else if (u.i << 1)
-+ u.f = 1.0;
- }
-- SET_FLOAT_WORD(x, i0);
-- return x;
-+ return u.f;
- }
-diff -Nur musl-0.9.13/src/math/ceill.c musl-git/src/math/ceill.c
---- musl-0.9.13/src/math/ceill.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/ceill.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,23 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_ceill.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * ceill(x)
-- * Return x rounded toward -inf to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to ceill(x).
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -26,77 +6,31 @@
- return ceil(x);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#ifdef LDBL_IMPLICIT_NBIT
--#define MANH_SIZE (LDBL_MANH_SIZE + 1)
--#define INC_MANH(u, c) do { \
-- uint64_t o = u.bits.manh; \
-- u.bits.manh += (c); \
-- if (u.bits.manh < o) \
-- u.bits.exp++; \
--} while (0)
--#else
--#define MANH_SIZE LDBL_MANH_SIZE
--#define INC_MANH(u, c) do { \
-- uint64_t o = u.bits.manh; \
-- u.bits.manh += (c); \
-- if (u.bits.manh < o) { \
-- u.bits.exp++; \
-- u.bits.manh |= 1llu << (LDBL_MANH_SIZE - 1); \
-- } \
--} while (0)
-+#if LDBL_MANT_DIG == 64
-+#define TOINT 0x1p63
-+#elif LDBL_MANT_DIG == 113
-+#define TOINT 0x1p112
- #endif
--
--static const long double huge = 1.0e300;
--
- long double ceill(long double x)
- {
-- union IEEEl2bits u = { .e = x };
-- int e = u.bits.exp - LDBL_MAX_EXP + 1;
--
-- if (e < MANH_SIZE - 1) {
-- if (e < 0) {
-- /* raise inexact if x != 0 */
-- if (huge + x > 0.0)
-- if (u.bits.exp > 0 ||
-- (u.bits.manh | u.bits.manl) != 0)
-- u.e = u.bits.sign ? -0.0 : 1.0;
-- } else {
-- uint64_t m = ((1llu << MANH_SIZE) - 1) >> (e + 1);
-- if (((u.bits.manh & m) | u.bits.manl) == 0)
-- return x; /* x is integral */
-- if (!u.bits.sign) {
--#ifdef LDBL_IMPLICIT_NBIT
-- if (e == 0)
-- u.bits.exp++;
-- else
--#endif
-- INC_MANH(u, 1llu << (MANH_SIZE - e - 1));
-- }
-- /* raise inexact flag */
-- if (huge + x > 0.0) {
-- u.bits.manh &= ~m;
-- u.bits.manl = 0;
-- }
-- }
-- } else if (e < LDBL_MANT_DIG - 1) {
-- uint64_t m = (uint64_t)-1 >> (64 - LDBL_MANT_DIG + e + 1);
-- if ((u.bits.manl & m) == 0)
-- return x; /* x is integral */
-- if (!u.bits.sign) {
-- if (e == MANH_SIZE - 1)
-- INC_MANH(u, 1);
-- else {
-- uint64_t o = u.bits.manl;
-- u.bits.manl += 1llu << (LDBL_MANT_DIG - e - 1);
-- if (u.bits.manl < o) /* got a carry */
-- INC_MANH(u, 1);
-- }
-- }
-- /* raise inexact flag */
-- if (huge + x > 0.0)
-- u.bits.manl &= ~m;
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-+ long double y;
-+
-+ if (e >= 0x3fff+LDBL_MANT_DIG-1 || x == 0)
-+ return x;
-+ /* y = int(x) - x, where int(x) is an integer neighbor of x */
-+ if (u.i.se >> 15)
-+ y = x - TOINT + TOINT - x;
-+ else
-+ y = x + TOINT - TOINT - x;
-+ /* special case because of non-nearest rounding modes */
-+ if (e <= 0x3fff-1) {
-+ FORCE_EVAL(y);
-+ return u.i.se >> 15 ? -0.0 : 1;
- }
-- return u.e;
-+ if (y < 0)
-+ return x + y + 1;
-+ return x + y;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/copysign.c musl-git/src/math/copysign.c
---- musl-0.9.13/src/math/copysign.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/copysign.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,11 +1,8 @@
- #include "libm.h"
-
- double copysign(double x, double y) {
-- union dshape ux, uy;
--
-- ux.value = x;
-- uy.value = y;
-- ux.bits &= (uint64_t)-1>>1;
-- ux.bits |= uy.bits & (uint64_t)1<<63;
-- return ux.value;
-+ union {double f; uint64_t i;} ux={x}, uy={y};
-+ ux.i &= -1ULL/2;
-+ ux.i |= uy.i & 1ULL<<63;
-+ return ux.f;
- }
-diff -Nur musl-0.9.13/src/math/copysignf.c musl-git/src/math/copysignf.c
---- musl-0.9.13/src/math/copysignf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/copysignf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,11 +1,10 @@
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
--float copysignf(float x, float y) {
-- union fshape ux, uy;
--
-- ux.value = x;
-- uy.value = y;
-- ux.bits &= (uint32_t)-1>>1;
-- ux.bits |= uy.bits & (uint32_t)1<<31;
-- return ux.value;
-+float copysignf(float x, float y)
-+{
-+ union {float f; uint32_t i;} ux={x}, uy={y};
-+ ux.i &= 0x7fffffff;
-+ ux.i |= uy.i & 0x80000000;
-+ return ux.f;
- }
-diff -Nur musl-0.9.13/src/math/copysignl.c musl-git/src/math/copysignl.c
---- musl-0.9.13/src/math/copysignl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/copysignl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -9,8 +9,8 @@
- long double copysignl(long double x, long double y)
- {
- union ldshape ux = {x}, uy = {y};
--
-- ux.bits.sign = uy.bits.sign;
-- return ux.value;
-+ ux.i.se &= 0x7fff;
-+ ux.i.se |= uy.i.se & 0x8000;
-+ return ux.f;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/coshl.c musl-git/src/math/coshl.c
---- musl-0.9.13/src/math/coshl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/coshl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -8,10 +8,7 @@
- #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
- long double coshl(long double x)
- {
-- union {
-- long double f;
-- struct{uint64_t m; uint16_t se; uint16_t pad;} i;
-- } u = {.f = x};
-+ union ldshape u = {x};
- unsigned ex = u.i.se & 0x7fff;
- uint32_t w;
- long double t;
-diff -Nur musl-0.9.13/src/math/cosl.c musl-git/src/math/cosl.c
---- musl-0.9.13/src/math/cosl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/cosl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,34 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_cosl.c */
--/*-
-- * Copyright (c) 2007 Steven G. Kargl
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice unmodified, this list of conditions, and the following
-- * disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-- */
--/*
-- * Limited testing on pseudorandom numbers drawn within [-2e8:4e8] shows
-- * an accuracy of <= 0.7412 ULP.
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -38,44 +7,33 @@
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- long double cosl(long double x)
- {
-- union IEEEl2bits z;
-+ union ldshape u = {x};
- unsigned n;
-- long double y[2];
-- long double hi, lo;
--
-- z.e = x;
-- z.bits.sign = 0;
-+ long double y[2], hi, lo;
-
-- /* If x = NaN or Inf, then cos(x) = NaN. */
-- if (z.bits.exp == 0x7fff)
-- return (x - x) / (x - x);
--
-- /* |x| < (double)pi/4 */
-- if (z.e < M_PI_4) {
-- /* |x| < 0x1p-64 */
-- if (z.bits.exp < 0x3fff - 64)
-+ u.i.se &= 0x7fff;
-+ if (u.i.se == 0x7fff)
-+ return x - x;
-+ x = u.f;
-+ if (x < M_PI_4) {
-+ if (u.i.se < 0x3fff - LDBL_MANT_DIG)
- /* raise inexact if x!=0 */
- return 1.0 + x;
-- return __cosl(z.e, 0);
-+ return __cosl(x, 0);
- }
--
- n = __rem_pio2l(x, y);
- hi = y[0];
- lo = y[1];
- switch (n & 3) {
- case 0:
-- hi = __cosl(hi, lo);
-- break;
-+ return __cosl(hi, lo);
- case 1:
-- hi = -__sinl(hi, lo, 1);
-- break;
-+ return -__sinl(hi, lo, 1);
- case 2:
-- hi = -__cosl(hi, lo);
-- break;
-+ return -__cosl(hi, lo);
- case 3:
-- hi = __sinl(hi, lo, 1);
-- break;
-+ default:
-+ return __sinl(hi, lo, 1);
- }
-- return hi;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/erfl.c musl-git/src/math/erfl.c
---- musl-0.9.13/src/math/erfl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/erfl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -253,8 +253,8 @@
-
- static long double erfc2(uint32_t ix, long double x)
- {
-+ union ldshape u;
- long double s,z,R,S;
-- uint32_t i0,i1;
-
- if (ix < 0x3fffa000) /* 0.84375 <= |x| < 1.25 */
- return erfc1(x);
-@@ -288,28 +288,22 @@
- S = sc[0] + s * (sc[1] + s * (sc[2] + s * (sc[3] +
- s * (sc[4] + s))));
- }
-- z = x;
-- GET_LDOUBLE_WORDS(ix, i0, i1, z);
-- i1 = 0;
-- i0 &= 0xffffff00;
-- SET_LDOUBLE_WORDS(z, ix, i0, i1);
-+ u.f = x;
-+ u.i.m &= -1ULL << 40;
-+ z = u.f;
- return expl(-z*z - 0.5625) * expl((z - x) * (z + x) + R / S) / x;
- }
-
- long double erfl(long double x)
- {
- long double r, s, z, y;
-- uint32_t i0, i1, ix;
-- int sign;
-+ union ldshape u = {x};
-+ uint32_t ix = (u.i.se & 0x7fffU)<<16 | u.i.m>>48;
-+ int sign = u.i.se >> 15;
-
-- GET_LDOUBLE_WORDS(ix, i0, i1, x);
-- sign = ix >> 15;
-- ix &= 0x7fff;
-- if (ix == 0x7fff) {
-+ if (ix >= 0x7fff0000)
- /* erf(nan)=nan, erf(+-inf)=+-1 */
- return 1 - 2*sign + 1/x;
-- }
-- ix = (ix << 16) | (i0 >> 16);
- if (ix < 0x3ffed800) { /* |x| < 0.84375 */
- if (ix < 0x3fde8000) { /* |x| < 2**-33 */
- return 0.125 * (8 * x + efx8 * x); /* avoid underflow */
-@@ -332,17 +326,13 @@
- long double erfcl(long double x)
- {
- long double r, s, z, y;
-- uint32_t i0, i1, ix;
-- int sign;
-+ union ldshape u = {x};
-+ uint32_t ix = (u.i.se & 0x7fffU)<<16 | u.i.m>>48;
-+ int sign = u.i.se >> 15;
-
-- GET_LDOUBLE_WORDS(ix, i0, i1, x);
-- sign = ix>>15;
-- ix &= 0x7fff;
-- if (ix == 0x7fff)
-+ if (ix >= 0x7fff0000)
- /* erfc(nan) = nan, erfc(+-inf) = 0,2 */
- return 2*sign + 1/x;
--
-- ix = (ix << 16) | (i0 >> 16);
- if (ix < 0x3ffed800) { /* |x| < 0.84375 */
- if (ix < 0x3fbe0000) /* |x| < 2**-65 */
- return 1.0 - x;
-@@ -358,6 +348,7 @@
- }
- if (ix < 0x4005d600) /* |x| < 107 */
- return sign ? 2 - erfc2(ix,x) : erfc2(ix,x);
-- return sign ? 2 - 0x1p-16382L : 0x1p-16382L*0x1p-16382L;
-+ y = 0x1p-16382L;
-+ return sign ? 2 - y : y*y;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/exp.c musl-git/src/math/exp.c
---- musl-0.9.13/src/math/exp.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/exp.c 2013-09-16 20:31:39.000000000 +0200
-@@ -80,7 +80,7 @@
-
- double exp(double x)
- {
-- double hi, lo, c, xx;
-+ double_t hi, lo, c, xx, y;
- int k, sign;
- uint32_t hx;
-
-@@ -89,20 +89,19 @@
- hx &= 0x7fffffff; /* high word of |x| */
-
- /* special cases */
-- if (hx >= 0x40862e42) { /* if |x| >= 709.78... */
-+ if (hx >= 0x4086232b) { /* if |x| >= 708.39... */
- if (isnan(x))
- return x;
-- if (hx == 0x7ff00000 && sign) /* -inf */
-- return 0;
- if (x > 709.782712893383973096) {
- /* overflow if x!=inf */
-- STRICT_ASSIGN(double, x, 0x1p1023 * x);
-+ x *= 0x1p1023;
- return x;
- }
-- if (x < -745.13321910194110842) {
-- /* underflow */
-- STRICT_ASSIGN(double, x, 0x1p-1000 * 0x1p-1000);
-- return x;
-+ if (x < -708.39641853226410622) {
-+ /* underflow if x!=-inf */
-+ FORCE_EVAL((float)(-0x1p-149/x));
-+ if (x < -745.13321910194110842)
-+ return 0;
- }
- }
-
-@@ -114,7 +113,7 @@
- k = 1 - sign - sign;
- hi = x - k*ln2hi; /* k*ln2hi is exact here */
- lo = k*ln2lo;
-- STRICT_ASSIGN(double, x, hi - lo);
-+ x = hi - lo;
- } else if (hx > 0x3e300000) { /* if |x| > 2**-28 */
- k = 0;
- hi = x;
-@@ -128,8 +127,8 @@
- /* x is now in primary range */
- xx = x*x;
- c = x - xx*(P1+xx*(P2+xx*(P3+xx*(P4+xx*P5))));
-- x = 1 + (x*c/(2-c) - lo + hi);
-+ y = 1 + (x*c/(2-c) - lo + hi);
- if (k == 0)
-- return x;
-- return scalbn(x, k);
-+ return y;
-+ return scalbn(y, k);
- }
-diff -Nur musl-0.9.13/src/math/exp2.c musl-git/src/math/exp2.c
---- musl-0.9.13/src/math/exp2.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/exp2.c 2013-09-16 20:31:39.000000000 +0200
-@@ -305,7 +305,7 @@
- * Method: (accurate tables)
- *
- * Reduce x:
-- * x = 2**k + y, for integer k and |y| <= 1/2.
-+ * x = k + y, for integer k and |y| <= 1/2.
- * Thus we have exp2(x) = 2**k * exp2(y).
- *
- * Reduce y:
-@@ -330,41 +330,41 @@
- */
- double exp2(double x)
- {
-- double r, t, z;
-- uint32_t hx, ix, i0;
-+ double_t r, t, z;
-+ uint32_t ix, i0;
-+ union {double f; uint64_t i;} u = {x};
- union {uint32_t u; int32_t i;} k;
-
- /* Filter out exceptional cases. */
-- GET_HIGH_WORD(hx, x);
-- ix = hx & 0x7fffffff;
-- if (ix >= 0x40900000) { /* |x| >= 1024 */
-- if (ix >= 0x7ff00000) {
-- GET_LOW_WORD(ix, x);
-- if (hx == 0xfff00000 && ix == 0) /* -inf */
-- return 0;
-- return x;
-- }
-- if (x >= 1024) {
-- STRICT_ASSIGN(double, x, x * 0x1p1023);
-+ ix = u.i>>32 & 0x7fffffff;
-+ if (ix >= 0x408ff000) { /* |x| >= 1022 or nan */
-+ if (ix >= 0x40900000 && u.i>>63 == 0) { /* x >= 1024 or nan */
-+ /* overflow */
-+ x *= 0x1p1023;
- return x;
- }
-- if (x <= -1075) {
-- STRICT_ASSIGN(double, x, 0x1p-1000*0x1p-1000);
-- return x;
-+ if (ix >= 0x7ff00000) /* -inf or -nan */
-+ return -1/x;
-+ if (u.i>>63) { /* x <= -1022 */
-+ /* underflow */
-+ if (x <= -1075 || x - 0x1p52 + 0x1p52 != x)
-+ FORCE_EVAL((float)(-0x1p-149/x));
-+ if (x <= -1075)
-+ return 0;
- }
- } else if (ix < 0x3c900000) { /* |x| < 0x1p-54 */
- return 1.0 + x;
- }
-
- /* Reduce x, computing z, i0, and k. */
-- STRICT_ASSIGN(double, t, x + redux);
-- GET_LOW_WORD(i0, t);
-+ u.f = x + redux;
-+ i0 = u.i;
- i0 += TBLSIZE / 2;
- k.u = i0 / TBLSIZE * TBLSIZE;
- k.i /= TBLSIZE;
- i0 %= TBLSIZE;
-- t -= redux;
-- z = x - t;
-+ u.f -= redux;
-+ z = x - u.f;
-
- /* Compute r = exp2(y) = exp2t[i0] * p(z - eps[i]). */
- t = tbl[2*i0]; /* exp2t[i0] */
-diff -Nur musl-0.9.13/src/math/exp2f.c musl-git/src/math/exp2f.c
---- musl-0.9.13/src/math/exp2f.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/exp2f.c 2013-09-16 20:31:39.000000000 +0200
-@@ -63,7 +63,7 @@
- * Method: (equally-spaced tables)
- *
- * Reduce x:
-- * x = 2**k + y, for integer k and |y| <= 1/2.
-+ * x = k + y, for integer k and |y| <= 1/2.
- * Thus we have exp2f(x) = 2**k * exp2(y).
- *
- * Reduce y:
-@@ -83,46 +83,42 @@
- */
- float exp2f(float x)
- {
-- double tv, twopk, u, z;
-- float t;
-- uint32_t hx, ix, i0, k;
-+ double_t t, r, z;
-+ union {float f; uint32_t i;} u = {x};
-+ union {double f; uint64_t i;} uk;
-+ uint32_t ix, i0, k;
-
- /* Filter out exceptional cases. */
-- GET_FLOAT_WORD(hx, x);
-- ix = hx & 0x7fffffff;
-- if (ix >= 0x43000000) { /* |x| >= 128 */
-- if (ix >= 0x7f800000) {
-- if (hx == 0xff800000) /* -inf */
-- return 0;
-- return x;
-- }
-- if (x >= 128) {
-- STRICT_ASSIGN(float, x, x * 0x1p127f);
-+ ix = u.i & 0x7fffffff;
-+ if (ix > 0x42fc0000) { /* |x| > 126 */
-+ if (u.i >= 0x43000000 && u.i < 0x80000000) { /* x >= 128 */
-+ x *= 0x1p127f;
- return x;
- }
-- if (x <= -150) {
-- STRICT_ASSIGN(float, x, 0x1p-100f*0x1p-100f);
-- return x;
-+ if (u.i >= 0x80000000) { /* x < -126 */
-+ if (u.i >= 0xc3160000 || (u.i & 0x0000ffff))
-+ FORCE_EVAL(-0x1p-149f/x);
-+ if (u.i >= 0xc3160000) /* x <= -150 */
-+ return 0;
- }
- } else if (ix <= 0x33000000) { /* |x| <= 0x1p-25 */
- return 1.0f + x;
- }
-
- /* Reduce x, computing z, i0, and k. */
-- STRICT_ASSIGN(float, t, x + redux);
-- GET_FLOAT_WORD(i0, t);
-+ u.f = x + redux;
-+ i0 = u.i;
- i0 += TBLSIZE / 2;
-- k = (i0 / TBLSIZE) << 20;
-+ k = i0 / TBLSIZE;
-+ uk.i = (uint64_t)(0x3ff + k)<<52;
- i0 &= TBLSIZE - 1;
-- t -= redux;
-- z = x - t;
-- INSERT_WORDS(twopk, 0x3ff00000 + k, 0);
--
-+ u.f -= redux;
-+ z = x - u.f;
- /* Compute r = exp2(y) = exp2ft[i0] * p(z). */
-- tv = exp2ft[i0];
-- u = tv * z;
-- tv = tv + u * (P1 + z * P2) + u * (z * z) * (P3 + z * P4);
-+ r = exp2ft[i0];
-+ t = r * z;
-+ r = r + t * (P1 + z * P2) + t * (z * z) * (P3 + z * P4);
-
-- /* Scale by 2**(k>>20). */
-- return tv * twopk;
-+ /* Scale by 2**k */
-+ return r * uk.f;
- }
-diff -Nur musl-0.9.13/src/math/exp2l.c musl-git/src/math/exp2l.c
---- musl-0.9.13/src/math/exp2l.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/exp2l.c 2013-09-16 20:31:39.000000000 +0200
-@@ -33,13 +33,9 @@
- return exp2(x);
- }
- #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
--
- #define TBLBITS 7
- #define TBLSIZE (1 << TBLBITS)
-
--#define BIAS (LDBL_MAX_EXP - 1)
--#define EXPMASK (BIAS + LDBL_MAX_EXP)
--
- static const double
- redux = 0x1.8p63 / TBLSIZE,
- P1 = 0x1.62e42fefa39efp-1,
-@@ -203,29 +199,29 @@
- */
- long double exp2l(long double x)
- {
-- union IEEEl2bits u, v;
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
- long double r, z;
-- uint32_t hx, ix, i0;
-+ uint32_t i0;
- union {uint32_t u; int32_t i;} k;
-
- /* Filter out exceptional cases. */
-- u.e = x;
-- hx = u.xbits.expsign;
-- ix = hx & EXPMASK;
-- if (ix >= BIAS + 14) { /* |x| >= 16384 or x is NaN */
-- if (ix == EXPMASK) {
-- if (u.xbits.man == 1ULL << 63 && hx == 0xffff) /* -inf */
-+ if (e >= 0x3fff + 13) { /* |x| >= 8192 or x is NaN */
-+ if (u.i.se >= 0x3fff + 14 && u.i.se >> 15 == 0)
-+ /* overflow */
-+ return x * 0x1p16383L;
-+ if (e == 0x7fff) /* -inf or -nan */
-+ return -1/x;
-+ if (x < -16382) {
-+ if (x <= -16446 || x - 0x1p63 + 0x1p63 != x)
-+ /* underflow */
-+ FORCE_EVAL((float)(-0x1p-149/x));
-+ if (x <= -16446)
- return 0;
-- return x;
-- }
-- if (x >= 16384) {
-- x *= 0x1p16383L;
-- return x;
- }
-- if (x <= -16446)
-- return 0x1p-10000L*0x1p-10000L;
-- } else if (ix < BIAS - 64) /* |x| < 0x1p-64 */
-+ } else if (e < 0x3fff - 64) {
- return 1 + x;
-+ }
-
- /*
- * Reduce x, computing z, i0, and k. The low bits of x + redux
-@@ -238,13 +234,13 @@
- * We split this into k = 0xabc and i0 = 0x12 (adjusted to
- * index into the table), then we compute z = 0x0.003456p0.
- */
-- u.e = x + redux;
-- i0 = u.bits.manl + TBLSIZE / 2;
-+ u.f = x + redux;
-+ i0 = u.i.m + TBLSIZE / 2;
- k.u = i0 / TBLSIZE * TBLSIZE;
- k.i /= TBLSIZE;
- i0 %= TBLSIZE;
-- u.e -= redux;
-- z = x - u.e;
-+ u.f -= redux;
-+ z = x - u.f;
-
- /* Compute r = exp2l(y) = exp2lt[i0] * p(z). */
- long double t_hi = tbl[2*i0];
-diff -Nur musl-0.9.13/src/math/expf.c musl-git/src/math/expf.c
---- musl-0.9.13/src/math/expf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/expf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -29,7 +29,7 @@
-
- float expf(float x)
- {
-- float hi, lo, c, xx;
-+ float_t hi, lo, c, xx, y;
- int k, sign;
- uint32_t hx;
-
-@@ -38,20 +38,17 @@
- hx &= 0x7fffffff; /* high word of |x| */
-
- /* special cases */
-- if (hx >= 0x42b17218) { /* if |x| >= 88.722839f or NaN */
-- if (hx > 0x7f800000) /* NaN */
-- return x;
-- if (!sign) {
-- /* overflow if x!=inf */
-- STRICT_ASSIGN(float, x, x * 0x1p127f);
-+ if (hx >= 0x42aeac50) { /* if |x| >= -87.33655f or NaN */
-+ if (hx >= 0x42b17218 && !sign) { /* x >= 88.722839f */
-+ /* overflow */
-+ x *= 0x1p127f;
- return x;
- }
-- if (hx == 0x7f800000) /* -inf */
-- return 0;
-- if (hx >= 0x42cff1b5) { /* x <= -103.972084f */
-+ if (sign) {
- /* underflow */
-- STRICT_ASSIGN(float, x, 0x1p-100f*0x1p-100f);
-- return x;
-+ FORCE_EVAL(-0x1p-149f/x);
-+ if (hx >= 0x42cff1b5) /* x <= -103.972084f */
-+ return 0;
- }
- }
-
-@@ -63,7 +60,7 @@
- k = 1 - sign - sign;
- hi = x - k*ln2hi; /* k*ln2hi is exact here */
- lo = k*ln2lo;
-- STRICT_ASSIGN(float, x, hi - lo);
-+ x = hi - lo;
- } else if (hx > 0x39000000) { /* |x| > 2**-14 */
- k = 0;
- hi = x;
-@@ -77,8 +74,8 @@
- /* x is now in primary range */
- xx = x*x;
- c = x - xx*(P1+xx*P2);
-- x = 1 + (x*c/(2-c) - lo + hi);
-+ y = 1 + (x*c/(2-c) - lo + hi);
- if (k == 0)
-- return x;
-- return scalbnf(x, k);
-+ return y;
-+ return scalbnf(y, k);
- }
-diff -Nur musl-0.9.13/src/math/expl.c musl-git/src/math/expl.c
---- musl-0.9.13/src/math/expl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/expl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -100,7 +100,7 @@
- if (x > 11356.5234062941439488L) /* x > ln(2^16384 - 0.5) */
- return x * 0x1p16383L;
- if (x < -11399.4985314888605581L) /* x < ln(2^-16446) */
-- return 0x1p-10000L * 0x1p-10000L;
-+ return -0x1p-16445L/x;
-
- /* Express e**x = e**f 2**k
- * = e**(f + k ln(2))
-diff -Nur musl-0.9.13/src/math/expm1.c musl-git/src/math/expm1.c
---- musl-0.9.13/src/math/expm1.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/expm1.c 2013-09-16 20:31:39.000000000 +0200
-@@ -31,7 +31,7 @@
- * R1(r**2) = 6/r *((exp(r)+1)/(exp(r)-1) - 2/r)
- * = 6/r * ( 1 + 2.0*(1/(exp(r)-1) - 1/r))
- * = 1 - r^2/60 + r^4/2520 - r^6/100800 + ...
-- * We use a special Reme algorithm on [0,0.347] to generate
-+ * We use a special Remez algorithm on [0,0.347] to generate
- * a polynomial of degree 5 in r*r to approximate R1. The
- * maximum error of this polynomial approximation is bounded
- * by 2**-61. In other words,
-@@ -107,8 +107,6 @@
- #include "libm.h"
-
- static const double
--huge = 1.0e+300,
--tiny = 1.0e-300,
- o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */
- ln2_hi = 6.93147180369123816490e-01, /* 0x3fe62e42, 0xfee00000 */
- ln2_lo = 1.90821492927058770002e-10, /* 0x3dea39ef, 0x35793c76 */
-@@ -122,39 +120,27 @@
-
- double expm1(double x)
- {
-- double y,hi,lo,c,t,e,hxs,hfx,r1,twopk;
-- int32_t k,xsb;
-- uint32_t hx;
--
-- GET_HIGH_WORD(hx, x);
-- xsb = hx&0x80000000; /* sign bit of x */
-- hx &= 0x7fffffff; /* high word of |x| */
-+ double_t y,hi,lo,c,t,e,hxs,hfx,r1,twopk;
-+ union {double f; uint64_t i;} u = {x};
-+ uint32_t hx = u.i>>32 & 0x7fffffff;
-+ int k, sign = u.i>>63;
-
- /* filter out huge and non-finite argument */
- if (hx >= 0x4043687A) { /* if |x|>=56*ln2 */
-- if (hx >= 0x40862E42) { /* if |x|>=709.78... */
-- if (hx >= 0x7ff00000) {
-- uint32_t low;
--
-- GET_LOW_WORD(low, x);
-- if (((hx&0xfffff)|low) != 0) /* NaN */
-- return x+x;
-- return xsb==0 ? x : -1.0; /* exp(+-inf)={inf,-1} */
-- }
-- if(x > o_threshold)
-- return huge*huge; /* overflow */
-- }
-- if (xsb != 0) { /* x < -56*ln2, return -1.0 with inexact */
-- /* raise inexact */
-- if(x+tiny<0.0)
-- return tiny-1.0; /* return -1 */
-+ if (isnan(x))
-+ return x;
-+ if (sign)
-+ return -1;
-+ if (x > o_threshold) {
-+ x *= 0x1p1023;
-+ return x;
- }
- }
-
- /* argument reduction */
- if (hx > 0x3fd62e42) { /* if |x| > 0.5 ln2 */
- if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */
-- if (xsb == 0) {
-+ if (!sign) {
- hi = x - ln2_hi;
- lo = ln2_lo;
- k = 1;
-@@ -164,17 +150,17 @@
- k = -1;
- }
- } else {
-- k = invln2*x + (xsb==0 ? 0.5 : -0.5);
-+ k = invln2*x + (sign ? -0.5 : 0.5);
- t = k;
- hi = x - t*ln2_hi; /* t*ln2_hi is exact here */
- lo = t*ln2_lo;
- }
-- STRICT_ASSIGN(double, x, hi - lo);
-+ x = hi-lo;
- c = (hi-x)-lo;
- } else if (hx < 0x3c900000) { /* |x| < 2**-54, return x */
-- /* raise inexact flags when x != 0 */
-- t = huge+x;
-- return x - (t-(huge+x));
-+ if (hx < 0x00100000)
-+ FORCE_EVAL((float)x);
-+ return x;
- } else
- k = 0;
-
-@@ -186,9 +172,9 @@
- e = hxs*((r1-t)/(6.0 - x*t));
- if (k == 0) /* c is 0 */
- return x - (x*e-hxs);
-- INSERT_WORDS(twopk, 0x3ff00000+(k<<20), 0); /* 2^k */
- e = x*(e-c) - c;
- e -= hxs;
-+ /* exp(x) ~ 2^k (x_reduced - e + 1) */
- if (k == -1)
- return 0.5*(x-e) - 0.5;
- if (k == 1) {
-@@ -196,24 +182,20 @@
- return -2.0*(e-(x+0.5));
- return 1.0+2.0*(x-e);
- }
-- if (k <= -2 || k > 56) { /* suffice to return exp(x)-1 */
-- y = 1.0 - (e-x);
-+ u.i = (uint64_t)(0x3ff + k)<<52; /* 2^k */
-+ twopk = u.f;
-+ if (k < 0 || k > 56) { /* suffice to return exp(x)-1 */
-+ y = x - e + 1.0;
- if (k == 1024)
- y = y*2.0*0x1p1023;
- else
- y = y*twopk;
- return y - 1.0;
- }
-- t = 1.0;
-- if (k < 20) {
-- SET_HIGH_WORD(t, 0x3ff00000 - (0x200000>>k)); /* t=1-2^-k */
-- y = t-(e-x);
-- y = y*twopk;
-- } else {
-- SET_HIGH_WORD(t, ((0x3ff-k)<<20)); /* 2^-k */
-- y = x-(e+t);
-- y += 1.0;
-- y = y*twopk;
-- }
-+ u.i = (uint64_t)(0x3ff - k)<<52; /* 2^-k */
-+ if (k < 20)
-+ y = (x-e+(1-u.f))*twopk;
-+ else
-+ y = (x-(e+u.f)+1)*twopk;
- return y;
- }
-diff -Nur musl-0.9.13/src/math/expm1f.c musl-git/src/math/expm1f.c
---- musl-0.9.13/src/math/expm1f.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/expm1f.c 2013-09-16 20:31:39.000000000 +0200
-@@ -16,8 +16,6 @@
- #include "libm.h"
-
- static const float
--huge = 1.0e+30,
--tiny = 1.0e-30,
- o_threshold = 8.8721679688e+01, /* 0x42b17180 */
- ln2_hi = 6.9313812256e-01, /* 0x3f317180 */
- ln2_lo = 9.0580006145e-06, /* 0x3717f7d1 */
-@@ -32,35 +30,27 @@
-
- float expm1f(float x)
- {
-- float y,hi,lo,c,t,e,hxs,hfx,r1,twopk;
-- int32_t k,xsb;
-- uint32_t hx;
--
-- GET_FLOAT_WORD(hx, x);
-- xsb = hx&0x80000000; /* sign bit of x */
-- hx &= 0x7fffffff; /* high word of |x| */
-+ float_t y,hi,lo,c,t,e,hxs,hfx,r1,twopk;
-+ union {float f; uint32_t i;} u = {x};
-+ uint32_t hx = u.i & 0x7fffffff;
-+ int k, sign = u.i >> 31;
-
- /* filter out huge and non-finite argument */
- if (hx >= 0x4195b844) { /* if |x|>=27*ln2 */
-- if (hx >= 0x42b17218) { /* if |x|>=88.721... */
-- if (hx > 0x7f800000) /* NaN */
-- return x+x;
-- if (hx == 0x7f800000) /* exp(+-inf)={inf,-1} */
-- return xsb==0 ? x : -1.0;
-- if (x > o_threshold)
-- return huge*huge; /* overflow */
-- }
-- if (xsb != 0) { /* x < -27*ln2 */
-- /* raise inexact */
-- if (x+tiny < 0.0f)
-- return tiny-1.0f; /* return -1 */
-+ if (hx > 0x7f800000) /* NaN */
-+ return x;
-+ if (sign)
-+ return -1;
-+ if (x > o_threshold) {
-+ x *= 0x1p127f;
-+ return x;
- }
- }
-
- /* argument reduction */
- if (hx > 0x3eb17218) { /* if |x| > 0.5 ln2 */
- if (hx < 0x3F851592) { /* and |x| < 1.5 ln2 */
-- if (xsb == 0) {
-+ if (!sign) {
- hi = x - ln2_hi;
- lo = ln2_lo;
- k = 1;
-@@ -70,16 +60,17 @@
- k = -1;
- }
- } else {
-- k = invln2*x + (xsb==0 ? 0.5f : -0.5f);
-+ k = invln2*x + (sign ? -0.5f : 0.5f);
- t = k;
- hi = x - t*ln2_hi; /* t*ln2_hi is exact here */
- lo = t*ln2_lo;
- }
-- STRICT_ASSIGN(float, x, hi - lo);
-+ x = hi-lo;
- c = (hi-x)-lo;
- } else if (hx < 0x33000000) { /* when |x|<2**-25, return x */
-- t = huge+x; /* return x with inexact flags when x!=0 */
-- return x - (t-(huge+x));
-+ if (hx < 0x00800000)
-+ FORCE_EVAL(x*x);
-+ return x;
- } else
- k = 0;
-
-@@ -91,9 +82,9 @@
- e = hxs*((r1-t)/(6.0f - x*t));
- if (k == 0) /* c is 0 */
- return x - (x*e-hxs);
-- SET_FLOAT_WORD(twopk, 0x3f800000+(k<<23)); /* 2^k */
- e = x*(e-c) - c;
- e -= hxs;
-+ /* exp(x) ~ 2^k (x_reduced - e + 1) */
- if (k == -1)
- return 0.5f*(x-e) - 0.5f;
- if (k == 1) {
-@@ -101,24 +92,20 @@
- return -2.0f*(e-(x+0.5f));
- return 1.0f + 2.0f*(x-e);
- }
-- if (k <= -2 || k > 56) { /* suffice to return exp(x)-1 */
-- y = 1.0f - (e - x);
-+ u.i = (0x7f+k)<<23; /* 2^k */
-+ twopk = u.f;
-+ if (k < 0 || k > 56) { /* suffice to return exp(x)-1 */
-+ y = x - e + 1.0f;
- if (k == 128)
- y = y*2.0f*0x1p127f;
- else
- y = y*twopk;
- return y - 1.0f;
- }
-- t = 1.0f;
-- if (k < 23) {
-- SET_FLOAT_WORD(t, 0x3f800000 - (0x1000000>>k)); /* t=1-2^-k */
-- y = t - (e - x);
-- y = y*twopk;
-- } else {
-- SET_FLOAT_WORD(t, (0x7f-k)<<23); /* 2^-k */
-- y = x - (e + t);
-- y += 1.0f;
-- y = y*twopk;
-- }
-+ u.i = (0x7f-k)<<23; /* 2^-k */
-+ if (k < 23)
-+ y = (x-e+(1-u.f))*twopk;
-+ else
-+ y = (x-(e+u.f)+1)*twopk;
- return y;
- }
-diff -Nur musl-0.9.13/src/math/fabs.c musl-git/src/math/fabs.c
---- musl-0.9.13/src/math/fabs.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fabs.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,10 +1,9 @@
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- double fabs(double x)
- {
-- union dshape u;
--
-- u.value = x;
-- u.bits &= (uint64_t)-1 / 2;
-- return u.value;
-+ union {double f; uint64_t i;} u = {x};
-+ u.i &= -1ULL/2;
-+ return u.f;
- }
-diff -Nur musl-0.9.13/src/math/fabsf.c musl-git/src/math/fabsf.c
---- musl-0.9.13/src/math/fabsf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fabsf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,10 +1,9 @@
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- float fabsf(float x)
- {
-- union fshape u;
--
-- u.value = x;
-- u.bits &= (uint32_t)-1 / 2;
-- return u.value;
-+ union {float f; uint32_t i;} u = {x};
-+ u.i &= 0x7fffffff;
-+ return u.f;
- }
-diff -Nur musl-0.9.13/src/math/fabsl.c musl-git/src/math/fabsl.c
---- musl-0.9.13/src/math/fabsl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fabsl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -9,7 +9,7 @@
- {
- union ldshape u = {x};
-
-- u.bits.sign = 0;
-- return u.value;
-+ u.i.se &= 0x7fff;
-+ return u.f;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/floor.c musl-git/src/math/floor.c
---- musl-0.9.13/src/math/floor.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/floor.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,82 +1,24 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_floor.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * floor(x)
-- * Return x rounded toward -inf to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to floor(x).
-- */
--
- #include "libm.h"
-
--static const double huge = 1.0e300;
--
- double floor(double x)
- {
-- int32_t i0,i1,j0;
-- uint32_t i,j;
-+ union {double f; uint64_t i;} u = {x};
-+ int e = u.i >> 52 & 0x7ff;
-+ double_t y;
-
-- EXTRACT_WORDS(i0, i1, x);
-- // FIXME: signed shift
-- j0 = ((i0>>20)&0x7ff) - 0x3ff;
-- if (j0 < 20) {
-- if (j0 < 0) { /* |x| < 1 */
-- /* raise inexact if x != 0 */
-- if (huge+x > 0.0) {
-- if (i0 >= 0) { /* x >= 0 */
-- i0 = i1 = 0;
-- } else if (((i0&0x7fffffff)|i1) != 0) {
-- i0 = 0xbff00000;
-- i1 = 0;
-- }
-- }
-- } else {
-- i = 0x000fffff>>j0;
-- if (((i0&i)|i1) == 0)
-- return x; /* x is integral */
-- /* raise inexact flag */
-- if (huge+x > 0.0) {
-- if (i0 < 0)
-- i0 += 0x00100000>>j0;
-- i0 &= ~i;
-- i1 = 0;
-- }
-- }
-- } else if (j0 > 51) {
-- if (j0 == 0x400)
-- return x+x; /* inf or NaN */
-- else
-- return x; /* x is integral */
-- } else {
-- i = (uint32_t)0xffffffff>>(j0-20);
-- if ((i1&i) == 0)
-- return x; /* x is integral */
-- /* raise inexact flag */
-- if (huge+x > 0.0) {
-- if (i0 < 0) {
-- if (j0 == 20)
-- i0++;
-- else {
-- j = i1+(1<<(52-j0));
-- if (j < i1)
-- i0++; /* got a carry */
-- i1 = j;
-- }
-- }
-- i1 &= ~i;
-- }
-+ if (e >= 0x3ff+52 || x == 0)
-+ return x;
-+ /* y = int(x) - x, where int(x) is an integer neighbor of x */
-+ if (u.i >> 63)
-+ y = (double)(x - 0x1p52) + 0x1p52 - x;
-+ else
-+ y = (double)(x + 0x1p52) - 0x1p52 - x;
-+ /* special case because of non-nearest rounding modes */
-+ if (e <= 0x3ff-1) {
-+ FORCE_EVAL(y);
-+ return u.i >> 63 ? -1 : 0;
- }
-- INSERT_WORDS(x, i0, i1);
-- return x;
-+ if (y > 0)
-+ return x + y - 1;
-+ return x + y;
- }
-diff -Nur musl-0.9.13/src/math/floorf.c musl-git/src/math/floorf.c
---- musl-0.9.13/src/math/floorf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/floorf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,64 +1,27 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_floorf.c */
--/*
-- * Conversion to float by Ian Lance Taylor, Cygnus Support, ian@cygnus.com.
-- */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * floorf(x)
-- * Return x rounded toward -inf to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to floorf(x).
-- */
--
- #include "libm.h"
-
--static const float huge = 1.0e30;
--
- float floorf(float x)
- {
-- int32_t i0,j0;
-- uint32_t i;
-+ union {float f; uint32_t i;} u = {x};
-+ int e = (int)(u.i >> 23 & 0xff) - 0x7f;
-+ uint32_t m;
-
-- GET_FLOAT_WORD(i0, x);
-- // FIXME: signed shift
-- j0 = ((i0>>23)&0xff) - 0x7f;
-- if (j0 < 23) {
-- if (j0 < 0) { /* |x| < 1 */
-- /* raise inexact if x != 0 */
-- if (huge+x > 0.0f) {
-- if (i0 >= 0) /* x >= 0 */
-- i0 = 0;
-- else if ((i0&0x7fffffff) != 0)
-- i0 = 0xbf800000;
-- }
-- } else {
-- i = 0x007fffff>>j0;
-- if ((i0&i) == 0)
-- return x; /* x is integral */
-- /* raise inexact flag */
-- if (huge+x > 0.0f) {
-- if (i0 < 0)
-- i0 += 0x00800000>>j0;
-- i0 &= ~i;
-- }
-- }
-+ if (e >= 23)
-+ return x;
-+ if (e >= 0) {
-+ m = 0x007fffff >> e;
-+ if ((u.i & m) == 0)
-+ return x;
-+ FORCE_EVAL(x + 0x1p120f);
-+ if (u.i >> 31)
-+ u.i += m;
-+ u.i &= ~m;
- } else {
-- if (j0 == 0x80) /* inf or NaN */
-- return x+x;
-- else
-- return x; /* x is integral */
-+ FORCE_EVAL(x + 0x1p120f);
-+ if (u.i >> 31 == 0)
-+ u.i = 0;
-+ else if (u.i << 1)
-+ u.f = -1.0;
- }
-- SET_FLOAT_WORD(x, i0);
-- return x;
-+ return u.f;
- }
-diff -Nur musl-0.9.13/src/math/floorl.c musl-git/src/math/floorl.c
---- musl-0.9.13/src/math/floorl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/floorl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,23 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_floorl.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * floorl(x)
-- * Return x rounded toward -inf to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to floorl(x).
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -26,77 +6,31 @@
- return floor(x);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#ifdef LDBL_IMPLICIT_NBIT
--#define MANH_SIZE (LDBL_MANH_SIZE + 1)
--#define INC_MANH(u, c) do { \
-- uint64_t o = u.bits.manh; \
-- u.bits.manh += (c); \
-- if (u.bits.manh < o) \
-- u.bits.exp++; \
--} while (0)
--#else
--#define MANH_SIZE LDBL_MANH_SIZE
--#define INC_MANH(u, c) do { \
-- uint64_t o = u.bits.manh; \
-- u.bits.manh += (c); \
-- if (u.bits.manh < o) { \
-- u.bits.exp++; \
-- u.bits.manh |= 1llu << (LDBL_MANH_SIZE - 1); \
-- } \
--} while (0)
-+#if LDBL_MANT_DIG == 64
-+#define TOINT 0x1p63
-+#elif LDBL_MANT_DIG == 113
-+#define TOINT 0x1p112
- #endif
--
--static const long double huge = 1.0e300;
--
- long double floorl(long double x)
- {
-- union IEEEl2bits u = { .e = x };
-- int e = u.bits.exp - LDBL_MAX_EXP + 1;
--
-- if (e < MANH_SIZE - 1) {
-- if (e < 0) {
-- /* raise inexact if x != 0 */
-- if (huge + x > 0.0)
-- if (u.bits.exp > 0 ||
-- (u.bits.manh | u.bits.manl) != 0)
-- u.e = u.bits.sign ? -1.0 : 0.0;
-- } else {
-- uint64_t m = ((1llu << MANH_SIZE) - 1) >> (e + 1);
-- if (((u.bits.manh & m) | u.bits.manl) == 0)
-- return x; /* x is integral */
-- if (u.bits.sign) {
--#ifdef LDBL_IMPLICIT_NBIT
-- if (e == 0)
-- u.bits.exp++;
-- else
--#endif
-- INC_MANH(u, 1llu << (MANH_SIZE - e - 1));
-- }
-- /* raise inexact flag */
-- if (huge + x > 0.0) {
-- u.bits.manh &= ~m;
-- u.bits.manl = 0;
-- }
-- }
-- } else if (e < LDBL_MANT_DIG - 1) {
-- uint64_t m = (uint64_t)-1 >> (64 - LDBL_MANT_DIG + e + 1);
-- if ((u.bits.manl & m) == 0)
-- return x; /* x is integral */
-- if (u.bits.sign) {
-- if (e == MANH_SIZE - 1)
-- INC_MANH(u, 1);
-- else {
-- uint64_t o = u.bits.manl;
-- u.bits.manl += 1llu << (LDBL_MANT_DIG - e - 1);
-- if (u.bits.manl < o) /* got a carry */
-- INC_MANH(u, 1);
-- }
-- }
-- /* raise inexact flag */
-- if (huge + x > 0.0)
-- u.bits.manl &= ~m;
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-+ long double y;
-+
-+ if (e >= 0x3fff+LDBL_MANT_DIG-1 || x == 0)
-+ return x;
-+ /* y = int(x) - x, where int(x) is an integer neighbor of x */
-+ if (u.i.se >> 15)
-+ y = x - TOINT + TOINT - x;
-+ else
-+ y = x + TOINT - TOINT - x;
-+ /* special case because of non-nearest rounding modes */
-+ if (e <= 0x3fff-1) {
-+ FORCE_EVAL(y);
-+ return u.i.se >> 15 ? -1 : 0;
- }
-- return u.e;
-+ if (y > 0)
-+ return x + y - 1;
-+ return x + y;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/fma.c musl-git/src/math/fma.c
---- musl-0.9.13/src/math/fma.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fma.c 2013-09-16 20:31:39.000000000 +0200
-@@ -2,16 +2,6 @@
- #include "libm.h"
-
- #if LDBL_MANT_DIG==64 && LDBL_MAX_EXP==16384
--union ld80 {
-- long double x;
-- struct {
-- uint64_t m;
-- uint16_t e : 15;
-- uint16_t s : 1;
-- uint16_t pad;
-- } bits;
--};
--
- /* exact add, assumes exponent_x >= exponent_y */
- static void add(long double *hi, long double *lo, long double x, long double y)
- {
-@@ -45,25 +35,25 @@
- */
- static long double adjust(long double hi, long double lo)
- {
-- union ld80 uhi, ulo;
-+ union ldshape uhi, ulo;
-
- if (lo == 0)
- return hi;
-- uhi.x = hi;
-- if (uhi.bits.m & 0x3ff)
-+ uhi.f = hi;
-+ if (uhi.i.m & 0x3ff)
- return hi;
-- ulo.x = lo;
-- if (uhi.bits.s == ulo.bits.s)
-- uhi.bits.m++;
-+ ulo.f = lo;
-+ if ((uhi.i.se & 0x8000) == (ulo.i.se & 0x8000))
-+ uhi.i.m++;
- else {
-- uhi.bits.m--;
- /* handle underflow and take care of ld80 implicit msb */
-- if (uhi.bits.m == (uint64_t)-1/2) {
-- uhi.bits.m *= 2;
-- uhi.bits.e--;
-+ if (uhi.i.m << 1 == 0) {
-+ uhi.i.m = 0;
-+ uhi.i.se--;
- }
-+ uhi.i.m--;
- }
-- return uhi.x;
-+ return uhi.f;
- }
-
- /* adjusted add so the result is correct when rounded to double (or less) precision */
-@@ -82,9 +72,9 @@
-
- static int getexp(long double x)
- {
-- union ld80 u;
-- u.x = x;
-- return u.bits.e;
-+ union ldshape u;
-+ u.f = x;
-+ return u.i.se & 0x7fff;
- }
-
- double fma(double x, double y, double z)
-@@ -242,16 +232,16 @@
- static inline double add_adjusted(double a, double b)
- {
- struct dd sum;
-- uint64_t hibits, lobits;
-+ union {double f; uint64_t i;} uhi, ulo;
-
- sum = dd_add(a, b);
- if (sum.lo != 0) {
-- EXTRACT_WORD64(hibits, sum.hi);
-- if ((hibits & 1) == 0) {
-+ uhi.f = sum.hi;
-+ if ((uhi.i & 1) == 0) {
- /* hibits += (int)copysign(1.0, sum.hi * sum.lo) */
-- EXTRACT_WORD64(lobits, sum.lo);
-- hibits += 1 - ((hibits ^ lobits) >> 62);
-- INSERT_WORD64(sum.hi, hibits);
-+ ulo.f = sum.lo;
-+ uhi.i += 1 - ((uhi.i ^ ulo.i) >> 62);
-+ sum.hi = uhi.f;
- }
- }
- return (sum.hi);
-@@ -265,7 +255,7 @@
- static inline double add_and_denormalize(double a, double b, int scale)
- {
- struct dd sum;
-- uint64_t hibits, lobits;
-+ union {double f; uint64_t i;} uhi, ulo;
- int bits_lost;
-
- sum = dd_add(a, b);
-@@ -281,13 +271,13 @@
- * break the ties manually.
- */
- if (sum.lo != 0) {
-- EXTRACT_WORD64(hibits, sum.hi);
-- bits_lost = -((int)(hibits >> 52) & 0x7ff) - scale + 1;
-- if (bits_lost != 1 ^ (int)(hibits & 1)) {
-+ uhi.f = sum.hi;
-+ bits_lost = -((int)(uhi.i >> 52) & 0x7ff) - scale + 1;
-+ if (bits_lost != 1 ^ (int)(uhi.i & 1)) {
- /* hibits += (int)copysign(1.0, sum.hi * sum.lo) */
-- EXTRACT_WORD64(lobits, sum.lo);
-- hibits += 1 - (((hibits ^ lobits) >> 62) & 2);
-- INSERT_WORD64(sum.hi, hibits);
-+ ulo.f = sum.lo;
-+ uhi.i += 1 - (((uhi.i ^ ulo.i) >> 62) & 2);
-+ sum.hi = uhi.f;
- }
- }
- return scalbn(sum.hi, scale);
-diff -Nur musl-0.9.13/src/math/fmal.c musl-git/src/math/fmal.c
---- musl-0.9.13/src/math/fmal.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fmal.c 2013-09-16 20:31:39.000000000 +0200
-@@ -34,6 +34,13 @@
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- #include <fenv.h>
-+#if LDBL_MANT_DIG == 64
-+#define LASTBIT(u) (u.i.m & 1)
-+#define SPLIT (0x1p32L + 1)
-+#elif LDBL_MANT_DIG == 113
-+#define LASTBIT(u) (u.i.lo & 1)
-+#define SPLIT (0x1p57L + 1)
-+#endif
-
- /*
- * A struct dd represents a floating-point number with twice the precision
-@@ -75,12 +82,12 @@
- static inline long double add_adjusted(long double a, long double b)
- {
- struct dd sum;
-- union IEEEl2bits u;
-+ union ldshape u;
-
- sum = dd_add(a, b);
- if (sum.lo != 0) {
-- u.e = sum.hi;
-- if ((u.bits.manl & 1) == 0)
-+ u.f = sum.hi;
-+ if (!LASTBIT(u))
- sum.hi = nextafterl(sum.hi, INFINITY * sum.lo);
- }
- return (sum.hi);
-@@ -95,7 +102,7 @@
- {
- struct dd sum;
- int bits_lost;
-- union IEEEl2bits u;
-+ union ldshape u;
-
- sum = dd_add(a, b);
-
-@@ -110,9 +117,9 @@
- * break the ties manually.
- */
- if (sum.lo != 0) {
-- u.e = sum.hi;
-- bits_lost = -u.bits.exp - scale + 1;
-- if (bits_lost != 1 ^ (int)(u.bits.manl & 1))
-+ u.f = sum.hi;
-+ bits_lost = -u.i.se - scale + 1;
-+ if ((bits_lost != 1) ^ LASTBIT(u))
- sum.hi = nextafterl(sum.hi, INFINITY * sum.lo);
- }
- return scalbnl(sum.hi, scale);
-@@ -125,20 +132,15 @@
- */
- static inline struct dd dd_mul(long double a, long double b)
- {
--#if LDBL_MANT_DIG == 64
-- static const long double split = 0x1p32L + 1.0;
--#elif LDBL_MANT_DIG == 113
-- static const long double split = 0x1p57L + 1.0;
--#endif
- struct dd ret;
- long double ha, hb, la, lb, p, q;
-
-- p = a * split;
-+ p = a * SPLIT;
- ha = a - p;
- ha += p;
- la = a - ha;
-
-- p = b * split;
-+ p = b * SPLIT;
- hb = b - p;
- hb += p;
- lb = b - hb;
-diff -Nur musl-0.9.13/src/math/fmod.c musl-git/src/math/fmod.c
---- musl-0.9.13/src/math/fmod.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fmod.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,145 +1,68 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_fmod.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * fmod(x,y)
-- * Return x mod y in exact arithmetic
-- * Method: shift and subtract
-- */
--
--#include "libm.h"
--
--static const double Zero[] = {0.0, -0.0,};
-+#include <math.h>
-+#include <stdint.h>
-
- double fmod(double x, double y)
- {
-- int32_t n,hx,hy,hz,ix,iy,sx,i;
-- uint32_t lx,ly,lz;
-+ union {double f; uint64_t i;} ux = {x}, uy = {y};
-+ int ex = ux.i>>52 & 0x7ff;
-+ int ey = uy.i>>52 & 0x7ff;
-+ int sx = ux.i>>63;
-+ uint64_t i;
-+
-+ /* in the followings uxi should be ux.i, but then gcc wrongly adds */
-+ /* float load/store to inner loops ruining performance and code size */
-+ uint64_t uxi = ux.i;
-
-- EXTRACT_WORDS(hx, lx, x);
-- EXTRACT_WORDS(hy, ly, y);
-- sx = hx & 0x80000000; /* sign of x */
-- hx ^= sx; /* |x| */
-- hy &= 0x7fffffff; /* |y| */
--
-- /* purge off exception values */
-- if ((hy|ly) == 0 || hx >= 0x7ff00000 || /* y=0,or x not finite */
-- (hy|((ly|-ly)>>31)) > 0x7ff00000) /* or y is NaN */
-+ if (uy.i<<1 == 0 || isnan(y) || ex == 0x7ff)
- return (x*y)/(x*y);
-- if (hx <= hy) {
-- if (hx < hy || lx < ly) /* |x| < |y| */
-- return x;
-- if (lx == ly) /* |x| = |y|, return x*0 */
-- return Zero[(uint32_t)sx>>31];
-- }
--
-- /* determine ix = ilogb(x) */
-- if (hx < 0x00100000) { /* subnormal x */
-- if (hx == 0) {
-- for (ix = -1043, i = lx; i > 0; i <<= 1)
-- ix -= 1;
-- } else {
-- for (ix = -1022, i = hx<<11; i > 0; i <<= 1)
-- ix -= 1;
-- }
-- } else
-- ix = (hx>>20) - 1023;
--
-- /* determine iy = ilogb(y) */
-- if (hy < 0x00100000) { /* subnormal y */
-- if (hy == 0) {
-- for (iy = -1043, i = ly; i > 0; i <<= 1)
-- iy -= 1;
-- } else {
-- for (iy = -1022, i = hy<<11; i > 0; i <<= 1)
-- iy -= 1;
-- }
-- } else
-- iy = (hy>>20) - 1023;
--
-- /* set up {hx,lx}, {hy,ly} and align y to x */
-- if (ix >= -1022)
-- hx = 0x00100000|(0x000fffff&hx);
-- else { /* subnormal x, shift x to normal */
-- n = -1022-ix;
-- if (n <= 31) {
-- hx = (hx<<n)|(lx>>(32-n));
-- lx <<= n;
-- } else {
-- hx = lx<<(n-32);
-- lx = 0;
-- }
-- }
-- if(iy >= -1022)
-- hy = 0x00100000|(0x000fffff&hy);
-- else { /* subnormal y, shift y to normal */
-- n = -1022-iy;
-- if (n <= 31) {
-- hy = (hy<<n)|(ly>>(32-n));
-- ly <<= n;
-- } else {
-- hy = ly<<(n-32);
-- ly = 0;
-- }
-- }
--
-- /* fix point fmod */
-- n = ix - iy;
-- while (n--) {
-- hz = hx-hy;
-- lz = lx-ly;
-- if (lx < ly)
-- hz -= 1;
-- if (hz < 0) {
-- hx = hx+hx+(lx>>31);
-- lx = lx+lx;
-- } else {
-- if ((hz|lz) == 0) /* return sign(x)*0 */
-- return Zero[(uint32_t)sx>>31];
-- hx = hz+hz+(lz>>31);
-- lx = lz+lz;
-- }
-- }
-- hz = hx-hy;
-- lz = lx-ly;
-- if (lx < ly)
-- hz -= 1;
-- if (hz >= 0) {
-- hx = hz;
-- lx = lz;
-- }
--
-- /* convert back to floating value and restore the sign */
-- if ((hx|lx) == 0) /* return sign(x)*0 */
-- return Zero[(uint32_t)sx>>31];
-- while (hx < 0x00100000) { /* normalize x */
-- hx = hx+hx+(lx>>31);
-- lx = lx+lx;
-- iy -= 1;
-- }
-- if (iy >= -1022) { /* normalize output */
-- hx = ((hx-0x00100000)|((iy+1023)<<20));
-- INSERT_WORDS(x, hx|sx, lx);
-- } else { /* subnormal output */
-- n = -1022 - iy;
-- if (n <= 20) {
-- lx = (lx>>n)|((uint32_t)hx<<(32-n));
-- hx >>= n;
-- } else if (n <= 31) {
-- lx = (hx<<(32-n))|(lx>>n);
-- hx = sx;
-- } else {
-- lx = hx>>(n-32); hx = sx;
-- }
-- INSERT_WORDS(x, hx|sx, lx);
-- }
-- return x; /* exact output */
-+ if (uxi<<1 <= uy.i<<1) {
-+ if (uxi<<1 == uy.i<<1)
-+ return 0*x;
-+ return x;
-+ }
-+
-+ /* normalize x and y */
-+ if (!ex) {
-+ for (i = uxi<<12; i>>63 == 0; ex--, i <<= 1);
-+ uxi <<= -ex + 1;
-+ } else {
-+ uxi &= -1ULL >> 12;
-+ uxi |= 1ULL << 52;
-+ }
-+ if (!ey) {
-+ for (i = uy.i<<12; i>>63 == 0; ey--, i <<= 1);
-+ uy.i <<= -ey + 1;
-+ } else {
-+ uy.i &= -1ULL >> 12;
-+ uy.i |= 1ULL << 52;
-+ }
-+
-+ /* x mod y */
-+ for (; ex > ey; ex--) {
-+ i = uxi - uy.i;
-+ if (i >> 63 == 0) {
-+ if (i == 0)
-+ return 0*x;
-+ uxi = i;
-+ }
-+ uxi <<= 1;
-+ }
-+ i = uxi - uy.i;
-+ if (i >> 63 == 0) {
-+ if (i == 0)
-+ return 0*x;
-+ uxi = i;
-+ }
-+ for (; uxi>>52 == 0; uxi <<= 1, ex--);
-+
-+ /* scale result */
-+ if (ex > 0) {
-+ uxi -= 1ULL << 52;
-+ uxi |= (uint64_t)ex << 52;
-+ } else {
-+ uxi >>= -ex + 1;
-+ }
-+ uxi |= (uint64_t)sx << 63;
-+ ux.i = uxi;
-+ return ux.f;
- }
-diff -Nur musl-0.9.13/src/math/fmodf.c musl-git/src/math/fmodf.c
---- musl-0.9.13/src/math/fmodf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fmodf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,104 +1,65 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_fmodf.c */
--/*
-- * Conversion to float by Ian Lance Taylor, Cygnus Support, ian@cygnus.com.
-- */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * fmodf(x,y)
-- * Return x mod y in exact arithmetic
-- * Method: shift and subtract
-- */
--
--#include "libm.h"
--
--static const float Zero[] = {0.0, -0.0,};
-+#include <math.h>
-+#include <stdint.h>
-
- float fmodf(float x, float y)
- {
-- int32_t n,hx,hy,hz,ix,iy,sx,i;
-+ union {float f; uint32_t i;} ux = {x}, uy = {y};
-+ int ex = ux.i>>23 & 0xff;
-+ int ey = uy.i>>23 & 0xff;
-+ uint32_t sx = ux.i & 0x80000000;
-+ uint32_t i;
-+ uint32_t uxi = ux.i;
-
-- GET_FLOAT_WORD(hx, x);
-- GET_FLOAT_WORD(hy, y);
-- sx = hx & 0x80000000; /* sign of x */
-- hx ^= sx; /* |x| */
-- hy &= 0x7fffffff; /* |y| */
--
-- /* purge off exception values */
-- if (hy == 0 || hx >= 0x7f800000 || /* y=0,or x not finite */
-- hy > 0x7f800000) /* or y is NaN */
-+ if (uy.i<<1 == 0 || isnan(y) || ex == 0xff)
- return (x*y)/(x*y);
-- if (hx < hy) /* |x| < |y| */
-+ if (uxi<<1 <= uy.i<<1) {
-+ if (uxi<<1 == uy.i<<1)
-+ return 0*x;
- return x;
-- if (hx == hy) /* |x| = |y|, return x*0 */
-- return Zero[(uint32_t)sx>>31];
--
-- /* determine ix = ilogb(x) */
-- if (hx < 0x00800000) { /* subnormal x */
-- for (ix = -126, i = hx<<8; i > 0; i <<= 1)
-- ix -= 1;
-- } else
-- ix = (hx>>23) - 127;
--
-- /* determine iy = ilogb(y) */
-- if (hy < 0x00800000) { /* subnormal y */
-- for (iy = -126, i = hy<<8; i >= 0; i <<= 1)
-- iy -= 1;
-- } else
-- iy = (hy>>23) - 127;
-+ }
-
-- /* set up {hx,lx}, {hy,ly} and align y to x */
-- if (ix >= -126)
-- hx = 0x00800000|(0x007fffff&hx);
-- else { /* subnormal x, shift x to normal */
-- n = -126-ix;
-- hx = hx<<n;
-- }
-- if (iy >= -126)
-- hy = 0x00800000|(0x007fffff&hy);
-- else { /* subnormal y, shift y to normal */
-- n = -126-iy;
-- hy = hy<<n;
-+ /* normalize x and y */
-+ if (!ex) {
-+ for (i = uxi<<9; i>>31 == 0; ex--, i <<= 1);
-+ uxi <<= -ex + 1;
-+ } else {
-+ uxi &= -1U >> 9;
-+ uxi |= 1U << 23;
-+ }
-+ if (!ey) {
-+ for (i = uy.i<<9; i>>31 == 0; ey--, i <<= 1);
-+ uy.i <<= -ey + 1;
-+ } else {
-+ uy.i &= -1U >> 9;
-+ uy.i |= 1U << 23;
- }
-
-- /* fix point fmod */
-- n = ix - iy;
-- while (n--) {
-- hz = hx-hy;
-- if (hz<0)
-- hx = hx+hx;
-- else {
-- if(hz == 0) /* return sign(x)*0 */
-- return Zero[(uint32_t)sx>>31];
-- hx = hz+hz;
-+ /* x mod y */
-+ for (; ex > ey; ex--) {
-+ i = uxi - uy.i;
-+ if (i >> 31 == 0) {
-+ if (i == 0)
-+ return 0*x;
-+ uxi = i;
- }
-+ uxi <<= 1;
-+ }
-+ i = uxi - uy.i;
-+ if (i >> 31 == 0) {
-+ if (i == 0)
-+ return 0*x;
-+ uxi = i;
- }
-- hz = hx-hy;
-- if (hz >= 0)
-- hx = hz;
-+ for (; uxi>>23 == 0; uxi <<= 1, ex--);
-
-- /* convert back to floating value and restore the sign */
-- if (hx == 0) /* return sign(x)*0 */
-- return Zero[(uint32_t)sx>>31];
-- while (hx < 0x00800000) { /* normalize x */
-- hx = hx+hx;
-- iy -= 1;
-- }
-- if (iy >= -126) { /* normalize output */
-- hx = ((hx-0x00800000)|((iy+127)<<23));
-- SET_FLOAT_WORD(x, hx|sx);
-- } else { /* subnormal output */
-- n = -126 - iy;
-- hx >>= n;
-- SET_FLOAT_WORD(x, hx|sx);
-+ /* scale result up */
-+ if (ex > 0) {
-+ uxi -= 1U << 23;
-+ uxi |= (uint32_t)ex << 23;
-+ } else {
-+ uxi >>= -ex + 1;
- }
-- return x; /* exact output */
-+ uxi |= sx;
-+ ux.i = uxi;
-+ return ux.f;
- }
-diff -Nur musl-0.9.13/src/math/fmodl.c musl-git/src/math/fmodl.c
---- musl-0.9.13/src/math/fmodl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/fmodl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,15 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_fmodl.c */
--/*-
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -18,141 +6,100 @@
- return fmod(x, y);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#define BIAS (LDBL_MAX_EXP - 1)
--
--#if LDBL_MANL_SIZE > 32
--typedef uint64_t manl_t;
--#else
--typedef uint32_t manl_t;
--#endif
--
--#if LDBL_MANH_SIZE > 32
--typedef uint64_t manh_t;
--#else
--typedef uint32_t manh_t;
--#endif
--
--/*
-- * These macros add and remove an explicit integer bit in front of the
-- * fractional mantissa, if the architecture doesn't have such a bit by
-- * default already.
-- */
--#ifdef LDBL_IMPLICIT_NBIT
--#define SET_NBIT(hx) ((hx) | (1ULL << LDBL_MANH_SIZE))
--#define HFRAC_BITS LDBL_MANH_SIZE
--#else
--#define SET_NBIT(hx) (hx)
--#define HFRAC_BITS (LDBL_MANH_SIZE - 1)
--#endif
--
--#define MANL_SHIFT (LDBL_MANL_SIZE - 1)
--
--static const long double Zero[] = {0.0, -0.0,};
--
--/*
-- * fmodl(x,y)
-- * Return x mod y in exact arithmetic
-- * Method: shift and subtract
-- *
-- * Assumptions:
-- * - The low part of the mantissa fits in a manl_t exactly.
-- * - The high part of the mantissa fits in an int64_t with enough room
-- * for an explicit integer bit in front of the fractional bits.
-- */
- long double fmodl(long double x, long double y)
- {
-- union IEEEl2bits ux, uy;
-- int64_t hx,hz; /* We need a carry bit even if LDBL_MANH_SIZE is 32. */
-- manh_t hy;
-- manl_t lx,ly,lz;
-- int ix,iy,n,sx;
--
-- ux.e = x;
-- uy.e = y;
-- sx = ux.bits.sign;
-+ union ldshape ux = {x}, uy = {y};
-+ int ex = ux.i.se & 0x7fff;
-+ int ey = uy.i.se & 0x7fff;
-+ int sx = ux.i.se & 0x8000;
-
-- /* purge off exception values */
-- if ((uy.bits.exp|uy.bits.manh|uy.bits.manl) == 0 || /* y=0 */
-- ux.bits.exp == BIAS + LDBL_MAX_EXP || /* or x not finite */
-- (uy.bits.exp == BIAS + LDBL_MAX_EXP &&
-- ((uy.bits.manh&~LDBL_NBIT)|uy.bits.manl) != 0)) /* or y is NaN */
-+ if (y == 0 || isnan(y) || ex == 0x7fff)
- return (x*y)/(x*y);
-- if (ux.bits.exp <= uy.bits.exp) {
-- if (ux.bits.exp < uy.bits.exp ||
-- (ux.bits.manh<=uy.bits.manh &&
-- (ux.bits.manh<uy.bits.manh ||
-- ux.bits.manl<uy.bits.manl))) /* |x|<|y| return x or x-y */
-- return x;
-- if (ux.bits.manh==uy.bits.manh && ux.bits.manl==uy.bits.manl)
-- return Zero[sx]; /* |x| = |y| return x*0 */
-- }
--
-- /* determine ix = ilogb(x) */
-- if (ux.bits.exp == 0) { /* subnormal x */
-- ux.e *= 0x1.0p512;
-- ix = ux.bits.exp - (BIAS + 512);
-- } else {
-- ix = ux.bits.exp - BIAS;
-- }
--
-- /* determine iy = ilogb(y) */
-- if (uy.bits.exp == 0) { /* subnormal y */
-- uy.e *= 0x1.0p512;
-- iy = uy.bits.exp - (BIAS + 512);
-- } else {
-- iy = uy.bits.exp - BIAS;
-- }
--
-- /* set up {hx,lx}, {hy,ly} and align y to x */
-- hx = SET_NBIT(ux.bits.manh);
-- hy = SET_NBIT(uy.bits.manh);
-- lx = ux.bits.manl;
-- ly = uy.bits.manl;
--
-- /* fix point fmod */
-- n = ix - iy;
--
-- while (n--) {
-- hz = hx-hy;
-- lz = lx-ly;
-- if (lx < ly)
-- hz -= 1;
-- if (hz < 0) {
-- hx = hx+hx+(lx>>MANL_SHIFT);
-- lx = lx+lx;
-+ ux.i.se = ex;
-+ uy.i.se = ey;
-+ if (ux.f <= uy.f) {
-+ if (ux.f == uy.f)
-+ return 0*x;
-+ return x;
-+ }
-+
-+ /* normalize x and y */
-+ if (!ex) {
-+ ux.f *= 0x1p120f;
-+ ex = ux.i.se - 120;
-+ }
-+ if (!ey) {
-+ uy.f *= 0x1p120f;
-+ ey = uy.i.se - 120;
-+ }
-+
-+ /* x mod y */
-+#if LDBL_MANT_DIG == 64
-+ uint64_t i, mx, my;
-+ mx = ux.i.m;
-+ my = uy.i.m;
-+ for (; ex > ey; ex--) {
-+ i = mx - my;
-+ if (mx >= my) {
-+ if (i == 0)
-+ return 0*x;
-+ mx = 2*i;
-+ } else if (2*mx < mx) {
-+ mx = 2*mx - my;
- } else {
-- if ((hz|lz)==0) /* return sign(x)*0 */
-- return Zero[sx];
-- hx = hz+hz+(lz>>MANL_SHIFT);
-- lx = lz+lz;
-+ mx = 2*mx;
- }
- }
-- hz = hx-hy;
-- lz = lx-ly;
-- if (lx < ly)
-- hz -= 1;
-- if (hz >= 0) {
-- hx = hz;
-- lx = lz;
-+ i = mx - my;
-+ if (mx >= my) {
-+ if (i == 0)
-+ return 0*x;
-+ mx = i;
-+ }
-+ for (; mx >> 63 == 0; mx *= 2, ex--);
-+ ux.i.m = mx;
-+#elif LDBL_MANT_DIG == 113
-+ uint64_t hi, lo, xhi, xlo, yhi, ylo;
-+ xhi = (ux.i2.hi & -1ULL>>16) | 1ULL<<48;
-+ yhi = (uy.i2.hi & -1ULL>>16) | 1ULL<<48;
-+ xlo = ux.i2.lo;
-+ ylo = ux.i2.lo;
-+ for (; ex > ey; ex--) {
-+ hi = xhi - yhi;
-+ lo = xlo - ylo;
-+ if (xlo < ylo)
-+ hi -= 1;
-+ if (hi >> 63 == 0) {
-+ if ((hi|lo) == 0)
-+ return 0*x;
-+ xhi = 2*hi + (lo>>63);
-+ xlo = 2*lo;
-+ } else {
-+ xhi = 2*xhi + (xlo>>63);
-+ xlo = 2*xlo;
-+ }
- }
-+ hi = xhi - yhi;
-+ lo = xlo - ylo;
-+ if (xlo < ylo)
-+ hi -= 1;
-+ if (hi >> 63 == 0) {
-+ if ((hi|lo) == 0)
-+ return 0*x;
-+ xhi = hi;
-+ xlo = lo;
-+ }
-+ for (; xhi >> 48 == 0; xhi = 2*xhi + (xlo>>63), xlo = 2*xlo, ex--);
-+ ux.i2.hi = xhi;
-+ ux.i2.lo = xlo;
-+#endif
-
-- /* convert back to floating value and restore the sign */
-- if ((hx|lx) == 0) /* return sign(x)*0 */
-- return Zero[sx];
-- while (hx < (1ULL<<HFRAC_BITS)) { /* normalize x */
-- hx = hx+hx+(lx>>MANL_SHIFT);
-- lx = lx+lx;
-- iy -= 1;
-- }
-- ux.bits.manh = hx; /* The mantissa is truncated here if needed. */
-- ux.bits.manl = lx;
-- if (iy < LDBL_MIN_EXP) {
-- ux.bits.exp = iy + (BIAS + 512);
-- ux.e *= 0x1p-512;
-- } else {
-- ux.bits.exp = iy + BIAS;
-- }
-- return ux.e; /* exact output */
-+ /* scale result */
-+ if (ex <= 0) {
-+ ux.i.se = (ex+120)|sx;
-+ ux.f *= 0x1p-120f;
-+ } else
-+ ux.i.se = ex|sx;
-+ return ux.f;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/frexpl.c musl-git/src/math/frexpl.c
---- musl-0.9.13/src/math/frexpl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/frexpl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,20 +1,20 @@
--#include <math.h>
--#include <stdint.h>
--#include <float.h>
--
--#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
--
--/* This version is for 80-bit little endian long double */
-+#include "libm.h"
-
-+#if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
- long double frexpl(long double x, int *e)
- {
-- union { long double ld; uint16_t hw[5]; } y = { x };
-- int ee = y.hw[4]&0x7fff;
-+ return frexp(x, e);
-+}
-+#elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
-+long double frexpl(long double x, int *e)
-+{
-+ union ldshape u = {x};
-+ int ee = u.i.se & 0x7fff;
-
- if (!ee) {
- if (x) {
-- x = frexpl(x*0x1p64, e);
-- *e -= 64;
-+ x = frexpl(x*0x1p120, e);
-+ *e -= 120;
- } else *e = 0;
- return x;
- } else if (ee == 0x7fff) {
-@@ -22,16 +22,8 @@
- }
-
- *e = ee - 0x3ffe;
-- y.hw[4] &= 0x8000;
-- y.hw[4] |= 0x3ffe;
-- return y.ld;
-+ u.i.se &= 0x8000;
-+ u.i.se |= 0x3ffe;
-+ return u.f;
- }
--
--#else
--
--long double frexpl(long double x, int *e)
--{
-- return frexp(x, e);
--}
--
- #endif
-diff -Nur musl-0.9.13/src/math/hypot.c musl-git/src/math/hypot.c
---- musl-0.9.13/src/math/hypot.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/hypot.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,123 +1,67 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_hypot.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/* hypot(x,y)
-- *
-- * Method :
-- * If (assume round-to-nearest) z=x*x+y*y
-- * has error less than sqrt(2)/2 ulp, then
-- * sqrt(z) has error less than 1 ulp (exercise).
-- *
-- * So, compute sqrt(x*x+y*y) with some care as
-- * follows to get the error below 1 ulp:
-- *
-- * Assume x>y>0;
-- * (if possible, set rounding to round-to-nearest)
-- * 1. if x > 2y use
-- * x1*x1+(y*y+(x2*(x+x1))) for x*x+y*y
-- * where x1 = x with lower 32 bits cleared, x2 = x-x1; else
-- * 2. if x <= 2y use
-- * t1*y1+((x-y)*(x-y)+(t1*y2+t2*y))
-- * where t1 = 2x with lower 32 bits cleared, t2 = 2x-t1,
-- * y1= y with lower 32 bits chopped, y2 = y-y1.
-- *
-- * NOTE: scaling may be necessary if some argument is too
-- * large or too tiny
-- *
-- * Special cases:
-- * hypot(x,y) is INF if x or y is +INF or -INF; else
-- * hypot(x,y) is NAN if x or y is NAN.
-- *
-- * Accuracy:
-- * hypot(x,y) returns sqrt(x^2+y^2) with error less
-- * than 1 ulps (units in the last place)
-- */
-+#include <math.h>
-+#include <stdint.h>
-+#include <float.h>
-
--#include "libm.h"
-+#if FLT_EVAL_METHOD > 1U && LDBL_MANT_DIG == 64
-+#define SPLIT (0x1p32 + 1)
-+#else
-+#define SPLIT (0x1p27 + 1)
-+#endif
-+
-+static void sq(double_t *hi, double_t *lo, double x)
-+{
-+ double_t xh, xl, xc;
-+
-+ xc = x*SPLIT;
-+ xh = x - xc + xc;
-+ xl = x - xh;
-+ *hi = x*x;
-+ *lo = xh*xh - *hi + 2*xh*xl + xl*xl;
-+}
-
- double hypot(double x, double y)
- {
-- double a,b,t1,t2,y1,y2,w;
-- int32_t j,k,ha,hb;
-+ union {double f; uint64_t i;} ux = {x}, uy = {y}, ut;
-+ int ex, ey;
-+ double_t hx, lx, hy, ly, z;
-
-- GET_HIGH_WORD(ha, x);
-- ha &= 0x7fffffff;
-- GET_HIGH_WORD(hb, y);
-- hb &= 0x7fffffff;
-- if (hb > ha) {
-- a = y;
-- b = x;
-- j=ha; ha=hb; hb=j;
-- } else {
-- a = x;
-- b = y;
-+ /* arrange |x| >= |y| */
-+ ux.i &= -1ULL>>1;
-+ uy.i &= -1ULL>>1;
-+ if (ux.i < uy.i) {
-+ ut = ux;
-+ ux = uy;
-+ uy = ut;
- }
-- a = fabs(a);
-- b = fabs(b);
-- if (ha - hb > 0x3c00000) /* x/y > 2**60 */
-- return a+b;
-- k = 0;
-- if (ha > 0x5f300000) { /* a > 2**500 */
-- if(ha >= 0x7ff00000) { /* Inf or NaN */
-- uint32_t low;
-- /* Use original arg order iff result is NaN; quieten sNaNs. */
-- w = fabs(x+0.0) - fabs(y+0.0);
-- GET_LOW_WORD(low, a);
-- if (((ha&0xfffff)|low) == 0) w = a;
-- GET_LOW_WORD(low, b);
-- if (((hb^0x7ff00000)|low) == 0) w = b;
-- return w;
-- }
-- /* scale a and b by 2**-600 */
-- ha -= 0x25800000; hb -= 0x25800000; k += 600;
-- SET_HIGH_WORD(a, ha);
-- SET_HIGH_WORD(b, hb);
-- }
-- if (hb < 0x20b00000) { /* b < 2**-500 */
-- if (hb <= 0x000fffff) { /* subnormal b or 0 */
-- uint32_t low;
-- GET_LOW_WORD(low, b);
-- if ((hb|low) == 0)
-- return a;
-- t1 = 0;
-- SET_HIGH_WORD(t1, 0x7fd00000); /* t1 = 2^1022 */
-- b *= t1;
-- a *= t1;
-- k -= 1022;
-- } else { /* scale a and b by 2^600 */
-- ha += 0x25800000; /* a *= 2^600 */
-- hb += 0x25800000; /* b *= 2^600 */
-- k -= 600;
-- SET_HIGH_WORD(a, ha);
-- SET_HIGH_WORD(b, hb);
-- }
-- }
-- /* medium size a and b */
-- w = a - b;
-- if (w > b) {
-- t1 = 0;
-- SET_HIGH_WORD(t1, ha);
-- t2 = a-t1;
-- w = sqrt(t1*t1-(b*(-b)-t2*(a+t1)));
-- } else {
-- a = a + a;
-- y1 = 0;
-- SET_HIGH_WORD(y1, hb);
-- y2 = b - y1;
-- t1 = 0;
-- SET_HIGH_WORD(t1, ha+0x00100000);
-- t2 = a - t1;
-- w = sqrt(t1*y1-(w*(-w)-(t1*y2+t2*b)));
-+
-+ /* special cases */
-+ ex = ux.i>>52;
-+ ey = uy.i>>52;
-+ x = ux.f;
-+ y = uy.f;
-+ /* note: hypot(inf,nan) == inf */
-+ if (ey == 0x7ff)
-+ return y;
-+ if (ex == 0x7ff || uy.i == 0)
-+ return x;
-+ /* note: hypot(x,y) ~= x + y*y/x/2 with inexact for small y/x */
-+ /* 64 difference is enough for ld80 double_t */
-+ if (ex - ey > 64)
-+ return x + y;
-+
-+ /* precise sqrt argument in nearest rounding mode without overflow */
-+ /* xh*xh must not overflow and xl*xl must not underflow in sq */
-+ z = 1;
-+ if (ex > 0x3ff+510) {
-+ z = 0x1p700;
-+ x *= 0x1p-700;
-+ y *= 0x1p-700;
-+ } else if (ey < 0x3ff-450) {
-+ z = 0x1p-700;
-+ x *= 0x1p700;
-+ y *= 0x1p700;
- }
-- if (k)
-- w = scalbn(w, k);
-- return w;
-+ sq(&hx, &lx, x);
-+ sq(&hy, &ly, y);
-+ return z*sqrt(ly+lx+hy+hx);
- }
-diff -Nur musl-0.9.13/src/math/hypotf.c musl-git/src/math/hypotf.c
---- musl-0.9.13/src/math/hypotf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/hypotf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,86 +1,35 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_hypotf.c */
--/*
-- * Conversion to float by Ian Lance Taylor, Cygnus Support, ian@cygnus.com.
-- */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- float hypotf(float x, float y)
- {
-- float a,b,t1,t2,y1,y2,w;
-- int32_t j,k,ha,hb;
-+ union {float f; uint32_t i;} ux = {x}, uy = {y}, ut;
-+ float_t z;
-
-- GET_FLOAT_WORD(ha,x);
-- ha &= 0x7fffffff;
-- GET_FLOAT_WORD(hb,y);
-- hb &= 0x7fffffff;
-- if (hb > ha) {
-- a = y;
-- b = x;
-- j=ha; ha=hb; hb=j;
-- } else {
-- a = x;
-- b = y;
-- }
-- a = fabsf(a);
-- b = fabsf(b);
-- if (ha - hb > 0xf000000) /* x/y > 2**30 */
-- return a+b;
-- k = 0;
-- if (ha > 0x58800000) { /* a > 2**50 */
-- if(ha >= 0x7f800000) { /* Inf or NaN */
-- /* Use original arg order iff result is NaN; quieten sNaNs. */
-- w = fabsf(x+0.0f) - fabsf(y+0.0f);
-- if (ha == 0x7f800000) w = a;
-- if (hb == 0x7f800000) w = b;
-- return w;
-- }
-- /* scale a and b by 2**-68 */
-- ha -= 0x22000000; hb -= 0x22000000; k += 68;
-- SET_FLOAT_WORD(a, ha);
-- SET_FLOAT_WORD(b, hb);
-- }
-- if (hb < 0x26800000) { /* b < 2**-50 */
-- if (hb <= 0x007fffff) { /* subnormal b or 0 */
-- if (hb == 0)
-- return a;
-- SET_FLOAT_WORD(t1, 0x7e800000); /* t1 = 2^126 */
-- b *= t1;
-- a *= t1;
-- k -= 126;
-- } else { /* scale a and b by 2^68 */
-- ha += 0x22000000; /* a *= 2^68 */
-- hb += 0x22000000; /* b *= 2^68 */
-- k -= 68;
-- SET_FLOAT_WORD(a, ha);
-- SET_FLOAT_WORD(b, hb);
-- }
-+ ux.i &= -1U>>1;
-+ uy.i &= -1U>>1;
-+ if (ux.i < uy.i) {
-+ ut = ux;
-+ ux = uy;
-+ uy = ut;
- }
-- /* medium size a and b */
-- w = a - b;
-- if (w > b) {
-- SET_FLOAT_WORD(t1, ha&0xfffff000);
-- t2 = a - t1;
-- w = sqrtf(t1*t1-(b*(-b)-t2*(a+t1)));
-- } else {
-- a = a + a;
-- SET_FLOAT_WORD(y1, hb&0xfffff000);
-- y2 = b - y1;
-- SET_FLOAT_WORD(t1,(ha+0x00800000)&0xfffff000);
-- t2 = a - t1;
-- w = sqrtf(t1*y1-(w*(-w)-(t1*y2+t2*b)));
-+
-+ x = ux.f;
-+ y = uy.f;
-+ if (uy.i == 0xff<<23)
-+ return y;
-+ if (ux.i >= 0xff<<23 || uy.i == 0 || ux.i - uy.i >= 25<<23)
-+ return x + y;
-+
-+ z = 1;
-+ if (ux.i >= (0x7f+60)<<23) {
-+ z = 0x1p90f;
-+ x *= 0x1p-90f;
-+ y *= 0x1p-90f;
-+ } else if (uy.i < (0x7f-60)<<23) {
-+ z = 0x1p-90f;
-+ x *= 0x1p90f;
-+ y *= 0x1p90f;
- }
-- if (k)
-- w = scalbnf(w, k);
-- return w;
-+ return z*sqrtf((double)x*x + (double)y*y);
- }
-diff -Nur musl-0.9.13/src/math/hypotl.c musl-git/src/math/hypotl.c
---- musl-0.9.13/src/math/hypotl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/hypotl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,16 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_hypotl.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/* long double version of hypot(). See comments in hypot.c. */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -19,130 +6,61 @@
- return hypot(x, y);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#define GET_LDBL_EXPSIGN(i, v) do { \
-- union IEEEl2bits uv; \
-- \
-- uv.e = v; \
-- i = uv.xbits.expsign; \
--} while (0)
--
--#define GET_LDBL_MAN(h, l, v) do { \
-- union IEEEl2bits uv; \
-- \
-- uv.e = v; \
-- h = uv.bits.manh; \
-- l = uv.bits.manl; \
--} while (0)
--
--#define SET_LDBL_EXPSIGN(v, i) do { \
-- union IEEEl2bits uv; \
-- \
-- uv.e = v; \
-- uv.xbits.expsign = i; \
-- v = uv.e; \
--} while (0)
--
--#undef GET_HIGH_WORD
--#define GET_HIGH_WORD(i, v) GET_LDBL_EXPSIGN(i, v)
--#undef SET_HIGH_WORD
--#define SET_HIGH_WORD(v, i) SET_LDBL_EXPSIGN(v, i)
--
--#define DESW(exp) (exp) /* delta expsign word */
--#define ESW(exp) (MAX_EXP - 1 + (exp)) /* expsign word */
--#define MANT_DIG LDBL_MANT_DIG
--#define MAX_EXP LDBL_MAX_EXP
--
--#if LDBL_MANL_SIZE > 32
--typedef uint64_t man_t;
--#else
--typedef uint32_t man_t;
-+#if LDBL_MANT_DIG == 64
-+#define SPLIT (0x1p32L+1)
-+#elif LDBL_MANT_DIG == 113
-+#define SPLIT (0x1p57L+1)
- #endif
-
--long double hypotl(long double x, long double y)
-+static void sq(long double *hi, long double *lo, long double x)
- {
-- long double a=x,b=y,t1,t2,y1,y2,w;
-- int32_t j,k,ha,hb;
-+ long double xh, xl, xc;
-+ xc = x*SPLIT;
-+ xh = x - xc + xc;
-+ xl = x - xh;
-+ *hi = x*x;
-+ *lo = xh*xh - *hi + 2*xh*xl + xl*xl;
-+}
-
-- GET_HIGH_WORD(ha, x);
-- ha &= 0x7fff;
-- GET_HIGH_WORD(hb, y);
-- hb &= 0x7fff;
-- if (hb > ha) {
-- a = y;
-- b = x;
-- j=ha; ha=hb; hb=j;
-- } else {
-- a = x;
-- b = y;
-- }
-- a = fabsl(a);
-- b = fabsl(b);
-- if (ha - hb > DESW(MANT_DIG+7)) /* x/y > 2**(MANT_DIG+7) */
-- return a+b;
-- k = 0;
-- if (ha > ESW(MAX_EXP/2-12)) { /* a>2**(MAX_EXP/2-12) */
-- if (ha >= ESW(MAX_EXP)) { /* Inf or NaN */
-- man_t manh, manl;
-- /* Use original arg order iff result is NaN; quieten sNaNs. */
-- w = fabsl(x+0.0)-fabsl(y+0.0);
-- GET_LDBL_MAN(manh,manl,a);
-- if (manh == LDBL_NBIT && manl == 0) w = a;
-- GET_LDBL_MAN(manh,manl,b);
-- if (hb >= ESW(MAX_EXP) && manh == LDBL_NBIT && manl == 0) w = b;
-- return w;
-- }
-- /* scale a and b by 2**-(MAX_EXP/2+88) */
-- ha -= DESW(MAX_EXP/2+88); hb -= DESW(MAX_EXP/2+88);
-- k += MAX_EXP/2+88;
-- SET_HIGH_WORD(a, ha);
-- SET_HIGH_WORD(b, hb);
-- }
-- if (hb < ESW(-(MAX_EXP/2-12))) { /* b < 2**-(MAX_EXP/2-12) */
-- if (hb <= 0) { /* subnormal b or 0 */
-- man_t manh, manl;
-- GET_LDBL_MAN(manh,manl,b);
-- if ((manh|manl) == 0)
-- return a;
-- t1 = 0;
-- SET_HIGH_WORD(t1, ESW(MAX_EXP-2)); /* t1 = 2^(MAX_EXP-2) */
-- b *= t1;
-- a *= t1;
-- k -= MAX_EXP-2;
-- } else { /* scale a and b by 2^(MAX_EXP/2+88) */
-- ha += DESW(MAX_EXP/2+88);
-- hb += DESW(MAX_EXP/2+88);
-- k -= MAX_EXP/2+88;
-- SET_HIGH_WORD(a, ha);
-- SET_HIGH_WORD(b, hb);
-- }
-- }
-- /* medium size a and b */
-- w = a - b;
-- if (w > b) {
-- t1 = a;
-- union IEEEl2bits uv;
-- uv.e = t1; uv.bits.manl = 0; t1 = uv.e;
-- t2 = a-t1;
-- w = sqrtl(t1*t1-(b*(-b)-t2*(a+t1)));
-+long double hypotl(long double x, long double y)
-+{
-+ union ldshape ux = {x}, uy = {y};
-+ int ex, ey;
-+ long double hx, lx, hy, ly, z;
-+
-+ ux.i.se &= 0x7fff;
-+ uy.i.se &= 0x7fff;
-+ if (ux.i.se < uy.i.se) {
-+ ex = uy.i.se;
-+ ey = ux.i.se;
-+ x = uy.f;
-+ y = ux.f;
- } else {
-- a = a+a;
-- y1 = b;
-- union IEEEl2bits uv;
-- uv.e = y1; uv.bits.manl = 0; y1 = uv.e;
-- y2 = b - y1;
-- t1 = a;
-- uv.e = t1; uv.bits.manl = 0; t1 = uv.e;
-- t2 = a - t1;
-- w = sqrtl(t1*y1-(w*(-w)-(t1*y2+t2*b)));
-+ ex = ux.i.se;
-+ ey = uy.i.se;
-+ x = ux.f;
-+ y = uy.f;
- }
-- if(k!=0) {
-- uint32_t high;
-- t1 = 1.0;
-- GET_HIGH_WORD(high, t1);
-- SET_HIGH_WORD(t1, high+DESW(k));
-- return t1*w;
-+
-+ if (ex == 0x7fff && isinf(y))
-+ return y;
-+ if (ex == 0x7fff || y == 0)
-+ return x;
-+ if (ex - ey > LDBL_MANT_DIG)
-+ return x + y;
-+
-+ z = 1;
-+ if (ex > 0x3fff+8000) {
-+ z = 0x1p10000L;
-+ x *= 0x1p-10000L;
-+ y *= 0x1p-10000L;
-+ } else if (ey < 0x3fff-8000) {
-+ z = 0x1p-10000L;
-+ x *= 0x1p10000L;
-+ y *= 0x1p10000L;
- }
-- return w;
-+ sq(&hx, &lx, x);
-+ sq(&hy, &ly, y);
-+ return z*sqrtl(ly+lx+hy+hx);
- }
- #endif
-diff -Nur musl-0.9.13/src/math/i386/exp.s musl-git/src/math/i386/exp.s
---- musl-0.9.13/src/math/i386/exp.s 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/i386/exp.s 2013-09-16 20:31:39.000000000 +0200
-@@ -95,42 +95,32 @@
- .type exp2,@function
- exp2:
- fldl 4(%esp)
--1: pushl $0x467ff000
-- flds (%esp) # 16380
-- xorl %eax,%eax
-- pushl $0x80000000
-- push %eax
-- fld %st(1)
-- fabs
-- fucomp %st(1)
-- fnstsw
-- fstp %st(0)
-- sahf
-- ja 3f # |x| > 16380
-- jp 2f # x is nan (avoid invalid except in fistp)
-+1: sub $12,%esp
- fld %st(0)
-- fistpl 8(%esp)
-- fildl 8(%esp)
-- fxch %st(1)
-- fsub %st(1)
-- mov $0x3fff,%eax
-- add %eax,8(%esp)
-- f2xm1
-- fld1
-- faddp # 2^(x-rint(x))
-- fldt (%esp) # 2^rint(x)
-- fmulp
-- fstp %st(1)
--2: add $12,%esp
-- ret
--
--3: fld %st(0)
- fstpt (%esp)
-- fld1
- mov 8(%esp),%ax
- and $0x7fff,%ax
-- cmp $0x7fff,%ax
-- je 1f # x = +-inf
-+ cmp $0x3fff+13,%ax
-+ jb 4f # |x| < 8192
-+ cmp $0x3fff+15,%ax
-+ jae 3f # |x| >= 32768
-+ fsts (%esp)
-+ cmpl $0xc67ff800,(%esp)
-+ jb 2f # x > -16382
-+ movl $0x5f000000,(%esp)
-+ flds (%esp) # 0x1p63
-+ fld %st(1)
-+ fsub %st(1)
-+ faddp
-+ fucomp %st(1)
-+ fnstsw
-+ sahf
-+ je 2f # x - 0x1p63 + 0x1p63 == x
-+ movl $1,(%esp)
-+ flds (%esp) # 0x1p-149
-+ fdiv %st(1)
-+ fstps (%esp) # raise underflow
-+2: fld1
- fld %st(1)
- frndint
- fxch %st(2)
-@@ -141,3 +131,19 @@
- fstp %st(1)
- add $12,%esp
- ret
-+3: xor %eax,%eax
-+4: cmp $0x3fff-64,%ax
-+ fld1
-+ jb 1b # |x| < 0x1p-64
-+ fstpt (%esp)
-+ fistl 8(%esp)
-+ fildl 8(%esp)
-+ fsubrp %st(1)
-+ addl $0x3fff,8(%esp)
-+ f2xm1
-+ fld1
-+ faddp # 2^(x-rint(x))
-+ fldt (%esp) # 2^rint(x)
-+ fmulp
-+ add $12,%esp
-+ ret
-diff -Nur musl-0.9.13/src/math/ilogb.c musl-git/src/math/ilogb.c
---- musl-0.9.13/src/math/ilogb.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/ilogb.c 2013-09-16 20:31:39.000000000 +0200
-@@ -3,22 +3,24 @@
-
- int ilogb(double x)
- {
-- union dshape u = {x};
-- int e = u.bits>>52 & 0x7ff;
-+ #pragma STDC FENV_ACCESS ON
-+ union {double f; uint64_t i;} u = {x};
-+ uint64_t i = u.i;
-+ int e = i>>52 & 0x7ff;
-
- if (!e) {
-- u.bits <<= 12;
-- if (u.bits == 0) {
-+ i <<= 12;
-+ if (i == 0) {
- FORCE_EVAL(0/0.0f);
- return FP_ILOGB0;
- }
- /* subnormal x */
-- for (e = -0x3ff; u.bits < (uint64_t)1<<63; e--, u.bits<<=1);
-+ for (e = -0x3ff; i>>63 == 0; e--, i<<=1);
- return e;
- }
- if (e == 0x7ff) {
- FORCE_EVAL(0/0.0f);
-- return u.bits<<12 ? FP_ILOGBNAN : INT_MAX;
-+ return i<<12 ? FP_ILOGBNAN : INT_MAX;
- }
- return e - 0x3ff;
- }
-diff -Nur musl-0.9.13/src/math/ilogbf.c musl-git/src/math/ilogbf.c
---- musl-0.9.13/src/math/ilogbf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/ilogbf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -3,22 +3,24 @@
-
- int ilogbf(float x)
- {
-- union fshape u = {x};
-- int e = u.bits>>23 & 0xff;
-+ #pragma STDC FENV_ACCESS ON
-+ union {float f; uint32_t i;} u = {x};
-+ uint32_t i = u.i;
-+ int e = i>>23 & 0xff;
-
- if (!e) {
-- u.bits <<= 9;
-- if (u.bits == 0) {
-+ i <<= 9;
-+ if (i == 0) {
- FORCE_EVAL(0/0.0f);
- return FP_ILOGB0;
- }
- /* subnormal x */
-- for (e = -0x7f; u.bits < (uint32_t)1<<31; e--, u.bits<<=1);
-+ for (e = -0x7f; i>>31 == 0; e--, i<<=1);
- return e;
- }
- if (e == 0xff) {
- FORCE_EVAL(0/0.0f);
-- return u.bits<<9 ? FP_ILOGBNAN : INT_MAX;
-+ return i<<9 ? FP_ILOGBNAN : INT_MAX;
- }
- return e - 0x7f;
- }
-diff -Nur musl-0.9.13/src/math/ilogbl.c musl-git/src/math/ilogbl.c
---- musl-0.9.13/src/math/ilogbl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/ilogbl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -9,9 +9,10 @@
- #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
- int ilogbl(long double x)
- {
-+ #pragma STDC FENV_ACCESS ON
- union ldshape u = {x};
-- uint64_t m = u.bits.m;
-- int e = u.bits.exp;
-+ uint64_t m = u.i.m;
-+ int e = u.i.se & 0x7fff;
-
- if (!e) {
- if (m == 0) {
-@@ -19,13 +20,35 @@
- return FP_ILOGB0;
- }
- /* subnormal x */
-- for (e = -0x3fff+1; m < (uint64_t)1<<63; e--, m<<=1);
-+ for (e = -0x3fff+1; m>>63 == 0; e--, m<<=1);
- return e;
- }
- if (e == 0x7fff) {
- FORCE_EVAL(0/0.0f);
-- /* in ld80 msb is set in inf */
-- return m & (uint64_t)-1>>1 ? FP_ILOGBNAN : INT_MAX;
-+ return m<<1 ? FP_ILOGBNAN : INT_MAX;
-+ }
-+ return e - 0x3fff;
-+}
-+#elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
-+int ilogbl(long double x)
-+{
-+ #pragma STDC FENV_ACCESS ON
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-+
-+ if (!e) {
-+ if (x == 0) {
-+ FORCE_EVAL(0/0.0f);
-+ return FP_ILOGB0;
-+ }
-+ /* subnormal x */
-+ x *= 0x1p120;
-+ return ilogbl(x) - 120;
-+ }
-+ if (e == 0x7fff) {
-+ FORCE_EVAL(0/0.0f);
-+ u.i.se = 0;
-+ return u.f ? FP_ILOGBNAN : INT_MAX;
- }
- return e - 0x3fff;
- }
-diff -Nur musl-0.9.13/src/math/lgamma_r.c musl-git/src/math/lgamma_r.c
---- musl-0.9.13/src/math/lgamma_r.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/lgamma_r.c 2013-09-16 20:31:39.000000000 +0200
-@@ -79,6 +79,7 @@
- */
-
- #include "libm.h"
-+#include "libc.h"
-
- static const double
- two52= 4.50359962737049600000e+15, /* 0x43300000, 0x00000000 */
-diff -Nur musl-0.9.13/src/math/lgammaf_r.c musl-git/src/math/lgammaf_r.c
---- musl-0.9.13/src/math/lgammaf_r.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/lgammaf_r.c 2013-09-16 20:31:39.000000000 +0200
-@@ -14,6 +14,7 @@
- */
-
- #include "libm.h"
-+#include "libc.h"
-
- static const float
- two23= 8.3886080000e+06, /* 0x4b000000 */
-diff -Nur musl-0.9.13/src/math/lgammal.c musl-git/src/math/lgammal.c
---- musl-0.9.13/src/math/lgammal.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/lgammal.c 2013-09-16 20:31:39.000000000 +0200
-@@ -87,6 +87,7 @@
-
- #define _GNU_SOURCE
- #include "libm.h"
-+#include "libc.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
- double __lgamma_r(double x, int *sg);
-@@ -202,13 +203,11 @@
-
- static long double sin_pi(long double x)
- {
-+ union ldshape u = {x};
-+ uint32_t ix = (u.i.se & 0x7fffU)<<16 | u.i.m>>48;
- long double y, z;
-- int n, ix;
-- uint32_t se, i0, i1;
-+ int n;
-
-- GET_LDOUBLE_WORDS(se, i0, i1, x);
-- ix = se & 0x7fff;
-- ix = (ix << 16) | (i0 >> 16);
- if (ix < 0x3ffd8000) /* 0.25 */
- return sinl(pi * x);
- y = -x; /* x is assume negative */
-@@ -229,8 +228,8 @@
- } else {
- if (ix < 0x403e8000) /* 2^63 */
- z = y + two63; /* exact */
-- GET_LDOUBLE_WORDS(se, i0, i1, z);
-- n = i1 & 1;
-+ u.f = z;
-+ n = u.i.m & 1;
- y = n;
- n <<= 2;
- }
-@@ -261,33 +260,28 @@
-
- long double __lgammal_r(long double x, int *sg) {
- long double t, y, z, nadj, p, p1, p2, q, r, w;
-- int i, ix;
-- uint32_t se, i0, i1;
-+ union ldshape u = {x};
-+ uint32_t ix = (u.i.se & 0x7fffU)<<16 | u.i.m>>48;
-+ int sign = u.i.se >> 15;
-+ int i;
-
- *sg = 1;
-- GET_LDOUBLE_WORDS(se, i0, i1, x);
-- ix = se & 0x7fff;
--
-- if ((ix | i0 | i1) == 0) {
-- if (se & 0x8000)
-- *sg = -1;
-- return 1.0 / fabsl(x);
-- }
--
-- ix = (ix << 16) | (i0 >> 16);
-
- /* purge off +-inf, NaN, +-0, and negative arguments */
- if (ix >= 0x7fff0000)
- return x * x;
--
-+ if (x == 0) {
-+ *sg -= 2*sign;
-+ return 1.0 / fabsl(x);
-+ }
- if (ix < 0x3fc08000) { /* |x|<2**-63, return -log(|x|) */
-- if (se & 0x8000) {
-+ if (sign) {
- *sg = -1;
- return -logl(-x);
- }
- return -logl(x);
- }
-- if (se & 0x8000) {
-+ if (sign) {
- t = sin_pi (x);
- if (t == 0.0)
- return 1.0 / fabsl(t); /* -integer */
-@@ -297,11 +291,7 @@
- x = -x;
- }
-
-- /* purge off 1 and 2 */
-- if ((((ix - 0x3fff8000) | i0 | i1) == 0) ||
-- (((ix - 0x40008000) | i0 | i1) == 0))
-- r = 0;
-- else if (ix < 0x40008000) { /* x < 2.0 */
-+ if (ix < 0x40008000) { /* x < 2.0 */
- if (ix <= 0x3ffee666) { /* 8.99993896484375e-1 */
- /* lgamma(x) = lgamma(x+1) - log(x) */
- r = -logl(x);
-@@ -380,7 +370,7 @@
- r = (x - 0.5) * (t - 1.0) + w;
- } else /* 2**66 <= x <= inf */
- r = x * (logl(x) - 1.0);
-- if (se & 0x8000)
-+ if (sign)
- r = nadj - r;
- return r;
- }
-diff -Nur musl-0.9.13/src/math/log1p.c musl-git/src/math/log1p.c
---- musl-0.9.13/src/math/log1p.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/log1p.c 2013-09-16 20:31:39.000000000 +0200
-@@ -122,7 +122,7 @@
- return x+x;
- if (k != 0) {
- if (hx < 0x43400000) {
-- STRICT_ASSIGN(double, u, 1.0 + x);
-+ u = 1 + x;
- GET_HIGH_WORD(hu, u);
- k = (hu>>20) - 1023;
- c = k > 0 ? 1.0-(u-x) : x-(u-1.0); /* correction term */
-diff -Nur musl-0.9.13/src/math/log1pf.c musl-git/src/math/log1pf.c
---- musl-0.9.13/src/math/log1pf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/log1pf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -61,7 +61,7 @@
- return x+x;
- if (k != 0) {
- if (hx < 0x5a000000) {
-- STRICT_ASSIGN(float, u, 1.0f + x);
-+ u = 1 + x;
- GET_FLOAT_WORD(hu, u);
- k = (hu>>23) - 127;
- /* correction term */
-diff -Nur musl-0.9.13/src/math/logb.c musl-git/src/math/logb.c
---- musl-0.9.13/src/math/logb.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/logb.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,4 +1,4 @@
--#include "libm.h"
-+#include <math.h>
-
- /*
- special cases:
-@@ -12,6 +12,6 @@
- if (!isfinite(x))
- return x * x;
- if (x == 0)
-- return -1/(x+0);
-+ return -1/(x*x);
- return ilogb(x);
- }
-diff -Nur musl-0.9.13/src/math/logbf.c musl-git/src/math/logbf.c
---- musl-0.9.13/src/math/logbf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/logbf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,10 +1,10 @@
--#include "libm.h"
-+#include <math.h>
-
- float logbf(float x)
- {
- if (!isfinite(x))
- return x * x;
- if (x == 0)
-- return -1/(x+0);
-+ return -1/(x*x);
- return ilogbf(x);
- }
-diff -Nur musl-0.9.13/src/math/logbl.c musl-git/src/math/logbl.c
---- musl-0.9.13/src/math/logbl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/logbl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,4 +1,4 @@
--#include "libm.h"
-+#include <math.h>
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
- long double logbl(long double x)
- {
-@@ -10,7 +10,7 @@
- if (!isfinite(x))
- return x * x;
- if (x == 0)
-- return -1/(x+0);
-+ return -1/(x*x);
- return ilogbl(x);
- }
- #endif
-diff -Nur musl-0.9.13/src/math/modf.c musl-git/src/math/modf.c
---- musl-0.9.13/src/math/modf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/modf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -2,36 +2,33 @@
-
- double modf(double x, double *iptr)
- {
-- union {double x; uint64_t n;} u = {x};
-+ union {double f; uint64_t i;} u = {x};
- uint64_t mask;
-- int e;
--
-- e = (int)(u.n>>52 & 0x7ff) - 0x3ff;
-+ int e = (int)(u.i>>52 & 0x7ff) - 0x3ff;
-
- /* no fractional part */
- if (e >= 52) {
- *iptr = x;
-- if (e == 0x400 && u.n<<12 != 0) /* nan */
-+ if (e == 0x400 && u.i<<12 != 0) /* nan */
- return x;
-- u.n &= (uint64_t)1<<63;
-- return u.x;
-+ u.i &= 1ULL<<63;
-+ return u.f;
- }
-
- /* no integral part*/
- if (e < 0) {
-- u.n &= (uint64_t)1<<63;
-- *iptr = u.x;
-+ u.i &= 1ULL<<63;
-+ *iptr = u.f;
- return x;
- }
-
-- mask = (uint64_t)-1>>12 >> e;
-- if ((u.n & mask) == 0) {
-+ mask = -1ULL>>12>>e;
-+ if ((u.i & mask) == 0) {
- *iptr = x;
-- u.n &= (uint64_t)1<<63;
-- return u.x;
-+ u.i &= 1ULL<<63;
-+ return u.f;
- }
-- u.n &= ~mask;
-- *iptr = u.x;
-- STRICT_ASSIGN(double, x, x - *iptr);
-- return x;
-+ u.i &= ~mask;
-+ *iptr = u.f;
-+ return x - u.f;
- }
-diff -Nur musl-0.9.13/src/math/modff.c musl-git/src/math/modff.c
---- musl-0.9.13/src/math/modff.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/modff.c 2013-09-16 20:31:39.000000000 +0200
-@@ -2,36 +2,33 @@
-
- float modff(float x, float *iptr)
- {
-- union {float x; uint32_t n;} u = {x};
-+ union {float f; uint32_t i;} u = {x};
- uint32_t mask;
-- int e;
--
-- e = (int)(u.n>>23 & 0xff) - 0x7f;
-+ int e = (int)(u.i>>23 & 0xff) - 0x7f;
-
- /* no fractional part */
- if (e >= 23) {
- *iptr = x;
-- if (e == 0x80 && u.n<<9 != 0) { /* nan */
-+ if (e == 0x80 && u.i<<9 != 0) { /* nan */
- return x;
- }
-- u.n &= 0x80000000;
-- return u.x;
-+ u.i &= 0x80000000;
-+ return u.f;
- }
- /* no integral part */
- if (e < 0) {
-- u.n &= 0x80000000;
-- *iptr = u.x;
-+ u.i &= 0x80000000;
-+ *iptr = u.f;
- return x;
- }
-
- mask = 0x007fffff>>e;
-- if ((u.n & mask) == 0) {
-+ if ((u.i & mask) == 0) {
- *iptr = x;
-- u.n &= 0x80000000;
-- return u.x;
-+ u.i &= 0x80000000;
-+ return u.f;
- }
-- u.n &= ~mask;
-- *iptr = u.x;
-- STRICT_ASSIGN(float, x, x - *iptr);
-- return x;
-+ u.i &= ~mask;
-+ *iptr = u.f;
-+ return x - u.f;
- }
-diff -Nur musl-0.9.13/src/math/modfl.c musl-git/src/math/modfl.c
---- musl-0.9.13/src/math/modfl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/modfl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,40 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_modfl.c */
--/*-
-- * Copyright (c) 2007 David Schultz <das@FreeBSD.ORG>
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice, this list of conditions and the following disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
-- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-- * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
-- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
-- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
-- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
-- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
-- * SUCH DAMAGE.
-- *
-- * Derived from s_modf.c, which has the following Copyright:
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -43,58 +6,46 @@
- return modf(x, (double *)iptr);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#if LDBL_MANL_SIZE > 32
--#define MASK ((uint64_t)-1)
--#else
--#define MASK ((uint32_t)-1)
-+#if LDBL_MANT_DIG == 64
-+#define TOINT 0x1p63
-+#elif LDBL_MANT_DIG == 113
-+#define TOINT 0x1p112
- #endif
--/* Return the last n bits of a word, representing the fractional part. */
--#define GETFRAC(bits, n) ((bits) & ~(MASK << (n)))
--/* The number of fraction bits in manh, not counting the integer bit */
--#define HIBITS (LDBL_MANT_DIG - LDBL_MANL_SIZE)
--
--static const long double zero[] = { 0.0, -0.0 };
--
- long double modfl(long double x, long double *iptr)
- {
-- union IEEEl2bits ux;
-- int e;
-+ union ldshape u = {x};
-+ uint64_t mask;
-+ int e = (u.i.se & 0x7fff) - 0x3fff;
-+ int s = u.i.se >> 15;
-+ long double absx;
-+ long double y;
-
-- ux.e = x;
-- e = ux.bits.exp - LDBL_MAX_EXP + 1;
-- if (e < HIBITS) { /* Integer part is in manh. */
-- if (e < 0) { /* |x|<1 */
-- *iptr = zero[ux.bits.sign];
-- return x;
-- }
-- if ((GETFRAC(ux.bits.manh, HIBITS - 1 - e)|ux.bits.manl) == 0) {
-- /* x is an integer. */
-- *iptr = x;
-- return zero[ux.bits.sign];
-- }
-- /* Clear all but the top e+1 bits. */
-- ux.bits.manh >>= HIBITS - 1 - e;
-- ux.bits.manh <<= HIBITS - 1 - e;
-- ux.bits.manl = 0;
-- *iptr = ux.e;
-- return x - ux.e;
-- } else if (e >= LDBL_MANT_DIG - 1) { /* x has no fraction part. */
-+ /* no fractional part */
-+ if (e >= LDBL_MANT_DIG-1) {
- *iptr = x;
-- if (e == LDBL_MAX_EXP && ((ux.bits.manh&~LDBL_NBIT)|ux.bits.manl)) /* nan */
-+ if (isnan(x))
- return x;
-- return zero[ux.bits.sign];
-- } else { /* Fraction part is in manl. */
-- if (GETFRAC(ux.bits.manl, LDBL_MANT_DIG - 1 - e) == 0) {
-- /* x is integral. */
-- *iptr = x;
-- return zero[ux.bits.sign];
-- }
-- /* Clear all but the top e+1 bits. */
-- ux.bits.manl >>= LDBL_MANT_DIG - 1 - e;
-- ux.bits.manl <<= LDBL_MANT_DIG - 1 - e;
-- *iptr = ux.e;
-- return x - ux.e;
-+ return s ? -0.0 : 0.0;
-+ }
-+
-+ /* no integral part*/
-+ if (e < 0) {
-+ *iptr = s ? -0.0 : 0.0;
-+ return x;
-+ }
-+
-+ /* raises spurious inexact */
-+ absx = s ? -x : x;
-+ y = absx + TOINT - TOINT - absx;
-+ if (y == 0) {
-+ *iptr = x;
-+ return s ? -0.0 : 0.0;
- }
-+ if (y > 0)
-+ y -= 1;
-+ if (s)
-+ y = -y;
-+ *iptr = x + y;
-+ return -y;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/nextafter.c musl-git/src/math/nextafter.c
---- musl-0.9.13/src/math/nextafter.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/nextafter.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,35 +1,31 @@
- #include "libm.h"
-
--#define SIGN ((uint64_t)1<<63)
--
- double nextafter(double x, double y)
- {
-- union dshape ux, uy;
-+ union {double f; uint64_t i;} ux={x}, uy={y};
- uint64_t ax, ay;
- int e;
-
- if (isnan(x) || isnan(y))
- return x + y;
-- ux.value = x;
-- uy.value = y;
-- if (ux.bits == uy.bits)
-+ if (ux.i == uy.i)
- return y;
-- ax = ux.bits & ~SIGN;
-- ay = uy.bits & ~SIGN;
-+ ax = ux.i & -1ULL/2;
-+ ay = uy.i & -1ULL/2;
- if (ax == 0) {
- if (ay == 0)
- return y;
-- ux.bits = (uy.bits & SIGN) | 1;
-- } else if (ax > ay || ((ux.bits ^ uy.bits) & SIGN))
-- ux.bits--;
-+ ux.i = (uy.i & 1ULL<<63) | 1;
-+ } else if (ax > ay || ((ux.i ^ uy.i) & 1ULL<<63))
-+ ux.i--;
- else
-- ux.bits++;
-- e = ux.bits >> 52 & 0x7ff;
-- /* raise overflow if ux.value is infinite and x is finite */
-+ ux.i++;
-+ e = ux.i >> 52 & 0x7ff;
-+ /* raise overflow if ux.f is infinite and x is finite */
- if (e == 0x7ff)
- FORCE_EVAL(x+x);
-- /* raise underflow if ux.value is subnormal or zero */
-+ /* raise underflow if ux.f is subnormal or zero */
- if (e == 0)
-- FORCE_EVAL(x*x + ux.value*ux.value);
-- return ux.value;
-+ FORCE_EVAL(x*x + ux.f*ux.f);
-+ return ux.f;
- }
-diff -Nur musl-0.9.13/src/math/nextafterf.c musl-git/src/math/nextafterf.c
---- musl-0.9.13/src/math/nextafterf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/nextafterf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,34 +1,30 @@
- #include "libm.h"
-
--#define SIGN 0x80000000
--
- float nextafterf(float x, float y)
- {
-- union fshape ux, uy;
-+ union {float f; uint32_t i;} ux={x}, uy={y};
- uint32_t ax, ay, e;
-
- if (isnan(x) || isnan(y))
- return x + y;
-- ux.value = x;
-- uy.value = y;
-- if (ux.bits == uy.bits)
-+ if (ux.i == uy.i)
- return y;
-- ax = ux.bits & ~SIGN;
-- ay = uy.bits & ~SIGN;
-+ ax = ux.i & 0x7fffffff;
-+ ay = uy.i & 0x7fffffff;
- if (ax == 0) {
- if (ay == 0)
- return y;
-- ux.bits = (uy.bits & SIGN) | 1;
-- } else if (ax > ay || ((ux.bits ^ uy.bits) & SIGN))
-- ux.bits--;
-+ ux.i = (uy.i & 0x80000000) | 1;
-+ } else if (ax > ay || ((ux.i ^ uy.i) & 0x80000000))
-+ ux.i--;
- else
-- ux.bits++;
-- e = ux.bits & 0x7f800000;
-- /* raise overflow if ux.value is infinite and x is finite */
-+ ux.i++;
-+ e = ux.i & 0x7f800000;
-+ /* raise overflow if ux.f is infinite and x is finite */
- if (e == 0x7f800000)
- FORCE_EVAL(x+x);
-- /* raise underflow if ux.value is subnormal or zero */
-+ /* raise underflow if ux.f is subnormal or zero */
- if (e == 0)
-- FORCE_EVAL(x*x + ux.value*ux.value);
-- return ux.value;
-+ FORCE_EVAL(x*x + ux.f*ux.f);
-+ return ux.f;
- }
-diff -Nur musl-0.9.13/src/math/nextafterl.c musl-git/src/math/nextafterl.c
---- musl-0.9.13/src/math/nextafterl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/nextafterl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -6,7 +6,6 @@
- return nextafter(x, y);
- }
- #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
--#define MSB ((uint64_t)1<<63)
- long double nextafterl(long double x, long double y)
- {
- union ldshape ux, uy;
-@@ -15,32 +14,32 @@
- return x + y;
- if (x == y)
- return y;
-- ux.value = x;
-+ ux.f = x;
- if (x == 0) {
-- uy.value = y;
-- ux.bits.m = 1;
-- ux.bits.sign = uy.bits.sign;
-- } else if (x < y ^ ux.bits.sign) {
-- ux.bits.m++;
-- if ((ux.bits.m & ~MSB) == 0) {
-- ux.bits.m = MSB;
-- ux.bits.exp++;
-+ uy.f = y;
-+ ux.i.m = 1;
-+ ux.i.se = uy.i.se & 0x8000;
-+ } else if ((x < y) == !(ux.i.se & 0x8000)) {
-+ ux.i.m++;
-+ if (ux.i.m << 1 == 0) {
-+ ux.i.m = 1ULL << 63;
-+ ux.i.se++;
- }
- } else {
-- if ((ux.bits.m & ~MSB) == 0) {
-- ux.bits.exp--;
-- if (ux.bits.exp)
-- ux.bits.m = 0;
-+ if (ux.i.m << 1 == 0) {
-+ ux.i.se--;
-+ if (ux.i.se)
-+ ux.i.m = 0;
- }
-- ux.bits.m--;
-+ ux.i.m--;
- }
-- /* raise overflow if ux.value is infinite and x is finite */
-- if (ux.bits.exp == 0x7fff)
-+ /* raise overflow if ux is infinite and x is finite */
-+ if ((ux.i.se & 0x7fff) == 0x7fff)
- return x + x;
-- /* raise underflow if ux.value is subnormal or zero */
-- if (ux.bits.exp == 0)
-- FORCE_EVAL(x*x + ux.value*ux.value);
-- return ux.value;
-+ /* raise underflow if ux is subnormal or zero */
-+ if ((ux.i.se & 0x7fff) == 0)
-+ FORCE_EVAL(x*x + ux.f*ux.f);
-+ return ux.f;
- }
- #elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
- long double nextafterl(long double x, long double y)
-@@ -51,32 +50,26 @@
- return x + y;
- if (x == y)
- return y;
-- ux.value = x;
-+ ux.f = x;
- if (x == 0) {
-- uy.value = y;
-- ux.bits.mlo = 1;
-- ux.bits.sign = uy.bits.sign;
-- } else if (x < y ^ ux.bits.sign) {
-- ux.bits.mlo++;
-- if (ux.bits.mlo == 0) {
-- ux.bits.mhi++;
-- if (ux.bits.mhi == 0)
-- ux.bits.exp++;
-- }
-+ uy.f = y;
-+ ux.i.lo = 1;
-+ ux.i.se = uy.i.se & 0x8000;
-+ } else if ((x < y) == !(ux.i.se & 0x8000)) {
-+ ux.i2.lo++;
-+ if (ux.i2.lo == 0)
-+ ux.i2.hi++;
- } else {
-- if (ux.bits.mlo == 0) {
-- if (ux.bits.mhi == 0)
-- ux.bits.exp--;
-- ux.bits.mhi--;
-- }
-- ux.bits.mlo--;
-+ if (ux.i2.lo == 0)
-+ ux.i2.hi--;
-+ ux.i2.lo--;
- }
-- /* raise overflow if ux.value is infinite and x is finite */
-- if (ux.bits.exp == 0x7fff)
-+ /* raise overflow if ux is infinite and x is finite */
-+ if ((ux.i.se & 0x7fff) == 0x7fff)
- return x + x;
-- /* raise underflow if ux.value is subnormal or zero */
-- if (ux.bits.exp == 0)
-- FORCE_EVAL(x*x + ux.value*ux.value);
-- return ux.value;
-+ /* raise underflow if ux is subnormal or zero */
-+ if ((ux.i.se & 0x7fff) == 0)
-+ FORCE_EVAL(x*x + ux.f*ux.f);
-+ return ux.f;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/nexttoward.c musl-git/src/math/nexttoward.c
---- musl-0.9.13/src/math/nexttoward.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/nexttoward.c 2013-09-16 20:31:39.000000000 +0200
-@@ -6,40 +6,37 @@
- return nextafter(x, y);
- }
- #else
--#define SIGN ((uint64_t)1<<63)
--
- double nexttoward(double x, long double y)
- {
-- union dshape ux;
-+ union {double f; uint64_t i;} ux = {x};
- int e;
-
- if (isnan(x) || isnan(y))
- return x + y;
- if (x == y)
- return y;
-- ux.value = x;
- if (x == 0) {
-- ux.bits = 1;
-+ ux.i = 1;
- if (signbit(y))
-- ux.bits |= SIGN;
-+ ux.i |= 1ULL<<63;
- } else if (x < y) {
- if (signbit(x))
-- ux.bits--;
-+ ux.i--;
- else
-- ux.bits++;
-+ ux.i++;
- } else {
- if (signbit(x))
-- ux.bits++;
-+ ux.i++;
- else
-- ux.bits--;
-+ ux.i--;
- }
-- e = ux.bits>>52 & 0x7ff;
-- /* raise overflow if ux.value is infinite and x is finite */
-+ e = ux.i>>52 & 0x7ff;
-+ /* raise overflow if ux.f is infinite and x is finite */
- if (e == 0x7ff)
- FORCE_EVAL(x+x);
-- /* raise underflow if ux.value is subnormal or zero */
-+ /* raise underflow if ux.f is subnormal or zero */
- if (e == 0)
-- FORCE_EVAL(x*x + ux.value*ux.value);
-- return ux.value;
-+ FORCE_EVAL(x*x + ux.f*ux.f);
-+ return ux.f;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/nexttowardf.c musl-git/src/math/nexttowardf.c
---- musl-0.9.13/src/math/nexttowardf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/nexttowardf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -2,35 +2,34 @@
-
- float nexttowardf(float x, long double y)
- {
-- union fshape ux;
-+ union {float f; uint32_t i;} ux = {x};
- uint32_t e;
-
- if (isnan(x) || isnan(y))
- return x + y;
- if (x == y)
- return y;
-- ux.value = x;
- if (x == 0) {
-- ux.bits = 1;
-+ ux.i = 1;
- if (signbit(y))
-- ux.bits |= 0x80000000;
-+ ux.i |= 0x80000000;
- } else if (x < y) {
- if (signbit(x))
-- ux.bits--;
-+ ux.i--;
- else
-- ux.bits++;
-+ ux.i++;
- } else {
- if (signbit(x))
-- ux.bits++;
-+ ux.i++;
- else
-- ux.bits--;
-+ ux.i--;
- }
-- e = ux.bits & 0x7f800000;
-- /* raise overflow if ux.value is infinite and x is finite */
-+ e = ux.i & 0x7f800000;
-+ /* raise overflow if ux.f is infinite and x is finite */
- if (e == 0x7f800000)
- FORCE_EVAL(x+x);
-- /* raise underflow if ux.value is subnormal or zero */
-+ /* raise underflow if ux.f is subnormal or zero */
- if (e == 0)
-- FORCE_EVAL(x*x + ux.value*ux.value);
-- return ux.value;
-+ FORCE_EVAL(x*x + ux.f*ux.f);
-+ return ux.f;
- }
-diff -Nur musl-0.9.13/src/math/remainder.c musl-git/src/math/remainder.c
---- musl-0.9.13/src/math/remainder.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/remainder.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,66 +1,7 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_remainder.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/* remainder(x,p)
-- * Return :
-- * returns x REM p = x - [x/p]*p as if in infinite
-- * precise arithmetic, where [x/p] is the (infinite bit)
-- * integer nearest x/p (in half way case choose the even one).
-- * Method :
-- * Based on fmod() return x-[x/p]chopped*p exactlp.
-- */
-+#include <math.h>
-
--#include "libm.h"
--
--double remainder(double x, double p)
-+double remainder(double x, double y)
- {
-- int32_t hx,hp;
-- uint32_t sx,lx,lp;
-- double p_half;
--
-- EXTRACT_WORDS(hx, lx, x);
-- EXTRACT_WORDS(hp, lp, p);
-- sx = hx & 0x80000000;
-- hp &= 0x7fffffff;
-- hx &= 0x7fffffff;
--
-- /* purge off exception values */
-- if ((hp|lp) == 0 || /* p = 0 */
-- hx >= 0x7ff00000 || /* x not finite */
-- (hp >= 0x7ff00000 && (hp-0x7ff00000 | lp) != 0)) /* p is NaN */
-- return (x*p)/(x*p);
--
-- if (hp <= 0x7fdfffff)
-- x = fmod(x, p+p); /* now x < 2p */
-- if (((hx-hp)|(lx-lp)) == 0)
-- return 0.0*x;
-- x = fabs(x);
-- p = fabs(p);
-- if (hp < 0x00200000) {
-- if (x + x > p) {
-- x -= p;
-- if (x + x >= p)
-- x -= p;
-- }
-- } else {
-- p_half = 0.5*p;
-- if (x > p_half) {
-- x -= p;
-- if (x >= p_half)
-- x -= p;
-- }
-- }
-- GET_HIGH_WORD(hx, x);
-- if ((hx&0x7fffffff) == 0)
-- hx = 0;
-- SET_HIGH_WORD(x, hx^sx);
-- return x;
-+ int q;
-+ return remquo(x, y, &q);
- }
-diff -Nur musl-0.9.13/src/math/remainderf.c musl-git/src/math/remainderf.c
---- musl-0.9.13/src/math/remainderf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/remainderf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,59 +1,7 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/e_remainderf.c */
--/*
-- * Conversion to float by Ian Lance Taylor, Cygnus Support, ian@cygnus.com.
-- */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
-+#include <math.h>
-
--#include "libm.h"
--
--float remainderf(float x, float p)
-+float remainderf(float x, float y)
- {
-- int32_t hx,hp;
-- uint32_t sx;
-- float p_half;
--
-- GET_FLOAT_WORD(hx, x);
-- GET_FLOAT_WORD(hp, p);
-- sx = hx & 0x80000000;
-- hp &= 0x7fffffff;
-- hx &= 0x7fffffff;
--
-- /* purge off exception values */
-- if (hp == 0 || hx >= 0x7f800000 || hp > 0x7f800000) /* p = 0, x not finite, p is NaN */
-- return (x*p)/(x*p);
--
-- if (hp <= 0x7effffff)
-- x = fmodf(x, p + p); /* now x < 2p */
-- if (hx - hp == 0)
-- return 0.0f*x;
-- x = fabsf(x);
-- p = fabsf(p);
-- if (hp < 0x01000000) {
-- if (x + x > p) {
-- x -= p;
-- if (x + x >= p)
-- x -= p;
-- }
-- } else {
-- p_half = 0.5f*p;
-- if (x > p_half) {
-- x -= p;
-- if (x >= p_half)
-- x -= p;
-- }
-- }
-- GET_FLOAT_WORD(hx, x);
-- if ((hx & 0x7fffffff) == 0)
-- hx = 0;
-- SET_FLOAT_WORD(x, hx ^ sx);
-- return x;
-+ int q;
-+ return remquof(x, y, &q);
- }
-diff -Nur musl-0.9.13/src/math/remquo.c musl-git/src/math/remquo.c
---- musl-0.9.13/src/math/remquo.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/remquo.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,171 +1,82 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_remquo.c */
--/*-
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * Return the IEEE remainder and set *quo to the last n bits of the
-- * quotient, rounded to the nearest integer. We choose n=31 because
-- * we wind up computing all the integer bits of the quotient anyway as
-- * a side-effect of computing the remainder by the shift and subtract
-- * method. In practice, this is far more bits than are needed to use
-- * remquo in reduction algorithms.
-- */
--
--#include "libm.h"
--
--static const double Zero[] = {0.0, -0.0,};
-+#include <math.h>
-+#include <stdint.h>
-
- double remquo(double x, double y, int *quo)
- {
-- int32_t n,hx,hy,hz,ix,iy,sx,i;
-- uint32_t lx,ly,lz,q,sxy;
--
-- EXTRACT_WORDS(hx, lx, x);
-- EXTRACT_WORDS(hy, ly, y);
-- sxy = (hx ^ hy) & 0x80000000;
-- sx = hx & 0x80000000; /* sign of x */
-- hx ^= sx; /* |x| */
-- hy &= 0x7fffffff; /* |y| */
-+ union {double f; uint64_t i;} ux = {x}, uy = {y};
-+ int ex = ux.i>>52 & 0x7ff;
-+ int ey = uy.i>>52 & 0x7ff;
-+ int sx = ux.i>>63;
-+ int sy = uy.i>>63;
-+ uint32_t q;
-+ uint64_t i;
-+ uint64_t uxi = ux.i;
-
-- /* purge off exception values */
-- if ((hy|ly) == 0 || hx >= 0x7ff00000 || /* y = 0, or x not finite */
-- (hy|((ly|-ly)>>31)) > 0x7ff00000) /* or y is NaN */
-+ *quo = 0;
-+ if (uy.i<<1 == 0 || isnan(y) || ex == 0x7ff)
- return (x*y)/(x*y);
-- if (hx <= hy) {
-- if (hx < hy || lx < ly) { /* |x| < |y| return x or x-y */
-- q = 0;
-- goto fixup;
-- }
-- if (lx == ly) { /* |x| = |y| return x*0 */
-- *quo = sxy ? -1 : 1;
-- return Zero[(uint32_t)sx>>31];
-- }
-- }
-+ if (ux.i<<1 == 0)
-+ return x;
-
-- // FIXME: use ilogb?
--
-- /* determine ix = ilogb(x) */
-- if (hx < 0x00100000) { /* subnormal x */
-- if (hx == 0) {
-- for (ix = -1043, i=lx; i>0; i<<=1) ix--;
-- } else {
-- for (ix = -1022, i=hx<<11; i>0; i<<=1) ix--;
-- }
-- } else
-- ix = (hx>>20) - 1023;
--
-- /* determine iy = ilogb(y) */
-- if (hy < 0x00100000) { /* subnormal y */
-- if (hy == 0) {
-- for (iy = -1043, i=ly; i>0; i<<=1) iy--;
-- } else {
-- for (iy = -1022, i=hy<<11; i>0; i<<=1) iy--;
-- }
-- } else
-- iy = (hy>>20) - 1023;
--
-- /* set up {hx,lx}, {hy,ly} and align y to x */
-- if (ix >= -1022)
-- hx = 0x00100000|(0x000fffff&hx);
-- else { /* subnormal x, shift x to normal */
-- n = -1022 - ix;
-- if (n <= 31) {
-- hx = (hx<<n)|(lx>>(32-n));
-- lx <<= n;
-- } else {
-- hx = lx<<(n-32);
-- lx = 0;
-- }
-- }
-- if (iy >= -1022)
-- hy = 0x00100000|(0x000fffff&hy);
-- else { /* subnormal y, shift y to normal */
-- n = -1022 - iy;
-- if (n <= 31) {
-- hy = (hy<<n)|(ly>>(32-n));
-- ly <<= n;
-- } else {
-- hy = ly<<(n-32);
-- ly = 0;
-- }
-+ /* normalize x and y */
-+ if (!ex) {
-+ for (i = uxi<<12; i>>63 == 0; ex--, i <<= 1);
-+ uxi <<= -ex + 1;
-+ } else {
-+ uxi &= -1ULL >> 12;
-+ uxi |= 1ULL << 52;
-+ }
-+ if (!ey) {
-+ for (i = uy.i<<12; i>>63 == 0; ey--, i <<= 1);
-+ uy.i <<= -ey + 1;
-+ } else {
-+ uy.i &= -1ULL >> 12;
-+ uy.i |= 1ULL << 52;
- }
-
-- /* fix point fmod */
-- n = ix - iy;
- q = 0;
-- while (n--) {
-- hz = hx - hy;
-- lz = lx - ly;
-- if (lx < ly)
-- hz--;
-- if (hz < 0) {
-- hx = hx + hx + (lx>>31);
-- lx = lx + lx;
-- } else {
-- hx = hz + hz + (lz>>31);
-- lx = lz + lz;
-+ if (ex < ey) {
-+ if (ex+1 == ey)
-+ goto end;
-+ return x;
-+ }
-+
-+ /* x mod y */
-+ for (; ex > ey; ex--) {
-+ i = uxi - uy.i;
-+ if (i >> 63 == 0) {
-+ uxi = i;
- q++;
- }
-+ uxi <<= 1;
- q <<= 1;
- }
-- hz = hx - hy;
-- lz = lx - ly;
-- if (lx < ly)
-- hz--;
-- if (hz >= 0) {
-- hx = hz;
-- lx = lz;
-+ i = uxi - uy.i;
-+ if (i >> 63 == 0) {
-+ uxi = i;
- q++;
- }
--
-- /* convert back to floating value and restore the sign */
-- if ((hx|lx) == 0) { /* return sign(x)*0 */
-- q &= 0x7fffffff;
-- *quo = sxy ? -q : q;
-- return Zero[(uint32_t)sx>>31];
-- }
-- while (hx < 0x00100000) { /* normalize x */
-- hx = hx + hx + (lx>>31);
-- lx = lx + lx;
-- iy--;
-- }
-- if (iy >= -1022) { /* normalize output */
-- hx = (hx-0x00100000)|((iy+1023)<<20);
-- } else { /* subnormal output */
-- n = -1022 - iy;
-- if (n <= 20) {
-- lx = (lx>>n)|((uint32_t)hx<<(32-n));
-- hx >>= n;
-- } else if (n <= 31) {
-- lx = (hx<<(32-n))|(lx>>n);
-- hx = 0;
-- } else {
-- lx = hx>>(n-32);
-- hx = 0;
-- }
-- }
--fixup:
-- INSERT_WORDS(x, hx, lx);
-- y = fabs(y);
-- if (y < 0x1p-1021) {
-- if (x + x > y || (x + x == y && (q & 1))) {
-- q++;
-- x -= y;
-- }
-- } else if (x > 0.5*y || (x == 0.5*y && (q & 1))) {
-- q++;
-+ if (uxi == 0)
-+ ex = -60;
-+ else
-+ for (; uxi>>52 == 0; uxi <<= 1, ex--);
-+end:
-+ /* scale result and decide between |x| and |x|-|y| */
-+ if (ex > 0) {
-+ uxi -= 1ULL << 52;
-+ uxi |= (uint64_t)ex << 52;
-+ } else {
-+ uxi >>= -ex + 1;
-+ }
-+ ux.i = uxi;
-+ x = ux.f;
-+ if (sy)
-+ y = -y;
-+ if (ex == ey || (ex+1 == ey && (2*x > y || (2*x == y && q%2)))) {
- x -= y;
-+ q++;
- }
-- GET_HIGH_WORD(hx, x);
-- SET_HIGH_WORD(x, hx ^ sx);
- q &= 0x7fffffff;
-- *quo = sxy ? -q : q;
-- return x;
-+ *quo = sx^sy ? -(int)q : (int)q;
-+ return sx ? -x : x;
- }
-diff -Nur musl-0.9.13/src/math/remquof.c musl-git/src/math/remquof.c
---- musl-0.9.13/src/math/remquof.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/remquof.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,126 +1,82 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_remquof.c */
--/*-
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * Return the IEEE remainder and set *quo to the last n bits of the
-- * quotient, rounded to the nearest integer. We choose n=31 because
-- * we wind up computing all the integer bits of the quotient anyway as
-- * a side-effect of computing the remainder by the shift and subtract
-- * method. In practice, this is far more bits than are needed to use
-- * remquo in reduction algorithms.
-- */
--
--#include "libm.h"
--
--static const float Zero[] = {0.0, -0.0,};
-+#include <math.h>
-+#include <stdint.h>
-
- float remquof(float x, float y, int *quo)
- {
-- int32_t n,hx,hy,hz,ix,iy,sx,i;
-- uint32_t q,sxy;
-+ union {float f; uint32_t i;} ux = {x}, uy = {y};
-+ int ex = ux.i>>23 & 0xff;
-+ int ey = uy.i>>23 & 0xff;
-+ int sx = ux.i>>31;
-+ int sy = uy.i>>31;
-+ uint32_t q;
-+ uint32_t i;
-+ uint32_t uxi = ux.i;
-
-- GET_FLOAT_WORD(hx, x);
-- GET_FLOAT_WORD(hy, y);
-- sxy = (hx ^ hy) & 0x80000000;
-- sx = hx & 0x80000000; /* sign of x */
-- hx ^= sx; /* |x| */
-- hy &= 0x7fffffff; /* |y| */
--
-- /* purge off exception values */
-- if (hy == 0 || hx >= 0x7f800000 || hy > 0x7f800000) /* y=0,NaN;or x not finite */
-+ *quo = 0;
-+ if (uy.i<<1 == 0 || isnan(y) || ex == 0xff)
- return (x*y)/(x*y);
-- if (hx < hy) { /* |x| < |y| return x or x-y */
-- q = 0;
-- goto fixup;
-- } else if(hx==hy) { /* |x| = |y| return x*0*/
-- *quo = sxy ? -1 : 1;
-- return Zero[(uint32_t)sx>>31];
-- }
-+ if (ux.i<<1 == 0)
-+ return x;
-
-- /* determine ix = ilogb(x) */
-- if (hx < 0x00800000) { /* subnormal x */
-- for (ix = -126, i=hx<<8; i>0; i<<=1) ix--;
-- } else
-- ix = (hx>>23) - 127;
--
-- /* determine iy = ilogb(y) */
-- if (hy < 0x00800000) { /* subnormal y */
-- for (iy = -126, i=hy<<8; i>0; i<<=1) iy--;
-- } else
-- iy = (hy>>23) - 127;
--
-- /* set up {hx,lx}, {hy,ly} and align y to x */
-- if (ix >= -126)
-- hx = 0x00800000|(0x007fffff&hx);
-- else { /* subnormal x, shift x to normal */
-- n = -126 - ix;
-- hx <<= n;
-- }
-- if (iy >= -126)
-- hy = 0x00800000|(0x007fffff&hy);
-- else { /* subnormal y, shift y to normal */
-- n = -126 - iy;
-- hy <<= n;
-+ /* normalize x and y */
-+ if (!ex) {
-+ for (i = uxi<<9; i>>31 == 0; ex--, i <<= 1);
-+ uxi <<= -ex + 1;
-+ } else {
-+ uxi &= -1U >> 9;
-+ uxi |= 1U << 23;
-+ }
-+ if (!ey) {
-+ for (i = uy.i<<9; i>>31 == 0; ey--, i <<= 1);
-+ uy.i <<= -ey + 1;
-+ } else {
-+ uy.i &= -1U >> 9;
-+ uy.i |= 1U << 23;
- }
-
-- /* fix point fmod */
-- n = ix - iy;
- q = 0;
-- while (n--) {
-- hz = hx - hy;
-- if (hz < 0)
-- hx = hx << 1;
-- else {
-- hx = hz << 1;
-+ if (ex < ey) {
-+ if (ex+1 == ey)
-+ goto end;
-+ return x;
-+ }
-+
-+ /* x mod y */
-+ for (; ex > ey; ex--) {
-+ i = uxi - uy.i;
-+ if (i >> 31 == 0) {
-+ uxi = i;
- q++;
- }
-+ uxi <<= 1;
- q <<= 1;
- }
-- hz = hx - hy;
-- if (hz >= 0) {
-- hx = hz;
-+ i = uxi - uy.i;
-+ if (i >> 31 == 0) {
-+ uxi = i;
- q++;
- }
--
-- /* convert back to floating value and restore the sign */
-- if (hx == 0) { /* return sign(x)*0 */
-- q &= 0x7fffffff;
-- *quo = sxy ? -q : q;
-- return Zero[(uint32_t)sx>>31];
-- }
-- while (hx < 0x00800000) { /* normalize x */
-- hx <<= 1;
-- iy--;
-- }
-- if (iy >= -126) { /* normalize output */
-- hx = (hx-0x00800000)|((iy+127)<<23);
-- } else { /* subnormal output */
-- n = -126 - iy;
-- hx >>= n;
-- }
--fixup:
-- SET_FLOAT_WORD(x,hx);
-- y = fabsf(y);
-- if (y < 0x1p-125f) {
-- if (x + x > y || (x + x == y && (q & 1))) {
-- q++;
-- x -= y;
-- }
-- } else if (x > 0.5f*y || (x == 0.5f*y && (q & 1))) {
-- q++;
-+ if (uxi == 0)
-+ ex = -30;
-+ else
-+ for (; uxi>>23 == 0; uxi <<= 1, ex--);
-+end:
-+ /* scale result and decide between |x| and |x|-|y| */
-+ if (ex > 0) {
-+ uxi -= 1U << 23;
-+ uxi |= (uint32_t)ex << 23;
-+ } else {
-+ uxi >>= -ex + 1;
-+ }
-+ ux.i = uxi;
-+ x = ux.f;
-+ if (sy)
-+ y = -y;
-+ if (ex == ey || (ex+1 == ey && (2*x > y || (2*x == y && q%2)))) {
- x -= y;
-+ q++;
- }
-- GET_FLOAT_WORD(hx, x);
-- SET_FLOAT_WORD(x, hx ^ sx);
- q &= 0x7fffffff;
-- *quo = sxy ? -q : q;
-- return x;
-+ *quo = sx^sy ? -(int)q : (int)q;
-+ return sx ? -x : x;
- }
-diff -Nur musl-0.9.13/src/math/remquol.c musl-git/src/math/remquol.c
---- musl-0.9.13/src/math/remquol.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/remquol.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,15 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_remquol.c */
--/*-
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunSoft, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -18,177 +6,119 @@
- return remquo(x, y, quo);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#define BIAS (LDBL_MAX_EXP - 1)
--
--#if LDBL_MANL_SIZE > 32
--typedef uint64_t manl_t;
--#else
--typedef uint32_t manl_t;
--#endif
--
--#if LDBL_MANH_SIZE > 32
--typedef uint64_t manh_t;
--#else
--typedef uint32_t manh_t;
--#endif
--
--/*
-- * These macros add and remove an explicit integer bit in front of the
-- * fractional mantissa, if the architecture doesn't have such a bit by
-- * default already.
-- */
--#ifdef LDBL_IMPLICIT_NBIT
--#define SET_NBIT(hx) ((hx) | (1ULL << LDBL_MANH_SIZE))
--#define HFRAC_BITS LDBL_MANH_SIZE
--#else
--#define SET_NBIT(hx) (hx)
--#define HFRAC_BITS (LDBL_MANH_SIZE - 1)
--#endif
--
--#define MANL_SHIFT (LDBL_MANL_SIZE - 1)
--
--static const long double Zero[] = {0.0, -0.0};
--
--/*
-- * Return the IEEE remainder and set *quo to the last n bits of the
-- * quotient, rounded to the nearest integer. We choose n=31 because
-- * we wind up computing all the integer bits of the quotient anyway as
-- * a side-effect of computing the remainder by the shift and subtract
-- * method. In practice, this is far more bits than are needed to use
-- * remquo in reduction algorithms.
-- *
-- * Assumptions:
-- * - The low part of the mantissa fits in a manl_t exactly.
-- * - The high part of the mantissa fits in an int64_t with enough room
-- * for an explicit integer bit in front of the fractional bits.
-- */
- long double remquol(long double x, long double y, int *quo)
- {
-- union IEEEl2bits ux, uy;
-- int64_t hx,hz; /* We need a carry bit even if LDBL_MANH_SIZE is 32. */
-- manh_t hy;
-- manl_t lx,ly,lz;
-- int ix,iy,n,q,sx,sxy;
-+ union ldshape ux = {x}, uy = {y};
-+ int ex = ux.i.se & 0x7fff;
-+ int ey = uy.i.se & 0x7fff;
-+ int sx = ux.i.se >> 15;
-+ int sy = uy.i.se >> 15;
-+ uint32_t q;
-
-- ux.e = x;
-- uy.e = y;
-- sx = ux.bits.sign;
-- sxy = sx ^ uy.bits.sign;
-- ux.bits.sign = 0; /* |x| */
-- uy.bits.sign = 0; /* |y| */
-- x = ux.e;
--
-- /* purge off exception values */
-- if ((uy.bits.exp|uy.bits.manh|uy.bits.manl)==0 || /* y=0 */
-- (ux.bits.exp == BIAS + LDBL_MAX_EXP) || /* or x not finite */
-- (uy.bits.exp == BIAS + LDBL_MAX_EXP &&
-- ((uy.bits.manh&~LDBL_NBIT)|uy.bits.manl)!=0)) /* or y is NaN */
-+ *quo = 0;
-+ if (y == 0 || isnan(y) || ex == 0x7fff)
- return (x*y)/(x*y);
-- if (ux.bits.exp <= uy.bits.exp) {
-- if ((ux.bits.exp < uy.bits.exp) ||
-- (ux.bits.manh <= uy.bits.manh &&
-- (ux.bits.manh < uy.bits.manh ||
-- ux.bits.manl < uy.bits.manl))) {
-- q = 0;
-- goto fixup; /* |x|<|y| return x or x-y */
-- }
-- if (ux.bits.manh == uy.bits.manh && ux.bits.manl == uy.bits.manl) {
-- *quo = sxy ? -1 : 1;
-- return Zero[sx]; /* |x|=|y| return x*0*/
-- }
-- }
--
-- /* determine ix = ilogb(x) */
-- if (ux.bits.exp == 0) { /* subnormal x */
-- ux.e *= 0x1.0p512;
-- ix = ux.bits.exp - (BIAS + 512);
-- } else {
-- ix = ux.bits.exp - BIAS;
-- }
-+ if (x == 0)
-+ return x;
-
-- /* determine iy = ilogb(y) */
-- if (uy.bits.exp == 0) { /* subnormal y */
-- uy.e *= 0x1.0p512;
-- iy = uy.bits.exp - (BIAS + 512);
-- } else {
-- iy = uy.bits.exp - BIAS;
-+ /* normalize x and y */
-+ if (!ex) {
-+ ux.i.se = ex;
-+ ux.f *= 0x1p120f;
-+ ex = ux.i.se - 120;
-+ }
-+ if (!ey) {
-+ uy.i.se = ey;
-+ uy.f *= 0x1p120f;
-+ ey = uy.i.se - 120;
- }
-
-- /* set up {hx,lx}, {hy,ly} and align y to x */
-- hx = SET_NBIT(ux.bits.manh);
-- hy = SET_NBIT(uy.bits.manh);
-- lx = ux.bits.manl;
-- ly = uy.bits.manl;
--
-- /* fix point fmod */
-- n = ix - iy;
- q = 0;
--
-- while (n--) {
-- hz = hx - hy;
-- lz = lx - ly;
-- if (lx < ly)
-- hz -= 1;
-- if (hz < 0) {
-- hx = hx + hx + (lx>>MANL_SHIFT);
-- lx = lx + lx;
-- } else {
-- hx = hz + hz + (lz>>MANL_SHIFT);
-- lx = lz + lz;
-+ if (ex >= ey) {
-+ /* x mod y */
-+#if LDBL_MANT_DIG == 64
-+ uint64_t i, mx, my;
-+ mx = ux.i.m;
-+ my = uy.i.m;
-+ for (; ex > ey; ex--) {
-+ i = mx - my;
-+ if (mx >= my) {
-+ mx = 2*i;
-+ q++;
-+ q <<= 1;
-+ } else if (2*mx < mx) {
-+ mx = 2*mx - my;
-+ q <<= 1;
-+ q++;
-+ } else {
-+ mx = 2*mx;
-+ q <<= 1;
-+ }
-+ }
-+ i = mx - my;
-+ if (mx >= my) {
-+ mx = i;
- q++;
- }
-- q <<= 1;
-- }
-- hz = hx - hy;
-- lz = lx - ly;
-- if (lx < ly)
-- hz -= 1;
-- if (hz >= 0) {
-- hx = hz;
-- lx = lz;
-- q++;
-- }
--
-- /* convert back to floating value and restore the sign */
-- if ((hx|lx) == 0) { /* return sign(x)*0 */
-- q &= 0x7fffffff;
-- *quo = sxy ? -q : q;
-- return Zero[sx];
-- }
-- while (hx < (1ULL<<HFRAC_BITS)) { /* normalize x */
-- hx = hx + hx + (lx>>MANL_SHIFT);
-- lx = lx + lx;
-- iy -= 1;
-- }
-- ux.bits.manh = hx; /* The integer bit is truncated here if needed. */
-- ux.bits.manl = lx;
-- if (iy < LDBL_MIN_EXP) {
-- ux.bits.exp = iy + (BIAS + 512);
-- ux.e *= 0x1p-512;
-- } else {
-- ux.bits.exp = iy + BIAS;
-- }
-- ux.bits.sign = 0;
-- x = ux.e;
--fixup:
-- y = fabsl(y);
-- if (y < LDBL_MIN * 2) {
-- if (x + x > y || (x + x == y && (q & 1))) {
-+ if (mx == 0)
-+ ex = -120;
-+ else
-+ for (; mx >> 63 == 0; mx *= 2, ex--);
-+ ux.i.m = mx;
-+#elif LDBL_MANT_DIG == 113
-+ uint64_t hi, lo, xhi, xlo, yhi, ylo;
-+ xhi = (ux.i2.hi & -1ULL>>16) | 1ULL<<48;
-+ yhi = (uy.i2.hi & -1ULL>>16) | 1ULL<<48;
-+ xlo = ux.i2.lo;
-+ ylo = ux.i2.lo;
-+ for (; ex > ey; ex--) {
-+ hi = xhi - yhi;
-+ lo = xlo - ylo;
-+ if (xlo < ylo)
-+ hi -= 1;
-+ if (hi >> 63 == 0) {
-+ xhi = 2*hi + (lo>>63);
-+ xlo = 2*lo;
-+ q++;
-+ } else {
-+ xhi = 2*xhi + (xlo>>63);
-+ xlo = 2*xlo;
-+ }
-+ q <<= 1;
-+ }
-+ hi = xhi - yhi;
-+ lo = xlo - ylo;
-+ if (xlo < ylo)
-+ hi -= 1;
-+ if (hi >> 63 == 0) {
-+ xhi = hi;
-+ xlo = lo;
- q++;
-- x-=y;
- }
-- } else if (x > 0.5*y || (x == 0.5*y && (q & 1))) {
-- q++;
-- x-=y;
-+ if ((xhi|xlo) == 0)
-+ ex = -120;
-+ else
-+ for (; xhi >> 48 == 0; xhi = 2*xhi + (xlo>>63), xlo = 2*xlo, ex--);
-+ ux.i2.hi = xhi;
-+ ux.i2.lo = xlo;
-+#endif
- }
-
-- ux.e = x;
-- ux.bits.sign ^= sx;
-- x = ux.e;
--
-+ /* scale result and decide between |x| and |x|-|y| */
-+ if (ex <= 0) {
-+ ux.i.se = ex + 120;
-+ ux.f *= 0x1p-120f;
-+ } else
-+ ux.i.se = ex;
-+ x = ux.f;
-+ if (sy)
-+ y = -y;
-+ if (ex == ey || (ex+1 == ey && (2*x > y || (2*x == y && q%2)))) {
-+ x -= y;
-+ q++;
-+ }
- q &= 0x7fffffff;
-- *quo = sxy ? -q : q;
-- return x;
-+ *quo = sx^sy ? -(int)q : (int)q;
-+ return sx ? -x : x;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/rint.c musl-git/src/math/rint.c
---- musl-0.9.13/src/math/rint.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/rint.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,90 +1,20 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_rint.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * rint(x)
-- * Return x rounded to integral value according to the prevailing
-- * rounding mode.
-- * Method:
-- * Using floating addition.
-- * Exception:
-- * Inexact flag raised if x not equal to rint(x).
-- */
--
--#include "libm.h"
--
--static const double
--TWO52[2] = {
-- 4.50359962737049600000e+15, /* 0x43300000, 0x00000000 */
-- -4.50359962737049600000e+15, /* 0xC3300000, 0x00000000 */
--};
-+#include <math.h>
-+#include <stdint.h>
-
- double rint(double x)
- {
-- int32_t i0,j0,sx;
-- uint32_t i,i1;
-- double w,t;
-+ union {double f; uint64_t i;} u = {x};
-+ int e = u.i>>52 & 0x7ff;
-+ int s = u.i>>63;
-+ double_t y;
-
-- EXTRACT_WORDS(i0, i1, x);
-- // FIXME: signed shift
-- sx = (i0>>31) & 1;
-- j0 = ((i0>>20)&0x7ff) - 0x3ff;
-- if (j0 < 20) {
-- if (j0 < 0) {
-- if (((i0&0x7fffffff)|i1) == 0)
-- return x;
-- i1 |= i0 & 0x0fffff;
-- i0 &= 0xfffe0000;
-- i0 |= ((i1|-i1)>>12) & 0x80000;
-- SET_HIGH_WORD(x, i0);
-- STRICT_ASSIGN(double, w, TWO52[sx] + x);
-- t = w - TWO52[sx];
-- GET_HIGH_WORD(i0, t);
-- SET_HIGH_WORD(t, (i0&0x7fffffff)|(sx<<31));
-- return t;
-- } else {
-- i = 0x000fffff>>j0;
-- if (((i0&i)|i1) == 0)
-- return x; /* x is integral */
-- i >>= 1;
-- if (((i0&i)|i1) != 0) {
-- /*
-- * Some bit is set after the 0.5 bit. To avoid the
-- * possibility of errors from double rounding in
-- * w = TWO52[sx]+x, adjust the 0.25 bit to a lower
-- * guard bit. We do this for all j0<=51. The
-- * adjustment is trickiest for j0==18 and j0==19
-- * since then it spans the word boundary.
-- */
-- if (j0 == 19)
-- i1 = 0x40000000;
-- else if (j0 == 18)
-- i1 = 0x80000000;
-- else
-- i0 = (i0 & ~i)|(0x20000>>j0);
-- }
-- }
-- } else if (j0 > 51) {
-- if (j0 == 0x400)
-- return x+x; /* inf or NaN */
-- return x; /* x is integral */
-- } else {
-- i = (uint32_t)0xffffffff>>(j0-20);
-- if ((i1&i) == 0)
-- return x; /* x is integral */
-- i >>= 1;
-- if ((i1&i) != 0)
-- i1 = (i1 & ~i)|(0x40000000>>(j0-20));
-- }
-- INSERT_WORDS(x, i0, i1);
-- STRICT_ASSIGN(double, w, TWO52[sx] + x);
-- return w - TWO52[sx];
-+ if (e >= 0x3ff+52)
-+ return x;
-+ if (s)
-+ y = (double)(x - 0x1p52) + 0x1p52;
-+ else
-+ y = (double)(x + 0x1p52) - 0x1p52;
-+ if (y == 0)
-+ return s ? -0.0 : 0;
-+ return y;
- }
-diff -Nur musl-0.9.13/src/math/rintf.c musl-git/src/math/rintf.c
---- musl-0.9.13/src/math/rintf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/rintf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,48 +1,20 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_rintf.c */
--/*
-- * Conversion to float by Ian Lance Taylor, Cygnus Support, ian@cygnus.com.
-- */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--
--#include "libm.h"
--
--static const float
--TWO23[2] = {
-- 8.3886080000e+06, /* 0x4b000000 */
-- -8.3886080000e+06, /* 0xcb000000 */
--};
-+#include <math.h>
-+#include <stdint.h>
-
- float rintf(float x)
- {
-- int32_t i0,j0,sx;
-- float w,t;
-+ union {float f; uint32_t i;} u = {x};
-+ int e = u.i>>23 & 0xff;
-+ int s = u.i>>31;
-+ float_t y;
-
-- GET_FLOAT_WORD(i0, x);
-- sx = (i0>>31) & 1;
-- j0 = ((i0>>23)&0xff) - 0x7f;
-- if (j0 < 23) {
-- if (j0 < 0) {
-- if ((i0&0x7fffffff) == 0)
-- return x;
-- STRICT_ASSIGN(float, w, TWO23[sx] + x);
-- t = w - TWO23[sx];
-- GET_FLOAT_WORD(i0, t);
-- SET_FLOAT_WORD(t, (i0&0x7fffffff)|(sx<<31));
-- return t;
-- }
-- STRICT_ASSIGN(float, w, TWO23[sx] + x);
-- return w - TWO23[sx];
-- }
-- if (j0 == 0x80)
-- return x+x; /* inf or NaN */
-- return x; /* x is integral */
-+ if (e >= 0x7f+23)
-+ return x;
-+ if (s)
-+ y = (float)(x - 0x1p23f) + 0x1p23f;
-+ else
-+ y = (float)(x + 0x1p23f) - 0x1p23f;
-+ if (y == 0)
-+ return s ? -0.0f : 0.0f;
-+ return y;
- }
-diff -Nur musl-0.9.13/src/math/rintl.c musl-git/src/math/rintl.c
---- musl-0.9.13/src/math/rintl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/rintl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,30 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_rintl.c */
--/*-
-- * Copyright (c) 2008 David Schultz <das@FreeBSD.ORG>
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice, this list of conditions and the following disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
-- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-- * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
-- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
-- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
-- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
-- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
-- * SUCH DAMAGE.
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -33,53 +6,26 @@
- return rint(x);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--
--#define BIAS (LDBL_MAX_EXP - 1)
--
--static const float
--shift[2] = {
- #if LDBL_MANT_DIG == 64
-- 0x1.0p63, -0x1.0p63
-+#define TOINT 0x1p63
- #elif LDBL_MANT_DIG == 113
-- 0x1.0p112, -0x1.0p112
-+#define TOINT 0x1p112
- #endif
--};
--static const float zero[2] = { 0.0, -0.0 };
--
- long double rintl(long double x)
- {
-- union IEEEl2bits u;
-- uint32_t expsign;
-- int ex, sign;
--
-- u.e = x;
-- expsign = u.xbits.expsign;
-- ex = expsign & 0x7fff;
--
-- if (ex >= BIAS + LDBL_MANT_DIG - 1) {
-- if (ex == BIAS + LDBL_MAX_EXP)
-- return x + x; /* Inf, NaN, or unsupported format */
-- return x; /* finite and already an integer */
-- }
-- sign = expsign >> 15;
--
-- /*
-- * The following code assumes that intermediate results are
-- * evaluated in long double precision. If they are evaluated in
-- * greater precision, double rounding may occur, and if they are
-- * evaluated in less precision (as on i386), results will be
-- * wildly incorrect.
-- */
-- x += shift[sign];
-- x -= shift[sign];
--
-- /*
-- * If the result is +-0, then it must have the same sign as x, but
-- * the above calculation doesn't always give this. Fix up the sign.
-- */
-- if (ex < BIAS && x == 0.0)
-- return zero[sign];
--
-- return x;
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-+ int s = u.i.se >> 15;
-+ long double y;
-+
-+ if (e >= 0x3fff+LDBL_MANT_DIG-1)
-+ return x;
-+ if (s)
-+ y = x - TOINT + TOINT;
-+ else
-+ y = x + TOINT - TOINT;
-+ if (y == 0)
-+ return 0*x;
-+ return y;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/round.c musl-git/src/math/round.c
---- musl-0.9.13/src/math/round.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/round.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,48 +1,28 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_round.c */
--/*-
-- * Copyright (c) 2003, Steven G. Kargl
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice unmodified, this list of conditions, and the following
-- * disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-- */
--
--#include <math.h>
-+#include "libm.h"
-
- double round(double x)
- {
-- double t;
-+ union {double f; uint64_t i;} u = {x};
-+ int e = u.i >> 52 & 0x7ff;
-+ double_t y;
-
-- if (!isfinite(x))
-+ if (e >= 0x3ff+52)
- return x;
--
-- if (x >= 0.0) {
-- t = floor(x);
-- if (t - x <= -0.5)
-- t += 1.0;
-- return t;
-- } else {
-- t = floor(-x);
-- if (t + x <= -0.5)
-- t += 1.0;
-- return -t;
-+ if (u.i >> 63)
-+ x = -x;
-+ if (e < 0x3ff-1) {
-+ /* raise inexact if x!=0 */
-+ FORCE_EVAL(x + 0x1p52);
-+ return 0*u.f;
- }
-+ y = (double)(x + 0x1p52) - 0x1p52 - x;
-+ if (y > 0.5)
-+ y = y + x - 1;
-+ else if (y <= -0.5)
-+ y = y + x + 1;
-+ else
-+ y = y + x;
-+ if (u.i >> 63)
-+ y = -y;
-+ return y;
- }
-diff -Nur musl-0.9.13/src/math/roundf.c musl-git/src/math/roundf.c
---- musl-0.9.13/src/math/roundf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/roundf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,48 +1,27 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_roundf.c */
--/*-
-- * Copyright (c) 2003, Steven G. Kargl
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice unmodified, this list of conditions, and the following
-- * disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-- */
--
--#include <math.h>
-+#include "libm.h"
-
- float roundf(float x)
- {
-- float t;
-+ union {float f; uint32_t i;} u = {x};
-+ int e = u.i >> 23 & 0xff;
-+ float_t y;
-
-- if (!isfinite(x))
-+ if (e >= 0x7f+23)
- return x;
--
-- if (x >= 0.0) {
-- t = floorf(x);
-- if (t - x <= -0.5)
-- t += 1.0;
-- return t;
-- } else {
-- t = floorf(-x);
-- if (t + x <= -0.5)
-- t += 1.0;
-- return -t;
-+ if (u.i >> 31)
-+ x = -x;
-+ if (e < 0x7f-1) {
-+ FORCE_EVAL(x + 0x1p23f);
-+ return 0*u.f;
- }
-+ y = (float)(x + 0x1p23f) - 0x1p23f - x;
-+ if (y > 0.5f)
-+ y = y + x - 1;
-+ else if (y <= -0.5f)
-+ y = y + x + 1;
-+ else
-+ y = y + x;
-+ if (u.i >> 31)
-+ y = -y;
-+ return y;
- }
-diff -Nur musl-0.9.13/src/math/roundl.c musl-git/src/math/roundl.c
---- musl-0.9.13/src/math/roundl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/roundl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,56 +1,39 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_roundl.c */
--/*-
-- * Copyright (c) 2003, Steven G. Kargl
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice unmodified, this list of conditions, and the following
-- * disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-- */
--
--#include <math.h>
--#include <float.h>
-+#include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
- long double roundl(long double x)
- {
- return round(x);
- }
--#else
-+#elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
-+#if LDBL_MANT_DIG == 64
-+#define TOINT 0x1p63
-+#elif LDBL_MANT_DIG == 113
-+#define TOINT 0x1p112
-+#endif
- long double roundl(long double x)
- {
-- long double t;
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-+ long double y;
-
-- if (!isfinite(x))
-+ if (e >= 0x3fff+LDBL_MANT_DIG-1)
- return x;
--
-- if (x >= 0.0) {
-- t = floorl(x);
-- if (t - x <= -0.5)
-- t += 1.0;
-- return t;
-- } else {
-- t = floorl(-x);
-- if (t + x <= -0.5)
-- t += 1.0;
-- return -t;
-+ if (u.i.se >> 15)
-+ x = -x;
-+ if (e < 0x3fff-1) {
-+ FORCE_EVAL(x + TOINT);
-+ return 0*u.f;
- }
-+ y = x + TOINT - TOINT - x;
-+ if (y > 0.5)
-+ y = y + x - 1;
-+ else if (y <= -0.5)
-+ y = y + x + 1;
-+ else
-+ y = y + x;
-+ if (u.i.se >> 15)
-+ y = -y;
-+ return y;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/scalbn.c musl-git/src/math/scalbn.c
---- musl-0.9.13/src/math/scalbn.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/scalbn.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,29 +1,31 @@
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- double scalbn(double x, int n)
- {
-- double scale;
-+ union {double f; uint64_t i;} u;
-+ double_t y = x;
-
- if (n > 1023) {
-- x *= 0x1p1023;
-+ y *= 0x1p1023;
- n -= 1023;
- if (n > 1023) {
-- x *= 0x1p1023;
-+ y *= 0x1p1023;
- n -= 1023;
- if (n > 1023)
- n = 1023;
- }
- } else if (n < -1022) {
-- x *= 0x1p-1022;
-+ y *= 0x1p-1022;
- n += 1022;
- if (n < -1022) {
-- x *= 0x1p-1022;
-+ y *= 0x1p-1022;
- n += 1022;
- if (n < -1022)
- n = -1022;
- }
- }
-- INSERT_WORDS(scale, (uint32_t)(0x3ff+n)<<20, 0);
-- STRICT_ASSIGN(double, x, x * scale);
-+ u.i = (uint64_t)(0x3ff+n)<<52;
-+ x = y * u.f;
- return x;
- }
-diff -Nur musl-0.9.13/src/math/scalbnf.c musl-git/src/math/scalbnf.c
---- musl-0.9.13/src/math/scalbnf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/scalbnf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,29 +1,31 @@
--#include "libm.h"
-+#include <math.h>
-+#include <stdint.h>
-
- float scalbnf(float x, int n)
- {
-- float scale;
-+ union {float f; uint32_t i;} u;
-+ float_t y = x;
-
- if (n > 127) {
-- x *= 0x1p127f;
-+ y *= 0x1p127f;
- n -= 127;
- if (n > 127) {
-- x *= 0x1p127f;
-+ y *= 0x1p127f;
- n -= 127;
- if (n > 127)
- n = 127;
- }
- } else if (n < -126) {
-- x *= 0x1p-126f;
-+ y *= 0x1p-126f;
- n += 126;
- if (n < -126) {
-- x *= 0x1p-126f;
-+ y *= 0x1p-126f;
- n += 126;
- if (n < -126)
- n = -126;
- }
- }
-- SET_FLOAT_WORD(scale, (uint32_t)(0x7f+n)<<23);
-- STRICT_ASSIGN(float, x, x * scale);
-+ u.i = (uint32_t)(0x7f+n)<<23;
-+ x = y * u.f;
- return x;
- }
-diff -Nur musl-0.9.13/src/math/scalbnl.c musl-git/src/math/scalbnl.c
---- musl-0.9.13/src/math/scalbnl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/scalbnl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -8,7 +8,7 @@
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- long double scalbnl(long double x, int n)
- {
-- union IEEEl2bits scale;
-+ union ldshape u;
-
- if (n > 16383) {
- x *= 0x1p16383L;
-@@ -29,8 +29,8 @@
- n = -16382;
- }
- }
-- scale.e = 1.0;
-- scale.bits.exp = 0x3fff + n;
-- return x * scale.e;
-+ u.f = 1.0;
-+ u.i.se = 0x3fff + n;
-+ return x * u.f;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/signgam.c musl-git/src/math/signgam.c
---- musl-0.9.13/src/math/signgam.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/signgam.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,4 +1,5 @@
--#include "libm.h"
-+#include <math.h>
-+#include "libc.h"
-
- int __signgam = 0;
-
-diff -Nur musl-0.9.13/src/math/sincosl.c musl-git/src/math/sincosl.c
---- musl-0.9.13/src/math/sincosl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/sincosl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -9,25 +9,19 @@
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- void sincosl(long double x, long double *sin, long double *cos)
- {
-- union IEEEl2bits u;
-+ union ldshape u = {x};
- unsigned n;
- long double y[2], s, c;
-
-- u.e = x;
-- u.bits.sign = 0;
--
-- /* x = nan or inf */
-- if (u.bits.exp == 0x7fff) {
-+ u.i.se &= 0x7fff;
-+ if (u.i.se == 0x7fff) {
- *sin = *cos = x - x;
- return;
- }
--
-- /* |x| < (double)pi/4 */
-- if (u.e < M_PI_4) {
-- /* |x| < 0x1p-64 */
-- if (u.bits.exp < 0x3fff - 64) {
-+ if (u.f < M_PI_4) {
-+ if (u.i.se < 0x3fff - LDBL_MANT_DIG) {
- /* raise underflow if subnormal */
-- if (u.bits.exp == 0) FORCE_EVAL(x*0x1p-120f);
-+ if (u.i.se == 0) FORCE_EVAL(x*0x1p-120f);
- *sin = x;
- /* raise inexact if x!=0 */
- *cos = 1.0 + x;
-@@ -37,7 +31,6 @@
- *cos = __cosl(x, 0);
- return;
- }
--
- n = __rem_pio2l(x, y);
- s = __sinl(y[0], y[1], 1);
- c = __cosl(y[0], y[1]);
-diff -Nur musl-0.9.13/src/math/sinhl.c musl-git/src/math/sinhl.c
---- musl-0.9.13/src/math/sinhl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/sinhl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -8,10 +8,7 @@
- #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
- long double sinhl(long double x)
- {
-- union {
-- long double f;
-- struct{uint64_t m; uint16_t se; uint16_t pad;} i;
-- } u = {.f = x};
-+ union ldshape u = {x};
- unsigned ex = u.i.se & 0x7fff;
- long double h, t, absx;
-
-diff -Nur musl-0.9.13/src/math/sinl.c musl-git/src/math/sinl.c
---- musl-0.9.13/src/math/sinl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/sinl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,31 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_sinl.c */
--/*-
-- * Copyright (c) 2007 Steven G. Kargl
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice unmodified, this list of conditions, and the following
-- * disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-- */
--
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -36,46 +8,34 @@
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- long double sinl(long double x)
- {
-- union IEEEl2bits z;
-+ union ldshape u = {x};
- unsigned n;
-- long double y[2];
-- long double hi, lo;
--
-- z.e = x;
-- z.bits.sign = 0;
-+ long double y[2], hi, lo;
-
-- /* If x = NaN or Inf, then sin(x) = NaN. */
-- if (z.bits.exp == 0x7fff)
-- return (x - x) / (x - x);
--
-- /* |x| < (double)pi/4 */
-- if (z.e < M_PI_4) {
-- /* |x| < 0x1p-64 */
-- if (z.bits.exp < 0x3fff - 64) {
-+ u.i.se &= 0x7fff;
-+ if (u.i.se == 0x7fff)
-+ return x - x;
-+ if (u.f < M_PI_4) {
-+ if (u.i.se < 0x3fff - LDBL_MANT_DIG/2) {
- /* raise inexact if x!=0 and underflow if subnormal */
-- FORCE_EVAL(z.bits.exp == 0 ? x/0x1p120f : x+0x1p120f);
-+ FORCE_EVAL(u.i.se == 0 ? x*0x1p-120f : x+0x1p120f);
- return x;
- }
- return __sinl(x, 0.0, 0);
- }
--
- n = __rem_pio2l(x, y);
- hi = y[0];
- lo = y[1];
- switch (n & 3) {
- case 0:
-- hi = __sinl(hi, lo, 1);
-- break;
-+ return __sinl(hi, lo, 1);
- case 1:
-- hi = __cosl(hi, lo);
-- break;
-+ return __cosl(hi, lo);
- case 2:
-- hi = -__sinl(hi, lo, 1);
-- break;
-+ return -__sinl(hi, lo, 1);
- case 3:
-- hi = -__cosl(hi, lo);
-- break;
-+ default:
-+ return -__cosl(hi, lo);
- }
-- return hi;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/sqrtl.c musl-git/src/math/sqrtl.c
---- musl-0.9.13/src/math/sqrtl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/sqrtl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -2,8 +2,6 @@
-
- long double sqrtl(long double x)
- {
-- /* FIXME: implement sqrtl in C. At least this works for now on
-- * ARM (which uses ld64), the only arch without sqrtl asm
-- * that's supported so far. */
-+ /* FIXME: implement in C, this is for LDBL_MANT_DIG == 64 only */
- return sqrt(x);
- }
-diff -Nur musl-0.9.13/src/math/tanhl.c musl-git/src/math/tanhl.c
---- musl-0.9.13/src/math/tanhl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/tanhl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -8,10 +8,7 @@
- #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
- long double tanhl(long double x)
- {
-- union {
-- long double f;
-- struct{uint64_t m; uint16_t se; uint16_t pad;} i;
-- } u = {.f = x};
-+ union ldshape u = {x};
- unsigned ex = u.i.se & 0x7fff;
- unsigned sign = u.i.se & 0x8000;
- uint32_t w;
-diff -Nur musl-0.9.13/src/math/tanl.c musl-git/src/math/tanl.c
---- musl-0.9.13/src/math/tanl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/tanl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,35 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_tanl.c */
--/*-
-- * Copyright (c) 2007 Steven G. Kargl
-- * All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice unmodified, this list of conditions, and the following
-- * disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-- */
--/*
-- * Limited testing on pseudorandom numbers drawn within [0:4e8] shows
-- * an accuracy of <= 1.5 ULP where 247024 values of x out of 40 million
-- * possibles resulted in tan(x) that exceeded 0.5 ULP (ie., 0.6%).
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -40,28 +8,21 @@
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
- long double tanl(long double x)
- {
-- union IEEEl2bits z;
-+ union ldshape u = {x};
- long double y[2];
- unsigned n;
-
-- z.e = x;
-- z.bits.sign = 0;
--
-- /* If x = NaN or Inf, then tan(x) = NaN. */
-- if (z.bits.exp == 0x7fff)
-- return (x - x) / (x - x);
--
-- /* |x| < (double)pi/4 */
-- if (z.e < M_PI_4) {
-- /* |x| < 0x1p-64 */
-- if (z.bits.exp < 0x3fff - 64) {
-+ u.i.se &= 0x7fff;
-+ if (u.i.se == 0x7fff)
-+ return x - x;
-+ if (u.f < M_PI_4) {
-+ if (u.i.se < 0x3fff - LDBL_MANT_DIG/2) {
- /* raise inexact if x!=0 and underflow if subnormal */
-- FORCE_EVAL(z.bits.exp == 0 ? x/0x1p120f : x+0x1p120f);
-+ FORCE_EVAL(u.i.se == 0 ? x*0x1p-120f : x+0x1p120f);
- return x;
- }
- return __tanl(x, 0, 0);
- }
--
- n = __rem_pio2l(x, y);
- return __tanl(y[0], y[1], n&1);
- }
-diff -Nur musl-0.9.13/src/math/trunc.c musl-git/src/math/trunc.c
---- musl-0.9.13/src/math/trunc.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/trunc.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,63 +1,19 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_trunc.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * trunc(x)
-- * Return x rounded toward 0 to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to trunc(x).
-- */
--
- #include "libm.h"
-
--static const double huge = 1.0e300;
--
- double trunc(double x)
- {
-- int32_t i0,i1,j0;
-- uint32_t i;
-+ union {double f; uint64_t i;} u = {x};
-+ int e = (int)(u.i >> 52 & 0x7ff) - 0x3ff + 12;
-+ uint64_t m;
-
-- EXTRACT_WORDS(i0, i1, x);
-- j0 = ((i0>>20)&0x7ff) - 0x3ff;
-- if (j0 < 20) {
-- if (j0 < 0) { /* |x|<1, return 0*sign(x) */
-- /* raise inexact if x != 0 */
-- if (huge+x > 0.0) {
-- i0 &= 0x80000000U;
-- i1 = 0;
-- }
-- } else {
-- i = 0x000fffff>>j0;
-- if (((i0&i)|i1) == 0)
-- return x; /* x is integral */
-- /* raise inexact */
-- if (huge+x > 0.0) {
-- i0 &= ~i;
-- i1 = 0;
-- }
-- }
-- } else if (j0 > 51) {
-- if (j0 == 0x400)
-- return x + x; /* inf or NaN */
-- return x; /* x is integral */
-- } else {
-- i = (uint32_t)0xffffffff>>(j0-20);
-- if ((i1&i) == 0)
-- return x; /* x is integral */
-- /* raise inexact */
-- if (huge+x > 0.0)
-- i1 &= ~i;
-- }
-- INSERT_WORDS(x, i0, i1);
-- return x;
-+ if (e >= 52 + 12)
-+ return x;
-+ if (e < 12)
-+ e = 1;
-+ m = -1ULL >> e;
-+ if ((u.i & m) == 0)
-+ return x;
-+ FORCE_EVAL(x + 0x1p120f);
-+ u.i &= ~m;
-+ return u.f;
- }
-diff -Nur musl-0.9.13/src/math/truncf.c musl-git/src/math/truncf.c
---- musl-0.9.13/src/math/truncf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/truncf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,52 +1,19 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_truncf.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * truncf(x)
-- * Return x rounded toward 0 to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to truncf(x).
-- */
--
- #include "libm.h"
-
--static const float huge = 1.0e30f;
--
- float truncf(float x)
- {
-- int32_t i0,j0;
-- uint32_t i;
-+ union {float f; uint32_t i;} u = {x};
-+ int e = (int)(u.i >> 23 & 0xff) - 0x7f + 9;
-+ uint32_t m;
-
-- GET_FLOAT_WORD(i0, x);
-- j0 = ((i0>>23)&0xff) - 0x7f;
-- if (j0 < 23) {
-- if (j0 < 0) { /* |x|<1, return 0*sign(x) */
-- /* raise inexact if x != 0 */
-- if (huge+x > 0.0f)
-- i0 &= 0x80000000;
-- } else {
-- i = 0x007fffff>>j0;
-- if ((i0&i) == 0)
-- return x; /* x is integral */
-- /* raise inexact */
-- if (huge+x > 0.0f)
-- i0 &= ~i;
-- }
-- } else {
-- if (j0 == 0x80)
-- return x + x; /* inf or NaN */
-- return x; /* x is integral */
-- }
-- SET_FLOAT_WORD(x, i0);
-- return x;
-+ if (e >= 23 + 9)
-+ return x;
-+ if (e < 9)
-+ e = 1;
-+ m = -1U >> e;
-+ if ((u.i & m) == 0)
-+ return x;
-+ FORCE_EVAL(x + 0x1p120f);
-+ u.i &= ~m;
-+ return u.f;
- }
-diff -Nur musl-0.9.13/src/math/truncl.c musl-git/src/math/truncl.c
---- musl-0.9.13/src/math/truncl.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/truncl.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,23 +1,3 @@
--/* origin: FreeBSD /usr/src/lib/msun/src/s_truncl.c */
--/*
-- * ====================================================
-- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
-- *
-- * Developed at SunPro, a Sun Microsystems, Inc. business.
-- * Permission to use, copy, modify, and distribute this
-- * software is freely granted, provided that this notice
-- * is preserved.
-- * ====================================================
-- */
--/*
-- * truncl(x)
-- * Return x rounded toward 0 to integral value
-- * Method:
-- * Bit twiddling.
-- * Exception:
-- * Inexact flag raised if x not equal to truncl(x).
-- */
--
- #include "libm.h"
-
- #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
-@@ -26,43 +6,31 @@
- return trunc(x);
- }
- #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384
--#ifdef LDBL_IMPLICIT_NBIT
--#define MANH_SIZE (LDBL_MANH_SIZE + 1)
--#else
--#define MANH_SIZE LDBL_MANH_SIZE
-+#if LDBL_MANT_DIG == 64
-+#define TOINT 0x1p63
-+#elif LDBL_MANT_DIG == 113
-+#define TOINT 0x1p112
- #endif
--
--static const long double huge = 1.0e300;
--static const float zero[] = { 0.0, -0.0 };
--
- long double truncl(long double x)
- {
-- union IEEEl2bits u = { .e = x };
-- int e = u.bits.exp - LDBL_MAX_EXP + 1;
-+ union ldshape u = {x};
-+ int e = u.i.se & 0x7fff;
-+ int s = u.i.se >> 15;
-+ long double y;
-
-- if (e < MANH_SIZE - 1) {
-- if (e < 0) {
-- /* raise inexact if x != 0 */
-- if (huge + x > 0.0)
-- u.e = zero[u.bits.sign];
-- } else {
-- uint64_t m = ((1llu << MANH_SIZE) - 1) >> (e + 1);
-- if (((u.bits.manh & m) | u.bits.manl) == 0)
-- return x; /* x is integral */
-- /* raise inexact */
-- if (huge + x > 0.0) {
-- u.bits.manh &= ~m;
-- u.bits.manl = 0;
-- }
-- }
-- } else if (e < LDBL_MANT_DIG - 1) {
-- uint64_t m = (uint64_t)-1 >> (64 - LDBL_MANT_DIG + e + 1);
-- if ((u.bits.manl & m) == 0)
-- return x; /* x is integral */
-- /* raise inexact */
-- if (huge + x > 0.0)
-- u.bits.manl &= ~m;
-+ if (e >= 0x3fff+LDBL_MANT_DIG-1)
-+ return x;
-+ if (e <= 0x3fff-1) {
-+ FORCE_EVAL(x + 0x1p120f);
-+ return x*0;
- }
-- return u.e;
-+ /* y = int(|x|) - |x|, where int(|x|) is an integer neighbor of |x| */
-+ if (s)
-+ x = -x;
-+ y = x + TOINT - TOINT - x;
-+ if (y > 0)
-+ y -= 1;
-+ x += y;
-+ return s ? -x : x;
- }
- #endif
-diff -Nur musl-0.9.13/src/math/x86_64/ceill.s musl-git/src/math/x86_64/ceill.s
---- musl-0.9.13/src/math/x86_64/ceill.s 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/x86_64/ceill.s 2013-09-16 20:31:39.000000000 +0200
-@@ -1 +1 @@
--# see floor.s
-+# see floorl.s
-diff -Nur musl-0.9.13/src/math/x86_64/exp2l.s musl-git/src/math/x86_64/exp2l.s
---- musl-0.9.13/src/math/x86_64/exp2l.s 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/x86_64/exp2l.s 2013-09-16 20:31:39.000000000 +0200
-@@ -4,8 +4,18 @@
- fldt 8(%rsp)
- fldl2e
- fmulp
-+ movl $0xc2820000,-4(%rsp)
-+ flds -4(%rsp)
-+ fucomp %st(1)
-+ fnstsw %ax
-+ sahf
- fld1
-- fld %st(1)
-+ jb 1f
-+ # x*log2e <= -65, return -1 without underflow
-+ fstp %st(1)
-+ fchs
-+ ret
-+1: fld %st(1)
- fabs
- fucom %st(1)
- fnstsw %ax
-@@ -26,44 +36,32 @@
- .type exp2l,@function
- exp2l:
- fldt 8(%rsp)
--1: mov $0x467ff000,%eax
-- mov %eax,-16(%rsp)
-- mov $0x80000000,%eax
-- mov %eax,-20(%rsp)
-- xor %eax,%eax
-- mov %eax,-24(%rsp)
-- flds -16(%rsp) # 16380
-+1: fld %st(0)
-+ sub $16,%rsp
-+ fstpt (%rsp)
-+ mov 8(%rsp),%ax
-+ and $0x7fff,%ax
-+ cmp $0x3fff+13,%ax
-+ jb 4f # |x| < 8192
-+ cmp $0x3fff+15,%ax
-+ jae 3f # |x| >= 32768
-+ fsts (%rsp)
-+ cmpl $0xc67ff800,(%rsp)
-+ jb 2f # x > -16382
-+ movl $0x5f000000,(%rsp)
-+ flds (%rsp) # 0x1p63
- fld %st(1)
-- fabs
-- fucom %st(1)
-+ fsub %st(1)
-+ faddp
-+ fucomp %st(1)
- fnstsw
-- fstp %st(0)
-- fstp %st(0)
- sahf
-- ja 3f # |x| > 16380
-- jp 2f # x is nan (avoid invalid except in fistp)
-- fld %st(0)
-- fistpl -16(%rsp)
-- fildl -16(%rsp)
-- fxch %st(1)
-- fsub %st(1)
-- mov $0x3fff,%eax
-- add %eax,-16(%rsp)
-- f2xm1
-- fld1
-- faddp # 2^(x-rint(x))
-- fldt -24(%rsp) # 2^rint(x)
-- fmulp
--2: fstp %st(1)
-- ret
--
--3: fld %st(0)
-- fstpt -24(%rsp)
-- fld1
-- mov -15(%rsp),%ax
-- and $0x7fff,%ax
-- cmp $0x7fff,%ax
-- je 1f # x = +-inf
-+ je 2f # x - 0x1p63 + 0x1p63 == x
-+ movl $1,(%rsp)
-+ flds (%rsp) # 0x1p-149
-+ fdiv %st(1)
-+ fstps (%rsp) # raise underflow
-+2: fld1
- fld %st(1)
- frndint
- fxch %st(2)
-@@ -72,4 +70,21 @@
- faddp # 2^(x-rint(x))
- 1: fscale
- fstp %st(1)
-+ add $16,%rsp
-+ ret
-+3: xor %eax,%eax
-+4: cmp $0x3fff-64,%ax
-+ fld1
-+ jb 1b # |x| < 0x1p-64
-+ fstpt (%rsp)
-+ fistl 8(%rsp)
-+ fildl 8(%rsp)
-+ fsubrp %st(1)
-+ addl $0x3fff,8(%rsp)
-+ f2xm1
-+ fld1
-+ faddp # 2^(x-rint(x))
-+ fldt (%rsp) # 2^rint(x)
-+ fmulp
-+ add $16,%rsp
- ret
-diff -Nur musl-0.9.13/src/math/x86_64/lrintl.s musl-git/src/math/x86_64/lrintl.s
---- musl-0.9.13/src/math/x86_64/lrintl.s 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/x86_64/lrintl.s 2013-09-16 20:31:39.000000000 +0200
-@@ -2,6 +2,6 @@
- .type lrintl,@function
- lrintl:
- fldt 8(%rsp)
-- fistpl 8(%rsp)
-- mov 8(%rsp),%eax
-+ fistpll 8(%rsp)
-+ mov 8(%rsp),%rax
- ret
-diff -Nur musl-0.9.13/src/math/x86_64/truncl.s musl-git/src/math/x86_64/truncl.s
---- musl-0.9.13/src/math/x86_64/truncl.s 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/math/x86_64/truncl.s 2013-09-16 20:31:39.000000000 +0200
-@@ -1 +1 @@
--# see floor.s
-+# see floorl.s
-diff -Nur musl-0.9.13/src/misc/realpath.c musl-git/src/misc/realpath.c
---- musl-0.9.13/src/misc/realpath.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/misc/realpath.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,10 +1,11 @@
- #include <stdlib.h>
--#include <stdio.h>
- #include <limits.h>
- #include <sys/stat.h>
- #include <fcntl.h>
- #include <errno.h>
- #include <unistd.h>
-+#include <string.h>
-+#include "syscall.h"
-
- void __procfdname(char *, unsigned);
-
-@@ -14,38 +15,31 @@
- ssize_t r;
- struct stat st1, st2;
- char buf[15+3*sizeof(int)];
-- int alloc = 0;
-+ char tmp[PATH_MAX];
-
- if (!filename) {
- errno = EINVAL;
- return 0;
- }
-
-- fd = open(filename, O_RDONLY|O_NONBLOCK|O_CLOEXEC);
-+ fd = syscall(SYS_open, filename, O_PATH|O_NONBLOCK|O_CLOEXEC|O_LARGEFILE);
- if (fd < 0) return 0;
- __procfdname(buf, fd);
-
-- if (!resolved) {
-- alloc = 1;
-- resolved = malloc(PATH_MAX);
-- if (!resolved) return 0;
-- }
--
-- r = readlink(buf, resolved, PATH_MAX-1);
-+ r = readlink(buf, tmp, sizeof tmp - 1);
- if (r < 0) goto err;
-- resolved[r] = 0;
-+ tmp[r] = 0;
-
- fstat(fd, &st1);
-- r = stat(resolved, &st2);
-+ r = stat(tmp, &st2);
- if (r<0 || st1.st_dev != st2.st_dev || st1.st_ino != st2.st_ino) {
- if (!r) errno = ELOOP;
- goto err;
- }
-
-- close(fd);
-- return resolved;
-+ __syscall(SYS_close, fd);
-+ return resolved ? strcpy(resolved, tmp) : strdup(tmp);
- err:
-- if (alloc) free(resolved);
-- close(fd);
-+ __syscall(SYS_close, fd);
- return 0;
- }
-diff -Nur musl-0.9.13/src/mman/mprotect.c musl-git/src/mman/mprotect.c
---- musl-0.9.13/src/mman/mprotect.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/mman/mprotect.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,5 +1,5 @@
- #include <sys/mman.h>
--#include <limits.h>
-+#include "libc.h"
- #include "syscall.h"
-
- int mprotect(void *addr, size_t len, int prot)
-diff -Nur musl-0.9.13/src/signal/sigemptyset.c musl-git/src/signal/sigemptyset.c
---- musl-0.9.13/src/signal/sigemptyset.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/signal/sigemptyset.c 2013-09-16 20:31:39.000000000 +0200
-@@ -4,6 +4,10 @@
- int sigemptyset(sigset_t *set)
- {
- set->__bits[0] = 0;
-- if (sizeof(long)==4) set->__bits[1] = 0;
-+ if (sizeof(long)==4 || _NSIG > 65) set->__bits[1] = 0;
-+ if (sizeof(long)==4 && _NSIG > 65) {
-+ set->__bits[2] = 0;
-+ set->__bits[3] = 0;
-+ }
- return 0;
- }
-diff -Nur musl-0.9.13/src/signal/sigfillset.c musl-git/src/signal/sigfillset.c
---- musl-0.9.13/src/signal/sigfillset.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/signal/sigfillset.c 2013-09-16 20:31:39.000000000 +0200
-@@ -7,8 +7,13 @@
- #if ULONG_MAX == 0xffffffff
- set->__bits[0] = 0x7ffffffful;
- set->__bits[1] = 0xfffffffcul;
-+ if (_NSIG > 65) {
-+ set->__bits[2] = 0xfffffffful;
-+ set->__bits[3] = 0xfffffffful;
-+ }
- #else
- set->__bits[0] = 0xfffffffc7ffffffful;
-+ if (_NSIG > 65) set->__bits[1] = 0xfffffffffffffffful;
- #endif
- return 0;
- }
-diff -Nur musl-0.9.13/src/signal/sigqueue.c musl-git/src/signal/sigqueue.c
---- musl-0.9.13/src/signal/sigqueue.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/signal/sigqueue.c 2013-09-16 20:31:39.000000000 +0200
-@@ -3,6 +3,7 @@
- #include <unistd.h>
- #include <stdint.h>
- #include "syscall.h"
-+#include "pthread_impl.h"
-
- int sigqueue(pid_t pid, int sig, const union sigval value)
- {
-@@ -14,9 +15,9 @@
- si.si_code = SI_QUEUE;
- si.si_value = value;
- si.si_uid = getuid();
-- pthread_sigmask(SIG_BLOCK, (void *)(uint64_t[1]){-1}, &set);
-+ __block_app_sigs(&set);
- si.si_pid = getpid();
- r = syscall(SYS_rt_sigqueueinfo, pid, sig, &si);
-- pthread_sigmask(SIG_SETMASK, &set, 0);
-+ __restore_sigs(&set);
- return r;
- }
-diff -Nur musl-0.9.13/src/stdio/popen.c musl-git/src/stdio/popen.c
---- musl-0.9.13/src/stdio/popen.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/stdio/popen.c 2013-09-16 20:31:39.000000000 +0200
-@@ -39,7 +39,7 @@
- * remove the close-on-exec flag in the child without also creating
- * a file descriptor leak race condition in the parent. */
- if (p[1-op] == 1-op) {
-- int tmp = fcntl(F_DUPFD_CLOEXEC, 1-op, 0);
-+ int tmp = fcntl(1-op, F_DUPFD_CLOEXEC, 0);
- if (tmp < 0) {
- e = errno;
- goto fail;
-diff -Nur musl-0.9.13/src/stdio/vfscanf.c musl-git/src/stdio/vfscanf.c
---- musl-0.9.13/src/stdio/vfscanf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/stdio/vfscanf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -118,6 +118,8 @@
- }
-
- if (*p=='m') {
-+ wcs = 0;
-+ s = 0;
- alloc = !!dest;
- p++;
- } else {
-diff -Nur musl-0.9.13/src/stdio/vfwscanf.c musl-git/src/stdio/vfwscanf.c
---- musl-0.9.13/src/stdio/vfwscanf.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/stdio/vfwscanf.c 2013-09-16 20:31:39.000000000 +0200
-@@ -143,6 +143,8 @@
- }
-
- if (*p=='m') {
-+ wcs = 0;
-+ s = 0;
- alloc = !!dest;
- p++;
- } else {
-diff -Nur musl-0.9.13/src/temp/__randname.c musl-git/src/temp/__randname.c
---- musl-0.9.13/src/temp/__randname.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/temp/__randname.c 2013-09-16 20:31:39.000000000 +0200
-@@ -5,7 +5,7 @@
- int __clock_gettime(clockid_t, struct timespec *);
-
- /* This assumes that a check for the
-- template size has alrady been made */
-+ template size has already been made */
- char *__randname(char *template)
- {
- int i;
-diff -Nur musl-0.9.13/src/thread/mips/clone.s musl-git/src/thread/mips/clone.s
---- musl-0.9.13/src/thread/mips/clone.s 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/thread/mips/clone.s 2013-09-16 20:31:39.000000000 +0200
-@@ -3,6 +3,7 @@
- .type __clone,@function
- __clone:
- # Save function pointer and argument pointer on new thread stack
-+ and $5, $5, -8
- subu $5, $5, 16
- sw $4, 0($5)
- sw $7, 4($5)
-@@ -11,15 +12,18 @@
- lw $6, 16($sp)
- lw $7, 20($sp)
- lw $9, 24($sp)
-+ subu $sp, $sp, 16
- sw $9, 16($sp)
- li $2, 4120
- syscall
- beq $7, $0, 1f
- nop
-+ addu $sp, $sp, 16
- jr $ra
- subu $2, $0, $2
- 1: beq $2, $0, 1f
- nop
-+ addu $sp, $sp, 16
- jr $ra
- nop
- 1: lw $25, 0($sp)
-diff -Nur musl-0.9.13/src/thread/pthread_create.c musl-git/src/thread/pthread_create.c
---- musl-0.9.13/src/thread/pthread_create.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/thread/pthread_create.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,5 +1,7 @@
-+#define _GNU_SOURCE
- #include "pthread_impl.h"
- #include "stdio_impl.h"
-+#include "libc.h"
- #include <sys/mman.h>
-
- static void dummy_0()
-@@ -127,7 +129,9 @@
- size_t size, guard;
- struct pthread *self = pthread_self(), *new;
- unsigned char *map = 0, *stack = 0, *tsd = 0, *stack_limit;
-- unsigned flags = 0x7d8f00;
-+ unsigned flags = CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGHAND
-+ | CLONE_THREAD | CLONE_SYSVSEM | CLONE_SETTLS
-+ | CLONE_PARENT_SETTID | CLONE_CHILD_CLEARTID | CLONE_DETACHED;
- int do_sched = 0;
- pthread_attr_t attr = {0};
-
-@@ -197,7 +201,7 @@
- new->tsd = (void *)tsd;
- if (attr._a_detach) {
- new->detached = 1;
-- flags -= 0x200000;
-+ flags -= CLONE_CHILD_CLEARTID;
- }
- if (attr._a_sched) {
- do_sched = new->startlock[0] = 1;
-diff -Nur musl-0.9.13/src/thread/pthread_getattr_np.c musl-git/src/thread/pthread_getattr_np.c
---- musl-0.9.13/src/thread/pthread_getattr_np.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/thread/pthread_getattr_np.c 2013-09-16 20:31:39.000000000 +0200
-@@ -1,5 +1,6 @@
- #define _GNU_SOURCE
- #include "pthread_impl.h"
-+#include "libc.h"
- #include <sys/mman.h>
-
- int pthread_getattr_np(pthread_t t, pthread_attr_t *a)
-diff -Nur musl-0.9.13/src/thread/synccall.c musl-git/src/thread/synccall.c
---- musl-0.9.13/src/thread/synccall.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/thread/synccall.c 2013-09-16 20:31:39.000000000 +0200
-@@ -43,7 +43,7 @@
- pthread_t self;
- struct sigaction sa;
- struct chain *next;
-- uint64_t oldmask;
-+ sigset_t oldmask;
-
- if (!libc.threads_minus_1) {
- func(ctx);
-@@ -52,12 +52,12 @@
-
- __inhibit_ptc();
-
-- __syscall(SYS_rt_sigprocmask, SIG_BLOCK, SIGALL_SET,
-- &oldmask, _NSIG/8);
-+ __block_all_sigs(&oldmask);
-
- sem_init(&chaindone, 0, 0);
- sem_init(&chainlock, 0, 1);
- chainlen = 0;
-+ head = 0;
- callback = func;
- context = ctx;
-
-@@ -70,6 +70,10 @@
- sigqueue(self->pid, SIGSYNCCALL, (union sigval){0});
- while (sem_wait(&chaindone));
-
-+ sa.sa_flags = 0;
-+ sa.sa_handler = SIG_IGN;
-+ __libc_sigaction(SIGSYNCCALL, &sa, 0);
-+
- for (cur=head; cur; cur=cur->next) {
- sem_post(&cur->sem);
- while (sem_wait(&cur->sem2));
-@@ -81,12 +85,7 @@
- sem_post(&cur->sem);
- }
-
-- sa.sa_flags = 0;
-- sa.sa_handler = SIG_IGN;
-- __libc_sigaction(SIGSYNCCALL, &sa, 0);
--
-- __syscall(SYS_rt_sigprocmask, SIG_SETMASK,
-- &oldmask, 0, _NSIG/8);
-+ __restore_sigs(&oldmask);
-
- __release_ptc();
- }
-diff -Nur musl-0.9.13/src/unistd/faccessat.c musl-git/src/unistd/faccessat.c
---- musl-0.9.13/src/unistd/faccessat.c 2013-08-30 23:30:53.000000000 +0200
-+++ musl-git/src/unistd/faccessat.c 2013-09-16 20:31:39.000000000 +0200
-@@ -19,7 +19,7 @@
- __syscall(SYS_exit, 1);
- ret = __syscall(SYS_faccessat, c->fd, c->filename, c->amode, 0);
- __syscall(SYS_write, c->p, &ret, sizeof ret);
-- __syscall(SYS_exit, 0);
-+ return 0;
- }
-
- int faccessat(int fd, const char *filename, int amode, int flag)