From patchwork Thu Jul 2 15:46:21 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Joseph Myers X-Patchwork-Id: 6711241 Return-Path: X-Original-To: patchwork-linux-sh@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork2.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.136]) by patchwork2.web.kernel.org (Postfix) with ESMTP id 0616CC05AC for ; Thu, 2 Jul 2015 15:46:38 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id E3FB220771 for ; Thu, 2 Jul 2015 15:46:35 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 7F73E2076B for ; Thu, 2 Jul 2015 15:46:29 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752965AbbGBPq2 (ORCPT ); Thu, 2 Jul 2015 11:46:28 -0400 Received: from relay1.mentorg.com ([192.94.38.131]:36898 "EHLO relay1.mentorg.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753220AbbGBPq0 (ORCPT ); Thu, 2 Jul 2015 11:46:26 -0400 Received: from nat-ies.mentorg.com ([192.94.31.2] helo=SVR-IES-FEM-01.mgc.mentorg.com) by relay1.mentorg.com with esmtp id 1ZAggy-0003WT-SL from joseph_myers@mentor.com ; Thu, 02 Jul 2015 08:46:25 -0700 Received: from digraph.polyomino.org.uk (137.202.0.76) by SVR-IES-FEM-01.mgc.mentorg.com (137.202.0.104) with Microsoft SMTP Server id 14.3.224.2; Thu, 2 Jul 2015 16:46:23 +0100 Received: from jsm28 (helo=localhost) by digraph.polyomino.org.uk with local-esmtp (Exim 4.82) (envelope-from ) id 1ZAggv-0002FN-Hh; Thu, 02 Jul 2015 15:46:21 +0000 Date: Thu, 2 Jul 2015 15:46:21 +0000 From: Joseph Myers X-X-Sender: jsm28@digraph.polyomino.org.uk To: , , , , , , Subject: [PATCH 1/8] math-emu: Move math-emu to math-emu-old Message-ID: User-Agent: Alpine 2.10 (DEB 1266 2009-07-14) MIME-Version: 1.0 Sender: linux-sh-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-sh@vger.kernel.org X-Spam-Status: No, score=-7.5 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=ham version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP From: Joseph Myers The include/math-emu code (used for alpha powerpc sh sparc, and to a very limited extent for s390) was taken from an old version of glibc's soft-fp code around 15 years ago (in the pre-git era, anyway, and some of the initial code may have been developed around 1997-9 with a view to being used in both places). Since then, there have only been a handful of small changes in the kernel version, while the glibc version has been extensively developed, with many bug fixes, performance improvements and miscellaneous cleanups, and is also now used in libgcc, including for __float128 on x86_64 since GCC 4.3 (see for more information regarding performance improvements and use in libgcc). Thus the kernel version is missing those various improvements and it would make sense to update it to include them (as was noted back in 2006 when a large group of changes went into glibc). I believe it also makes sense to aim to have *exactly* the same code in both places to simplify future updates of the kernel version. (And in particular, as external code imported largely verbatim into the kernel, include/math-emu has never followed the kernel coding style and it doesn't make sense for it to do so.) I made an analysis of what kernel-local changes there were to this code in , and since then have added the various missing features to the glibc version so that it is feature-complete regarding features used in the kernel and so that exactly the same code is usable in both places. This patch moves the include/math-emu code to math-emu-old, updating #includes, in preparation for importing glibc's current soft-fp code as include/math-emu without requiring all architectures to be updated for API changes at the same time. Signed-off-by: Joseph Myers diff --git a/arch/alpha/math-emu/math.c b/arch/alpha/math-emu/math.c index 58c2669..917196e 100644 --- a/arch/alpha/math-emu/math.c +++ b/arch/alpha/math-emu/math.c @@ -6,9 +6,9 @@ #include #include "sfp-util.h" -#include -#include -#include +#include +#include +#include #define OPC_PAL 0x00 #define OPC_INTA 0x10 diff --git a/arch/powerpc/math-emu/fadd.c b/arch/powerpc/math-emu/fadd.c index 0158a16..3c821be 100644 --- a/arch/powerpc/math-emu/fadd.c +++ b/arch/powerpc/math-emu/fadd.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fadd(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fadds.c b/arch/powerpc/math-emu/fadds.c index 5930f40..14bc579 100644 --- a/arch/powerpc/math-emu/fadds.c +++ b/arch/powerpc/math-emu/fadds.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fadds(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fcmpo.c b/arch/powerpc/math-emu/fcmpo.c index 5bce011..3c4afbf 100644 --- a/arch/powerpc/math-emu/fcmpo.c +++ b/arch/powerpc/math-emu/fcmpo.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fcmpo(u32 *ccr, int crfD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fcmpu.c b/arch/powerpc/math-emu/fcmpu.c index d4fb1ba..948d9db 100644 --- a/arch/powerpc/math-emu/fcmpu.c +++ b/arch/powerpc/math-emu/fcmpu.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fcmpu(u32 *ccr, int crfD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fctiw.c b/arch/powerpc/math-emu/fctiw.c index f694440..d3efc14 100644 --- a/arch/powerpc/math-emu/fctiw.c +++ b/arch/powerpc/math-emu/fctiw.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fctiw(u32 *frD, void *frB) diff --git a/arch/powerpc/math-emu/fctiwz.c b/arch/powerpc/math-emu/fctiwz.c index 71e782f..cce3457 100644 --- a/arch/powerpc/math-emu/fctiwz.c +++ b/arch/powerpc/math-emu/fctiwz.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fctiwz(u32 *frD, void *frB) diff --git a/arch/powerpc/math-emu/fdiv.c b/arch/powerpc/math-emu/fdiv.c index a29239c..f3084fd 100644 --- a/arch/powerpc/math-emu/fdiv.c +++ b/arch/powerpc/math-emu/fdiv.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fdiv(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fdivs.c b/arch/powerpc/math-emu/fdivs.c index 526bc26..4fde33b 100644 --- a/arch/powerpc/math-emu/fdivs.c +++ b/arch/powerpc/math-emu/fdivs.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fdivs(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fmadd.c b/arch/powerpc/math-emu/fmadd.c index 8c3f20a..9a2b1ff 100644 --- a/arch/powerpc/math-emu/fmadd.c +++ b/arch/powerpc/math-emu/fmadd.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fmadd(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/fmadds.c b/arch/powerpc/math-emu/fmadds.c index 794fb31..3dac172 100644 --- a/arch/powerpc/math-emu/fmadds.c +++ b/arch/powerpc/math-emu/fmadds.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fmadds(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/fmsub.c b/arch/powerpc/math-emu/fmsub.c index 626f6fe..bfcf698 100644 --- a/arch/powerpc/math-emu/fmsub.c +++ b/arch/powerpc/math-emu/fmsub.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fmsub(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/fmsubs.c b/arch/powerpc/math-emu/fmsubs.c index 3425bc8..144d43a 100644 --- a/arch/powerpc/math-emu/fmsubs.c +++ b/arch/powerpc/math-emu/fmsubs.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fmsubs(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/fmul.c b/arch/powerpc/math-emu/fmul.c index 2c19297..1ea819d 100644 --- a/arch/powerpc/math-emu/fmul.c +++ b/arch/powerpc/math-emu/fmul.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fmul(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fmuls.c b/arch/powerpc/math-emu/fmuls.c index f5ad5c9..6f62191 100644 --- a/arch/powerpc/math-emu/fmuls.c +++ b/arch/powerpc/math-emu/fmuls.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fmuls(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fnmadd.c b/arch/powerpc/math-emu/fnmadd.c index e817bc5..e290ef7 100644 --- a/arch/powerpc/math-emu/fnmadd.c +++ b/arch/powerpc/math-emu/fnmadd.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fnmadd(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/fnmadds.c b/arch/powerpc/math-emu/fnmadds.c index 4db4b7d..41a5a4c 100644 --- a/arch/powerpc/math-emu/fnmadds.c +++ b/arch/powerpc/math-emu/fnmadds.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fnmadds(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/fnmsub.c b/arch/powerpc/math-emu/fnmsub.c index f65979f..7e6168a 100644 --- a/arch/powerpc/math-emu/fnmsub.c +++ b/arch/powerpc/math-emu/fnmsub.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fnmsub(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/fnmsubs.c b/arch/powerpc/math-emu/fnmsubs.c index 9021dac..bb4a27f 100644 --- a/arch/powerpc/math-emu/fnmsubs.c +++ b/arch/powerpc/math-emu/fnmsubs.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fnmsubs(void *frD, void *frA, void *frB, void *frC) diff --git a/arch/powerpc/math-emu/frsp.c b/arch/powerpc/math-emu/frsp.c index ddcc146..6fda802 100644 --- a/arch/powerpc/math-emu/frsp.c +++ b/arch/powerpc/math-emu/frsp.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int frsp(void *frD, void *frB) diff --git a/arch/powerpc/math-emu/fsel.c b/arch/powerpc/math-emu/fsel.c index 1b0c144..681898d 100644 --- a/arch/powerpc/math-emu/fsel.c +++ b/arch/powerpc/math-emu/fsel.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fsel(u32 *frD, void *frA, u32 *frB, u32 *frC) diff --git a/arch/powerpc/math-emu/fsqrt.c b/arch/powerpc/math-emu/fsqrt.c index a55fc7d..f66b52e 100644 --- a/arch/powerpc/math-emu/fsqrt.c +++ b/arch/powerpc/math-emu/fsqrt.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fsqrt(void *frD, void *frB) diff --git a/arch/powerpc/math-emu/fsqrts.c b/arch/powerpc/math-emu/fsqrts.c index 31dccbf..b042ff6 100644 --- a/arch/powerpc/math-emu/fsqrts.c +++ b/arch/powerpc/math-emu/fsqrts.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fsqrts(void *frD, void *frB) diff --git a/arch/powerpc/math-emu/fsub.c b/arch/powerpc/math-emu/fsub.c index 02c5dff..aa2105f 100644 --- a/arch/powerpc/math-emu/fsub.c +++ b/arch/powerpc/math-emu/fsub.c @@ -3,8 +3,8 @@ #include #include -#include -#include +#include +#include int fsub(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/fsubs.c b/arch/powerpc/math-emu/fsubs.c index 5d9b18c..9fd6cf6 100644 --- a/arch/powerpc/math-emu/fsubs.c +++ b/arch/powerpc/math-emu/fsubs.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int fsubs(void *frD, void *frA, void *frB) diff --git a/arch/powerpc/math-emu/lfd.c b/arch/powerpc/math-emu/lfd.c index 79ac76d..acc5a3f 100644 --- a/arch/powerpc/math-emu/lfd.c +++ b/arch/powerpc/math-emu/lfd.c @@ -3,7 +3,7 @@ #include #include -#include +#include int lfd(void *frD, void *ea) diff --git a/arch/powerpc/math-emu/lfs.c b/arch/powerpc/math-emu/lfs.c index 434ed27..582e0b8 100644 --- a/arch/powerpc/math-emu/lfs.c +++ b/arch/powerpc/math-emu/lfs.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int lfs(void *frD, void *ea) diff --git a/arch/powerpc/math-emu/math.c b/arch/powerpc/math-emu/math.c index ab151f0..d6e1a8f 100644 --- a/arch/powerpc/math-emu/math.c +++ b/arch/powerpc/math-emu/math.c @@ -10,7 +10,7 @@ #include #include -#include +#include #define FLOATFUNC(x) extern int x(void *, void *, void *, void *) diff --git a/arch/powerpc/math-emu/math_efp.c b/arch/powerpc/math-emu/math_efp.c index 28337c9..8d87cf9 100644 --- a/arch/powerpc/math-emu/math_efp.c +++ b/arch/powerpc/math-emu/math_efp.c @@ -28,9 +28,9 @@ #define FP_EX_BOOKE_E500_SPE #include -#include -#include -#include +#include +#include +#include #define EFAPU 0x4 diff --git a/arch/powerpc/math-emu/mcrfs.c b/arch/powerpc/math-emu/mcrfs.c index e948d57..f37ea50 100644 --- a/arch/powerpc/math-emu/mcrfs.c +++ b/arch/powerpc/math-emu/mcrfs.c @@ -3,7 +3,7 @@ #include #include -#include +#include int mcrfs(u32 *ccr, u32 crfD, u32 crfS) diff --git a/arch/powerpc/math-emu/mffs.c b/arch/powerpc/math-emu/mffs.c index 5526cf9..558e621 100644 --- a/arch/powerpc/math-emu/mffs.c +++ b/arch/powerpc/math-emu/mffs.c @@ -3,7 +3,7 @@ #include #include -#include +#include int mffs(u32 *frD) diff --git a/arch/powerpc/math-emu/mtfsb0.c b/arch/powerpc/math-emu/mtfsb0.c index bc98558..7c325d8 100644 --- a/arch/powerpc/math-emu/mtfsb0.c +++ b/arch/powerpc/math-emu/mtfsb0.c @@ -3,7 +3,7 @@ #include #include -#include +#include int mtfsb0(int crbD) diff --git a/arch/powerpc/math-emu/mtfsb1.c b/arch/powerpc/math-emu/mtfsb1.c index fe6ed5a..d15f724 100644 --- a/arch/powerpc/math-emu/mtfsb1.c +++ b/arch/powerpc/math-emu/mtfsb1.c @@ -3,7 +3,7 @@ #include #include -#include +#include int mtfsb1(int crbD) diff --git a/arch/powerpc/math-emu/mtfsf.c b/arch/powerpc/math-emu/mtfsf.c index 44b0fc8..b352968 100644 --- a/arch/powerpc/math-emu/mtfsf.c +++ b/arch/powerpc/math-emu/mtfsf.c @@ -3,7 +3,7 @@ #include #include -#include +#include int mtfsf(unsigned int FM, u32 *frB) diff --git a/arch/powerpc/math-emu/mtfsfi.c b/arch/powerpc/math-emu/mtfsfi.c index fd2acc2..8abeb3c 100644 --- a/arch/powerpc/math-emu/mtfsfi.c +++ b/arch/powerpc/math-emu/mtfsfi.c @@ -3,7 +3,7 @@ #include #include -#include +#include int mtfsfi(unsigned int crfD, unsigned int IMM) diff --git a/arch/powerpc/math-emu/stfs.c b/arch/powerpc/math-emu/stfs.c index 6122147..8430631 100644 --- a/arch/powerpc/math-emu/stfs.c +++ b/arch/powerpc/math-emu/stfs.c @@ -3,9 +3,9 @@ #include #include -#include -#include -#include +#include +#include +#include int stfs(void *frS, void *ea) diff --git a/arch/powerpc/math-emu/udivmodti4.c b/arch/powerpc/math-emu/udivmodti4.c index 6172044..86e4013 100644 --- a/arch/powerpc/math-emu/udivmodti4.c +++ b/arch/powerpc/math-emu/udivmodti4.c @@ -1,6 +1,6 @@ /* This has so very few changes over libgcc2's __udivmoddi4 it isn't funny. */ -#include +#include #undef count_leading_zeros #define count_leading_zeros __FP_CLZ diff --git a/arch/s390/kernel/sysinfo.c b/arch/s390/kernel/sysinfo.c index 99babea..c7d8df7 100644 --- a/arch/s390/kernel/sysinfo.c +++ b/arch/s390/kernel/sysinfo.c @@ -19,8 +19,8 @@ /* Sigh, math-emu. Don't ask. */ #include -#include -#include +#include +#include int topology_max_mnest; diff --git a/arch/sh/math-emu/math.c b/arch/sh/math-emu/math.c index 04aa55f..0cd5ec3 100644 --- a/arch/sh/math-emu/math.c +++ b/arch/sh/math-emu/math.c @@ -19,9 +19,9 @@ #include #include "sfp-util.h" -#include -#include -#include +#include +#include +#include #define FPUL (fregs->fpul) #define FPSCR (fregs->fpscr) diff --git a/arch/sparc/math-emu/math_32.c b/arch/sparc/math-emu/math_32.c index 5ce8f2f..3aaaeef 100644 --- a/arch/sparc/math-emu/math_32.c +++ b/arch/sparc/math-emu/math_32.c @@ -71,10 +71,10 @@ #include #include "sfp-util_32.h" -#include -#include -#include -#include +#include +#include +#include +#include #define FLOATFUNC(x) extern int x(void *,void *,void *) diff --git a/arch/sparc/math-emu/math_64.c b/arch/sparc/math-emu/math_64.c index 034aadb..c720cbb 100644 --- a/arch/sparc/math-emu/math_64.c +++ b/arch/sparc/math-emu/math_64.c @@ -19,10 +19,10 @@ #include #include "sfp-util_64.h" -#include -#include -#include -#include +#include +#include +#include +#include /* QUAD - ftt == 3 */ #define FMOVQ 0x003 diff --git a/include/math-emu/double.h b/include/math-emu-old/double.h similarity index 100% rename from include/math-emu/double.h rename to include/math-emu-old/double.h diff --git a/include/math-emu/op-1.h b/include/math-emu-old/op-1.h similarity index 100% rename from include/math-emu/op-1.h rename to include/math-emu-old/op-1.h diff --git a/include/math-emu/op-2.h b/include/math-emu-old/op-2.h similarity index 100% rename from include/math-emu/op-2.h rename to include/math-emu-old/op-2.h diff --git a/include/math-emu/op-4.h b/include/math-emu-old/op-4.h similarity index 100% rename from include/math-emu/op-4.h rename to include/math-emu-old/op-4.h diff --git a/include/math-emu/op-8.h b/include/math-emu-old/op-8.h similarity index 100% rename from include/math-emu/op-8.h rename to include/math-emu-old/op-8.h diff --git a/include/math-emu/op-common.h b/include/math-emu-old/op-common.h similarity index 100% rename from include/math-emu/op-common.h rename to include/math-emu-old/op-common.h diff --git a/include/math-emu/quad.h b/include/math-emu-old/quad.h similarity index 100% rename from include/math-emu/quad.h rename to include/math-emu-old/quad.h diff --git a/include/math-emu/single.h b/include/math-emu-old/single.h similarity index 100% rename from include/math-emu/single.h rename to include/math-emu-old/single.h diff --git a/include/math-emu/soft-fp.h b/include/math-emu-old/soft-fp.h similarity index 96% rename from include/math-emu/soft-fp.h rename to include/math-emu-old/soft-fp.h index 3f284bc..0ce1032 100644 --- a/include/math-emu/soft-fp.h +++ b/include/math-emu-old/soft-fp.h @@ -180,11 +180,11 @@ do { \ #define _FP_CLS_COMBINE(x,y) (((x) << 2) | (y)) -#include -#include -#include -#include -#include +#include +#include +#include +#include +#include /* Sigh. Silly things longlong.h needs. */ #define UWtype _FP_W_TYPE