]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
S/390: Fix uc_link == NULL handling for makecontext
authorAndreas Krebbel <krebbel@linux.vnet.ibm.com>
Thu, 19 Jul 2012 13:58:17 +0000 (15:58 +0200)
committerAndreas Krebbel <krebbel@linux.vnet.ibm.com>
Thu, 19 Jul 2012 13:58:17 +0000 (15:58 +0200)
ChangeLog
sysdeps/unix/sysv/linux/s390/s390-32/Makefile
sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S [new file with mode: 0644]
sysdeps/unix/sysv/linux/s390/s390-32/makecontext.c
sysdeps/unix/sysv/linux/s390/s390-64/Makefile
sysdeps/unix/sysv/linux/s390/s390-64/__makecontext_ret.S [new file with mode: 0644]
sysdeps/unix/sysv/linux/s390/s390-64/makecontext.c

index 3dee64dcf5139452cd255054a3684958c2ccecc4..d96f3686aa0f4e8bc5a747d7e1735e610d0a7c33 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,18 @@
+2012-07-19  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
+
+       * sysdeps/unix/sysv/linux/s390/s390-32/makecontext.c: Move
+       __makecontext_ret to ...
+       * sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S:
+       ... here and call exit if uc_link is NULL.  New file.
+       * sysdeps/unix/sysv/linux/s390/s390-32/Makefile: Add
+       __makecontext_ret.S.
+       * sysdeps/unix/sysv/linux/s390/s390-64/makecontext.c: Move
+       __makecontext_ret to ...
+       * sysdeps/unix/sysv/linux/s390/s390-64/__makecontext_ret.S:
+       ... here and call exit if uc_link is NULL.  New file.
+       * sysdeps/unix/sysv/linux/s390/s390-64/Makefile: Add
+       __makecontext_ret.S.
+
 2012-07-19  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
 
        * elf/elf.h (R_390_IRELATIVE): New definition.
index 3216804f7b5c3baee5bd02d186fdc861515c2a3a..626a96f04fd916812c902b9440779cae04e061d5 100644 (file)
@@ -21,3 +21,7 @@ sysdep_routines += framestate
 shared-only-routines += framestate
 endif
 endif
+
+ifeq ($(subdir),stdlib)
+sysdep_routines += __makecontext_ret
+endif
diff --git a/sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S b/sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S
new file mode 100644 (file)
index 0000000..ab172bb
--- /dev/null
@@ -0,0 +1,48 @@
+/* Copyright (C) 2012 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library 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
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+
+ENTRY(__makecontext_ret)
+       basr  %r14,%r7
+       ltr   %r8,%r8                   /* Check whether uc_link is 0.  */
+       jz    1f
+       lr    %r2,%r8
+       br    %r9
+1:     lhi   %r2,0                     /* EXIT return value.  */
+       basr    %r13,0
+2:
+#ifdef PIC
+       l       %r12,4f-2b(%r13)
+       la      %r12,0(%r12,%r13)       /* GOT pointer in r12 after this.  */
+       l       %r1,3f-2b(%r13)
+       bas     %r14,0(%r1,%r12)
+       .align  4
+3:
+       .long   HIDDEN_JUMPTARGET (exit)@GOTOFF
+4:
+       .long   _GLOBAL_OFFSET_TABLE_-2b
+#else
+       l       %r1,3f-2b(%r13)
+       basr    %r14,%r1
+       .align  4
+3:
+       .long   HIDDEN_JUMPTARGET (exit)
+#endif
+       .align  2
+       j       .+2                     /* Trap if exit returns for some reason.  */
+END(__makecontext_ret)
index 7eb2712ecee95157306f38fcbe8579b0230c5bcc..407676b488ea15eba224abfc8bab26c214ad6985 100644 (file)
@@ -80,10 +80,10 @@ __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
   sp -= 24;
   *sp = 0;
 
-  /* Pass (*func) to __start_context in %r7.  */
+  /* Pass (*func) to __makecontext_ret in %r7.  */
   ucp->uc_mcontext.gregs[7] = (long int) func;
 
-  /* Pass ucp->uc_link to __start_context in %r8.  */
+  /* Pass ucp->uc_link to __makecontext_ret in %r8.  */
   ucp->uc_mcontext.gregs[8] = (long int) ucp->uc_link;
 
   /* Pass address of setcontext in %r9.  */
@@ -93,12 +93,4 @@ __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
   ucp->uc_mcontext.gregs[15] = (long int) sp;
 }
 
-asm (".text\n"
-     ".type __makecontext_ret,@function\n"
-     "__makecontext_ret:\n"
-     "      basr  %r14,%r7\n"
-     "      lr    %r2,%r8\n"
-     "      br    %r9\n"
-     ".size __makecontext_ret, .-__makecontext_ret");
-
 weak_alias (__makecontext, makecontext)
index 1f6ad210642b734a7d386d714d1bf1422e7dadcb..679573474734ad1fbadf54776de4eebfbd739859 100644 (file)
@@ -12,3 +12,7 @@ sysdep_routines += framestate
 shared-only-routines += framestate
 endif
 endif
+
+ifeq ($(subdir),stdlib)
+sysdep_routines += __makecontext_ret
+endif
diff --git a/sysdeps/unix/sysv/linux/s390/s390-64/__makecontext_ret.S b/sysdeps/unix/sysv/linux/s390/s390-64/__makecontext_ret.S
new file mode 100644 (file)
index 0000000..cbd88e1
--- /dev/null
@@ -0,0 +1,29 @@
+/* Copyright (C) 2012 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library 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
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+
+ENTRY(__makecontext_ret)
+       basr    %r14,%r7
+       ltgr    %r8,%r8                 /* Check whether uc_link is 0.  */
+       jz      1f
+       lgr     %r2,%r8
+       br      %r9
+1:     lghi    %r2,0
+       brasl   %r14,HIDDEN_JUMPTARGET (exit)
+       j       .+2                     /* Trap if exit returns.  */
+END(__makecontext_ret)
index dcc63a235410ab8037571431539b43b4578183f0..17e5dba3c275202a686cc6cf78754a2616bdc11b 100644 (file)
@@ -80,10 +80,10 @@ __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
   sp -= 20;
   *sp = 0;
 
-  /* Pass (*func) to __start_context in %r7.  */
+  /* Pass (*func) to __makecontext_ret in %r7.  */
   ucp->uc_mcontext.gregs[7] = (long int) func;
 
-  /* Pass ucp->uc_link to __start_context in %r8.  */
+  /* Pass ucp->uc_link to __makecontext_ret in %r8.  */
   ucp->uc_mcontext.gregs[8] = (long int) ucp->uc_link;
 
   /* Pass address of setcontext in %r9.  */
@@ -93,12 +93,4 @@ __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
   ucp->uc_mcontext.gregs[15] = (long int) sp;
 }
 
-asm (".text\n"
-     ".type __makecontext_ret,@function\n"
-     "__makecontext_ret:\n"
-     "      basr  %r14,%r7\n"
-     "      lgr   %r2,%r8\n"
-     "      br    %r9\n"
-     ".size __makecontext_ret, .-__makecontext_ret");
-
 weak_alias (__makecontext, makecontext)