ring-buffer: add total count in ring-buffer-benchmark
authorSteven Rostedt <srostedt@redhat.com>
Thu, 7 May 2009 23:52:20 +0000 (19:52 -0400)
committerSteven Rostedt <rostedt@goodmis.org>
Thu, 7 May 2009 23:52:20 +0000 (19:52 -0400)
It is nice to see the overhead of the benchmark test when tracing is
disabled. That is, we turn off the ring buffer just to see what the
cost of running the loop that calls into the ring buffer is.

Currently, if no entries wer made, we get 0. This is not informative.
This patch changes it to check if we had any "missed" (non recorded)
events. If so, a total count is also reported.

[ Impact: evaluate the over head of the ring buffer benchmark test ]

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/ring_buffer_benchmark.c

index a7c048bb4466896fb4c3bab85998652f5f2d904a..a21aa7b3d05e0a72d43a69726f126b549af11083 100644 (file)
@@ -285,6 +285,17 @@ static void ring_buffer_producer(void)
                avg = 1000000 / hit;
                pr_info("%ld ns per entry\n", avg);
        }
+
+
+       if (missed) {
+               if (time)
+                       missed /= (long)time;
+
+               pr_info("Total iterations per millisec: %ld\n", hit + missed);
+
+               avg = 1000000 / (hit + missed);
+               pr_info("%ld ns per entry\n", avg);
+       }
 }
 
 static void wait_to_die(void)