mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-30 22:43:12 +03:00
S/390: Fix uc_link == NULL handling for makecontext
This commit is contained in:
15
ChangeLog
15
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>
|
2012-07-19 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
|
||||||
|
|
||||||
* elf/elf.h (R_390_IRELATIVE): New definition.
|
* elf/elf.h (R_390_IRELATIVE): New definition.
|
||||||
|
@ -21,3 +21,7 @@ sysdep_routines += framestate
|
|||||||
shared-only-routines += framestate
|
shared-only-routines += framestate
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(subdir),stdlib)
|
||||||
|
sysdep_routines += __makecontext_ret
|
||||||
|
endif
|
||||||
|
48
sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S
Normal file
48
sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S
Normal file
@ -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)
|
@ -80,10 +80,10 @@ __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
|
|||||||
sp -= 24;
|
sp -= 24;
|
||||||
*sp = 0;
|
*sp = 0;
|
||||||
|
|
||||||
/* Pass (*func) to __start_context in %r7. */
|
/* Pass (*func) to __makecontext_ret in %r7. */
|
||||||
ucp->uc_mcontext.gregs[7] = (long int) func;
|
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;
|
ucp->uc_mcontext.gregs[8] = (long int) ucp->uc_link;
|
||||||
|
|
||||||
/* Pass address of setcontext in %r9. */
|
/* 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;
|
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)
|
weak_alias (__makecontext, makecontext)
|
||||||
|
@ -12,3 +12,7 @@ sysdep_routines += framestate
|
|||||||
shared-only-routines += framestate
|
shared-only-routines += framestate
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(subdir),stdlib)
|
||||||
|
sysdep_routines += __makecontext_ret
|
||||||
|
endif
|
||||||
|
29
sysdeps/unix/sysv/linux/s390/s390-64/__makecontext_ret.S
Normal file
29
sysdeps/unix/sysv/linux/s390/s390-64/__makecontext_ret.S
Normal file
@ -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)
|
@ -80,10 +80,10 @@ __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
|
|||||||
sp -= 20;
|
sp -= 20;
|
||||||
*sp = 0;
|
*sp = 0;
|
||||||
|
|
||||||
/* Pass (*func) to __start_context in %r7. */
|
/* Pass (*func) to __makecontext_ret in %r7. */
|
||||||
ucp->uc_mcontext.gregs[7] = (long int) func;
|
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;
|
ucp->uc_mcontext.gregs[8] = (long int) ucp->uc_link;
|
||||||
|
|
||||||
/* Pass address of setcontext in %r9. */
|
/* 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;
|
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)
|
weak_alias (__makecontext, makecontext)
|
||||||
|
Reference in New Issue
Block a user