国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux內(nèi)核中的jump label原理與邏輯及運(yùn)行過程

Linux閱碼場 ? 來源:CSDN技術(shù)社區(qū) ? 作者:dog250 ? 2021-03-25 14:02 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

jump label機(jī)制進(jìn)入Linux內(nèi)核已經(jīng)很多很多年了,它的目的是 消除分支。 為了達(dá)到這個目的,jump label的手段是 修改分支處的代碼。

~把代碼當(dāng)做數(shù)據(jù),代碼和數(shù)據(jù)在馮諾伊曼計算機(jī)中得到了統(tǒng)一~

本質(zhì)上,jump label作用于下面的邏輯:

e0bbcc26-8cdd-11eb-8b86-12bb97331649.png

靜態(tài)拆分成了下面的兩個邏輯,其一是:

e0e058fc-8cdd-11eb-8b86-12bb97331649.png

或者,其二是:

e12ea246-8cdd-11eb-8b86-12bb97331649.png

但二者不能同時共存。顯然,這破壞了通用性和靈活性,帶來了高效!

這相當(dāng)于一個硬熔斷,具體詳情參見:

本文來一點(diǎn)可以看得見的東西,演示一下真實(shí)的jump label & static key。

先看下面的C代碼:

e1519dc8-8cdd-11eb-8b86-12bb97331649.png

很簡單的代碼,也很正確。然而, 如果main函數(shù)是一個高頻調(diào)用的函數(shù),并且在E1,E2是不隨著代碼邏輯而發(fā)生變化,僅僅參數(shù)設(shè)定的情況下, 那么if語句盡量消除以消除不必要的分支預(yù)測,而這正是jump label的用武之地!

我們下面用jump label機(jī)制來重寫上面的代碼,請看:

e18ee192-8cdd-11eb-8b86-12bb97331649.png

e1e3bc44-8cdd-11eb-8b86-12bb97331649.png

e22b2692-8cdd-11eb-8b86-12bb97331649.png

e26cc53e-8cdd-11eb-8b86-12bb97331649.png

e2a16848-8cdd-11eb-8b86-12bb97331649.png

定義JUMP_LABEL宏編譯之,看看效果:

e2c8bb50-8cdd-11eb-8b86-12bb97331649.png

如何做到的呢?static_branch_true內(nèi)聯(lián)函數(shù)是如何判斷true or false的呢?

事實(shí)上,jump label邏輯修改了代碼段,取消了條件判斷!這一切都是在update_branch中發(fā)生的。我們看下update_branch調(diào)用之前,main函數(shù)的匯編碼:

e31df26e-8cdd-11eb-8b86-12bb97331649.png

在執(zhí)行了update_branch之后,main函數(shù)發(fā)生了變化:

e338ed80-8cdd-11eb-8b86-12bb97331649.png

e39d2124-8cdd-11eb-8b86-12bb97331649.png

看樣子就是這么回事!

之所以這件事可以發(fā)生得如此簡單,多虧了一個新的section,即__jump_table,我們通過objdump看看__jump_table的內(nèi)容:

e3e7c74c-8cdd-11eb-8b86-12bb97331649.png

通過jump_label_demo.c的struct entry結(jié)構(gòu)體,我們直到這個section中包含了多個3元組,包含3個字段:

需要修改的代碼地址。

需要jmp到的代碼地址。

匹配健。

我們看67064000 00000000按照小端就是0x400667,它就是需要修改的代碼地址,而6e064000 00000000按照小端則是0x40066e:

e41fa0e0-8cdd-11eb-8b86-12bb97331649.png

看來,這個__jump_table的item會將jmpq 40066c修改為jmpq 40066e,從而實(shí)現(xiàn)了 永久靜態(tài)分支。

最后,__jump_table的內(nèi)容就是在每一個內(nèi)聯(lián)的static_branch_true函數(shù)中被填充的,該參數(shù)的參數(shù)是一個key,它指示了branch entry三元組中的最后一個字段。

static_branch_true函數(shù)的內(nèi)聯(lián)非常重要,它實(shí)現(xiàn)了將branch entry三元組數(shù)據(jù)直接插入到__jump_table section,而不是共享同一個函數(shù)體。

總之,如果你看代碼還是覺得別扭,手敲一遍我上面的示例程序,就理解了,內(nèi)核里面的也就這么回事,總結(jié)一句話:

依靠運(yùn)行時修改代碼而不是依靠狀態(tài)數(shù)據(jù)來控制執(zhí)行流。

我不知道這對于所謂的 通用計算機(jī)程序設(shè)計 是不是反其道而行之,但在效果上,它確實(shí)是一匹好馬。不禁感嘆, 硬編碼讀起來是丑陋的,但執(zhí)行起來卻是高效的!

靈活性換高效率,得不償失,我是這樣以為。jump label的本質(zhì)在于, 將同時刻存在的一套代碼沿著時間線在可預(yù)期的固定時間點(diǎn)上分割成邏輯相反的兩套代碼。

硬件性能的提升將會證明jump label就是個笑話。

說兩句好話,Linux內(nèi)核參數(shù),sysctl變量基本上就可以通過jump label來運(yùn)作,從而替代if判斷。

原文鏈接:https://blog.csdn.net/dog250/article/details/106715700
編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    7335

    瀏覽量

    94755
  • 邏輯
    +關(guān)注

    關(guān)注

    2

    文章

    834

    瀏覽量

    30138
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4967

    瀏覽量

    73960
  • LINUX內(nèi)核
    +關(guān)注

    關(guān)注

    1

    文章

    321

    瀏覽量

    23202

原文標(biāo)題:Linux內(nèi)核jump label與static key的原理與示例

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    Linux內(nèi)核伙伴系統(tǒng)內(nèi)存申請函數(shù)詳解:從原理到實(shí)戰(zhàn)

    Linux 內(nèi)核,內(nèi)存管理是整個系統(tǒng)穩(wěn)定運(yùn)行的基石,而伙伴系統(tǒng)(Buddy System) 作為內(nèi)核物理內(nèi)存分配的核心機(jī)制,更是驅(qū)動開
    的頭像 發(fā)表于 02-10 16:58 ?3630次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>伙伴系統(tǒng)內(nèi)存申請函數(shù)詳解:從原理到實(shí)戰(zhàn)

    Linux內(nèi)核的“心跳”:jiffies如何為系統(tǒng)計時?

    Linux 內(nèi)核的世界里,有一個默默工作的 "計時器"——jiffies。它不像我們手機(jī)上的時鐘那樣顯示年月日,卻掌控著內(nèi)核絕大多數(shù)時間相關(guān)的操作:從進(jìn)程調(diào)度到設(shè)備驅(qū)動的定時檢查
    的頭像 發(fā)表于 02-04 16:27 ?816次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>的“心跳”:jiffies如何為系統(tǒng)計時?

    深入RK3588內(nèi)核:rockchip_linux_defconfig的作用與調(diào)試價值

    在 RK3588 芯片的 Linux 開發(fā),有一個文件始終是開發(fā)者繞不開的核心 ——kernel/arch/arm64/configs/rockchip_linux_defconfig。無論是首次
    的頭像 發(fā)表于 02-03 15:56 ?1156次閱讀
    深入RK3588<b class='flag-5'>內(nèi)核</b>:rockchip_<b class='flag-5'>linux</b>_defconfig的作用與調(diào)試價值

    深度解析ES8389/ES8390/音頻芯片Linux驅(qū)動(Linux6.1內(nèi)核

    基于 Linux6.1 內(nèi)核,從驅(qū)動架構(gòu)、寄存器配置、核心函數(shù)、數(shù)據(jù)流走向四個維度,完整拆解 ES8389 的 Linux 驅(qū)動實(shí)現(xiàn),幫你吃透這款芯片的驅(qū)動邏輯。 ? ? 注意:在講解
    的頭像 發(fā)表于 02-02 11:37 ?1327次閱讀
    深度解析ES8389/ES8390/音頻芯片<b class='flag-5'>Linux</b>驅(qū)動(<b class='flag-5'>Linux</b>6.1<b class='flag-5'>內(nèi)核</b>)

    Linux系統(tǒng)內(nèi)核參數(shù)調(diào)優(yōu)實(shí)戰(zhàn)指南

    Linux 內(nèi)核參數(shù)調(diào)優(yōu)是系統(tǒng)性能優(yōu)化的核心環(huán)節(jié)。隨著云原生架構(gòu)的普及和硬件性能的飛速提升,默認(rèn)的內(nèi)核參數(shù)配置往往無法充分發(fā)揮系統(tǒng)潛力。在高并發(fā) Web 服務(wù)、大數(shù)據(jù)處理、容器化部署等場景下,合理的
    的頭像 發(fā)表于 01-28 14:27 ?426次閱讀

    【「Linux 設(shè)備驅(qū)動開發(fā)(第 2 版)」閱讀體驗(yàn)】+讀深入理解Linux內(nèi)核內(nèi)存分配

    每個內(nèi)存地址是虛擬的,不是直接指向RAM的任何地址。當(dāng)用戶訪問內(nèi)存的存儲單元時,都會進(jìn)行地址轉(zhuǎn)換以匹配相應(yīng)的物理內(nèi)存。書籍的第10章討論了五個主題,對Linux內(nèi)核內(nèi)存分配進(jìn)行詳細(xì)
    發(fā)表于 01-16 20:05

    【「Linux 設(shè)備驅(qū)動開發(fā)(第 2 版)」閱讀體驗(yàn)】Linux內(nèi)核開發(fā)基礎(chǔ)

    感謝電子發(fā)燒友論壇提供的《Linux設(shè)備驅(qū)動開發(fā)(第2版)》閱讀機(jī)會,測評將從Linux內(nèi)核開發(fā)基礎(chǔ)、Linux內(nèi)核平臺抽象和設(shè)備驅(qū)動程序、
    發(fā)表于 01-12 22:45

    深入Linux內(nèi)核:進(jìn)程調(diào)度的核心邏輯與實(shí)現(xiàn)細(xì)節(jié)

    ,背后都離不開內(nèi)核調(diào)度算法的精準(zhǔn)操控。今天,我們就從優(yōu)先級、調(diào)度算法、時間片分配到底層實(shí)現(xiàn),全方位拆解Linux內(nèi)核進(jìn)程調(diào)度的核心邏輯。 一、進(jìn)程調(diào)度的“身份標(biāo)識”:優(yōu)先級與分類 要理
    的頭像 發(fā)表于 12-24 07:05 ?4299次閱讀
    深入<b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>:進(jìn)程調(diào)度的核心<b class='flag-5'>邏輯</b>與實(shí)現(xiàn)細(xì)節(jié)

    探索操作系統(tǒng)底層的關(guān)鍵接口

      在linux,將程序的運(yùn)行空間分為內(nèi)核空間與用戶空間(內(nèi)核態(tài)和用戶態(tài)),在邏輯上它們之間是
    的頭像 發(fā)表于 11-08 12:42 ?745次閱讀

    deepin亮相2025Linux內(nèi)核開發(fā)者大會

    11 月 1 日,第二十屆中國 Linux 內(nèi)核開發(fā)者大會(CLK)在深圳舉辦。CLK 作為國內(nèi) Linux 內(nèi)核領(lǐng)域極具影響力的峰會,由清華大學(xué)、Intel、華為、阿里云、富士通南大
    的頭像 發(fā)表于 11-05 17:59 ?817次閱讀

    使用rk3568開發(fā)板,核0\\1\\3運(yùn)行linux,核2運(yùn)行hal,在核0怎么關(guān)閉核2

    使用rk3568開發(fā)板,核0\\\\1\\\\3運(yùn)行linux,核2運(yùn)行hal,想在內(nèi)核通過smc指令完成核0對核2得啟動和關(guān)閉,文件系統(tǒng)
    發(fā)表于 10-27 10:09

    如何在裸機(jī)環(huán)境運(yùn)行KleidiAI微內(nèi)核

    ,對 KleidiAI 進(jìn)行了簡要概述,并附有相關(guān)指南鏈接,其中詳細(xì)說明了在 Linux 環(huán)境運(yùn)行 KleidiAI 矩陣乘法 (matmul) 微內(nèi)核的分步操作,這份指南內(nèi)容詳實(shí)且
    的頭像 發(fā)表于 08-08 15:16 ?3829次閱讀
    如何在裸機(jī)環(huán)境<b class='flag-5'>中</b><b class='flag-5'>運(yùn)行</b>KleidiAI微<b class='flag-5'>內(nèi)核</b>

    Linux內(nèi)核參數(shù)調(diào)優(yōu)方案

    在高并發(fā)微服務(wù)環(huán)境,網(wǎng)絡(luò)性能往往成為K8s集群的瓶頸。本文將深入探討如何通過精細(xì)化的Linux內(nèi)核參數(shù)調(diào)優(yōu),讓你的K8s節(jié)點(diǎn)網(wǎng)絡(luò)性能提升30%以上。
    的頭像 發(fā)表于 08-06 17:50 ?947次閱讀

    如何配置和驗(yàn)證Linux內(nèi)核參數(shù)

    Linux系統(tǒng)運(yùn)維和性能優(yōu)化內(nèi)核參數(shù)(sysctl)的配置至關(guān)重要。合理的參數(shù)調(diào)整可以顯著提升網(wǎng)絡(luò)性能、系統(tǒng)穩(wěn)定性及資源利用率。然而,僅僅修改參數(shù)是不夠的,如何驗(yàn)證這些參數(shù)是否生效同樣關(guān)鍵。
    的頭像 發(fā)表于 05-29 17:40 ?1150次閱讀

    樹莓派4 性能大比拼:標(biāo)準(zhǔn)Linux與實(shí)時Linux 4.19內(nèi)核的延遲測試

    使用的是raspberrypi/linux倉庫的rpi-4.19.y-rt分支。同樣,在測試,我使用了實(shí)時Linux項(xiàng)目中的cyclictest程序。Cyclictest程序
    的頭像 發(fā)表于 03-25 09:39 ?809次閱讀
    樹莓派4 性能大比拼:標(biāo)準(zhǔn)<b class='flag-5'>Linux</b>與實(shí)時<b class='flag-5'>Linux</b> 4.19<b class='flag-5'>內(nèi)核</b>的延遲測試