From patchwork Tue Jun 6 19:10:19 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Palmer Dabbelt X-Patchwork-Id: 9769733 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id B0A7F60364 for ; Tue, 6 Jun 2017 19:14:26 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 9EB6C284A6 for ; Tue, 6 Jun 2017 19:14:26 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 91ED0284DA; Tue, 6 Jun 2017 19:14:26 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=2.0 tests=BAYES_00,DKIM_SIGNED, RCVD_IN_DNSWL_HI,T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id D05DE284A6 for ; Tue, 6 Jun 2017 19:14:25 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751721AbdFFTOB (ORCPT ); Tue, 6 Jun 2017 15:14:01 -0400 Received: from mail-pf0-f194.google.com ([209.85.192.194]:32920 "EHLO mail-pf0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751607AbdFFTKn (ORCPT ); Tue, 6 Jun 2017 15:10:43 -0400 Received: by mail-pf0-f194.google.com with SMTP id f27so25182038pfe.0 for ; Tue, 06 Jun 2017 12:10:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=dabbelt-com.20150623.gappssmtp.com; s=20150623; h=from:to:to:to:to:to:to:to:to:to:to:to:to:to:cc:subject:date :message-id:in-reply-to:references; bh=0itul/GK7qRp9jnMy5gS0r+p/dFmiW771vnK3G3G24g=; b=035A5fGVIWUd3ewnANjVLafKBevz1hNtOdm4Vhm6gm628XZpn+b6x7NftqWXkg1QnL ePmo8iKZr9t3tfeVe0u/uMDE6tAHQJ5g/cMXvLxFIBpMuuyqjrUYISIZ5jVfJ8Oi5hQG bY1DLJAtYr50f8zNaKGlT+yyZYlz/+y77HNyetyBq/KcZbM1mLjQJJFjHb5uZf5iPH+b +wxWb1Z8mT+/b7hiyEkuQxJkBRXfzi42XDiqOBeyGjXMLOano6zQkN2jk7bLq0V/oyJF NIYp22pVPaFFh5t+CihugQtFoDnku+G71FWypImbhyJ/+AIjlFD6quCiAq0cIXSwRTk+ 6p1A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:to:to:to:to:to:to:to:to:to:to:to:to:cc :subject:date:message-id:in-reply-to:references; bh=0itul/GK7qRp9jnMy5gS0r+p/dFmiW771vnK3G3G24g=; b=hHgXRCl9AgElWXFtr5GVe1n5IjqSVCUFXvtkgTdtiQ58MouLV7AnFA4Q4uTT4gl6Aj M/bbFczY7Jf4XCTDODx1UzSV6gnQnVFe2mJitLnoXtOi+bqOxrptlQsT0Sxqx8fFpH7k 9sPZ7C4JpQ29XdJXr8xmtKW/vBUgNPyiqwqGBiWtIxnk5E/SWe53sSkxGTbn9J2cURc2 PVR0uh63clLHBL6q16TiQbl/bwWYJ8n1BXBmyO2Qo7Bt3ISuA95GXmn3BzNKoqzAUCsR tWjeuhBKt/bMRdA8SmAcIl0CtX4FwAruXnxhZw12Gs0vOGQN+yvEwbNu2wrSOFh98i+N lp6Q== X-Gm-Message-State: AODbwcBXuSbq/96Q/l41dbPvRx4uo6QKuTV/6ln6Oa2V+iZibly0BbfS l0X7e5yvXXmu+3Pl X-Received: by 10.98.63.218 with SMTP id z87mr18188912pfj.144.1496776232442; Tue, 06 Jun 2017 12:10:32 -0700 (PDT) Received: from localhost ([216.38.154.21]) by smtp.gmail.com with ESMTPSA id c205sm13928399pfb.74.2017.06.06.12.10.31 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 06 Jun 2017 12:10:31 -0700 (PDT) From: Palmer Dabbelt To: monstr@monstr.eu To: ralf@linux-mips.org To: liqin.linux@gmail.com To: lennox.wu@gmail.com To: ysato@users.sourceforge.jp To: dalias@libc.org To: davem@davemloft.net To: linux-mips@linux-mips.org To: linux-sh@vger.kernel.org To: sparclinux@vger.kernel.org To: geert@linux-m68k.org To: linux-kernel@vger.kernel.org To: linux-arch@vger.kernel.org Cc: Palmer Dabbelt Subject: [PATCH 3/7] microblaze: Use libgcc files from lib/ Date: Tue, 6 Jun 2017 12:10:19 -0700 Message-Id: <20170606191023.24581-4-palmer@dabbelt.com> X-Mailer: git-send-email 2.13.0 In-Reply-To: <20170606191023.24581-1-palmer@dabbelt.com> References: <20170523220546.16758-1-palmer@dabbelt.com> <20170606191023.24581-1-palmer@dabbelt.com> Sender: linux-sh-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-sh@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP These files are functionally identical to the shared copies that I recently added. Signed-off-by: Palmer Dabbelt Reviewed-by: Geert Uytterhoeven --- arch/microblaze/Kconfig | 6 +++++ arch/microblaze/lib/Makefile | 3 +-- arch/microblaze/lib/ashldi3.c | 28 --------------------- arch/microblaze/lib/ashrdi3.c | 30 ----------------------- arch/microblaze/lib/cmpdi2.c | 26 -------------------- arch/microblaze/lib/libgcc.h | 32 ------------------------ arch/microblaze/lib/lshrdi3.c | 28 --------------------- arch/microblaze/lib/muldi3.c | 57 ------------------------------------------- arch/microblaze/lib/ucmpdi2.c | 20 --------------- 9 files changed, 7 insertions(+), 223 deletions(-) delete mode 100644 arch/microblaze/lib/ashldi3.c delete mode 100644 arch/microblaze/lib/ashrdi3.c delete mode 100644 arch/microblaze/lib/cmpdi2.c delete mode 100644 arch/microblaze/lib/libgcc.h delete mode 100644 arch/microblaze/lib/lshrdi3.c delete mode 100644 arch/microblaze/lib/muldi3.c delete mode 100644 arch/microblaze/lib/ucmpdi2.c diff --git a/arch/microblaze/Kconfig b/arch/microblaze/Kconfig index 85885a501dce..833487c17996 100644 --- a/arch/microblaze/Kconfig +++ b/arch/microblaze/Kconfig @@ -34,6 +34,12 @@ config MICROBLAZE select TRACING_SUPPORT select VIRT_TO_BUS select CPU_NO_EFFICIENT_FFS + select GENERIC_ASHLDI3 + select GENERIC_ASHRDI3 + select GENERIC_CMPDI2 + select GENERIC_LSHRDI3 + select GENERIC_MULDI3 + select GENERIC_UCMPDI3 config SWAP def_bool n diff --git a/arch/microblaze/lib/Makefile b/arch/microblaze/lib/Makefile index 70c7ae6a3fb5..c9a4d537e2fd 100644 --- a/arch/microblaze/lib/Makefile +++ b/arch/microblaze/lib/Makefile @@ -19,5 +19,4 @@ endif lib-y += uaccess_old.o # libgcc-style stuff needed in the kernel -obj-y += ashldi3.o ashrdi3.o cmpdi2.o divsi3.o lshrdi3.o modsi3.o -obj-y += muldi3.o mulsi3.o ucmpdi2.o udivsi3.o umodsi3.o +obj-y += divsi3.o modsi3.o mulsi3.o udivsi3.o umodsi3.o diff --git a/arch/microblaze/lib/ashldi3.c b/arch/microblaze/lib/ashldi3.c deleted file mode 100644 index 1af904cd972d..000000000000 --- a/arch/microblaze/lib/ashldi3.c +++ /dev/null @@ -1,28 +0,0 @@ -#include - -#include "libgcc.h" - -long long __ashldi3(long long u, word_type b) -{ - DWunion uu, w; - word_type bm; - - if (b == 0) - return u; - - uu.ll = u; - bm = 32 - b; - - if (bm <= 0) { - w.s.low = 0; - w.s.high = (unsigned int) uu.s.low << -bm; - } else { - const unsigned int carries = (unsigned int) uu.s.low >> bm; - - w.s.low = (unsigned int) uu.s.low << b; - w.s.high = ((unsigned int) uu.s.high << b) | carries; - } - - return w.ll; -} -EXPORT_SYMBOL(__ashldi3); diff --git a/arch/microblaze/lib/ashrdi3.c b/arch/microblaze/lib/ashrdi3.c deleted file mode 100644 index 32c334c05d04..000000000000 --- a/arch/microblaze/lib/ashrdi3.c +++ /dev/null @@ -1,30 +0,0 @@ -#include - -#include "libgcc.h" - -long long __ashrdi3(long long u, word_type b) -{ - DWunion uu, w; - word_type bm; - - if (b == 0) - return u; - - uu.ll = u; - bm = 32 - b; - - if (bm <= 0) { - /* w.s.high = 1..1 or 0..0 */ - w.s.high = - uu.s.high >> 31; - w.s.low = uu.s.high >> -bm; - } else { - const unsigned int carries = (unsigned int) uu.s.high << bm; - - w.s.high = uu.s.high >> b; - w.s.low = ((unsigned int) uu.s.low >> b) | carries; - } - - return w.ll; -} -EXPORT_SYMBOL(__ashrdi3); diff --git a/arch/microblaze/lib/cmpdi2.c b/arch/microblaze/lib/cmpdi2.c deleted file mode 100644 index 67abc9ac1bd4..000000000000 --- a/arch/microblaze/lib/cmpdi2.c +++ /dev/null @@ -1,26 +0,0 @@ -#include - -#include "libgcc.h" - -word_type __cmpdi2(long long a, long long b) -{ - const DWunion au = { - .ll = a - }; - const DWunion bu = { - .ll = b - }; - - if (au.s.high < bu.s.high) - return 0; - else if (au.s.high > bu.s.high) - return 2; - - if ((unsigned int) au.s.low < (unsigned int) bu.s.low) - return 0; - else if ((unsigned int) au.s.low > (unsigned int) bu.s.low) - return 2; - - return 1; -} -EXPORT_SYMBOL(__cmpdi2); diff --git a/arch/microblaze/lib/libgcc.h b/arch/microblaze/lib/libgcc.h deleted file mode 100644 index ab077ef7e14b..000000000000 --- a/arch/microblaze/lib/libgcc.h +++ /dev/null @@ -1,32 +0,0 @@ -#ifndef __ASM_LIBGCC_H -#define __ASM_LIBGCC_H - -#include - -typedef int word_type __attribute__ ((mode (__word__))); - -#ifdef __BIG_ENDIAN -struct DWstruct { - int high, low; -}; -#elif defined(__LITTLE_ENDIAN) -struct DWstruct { - int low, high; -}; -#else -#error I feel sick. -#endif - -typedef union { - struct DWstruct s; - long long ll; -} DWunion; - -extern long long __ashldi3(long long u, word_type b); -extern long long __ashrdi3(long long u, word_type b); -extern word_type __cmpdi2(long long a, long long b); -extern long long __lshrdi3(long long u, word_type b); -extern long long __muldi3(long long u, long long v); -extern word_type __ucmpdi2(unsigned long long a, unsigned long long b); - -#endif /* __ASM_LIBGCC_H */ diff --git a/arch/microblaze/lib/lshrdi3.c b/arch/microblaze/lib/lshrdi3.c deleted file mode 100644 index adcb253f11c8..000000000000 --- a/arch/microblaze/lib/lshrdi3.c +++ /dev/null @@ -1,28 +0,0 @@ -#include - -#include "libgcc.h" - -long long __lshrdi3(long long u, word_type b) -{ - DWunion uu, w; - word_type bm; - - if (b == 0) - return u; - - uu.ll = u; - bm = 32 - b; - - if (bm <= 0) { - w.s.high = 0; - w.s.low = (unsigned int) uu.s.high >> -bm; - } else { - const unsigned int carries = (unsigned int) uu.s.high << bm; - - w.s.high = (unsigned int) uu.s.high >> b; - w.s.low = ((unsigned int) uu.s.low >> b) | carries; - } - - return w.ll; -} -EXPORT_SYMBOL(__lshrdi3); diff --git a/arch/microblaze/lib/muldi3.c b/arch/microblaze/lib/muldi3.c deleted file mode 100644 index a3f9a03acdcd..000000000000 --- a/arch/microblaze/lib/muldi3.c +++ /dev/null @@ -1,57 +0,0 @@ -#include - -#include "libgcc.h" - -#define W_TYPE_SIZE 32 - -#define __ll_B ((unsigned long) 1 << (W_TYPE_SIZE / 2)) -#define __ll_lowpart(t) ((unsigned long) (t) & (__ll_B - 1)) -#define __ll_highpart(t) ((unsigned long) (t) >> (W_TYPE_SIZE / 2)) - -/* If we still don't have umul_ppmm, define it using plain C. */ -#if !defined(umul_ppmm) -#define umul_ppmm(w1, w0, u, v) \ - do { \ - unsigned long __x0, __x1, __x2, __x3; \ - unsigned short __ul, __vl, __uh, __vh; \ - \ - __ul = __ll_lowpart(u); \ - __uh = __ll_highpart(u); \ - __vl = __ll_lowpart(v); \ - __vh = __ll_highpart(v); \ - \ - __x0 = (unsigned long) __ul * __vl; \ - __x1 = (unsigned long) __ul * __vh; \ - __x2 = (unsigned long) __uh * __vl; \ - __x3 = (unsigned long) __uh * __vh; \ - \ - __x1 += __ll_highpart(__x0); /* this can't give carry */\ - __x1 += __x2; /* but this indeed can */ \ - if (__x1 < __x2) /* did we get it? */ \ - __x3 += __ll_B; /* yes, add it in the proper pos */ \ - \ - (w1) = __x3 + __ll_highpart(__x1); \ - (w0) = __ll_lowpart(__x1) * __ll_B + __ll_lowpart(__x0);\ - } while (0) -#endif - -#if !defined(__umulsidi3) -#define __umulsidi3(u, v) ({ \ - DWunion __w; \ - umul_ppmm(__w.s.high, __w.s.low, u, v); \ - __w.ll; \ - }) -#endif - -long long __muldi3(long long u, long long v) -{ - const DWunion uu = {.ll = u}; - const DWunion vv = {.ll = v}; - DWunion w = {.ll = __umulsidi3(uu.s.low, vv.s.low)}; - - w.s.high += ((unsigned long) uu.s.low * (unsigned long) vv.s.high - + (unsigned long) uu.s.high * (unsigned long) vv.s.low); - - return w.ll; -} -EXPORT_SYMBOL(__muldi3); diff --git a/arch/microblaze/lib/ucmpdi2.c b/arch/microblaze/lib/ucmpdi2.c deleted file mode 100644 index d05f1585121c..000000000000 --- a/arch/microblaze/lib/ucmpdi2.c +++ /dev/null @@ -1,20 +0,0 @@ -#include - -#include "libgcc.h" - -word_type __ucmpdi2(unsigned long long a, unsigned long long b) -{ - const DWunion au = {.ll = a}; - const DWunion bu = {.ll = b}; - - if ((unsigned int) au.s.high < (unsigned int) bu.s.high) - return 0; - else if ((unsigned int) au.s.high > (unsigned int) bu.s.high) - return 2; - if ((unsigned int) au.s.low < (unsigned int) bu.s.low) - return 0; - else if ((unsigned int) au.s.low > (unsigned int) bu.s.low) - return 2; - return 1; -} -EXPORT_SYMBOL(__ucmpdi2);