From mboxrd@z Thu Jan 1 00:00:00 1970 From: mhiramat@kernel.org (Masami Hiramatsu) Date: Thu, 22 Mar 2018 18:23:47 +0800 Subject: [PATCH v6 21/21] perf-probe: Add array argument support In-Reply-To: <8c02c538-4934-59c2-7795-9058ce57e625@linux.vnet.ibm.com> References: <152129024033.31874.15800253385376959274.stgit@devbox> <152129118998.31874.16273532808298489908.stgit@devbox> <8c02c538-4934-59c2-7795-9058ce57e625@linux.vnet.ibm.com> Message-ID: <20180322182347.ca1aab9b77ab4c351100646b@kernel.org> Content-Type: text/plain; charset="UTF-8" Message-ID: <20180322102347.Mv2GWMnoNl6VkZdzytaHtTR5cbTLYnjOKdeu3Z6JBVg@z> On Mon, 19 Mar 2018 13:29:59 +0530 Ravi Bangoria wrote: > Hi Masami, > > On 03/17/2018 06:23 PM, Masami Hiramatsu wrote: > > Since kprobes events support an array argument, perf-probe > > can also support dumping array now. > > The syntax are > > > > [] > > or > > [] > > > > where the is ... e.g. array[0..5]. > > This can also be available with string type. In this > > case, the string array should be "char *array[]" or > > "char **array_ptr". > > > > Note that this feature is only available on the kernel which > > supports array type. > > User can still do, > > # perf probe -x ~/hello main:3 'a=a:x32[3]' > > which will successfully be installed in uprobe_events. But for a > perf tool, x32[3] is not a valid type. And it seems perf tool don't > validate the 'type' field: > >     static int parse_perf_probe_arg(char *str, struct perf_probe_arg *arg) >     { >         .... >         tmp = strchr(str, ':'); >         if (tmp) {      /* Type setting */ >                 *tmp = '\0'; >                 arg->type = strdup(tmp + 1); >                 if (arg->type == NULL) >                         return -ENOMEM; >                 pr_debug("type:%s ", arg->type); >         } > > Is it okay to allow user to specify array size with type field? Fro this patch, yes. The availability of type is checked only when it is automatically generated. IMO, it should be done in another patch, something like "Validate user specified type casting" patch. Would you need it? Thank you, -- Masami Hiramatsu -- To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in the body of a message to majordomo at vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html