xref: /aosp_15_r20/external/strace/ipc_msg.c (revision cf84ac9a129d8ea9952db616b4e9b904c4bdde56)
1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 1993 Ulrich Pegelow <[email protected]>
3*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 1993 Branko Lankester <[email protected]>
4*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 1993, 1994, 1995, 1996 Rick Sladkey <[email protected]>
5*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 1996-1999 Wichert Akkerman <[email protected]>
6*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2003-2006 Roland McGrath <[email protected]>
7*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2006-2015 Dmitry V. Levin <[email protected]>
8*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2015-2018 The strace developers.
9*cf84ac9aSAndroid Build Coastguard Worker  * All rights reserved.
10*cf84ac9aSAndroid Build Coastguard Worker  *
11*cf84ac9aSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
12*cf84ac9aSAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
13*cf84ac9aSAndroid Build Coastguard Worker  * are met:
14*cf84ac9aSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright
15*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
16*cf84ac9aSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
17*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in the
18*cf84ac9aSAndroid Build Coastguard Worker  *    documentation and/or other materials provided with the distribution.
19*cf84ac9aSAndroid Build Coastguard Worker  * 3. The name of the author may not be used to endorse or promote products
20*cf84ac9aSAndroid Build Coastguard Worker  *    derived from this software without specific prior written permission.
21*cf84ac9aSAndroid Build Coastguard Worker  *
22*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23*cf84ac9aSAndroid Build Coastguard Worker  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24*cf84ac9aSAndroid Build Coastguard Worker  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25*cf84ac9aSAndroid Build Coastguard Worker  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
26*cf84ac9aSAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27*cf84ac9aSAndroid Build Coastguard Worker  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28*cf84ac9aSAndroid Build Coastguard Worker  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29*cf84ac9aSAndroid Build Coastguard Worker  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30*cf84ac9aSAndroid Build Coastguard Worker  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
31*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32*cf84ac9aSAndroid Build Coastguard Worker  */
33*cf84ac9aSAndroid Build Coastguard Worker 
34*cf84ac9aSAndroid Build Coastguard Worker #include "defs.h"
35*cf84ac9aSAndroid Build Coastguard Worker #include "ipc_defs.h"
36*cf84ac9aSAndroid Build Coastguard Worker 
37*cf84ac9aSAndroid Build Coastguard Worker #ifdef HAVE_SYS_MSG_H
38*cf84ac9aSAndroid Build Coastguard Worker # include <sys/msg.h>
39*cf84ac9aSAndroid Build Coastguard Worker #elif defined HAVE_LINUX_MSG_H
40*cf84ac9aSAndroid Build Coastguard Worker # include <linux/msg.h>
41*cf84ac9aSAndroid Build Coastguard Worker #endif
42*cf84ac9aSAndroid Build Coastguard Worker 
43*cf84ac9aSAndroid Build Coastguard Worker #include "xlat/ipc_msg_flags.h"
44*cf84ac9aSAndroid Build Coastguard Worker #include "xlat/ipc_private.h"
45*cf84ac9aSAndroid Build Coastguard Worker #include "xlat/resource_flags.h"
46*cf84ac9aSAndroid Build Coastguard Worker 
SYS_FUNC(msgget)47*cf84ac9aSAndroid Build Coastguard Worker SYS_FUNC(msgget)
48*cf84ac9aSAndroid Build Coastguard Worker {
49*cf84ac9aSAndroid Build Coastguard Worker 	printxval(ipc_private, (unsigned int) tcp->u_arg[0], NULL);
50*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
51*cf84ac9aSAndroid Build Coastguard Worker 	if (printflags(resource_flags, tcp->u_arg[1] & ~0777, NULL) != 0)
52*cf84ac9aSAndroid Build Coastguard Worker 		tprints("|");
53*cf84ac9aSAndroid Build Coastguard Worker 	print_numeric_umode_t(tcp->u_arg[1] & 0777);
54*cf84ac9aSAndroid Build Coastguard Worker 	return RVAL_DECODED;
55*cf84ac9aSAndroid Build Coastguard Worker }
56*cf84ac9aSAndroid Build Coastguard Worker 
57*cf84ac9aSAndroid Build Coastguard Worker static void
tprint_msgsnd(struct tcb * const tcp,const kernel_ulong_t addr,const kernel_ulong_t count,const unsigned int flags)58*cf84ac9aSAndroid Build Coastguard Worker tprint_msgsnd(struct tcb *const tcp, const kernel_ulong_t addr,
59*cf84ac9aSAndroid Build Coastguard Worker 	      const kernel_ulong_t count, const unsigned int flags)
60*cf84ac9aSAndroid Build Coastguard Worker {
61*cf84ac9aSAndroid Build Coastguard Worker 	tprint_msgbuf(tcp, addr, count);
62*cf84ac9aSAndroid Build Coastguard Worker 	printflags(ipc_msg_flags, flags, "MSG_???");
63*cf84ac9aSAndroid Build Coastguard Worker }
64*cf84ac9aSAndroid Build Coastguard Worker 
SYS_FUNC(msgsnd)65*cf84ac9aSAndroid Build Coastguard Worker SYS_FUNC(msgsnd)
66*cf84ac9aSAndroid Build Coastguard Worker {
67*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("%d, ", (int) tcp->u_arg[0]);
68*cf84ac9aSAndroid Build Coastguard Worker 	if (indirect_ipccall(tcp)) {
69*cf84ac9aSAndroid Build Coastguard Worker 		tprint_msgsnd(tcp, tcp->u_arg[3], tcp->u_arg[1],
70*cf84ac9aSAndroid Build Coastguard Worker 			      tcp->u_arg[2]);
71*cf84ac9aSAndroid Build Coastguard Worker 	} else {
72*cf84ac9aSAndroid Build Coastguard Worker 		tprint_msgsnd(tcp, tcp->u_arg[1], tcp->u_arg[2],
73*cf84ac9aSAndroid Build Coastguard Worker 			      tcp->u_arg[3]);
74*cf84ac9aSAndroid Build Coastguard Worker 	}
75*cf84ac9aSAndroid Build Coastguard Worker 	return RVAL_DECODED;
76*cf84ac9aSAndroid Build Coastguard Worker }
77*cf84ac9aSAndroid Build Coastguard Worker 
78*cf84ac9aSAndroid Build Coastguard Worker static void
tprint_msgrcv(struct tcb * const tcp,const kernel_ulong_t addr,const kernel_ulong_t count,const kernel_ulong_t msgtyp)79*cf84ac9aSAndroid Build Coastguard Worker tprint_msgrcv(struct tcb *const tcp, const kernel_ulong_t addr,
80*cf84ac9aSAndroid Build Coastguard Worker 	      const kernel_ulong_t count, const kernel_ulong_t msgtyp)
81*cf84ac9aSAndroid Build Coastguard Worker {
82*cf84ac9aSAndroid Build Coastguard Worker 	tprint_msgbuf(tcp, addr, count);
83*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("%" PRI_kld ", ", msgtyp);
84*cf84ac9aSAndroid Build Coastguard Worker }
85*cf84ac9aSAndroid Build Coastguard Worker 
86*cf84ac9aSAndroid Build Coastguard Worker static int
fetch_msgrcv_args(struct tcb * const tcp,const kernel_ulong_t addr,kernel_ulong_t * const pair)87*cf84ac9aSAndroid Build Coastguard Worker fetch_msgrcv_args(struct tcb *const tcp, const kernel_ulong_t addr,
88*cf84ac9aSAndroid Build Coastguard Worker 		  kernel_ulong_t *const pair)
89*cf84ac9aSAndroid Build Coastguard Worker {
90*cf84ac9aSAndroid Build Coastguard Worker 	if (current_wordsize == sizeof(*pair)) {
91*cf84ac9aSAndroid Build Coastguard Worker 		if (umoven_or_printaddr(tcp, addr, 2 * sizeof(*pair), pair))
92*cf84ac9aSAndroid Build Coastguard Worker 			return -1;
93*cf84ac9aSAndroid Build Coastguard Worker 	} else {
94*cf84ac9aSAndroid Build Coastguard Worker 		unsigned int tmp[2];
95*cf84ac9aSAndroid Build Coastguard Worker 
96*cf84ac9aSAndroid Build Coastguard Worker 		if (umove_or_printaddr(tcp, addr, &tmp))
97*cf84ac9aSAndroid Build Coastguard Worker 			return -1;
98*cf84ac9aSAndroid Build Coastguard Worker 		pair[0] = tmp[0];
99*cf84ac9aSAndroid Build Coastguard Worker 		pair[1] = (int) tmp[1];
100*cf84ac9aSAndroid Build Coastguard Worker 	}
101*cf84ac9aSAndroid Build Coastguard Worker 	return 0;
102*cf84ac9aSAndroid Build Coastguard Worker }
103*cf84ac9aSAndroid Build Coastguard Worker 
SYS_FUNC(msgrcv)104*cf84ac9aSAndroid Build Coastguard Worker SYS_FUNC(msgrcv)
105*cf84ac9aSAndroid Build Coastguard Worker {
106*cf84ac9aSAndroid Build Coastguard Worker 	if (entering(tcp)) {
107*cf84ac9aSAndroid Build Coastguard Worker 		tprintf("%d, ", (int) tcp->u_arg[0]);
108*cf84ac9aSAndroid Build Coastguard Worker 	} else {
109*cf84ac9aSAndroid Build Coastguard Worker 		if (indirect_ipccall(tcp)) {
110*cf84ac9aSAndroid Build Coastguard Worker 			const bool direct =
111*cf84ac9aSAndroid Build Coastguard Worker #ifdef SPARC64
112*cf84ac9aSAndroid Build Coastguard Worker 				current_wordsize == 8 ||
113*cf84ac9aSAndroid Build Coastguard Worker #endif
114*cf84ac9aSAndroid Build Coastguard Worker 				get_tcb_priv_ulong(tcp) != 0;
115*cf84ac9aSAndroid Build Coastguard Worker 			if (direct) {
116*cf84ac9aSAndroid Build Coastguard Worker 				tprint_msgrcv(tcp, tcp->u_arg[3],
117*cf84ac9aSAndroid Build Coastguard Worker 					      tcp->u_arg[1], tcp->u_arg[4]);
118*cf84ac9aSAndroid Build Coastguard Worker 			} else {
119*cf84ac9aSAndroid Build Coastguard Worker 				kernel_ulong_t pair[2];
120*cf84ac9aSAndroid Build Coastguard Worker 
121*cf84ac9aSAndroid Build Coastguard Worker 				if (fetch_msgrcv_args(tcp, tcp->u_arg[3], pair))
122*cf84ac9aSAndroid Build Coastguard Worker 					tprintf(", %" PRI_klu ", ", tcp->u_arg[1]);
123*cf84ac9aSAndroid Build Coastguard Worker 				else
124*cf84ac9aSAndroid Build Coastguard Worker 					tprint_msgrcv(tcp, pair[0],
125*cf84ac9aSAndroid Build Coastguard Worker 						      tcp->u_arg[1], pair[1]);
126*cf84ac9aSAndroid Build Coastguard Worker 			}
127*cf84ac9aSAndroid Build Coastguard Worker 			printflags(ipc_msg_flags, tcp->u_arg[2], "MSG_???");
128*cf84ac9aSAndroid Build Coastguard Worker 		} else {
129*cf84ac9aSAndroid Build Coastguard Worker 			tprint_msgrcv(tcp, tcp->u_arg[1],
130*cf84ac9aSAndroid Build Coastguard Worker 				tcp->u_arg[2], tcp->u_arg[3]);
131*cf84ac9aSAndroid Build Coastguard Worker 			printflags(ipc_msg_flags, tcp->u_arg[4], "MSG_???");
132*cf84ac9aSAndroid Build Coastguard Worker 		}
133*cf84ac9aSAndroid Build Coastguard Worker 	}
134*cf84ac9aSAndroid Build Coastguard Worker 	return 0;
135*cf84ac9aSAndroid Build Coastguard Worker }
136