| Index: runtime/vm/cpuinfo_linux.cc
|
| ===================================================================
|
| --- runtime/vm/cpuinfo_linux.cc (revision 0)
|
| +++ runtime/vm/cpuinfo_linux.cc (revision 0)
|
| @@ -0,0 +1,128 @@
|
| +// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
|
| +// for details. All rights reserved. Use of this source code is governed by a
|
| +// BSD-style license that can be found in the LICENSE file.
|
| +
|
| +#include "vm/globals.h"
|
| +#if defined(TARGET_OS_LINUX)
|
| +
|
| +#include "vm/cpuinfo.h"
|
| +#include "vm/cpuid.h"
|
| +#include "vm/proccpuinfo.h"
|
| +
|
| +#include "platform/assert.h"
|
| +
|
| +// As with Windows, on IA32 and X64, we use the cpuid instruction.
|
| +// The analogous instruction is privileged on ARM and MIPS, so we resort to
|
| +// reading from /proc/cpuinfo.
|
| +
|
| +namespace dart {
|
| +
|
| +CpuInfoMethod CpuInfo::method_ = kCpuInfoDefault;
|
| +const char* CpuInfo::fields_[kCpuInfoMax] = {0};
|
| +
|
| +void CpuInfo::InitOnce() {
|
| +#if defined(HOST_ARCH_IA32) || defined(HOST_ARCH_X64)
|
| + fields_[kCpuInfoProcessor] = "vendor_id";
|
| + fields_[kCpuInfoModel] = "model name";
|
| + fields_[kCpuInfoHardware] = "model name";
|
| + fields_[kCpuInfoFeatures] = "flags";
|
| + method_ = kCpuInfoCpuId;
|
| + CpuId::InitOnce();
|
| +#elif defined(HOST_ARCH_ARM)
|
| + fields_[kCpuInfoProcessor] = "Processor";
|
| + fields_[kCpuInfoModel] = "model name";
|
| + fields_[kCpuInfoHardware] = "Hardware";
|
| + fields_[kCpuInfoFeatures] = "Features";
|
| + method_ = kCpuInfoSystem;
|
| + ProcCpuInfo::InitOnce();
|
| +#elif defined(HOST_ARCH_MIPS)
|
| + fields_[kCpuInfoProcessor] = "system type";
|
| + fields_[kCpuInfoModel] = "cpu model";
|
| + fields_[kCpuInfoHardware] = "cpu model";
|
| + fields_[kCpuInfoFeatures] = "ASEs implemented";
|
| + method_ = kCpuInfoSystem;
|
| + ProcCpuInfo::InitOnce();
|
| +#else
|
| +#error Unrecognized target architecture
|
| +#endif
|
| +}
|
| +
|
| +
|
| +void CpuInfo::Cleanup() {
|
| + if (method_ == kCpuInfoCpuId) {
|
| + CpuId::Cleanup();
|
| + } else {
|
| + ASSERT(method_ == kCpuInfoSystem);
|
| + ProcCpuInfo::Cleanup();
|
| + }
|
| +}
|
| +
|
| +
|
| +bool CpuInfo::FieldContains(CpuInfoIndices idx, const char* search_string) {
|
| + if (method_ == kCpuInfoCpuId) {
|
| + return strstr(CpuId::field(idx), search_string);
|
| + } else {
|
| + ASSERT(method_ == kCpuInfoSystem);
|
| + return ProcCpuInfo::FieldContains(FieldName(idx), search_string);
|
| + }
|
| +}
|
| +
|
| +
|
| +bool CpuInfo::FieldContainsByString(const char* field,
|
| + const char* search_string) {
|
| + if (method_ == kCpuInfoCpuId) {
|
| + for (int i = 0; i < kCpuInfoMax; i++) {
|
| + if (strcmp(field, fields_[i]) == 0) {
|
| + return FieldContains(static_cast<CpuInfoIndices>(i), search_string);
|
| + }
|
| + }
|
| + UNIMPLEMENTED();
|
| + return false;
|
| + } else {
|
| + ASSERT(method_ == kCpuInfoSystem);
|
| + return ProcCpuInfo::FieldContains(field, search_string);
|
| + }
|
| +}
|
| +
|
| +
|
| +const char* CpuInfo::ExtractField(CpuInfoIndices idx) {
|
| + if (method_ == kCpuInfoCpuId) {
|
| + return CpuId::field(idx);
|
| + } else {
|
| + ASSERT(method_ == kCpuInfoSystem);
|
| + return ProcCpuInfo::ExtractField(FieldName(idx));
|
| + }
|
| +}
|
| +
|
| +
|
| +const char* CpuInfo::ExtractFieldByString(const char* field) {
|
| + if (method_ == kCpuInfoCpuId) {
|
| + for (int i = 0; i < kCpuInfoMax; i++) {
|
| + if (strcmp(field, fields_[i]) == 0) {
|
| + return ExtractField(static_cast<CpuInfoIndices>(i));
|
| + }
|
| + }
|
| + UNIMPLEMENTED();
|
| + return NULL;
|
| + } else {
|
| + ASSERT(method_ == kCpuInfoSystem);
|
| + return ProcCpuInfo::ExtractField(field);
|
| + }
|
| +}
|
| +
|
| +
|
| +bool CpuInfo::HasField(const char* field) {
|
| + if (method_ == kCpuInfoCpuId) {
|
| + return (strcmp(field, fields_[kCpuInfoProcessor]) == 0) ||
|
| + (strcmp(field, fields_[kCpuInfoModel]) == 0) ||
|
| + (strcmp(field, fields_[kCpuInfoHardware]) == 0) ||
|
| + (strcmp(field, fields_[kCpuInfoFeatures]) == 0);
|
| + } else {
|
| + ASSERT(method_ == kCpuInfoSystem);
|
| + return ProcCpuInfo::HasField(field);
|
| + }
|
| +}
|
| +
|
| +} // namespace dart
|
| +
|
| +#endif // defined(TARGET_OS_LINUX)
|
|
|