日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

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


作者簡介


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

Google SwitchTo

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

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

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

什么是 futex

futex 全稱 fast user-space locking,快速用戶空間互斥鎖,作為內(nèi)核中一種基本的同步原語,它提供了非??焖俚臒o競爭鎖獲取和釋放,用于構(gòu)建復(fù)雜的同步結(jié)構(gòu):互斥鎖、條件變量、信號量等。由于 futex 的一些機制和使用過于復(fù)雜,glibc 沒有為 futex 提供包裝器,但我們?nèi)匀豢梢允褂?syscall 來調(diào)用這個 極其 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: 一個四字節(jié)的用戶空間地址。多個任務(wù)間可以通過 *uaddr 的值的變化來控制阻塞或者運行。

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

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

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

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

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

為什么 futex “快速”?

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

futex_wait() 和 futex_wake()

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

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

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è)置定時器?*/
14????to?=?futex_setup_timer(abs_time,?
本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉