Unity 改变CPU亲和度(Android)

2024-03-25 03:32

本文主要是介绍Unity 改变CPU亲和度(Android),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 定义
    • 读写CPU亲和度


20207.13 更新:以下内容不可行。在移动平台上,移动厂商限制了通过自行设置CPU亲和度来控制进程具体在哪个核心上调度的功能。所以以下做法在移动平台上是无效的。

定义

CPU亲和度(CPU Affinity)一种表征软件在特定处理器运作倾向的方法。比如目前的骁龙处理器一般是八个核心,由四个大核和四个小核,或者2个大核六个小核组成。在Android平台上,通过以下命令查看对应的CPU最大频率。频率高的就是大核,反之就是小核。

adb shell cat /sys/devices/system/cpu/cpu0/cpufreq/cpuinfo_max_freq

通常,一个应用程序默认设置为软CPU亲和度,这表示没有限制必须在哪个核心上跑这个应用程序,由调度程序来决定它当前时刻跑在哪个CPU核心上。而硬CPU亲和度指定了应用程序只能跑在特定的一个或者多个处理核心上。这种想法来源于以下几个事实:

  • 应用程序由一个核心切换到另一个核心会丢失已经缓存好的数据,导致缓存命令率下降,从而降低了性能。
  • 每次应用程序被重新调度,都可能会被分配到其他核心上。在最坏的情况下,每次调度之后应用程序都在与之前不同的CPU核心上运行,这就是“乒乓效应”。
  • 大核心的CPU性能会比小核心更好,在一些最求性能的应用程序上,将主进程绑定到特定的大核中,往往可以提升应用程序的整体性能。

读写CPU亲和度

在Android(接口和数据结构与Linux的大体一致)系统上,用数据结构cpu_set_t表示CPU亲和度,它在头文件sched.h中被定义:

#ifdef __LP64__
#define CPU_SETSIZE 1024
#else
#define CPU_SETSIZE 32
#endif#define __CPU_BITTYPE  unsigned long int  /* mandated by the kernel  */
#define __CPU_BITS     (8 * sizeof(__CPU_BITTYPE))typedef struct {__CPU_BITTYPE  __bits[ CPU_SETSIZE / __CPU_BITS ];
} cpu_set_t;

注意这个结构虽然包含一个数组,但其实是一个整体,每个bit都对应一个CPU核心,所以它其实是对应每个CPU核心的亲和度掩码。在32bit系统下,cpu_set_t的内存占用是32bit,在64bit系统下,内存占用是1024bit,分别表示最多能够表示32个核心和1024个核心的CPU亲和度。同时,这个头文件还提供了一些方法用来读写这个掩码:

#define CPU_ZERO(set)          CPU_ZERO_S(sizeof(cpu_set_t), set)
#define CPU_SET(cpu, set)      CPU_SET_S(cpu, sizeof(cpu_set_t), set)
#define CPU_CLR(cpu, set)      CPU_CLR_S(cpu, sizeof(cpu_set_t), set)
#define CPU_ISSET(cpu, set)    CPU_ISSET_S(cpu, sizeof(cpu_set_t), set)
#define CPU_COUNT(set)         CPU_COUNT_S(sizeof(cpu_set_t), set)
#define CPU_EQUAL(set1, set2)  CPU_EQUAL_S(sizeof(cpu_set_t), set1, set2)#define CPU_AND(dst, set1, set2)  __CPU_OP(dst, set1, set2, &)
#define CPU_OR(dst, set1, set2)   __CPU_OP(dst, set1, set2, |)
#define CPU_XOR(dst, set1, set2)  __CPU_OP(dst, set1, set2, ^)

同时,这个头文件还提供两个函数,分别利用这个掩码来设置或者读取CPU的亲和度:

int sched_setaffinity(pid_t pid, size_t cpusetsize, const cpu_set_t *mask);
int sched_getaffinity(pid_t pid, size_t cpusetsize, cpu_set_t *mask);

下面就可以书写Native代码实战了:

#include <sched.h>
#include <unistd.h>int SetCpuAffinity(void *p)
{cpu_set_t mask;CPU_ZERO(&mask);char *cpus = (char *)p;int size = 8;for(int i=0;i<size;i++){char cpu = cpus[i];if(cpu == '1'){CPU_SET(i, &mask);}            }pid_t pid = getpid();if(sched_setaffinity(pid, sizeof(cpu_set_t), &mask)==-1)return -1;return 0;
}int GetCpuAffinity(void *p)
{cpu_set_t mask;pid_t pid = getpid();if(sched_getaffinity(pid, sizeof(cpu_set_t), &mask) == -1)return -1;char *a = (char *)p;for(int i=0;i<CPU_SETSIZE;i++){if(CPU_ISSET(i, &mask))a[i] = '1';elsea[i] = '0';}return 0;
}

然后参考文章 Unity 与 NDK 开发 里介绍的方法,将这两个函数暴露给Unity的C#层调用。C#层可以这样使用这两个代码:

IntPtr getP = Marshal.AllocHGlobal(100 * sizeof(char));string Test_GetCpuAffinity()
{GetCpuAffinity(getP);string cpuInfo = Marshal.PtrToStringAnsi(getP);Debug.Log(cpuInfo);return cpuInfo;
}void Test_SetCpuAffinity()
{string cpus = "10000000"; // 绑定到核心0上,剩下的都为0 e_SetCpuAffinity(cpus);
}

这篇关于Unity 改变CPU亲和度(Android)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/843726

相关文章

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

android应用中res目录说明

Android应用的res目录是一个特殊的项目,该项目里存放了Android应用所用的全部资源,包括图片、字符串、颜色、尺寸、样式等,类似于web开发中的public目录,js、css、image、style。。。。 Android按照约定,将不同的资源放在不同的文件夹中,这样可以方便的让AAPT(即Android Asset Packaging Tool , 在SDK的build-tools目

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

Android逆向(反调,脱壳,过ssl证书脚本)

文章目录 总结 基础Android基础工具 定位关键代码页面activity定位数据包参数定位堆栈追踪 编写反调脱壳好用的脚本过ssl证书校验抓包反调的脚本打印堆栈bilibili反调的脚本 总结 暑假做了两个月的Android逆向,记录一下自己学到的东西。对于app渗透有了一些思路。 这两个月主要做的是代码分析,对于分析完后的持久化等没有学习。主要是如何反编译源码,如何找到

android系统源码12 修改默认桌面壁纸--SRO方式

1、aosp12修改默认桌面壁纸 代码路径 :frameworks\base\core\res\res\drawable-nodpi 替换成自己的图片即可,不过需要覆盖所有目录下的图片。 由于是静态修改,则需要make一下,重新编译。 2、方法二Overlay方式 由于上述方法有很大缺点,修改多了之后容易遗忘自己修改哪些文件,为此我们采用另外一种方法,使用Overlay方式。