/* * Copyright (c) 2015 The Chromium OS 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 <unistd.h> #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <time.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> static int write_marker(int fd, char *name) { char buf[1024]; struct timespec ts; int size, ret; unsigned long usec; ret = clock_gettime(CLOCK_MONOTONIC, &ts); if (ret < 0) { perror("clock_gettime"); return 1; } // normalize nanoseconds down to microseconds // to make it easier to compare to the entry // timestamps usec = ts.tv_nsec / 1000; size = snprintf(buf, 1024, "%s: %lu.%06lu\n", name, ts.tv_sec, usec); ret = write(fd, buf, size); if (ret < size) { perror("write"); return 1; } return 0; } #define TRACE_PATH "/sys/kernel/debug/tracing/" int main(int argc, char* argv[]) { int ret, fd; fd = open(TRACE_PATH "trace_marker", O_WRONLY); if (fd < 0) { perror("open"); return 1; } ret = write_marker(fd, "start"); if (ret) goto out; ret = write_marker(fd, "middle"); if (ret) goto out; ret = write_marker(fd, "end"); out: close(fd); return ret; }