当前位置:网站首页>一点点读懂cpufreq(一)
一点点读懂cpufreq(一)
2022-08-04 22:50:00 【szembed】
目录
1、内核频率管理策略
Linux针对CPU的DVFS,主要在cpufreq中实现,Linux内部共有6种对频率的管理策略userspace,conservative,ondemand,powersave ,performance和Interactive
1.1 performance
CPU会固定工作在其支持的最高运行频率上;
1.2 powersave
CPU会固定工作在其支持的最低运行频率上。因此这两种 governors 都属于静态 governor ,即在使用它们时 CPU 的运行频率不会根据系统运行时负载的变化动态作出调整。这两种 governors 对应的是两种极端的应用场景,使用 performance governor 体现的是对系统高性能的最大追求,而使用 powersave governor 则是对系统低功耗的最大追求。
1.3 Userspace
最早的 cpufreq 子系统通过 userspace governor 为用户提供了这种灵活性。系统将变频策略的决策权交给了用户态应用程序,并提供了相应的接口供用户态应用程序调节 CPU 运行频率使用。用户态程序通过向/sys/devices/system/cpu/cpux/cpufreq/scaling_setspeed写入指定的频率来设置CPU的运行频率(x表示cpu序号,和/proc/cpuinfo中对应),写入的频率必须是同目录下scaling_available_frequencies中支持的频率。
1.4 ondemand
每隔一定时间间隔对系统负载进行一次计算,并且计算出CPU使用率,若高于门限值的话,CPU频率会被直接调至最高频率;若使用率低于设定值的话,就根据使用率计算出目标频率。
1.5 conservative
和Ondemand相比,Conservative是随着负载逐步的往上调整CPU频率。当某个APP在启动瞬间比较耗费CPU,而正常运行则不耗费CPU的情况下,Conservative显然会影响APP的启动速度和系统性能。Ondemand降频更加激进,conservative降频比较缓慢保守,事实使用ondemand的效果也是比较好的。和ondemand管理器不同的是,在CPU负载高的时候conservative并不直接跳上最高的主频,而是采用步进的方式来升高主频。
1.6 Interactive
由Android提出的机制,未被linux kernel社区接纳,在AOSP的linux分支上存在了较长时间。它针对CPU密集的任务的调频策略会比较激进。因为它在每一个 CPU 上都注册了一个 idle notifier。当 CPU 退出 idle 时,去检查然后决策是否需要调整频率,非idle时仍然需要依赖timer去定时采样,才能知道系统负载信息。
2、频率和电压调整顺序
针对DVFS来说:
1)在需要增加Freq,over drive的情况下:软件首先决定最小的clock frequency,再决定最小的voltage供应。
(1)cpu program power supply to new voltage。(cpu可以换为其他逻辑)
(2)cpu继续工作在现有freq,直到voltage稳定。
(3)cpu program新的freq,可以是clock divider或者PLL,如果是PLL,则需要花费更多时间等待PLL稳定。
2)如果是要降低Freq,则执行顺序:
(1)cpu program新的freq。
(2)等待clock divider或者PLL稳定。
(3)cpu program新的voltage。
总之Freq只有在voltage增加之后,才能提高,Freq必须在voltage减小前,先降低。
3、模块之间关系
cpufreq.c、cpufreq_governor、cpufreq_driver、cpufreq_ondemand之间的调用关系如下,在cpu加入到系统中和移除系统时,cpufreq之间的调用关系:
边栏推荐
- go语言的time包介绍
- Use ngrok to optimize web pages on raspberry pi (1)
- SQL Server calls WebService
- 【论文笔记KDD2021】MixGCF: An Improved Training Method for Graph Neural Network-based Recommender Systems
- MySQL的JSON 数据类型1
- Both synchronized and ReentrantLock are smooth, because they are reentrant locks, and a thread will not deadlock if it takes the lock multiple times. We need reentrant locks
- JVM内存配置参数GC日志
- Will we still need browsers in the future?(feat. Maple words Maple language)
- 轮播图动态渲染
- promise详解
猜你喜欢
【游戏建模模型制作全流程】使用ZBrush制作骷髅王
各行各业都受到重创,游戏行业却如火如荼,如何加入游戏模型师职业
[Mock Interview - 10 Years of Work] Are more projects an advantage?
线上虚拟展馆展示具有哪些优势
How to make a video gif?Try this video making gif artifact
If you can't get your heart, use "distributed lock" to lock your people
重新配置chrome中ffmpeg插件
js中小数四则运算精度问题原因及解决办法
2022七夕程序员必备的表白黑科技(七夕限定款)
【组成原理 六 存储器类型】
随机推荐
线性DP(下)
Shell expect 实战案例
剑指 Offer | 03. 数组中重复的数字
Service Mesh落地路径
智慧养老整体解决方案
学生管理系统架构设计
Go 编程语言(简介)
If you can't get your heart, use "distributed lock" to lock your people
TypeScript - the use of closure functions
阿里巴巴2022届秋招面试真题和答案!
生成回文数
轮播图动态渲染
JVM memory configuration parameter GC log
年薪40W测试工程师成长之路,你在哪个阶段?
SQL Server 调用 WebService
特征工程资料汇总
【3D建模制作技巧分享】如何使用ZBrush导出效果图
测试薪资这么高?刚毕业20K,仅需3.5个月
力扣24-两两交换链表中的节点——链表
2022七夕程序员必备的表白黑科技(七夕限定款)