关联线程组调度特性介绍
基本概念
关联线程组(related thread group)提供了对一组关键线程调度优化的能力,支持对关键线程组单独进行负载统计和预测,并且设置优选CPU cluster功能,从而达到为组内线程选择最优CPU运行并且根据分组负载选择合适的CPU调频点运行。
配置指导
使能关联线程组
打开相关配置项及依赖,启用关联线程组功能,需要通过编译内核时打开相应的配置项及依赖,相关CONFIG如下:
CONFIG_SCHED_RTG=y
CONFIG_SCHED_RTG_DEBUG=y
CONFIG_SCHED_RTG_FRAME=y
CONFIG_SCHED_RTG_RT_THREAD_LIMIT=y
另有部分CONFIG被依赖:
CONFIG_SCHED_WALT=y
添加进程/线程到关联线程组中
内核中默认创建出20个可用的关联线程组,其中group id=1的分组为预留分组,不支持添加进程/线程:
// 将指定pid的进程添加到group id为2的关联线程组中
echo 2 > /proc/<pid>/sched_group_id
// 将指定pid的进程从group id为2的关联线程组中移出,其中group id=0表示非关联线程组
echo 0 > /proc/<pid>/sched_group_id
查看关联线程组信息
关联线程组信息包含group id,分组优选CPU cluster id,分组内线程信息等。
cat /proc/sched_rtg_debug
// 例如执行后显示如下:
RTG_ID : 2 // 分组id
RTG_INTERVAL : UPDATE:8ms\#INVALID:4294ms // CPU调频间隔和负载有效时长
RTG_CLUSTER : -1 // CPU cluster id,其中-1表示未设置优选cluster
RTG_THREADS : 0/1 // 分组包含的线程总数
STATE COMM PID PRIO CPU // 线程信息(状态/名称/pid/优先级/所在CPU编号)
---------------------------------------------------------
S bash 436 120 1(0-3)
关联线程组相关接口
关联线程组提供了设备节点和ioctl接口用于查询和配置分组信息,其中设备节点路径为/dev/sched_rtg_ctrl
。
设备节点 | request | 描述 |
---|---|---|
/dev/sched_rtg_ctrl | CMD_ID_SET_RTG | 创建分组,添加/更新/删除分组中线程 |
CMD_ID_SET_CONFIG | 配置全局分组属性,例如最大实时分组个数 | |
CMD_ID_SET_RTG_ATTR | 配置指定分组属性,例如分组线程优先级 | |
CMD_ID_SET_MIN_UTIL | 设置分组最小utilization值 |