blob: 350edc3e343b1d986e3869c48836a3a11cfe3e6d [file] [log] [blame]
// Copyright 2017 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <lib/async-loop/cpp/loop.h>
#include <lib/async-loop/default.h>
#include <lib/async/cpp/task.h>
#include <lib/trace-provider/provider.h>
#include <lib/trace/event.h>
#include <lib/zx/time.h>
#include <stdio.h>
#include <zircon/syscalls.h>
int main(int argc, char** argv) {
async::Loop loop(&kAsyncLoopConfigNoAttachToCurrentThread);
trace::TraceProviderWithFdio provider(loop.dispatcher());
// Wait for tracing to get set up. Without this, the tracing system can miss
// some of the initial tracing events we generate later.
//
// TODO(fxbug.dev/22911): Replace this sleep with single function that will start
// a TraceProvider in a non-racy way.
puts("Sleeping to allow tracing to start...");
loop.Run(zx::deadline_after(zx::sec(1)));
puts("Starting Benchmark...");
// Run the task for kIterationCount iterations. We use a fixed number
// of iterations (rather than iterating the test until a fixed amount
// of time has elapsed) to avoid some statistical problems with using a
// variable sample size.
const uint32_t kIterationCount = 1000;
uint32_t iteration = 0;
async::TaskClosure task([&loop, &task, &iteration] {
// `task_start` and `task_end` are used to measure the time between
// `example_event` benchmarks. This is measured with a `time_between`
// measurement type.
TRACE_INSTANT("benchmark", "task_start", TRACE_SCOPE_PROCESS);
// An `example_event` benchmark measured with a `duration` measurement
// type.
TRACE_DURATION("benchmark", "example_event");
// Simulate some kind of workload.
zx::nanosleep(zx::deadline_after(zx::usec(1500)));
if (++iteration >= kIterationCount) {
loop.Quit();
return;
}
// Schedule another benchmark.
TRACE_INSTANT("benchmark", "task_end", TRACE_SCOPE_PROCESS);
task.PostDelayed(loop.dispatcher(), zx::usec(500));
});
task.Post(loop.dispatcher());
loop.Run();
puts("Finished.");
return 0;
}