Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/sys_info.h" | 5 #include "base/sys_info.h" |
| 6 | 6 |
| 7 #include <sys/system_properties.h> | 7 #include <sys/system_properties.h> |
| 8 | 8 |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/string_piece.h" | 10 #include "base/string_piece.h" |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 37 return; | 37 return; |
| 38 } | 38 } |
| 39 } | 39 } |
| 40 | 40 |
| 41 // For some reason, we couldn't parse the version number string. | 41 // For some reason, we couldn't parse the version number string. |
| 42 *major_version = kDefaultAndroidMajorVersion; | 42 *major_version = kDefaultAndroidMajorVersion; |
| 43 *minor_version = kDefaultAndroidMinorVersion; | 43 *minor_version = kDefaultAndroidMinorVersion; |
| 44 *bugfix_version = kDefaultAndroidBugfixVersion; | 44 *bugfix_version = kDefaultAndroidBugfixVersion; |
| 45 } | 45 } |
| 46 | 46 |
| 47 int ParseHeapSize(const base::StringPiece& str) { | 47 // Parses a size (specified with unit 'k','m' or 'g'). |
| 48 // Returns a value in bytes. | |
| 49 int64 ParseSizeBytes(const base::StringPiece& str) { | |
| 48 const int64 KB = 1024; | 50 const int64 KB = 1024; |
| 49 const int64 MB = 1024 * KB; | 51 const int64 MB = 1024 * KB; |
| 50 const int64 GB = 1024 * MB; | 52 const int64 GB = 1024 * MB; |
| 51 CHECK_GT(str.size(), 0u); | 53 CHECK_GT(str.size(), 0u); |
| 52 int64 factor = 1; | 54 int64 unit_multiplier = 1; |
| 53 size_t length = str.size(); | 55 size_t length = str.size(); |
| 54 if (str[length - 1] == 'k') { | 56 if (str[length - 1] == 'k') { |
| 55 factor = KB; | 57 unit_multiplier = KB; |
| 56 length--; | 58 length--; |
| 57 } else if (str[length - 1] == 'm') { | 59 } else if (str[length - 1] == 'm') { |
| 58 factor = MB; | 60 unit_multiplier = MB; |
| 59 length--; | 61 length--; |
| 60 } else if (str[length - 1] == 'g') { | 62 } else if (str[length - 1] == 'g') { |
| 61 factor = GB; | 63 unit_multiplier = GB; |
| 62 length--; | 64 length--; |
| 63 } else { | 65 } else { |
| 64 CHECK('0' <= str[length - 1] && str[length - 1] <= '9'); | 66 CHECK('0' <= str[length - 1] && str[length - 1] <= '9'); |
|
jar (doing other things)
2013/02/13 21:54:11
It is bothersome that the un-tagged number is limi
epenner
2013/02/14 04:18:36
Sorry, how do you figure it's limited to 10billion
jar (doing other things)
2013/02/15 00:18:23
You are correct. I misread the code in a fast (mi
| |
| 65 } | 67 } |
| 66 int64 result = 0; | 68 int64 result = 0; |
| 67 bool parsed = base::StringToInt64(str.substr(0, length), &result); | 69 bool parsed = base::StringToInt64(str.substr(0, length), &result); |
| 68 CHECK(parsed); | 70 CHECK(parsed); |
| 69 result = result * factor / MB; | 71 return result * unit_multiplier; |
|
jar (doing other things)
2013/02/13 21:54:11
This newer code is still problematic, as it ignore
epenner
2013/02/14 04:18:36
Thanks, good point! So, I guess I'll need to add o
| |
| 70 // dalvik.vm.heapsize property is writable by user, | |
| 71 // truncate it to reasonable value to avoid overflows later. | |
| 72 result = std::min<int64>(std::max<int64>(32, result), 1024); | |
| 73 return static_cast<int>(result); | |
| 74 } | 72 } |
| 75 | 73 |
| 76 int GetDalvikHeapSizeMB() { | 74 int GetDalvikHeapSizeMB() { |
| 77 char heap_size_str[PROP_VALUE_MAX]; | 75 char heap_size_str[PROP_VALUE_MAX]; |
| 78 __system_property_get("dalvik.vm.heapsize", heap_size_str); | 76 __system_property_get("dalvik.vm.heapsize", heap_size_str); |
| 79 return ParseHeapSize(heap_size_str); | 77 // dalvik.vm.heapsize property is writable by a root user. |
| 78 // Clamp it to reasonable range as a sanity check. | |
| 79 const int64 MB = 1024 * 1024; | |
| 80 int64 result = ParseSizeBytes(heap_size_str); | |
| 81 result = std::min<int64>(std::max<int64>(32 * MB, result), 1024 * MB) / MB; | |
|
jar (doing other things)
2013/02/13 21:54:11
This bounding was partially (almost) done on line
epenner
2013/02/14 04:18:36
Since we will want to re-use the parsing function
jar (doing other things)
2013/02/15 00:18:23
OK.
On 2013/02/14 04:18:36, epenner wrote:
| |
| 82 return static_cast<int>(result); | |
| 83 } | |
| 84 | |
| 85 int GetDalvikHeapGrowthLimitMB() { | |
| 86 char heap_size_str[PROP_VALUE_MAX]; | |
| 87 __system_property_get("dalvik.vm.heapgrowthlimit", heap_size_str); | |
| 88 // dalvik.vm.heapgrowthlimit property is writable by a root user. | |
| 89 // Clamp it to reasonable range as a sanity check. | |
| 90 const int64 MB = 1024 * 1024; | |
| 91 int64 result = ParseSizeBytes(heap_size_str); | |
| 92 result = std::min<int64>(std::max<int64>(16 * MB, result), 1024 * MB) / MB; | |
|
jar (doing other things)
2013/02/14 01:48:41
Why do you clamp this to a different range than th
epenner
2013/02/14 04:18:36
The heap growth limit is typically half of the hea
jar (doing other things)
2013/02/15 00:18:23
nit: Please add comments explaining where these bo
| |
| 93 return static_cast<int>(result); | |
| 80 } | 94 } |
| 81 | 95 |
| 82 } // anonymous namespace | 96 } // anonymous namespace |
| 83 | 97 |
| 84 namespace base { | 98 namespace base { |
| 85 | 99 |
| 86 std::string SysInfo::OperatingSystemName() { | 100 std::string SysInfo::OperatingSystemName() { |
| 87 return "Android"; | 101 return "Android"; |
| 88 } | 102 } |
| 89 | 103 |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 115 // Parse out the numbers. | 129 // Parse out the numbers. |
| 116 ParseOSVersionNumbers(os_version_str, major_version, minor_version, | 130 ParseOSVersionNumbers(os_version_str, major_version, minor_version, |
| 117 bugfix_version); | 131 bugfix_version); |
| 118 } | 132 } |
| 119 | 133 |
| 120 int SysInfo::DalvikHeapSizeMB() { | 134 int SysInfo::DalvikHeapSizeMB() { |
| 121 static int heap_size = GetDalvikHeapSizeMB(); | 135 static int heap_size = GetDalvikHeapSizeMB(); |
| 122 return heap_size; | 136 return heap_size; |
| 123 } | 137 } |
| 124 | 138 |
| 139 int SysInfo::DalvikHeapGrowthLimitMB() { | |
| 140 static int heap_growth_limit = GetDalvikHeapGrowthLimitMB(); | |
| 141 return heap_growth_limit; | |
| 142 } | |
| 143 | |
| 144 | |
| 125 } // namespace base | 145 } // namespace base |
| OLD | NEW |