mail archive of the barebox mailing list
 help / color / mirror / Atom feed
* [PATCH v1 1/1] Add generic implementation for muldi3
@ 2019-01-05 18:45 Martin Hofmann
  2019-01-07  7:44 ` Sascha Hauer
  0 siblings, 1 reply; 3+ messages in thread
From: Martin Hofmann @ 2019-01-05 18:45 UTC (permalink / raw)
  To: barebox

Since version v2018.08.0 some shared copies of gcc routines got added to
barebox so that archs don't need to have thier own copy inside thier
lib. The arch I am working on atm also needs support for muldi3 which is
not present as a generic version right now.

This patch addes the generic version form latest linux v4.20 to barebox
and lets the archs select it in thier Kconfig so they don't need to
provide it themself.

Signed-off-by: Martin Hofmann <martin.hofmann_at_mni.thm.de>

---
 include/lib/libgcc.h |  1 +
 lib/Kconfig          |  3 ++
 lib/Makefile         |  1 +
 lib/muldi3.c         | 73 ++++++++++++++++++++++++++++++++++++++++++++
 4 files changed, 78 insertions(+)
 create mode 100644 lib/muldi3.c

diff --git a/include/lib/libgcc.h b/include/lib/libgcc.h
index adad27704..f7b9be61f 100644
--- a/include/lib/libgcc.h
+++ b/include/lib/libgcc.h
@@ -43,5 +43,6 @@ typedef union {
 long long __lshrdi3(long long u, word_type b);
 long long __ashldi3(long long u, word_type b);
 long long __ashrdi3(long long u, word_type b);
+long long __muldi3(long long u, long long v);

 #endif /* __ASM_LIBGCC_H */
diff --git a/lib/Kconfig b/lib/Kconfig
index 67680adbb..e048aded8 100644
--- a/lib/Kconfig
+++ b/lib/Kconfig
@@ -145,4 +145,7 @@ config GENERIC_LIB_ASHRDI3
 config GENERIC_LIB_LSHRDI3
 	bool

+config GENERIC_LIB_MULDI3
+	bool
+
 endmenu
diff --git a/lib/Makefile b/lib/Makefile
index 8ece2c284..e72aa6655 100644
--- a/lib/Makefile
+++ b/lib/Makefile
@@ -72,5 +72,6 @@ obj-$(CONFIG_CRC8)	+= crc8.o
 obj-$(CONFIG_GENERIC_LIB_ASHLDI3) += ashldi3.o
 obj-$(CONFIG_GENERIC_LIB_ASHRDI3) += ashrdi3.o
 obj-$(CONFIG_GENERIC_LIB_LSHRDI3) += lshrdi3.o
+obj-$(CONFIG_GENERIC_LIB_MULDI3)  += muldi3.o

 pbl-$(CONFIG_GENERIC_LIB_ASHLDI3) += ashldi3.o
diff --git a/lib/muldi3.c b/lib/muldi3.c
new file mode 100644
index 000000000..eec810e80
--- /dev/null
+++ b/lib/muldi3.c
@@ -0,0 +1,73 @@
+/*
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, see the file COPYING, or write
+ * to the Free Software Foundation, Inc.
+ */
+
+#include <module.h>
+
+#include <lib/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 notrace __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);
-- 
2.20.1


_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH v1 1/1] Add generic implementation for muldi3
  2019-01-05 18:45 [PATCH v1 1/1] Add generic implementation for muldi3 Martin Hofmann
@ 2019-01-07  7:44 ` Sascha Hauer
  2019-01-07  8:16   ` Martin Hofmann
  0 siblings, 1 reply; 3+ messages in thread
From: Sascha Hauer @ 2019-01-07  7:44 UTC (permalink / raw)
  To: Martin Hofmann; +Cc: barebox

Hi Martin,

On Sat, Jan 05, 2019 at 07:45:12PM +0100, Martin Hofmann wrote:
> Since version v2018.08.0 some shared copies of gcc routines got added to
> barebox so that archs don't need to have thier own copy inside thier
> lib. The arch I am working on atm also needs support for muldi3 which is
> not present as a generic version right now.
> 
> This patch addes the generic version form latest linux v4.20 to barebox
> and lets the archs select it in thier Kconfig so they don't need to
> provide it themself.

Applied, thanks

Which architecture is it you are working on?

Sascha

-- 
Pengutronix e.K.                           |                             |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0    |
Amtsgericht Hildesheim, HRA 2686           | Fax:   +49-5121-206917-5555 |

_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH v1 1/1] Add generic implementation for muldi3
  2019-01-07  7:44 ` Sascha Hauer
@ 2019-01-07  8:16   ` Martin Hofmann
  0 siblings, 0 replies; 3+ messages in thread
From: Martin Hofmann @ 2019-01-07  8:16 UTC (permalink / raw)
  To: Sascha Hauer; +Cc: barebox

Hi Sascha

On 1/7/19 8:44 AM, Sascha Hauer wrote:
> Hi Martin,
> 
> On Sat, Jan 05, 2019 at 07:45:12PM +0100, Martin Hofmann wrote:
>> Since version v2018.08.0 some shared copies of gcc routines got added to
>> barebox so that archs don't need to have thier own copy inside thier
>> lib. The arch I am working on atm also needs support for muldi3 which is
>> not present as a generic version right now.
>>
>> This patch addes the generic version form latest linux v4.20 to barebox
>> and lets the archs select it in thier Kconfig so they don't need to
>> provide it themself.
> 
> Applied, thanks
> 
> Which architecture is it you are working on?
> 
> Sascha
>

It is called eco32 and is a fairly simple RISC CPU made for educational
purpose designed by a lecturer of the Univerity Of Applied Science
Mittelhessen in germany. It is used for courses like operating systems
and compiler construction.

If you are interssted in it the port is available on my github:
https://github.com/mh0fmann/eco32-barebox

Martin

_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2019-01-07  8:16 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-01-05 18:45 [PATCH v1 1/1] Add generic implementation for muldi3 Martin Hofmann
2019-01-07  7:44 ` Sascha Hauer
2019-01-07  8:16   ` Martin Hofmann

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox