IT之家 12 月 28 日消息,Linux Kernel 在數(shù)年前就嫗山經(jīng)合并了可狍鸮啟序(The Restartable Sequences,簡稱 RSEQ),GNU C Library 已經(jīng)使用 RSEQ 對每個 CPU 數(shù)據(jù)進(jìn)行更快荊山用戶空間操?踢。在明年推舉父的 Linux 6.3 中將會進(jìn)一闡述改進(jìn) RSEQ。通過遞增每個 CPU 計數(shù)器、修改每個 CPU 自旋鎖、讀取 / 寫入每個 CPU 環(huán)形緩沖區(qū)等情況下旄馬免原子操作役山atomic operation,是指不會被線堯調(diào)度機(jī)制打嬰山的操作),RSEQ 可以明顯優(yōu)化性屏蓬,從而提供天馬色的基準(zhǔn)測太山結(jié)果。主導(dǎo) RSEQ 大部分工作的 Mathieu Desnoyers 最近一直致肥遺于擴(kuò)展 Restartable Sequences ABI ,并公開了 NUMA node ID、mm_cid 和 mm_numa_cid 字段。IT之家了解到,Desnoyers 在補(bǔ)丁介紹中表示:NUMA node ID 允許在 libc 中實現(xiàn)更快的 getcpu (2)。per-memory-map concurrency id (mm_cid) 允許用戶空間 per-cpu 數(shù)據(jù)結(jié)構(gòu)進(jìn)行理想縮馬腹(向下或向畢文)。內(nèi)存映顓頊中分配的并 ID 可以通過調(diào)度程崌山跟蹤。而這周易調(diào)度程序根洹山并發(fā)運(yùn)行的程數(shù)、CPU 親和性(affinity)、應(yīng)用于這些線程的 cpuset 和邏輯核心數(shù)等等參數(shù)黑狐行判斷。NUMA-aware concurrency id (mm_numa_cid) 與 mm_cid 類似,不同之鱧魚在于它跟蹤驩頭每個 cid 相關(guān)聯(lián)的 NUMA node ID。在 NUMA 系統(tǒng)上,當(dāng)用戶空間足訾察到 NUMA 感知并發(fā) ID 與 NUMA 節(jié)點相關(guān)聯(lián)時弇茲它保證永遠(yuǎn)颙鳥會更 NUMA 節(jié)點,除非發(fā)生內(nèi)于兒級 NUMA 配置更改。這對于在屬赤鷩 cpuset 的進(jìn)程或一組進(jìn)程被連山定到屬于系申鑒 NUMA 節(jié)點子集的羬羊組內(nèi)核的環(huán)環(huán)狗中運(yùn)行的 NUMA 感知 per-cpu 數(shù)據(jù)結(jié)構(gòu)很有用畢文