/*
 * 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;
}