Index: base/debug/proc_maps.h |
diff --git a/base/debug/proc_maps.h b/base/debug/proc_maps.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0dadbc13d3915c6d6d938378bce5a241f4cf5ab7 |
--- /dev/null |
+++ b/base/debug/proc_maps.h |
@@ -0,0 +1,61 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef BASE_DEBUG_PROC_MAPS_H_ |
+#define BASE_DEBUG_PROC_MAPS_H_ |
+ |
+#include <string> |
+#include <vector> |
+ |
+#include "base/base_export.h" |
+#include "base/basictypes.h" |
+#include "base/files/file_path.h" |
+ |
+namespace base { |
+namespace debug { |
Mark Mentovai
2013/07/02 19:36:57
Aren’t we not doing second-level nested namespaces
scherkus (not reviewing)
2013/07/02 21:43:01
here's the most relevant discussion I could find:
|
+ |
+#if defined(OS_LINUX) || defined(OS_ANDROID) |
Mark Mentovai
2013/07/02 19:36:57
Get rid of this. Just rename the file with _linux
scherkus (not reviewing)
2013/07/02 21:43:01
Done.
|
+ |
+// Describes a region of mapped memory and the path of the file mapped. |
+struct MappedMemoryRegion { |
+ enum Permissions { |
Mark Mentovai
2013/07/02 19:36:57
The members of this enum are single permissions, s
scherkus (not reviewing)
2013/07/02 21:43:01
Done.
|
+ READ = 1 << 0, |
+ WRITE = 1 << 1, |
+ EXECUTE = 1 << 2, |
+ PRIVATE = 1 << 3, // If set, region is private otherwise it is shared. |
Mark Mentovai
2013/07/02 19:36:57
Missing comma?
scherkus (not reviewing)
2013/07/02 21:43:01
Hrm. Not sure which comma is missing. I assume you
Mark Mentovai
2013/07/02 22:21:35
scherkus wrote:
|
+ }; |
+ |
+ // The address range [start,end) of mapped memory. |
+ uintptr_t start; |
+ uintptr_t end; |
+ |
+ // Byte offset into |path| of the range mapped into memory. |
+ size_t offset; |
+ |
+ // Bitmask of read/write/execute/private/shared permissions. |
+ uint8 permissions; |
+ |
+ // Path of the file mapped into memory. |
+ FilePath path; |
+}; |
+ |
+// Reads the data from /proc/self/maps. Returns an empty string if unable to |
+// do so. |
Mark Mentovai
2013/07/02 19:36:57
What’s it return otherwise? Just the contents of /
scherkus (not reviewing)
2013/07/02 21:43:01
Done.
|
+BASE_EXPORT std::string ReadProcMaps(); |
+ |
+// Parses /proc/<pid>/maps input data and stores in |regions|. Returns true |
+// and updates |regions| if and only if all of |input| was successfully parsed. |
+// |
+// NOTE: Parsed path names aren't guaranteed to point at valid files. For |
+// example, "[heap]" and "[stack]" are used to represent the location of the |
+// process' heap and stack, respectively. |
+BASE_EXPORT bool ParseProcMaps(const std::string& input, |
+ std::vector<MappedMemoryRegion>* regions); |
+ |
+#endif |
+ |
+} // namespace debug |
+} // namespace base |
+ |
+#endif // BASE_DEBUG_PROC_MAPS_H_ |