Clark, thanks for the changes. I checked it and it seems to work. I
added a bit of documentation, I wasn't sure if you wanted as much as
cyclictest has on debugging latency issues so I didn't add much.
John, no problem and thank you for your patience. I'm new to using
mailing lists like this. Original send plus patch is incoming.
Best,
Isaac
On 12/21/2015 07:15 AM, John Kacur wrote:
On Fri, 18 Dec 2015, Clark Williams wrote:
On Fri, 18 Dec 2015 00:36:31 +0000
Isaac Griswold-Steiner <isaac.griswold.steiner@xxxxxxxxx> wrote:
On Fri, Dec 11, 2015 at 2:40 PM Clark Williams <williams@xxxxxxxxxx> wrote:
On Fri, 21 Aug 2015 15:45:58 -0500
Isaac Griswold-Steiner <isaac.griswold.steiner@xxxxxxxxx> wrote:
From: Isaac Griswold-Steiner <isaac.griswoldsteiner@xxxxxx>
rdtscbench is a cyclictest-like tool that spawns a thread per cpu. Each
thread
measures the difference in cycle count (using the tsc) during the
execution of a
tight loop.
This is a simple tool intended to be used for the validation of
nohz_full CPU
configurations. As the validation of nohz_full CPUs is the objective,
the tool
avoids the usage of system calls, timers, or anything that might break
nohz_full.
Isaac,
A question and a request.
Was there any particular reason you used sleep() rather than
clock_nanosleep() in your cycles_per_second function? I see that you did
ten samples but wondered if the slop from a HZ-based wakeup might still
introduce some error, as opposed to a more precise programmed wakeup.
Hi Clark,
I'm sorry about the delayed response. I made that decision based on the
idea that if there was jitter (latency) being caused by system calls, I'd
want a larger measurement of time. That way if there was jitter, it would
make up a smaller percentage of the total time measured and would have less
of an impact on the accuracy of the testing tool.
However this could be totally false, in which case that can be changed.
I made this change which seems to work fine. Let me know what you think:
diff --git a/src/rdtscbench/rdtscbench.c b/src/rdtscbench/rdtscbench.c
index 9bed3e1292d5..7268e7c99469 100644
--- a/src/rdtscbench/rdtscbench.c
+++ b/src/rdtscbench/rdtscbench.c
@@ -113,14 +113,19 @@ static unsigned long long get_cycles_per_second(void)
{
static const int measurements = 10;
unsigned long long strt, end, total = 0;
-
+ struct timespec ts;
int i = 0;
printf("# getting cycles per second for %d seconds\n", measurements);
+ ts.tv_sec = 1;
+ ts.tv_nsec = 0;
for (i = 0; i < measurements; i++) {
strt = get_cycles();
- sleep(1);
+ if (clock_nanosleep(CLOCK_MONOTONIC, 0, &ts, NULL) < 0) {
+ fprintf(stderr, "get_cycles_per_second: clock_nanosleep() failed: %s\n", strerror(errno));
+ exit(errno);
+ }
end = get_cycles();
total += end - strt;
}
Also, I'd appreciate it if you would expand a bit on the usage section in
your README file, specifically how you tune a system prior to running
rdtscbench, what output indicates that your tuning is *not* working, versus
when to know you're doing the right things. It's probably as simple as
saying "if the max latency numbers are spiking you have a problem" but it's
good to be explicit about that sort of thing.
Will do! Thanks for pointing that out.
You're welcome, thanks for the code. I haven't talked to John Kacur about your code yet but it looked useful to me so I'm inclined to pull it in. Once he and I talk and agree, we'll pull it into the v0.97 devel branch. If we don't agree John will probably be asking you for more changes :).
Clark
Hi
There are some changes coming-up in rt-tests, and I don't want to include
this new test in those changes. However, I have added the code to a branch
called devel/rdtscbench so that we can add the test in a future version.
Can you send me your SOB for the two patches? (original send plus patch).
Also please make sure you cc everyone in the original thread on all
correspondence. (don't reply just in private to one person)
Cheers
John
--
To unsubscribe from this list: send the line "unsubscribe linux-rt-users" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html