Update copyright to LGPL on all files
[dyninst.git] / dyninstAPI_RT / src / RTsigill-x86.S
1 /*
2  * Copyright (c) 1996-2009 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as "Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * By your use of Paradyn, you understand and agree that we (or any
12  * other person or entity with proprietary rights in Paradyn) are
13  * under no obligation to provide either maintenance services,
14  * update services, notices of latent defects, or correction of
15  * defects for Paradyn.
16  * 
17  * This library is free software; you can redistribute it and/or
18  * modify it under the terms of the GNU Lesser General Public
19  * License as published by the Free Software Foundation; either
20  * version 2.1 of the License, or (at your option) any later version.
21  * 
22  * This library is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25  * Lesser General Public License for more details.
26  * 
27  * You should have received a copy of the GNU Lesser General Public
28  * License along with this library; if not, write to the Free Software
29  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
30  */
31
32 /*
33    DYNINSTsigill:
34         
35    DYNINSTsigill executes an illegal instruction, causing SIGILL to be
36    sent to the calling process.  It is only needed for
37    detach-on-the-fly, where detached mutatees stop to wait for the
38    mutator or paradynd to reattach by sending themselves SIGILL.
39
40    A detached mutatee that stops itself with SIGSTOP will not be
41    noticed by the mutator or paradynd.  It must send SIGILL to be
42    noticed.
43     
44    There are two ways to send SIGILL to yourself: call kill() or
45    execute an illegal instruction.
46
47    We chose to use illegal instructions. The SIGILL handler has a
48    simpler implementation if SIGILL is caused by an illegal
49    instruction.  We do not use kill() to send SIGILL.
50
51    The test suite calls this function through the dynamic loader to
52    avoid duplication of code in the test suite and additional makefile
53    complexity.
54     
55    3000 bytes of source code for 3 bytes of object code.
56 */
57
58     .text
59     .globl DYNINSTsigill
60
61 DYNINSTsigill:
62     ud2
63     ret