feature_arm.cpp
来自「该BSP是基于PXA270+WINCE的BSP」· C++ 代码 · 共 101 行
CPP
101 行
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
//------------------------------------------------------------------------------
//
// File: feature_arm.cpp
//
#include <windows.h>
#include <winnt.h>
#include <oal.h>
extern "C" UINT32 OALGetIdCode();
// The Architecture field definitions in the ID Code
enum ARM_ARCHITECTURE {
ARCH_4 = 1,
ARCH_4T,
ARCH_5,
ARCH_5T,
ARCH_5TE,
ARCH_5TEJ,
ARCH_6,
};
// Layout of the ID Code register
union IDCodeReg {
UINT32 idCode;
struct {
UINT32 revision : 4;
UINT32 partNumber : 12;
ARM_ARCHITECTURE architecture : 4;
UINT32 variant : 4;
UINT32 implementor : 8;
};
};
// Map a feature to a bitfield of architectures that have that feature.
struct FeatureToArchMask {
UINT32 processorFeature;
UINT32 archMask;
};
static const FeatureToArchMask sc_rgFeatureToArchMask[] = {
{ PF_ARM_V4, (1 << ARCH_4) | (1 << ARCH_4T) },
{ PF_ARM_V5, (1 << ARCH_5) | (1 << ARCH_5T) | (1 << ARCH_5TE) | (1 << ARCH_5TEJ) },
{ PF_ARM_V6, (1 << ARCH_6) },
{ PF_ARM_THUMB, (1 << ARCH_4T) | (1 << ARCH_5T) | (1 << ARCH_5TE) | (1 << ARCH_5TEJ) },
{ PF_ARM_JAZELLE, (1 << ARCH_5TEJ) },
};
#define dim(x) (sizeof(x)/sizeof((x)[0]))
//------------------------------------------------------------------------------
//
// Function: OALIsARMProcessorFeaturePresent
//
// Called to determine the processor's supported feature set.
//
extern "C" BOOL OALIsARMProcessorFeaturePresent(DWORD feature)
{
BOOL rc = FALSE;
// Get the ID from the hardware.
IDCodeReg idCode = { OALGetIdCode() };
OALMSG(OAL_INFO&&OAL_VERBOSE,
(L"OALIsProcessorFeaturePresent: ID Code register: %c 0x%02x 0x%02x 0x%03x 0x%02x\r\n",
idCode.implementor, idCode.variant, idCode.architecture,
idCode.partNumber, idCode.revision));
// Is it possible that this feature can be supported?
UINT32 idx;
for (idx = 0; idx < dim(sc_rgFeatureToArchMask); ++idx) {
if (sc_rgFeatureToArchMask[idx].processorFeature == feature) {
break;
}
}
if (idx < dim(sc_rgFeatureToArchMask)) {
// Yes, so now see if this CPU supports this feature.
UINT32 actualMask = (1 << idCode.architecture);
if (sc_rgFeatureToArchMask[idx].archMask & actualMask) {
rc = TRUE;
}
}
return rc;
}
//------------------------------------------------------------------------------
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?