blob: bc22d3b24b68c8a16f1aa949afb10a6df097d60d [file] [log] [blame]
Yi Konge5576ae2020-08-05 02:00:05 +08001//
2// Copyright (C) 2020 The Android Open Source Project
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15//
16
17//! Command to control profcollectd behaviour.
18
Yi Konge3aab142021-03-02 13:58:25 +080019use anyhow::{bail, Context, Result};
Yi Konge5576ae2020-08-05 02:00:05 +080020use std::env;
21
Yi Konge3aab142021-03-02 13:58:25 +080022const HELP_MSG: &str = r#"
Yi Konge5576ae2020-08-05 02:00:05 +080023usage: profcollectctl [command]
24
25Command to control profcollectd behaviour.
26
27command:
28 start Schedule periodic collection.
29 stop Terminate periodic collection.
Yi Kongc26c15b2024-07-06 17:20:44 +090030 trace Request an one-off system-wide trace.
Yi Konge5576ae2020-08-05 02:00:05 +080031 process Convert traces to perf profiles.
Yi Kong34ebf872021-11-29 19:57:55 +080032 report Create a report containing all profiles.
33 reset Clear all local data.
Yi Konge5576ae2020-08-05 02:00:05 +080034 help Print this message.
Yi Konge3aab142021-03-02 13:58:25 +080035"#;
Yi Konge5576ae2020-08-05 02:00:05 +080036
Yi Konge3aab142021-03-02 13:58:25 +080037fn main() -> Result<()> {
38 libprofcollectd::init_logging();
39
Yi Konge5576ae2020-08-05 02:00:05 +080040 let args: Vec<String> = env::args().collect();
41 if args.len() != 2 {
Yi Konge3aab142021-03-02 13:58:25 +080042 bail!("This program only takes one argument{}", &HELP_MSG);
Yi Konge5576ae2020-08-05 02:00:05 +080043 }
44
45 let action = &args[1];
46 match action.as_str() {
47 "start" => {
48 println!("Scheduling profile collection");
Yi Konge3aab142021-03-02 13:58:25 +080049 libprofcollectd::schedule().context("Failed to schedule collection.")?;
Yi Konge5576ae2020-08-05 02:00:05 +080050 }
51 "stop" => {
52 println!("Terminating profile collection");
Yi Konge3aab142021-03-02 13:58:25 +080053 libprofcollectd::terminate().context("Failed to terminate collection.")?;
Yi Konge5576ae2020-08-05 02:00:05 +080054 }
Yi Kongc26c15b2024-07-06 17:20:44 +090055 "trace" => {
56 println!("Performing system-wide trace");
57 libprofcollectd::trace_system("manual").context("Failed to trace.")?;
Yi Konge5576ae2020-08-05 02:00:05 +080058 }
59 "process" => {
Yi Konge3aab142021-03-02 13:58:25 +080060 println!("Processing traces");
61 libprofcollectd::process().context("Failed to process traces.")?;
Yi Konge5576ae2020-08-05 02:00:05 +080062 }
Yi Kong4e25de72020-09-08 14:43:33 +080063 "report" => {
Yi Konge3aab142021-03-02 13:58:25 +080064 println!("Creating profile report");
Yi Kong037bde82021-03-23 14:25:38 +080065 let path = libprofcollectd::report().context("Failed to create profile report.")?;
66 println!("Report created at: {}", &path);
Yi Kong4e25de72020-09-08 14:43:33 +080067 }
Yi Kong34ebf872021-11-29 19:57:55 +080068 "reset" => {
69 libprofcollectd::reset().context("Failed to reset.")?;
70 println!("Reset done.");
71 }
Yi Konge3aab142021-03-02 13:58:25 +080072 "help" => println!("{}", &HELP_MSG),
73 arg => bail!("Unknown argument: {}\n{}", &arg, &HELP_MSG),
Yi Konge5576ae2020-08-05 02:00:05 +080074 }
Yi Konge3aab142021-03-02 13:58:25 +080075 Ok(())
Yi Konge5576ae2020-08-05 02:00:05 +080076}