Blame SOURCES/0010-gnu-efi-fix-lib-ia64-setjmp.S-IA-64-build-failure.patch

7d5d2b
From 0e6995a96b0f5867c8d85fbd251cfbc295a3fc4d Mon Sep 17 00:00:00 2001
7d5d2b
From: Sergei Trofimovich <slyfox@gentoo.org>
7d5d2b
Date: Sun, 28 Jan 2018 16:44:21 +0000
7d5d2b
Subject: [PATCH 10/25] gnu-efi: fix lib/ia64/setjmp.S IA-64 build failure
7d5d2b
7d5d2b
The build failed as:
7d5d2b
  lib/ia64/setjmp.S:171: Error: Unknown opcode `ldf.nt1 f26=[r10],8'
7d5d2b
  lib/ia64/setjmp.S:178: Error: Operand 1 of `ldf.fill.nt1' should be a floating-point register
7d5d2b
7d5d2b
The change syncs longjmp definition with
7d5d2b
    edk2/EdkCompatibilityPkg/Foundation/Library/EdkIIGlueLib/Library/BaseLib/Ipf/setjmp.s
7d5d2b
pulling in:
7d5d2b
- branch in the end of function
7d5d2b
- registers used wrong instruction for float restore
7d5d2b
7d5d2b
Signed-off-by: Sergei Trofimovich <slyfox@gentoo.org>
7d5d2b
---
7d5d2b
 lib/ia64/setjmp.S | 61 +++++++++++++++++++++++++++----------------------------
7d5d2b
 1 file changed, 30 insertions(+), 31 deletions(-)
7d5d2b
7d5d2b
diff --git a/lib/ia64/setjmp.S b/lib/ia64/setjmp.S
7d5d2b
index c806fbc82b6..bbb29d8b8f5 100644
7d5d2b
--- a/lib/ia64/setjmp.S
7d5d2b
+++ b/lib/ia64/setjmp.S
7d5d2b
@@ -16,11 +16,11 @@ BASIS,
7d5d2b
 	.globl	setjmp
7d5d2b
 	.type	setjmp, @function
7d5d2b
 setjmp:
7d5d2b
-	alloc	loc = ar.pfs, 1, 2, 1, 0
7d5d2b
+	alloc	loc0 = ar.pfs, 1, 2, 1, 0
7d5d2b
 	;;
7d5d2b
 	mov	r14 = ar.unat
7d5d2b
 	mov	r15 = ar.bsp
7d5d2b
-	add	r10 = 0x10 * 20, in0
7d5d2b
+	add	r10 = 0x10*20, in0
7d5d2b
 	;;
7d5d2b
 	stf.spill.nta	[in0] = f2, 0x10 
7d5d2b
 	st8.spill.nta	[r10] = r4, 8
7d5d2b
@@ -98,29 +98,25 @@ setjmp:
7d5d2b
 
7d5d2b
 	.globl	longjmp
7d5d2b
 	.type	longjmp, @function
7d5d2b
-	.regstk
7d5d2b
+	.regstk 2, 0, 0, 0
7d5d2b
 longjmp:
7d5d2b
-	add		r10 = 0x10 * 20 + 8*14, in0
7d5d2b
-	movl		r2 = ~(((1<<14) - 1) << 16) | 3)
7d5d2b
+	add		r10 = 0x10*20 + 8*14, in0
7d5d2b
+	movl		r2  = ~((((1<<14) - 1) << 16) | 3)
7d5d2b
 	;;
7d5d2b
 	ld8.nt1		r14 = [r10], -8*2
7d5d2b
 	mov		r15 = ar.bspstore
7d5d2b
 	;;
7d5d2b
 	ld8.nt1		r17 = [r10], -8
7d5d2b
 	mov		r16 = ar.rsc
7d5d2b
-	cmp.leu		p6 = r14, r15
7d5d2b
+	cmp.leu		p6  = r14, r15
7d5d2b
 	;;
7d5d2b
 	ld8.nt1		r18 = [r10], -8
7d5d2b
 	ld8.nt1		r25 = [r10], -8
7d5d2b
-	and		r2 = r16, r2
7d5d2b
+	and		r2  = r16, r2
7d5d2b
 	;;
7d5d2b
-	ldf.fill.nt1	f2 = [in0], 0x10
7d5d2b
+	ldf.fill.nt1	f2  = [in0], 0x10
7d5d2b
 	ld8.nt1		r24 = [r10], -8
7d5d2b
-	mov		b5 = r25
7d5d2b
-	;;
7d5d2b
-	mov		ar.rsc = r2
7d5d2b
-	ld8.nt1		r23 = [r10], -8
7d5d2b
-	mov		b5 = r25
7d5d2b
+	mov		b5  = r25
7d5d2b
 	;;
7d5d2b
 	mov		ar.rsc = r2
7d5d2b
 	ld8.nt1		r23 = [r10], -8
7d5d2b
@@ -137,51 +133,51 @@ _skip_flushrs:
7d5d2b
 	mov		r31 = ar.rnat
7d5d2b
 	loadrs
7d5d2b
 	;;
7d5d2b
-	ldf.fill.nt1	f4 = [in0], 0x10
7d5d2b
+	ldf.fill.nt1	f4  = [in0], 0x10
7d5d2b
 	ld8.nt1		r22 = [r10], -8
7d5d2b
-	dep		r2 = -1, r14, 3, 6
7d5d2b
+	dep		r2  = -1, r14, 3, 6
7d5d2b
 	;;
7d5d2b
-	ldf.fill.nt1	f5 = [in0], 0x10
7d5d2b
-	ld8.nt1		f21 = [r10], -8
7d5d2b
-	cmp		p6 = r2, r15
7d5d2b
+	ldf.fill.nt1	f5  = [in0], 0x10
7d5d2b
+	ld8.nt1		r21 = [r10], -8
7d5d2b
+	cmp.ltu		p6  = r2, r15
7d5d2b
 	;;
7d5d2b
 	ld8.nt1		r20 = [r10], -0x10
7d5d2b
 (p6)	ld8.nta		r31 = [r2]
7d5d2b
-	mov		b3 = r23
7d5d2b
+	mov		b3  = r23
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f16 = [in0], 0x10
7d5d2b
-	ld8.fill.nt1	r7 = [r10], -8
7d5d2b
-	mov		b2 = r22
7d5d2b
+	ld8.fill.nt1	r7  = [r10], -8
7d5d2b
+	mov		b2  = r22
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f17 = [in0], 0x10
7d5d2b
-	ld8.fill.nt1	r6 = [r10], -8
7d5d2b
-	mov		b1 = r21
7d5d2b
+	ld8.fill.nt1	r6  = [r10], -8
7d5d2b
+	mov		b1  = r21
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f18 = [in0], 0x10
7d5d2b
-	ld8.fill.nt1	r5 = [r10], -8
7d5d2b
-	mov		b0 = r20
7d5d2b
+	ld8.fill.nt1	r5  = [r10], -8
7d5d2b
+	mov		b0  = r20
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f19 = [in0], 0x10
7d5d2b
-	ld8.fill.nt1	r4 = [r10], 8*13
7d5d2b
+	ld8.fill.nt1	r4  = [r10], 8*13
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f20 = [in0], 0x10
7d5d2b
 	ld8.nt1		r19 = [r10], 0x10
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f21 = [in0], 0x10
7d5d2b
-	ldf.nt1		f26 = [r10], 8
7d5d2b
+	ld8.nt1		r26 = [r10], 8
7d5d2b
 	mov		ar.pfs = r19
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f22 = [in0], 0x10
7d5d2b
 	ld8.nt1		r27 = [r10], 8
7d5d2b
-	mov		pr = r26, -1
7d5d2b
+	mov		pr  = r26, -1
7d5d2b
 	;;
7d5d2b
-	ldf.fill.nt1	r23 = [in0], 0x10
7d5d2b
+	ldf.fill.nt1	f23 = [in0], 0x10
7d5d2b
 	ld8.nt1		r28 = [r10], -17*8 - 0x10
7d5d2b
 	mov		ar.lc = r27
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f24 = [in0], 0x10
7d5d2b
 	ldf.fill.nt1	f25 = [in0], 0x10
7d5d2b
-	mov		r8 = in1
7d5d2b
+	mov		r8  = in1
7d5d2b
 	;;
7d5d2b
 	ldf.fill.nt1	f26 = [in0], 0x10
7d5d2b
 	ldf.fill.nt1	f31 = [r10], -0x10
7d5d2b
@@ -192,9 +188,12 @@ _skip_flushrs:
7d5d2b
 	ldf.fill.nt1	f28 = [in0]
7d5d2b
 	ldf.fill.nt1	f29 = [r10], 0x10*3 + 8*4
7d5d2b
 	;;
7d5d2b
-	ld8.fill.nt1	sp = [r10]
7d5d2b
+	ld8.fill.nt1	sp  = [r10]
7d5d2b
 	mov		ar.unat = r18
7d5d2b
 	;;
7d5d2b
 	mov		ar.bspstore = r14
7d5d2b
 	mov		ar.rnat = r31
7d5d2b
 	;;
7d5d2b
+	invala
7d5d2b
+	mov		ar.rsc = r16
7d5d2b
+	br.ret.sptk	b0
7d5d2b
-- 
7d5d2b
2.15.0
7d5d2b