1*4882a593Smuzhiyun // SPDX-License-Identifier: LGPL-2.1
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun * trace/beauty/arch_prctl.c
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * Copyright (C) 2018, Red Hat Inc, Arnaldo Carvalho de Melo <acme@redhat.com>
6*4882a593Smuzhiyun */
7*4882a593Smuzhiyun
8*4882a593Smuzhiyun #include "trace/beauty/beauty.h"
9*4882a593Smuzhiyun #include <linux/kernel.h>
10*4882a593Smuzhiyun
11*4882a593Smuzhiyun #include "trace/beauty/generated/x86_arch_prctl_code_array.c"
12*4882a593Smuzhiyun
13*4882a593Smuzhiyun static DEFINE_STRARRAY_OFFSET(x86_arch_prctl_codes_1, "ARCH_", x86_arch_prctl_codes_1_offset);
14*4882a593Smuzhiyun static DEFINE_STRARRAY_OFFSET(x86_arch_prctl_codes_2, "ARCH_", x86_arch_prctl_codes_2_offset);
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun static struct strarray *x86_arch_prctl_codes[] = {
17*4882a593Smuzhiyun &strarray__x86_arch_prctl_codes_1,
18*4882a593Smuzhiyun &strarray__x86_arch_prctl_codes_2,
19*4882a593Smuzhiyun };
20*4882a593Smuzhiyun
21*4882a593Smuzhiyun static DEFINE_STRARRAYS(x86_arch_prctl_codes);
22*4882a593Smuzhiyun
x86_arch_prctl__scnprintf_code(int option,char * bf,size_t size,bool show_prefix)23*4882a593Smuzhiyun static size_t x86_arch_prctl__scnprintf_code(int option, char *bf, size_t size, bool show_prefix)
24*4882a593Smuzhiyun {
25*4882a593Smuzhiyun return strarrays__scnprintf(&strarrays__x86_arch_prctl_codes, bf, size, "%#x", show_prefix, option);
26*4882a593Smuzhiyun }
27*4882a593Smuzhiyun
syscall_arg__scnprintf_x86_arch_prctl_code(char * bf,size_t size,struct syscall_arg * arg)28*4882a593Smuzhiyun size_t syscall_arg__scnprintf_x86_arch_prctl_code(char *bf, size_t size, struct syscall_arg *arg)
29*4882a593Smuzhiyun {
30*4882a593Smuzhiyun unsigned long code = arg->val;
31*4882a593Smuzhiyun
32*4882a593Smuzhiyun return x86_arch_prctl__scnprintf_code(code, bf, size, arg->show_string_prefix);
33*4882a593Smuzhiyun }
34