Skip to content

Commit

Permalink
DEV 22.04.23
Browse files Browse the repository at this point in the history
- 增加 系统动画主动探针
- 增加 CPU采样器负载预测
- 增加 与系统用户态性能控制器协同调度
- 增加 桌面启动器自动识别
- 增加 适配谷歌tensor/天玑810
- 改进 提高手势操作跟手性
- 改进 减少SfAnalysis误报
- 修复 识别上下文的任务调度器规则匹配错误
- 修复 联发科PPM接口适配
- 修复 破音问题
- 修复 部分平台功耗模型
- ...合计163个commit

Signed-off-by: Matt Yang <yccy@outlook.com>
  • Loading branch information
yc9559 committed Apr 23, 2022
1 parent da5c9ed commit 764c02f
Show file tree
Hide file tree
Showing 27 changed files with 358 additions and 950 deletions.
12 changes: 6 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ https://github.com/yc9559/uperf/releases
- `balance`均衡模式,比原厂略流畅的同时略省电
- `powersave`卡顿模式,保证基本流畅的同时尽可能降低功耗
- `performance`费电模式,保证费电的同时多一点流畅度
- `fast`性能模式,相对于均衡模式更佳激进
- `fast`性能模式,相对于均衡模式更加激进
3. 重启

#### 启动完成后切换性能模式
Expand All @@ -61,7 +61,7 @@ https://github.com/yc9559/uperf/releases
执行`sh /data/powercfg.sh balance`,其中`balance`是想要切换到的性能模式名称。

方法2:
安装[Scene 5](https://www.coolapk.com/apk/com.omarea.vtools)为APP绑定对应的性能模式。
安装[Scene](https://www.coolapk.com/apk/com.omarea.vtools)为APP绑定对应的性能模式。

## 常见问题

Expand Down Expand Up @@ -139,8 +139,8 @@ Uperf支持如下几种情景识别:

本程序采用了跟安卓系统框架获取触摸信号一样的方式,监听位于/dev/input的设备,解析来自触摸屏的报点信息,可以获取到最基本的手指触摸到屏幕和手指离开屏幕的事件。根据一段连续的报点信息可以得到手指滑动的距离以及离开屏幕时末端速度,由此可以推断是点击操作还是滑动操作,以及根据末端速度推算APP滚动的持续时间。

#### 重负载跟踪与限制(已经弃用)
**由于和其它分析出现冲突,已经弃用**
#### 重负载跟踪与限制

因为不在安卓框架层插入Hook无法确切知道APP正在启动,因此本程序在Hint开始后,用主动轮询的方式更新所有CPU核心的使用率和运行频率得到系统整体负载。`系统整体负载 = sum(efficiency(i) * (load_pct(i) / 100) * (freq_mhz(i) / 1000))`,其中`i`为CPU核心ID。如果整体负载高于`heavyLoad`,那么把当前Hint切换到重负载Hint。重负载Hint的响应性能很好但耗电也偏多,本程序会持续监测系统负载,如果整体负载低于阈值,提前结束耗电的重负载Hint。对于负载不是那么高的APP热启动,甚至不会触发重负载,不像高通Boost框架不管负载多少强行拉满CPU持续2s。此外,这样的检测不仅涵盖了APP冷热启动,还涵盖了例如点击进入微信朋友圈这样的短时重负载场景。本功能的能耗开销也是在非常低的0.6ms/100ms(Cortex-A55@1.0g)。下图为微信热启动Hint状态切换与持续时间。

![微信热启动](media/wechat_resume.png)
Expand Down Expand Up @@ -186,7 +186,7 @@ Sfanalysis是一个独立于Uperf的模块,注入到surfaceflinger进行修改
### 写入器

写入器基本功能是把目标字符串值写入到`sysfs`节点,除此以外,Uperf还内建了多种写入器实现了其他功能和更加紧凑的参数序列。在切换动作时,Uperf会比对与上一动作参数值的差异,跳过写入重复的值来减少自身功耗开销。Uperf支持的`knob`有如下几种类型:
- `string`,最基础的写入器。效果等同于`echo "val" > /path` **注意:为了提升性能,不会和echo一样清空原有内容**
- `string`,最基础的写入器。效果等同于`echo "val" > /path`
- `percluster`,分集群紧凑型写入器。使用配置文件中`platform/clusterCpuId`的CPU序号替换`path`中的`%d`,各个值由逗号分隔,使得按集群做区分的值更加紧凑,改善可读性。
- `percpu`,分核心紧凑型写入器。根据配置文件中`platform/efficiency`的列表长度,生成CPU序号替换`path`中的`%d`,各个值由逗号分隔,使得按CPU核心做区分的值更加紧凑,改善可读性。
- `cpufreq``percluster`写入器的变种。大部分功能相同,不同的是写入值=设定值*100000,缩短了频率参数序列的长度,以及带有写入失败重试以处理新的最低频率高于原有的最高频率。
Expand Down Expand Up @@ -559,4 +559,4 @@ UFS节能开关的`sysfs`节点路径为`/sys/devices/platform/soc/1d84000.ufshc

如果你实在愿意,下面是感谢云讨饭通道(备注写上你的ID和来源平台):

![](media/alipay-qr.png)
![](media/alipay-qr.png)
48 changes: 48 additions & 0 deletions changelog.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
# 更新日志

## DEV 22.04.23

- 增加 系统动画主动探针
- 增加 CPU采样器负载预测
- 增加 与系统用户态性能控制器协同调度
- 增加 桌面启动器自动识别
- 增加 适配谷歌tensor/天玑810
- 改进 提高手势操作跟手性
- 改进 减少SfAnalysis误报
- 修复 识别上下文的任务调度器规则匹配错误
- 修复 联发科PPM接口适配
- 修复 破音问题
- 修复 部分平台功耗模型

## DEV 22.04.09

- 增加大量平台初步适配
- 改进Unity游戏和吃鸡游戏抖动
- 改进弹幕2倍速视频流畅度
- 更新部分平台功耗模型
- 日志后缀名更换为txt

## DEV 22.04.04

- 插件式软件架构
- 使用C++重新开发
- 功能模块解耦,易扩展
- 感知能耗的CPU调频器
- 用户态使能全平台统一体验
- 单核高性能,多核高能效
- 20-100hz基础采样率,快响应低开销
- 识别上下文的任务调度器
- UI放大核,非关键放小核
- 全数据驱动,正则匹配
- 花费50%开发时间调试的默认规则
- 动态sysfs写入
- 用户态性能控制器基石功能
- 实现更加简约高效
- SfAnalysis
- 预测掉帧并在发生前拉升CPU
- 改进的帧反馈以及模糊匹配
- patch方式无需更改SELinux状态
- 独立选装,但是强烈推荐
- SsAnalysis
- 跟系统线程放置器斗智斗勇
- 独立选装,但是强烈推荐
144 changes: 131 additions & 13 deletions magisk/META-INF/com/google/android/update-binary
Original file line number Diff line number Diff line change
@@ -1,33 +1,151 @@
#!/sbin/sh

#################
# Initialization
#################
TMPDIR=/dev/tmp
MOUNTPATH=/dev/magisk_img

# Default permissions
umask 022

# Initial cleanup
rm -rf $TMPDIR 2>/dev/null
mkdir -p $TMPDIR

# echo before loading util_functions
ui_print() { echo "$1"; }

require_new_magisk() {
ui_print "*******************************"
ui_print " Please install Magisk v20.4+! "
ui_print "*******************************"
ui_print "***********************************"
ui_print " Please install the latest Magisk! "
ui_print "***********************************"
exit 1
}

#########################
# Load util_functions.sh
#########################
imageless_magisk() {
[ $MAGISK_VER_CODE -gt 18100 ]
return $?
}

##########################################################################################
# Environment
##########################################################################################

OUTFD=$2
ZIPFILE=$3

mount /data 2>/dev/null

[ -f /data/adb/magisk/util_functions.sh ] || require_new_magisk
. /data/adb/magisk/util_functions.sh
[ $MAGISK_VER_CODE -lt 20400 ] && require_new_magisk
# Load utility functions
if [ -f /data/adb/magisk/util_functions.sh ]; then
. /data/adb/magisk/util_functions.sh
NVBASE=/data/adb
else
require_new_magisk
fi

# Preperation for flashable zips
setup_flashable

# Mount partitions
mount_partitions

# Detect version and architecture
api_level_arch_detect

# Setup busybox and binaries
$BOOTMODE && boot_actions || recovery_actions

##########################################################################################
# Preparation
##########################################################################################

# Extract common files
unzip -oj "$ZIPFILE" module.prop install.sh uninstall.sh 'common/*' -d $TMPDIR >&2

[ ! -f $TMPDIR/install.sh ] && abort "! Unable to extract zip file!"
# Load install script
. $TMPDIR/install.sh

if imageless_magisk; then
$BOOTMODE && MODDIRNAME=modules_update || MODDIRNAME=modules
MODULEROOT=$NVBASE/$MODDIRNAME
else
$BOOTMODE && IMGNAME=magisk_merge.img || IMGNAME=magisk.img
IMG=$NVBASE/$IMGNAME
request_zip_size_check "$ZIPFILE"
mount_magisk_img
MODULEROOT=$MOUNTPATH
fi

MODID=`grep_prop id $TMPDIR/module.prop`
MODPATH=$MODULEROOT/$MODID

print_modname

ui_print "******************************"
ui_print "Powered by Magisk (@topjohnwu)"
ui_print "******************************"

##########################################################################################
# Install
##########################################################################################

# Create mod paths
rm -rf $MODPATH 2>/dev/null
mkdir -p $MODPATH

on_install

# Remove placeholder
rm -f $MODPATH/system/placeholder 2>/dev/null

# Custom uninstaller
[ -f $TMPDIR/uninstall.sh ] && cp -af $TMPDIR/uninstall.sh $MODPATH/uninstall.sh

# Auto Mount
if imageless_magisk; then
$SKIPMOUNT && touch $MODPATH/skip_mount
else
$SKIPMOUNT || touch $MODPATH/auto_mount
fi

# prop files
$PROPFILE && cp -af $TMPDIR/system.prop $MODPATH/system.prop

# Module info
cp -af $TMPDIR/module.prop $MODPATH/module.prop
if $BOOTMODE; then
# Update info for Magisk Manager
if imageless_magisk; then
mktouch $NVBASE/modules/$MODID/update
cp -af $TMPDIR/module.prop $NVBASE/modules/$MODID/module.prop
else
mktouch /sbin/.magisk/img/$MODID/update
cp -af $TMPDIR/module.prop /sbin/.magisk/img/$MODID/module.prop
fi
fi

# post-fs-data mode scripts
$POSTFSDATA && cp -af $TMPDIR/post-fs-data.sh $MODPATH/post-fs-data.sh

# service mode scripts
$LATESTARTSERVICE && cp -af $TMPDIR/service.sh $MODPATH/service.sh

# Handle replace folders
for TARGET in $REPLACE; do
mktouch $MODPATH$TARGET/.replace
done

ui_print "- Setting permissions"
set_permissions

##########################################################################################
# Finalizing
##########################################################################################

cd /
imageless_magisk || unmount_magisk_img
$BOOTMODE || recovery_cleanup
rm -rf $TMPDIR $MOUNTPATH

install_module
ui_print "- Done"
exit 0
2 changes: 1 addition & 1 deletion magisk/META-INF/com/google/android/updater-script
Original file line number Diff line number Diff line change
@@ -1 +1 @@
#MAGISK
#MAGISK
2 changes: 0 additions & 2 deletions magisk/post-fs-data.sh → magisk/common/post-fs-data.sh
Original file line number Diff line number Diff line change
Expand Up @@ -22,5 +22,3 @@ if [ -f "$MODDIR/flag/need_recuser" ]; then
else
true >$MODDIR/flag/need_recuser
fi

sh $MODDIR/script/powercfg_early.sh
1 change: 0 additions & 1 deletion magisk/service.sh → magisk/common/service.sh
Original file line number Diff line number Diff line change
Expand Up @@ -26,5 +26,4 @@ crash_recuser() {
}

(crash_recuser &)

sh $BASEDIR/script/initsvc.sh
7 changes: 7 additions & 0 deletions magisk/common/system.prop
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# This file will be read by resetprop
# Example: Change dpi
# ro.sf.lcd_density=320

# headroom for GC
dalvik.vm.heapminfree=8m
dalvik.vm.heapmaxfree=12m
Loading

0 comments on commit 764c02f

Please sign in to comment.