diff options
author | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | 2022-10-21 16:14:56 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2022-10-21 16:14:56 +0000 |
commit | aa889fd2dcf9e2b04af7864f081b2580afe25aa7 (patch) | |
tree | c31c0d8f4dc390580d8233a8eaf403c826e642db | |
parent | 047405344cab70692da795bd22358db4b1699004 (diff) | |
parent | 994c976e996c4591f7c0943375962ea6c818056d (diff) | |
download | native-gki13-boot-release.tar.gz |
Merge "Snap for 9204358 from 9a3a457f42f171cf0b64983219753ef8e3f52291 to gki13-boot-release" into gki13-boot-releasegki13-boot-release
-rw-r--r-- | cmds/dumpstate/dumpstate.cpp | 33 |
1 files changed, 32 insertions, 1 deletions
diff --git a/cmds/dumpstate/dumpstate.cpp b/cmds/dumpstate/dumpstate.cpp index 0a9f8e12d5..ee1c63a3ff 100644 --- a/cmds/dumpstate/dumpstate.cpp +++ b/cmds/dumpstate/dumpstate.cpp @@ -235,6 +235,7 @@ static const char* WAKE_LOCK_NAME = "dumpstate_wakelock"; // task and the log title of the duration report. static const std::string DUMP_TRACES_TASK = "DUMP TRACES"; static const std::string DUMP_INCIDENT_REPORT_TASK = "INCIDENT REPORT"; +static const std::string DUMP_NETSTATS_PROTO_TASK = "DUMP NETSTATS PROTO"; static const std::string DUMP_HALS_TASK = "DUMP HALS"; static const std::string DUMP_BOARD_TASK = "dumpstate_board()"; static const std::string DUMP_CHECKINS_TASK = "DUMP CHECKINS"; @@ -1042,6 +1043,26 @@ static void DumpIncidentReport() { } } +static void DumpNetstatsProto() { + const std::string path = ds.bugreport_internal_dir_ + "/tmp_netstats_proto"; + auto fd = android::base::unique_fd(TEMP_FAILURE_RETRY(open(path.c_str(), + O_WRONLY | O_CREAT | O_TRUNC | O_CLOEXEC | O_NOFOLLOW, + S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH))); + if (fd < 0) { + MYLOGE("Could not open %s to dump netstats proto.\n", path.c_str()); + return; + } + RunCommandToFd(fd, "", {"dumpsys", "netstats", "--proto"}, + CommandOptions::WithTimeout(120).Build()); + bool empty = 0 == lseek(fd, 0, SEEK_END); + if (!empty) { + ds.EnqueueAddZipEntryAndCleanupIfNeeded(kProtoPath + "netstats" + kProtoExt, + path); + } else { + unlink(path.c_str()); + } +} + static void MaybeAddSystemTraceToZip() { // This function copies into the .zip the system trace that was snapshotted // by the early call to MaybeSnapshotSystemTrace(), if any background @@ -1577,7 +1598,8 @@ static Dumpstate::RunStatus dumpstate() { DurationReporter duration_reporter("DUMPSTATE"); // Enqueue slow functions into the thread pool, if the parallel run is enabled. - std::future<std::string> dump_hals, dump_incident_report, dump_board, dump_checkins; + std::future<std::string> dump_hals, dump_incident_report, dump_board, dump_checkins, + dump_netstats_report; if (ds.dump_pool_) { // Pool was shutdown in DumpstateDefaultAfterCritical method in order to // drop root user. Restarts it with two threads for the parallel run. @@ -1586,6 +1608,8 @@ static Dumpstate::RunStatus dumpstate() { dump_hals = ds.dump_pool_->enqueueTaskWithFd(DUMP_HALS_TASK, &DumpHals, _1); dump_incident_report = ds.dump_pool_->enqueueTask( DUMP_INCIDENT_REPORT_TASK, &DumpIncidentReport); + dump_netstats_report = ds.dump_pool_->enqueueTask( + DUMP_NETSTATS_PROTO_TASK, &DumpNetstatsProto); dump_board = ds.dump_pool_->enqueueTaskWithFd( DUMP_BOARD_TASK, &Dumpstate::DumpstateBoard, &ds, _1); dump_checkins = ds.dump_pool_->enqueueTaskWithFd(DUMP_CHECKINS_TASK, &DumpCheckins, _1); @@ -1780,6 +1804,13 @@ static Dumpstate::RunStatus dumpstate() { dump_frozen_cgroupfs(); if (ds.dump_pool_) { + WAIT_TASK_WITH_CONSENT_CHECK(std::move(dump_netstats_report)); + } else { + RUN_SLOW_FUNCTION_WITH_CONSENT_CHECK_AND_LOG(DUMP_NETSTATS_PROTO_TASK, + DumpNetstatsProto); + } + + if (ds.dump_pool_) { WAIT_TASK_WITH_CONSENT_CHECK(std::move(dump_incident_report)); } else { RUN_SLOW_FUNCTION_WITH_CONSENT_CHECK_AND_LOG(DUMP_INCIDENT_REPORT_TASK, |