OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [uClibc/] [libc/] [sysdeps/] [linux/] [i386/] [bits/] [sigcontextinfo.h] - Blame information for rev 1325

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1325 phoenix
/* Copyright (C) 1998, 1999, 2001 Free Software Foundation, Inc.
2
   This file is part of the GNU C Library.
3
   Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
4
 
5
   The GNU C Library is free software; you can redistribute it and/or
6
   modify it under the terms of the GNU Lesser General Public
7
   License as published by the Free Software Foundation; either
8
   version 2.1 of the License, or (at your option) any later version.
9
 
10
   The GNU C Library is distributed in the hope that it will be useful,
11
   but WITHOUT ANY WARRANTY; without even the implied warranty of
12
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13
   Lesser General Public License for more details.
14
 
15
   You should have received a copy of the GNU Lesser General Public
16
   License along with the GNU C Library; if not, write to the Free
17
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18
   02111-1307 USA.  */
19
 
20
#define SIGCONTEXT struct sigcontext
21
#define SIGCONTEXT_EXTRA_ARGS
22
#define GET_PC(ctx)     ((void *) ctx.eip)
23
#define GET_FRAME(ctx)  ((void *) ctx.ebp)
24
#define GET_STACK(ctx)  ((void *) ctx.esp_at_signal)
25
#define CALL_SIGHANDLER(handler, signo, ctx) \
26
do {                                                                          \
27
  int __tmp1, __tmp2, __tmp3, __tmp4;                                         \
28
  __asm __volatile ("movl\t%%esp, %%edi\n\t"                                  \
29
                    "andl\t$-16, %%esp\n\t"                                   \
30
                    "subl\t%8, %%esp\n\t"                                     \
31
                    "movl\t%%edi, %c8-4(%%esp)\n\t"                           \
32
                    "movl\t%1, 0(%%esp)\n\t"                                  \
33
                    "leal\t4(%%esp), %%edi\n\t"                               \
34
                    "cld\n\t"                                                 \
35
                    "rep\tmovsl\n\t"                                          \
36
                    "call\t*%0\n\t"                                           \
37
                    "cld\n\t"                                                 \
38
                    "movl\t%9, %%ecx\n\t"                                     \
39
                    "subl\t%%edi, %%esi\n\t"                                  \
40
                    "leal\t4(%%esp,%%esi,1), %%edi\n\t"                       \
41
                    "leal\t4(%%esp), %%esi\n\t"                               \
42
                    "rep\tmovsl\n\t"                                          \
43
                    "movl\t%c8-4(%%esp), %%esp\n\t"                           \
44
                    : "=a" (__tmp1), "=d" (__tmp2), "=S" (__tmp3),            \
45
                      "=c" (__tmp4)                                           \
46
                    : "0" (handler), "1" (signo), "2" (&ctx),                  \
47
                      "3" (sizeof (struct sigcontext) / 4),                   \
48
                      "n" ((sizeof (struct sigcontext) + 19) & ~15),          \
49
                      "i" (sizeof (struct sigcontext) / 4)                    \
50
                    : "cc", "edi");                                           \
51
} while (0)

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.