焦點 >

        【WALT】scale_exec_time() 代碼詳解

        時間:2023-07-06 20:20:51       來源:博客園

        @

        目錄【WALT】scale_exec_time() 代碼詳解代碼展示代碼邏輯:為什么歸一化?⑴將 CPU cycles 轉換為 CPU 當前頻率⑵歸一化 delta【WALT】scale_exec_time() 代碼詳解

        代碼版本:Linux4.9 android-msm-crosshatch-4.9-android12


        (相關資料圖)

        代碼展示
        static inline u64 scale_exec_time(u64 delta, struct rq *rq){u32 freq;// ⑴ 將 CPU cycles 轉換為 CPU 當前頻率freq = cpu_cycles_to_freq(rq->cc.cycles, rq->cc.time);// ⑵ 歸一化 deltadelta = DIV64_U64_ROUNDUP(delta * freq, max_possible_freq);delta *= rq->cluster->exec_scale_factor;delta >>= 10;return delta;}
        代碼邏輯:

        scale_exec_time()函數用于給任務的運行時間 delta 進行歸一化。

        為什么歸一化?

        EAS 主要針對異構 CPU 架構,如 Arm big.LITTLE,因為這種架構有不同性能和功耗的 CPU 核心,不同 CPU 的最大算力、最大頻率等都不同。假定一個任務在當前窗口中運行了 5ms,對不同頻率的兩個 CPU 來說,5ms 帶來的負載是截然不同的。

        WALT 算法引入了一種類似權重的方法,根據 CPU 的頻率(frequency)和 最大每周期指令數(efficiency)來對任務的運行時間進行歸一化。(注:此處 efficiency 的定義并不確定,在內核文檔中出現過這個定義。)

        ⑴將 CPU cycles 轉換為 CPU 當前頻率

        freq = cpu_cycles_to_freq(rq->cc.cycles, rq->cc.time);

        static inline u32 cpu_cycles_to_freq(u64 cycles, u64 period){return div64_u64(cycles, period);}

        在這里 freq = rq->cc.cycles / rq->cc.time。其中,rq->cc.cycles 和 rq->cc.time 在函數 update_task_rq_cpu_cycles()中更新:

        static voidupdate_task_rq_cpu_cycles(struct task_struct *p, struct rq *rq, int event,  u64 wallclock, u64 irqtime){u64 cur_cycles;int cpu = cpu_of(rq);lockdep_assert_held(&rq->lock);if (!use_cycle_counter) {rq->cc.cycles = cpu_cur_freq(cpu);rq->cc.time = 1;return;}cur_cycles = read_cycle_counter(cpu, wallclock);/* * If current task is idle task and irqtime == 0 CPU was * indeed idle and probably its cycle counter was not * increasing.  We still need estimatied CPU frequency * for IO wait time accounting.  Use the previously * calculated frequency in such a case. */if (!is_idle_task(rq->curr) || irqtime) {if (unlikely(cur_cycles < p->cpu_cycles))rq->cc.cycles = cur_cycles + (U64_MAX - p->cpu_cycles);elserq->cc.cycles = cur_cycles - p->cpu_cycles;rq->cc.cycles = rq->cc.cycles * NSEC_PER_MSEC;if (event == IRQ_UPDATE && is_idle_task(p))/* * Time between mark_start of idle task and IRQ handler * entry time is CPU cycle counter stall period. * Upon IRQ handler entry sched_account_irqstart() * replenishes idle task"s cpu cycle counter so * rq->cc.cycles now represents increased cycles during * IRQ handler rather than time between idle entry and * IRQ exit.  Thus use irqtime as time delta. */rq->cc.time = irqtime;elserq->cc.time = wallclock - p->ravg.mark_start;BUG_ON((s64)rq->cc.time < 0);}p->cpu_cycles = cur_cycles;trace_sched_get_task_cpu_cycles(cpu, event, rq->cc.cycles, rq->cc.time, p);}
        ⑵歸一化 delta

        delta = DIV64_U64_ROUNDUP(delta * freq, max_possible_freq);即 delta = delta * freq/max_possible_freq。

        freq 是當前 CPU 的頻率,由 ⑴ 計算而得:freq = rq->cc.cycles / rq->cc.time。

        max_possible_freq 就是 max(policy->cpuinfo.max_freq)。policy 可以淺顯地認為是簇號,如不同的 policy 指向小核簇、大核簇和超大核:

        對于擁有多個 CPU 的簇來說,頻率的計算在 sugov_update_shared() 中進行,簇內每個 CPU 的頻率都是一致的,因此一個簇會擁有一個當前頻率和一個最大頻率,即 policy->cpuinfo.max_freq;對于單個 CPU 來說,頻率的計算在 sugov_update_single() 中進行,它也會有一個最大頻率 policy->cpuinfo.max_freq。

        在運行該版本內核的 pixel 3xl 中,8 個 CPU 分為小核簇與大核簇,他們的最大頻率分別是 381 和 1024。

        delta *= rq->cluster->exec_scale_factor;cluster->exec_scale_factor = 1024 * cluster->efficiency/max_possible_efficiency

        cluster->efficiency 可能指運行任務的 CPU 的每周期指令數 (IPC)。

        max_possible_efficiency 可能指系統中任何 CPU 提供的最大 IPC。這個值在設備樹中給定,在運行該版本內核的 pixel 3xl 中,小核簇和大核簇的 max_possible_efficiency 分別是 1024 和 1740。

        delta >>= 10;即 delta = delta / 1024。

        將三句代碼一起看,能得出一個等式:\(delta\_s = delta\times\dfrac{curr\_freq}{max\_possible\_freq}\times\dfrac{cluster->efficiency}{max\_possible\_efficiency}\)

        點擊此處回到 WALT 入口函數 update_task_ravg()

        關鍵詞:

        首頁
        頻道
        底部
        頂部
        亚洲欧美第一成人网站7777| 亚洲区视频在线观看| 久久久久噜噜噜亚洲熟女综合 | 亚洲va国产va天堂va久久| 综合自拍亚洲综合图不卡区| 亚洲色中文字幕无码AV| 不卡一卡二卡三亚洲| 国产国拍亚洲精品福利| 亚洲AⅤ优女AV综合久久久| 亚洲日韩国产二区无码| 亚洲伊人久久大香线蕉在观| 久久久无码精品亚洲日韩京东传媒| 亚洲VA中文字幕不卡无码| 亚洲尤码不卡AV麻豆| 国产精品亚洲综合专区片高清久久久 | 国产精品亚洲片夜色在线| 亚洲综合在线成人一区| 亚洲视频免费观看| 亚洲国产精品一区二区久| 亚洲一级毛片免费观看| 亚洲熟妇无码爱v在线观看| 亚洲美女中文字幕| 亚洲伊人色一综合网| 亚洲一区二区三区高清在线观看| 亚洲欧美日韩中文无线码| 亚洲精品日韩一区二区小说| 亚洲色大情网站www| 亚洲第一se情网站| 精品国产人成亚洲区| 亚洲精品乱码久久久久久按摩| 久久精品国产96精品亚洲| 亚洲高清中文字幕| 亚洲一卡2卡3卡4卡国产网站 | 久久亚洲精品专区蓝色区| 2020国产精品亚洲综合网| 亚洲AV色无码乱码在线观看| 亚洲电影日韩精品| 亚洲国产另类久久久精品小说| 国产亚洲A∨片在线观看| 911精品国产亚洲日本美国韩国| 亚洲国产日韩女人aaaaaa毛片在线|