OLD | NEW |
---|---|
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/process/process_metrics.h" | 5 #include "base/process/process_metrics.h" |
6 | 6 |
7 #include <dirent.h> | 7 #include <dirent.h> |
8 #include <fcntl.h> | 8 #include <fcntl.h> |
9 #include <stddef.h> | 9 #include <stddef.h> |
10 #include <stdint.h> | 10 #include <stdint.h> |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
86 } | 86 } |
87 return value; | 87 return value; |
88 } | 88 } |
89 } | 89 } |
90 // This can be reached if the process dies when proc is read -- in that case, | 90 // This can be reached if the process dies when proc is read -- in that case, |
91 // the kernel can return missing fields. | 91 // the kernel can return missing fields. |
92 return 0; | 92 return 0; |
93 } | 93 } |
94 | 94 |
95 #if defined(OS_LINUX) || defined(OS_AIX) | 95 #if defined(OS_LINUX) || defined(OS_AIX) |
96 // Read /proc/<pid>/sched and look for |field|. On succes, return true and | 96 // Read /proc/<pid>/status and look for |field|. On succes, return true and |
97 // write the value for |field| into |result|. | 97 // write the value for |field| into |result|. |
98 // Only works for fields in the form of "field : uint_value" | 98 // Only works for fields in the form of "field : uint_value" |
99 bool ReadProcSchedAndGetFieldAsUint64(pid_t pid, | 99 bool ReadProcStatusAndGetFieldAsUint64(pid_t pid, |
100 const std::string& field, | 100 const std::string& field, |
101 uint64_t* result) { | 101 uint64_t* result) { |
102 std::string sched_data; | 102 std::string stat_data; |
Mark Mentovai
2017/05/03 03:17:17
/proc/pid/stat and /proc/pid/status are distinct.
sabbakumov
2017/05/03 03:21:02
I used the convention from the ReadProcStatusAndGe
sabbakumov
2017/05/03 05:20:05
Done.
| |
103 { | 103 { |
104 // Synchronously reading files in /proc does not hit the disk. | 104 // Synchronously reading files in /proc does not hit the disk. |
105 ThreadRestrictions::ScopedAllowIO allow_io; | 105 ThreadRestrictions::ScopedAllowIO allow_io; |
106 FilePath sched_file = internal::GetProcPidDir(pid).Append("sched"); | 106 FilePath stat_file = internal::GetProcPidDir(pid).Append("status"); |
107 if (!ReadFileToString(sched_file, &sched_data)) | 107 if (!ReadFileToString(stat_file, &stat_data)) |
108 return false; | 108 return false; |
109 } | 109 } |
110 | 110 |
111 StringPairs pairs; | 111 StringPairs pairs; |
112 SplitStringIntoKeyValuePairs(sched_data, ':', '\n', &pairs); | 112 SplitStringIntoKeyValuePairs(stat_data, ':', '\n', &pairs); |
113 TrimKeyValuePairs(&pairs); | 113 TrimKeyValuePairs(&pairs); |
114 for (size_t i = 0; i < pairs.size(); ++i) { | 114 for (size_t i = 0; i < pairs.size(); ++i) { |
115 const std::string& key = pairs[i].first; | 115 const std::string& key = pairs[i].first; |
116 const std::string& value_str = pairs[i].second; | 116 const std::string& value_str = pairs[i].second; |
117 if (key == field) { | 117 if (key == field) { |
118 uint64_t value; | 118 uint64_t value; |
119 if (!StringToUint64(value_str, &value)) | 119 if (!StringToUint64(value_str, &value)) |
120 return false; | 120 return false; |
121 *result = value; | 121 *result = value; |
122 return true; | 122 return true; |
(...skipping 829 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
952 swap_info->num_writes = ReadFileToUint64(zram_path.Append("num_writes")); | 952 swap_info->num_writes = ReadFileToUint64(zram_path.Append("num_writes")); |
953 swap_info->compr_data_size = | 953 swap_info->compr_data_size = |
954 ReadFileToUint64(zram_path.Append("compr_data_size")); | 954 ReadFileToUint64(zram_path.Append("compr_data_size")); |
955 swap_info->mem_used_total = | 955 swap_info->mem_used_total = |
956 ReadFileToUint64(zram_path.Append("mem_used_total")); | 956 ReadFileToUint64(zram_path.Append("mem_used_total")); |
957 } | 957 } |
958 #endif // defined(OS_CHROMEOS) | 958 #endif // defined(OS_CHROMEOS) |
959 | 959 |
960 #if defined(OS_LINUX) || defined(OS_AIX) | 960 #if defined(OS_LINUX) || defined(OS_AIX) |
961 int ProcessMetrics::GetIdleWakeupsPerSecond() { | 961 int ProcessMetrics::GetIdleWakeupsPerSecond() { |
962 uint64_t wake_ups; | 962 uint64_t num_switches; |
963 const char kWakeupStat[] = "se.statistics.nr_wakeups"; | 963 static const char kSwitchStat[] = "voluntary_ctxt_switches"; |
Mark Mentovai
2017/05/03 03:17:18
I haven’t (yet?) verified that this is equivalent
| |
964 return ReadProcSchedAndGetFieldAsUint64(process_, kWakeupStat, &wake_ups) ? | 964 return ReadProcStatusAndGetFieldAsUint64(process_, kSwitchStat, &num_switches) |
965 CalculateIdleWakeupsPerSecond(wake_ups) : 0; | 965 ? CalculateIdleWakeupsPerSecond(num_switches) |
966 : 0; | |
966 } | 967 } |
967 #endif // defined(OS_LINUX) || defined(OS_AIX) | 968 #endif // defined(OS_LINUX) || defined(OS_AIX) |
968 | 969 |
969 } // namespace base | 970 } // namespace base |
OLD | NEW |