79 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: LGPL-2.1
 | |
| /*
 | |
|  * trace/beauty/cone.c
 | |
|  *
 | |
|  *  Copyright (C) 2017, Red Hat Inc, Arnaldo Carvalho de Melo <acme@redhat.com>
 | |
|  */
 | |
| 
 | |
| #include "trace/beauty/beauty.h"
 | |
| #include <linux/kernel.h>
 | |
| #include <sys/types.h>
 | |
| #include <uapi/linux/sched.h>
 | |
| 
 | |
| static size_t clone__scnprintf_flags(unsigned long flags, char *bf, size_t size, bool show_prefix)
 | |
| {
 | |
| 	const char *prefix = "CLONE_";
 | |
| 	int printed = 0;
 | |
| 
 | |
| #define	P_FLAG(n) \
 | |
| 	if (flags & CLONE_##n) { \
 | |
| 		printed += scnprintf(bf + printed, size - printed, "%s%s%s", printed ? "|" : "", show_prefix ? prefix : "", #n); \
 | |
| 		flags &= ~CLONE_##n; \
 | |
| 	}
 | |
| 
 | |
| 	P_FLAG(VM);
 | |
| 	P_FLAG(FS);
 | |
| 	P_FLAG(FILES);
 | |
| 	P_FLAG(SIGHAND);
 | |
| 	P_FLAG(PIDFD);
 | |
| 	P_FLAG(PTRACE);
 | |
| 	P_FLAG(VFORK);
 | |
| 	P_FLAG(PARENT);
 | |
| 	P_FLAG(THREAD);
 | |
| 	P_FLAG(NEWNS);
 | |
| 	P_FLAG(SYSVSEM);
 | |
| 	P_FLAG(SETTLS);
 | |
| 	P_FLAG(PARENT_SETTID);
 | |
| 	P_FLAG(CHILD_CLEARTID);
 | |
| 	P_FLAG(DETACHED);
 | |
| 	P_FLAG(UNTRACED);
 | |
| 	P_FLAG(CHILD_SETTID);
 | |
| 	P_FLAG(NEWCGROUP);
 | |
| 	P_FLAG(NEWUTS);
 | |
| 	P_FLAG(NEWIPC);
 | |
| 	P_FLAG(NEWUSER);
 | |
| 	P_FLAG(NEWPID);
 | |
| 	P_FLAG(NEWNET);
 | |
| 	P_FLAG(IO);
 | |
| 	P_FLAG(CLEAR_SIGHAND);
 | |
| 	P_FLAG(INTO_CGROUP);
 | |
| #undef P_FLAG
 | |
| 
 | |
| 	if (flags)
 | |
| 		printed += scnprintf(bf + printed, size - printed, "%s%#x", printed ? "|" : "", flags);
 | |
| 
 | |
| 	return printed;
 | |
| }
 | |
| 
 | |
| size_t syscall_arg__scnprintf_clone_flags(char *bf, size_t size, struct syscall_arg *arg)
 | |
| {
 | |
| 	unsigned long flags = arg->val;
 | |
| 	enum syscall_clone_args {
 | |
| 		SCC_FLAGS	  = (1 << 0),
 | |
| 		SCC_CHILD_STACK	  = (1 << 1),
 | |
| 		SCC_PARENT_TIDPTR = (1 << 2),
 | |
| 		SCC_CHILD_TIDPTR  = (1 << 3),
 | |
| 		SCC_TLS		  = (1 << 4),
 | |
| 	};
 | |
| 	if (!(flags & CLONE_PARENT_SETTID))
 | |
| 		arg->mask |= SCC_PARENT_TIDPTR;
 | |
| 
 | |
| 	if (!(flags & (CLONE_CHILD_SETTID | CLONE_CHILD_CLEARTID)))
 | |
| 		arg->mask |= SCC_CHILD_TIDPTR;
 | |
| 
 | |
| 	if (!(flags & CLONE_SETTLS))
 | |
| 		arg->mask |= SCC_TLS;
 | |
| 
 | |
| 	return clone__scnprintf_flags(flags, bf, size, arg->show_string_prefix);
 | |
| }
 |