olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone

Blame SOURCES/glibc-aarch64-syscall-rewrite.patch

00db10
From 9a7cb556eef7cb75b31d0bc05f73c6338dfd8e49 Mon Sep 17 00:00:00 2001
00db10
From: Richard Henderson <rth@redhat.com>
00db10
Date: Fri, 30 May 2014 13:57:04 -0400
00db10
Subject: [PATCH] aarch64: Backport syscall rewrite
00db10
00db10
From commits:
00db10
a60339aaff82beadea6f580e587d64052cb5e3b8 Fix handling of nocancel syscall...
00db10
3612eb8f25d978e7e4ac536a34098091f737161c Merge rtld_errno offset w/ mem ref
00db10
a6b3657be6bc5067aeec98d990f60765361c6557 Merge __local_multiple_threads ofs...
00db10
c69abcee726a6f63d9e5e8f0d9dcc79374ee3ef8 Fix DO_CALL block comment
00db10
6e6c2d01ebb1ef839675c7151d2a114f53663386 Remove DOARGS/UNDOARGS macros
00db10
ca3cfa40c16ef34c74951a07a57cfcbcd58898b1 Tidy syscall error check
00db10
af4e8ef9443e258ebeb0ddf3c5c9579f24dfacd5 Tabify sysdep-cancel.h
00db10
a8b4f04ad7dff4f39797a7ab7f8babda54266026 Share code in sysdep-cancel.h
00db10
645d44abe3ca6253a9d4762f092e4a1b9d294b11 Pass regno parameter to SINGLE_THREAD_P
00db10
b5be4597716eff94149f5529c8eb2cd3b4296188 Improve syscall-cancel stack frame
00db10
74f31c18593111725478a991b395ae45661985a3 Fix error return from __ioctl
00db10
f0712b543eaddeca8fc6d7a8eb6b5b8d24105ce2 Remove PSEUDO_RET
00db10
00db10
And a not-yet-committed cleanup to clone.S.
00db10
---
00db10
 ports/sysdeps/unix/sysv/linux/aarch64/clone.S      |  51 +++---
00db10
 ports/sysdeps/unix/sysv/linux/aarch64/ioctl.S      |  13 +-
00db10
 .../unix/sysv/linux/aarch64/nptl/localplt.data     |   1 -
00db10
 .../unix/sysv/linux/aarch64/nptl/sysdep-cancel.h   | 189 +++++++--------------
00db10
 ports/sysdeps/unix/sysv/linux/aarch64/syscall.S    |   4 +-
00db10
 ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h     |  84 ++-------
00db10
 ports/sysdeps/unix/sysv/linux/aarch64/vfork.S      |   4 +-
00db10
 7 files changed, 108 insertions(+), 238 deletions(-)
00db10
00db10
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/clone.S glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/clone.S
00db10
index 8be1464..d5c31f3 100644
00db10
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/clone.S
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/clone.S
00db10
@@ -39,46 +39,43 @@
00db10
  */
00db10
         .text
00db10
 ENTRY(__clone)
00db10
+	/* Save args for the child.  */
00db10
+	mov	x10, x0
00db10
+	mov	x11, x2
00db10
+	mov	x12, x3
00db10
+	
00db10
 	/* Sanity check args.  */
00db10
-	cbz	x0, 1f
00db10
-	cbz	x1, 1f
00db10
-	/* Insert the args onto the new stack.  */
00db10
-	stp	x0, x3, [x1, #-16]!	/* Fn, arg.  */
00db10
+	mov	x0, #-EINVAL
00db10
+	cbz	x10, .Lsyscall_error
00db10
+	cbz	x1, .Lsyscall_error
00db10
 
00db10
 	/* Do the system call.  */
00db10
+	/* X0:flags, x1:newsp, x2:parenttidptr, x3:newtls, x4:childtid.  */
00db10
 	mov	x0, x2                  /* flags  */
00db10
-
00db10
 	/* New sp is already in x1.  */
00db10
 	mov	x2, x4			/* ptid  */
00db10
 	mov	x3, x5			/* tls  */
00db10
 	mov	x4, x6			/* ctid  */
00db10
 
00db10
-#ifdef RESET_PID
00db10
-	/* We rely on the kernel preserving the argument regsiters across a
00db10
-	   each system call so that we can inspect the flags against after
00db10
-	   the clone call.  */
00db10
-	mov	x5, x0
00db10
-#endif
00db10
-
00db10
 	mov	x8, #SYS_ify(clone)
00db10
-	/* X0:flags, x1:newsp, x2:parenttidptr, x3:newtls, x4:childtid.  */
00db10
 	svc	0x0
00db10
-	cfi_endproc
00db10
 	cmp	x0, #0
00db10
-	beq	2f
00db10
-	blt	C_SYMBOL_NAME(__syscall_error)
00db10
+	beq	thread_start
00db10
+	blt	.Lsyscall_error
00db10
 	RET
00db10
-1:	mov	x0, #-EINVAL
00db10
-	b	syscall_error
00db10
+PSEUDO_END (__clone)
00db10
 
00db10
-2:
00db10
+	.align	4
00db10
+	.type	thread_start, %function
00db10
+thread_start:
00db10
 	cfi_startproc
00db10
 	cfi_undefined (x30)
00db10
 	mov	x29, 0
00db10
+
00db10
 #ifdef RESET_PID
00db10
-	tbnz	x5, #CLONE_THREAD_BIT, 3f
00db10
+	tbnz	x11, #CLONE_THREAD_BIT, 3f
00db10
 	mov	x0, #-1
00db10
-	tbnz	x5, #CLONE_VM_BIT, 2f
00db10
+	tbnz	x11, #CLONE_VM_BIT, 2f
00db10
 	mov	x8, #SYS_ify(getpid)
00db10
 	svc	0x0
00db10
 2:
00db10
@@ -86,18 +83,16 @@ ENTRY(__clone)
00db10
 	sub	x1, x1, #PTHREAD_SIZEOF
00db10
 	str	w0, [x1, #PTHREAD_PID_OFFSET]
00db10
 	str	w0, [x1, #PTHREAD_TID_OFFSET]
00db10
-
00db10
 3:
00db10
 #endif
00db10
-	/* Pick the function arg and call address from the stack and
00db10
-	   execute.  */
00db10
-	ldp	x1, x0, [sp], #16
00db10
-	blr	x1
00db10
+
00db10
+	/* Pick the function arg execute.  */
00db10
+	mov	x0, x12
00db10
+	blr	x10
00db10
 
00db10
 	/* We are done, pass the return value through x0.  */
00db10
 	b	HIDDEN_JUMPTARGET(_exit)
00db10
 	cfi_endproc
00db10
-	cfi_startproc
00db10
-PSEUDO_END (__clone)
00db10
+	.size	thread_start, .-thread_start
00db10
 
00db10
 weak_alias (__clone, clone)
00db10
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/ioctl.S glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/ioctl.S
00db10
index f01fb84..be6c026 100644
00db10
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/ioctl.S
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/ioctl.S
00db10
@@ -20,13 +20,12 @@
00db10
 
00db10
 	.text
00db10
 ENTRY(__ioctl)
00db10
-	movz	x8, #__NR_ioctl
00db10
-        sxtw	x0, w0
00db10
-        svc	#0x0
00db10
-	cmn	x0, #0x1, lsl #12
00db10
-	b.hi	C_SYMBOL_NAME(__syscall_error)
00db10
+	mov	x8, #__NR_ioctl
00db10
+	sxtw	x0, w0
00db10
+	svc	#0x0
00db10
+	cmn	x0, #4095
00db10
+	b.cs	.Lsyscall_error
00db10
 	ret
00db10
-
00db10
-	PSEUDO_END (__ioctl)
00db10
+PSEUDO_END (__ioctl)
00db10
 
00db10
 weak_alias (__ioctl, ioctl)
00db10
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/localplt.data glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/localplt.data
00db10
index 84af95d..dfca9a7 100644
00db10
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/localplt.data
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/localplt.data
00db10
@@ -12,4 +12,3 @@ libm.so: matherr
00db10
 libm.so: __signbit
00db10
 libm.so: __signbitf
00db10
 libm.so: __signbitl
00db10
-libpthread.so: __errno_location
00db10
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/sysdep-cancel.h glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/sysdep-cancel.h
00db10
index e0e5cc0..a3b9284 100644
00db10
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/sysdep-cancel.h
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/nptl/sysdep-cancel.h
00db10
@@ -26,119 +26,60 @@
00db10
 
00db10
 # undef PSEUDO
00db10
 # define PSEUDO(name, syscall_name, args)				\
00db10
-  .section ".text";							\
00db10
-  .type __##syscall_name##_nocancel,%function;				\
00db10
-  .globl __##syscall_name##_nocancel;					\
00db10
-  __##syscall_name##_nocancel:						\
00db10
-    cfi_startproc;							\
00db10
-    DO_CALL (syscall_name, args);					\
00db10
-    PSEUDO_RET;								\
00db10
-    cfi_endproc;							\
00db10
-    .size __##syscall_name##_nocancel,.-__##syscall_name##_nocancel;	\
00db10
-  ENTRY (name);								\
00db10
-    SINGLE_THREAD_P;							\
00db10
-    DOARGS_##args;							\
00db10
-    bne .Lpseudo_cancel;						\
00db10
-    DO_CALL (syscall_name, 0);						\
00db10
-    UNDOARGS_##args;							\
00db10
-    cmn x0, 4095;							\
00db10
-    PSEUDO_RET;								\
00db10
-  .Lpseudo_cancel:							\
00db10
-    DOCARGS_##args;	/* save syscall args etc. around CENABLE.  */	\
00db10
-    CENABLE;								\
00db10
-    mov x16, x0;	/* put mask in safe place.  */			\
00db10
-    UNDOCARGS_##args;	/* restore syscall args.  */			\
00db10
-    mov x8, SYS_ify (syscall_name);	/* do the call.  */		\
00db10
-    svc	0;								\
00db10
-    str x0, [sp, -16]!;	/* save syscall return value.  */		\
00db10
-    cfi_adjust_cfa_offset (16);						\
00db10
-    mov x0, x16;	 /* get mask back.  */				\
00db10
-    CDISABLE;								\
00db10
-    ldr x0, [sp], 16;							\
00db10
-    cfi_adjust_cfa_offset (-16);					\
00db10
-    ldr x30, [sp], 16;							\
00db10
-    cfi_adjust_cfa_offset (-16);					\
00db10
-    cfi_restore (x30);							\
00db10
-    UNDOARGS_##args;							\
00db10
-    cmn x0, 4095;
00db10
-
00db10
-# define DOCARGS_0							\
00db10
-	str x30, [sp, -16]!;						\
00db10
-	cfi_adjust_cfa_offset (16);					\
00db10
-	cfi_rel_offset (x30, 0)
00db10
+	.section ".text";						\
00db10
+ENTRY (__##syscall_name##_nocancel);					\
00db10
+.Lpseudo_nocancel:							\
00db10
+	DO_CALL (syscall_name, args);					\
00db10
+.Lpseudo_finish:							\
00db10
+	cmn	x0, 4095;						\
00db10
+	b.cs	.Lsyscall_error;					\
00db10
+	.subsection 2;							\
00db10
+	.size __##syscall_name##_nocancel,.-__##syscall_name##_nocancel; \
00db10
+ENTRY (name);								\
00db10
+	SINGLE_THREAD_P(16);						\
00db10
+	cbz	w16, .Lpseudo_nocancel;					\
00db10
+	/* Setup common stack frame no matter the number of args.	\
00db10
+	   Also save the first arg, since it's basically free.  */	\
00db10
+	stp	x30, x0, [sp, -64]!;					\
00db10
+	cfi_adjust_cfa_offset (64);					\
00db10
+	cfi_rel_offset (x30, 0);					\
00db10
+	DOCARGS_##args;		/* save syscall args around CENABLE.  */ \
00db10
+	CENABLE;							\
00db10
+	mov	x16, x0;	/* save mask around syscall.  */	\
00db10
+	UNDOCARGS_##args;	/* restore syscall args.  */		\
00db10
+	DO_CALL (syscall_name, args);					\
00db10
+	str	x0, [sp, 8];	/* save result around CDISABLE.  */	\
00db10
+	mov	x0, x16;	/* restore mask for CDISABLE.  */	\
00db10
+	CDISABLE;							\
00db10
+	/* Break down the stack frame, restoring result at once.  */	\
00db10
+	ldp	x30, x0, [sp], 64;					\
00db10
+	cfi_adjust_cfa_offset (-64);					\
00db10
+	cfi_restore (x30);						\
00db10
+	b	.Lpseudo_finish;					\
00db10
+	cfi_endproc;							\
00db10
+	.size	name, .-name;						\
00db10
+	.previous
00db10
+
00db10
+# undef PSEUDO_END
00db10
+# define PSEUDO_END(name)						\
00db10
+	SYSCALL_ERROR_HANDLER;						\
00db10
+	cfi_endproc
00db10
+
00db10
+# define DOCARGS_0
00db10
+# define DOCARGS_1
00db10
+# define DOCARGS_2	str x1, [sp, 16]
00db10
+# define DOCARGS_3	stp x1, x2, [sp, 16]
00db10
+# define DOCARGS_4	DOCARGS_3; str x3, [sp, 32]
00db10
+# define DOCARGS_5	DOCARGS_3; stp x3, x4, [sp, 32]
00db10
+# define DOCARGS_6	DOCARGS_5; str x5, [sp, 48]
00db10
 
00db10
 # define UNDOCARGS_0
00db10
-
00db10
-# define DOCARGS_1							\
00db10
-	DOCARGS_0;							\
00db10
-	str x0, [sp, -16]!;						\
00db10
-	cfi_adjust_cfa_offset (16);					\
00db10
-	cfi_rel_offset (x0, 0)
00db10
-
00db10
-# define UNDOCARGS_1							\
00db10
-	ldr x0, [sp], 16;						\
00db10
-	cfi_restore (x0);						\
00db10
-	cfi_adjust_cfa_offset (-16);					\
00db10
-
00db10
-# define DOCARGS_2							\
00db10
-	DOCARGS_1;							\
00db10
-	str x1, [sp, -16]!;						\
00db10
-	cfi_adjust_cfa_offset (16);					\
00db10
-	cfi_rel_offset (x1, 0)
00db10
-
00db10
-# define UNDOCARGS_2							\
00db10
-	ldr x1, [sp], 16;						\
00db10
-	cfi_restore (x1);						\
00db10
-	cfi_adjust_cfa_offset (-16);					\
00db10
-	UNDOCARGS_1
00db10
-
00db10
-# define DOCARGS_3							\
00db10
-	DOCARGS_2;							\
00db10
-	str x2, [sp, -16]!;						\
00db10
-	cfi_adjust_cfa_offset (16);					\
00db10
-	cfi_rel_offset (x2, 0)
00db10
-
00db10
-# define UNDOCARGS_3							\
00db10
-	ldr x2, [sp], 16;						\
00db10
-	cfi_restore (x2);						\
00db10
-	cfi_adjust_cfa_offset (-16);					\
00db10
-	UNDOCARGS_2
00db10
-
00db10
-# define DOCARGS_4							\
00db10
-	DOCARGS_3;							\
00db10
-	str x3, [sp, -16]!;						\
00db10
-	cfi_adjust_cfa_offset (16);					\
00db10
-	cfi_rel_offset (x3, 0)
00db10
-
00db10
-# define UNDOCARGS_4							\
00db10
-	ldr x3, [sp], 16;						\
00db10
-	cfi_restore (x3);						\
00db10
-	cfi_adjust_cfa_offset (-16);					\
00db10
-	UNDOCARGS_3
00db10
-
00db10
-# define DOCARGS_5							\
00db10
-	DOCARGS_4;							\
00db10
-	str x4, [sp, -16]!;						\
00db10
-	cfi_adjust_cfa_offset (16);					\
00db10
-	cfi_rel_offset (x4, 0)
00db10
-
00db10
-# define UNDOCARGS_5							\
00db10
-	ldr x4, [sp], 16;						\
00db10
-	cfi_restore (x4);						\
00db10
-	cfi_adjust_cfa_offset (-16);					\
00db10
-	UNDOCARGS_4
00db10
-
00db10
-# define DOCARGS_6							\
00db10
-	DOCARGS_5;							\
00db10
-	str x5, [sp, -16]!;						\
00db10
-	cfi_adjust_cfa_offset (16);					\
00db10
-	cfi_rel_offset (x5, 0)
00db10
-
00db10
-# define UNDOCARGS_6							\
00db10
-	ldr x5, [sp], 16;						\
00db10
-	cfi_restore (x5);						\
00db10
-	cfi_adjust_cfa_offset (-16);					\
00db10
-	UNDOCARGS_5
00db10
+# define UNDOCARGS_1	ldr x0, [sp, 8]
00db10
+# define UNDOCARGS_2	ldp x0, x1, [sp, 8]
00db10
+# define UNDOCARGS_3	UNDOCARGS_1; ldp x1, x2, [sp, 16]
00db10
+# define UNDOCARGS_4	UNDOCARGS_2; ldp x2, x3, [sp, 24]
00db10
+# define UNDOCARGS_5	UNDOCARGS_3; ldp x3, x4, [sp, 32]
00db10
+# define UNDOCARGS_6	UNDOCARGS_4; ldp x4, x5, [sp, 40]
00db10
 
00db10
 # ifdef IS_IN_libpthread
00db10
 #  define CENABLE	bl __pthread_enable_asynccancel
00db10
@@ -160,11 +101,9 @@
00db10
 extern int __local_multiple_threads attribute_hidden;
00db10
 #   define SINGLE_THREAD_P __builtin_expect (__local_multiple_threads == 0, 1)
00db10
 #  else
00db10
-#   define SINGLE_THREAD_P						\
00db10
-  adrp	x16, __local_multiple_threads;					\
00db10
-  add	x16, x16, #:lo12:__local_multiple_threads;			\
00db10
-  ldr	x16, [x16];							\
00db10
-  cmp	x16, 0;
00db10
+#   define SINGLE_THREAD_P(R)						\
00db10
+	adrp	x##R, __local_multiple_threads;				\
00db10
+	ldr	w##R, [x##R, :lo12:__local_multiple_threads]
00db10
 #  endif
00db10
 # else
00db10
 /*  There is no __local_multiple_threads for librt, so use the TCB.  */
00db10
@@ -173,20 +112,10 @@ extern int __local_multiple_threads attribute_hidden;
00db10
   __builtin_expect (THREAD_GETMEM (THREAD_SELF,				\
00db10
 				   header.multiple_threads) == 0, 1)
00db10
 #  else
00db10
-#   define SINGLE_THREAD_P						\
00db10
-  stp	x0, x30, [sp, -16]!;						\
00db10
-  cfi_adjust_cfa_offset (16);						\
00db10
-  cfi_rel_offset (x0, 0);						\
00db10
-  cfi_rel_offset (x30, 8);						\
00db10
-  bl	__read_tp;							\
00db10
-  sub	x0, x0, PTHREAD_SIZEOF;						\
00db10
-  ldr	x16, [x0, PTHREAD_MULTIPLE_THREADS_OFFSET];			\
00db10
-  ldp	x0, x30, [sp], 16;						\
00db10
-  cfi_restore (x0);							\
00db10
-  cfi_restore (x30);							\
00db10
-  cfi_adjust_cfa_offset (-16);						\
00db10
-  cmp	x16, 0
00db10
-#   define SINGLE_THREAD_P_PIC(x) SINGLE_THREAD_P
00db10
+#   define SINGLE_THREAD_P(R)						\
00db10
+	mrs	x##R, tpidr_el0;					\
00db10
+	sub	x##R, x##R, PTHREAD_SIZEOF;				\
00db10
+	ldr	w##R, [x##R, PTHREAD_MULTIPLE_THREADS_OFFSET]
00db10
 #  endif
00db10
 # endif
00db10
 
00db10
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/syscall.S glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/syscall.S
00db10
index 574fdf1..fac6416 100644
00db10
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/syscall.S
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/syscall.S
00db10
@@ -37,8 +37,6 @@ ENTRY (syscall)
00db10
 	mov	x6, x7
00db10
 	svc	0x0
00db10
 	cmn	x0, #4095
00db10
-	b.cs	1f
00db10
+	b.cs	.Lsyscall_error
00db10
 	RET
00db10
-1:
00db10
-	b	SYSCALL_ERROR
00db10
 PSEUDO_END (syscall)
00db10
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h
00db10
index 713bf7d..9961c03 100644
00db10
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h
00db10
@@ -58,19 +58,8 @@
00db10
   .text;								      \
00db10
   ENTRY (name);								      \
00db10
     DO_CALL (syscall_name, args);					      \
00db10
-    cmn x0, #4095;
00db10
-
00db10
-/* Notice the use of 'RET' instead of 'ret' the assembler is case
00db10
-   insensitive and eglibc already uses the preprocessor symbol 'ret'
00db10
-   so we use the upper case 'RET' to force through a ret instruction
00db10
-   to the assembler */
00db10
-# define PSEUDO_RET							      \
00db10
-    b.cs 1f;								      \
00db10
-    RET;								      \
00db10
-    1:                                                                        \
00db10
-    b SYSCALL_ERROR
00db10
-# undef ret
00db10
-# define ret PSEUDO_RET
00db10
+    cmn x0, #4095;							      \
00db10
+    b.cs .Lsyscall_error
00db10
 
00db10
 # undef	PSEUDO_END
00db10
 # define PSEUDO_END(name)						      \
00db10
@@ -83,15 +72,7 @@
00db10
   ENTRY (name);								      \
00db10
     DO_CALL (syscall_name, args);
00db10
 
00db10
-/* Notice the use of 'RET' instead of 'ret' the assembler is case
00db10
-   insensitive and eglibc already uses the preprocessor symbol 'ret'
00db10
-   so we use the upper case 'RET' to force through a ret instruction
00db10
-   to the assembler */
00db10
-# define PSEUDO_RET_NOERRNO						      \
00db10
-    RET;
00db10
-
00db10
-# undef ret_NOERRNO
00db10
-# define ret_NOERRNO PSEUDO_RET_NOERRNO
00db10
+# define ret_NOERRNO ret
00db10
 
00db10
 # undef	PSEUDO_END_NOERRNO
00db10
 # define PSEUDO_END_NOERRNO(name)					      \
00db10
@@ -109,47 +90,38 @@
00db10
 # define PSEUDO_END_ERRVAL(name) \
00db10
   END (name)
00db10
 
00db10
-# define ret_ERRVAL PSEUDO_RET_NOERRNO
00db10
+# define ret_ERRVAL ret
00db10
 
00db10
+# define SYSCALL_ERROR  .Lsyscall_error
00db10
 # if NOT_IN_libc
00db10
-#  define SYSCALL_ERROR __local_syscall_error
00db10
 #  if RTLD_PRIVATE_ERRNO
00db10
 #   define SYSCALL_ERROR_HANDLER				\
00db10
-__local_syscall_error:						\
00db10
+.Lsyscall_error:						\
00db10
 	adrp	x1, C_SYMBOL_NAME(rtld_errno);			\
00db10
-	add	x1, x1, #:lo12:C_SYMBOL_NAME(rtld_errno);	\
00db10
 	neg     w0, w0;						\
00db10
-	str     w0, [x1];					\
00db10
+	str     w0, [x1, :lo12:C_SYMBOL_NAME(rtld_errno)];	\
00db10
 	mov	x0, -1;						\
00db10
 	RET;
00db10
 #  else
00db10
 
00db10
 #   define SYSCALL_ERROR_HANDLER				\
00db10
-__local_syscall_error:						\
00db10
-	stp     x29, x30, [sp, -32]!;				\
00db10
-	cfi_adjust_cfa_offset (32);				\
00db10
-	cfi_rel_offset (x29, 0);				\
00db10
-	cfi_rel_offset (x30, 8);				\
00db10
-        add     x29, sp, 0;					\
00db10
-        str     x19, [sp,16];					\
00db10
-	neg	x19, x0;					\
00db10
-	bl	C_SYMBOL_NAME(__errno_location);		\
00db10
-	str	x19, [x0];					\
00db10
+.Lsyscall_error:						\
00db10
+	adrp	x1, :gottprel:errno;				\
00db10
+	neg	w2, w0;						\
00db10
+	ldr	x1, [x1, :gottprel_lo12:errno];			\
00db10
+	mrs	x3, tpidr_el0;					\
00db10
 	mov	x0, -1;						\
00db10
-        ldr     x19, [sp,16];					\
00db10
-        ldp     x29, x30, [sp], 32;				\
00db10
-	cfi_adjust_cfa_offset (-32);				\
00db10
-	cfi_restore (x29);					\
00db10
-	cfi_restore (x30);					\
00db10
+	str	w2, [x1, x3];					\
00db10
 	RET;
00db10
 #  endif
00db10
 # else
00db10
-#  define SYSCALL_ERROR_HANDLER	/* Nothing here; code in sysdep.S is used.  */
00db10
-#  define SYSCALL_ERROR __syscall_error
00db10
+#  define SYSCALL_ERROR_HANDLER					\
00db10
+.Lsyscall_error:						\
00db10
+	b	__syscall_error;
00db10
 # endif
00db10
 
00db10
 /* Linux takes system call args in registers:
00db10
-	syscall number	in the SVC instruction
00db10
+	syscall number	x8
00db10
 	arg 1		x0
00db10
 	arg 2		x1
00db10
 	arg 3		x2
00db10
@@ -177,28 +149,8 @@ __local_syscall_error:						\
00db10
 
00db10
 # undef	DO_CALL
00db10
 # define DO_CALL(syscall_name, args)		\
00db10
-    DOARGS_##args				\
00db10
     mov x8, SYS_ify (syscall_name);		\
00db10
-    svc 0;					\
00db10
-    UNDOARGS_##args
00db10
-
00db10
-# define DOARGS_0 /* nothing */
00db10
-# define DOARGS_1 /* nothing */
00db10
-# define DOARGS_2 /* nothing */
00db10
-# define DOARGS_3 /* nothing */
00db10
-# define DOARGS_4 /* nothing */
00db10
-# define DOARGS_5 /* nothing */
00db10
-# define DOARGS_6 /* nothing */
00db10
-# define DOARGS_7 /* nothing */
00db10
-
00db10
-# define UNDOARGS_0 /* nothing */
00db10
-# define UNDOARGS_1 /* nothing */
00db10
-# define UNDOARGS_2 /* nothing */
00db10
-# define UNDOARGS_3 /* nothing */
00db10
-# define UNDOARGS_4 /* nothing */
00db10
-# define UNDOARGS_5 /* nothing */
00db10
-# define UNDOARGS_6 /* nothing */
00db10
-# define UNDOARGS_7 /* nothing */
00db10
+    svc 0
00db10
 
00db10
 #else /* not __ASSEMBLER__ */
00db10
 
00db10
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/vfork.S glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/vfork.S
00db10
index f2dc49b..3fb68b9 100644
00db10
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/vfork.S
00db10
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/vfork.S
00db10
@@ -38,10 +38,8 @@ ENTRY (__vfork)
00db10
 	RESTORE_PID
00db10
 #endif
00db10
 	cmn	x0, #4095
00db10
-	b.cs    1f
00db10
+	b.cs    .Lsyscall_error
00db10
 	RET
00db10
-1:
00db10
-	b	SYSCALL_ERROR
00db10
 
00db10
 PSEUDO_END (__vfork)
00db10
 libc_hidden_def (__vfork)
00db10
-- 
00db10
1.8.3.1
00db10