blob: 835da20347bd735b5b30e401b62eec3d691ae109 [file] [log] [blame]
Kweku Adams5ce418d2018-02-05 16:43:53 -08001/*
2 * Copyright (C) 2018 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#include <set>
17
18#include <android-base/file.h>
19#include <android-base/stringprintf.h>
20#include <android/hidl/manager/1.0/IServiceManager.h>
21#include <dumputils/dump_utils.h>
22#include <log/log.h>
23
24/* list of native processes to include in the native dumps */
25// This matches the /proc/pid/exe link instead of /proc/pid/cmdline.
26static const char* native_processes_to_dump[] = {
27 "/system/bin/audioserver",
28 "/system/bin/cameraserver",
29 "/system/bin/drmserver",
30 "/system/bin/mediadrmserver",
31 "/system/bin/mediaextractor", // media.extractor
32 "/system/bin/mediametrics", // media.metrics
33 "/system/bin/mediaserver",
34 "/system/bin/sdcard",
35 "/system/bin/statsd",
36 "/system/bin/surfaceflinger",
37 "/system/bin/vehicle_network_service",
38 "/vendor/bin/hw/android.hardware.media.omx@1.0-service", // media.codec
39 NULL,
40};
41
42/* list of hal interface to dump containing process during native dumps */
43static const char* hal_interfaces_to_dump[] {
44 "android.hardware.audio@2.0::IDevicesFactory",
45 "android.hardware.bluetooth@1.0::IBluetoothHci",
46 "android.hardware.camera.provider@2.4::ICameraProvider",
Jeff Tinker5fce8822018-04-02 17:24:41 -070047 "android.hardware.drm@1.0::IDrmFactory",
Kweku Adams5ce418d2018-02-05 16:43:53 -080048 "android.hardware.graphics.composer@2.1::IComposer",
49 "android.hardware.media.omx@1.0::IOmx",
50 "android.hardware.sensors@1.0::ISensors",
51 "android.hardware.vr@1.0::IVr",
52 NULL,
53};
54
55bool should_dump_hal_interface(const char* interface) {
56 for (const char** i = hal_interfaces_to_dump; *i; i++) {
57 if (!strcmp(*i, interface)) {
58 return true;
59 }
60 }
61 return false;
62}
63
64bool should_dump_native_traces(const char* path) {
65 for (const char** p = native_processes_to_dump; *p; p++) {
66 if (!strcmp(*p, path)) {
67 return true;
68 }
69 }
70 return false;
71}
72
73std::set<int> get_interesting_hal_pids() {
74 using android::hidl::manager::V1_0::IServiceManager;
75 using android::sp;
76 using android::hardware::Return;
77
78 sp<IServiceManager> manager = IServiceManager::getService();
79 std::set<int> pids;
80
81 Return<void> ret = manager->debugDump([&](auto& hals) {
82 for (const auto &info : hals) {
83 if (info.pid == static_cast<int>(IServiceManager::PidConstant::NO_PID)) {
84 continue;
85 }
86
87 if (!should_dump_hal_interface(info.interfaceName.c_str())) {
88 continue;
89 }
90
91 pids.insert(info.pid);
92 }
93 });
94
95 if (!ret.isOk()) {
96 ALOGE("Could not get list of HAL PIDs: %s\n", ret.description().c_str());
97 }
98
99 return pids; // whether it was okay or not
100}
101
102bool IsZygote(int pid) {
103 static const std::string kZygotePrefix = "zygote";
104
105 std::string cmdline;
106 if (!android::base::ReadFileToString(android::base::StringPrintf("/proc/%d/cmdline", pid),
107 &cmdline)) {
108 return true;
109 }
110
111 return (cmdline.find(kZygotePrefix) == 0);
112}