~ubuntu-branches/ubuntu/utopic/eglibc/utopic

« back to all changes in this revision

Viewing changes to sysdeps/unix/sysv/linux/aarch64/setcontext.S

  • Committer: Package Import Robot
  • Author(s): Adam Conrad
  • Date: 2012-10-26 05:14:58 UTC
  • mfrom: (1.5.1) (4.4.22 experimental)
  • Revision ID: package-import@ubuntu.com-20121026051458-oryotr4i03ob5pab
Tags: 2.16-0ubuntu1
* Merge with unreleased 2.16 in Debian experimental, remaining changes:
  - Drop the Breaks line from libc6, which refers to a Debian transition
  - Remove the libc6 recommends on libc6-i686, which we don't build
  - Enable libc6{,-dev}-armel on armhf and libc6{-dev}-armhf on armel
  - Ship update-locale and validlocale in /usr/sbin in libc-bin
  - Don't build locales or locales-all in Ubuntu, we rely on langpacks
  - Heavily mangle the way we do service restarting on major upgrades
  - Use different MIN_KERNEL_SUPPORTED versions than Debian, due to
    buildd needs.  This should be universally bumped to 3.2.0 once all
    our buildds (including the PPA guests) are running precise kernels
  - Build i386 variants as -march=i686, build amd64 with -O3, and build
    ppc64 variants (both 64-bit and 32-bit) with -O3 -fno-tree-vectorize
  - Re-enable unsubmitted-ldconfig-cache-abi.diff and rebuild the cache
    on upgrades from previous versions that used a different constant
  - debian/patches/any/local-CVE-2012-3406.diff: switch to malloc when
    array grows too large to handle via alloca extension (CVE-2012-3406)
  - Build generic i386/i686 flavour with -mno-tls-direct-seg-refs
* Changes added/dropped with this merge while reducing our delta:
  - Stop building glibc docs from the eglibc source, and instead make
    the glibc-docs stub have a hard dependency on glibc-doc-reference
  - Remove outdated conflicts against ancient versions of ia32-libs
  - Drop the tzdata dependency from libc6, it's in required and minimal
  - Use gcc-4.7/g++-4.7 by default on all our supported architectures
  - Save our historical changelog as changelog.ubuntu in the source
  - Drop nscd's libaudit build-dep for now, as libaudit is in universe
  - Drop the unnecessary Breaks from libc6 to locales and locales-all
  - Ship xen's ld.so.conf.d snippet as /etc/ld.so.conf.d/libc6-xen.conf
* Disable hard failures on the test suite for the first upload to raring

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* Set current context.
 
2
 
 
3
   Copyright (C) 2009-2012 Free Software Foundation, Inc.
 
4
 
 
5
   This file is part of the GNU C Library.
 
6
 
 
7
   The GNU C Library is free software; you can redistribute it and/or
 
8
   modify it under the terms of the GNU Lesser General Public License as
 
9
   published by the Free Software Foundation; either version 2.1 of the
 
10
   License, or (at your option) any later version.
 
11
 
 
12
   The GNU C Library is distributed in the hope that it will be useful,
 
13
   but WITHOUT ANY WARRANTY; without even the implied warranty of
 
14
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 
15
   Lesser General Public License for more details.
 
16
 
 
17
   You should have received a copy of the GNU Lesser General Public
 
18
   License along with the GNU C Library; if not, see
 
19
   <http://www.gnu.org/licenses/>.  */
 
20
 
 
21
#include <sysdep.h>
 
22
#include "ucontext_i.h"
 
23
#include "ucontext-internal.h"
 
24
 
 
25
/* int setcontext (const ucontext_t *ucp) */
 
26
 
 
27
        .text
 
28
 
 
29
ENTRY(__setcontext)
 
30
 
 
31
        /* Create a signal frame on the stack:
 
32
 
 
33
                fp
 
34
                lr
 
35
                ...
 
36
           sp-> rt_sigframe
 
37
         */
 
38
 
 
39
        stp     x29, x30, [sp, -16]!
 
40
        cfi_adjust_cfa_offset (16)
 
41
        cfi_rel_offset (x29, 0)
 
42
        cfi_rel_offset (x30, 8)
 
43
 
 
44
        mov     x29, sp
 
45
        cfi_def_cfa_register (x29)
 
46
 
 
47
        /* Allocate space for the sigcontext.  */
 
48
        mov     w3, #((RT_SIGFRAME_SIZE + SP_ALIGN_SIZE) & SP_ALIGN_MASK)
 
49
        sub     sp, sp, x3
 
50
 
 
51
        /* Compute the base address of the ucontext structure.  */
 
52
        add     x1, sp, #RT_SIGFRAME_UCONTEXT
 
53
 
 
54
        /* Only ucontext is required in the frame, *copy* it in.  */
 
55
 
 
56
#if UCONTEXT_SIZE % 16
 
57
#error The implementation of setcontext.S assumes sizeof(ucontext_t) % 16 == 0
 
58
#endif
 
59
 
 
60
        mov     x2, #UCONTEXT_SIZE / 16
 
61
0:
 
62
        ldp     x3, x4, [x0], #16
 
63
        stp     x3, x4, [x1], #16
 
64
        sub     x2, x2, 1
 
65
        cbnz    x2, 0b
 
66
 
 
67
        /* rt_sigreturn () -- no arguments, sp points to struct rt_sigframe.  */
 
68
        mov     x8, SYS_ify (rt_sigreturn)
 
69
        svc     0
 
70
 
 
71
        /* Ooops we failed.  Recover the stack */
 
72
 
 
73
        mov     sp, x29
 
74
        cfi_def_cfa_register (sp)
 
75
 
 
76
        ldp     x29, x30, [sp], 16
 
77
        cfi_adjust_cfa_offset (16)
 
78
        cfi_restore (x29)
 
79
        cfi_restore (x30)
 
80
        b       PLTJMP(C_SYMBOL_NAME(__syscall_error))
 
81
 
 
82
PSEUDO_END (__setcontext)
 
83
weak_alias (__setcontext, setcontext)
 
84
 
 
85
ENTRY(__startcontext)
 
86
        mov     x0, x19
 
87
        cbnz    x0, PLTJMP(__setcontext)
 
88
1:      b       PLTJMP(HIDDEN_JUMPTARGET(_exit))
 
89
END(__startcontext)