From: "zhangwei(Jovi)" <jovi.zhangwei@huawei.com>
To: Oleg Nesterov <oleg@redhat.com>
Cc: Steven Rostedt <rostedt@goodmis.org>,
Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>,
Srikar Dronamraju <srikar@linux.vnet.ibm.com>,
Frederic Weisbecker <fweisbec@gmail.com>,
Ingo Molnar <mingo@redhat.com>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH v4] tracing/uprobes: Support ftrace_event_file base multibuffer
Date: Tue, 2 Jul 2013 14:51:21 +0800 [thread overview]
Message-ID: <51D27869.9090707@huawei.com> (raw)
In-Reply-To: <20130701202722.GA413@redhat.com>
On 2013/7/2 4:27, Oleg Nesterov wrote:
> On 06/29, zhangwei(Jovi) wrote:
>>
>> [v3->v4]:
>
> I am wondering how much you will hate me if I suggest to make v5 ;)
>
Feel free to do that :)
> But look, imho probe_event_enable() looks a bit more confusing than
> it needs.
>
>> -probe_event_enable(struct trace_uprobe *tu, int flag, filter_func_t filter)
>> +probe_event_enable(struct trace_uprobe *tu, struct ftrace_event_file *file,
>> + filter_func_t filter)
>> {
>> + bool enabled = is_trace_uprobe_enabled(tu);
>> + struct event_file_link *link;
>> int ret = 0;
>
> Unnecessary initialization.
>
>> - if (is_trace_uprobe_enabled(tu))
>> - return -EINTR;
>> + if (file) {
>> + if (tu->flags & TP_FLAG_PROFILE)
>> + return -EINTR;
>> +
>> + link = kmalloc(sizeof(*link), GFP_KERNEL);
>> + if (!link)
>> + return -ENOMEM;
>> +
>> + link->file = file;
>> + list_add_tail_rcu(&link->list, &tu->files);
>> +
>> + tu->flags |= TP_FLAG_TRACE;
>> + } else {
>> + if (tu->flags & TP_FLAG_TRACE)
>> + return -EINTR;
>> +
>> + tu->flags |= TP_FLAG_PROFILE;
>> + }
>>
>> WARN_ON(!uprobe_filter_is_empty(&tu->filter));
>>
>> - tu->flags |= flag;
>> - tu->consumer.filter = filter;
>> - ret = uprobe_register(tu->inode, tu->offset, &tu->consumer);
>> - if (ret)
>> - tu->flags &= ~flag;
>> + /* we cannot call uprobe_register twice for same tu */
>
> The comment is confusing, I'd suggest to simply remove it.
>
> Yes, we can't do uprobe_register() twice as we already discussed.
> But it is not that we "can't", we simply do not need this if uprobe
> was already created.
>
>> + if (!enabled) {
>> + tu->consumer.filter = filter;
>> + ret = uprobe_register(tu->inode, tu->offset, &tu->consumer);
>> + }
>> +
>> + if (ret) {
>> + if (file) {
>> + list_del_rcu(&link->list);
>
> I won't insist, but _rcu is not needed in this case. Again, this looks
> a bit confusing, as if we expect that some rcu reader can ever see this
> entry. But this is not true and we are going to just kfree it without
> synchronize_rcu().
>
Yes, _rcu is not needed in there.
>> + kfree(link);
>> + tu->flags &= ~TP_FLAG_TRACE;
>> + } else
>> + tu->flags &= ~TP_FLAG_PROFILE;
>> + }
>
> This is correct, but again, this is not immediately obvious.
>
> Why it is correct to correct to clear TP_FLAG_TRACE? Because we know
> that "enabled" was false and thus we remove the single list entry.
>
> So, perhaps,
>
> if (enabled)
> return 0;
>
> ret = uprobe_register();
> if (ret) {
> ...;
> }
>
> return ret;
>
> will be a bit more clean.
>
I will change it in v5 patch.
> Oleg.
>
>
> .
>
next prev parent reply other threads:[~2013-07-02 6:54 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-06-29 7:51 [PATCH v4] tracing/uprobes: Support ftrace_event_file base multibuffer zhangwei(Jovi)
2013-07-01 19:22 ` Steven Rostedt
2013-07-01 20:27 ` Oleg Nesterov
2013-07-01 21:10 ` Oleg Nesterov
2013-07-02 7:04 ` zhangwei(Jovi)
2013-07-02 6:51 ` zhangwei(Jovi) [this message]
2013-07-02 11:26 ` Masami Hiramatsu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=51D27869.9090707@huawei.com \
--to=jovi.zhangwei@huawei.com \
--cc=fweisbec@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=masami.hiramatsu.pt@hitachi.com \
--cc=mingo@redhat.com \
--cc=oleg@redhat.com \
--cc=rostedt@goodmis.org \
--cc=srikar@linux.vnet.ibm.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.