1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
.\"
.\" This file and its contents are supplied under the terms of the
.\" Common Development and Distribution License ("CDDL"), version 1.0.
.\" You may only use this file in accordance with the terms of version
.\" 1.0 of the CDDL.
.\"
.\" A full copy of the text of the CDDL should have accompanied this
.\" source. A copy of the CDDL is also available via the Internet at
.\" http://www.illumos.org/license/CDDL.
.\"
.\"
.\" Copyright 2015 Joyent, Inc.
.\"
.Dd May 11, 2016
.Dt PSYSENTRY 3PROC
.Os
.Sh NAME
.Nm Psysentry ,
.Nm Psysexit
.Nd set system call entry and exit actions
.Sh SYNOPSIS
.Lb libproc
.In libproc.h
.Ft int
.Fo Psysentry
.Fa "struct ps_prochandle *P"
.Fa "int which"
.Fa "int stop"
.Fc
.Ft int
.Fo Psysexit
.Fa "struct ps_prochandle *P"
.Fa "int which"
.Fa "int stop"
.Fc
.Sh DESCRIPTION
The
.Fn Psetentry
and
.Fn Psetexit
functions controls what actions the process handle
.Fa P
should take upon executing a system call.
.Pp
The system allows a process to be stopped on both entry and exit of a
system call.
For information on the state of the process when it is stopped due to system
call tracing, see the
.Sy PCSENTRY
and
.Sy PCSEXIT
sections of
.Xr proc 4 .
.Pp
The value of the
.Fa stop
parameter controls whether or not the system call listed in
.Fa which
causes the process to stop.
A value of non-zero indicates the process should stop;
a value of 0 indicates it should not.
.Pp
The value of
.Fa which
indicates which system call the change applies to.
A value of 0 applies to all system calls.
Note, the system does not supply a stable mapping from system call names to
identifiers.
.Pp
These functions only apply to actively running processes.
They do not function on handles that refer to core files, zombie processes,
or ELF objects.
.Sh RETURN VALUES
Upon successful completion, the
.Fn Psetentry
and
.Fn Psetexit
functions return the previous disposition of the system call --
.Sy 0
if it was not set to stop and
.Sy 1
if it was --
and the system call state is updated.
Otherwise,
.Sy -1
is returned,
.Dv errno
is updated with the error that occurred, and the system call state is
not updated.
.Sh ERRORS
The
.Fn Psysentry
and
.Fn Psysexit
functions will fail if:
.Bl -tag -width Er
.It Er EINVAL
The value of
.Fa which
is invalid, e.g. it is less than zero or greater than the largest defined
system call.
.It Er ENOENT
The handle
.Fa P
refers to a process that is a zombie, a core file, or an ELF object.
.El
.Sh INTERFACE STABILITY
.Sy Uncommitted
.Pp
Note, while the
.Fn Psysentry
and
.Fn Psysexit
functions are uncommitted, the mapping of system calls to system call
numbers is
.Sy Not-an-Interface
and may change at any time.
.Sh MT-LEVEL
See
.Sy LOCKING
in
.Xr libproc 3LIB .
.Sh SEE ALSO
.Xr libproc 3LIB ,
.Xr Psysentry 3PROC ,
.Xr Psysexit 3PROC ,
.Xr proc 4 ,
.Xr attributes 5
|