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