1*cf84ac9aSAndroid Build Coastguard Worker /* 2*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2017 The strace developers. 3*cf84ac9aSAndroid Build Coastguard Worker * All rights reserved. 4*cf84ac9aSAndroid Build Coastguard Worker * 5*cf84ac9aSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 6*cf84ac9aSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 7*cf84ac9aSAndroid Build Coastguard Worker * are met: 8*cf84ac9aSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright 9*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 10*cf84ac9aSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright 11*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the 12*cf84ac9aSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution. 13*cf84ac9aSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products 14*cf84ac9aSAndroid Build Coastguard Worker * derived from this software without specific prior written permission. 15*cf84ac9aSAndroid Build Coastguard Worker * 16*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 17*cf84ac9aSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 18*cf84ac9aSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 19*cf84ac9aSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 20*cf84ac9aSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 21*cf84ac9aSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 22*cf84ac9aSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 23*cf84ac9aSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24*cf84ac9aSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 25*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26*cf84ac9aSAndroid Build Coastguard Worker */ 27*cf84ac9aSAndroid Build Coastguard Worker 28*cf84ac9aSAndroid Build Coastguard Worker #ifndef STRACE_TRACE_EVENT_H 29*cf84ac9aSAndroid Build Coastguard Worker #define STRACE_TRACE_EVENT_H 30*cf84ac9aSAndroid Build Coastguard Worker 31*cf84ac9aSAndroid Build Coastguard Worker /* Possible trace event loop states. Returned by next_event() and dispatched by 32*cf84ac9aSAndroid Build Coastguard Worker * dispatch_event(). */ 33*cf84ac9aSAndroid Build Coastguard Worker enum trace_event { 34*cf84ac9aSAndroid Build Coastguard Worker /* Break the main loop. */ 35*cf84ac9aSAndroid Build Coastguard Worker TE_BREAK, 36*cf84ac9aSAndroid Build Coastguard Worker 37*cf84ac9aSAndroid Build Coastguard Worker /* Call next_event() again. */ 38*cf84ac9aSAndroid Build Coastguard Worker TE_NEXT, 39*cf84ac9aSAndroid Build Coastguard Worker 40*cf84ac9aSAndroid Build Coastguard Worker /* Restart the tracee with signal 0 and call next_event() again. */ 41*cf84ac9aSAndroid Build Coastguard Worker TE_RESTART, 42*cf84ac9aSAndroid Build Coastguard Worker 43*cf84ac9aSAndroid Build Coastguard Worker /* 44*cf84ac9aSAndroid Build Coastguard Worker * For all the events below, current_tcp is set to current tracee's 45*cf84ac9aSAndroid Build Coastguard Worker * tcb. All the suggested actions imply that you want to continue 46*cf84ac9aSAndroid Build Coastguard Worker * tracing of the current tracee; alternatively, you can detach it. 47*cf84ac9aSAndroid Build Coastguard Worker */ 48*cf84ac9aSAndroid Build Coastguard Worker 49*cf84ac9aSAndroid Build Coastguard Worker /* 50*cf84ac9aSAndroid Build Coastguard Worker * Syscall entry or exit. 51*cf84ac9aSAndroid Build Coastguard Worker * Restart the tracee with signal 0, or with an injected signal number. 52*cf84ac9aSAndroid Build Coastguard Worker */ 53*cf84ac9aSAndroid Build Coastguard Worker TE_SYSCALL_STOP, 54*cf84ac9aSAndroid Build Coastguard Worker 55*cf84ac9aSAndroid Build Coastguard Worker /* 56*cf84ac9aSAndroid Build Coastguard Worker * Tracee received signal with number WSTOPSIG(*pstatus); signal info 57*cf84ac9aSAndroid Build Coastguard Worker * is written to *si. Restart the tracee (with that signal number 58*cf84ac9aSAndroid Build Coastguard Worker * if you want to deliver it). 59*cf84ac9aSAndroid Build Coastguard Worker */ 60*cf84ac9aSAndroid Build Coastguard Worker TE_SIGNAL_DELIVERY_STOP, 61*cf84ac9aSAndroid Build Coastguard Worker 62*cf84ac9aSAndroid Build Coastguard Worker /* 63*cf84ac9aSAndroid Build Coastguard Worker * Tracee was killed by a signal with number WTERMSIG(*pstatus). 64*cf84ac9aSAndroid Build Coastguard Worker */ 65*cf84ac9aSAndroid Build Coastguard Worker TE_SIGNALLED, 66*cf84ac9aSAndroid Build Coastguard Worker 67*cf84ac9aSAndroid Build Coastguard Worker /* 68*cf84ac9aSAndroid Build Coastguard Worker * Tracee was stopped by a signal with number WSTOPSIG(*pstatus). 69*cf84ac9aSAndroid Build Coastguard Worker * Restart the tracee with that signal number. 70*cf84ac9aSAndroid Build Coastguard Worker */ 71*cf84ac9aSAndroid Build Coastguard Worker TE_GROUP_STOP, 72*cf84ac9aSAndroid Build Coastguard Worker 73*cf84ac9aSAndroid Build Coastguard Worker /* 74*cf84ac9aSAndroid Build Coastguard Worker * Tracee exited with status WEXITSTATUS(*pstatus). 75*cf84ac9aSAndroid Build Coastguard Worker */ 76*cf84ac9aSAndroid Build Coastguard Worker TE_EXITED, 77*cf84ac9aSAndroid Build Coastguard Worker 78*cf84ac9aSAndroid Build Coastguard Worker /* 79*cf84ac9aSAndroid Build Coastguard Worker * Tracee is going to perform execve(). 80*cf84ac9aSAndroid Build Coastguard Worker * Restart the tracee with signal 0. 81*cf84ac9aSAndroid Build Coastguard Worker */ 82*cf84ac9aSAndroid Build Coastguard Worker TE_STOP_BEFORE_EXECVE, 83*cf84ac9aSAndroid Build Coastguard Worker 84*cf84ac9aSAndroid Build Coastguard Worker /* 85*cf84ac9aSAndroid Build Coastguard Worker * Tracee is going to terminate. 86*cf84ac9aSAndroid Build Coastguard Worker * Restart the tracee with signal 0. 87*cf84ac9aSAndroid Build Coastguard Worker */ 88*cf84ac9aSAndroid Build Coastguard Worker TE_STOP_BEFORE_EXIT, 89*cf84ac9aSAndroid Build Coastguard Worker }; 90*cf84ac9aSAndroid Build Coastguard Worker 91*cf84ac9aSAndroid Build Coastguard Worker #endif /* !STRACE_TRACE_EVENT_H */ 92