From: Vladislav Bolkhovitin <vst@vlnb.net>
To: Steven Rostedt <srostedt@redhat.com>
Cc: Sam Ravnborg <sam@ravnborg.org>,
linux-scsi@vger.kernel.org,
James Bottomley <James.Bottomley@HansenPartnership.com>,
Andrew Morton <akpm@linux-foundation.org>,
FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>,
Mike Christie <michaelc@cs.wisc.edu>,
Jeff Garzik <jeff@garzik.org>,
Boaz Harrosh <bharrosh@panasas.com>,
Linus Torvalds <torvalds@linux-foundation.org>,
linux-kernel@vger.kernel.org, scst-devel@lists.sourceforge.net,
Bart Van Assche <bart.vanassche@gmail.com>,
"Nicholas A. Bellinger" <nab@linux-iscsi.org>,
fweisbec <fweisbec@gmail.com>, Ingo Molnar <mingo@elte.hu>
Subject: Re: [PATCH][RFC 2/23]: SCST core
Date: Sat, 13 Dec 2008 17:46:04 +0300 [thread overview]
Message-ID: <4943CAAB.4050008@vlnb.net> (raw)
In-Reply-To: <1229118607.24995.18.camel@localhost.localdomain>
Steven Rostedt wrote:
> (Added Ingo and Frederic)
>
> On Fri, 2008-12-12 at 22:24 +0300, Vladislav Bolkhovitin wrote:
>> Sam Ravnborg wrote:
>>>>>> drivers/scst/scst_lib.c | 3689
>>>>>> +++++++++++++++++++++++++++++++++++++
>>>>>> drivers/scst/scst_main.c | 1919 +++++++++++++++++++
>>>>>> drivers/scst/scst_module.c | 69
>>>>>> drivers/scst/scst_priv.h | 513 +++++
>>>>>> drivers/scst/scst_targ.c | 5458
>>>>>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>>>> 8 files changed, 12435 insertions(+)
>>>>> There was a lot af TRACE_ENTRY() / TRACE_EXIT() noise.
>>>>> We should have proper tools for that by now (I hope).
>>>> Sorry, I don't see such tools with, for instance, a possibility to be
>>>> compiled out in non-debug builds.
>>>>
>>>> From one side, I can agree, those TRACE_ENTRY()/TRACE_EXIT() statements
>>>> *may* look like a noise (I personally don't notice them), but, from
>>>> other side, in past times they have proved how usable they are. If an
>>>> SCST user has a problem, I simply ask him to make a debug build, then
>>>> enable entry_exit and some other logging levels, then reproduce the
>>>> problem and send me the logs. Then in most cases I can see what's wrong
>>>> and provide a fix without additional actions and questions.
>>> I had ftrace in mind but it has not hit mainline yet.
>
> I'm assuming you are talking about previous kernels. ftrace is in
> 2.6.27, and dynamic ftrace is back in 2.6.28-rcX
>
>>> But will do before this patchset does.
>> Unfortunately, ftrace at the moment can't fully replace
>> TRACE_ENTRY()/TRACE_EXIT() statements, because it lacks:
>>
>> 1. Doing trace in only some modules or source files. Noise from tracing
>> of the whole kernel is not needed if we investigate problem in only one
>> module (SCST in this case)
>
> With dynamic ftrace you can pick and choose the what functions you want
> to trace. 2.6.28 will not have the exit tracing, but 2.6.29 will (see
> linux-tip for latest ftrace)
>
> Here, for current 2.6.28, I can do:
>
> # awk '$2=="t" && $4=="[e1000]" { print $3; }' \
> /proc/kallsyms > /debug/tracing/set_ftrace_filter
>
> and now only the e1000 functions will be traced.
>
> # echo function > /debug/tracing/current_tracer
>
> [root@bxrhel51 ~]# cat /debug/tracing/trace |head
> # tracer: function
> #
> # TASK-PID CPU# TIMESTAMP FUNCTION
> # | | | | |
> sshd-3411 [000] 567.748887: e1000_xmit_frame <-dev_hard_start_xmit
> sshd-3411 [000] 567.748890: e1000_maybe_stop_tx <-e1000_xmit_frame
> sshd-3411 [000] 567.748893: e1000_maybe_stop_tx <-e1000_xmit_frame
> <idle>-0 [000] 567.748943: e1000_intr <-handle_IRQ_event
> <idle>-0 [000] 567.748948: e1000_clean <-net_rx_action
> <idle>-0 [000] 567.748949: e1000_unmap_and_free_tx_resource <-e1000_clean
>
>
> I can pick any function I want to trace. The list of available functions
> to trace is in /debug/tracing/available_filter_functions.
>
>
>> .
>>
>> 2. Ability to inject own messages in the output stream. It's needed to
>> have synchronized stream of output messages about both functions tracing
>> and what those functions doing. For instance:
>>
>> entry in func1()
>> adding cmd C to list L
>> exit from func1()
>
> Is this from within the driver?
>
> By adding this simply patch:
>
> diff --git a/drivers/net/e1000/e1000_main.c b/drivers/net/e1000/e1000_main.c
> index 872799b..b198dac 100644
> --- a/drivers/net/e1000/e1000_main.c
> +++ b/drivers/net/e1000/e1000_main.c
> @@ -29,6 +29,8 @@
> #include "e1000.h"
> #include <net/ip6_checksum.h>
>
> +#include <linux/ftrace.h>
> +
> char e1000_driver_name[] = "e1000";
> static char e1000_driver_string[] = "Intel(R) PRO/1000 Network Driver";
> #define DRV_VERSION "7.3.20-k3-NAPI"
> @@ -3810,6 +3812,8 @@ static int e1000_clean(struct napi_struct *napi, int budget)
> if (tx_cleaned)
> work_done = budget;
>
> + ftrace_printk("adapter is %p work_done: %d\n", adapter, work_done);
> +
> /* If budget not fully consumed, exit the polling mode */
> if (work_done < budget) {
> if (likely(adapter->itr_setting & 3))
>
>
> I could do:
>
> # awk '$2=="t" && $4=="[e1000]" { print $3; }' \
> /proc/kallsyms > /debug/tracing/set_ftrace_filter
> # echo 0 > /debug/tracing/tracing_enabled
> # echo ftrace_printk > /debug/tracing/iter_ctrl
> # echo function > /debug/tracing/current_tracer
> # echo 1 > /debug/tracing/tracing_enabled
> [wait]
> # echo 0 > /debug/tracing/tracing_enabled
> # cat /debug/tracing/trace | head
> # tracer: function
> #
> # TASK-PID CPU# TIMESTAMP FUNCTION
> # | | | | |
> bash-3393 [000] 469.809904: e1000_clean_rx_irq <-e1000_clean
> bash-3393 [000] 469.809939: e1000_alloc_rx_buffers <-e1000_clean_rx_irq
> bash-3393 [000] 469.809940: e1000_check_64k_bound <-e1000_alloc_rx_buffers
> bash-3393 [000] 469.809945: e1000_clean: adapter is ffff88003d13a900 work_done: 64
> bash-3393 [000] 469.809946: e1000_clean <-net_rx_action
>
>
>
> Note in 2.6.29 (and current tip): s/iter_ctrl/tracing_options/
>
>
>
>> Otherwise there would be 2 traces:
>>
>> entry in func1()
>> exit from func1()
>>
>> and
>>
>> adding cmd C to list L
>>
>> which almost impossible to merge to analyze.
>
> Perhaps you need to do it from userspace?
>
> # echo 1 > /debug/tracing/tracing_enabled ; \
> echo hi > /debug/tracing/trace_marker ; \
> sleep 1 ; \
> echo bye > /debug/tracing/trace_marker ; \
> echo 0 > /debug/tracing/tracing_enabled
> # cat /debug/tracing/trace
> # tracer: function
> #
> # TASK-PID CPU# TIMESTAMP FUNCTION
> # | | | | |
> bash-3393 [003] 1068.636510: 0: hi
> <idle>-0 [002] 1069.039891: e1000_intr <-handle_IRQ_event
> <idle>-0 [002] 1069.039898: e1000_clean <-net_rx_action
> <idle>-0 [002] 1069.039901: e1000_clean_rx_irq <-e1000_clean
> <idle>-0 [002] 1069.039950: e1000_alloc_rx_buffers <-e1000_clean_rx_irq
> <idle>-0 [002] 1069.039951: e1000_check_64k_bound <-e1000_alloc_rx_buffers
> <idle>-0 [002] 1069.039952: e1000_update_itr <-e1000_clean
> [...]
> <idle>-0 [002] 1069.487184: e1000_intr <-handle_IRQ_event
> <idle>-0 [002] 1069.487190: e1000_clean <-net_rx_action
> <idle>-0 [002] 1069.487191: e1000_clean_rx_irq <-e1000_clean
> <idle>-0 [002] 1069.487192: e1000_update_itr <-e1000_clean
> <idle>-0 [002] 1069.487192: e1000_update_itr <-e1000_clean
> bash-3393 [003] 1069.638193: 0: bye
>
All the above functionality is almost what we need. The only thing left,
which I forgot to mention, is possibility to log also functions return
value on exit. This is what TRACE_EXIT_RES() in SCST does. Is it
possible to add those?
Also (maybe I simply miss something) looks like ftrace doesn't trace
exit from functions, only entrance to them. Is it true? Is it possibly
to log exit from functions as well?
And one more question. Is it possible to redirect ftrace tracing to
serial console or any other console (netconsole?)? It can be helpful to
investigate hard lockups in IRQ or with IRQs disabled.
Thanks!
Vlad
next prev parent reply other threads:[~2008-12-13 14:46 UTC|newest]
Thread overview: 106+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-12-10 18:26 [PATCH][RFC 0/23] New SCSI target framework (SCST) and 4 target drivers Vladislav Bolkhovitin
2008-12-10 18:28 ` [PATCH][RFC 1/23]: SCST public headers Vladislav Bolkhovitin
2008-12-10 18:30 ` [PATCH][RFC 2/23]: SCST core Vladislav Bolkhovitin
2008-12-10 19:12 ` Sam Ravnborg
2008-12-11 17:28 ` Vladislav Bolkhovitin
2008-12-11 21:09 ` Sam Ravnborg
2008-12-12 19:24 ` Vladislav Bolkhovitin
2008-12-12 21:50 ` Steven Rostedt
[not found] ` <20081212230523.GB4775@ghostprotocols.net>
2008-12-13 1:25 ` Frédéric Weisbecker
2008-12-13 1:27 ` Frédéric Weisbecker
2008-12-13 14:46 ` Vladislav Bolkhovitin [this message]
2008-12-14 0:35 ` Frédéric Weisbecker
2008-12-16 21:49 ` Ingo Molnar
2008-12-16 22:13 ` Frédéric Weisbecker
2008-12-16 22:22 ` Ingo Molnar
2008-12-16 23:46 ` Frédéric Weisbecker
2008-12-18 11:45 ` Vladislav Bolkhovitin
2008-12-20 13:06 ` Frédéric Weisbecker
2008-12-23 19:11 ` Vladislav Bolkhovitin
2008-12-27 11:20 ` Ingo Molnar
2008-12-30 17:13 ` Vladislav Bolkhovitin
2008-12-30 21:03 ` Frederic Weisbecker
2008-12-30 21:35 ` Steven Rostedt
2008-12-10 18:34 ` [PATCH][RFC 3/23]: SCST core docs Vladislav Bolkhovitin
2008-12-10 18:36 ` [PATCH][RFC 4/23]: SCST debug support Vladislav Bolkhovitin
2008-12-10 18:37 ` [PATCH][RFC 5/23]: SCST /proc interface Vladislav Bolkhovitin
2008-12-11 20:23 ` Nicholas A. Bellinger
2008-12-12 19:23 ` Vladislav Bolkhovitin
2008-12-10 18:39 ` [PATCH][RFC 6/23]: SCST SGV cache Vladislav Bolkhovitin
2008-12-10 18:40 ` [PATCH][RFC 7/23]: SCST integration into the kernel Vladislav Bolkhovitin
2008-12-10 18:42 ` [PATCH][RFC 8/23]: SCST pass-through backend handlers Vladislav Bolkhovitin
2008-12-10 18:43 ` [PATCH][RFC 9/23]: SCST virtual disk backend handler Vladislav Bolkhovitin
2008-12-10 18:44 ` [PATCH][RFC 10/23]: SCST user space " Vladislav Bolkhovitin
2008-12-10 18:46 ` [PATCH][RFC 11/23]: Makefile for SCST backend handlers Vladislav Bolkhovitin
2008-12-10 18:47 ` [PATCH][RFC 12/23]: Patch to add necessary support for SCST pass-through Vladislav Bolkhovitin
2008-12-10 18:49 ` [PATCH][RFC 13/23]: Export of alloc_io_context() function Vladislav Bolkhovitin
2008-12-11 13:34 ` Jens Axboe
2008-12-11 18:17 ` Vladislav Bolkhovitin
2008-12-11 18:41 ` Jens Axboe
2008-12-11 19:00 ` Vladislav Bolkhovitin
2008-12-11 19:06 ` Jens Axboe
2008-12-12 19:16 ` Vladislav Bolkhovitin
2008-12-10 18:50 ` [PATCH][RFC 14/23]: Necessary functionality in qla2xxx driver to support target mode Vladislav Bolkhovitin
2008-12-10 18:51 ` [PATCH][RFC 15/23]: QLogic target driver Vladislav Bolkhovitin
2008-12-10 18:54 ` [PATCH][RFC 16/23]: Documentation for " Vladislav Bolkhovitin
2008-12-10 18:55 ` [PATCH][RFC 17/23]: InfiniBand SRP " Vladislav Bolkhovitin
2008-12-10 18:57 ` [PATCH][RFC 18/23]: Documentation for " Vladislav Bolkhovitin
2008-12-10 18:58 ` [PATCH][RFC 19/23]: scst_local " Vladislav Bolkhovitin
2008-12-10 19:00 ` [PATCH][RFC 20/23]: Documentation for scst_local driver Vladislav Bolkhovitin
2008-12-10 19:01 ` [PATCH][RFC 21/23]: iSCSI target driver Vladislav Bolkhovitin
2008-12-11 22:55 ` Nicholas A. Bellinger
2008-12-11 22:59 ` Nicholas A. Bellinger
2008-12-12 19:26 ` Vladislav Bolkhovitin
2008-12-13 10:03 ` Nicholas A. Bellinger
2008-12-13 10:11 ` Bart Van Assche
2008-12-13 10:16 ` Nicholas A. Bellinger
2008-12-13 10:27 ` Bart Van Assche
2008-12-13 15:01 ` Vladislav Bolkhovitin
2008-12-13 14:57 ` Vladislav Bolkhovitin
2008-12-10 19:02 ` [PATCH][RFC 22/23]: Documentation for iSCSI-SCST Vladislav Bolkhovitin
2008-12-10 19:04 ` [PATCH][RFC 23/23]: Support for zero-copy TCP transmit of user space data Vladislav Bolkhovitin
2008-12-10 21:45 ` Evgeniy Polyakov
2008-12-11 18:16 ` Vladislav Bolkhovitin
2008-12-11 19:12 ` James Bottomley
2008-12-12 19:25 ` Vladislav Bolkhovitin
2008-12-12 19:37 ` James Bottomley
2008-12-15 17:58 ` Vladislav Bolkhovitin
2008-12-15 23:18 ` Christoph Hellwig
2008-12-16 18:57 ` Vladislav Bolkhovitin
2008-12-18 18:35 ` [RFC]: " Vladislav Bolkhovitin
2008-12-18 18:43 ` David M. Lloyd
2008-12-19 17:37 ` Vladislav Bolkhovitin
2008-12-19 19:07 ` Jens Axboe
2008-12-19 19:17 ` Vladislav Bolkhovitin
2008-12-19 19:27 ` Jens Axboe
2008-12-19 21:58 ` Evgeniy Polyakov
2008-12-23 19:11 ` Vladislav Bolkhovitin
2008-12-19 11:27 ` Andi Kleen
2008-12-19 17:38 ` Vladislav Bolkhovitin
2008-12-19 18:00 ` Andi Kleen
2008-12-19 17:57 ` Vladislav Bolkhovitin
2008-12-16 16:00 ` [PATCH][RFC 23/23]: " Bart Van Assche
2008-12-16 17:41 ` Evgeniy Polyakov
2008-12-19 20:21 ` Jeremy Fitzhardinge
2008-12-19 22:04 ` Evgeniy Polyakov
2008-12-19 22:21 ` Jeremy Fitzhardinge
2008-12-19 22:33 ` Evgeniy Polyakov
2008-12-20 1:56 ` Jeremy Fitzhardinge
2008-12-20 2:02 ` Herbert Xu
2008-12-20 6:14 ` Jeremy Fitzhardinge
2008-12-20 6:51 ` Herbert Xu
2008-12-20 7:43 ` Jeremy Fitzhardinge
2008-12-20 8:10 ` Herbert Xu
2008-12-20 10:32 ` Evgeniy Polyakov
2008-12-20 19:39 ` Jeremy Fitzhardinge
2008-12-22 0:43 ` Rusty Russell
2008-12-23 19:14 ` Vladislav Bolkhovitin
2008-12-23 19:16 ` Vladislav Bolkhovitin
2008-12-23 21:38 ` Evgeniy Polyakov
2008-12-24 14:37 ` Vladislav Bolkhovitin
2008-12-24 14:44 ` Evgeniy Polyakov
2008-12-24 17:46 ` Vladislav Bolkhovitin
2008-12-24 18:08 ` Evgeniy Polyakov
2008-12-30 17:37 ` Vladislav Bolkhovitin
2008-12-30 21:35 ` Evgeniy Polyakov
2008-12-23 19:13 ` Vladislav Bolkhovitin
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=4943CAAB.4050008@vlnb.net \
--to=vst@vlnb.net \
--cc=James.Bottomley@HansenPartnership.com \
--cc=akpm@linux-foundation.org \
--cc=bart.vanassche@gmail.com \
--cc=bharrosh@panasas.com \
--cc=fujita.tomonori@lab.ntt.co.jp \
--cc=fweisbec@gmail.com \
--cc=jeff@garzik.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-scsi@vger.kernel.org \
--cc=michaelc@cs.wisc.edu \
--cc=mingo@elte.hu \
--cc=nab@linux-iscsi.org \
--cc=sam@ravnborg.org \
--cc=scst-devel@lists.sourceforge.net \
--cc=srostedt@redhat.com \
--cc=torvalds@linux-foundation.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).