當(dāng)前位置:首頁 > 公眾號(hào)精選 > Linux閱碼場(chǎng)
[導(dǎo)讀]作者簡(jiǎn)介胡哲寧,西安郵電大學(xué)計(jì)算機(jī)科學(xué)與技術(shù)專業(yè)大二學(xué)生。GoogleSwitchTo由于協(xié)程本身對(duì)操作系統(tǒng)的不可見性,協(xié)程中出現(xiàn)的BUG往往不能通過一些已有的工具去排查。在谷歌內(nèi)部有一套閉源的用戶態(tài)任務(wù)調(diào)度框架SwitchTo,這個(gè)框架可以為谷歌提供延遲敏感的服務(wù),對(duì)運(yùn)行的內(nèi)容...


作者簡(jiǎn)介


胡哲寧,西安郵電大學(xué)計(jì)算機(jī)科學(xué)與技術(shù)專業(yè)大二學(xué)生。

Google SwitchTo

由于協(xié)程本身對(duì)操作系統(tǒng)的不可見性,協(xié)程中出現(xiàn)的 BUG 往往不能通過一些已有的工具去排查。在谷歌內(nèi)部有一套閉源的用戶態(tài)任務(wù)調(diào)度框架 SwitchTo, 這個(gè)框架可以為谷歌提供延遲敏感的服務(wù),對(duì)運(yùn)行的內(nèi)容進(jìn)行細(xì)粒度的用戶空間控制/調(diào)度,它可以讓內(nèi)核來實(shí)現(xiàn)上下文的切換,同時(shí)將任務(wù)何時(shí)切換,何時(shí)恢復(fù)的工作交給了用戶態(tài)的程序來做,這樣既可以實(shí)現(xiàn)在任務(wù)間協(xié)作式切換的功能,又可以不喪失內(nèi)核對(duì)于任務(wù)的控制和觀察能力。谷歌去年恢復(fù)嘗試將其 SwitchTo API 上游引入 Linux。相關(guān)補(bǔ)丁見:[1],[2],[3],[4].

1pid_t?switchto_wait(timespec?*timeout)
2/*??Enter?an?'unscheduled?state',?until?our?control?is?re-initiated?by?another?thread?or?external?event?(signal).?*/
3void?switchto_resume(pid_t?tid)
4/*?Resume?regular?execution?of?tid?*/
5pid_t?switchto_switch(pid_t?tid)
6/*?Synchronously?transfer?control?to?target?sibling?thread,?leaving?the?current?thread?unscheduled.Analogous?to:Atomically?{?Resume(t1);?Wait(NULL);?}
7*/

這是使用 SwitchTo 和使用其他線程間切換的組件的上下文切換性能對(duì)比:

BenchmarkTime(ns)CPU(ns)Iterations
BM_Futex290519581000000
BM_GoogleMutex310223261000000
BM_SwitchTo1791783917412
BM_SwitchResume273415541000000
可以看到在使用 SwitchTo 后切換的性能比其他組件提高了一個(gè)數(shù)量級(jí)別。

SwitchTo 是如何做到在切換性能上大幅度領(lǐng)先的呢?我們暫時(shí)可能無法看到它們,但讓我們來看看 Peter Oskolkov 向 LKML(Linux Kernel Mail List) 提出的補(bǔ)丁中有關(guān) futex_swap() 的實(shí)現(xiàn)??梢源_定的是,SwitchTo 構(gòu)建在這個(gè)內(nèi)核函數(shù)之上。

什么是 futex

futex 全稱 fast user-space locking,快速用戶空間互斥鎖,作為內(nèi)核中一種基本的同步原語,它提供了非??焖俚臒o競(jìng)爭(zhēng)鎖獲取和釋放,用于構(gòu)建復(fù)雜的同步結(jié)構(gòu):互斥鎖、條件變量、信號(hào)量等。由于 futex 的一些機(jī)制和使用過于復(fù)雜,glibc 沒有為 futex 提供包裝器,但我們?nèi)匀豢梢允褂?syscall 來調(diào)用這個(gè) 極其 hack 的系統(tǒng)調(diào)用。

1static?int?futex(uint32_t?*uaddr,?int?futex_op,?uint32_t?val,
2?????????????????const?struct?timespec?*timeout,?uint32_t?*uaddr2,
3?????????????????uint32_t?val3)

4?
{
5??return?syscall(SYS_futex,?uaddr,?futex_op,?val,?timeout,?uaddr2,?val3);
6}
  • uaddr: 一個(gè)四字節(jié)的用戶空間地址。多個(gè)任務(wù)間可以通過 *uaddr 的值的變化來控制阻塞或者運(yùn)行。

  • futex_op: 用于控制 futex 執(zhí)行的命令 如 FUTEX_WAIT,FUTEX_WAKEFUTEX_LOCK_PI,FUTEX_UNLOCK_PI

  • val: 在不同的 futex_op 具有不同的含義,如在 futex(uaddr, FUTEX_WAKE) 中作為喚醒等待在該 futex 上所有任務(wù)的數(shù)量。

  • timeout: 作為等待(如 FUTEX_WAIT)的超時(shí)時(shí)間。

  • uaddr2: uaddr2 參數(shù)是一個(gè)四字節(jié)的用戶空間地址 在需要的場(chǎng)景使用(如后文的 FUTEX_SWAP )。

  • val3: 整數(shù)參數(shù)val3的解釋取決于在操作上。

為什么 futex “快速”?

由于用戶模式和內(nèi)核模式之間的上下文切換很昂貴,futex 實(shí)現(xiàn)的同步結(jié)構(gòu)會(huì)盡可能多地留在用戶空間,這意味著它們只需要執(zhí)行更少的系統(tǒng)調(diào)用。futex 的狀態(tài)存儲(chǔ)在用戶空間變量中,futex 可以通過一些原子操作在沒有競(jìng)爭(zhēng)的情況下更改 futex 的狀態(tài),而無需系統(tǒng)調(diào)用的開銷。

futex_wait() 和 futex_wake()

在看 futex_swap() 之前讓我們先看看 內(nèi)核中 與 futex 最重要的兩個(gè)內(nèi)核函數(shù):

1static?int?futex_wait(u32?__user?*uaddr,?unsigned?int?flags,?u32?val,?ktime_t?*abs_time,?u32?bitset);
簡(jiǎn)單來說 對(duì)于 futex_wait() 有用的參數(shù)就只有 uaddr,valabs_time,就像 futex_wait(uaddr,val,abs_time)。其含義是當(dāng)這個(gè)用戶空間地址 uaddr的值等于傳入的參數(shù) val 的時(shí)候睡眠,即 if (*uaddr == val) wait(). futex_wake() 可以將它喚醒,另外還可以通過指定超時(shí)時(shí)間來超時(shí)喚醒。

1static?int?futex_wait(u32?__user?*uaddr,?unsigned?int?flags,?u32?val,
2??????????????ktime_t?*abs_time,?u32?bitset)

3
{
4????struct?hrtimer_sleeper?timeout,?*to;
5????struct?restart_block?*restart;
6????struct?futex_hash_bucket?*hb;
7????struct?futex_q?q?=?futex_q_init;
8????int?ret;
9
10????if?(!bitset)
11????????return?-EINVAL;
12????q.bitset?=?bitset;
13??/*?設(shè)置定時(shí)器?*/
14????to?=?futex_setup_timer(abs_time,?
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉