Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 1b4af13f authored by David S. Miller's avatar David S. Miller
Browse files

sparc64: Add __multi3 for gcc 7.x and later.

parent 0fde7ad7
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -15,6 +15,7 @@ lib-$(CONFIG_SPARC32) += copy_user.o locks.o
lib-$(CONFIG_SPARC64) += atomic_64.o
lib-$(CONFIG_SPARC32) += lshrdi3.o ashldi3.o
lib-$(CONFIG_SPARC32) += muldi3.o bitext.o cmpdi2.o
lib-$(CONFIG_SPARC64) += multi3.o

lib-$(CONFIG_SPARC64) += copy_page.o clear_page.o bzero.o
lib-$(CONFIG_SPARC64) += csum_copy.o csum_copy_from_user.o csum_copy_to_user.o
+35 −0
Original line number Diff line number Diff line
#include <linux/linkage.h>
#include <asm/export.h>

	.text
	.align	4
ENTRY(__multi3) /* %o0 = u, %o1 = v */
	mov	%o1, %g1
	srl	%o3, 0, %g4
	mulx	%g4, %g1, %o1
	srlx	%g1, 0x20, %g3
	mulx	%g3, %g4, %g5
	sllx	%g5, 0x20, %o5
	srl	%g1, 0, %g4
	sub	%o1, %o5, %o5
	srlx	%o5, 0x20, %o5
	addcc	%g5, %o5, %g5
	srlx	%o3, 0x20, %o5
	mulx	%g4, %o5, %g4
	mulx	%g3, %o5, %o5
	sethi	%hi(0x80000000), %g3
	addcc	%g5, %g4, %g5
	srlx	%g5, 0x20, %g5
	add	%g3, %g3, %g3
	movcc	%xcc, %g0, %g3
	addcc	%o5, %g5, %o5
	sllx	%g4, 0x20, %g4
	add	%o1, %g4, %o1
	add	%o5, %g3, %g2
	mulx	%g1, %o2, %g1
	add	%g1, %g2, %g1
	mulx	%o0, %o3, %o0
	retl
	 add	%g1, %o0, %o0
ENDPROC(__multi3)
EXPORT_SYMBOL(__multi3)