ref: 4d729c94186457f205fc73e375a781af9468229a
parent: ff94e7053df980111eb7f22a04e4c0cfd6b84c97
author: volvet <[email protected]>
date: Tue Mar 4 10:50:41 EST 2014
get cpu cores for android
--- a/codec/common/cpu.cpp
+++ b/codec/common/cpu.cpp
@@ -216,7 +216,7 @@
#if defined(HAVE_NEON)//For supporting both android platform and iOS platform
#if defined(ANDROID_NDK)
-uint32_t WelsCPUFeatureDetectAndroid()
+uint32_t WelsCPUFeatureDetect (int32_t* pNumberOfLogicProcessors)
{
uint32_t uiCPU = 0;
AndroidCpuFamily cpuFamily = ANDROID_CPU_FAMILY_UNKNOWN;
@@ -234,6 +234,11 @@
uiCPU |= WELS_CPU_NEON;
}
}
+
+ if( pNumberOfLogicProcessors != NULL ){
+ *pNumberOfLogicProcessors = android_getCpuCount();
+ }
+
return uiCPU;
}
--- a/codec/common/cpu.h
+++ b/codec/common/cpu.h
@@ -82,7 +82,9 @@
#if defined(HAVE_NEON)
#if defined(ANDROID_NDK)
- uint32_t WelsCPUFeatureDetectAndroid();
+
+uint32_t WelsCPUFeatureDetect (int32_t* pNumberOfLogicProcessors);
+
#endif
#if defined(APPLE_IOS)
--- a/codec/decoder/core/src/decoder.cpp
+++ b/codec/decoder/core/src/decoder.cpp
@@ -148,7 +148,7 @@
pCtx->uiCpuFlag = WelsCPUFeatureDetect (&iCpuCores);
#elif defined(HAVE_NEON)
#if defined(ANDROID_NDK)
- pCtx->uiCpuFlag = WelsCPUFeatureDetectAndroid();
+ pCtx->uiCpuFlag = WelsCPUFeatureDetect(&iCpuCores);
#endif
#if defined(APPLE_IOS)
pCtx->uiCpuFlag = WelsCPUFeatureDetectIOS();