summaryrefslogtreecommitdiffstats
path: root/src/perfglue/cpu_profiler.cc
blob: 81f2ccf8c9f664fa27ad3b250e3db8dff3c2fc20 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
// vim: ts=8 sw=2 smarttab
/*
 * Ceph - scalable distributed file system
 *
 * Copyright (C) 2011 New Dream Network
 *
 * This is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License version 2.1, as published by the Free Software
 * Foundation.  See file COPYING.
 *
 */

#include "acconfig.h"

#include <gperftools/profiler.h>

#include "common/LogClient.h"
#include "perfglue/cpu_profiler.h"

void cpu_profiler_handle_command(const std::vector<std::string> &cmd,
				 std::ostream& out)
{
  if (cmd.size() == 1 && cmd[0] == "status") {
    ProfilerState st;
    ProfilerGetCurrentState(&st);
    out << "cpu_profiler " << (st.enabled ? "enabled":"not enabled")
	<< " start_time " << st.start_time
	<< " profile_name " << st.profile_name
	<< " samples " << st.samples_gathered;
  }
  else if (cmd.size() == 1 && cmd[0] == "flush") {
    ProfilerFlush();
    out << "cpu_profiler: flushed";
  }
  else {
    out << "cpu_profiler: unrecognized command " << cmd
	<< "; expected one of status, flush.";
  }
}