色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

Linux中的傷害/等待互斥鎖介紹

Linux閱碼場 ? 來源:Linux驛站 ? 作者:szyhb1981 ? 2021-11-06 17:27 ? 次閱讀
序言:近期讀Linux 5.15的發(fā)布說明,該版本合并了實時鎖機制,當(dāng)開啟配置宏CONFIG_PREEMPT_RT的時候,這些鎖被基于實時互斥鎖的變體替代:mutex、ww_mutexrw_semaphorespinlock和rwlock。第一次聽說ww_mutex,在百度上查找的時候發(fā)現(xiàn)介紹文檔很少,于是自己學(xué)習(xí),寫成筆記。在某些場合必須同時持有多個鎖,并且獲取鎖的順序可能不同,為了避免死鎖,應(yīng)該使用傷害/等待互斥鎖(Wound/Wait Mutexes)。獲取一個鎖集合稱為一個事務(wù)(transaction),每個事務(wù)關(guān)聯(lián)一張門票(ticket),門票也稱為序列號,根據(jù)門票判斷哪個事務(wù)年輕。有2種處理死鎖的方法,如下。(1)等待-死亡(Wait-Die)算法:一個事務(wù)申請另一個事務(wù)已經(jīng)獲取的鎖的時候,如果持有鎖的事務(wù)年輕,那么申請鎖的事務(wù)等待(wait);如果持有鎖的事務(wù)年老,那么申請鎖的事務(wù)退并且死亡(die)

(2) 4.19版本開始支持傷害-等待(Wound-Wait)算法:一個事務(wù)申請另一個事務(wù)已經(jīng)獲取的鎖的時候,如果持有鎖的事務(wù)年輕,那么申請鎖的事務(wù)傷害(wound)持有鎖的事務(wù),請求它去死亡;如果持有鎖的事務(wù)年老,那么申請鎖的事務(wù)等待(wait)

假設(shè)進程1和進程2分別在2個處理器上運行,進程1獲取鎖A,進程2獲取鎖B,然后進程1申請鎖B,進程2申請鎖A。假設(shè)進程1的門票編號比進程2的門票編號小,也就是進程1年老,進程2年輕。假設(shè)選擇等待-死亡算法。年老的進程1申請鎖B,發(fā)現(xiàn)持有鎖B的進程2年輕,那么年老的進程1等待。年輕的進程2申請鎖A,發(fā)現(xiàn)持有鎖A的進程1年老,那么年輕的進程2死亡(即申請鎖的函數(shù)返回“-EDEADLK”),接著回滾(即釋放已經(jīng)獲取的鎖B),然后重新開始:先申請鎖A然后申請鎖B(必須改變申請順序,如果先申請鎖B,那么會把剛釋放的鎖B搶回來)。假設(shè)選擇傷害-等待算法。年老的進程1申請鎖B,發(fā)現(xiàn)持有鎖B的進程2年輕,那么傷害年輕的進程2,請求它死亡。年輕的進程2申請鎖A,發(fā)現(xiàn)持有鎖A的進程1年老,那么年輕的進程2等待,在收到進程1的死亡請求以后,年輕的進程2死亡(即申請鎖的函數(shù)返回“-EDEADLK”),接著回滾(即釋放已經(jīng)獲取的鎖B),然后重新開始:先申請鎖A然后申請鎖B。兩種算法都是公平的,因為其中一個事務(wù)最終會成功。和等待-死亡算法相比,傷害-等待算法生成的退避少,但是從一次退避恢復(fù)的時候要做更多的工作。傷害-等待算法是一種搶占性的算法(因為事務(wù)被其它事務(wù)傷害),需要一種可靠的方法來選擇受傷狀態(tài)和搶占正在運行的事務(wù)。在傷害-等待算法中,一個事務(wù)在受傷后死亡(返回“-EDEADLK”),就認為這個事務(wù)被搶占。如果競爭鎖的進程少,并且希望減少回滾的次數(shù),那么應(yīng)該選擇傷害-等待算法。 和普通的互斥鎖相比,傷害/等待互斥鎖增加了下面2個概念。

(1)獲取上下文acquire context):一個獲取上下文表示一個事務(wù),關(guān)聯(lián)一張門票(ticket),門票也稱為序列號,門票編號小表示年老,門票編號大表示年輕。獲取上下文跟蹤調(diào)試狀態(tài),捕獲對傷害/等待互斥鎖接口的錯誤使用。

(2)傷害/等待類初始化獲取上下文的時候需要指定鎖類,鎖類會給獲取上下文分配門票。鎖類也指定算法:等待-死亡(Wait-Die)或傷害-等待(Wound-Wait)。當(dāng)多個進程競爭同一個鎖集合的時候,它們必須使用相同的鎖類。

3種獲取傷害/等待互斥鎖的函數(shù),如下。

(1) 普通的獲取鎖函數(shù)ww_mutex_lock(),帶有獲取上下文。

(2) 進程在回滾(即釋放所有已經(jīng)獲取的鎖)以后,使用慢路徑獲取鎖函數(shù)ww_mutex_lock_slow()獲取正在競爭的鎖。帶有“_slow”后綴的函數(shù)不是必需的,因為可以調(diào)用函數(shù)ww_mutex_lock()獲取正在競爭的鎖。帶有“_slow”后綴的函數(shù)的優(yōu)點是接口安全,如下。

  • 函數(shù)ww_mutex_lock()有一個整數(shù)返回值,而函數(shù)ww_mutex_lock_slow()沒有返回值。
  • 當(dāng)開啟調(diào)試的時候,函數(shù)ww_mutex_lock_slow()檢查所有已經(jīng)獲取的鎖已經(jīng)被釋放,并且確保進程阻塞在正在競爭的鎖上面。

(3) 只獲取一個傷害/等待互斥鎖,和獲取普通的互斥鎖完全相同。調(diào)用函數(shù)ww_mutex_lock(),把獲取上下文指定為空指針。

傷害/等待互斥鎖的使用方法如下。

(1) 定義一個鎖類,鎖類在初始化獲取上下文的時候需要,鎖類也指定算法:等待-死亡(Wait-Die)或傷害-等待(Wound-Wait)。

/* 指定等待-死亡算法 */static DEFINE_WD_CLASS(my_class);
/* 指定傷害-等待算法 */staticDEFINE_WW_CLASS(my_class);

(2) 初始化一個獲取上下文,鎖類會給獲取上下文分配一張門票。

void ww_acquire_init(struct ww_acquire_ctx *ctx, struct ww_class *ww_class);
(3) 獲取鎖,返回0表示獲取成功,返回“-EDEADLK”表示檢測出死鎖。
int ww_mutex_lock(struct ww_mutex *lock, struct ww_acquire_ctx *ctx);
(4) 獲取需要的所有鎖以后,標記獲取階段結(jié)束。目前這個函數(shù)沒有執(zhí)行任何操作,但是將來可能改變。
void ww_acquire_done(struct ww_acquire_ctx *ctx);
(5) 釋放鎖。
void ww_mutex_unlock(struct ww_mutex *lock);
(6) 釋放所有鎖以后,釋放獲取上下文。
void ww_acquire_fini(struct ww_acquire_ctx *ctx);

下面是一個例子,注意:調(diào)用函數(shù)ww_mutex_lock()申請鎖失敗以后,應(yīng)該先釋放已經(jīng)獲取的鎖,然后調(diào)用慢路徑函數(shù)ww_mutex_lock_slow()獲取正在競爭的鎖,最后獲取其它鎖。重新開始申請鎖的時候必須改變申請順序,因為如果按照原來的順序申請鎖,那么會把剛釋放的鎖搶回來。
/* 第1步:定義鎖類,指定傷害-等待算法。*/static DEFINE_WW_CLASS(ww_class);
struct obj {  struct ww_mutex lock;  /* obj data */};
struct obj_entry {  struct list_head head;  struct obj *obj;};
int lock_objs(struct list_head *list, struct ww_acquire_ctx *ctx){  struct obj *res_obj = NULL;  struct obj_entry *contended_entry = NULL;  struct obj_entry *entry;  int ret;
  /* 第2步:初始化獲取上下文。*/  ww_acquire_init(ctx, &ww_class);
  /* 第3步:獲取鎖。*/retry:  list_for_each_entry(entry, list, head) {    if (entry->obj == res_obj) {      res_obj = NULL;      continue;    }
    ret = ww_mutex_lock(&entry->obj->lock, ctx);    if (ret < 0) {      contended_entry = entry;      goto err;    }  }
  /* 第4步:標記獲取階段結(jié)束。*/  ww_acquire_done(ctx);  return 0;
err:  /* 回滾,釋放已經(jīng)獲取的鎖。*/  list_for_each_entry_continue_reverse(entry, list, head) {    ww_mutex_unlock(&entry->obj->lock);  }
  if (res_obj) {    ww_mutex_unlock(&res_obj->lock);  }
  if (ret == -EDEADLK) {    /* 使用慢路徑獲取鎖函數(shù)獲取正在競爭的鎖。*/    ww_mutex_lock_slow(&contended_entry->obj->lock, ctx);    res_obj = contended_entry->obj;    /* 獲取其它鎖。*/    goto retry;  }  ww_acquire_fini(ctx);
  return ret;}
void unlock_objs(struct list_head *list, struct ww_acquire_ctx *ctx){  struct obj_entry *entry;
  /* 第5步:釋放鎖。*/  list_for_each_entry (entry, list, head) {    ww_mutex_unlock(&entry->obj->lock);  }
  /* 第6步:釋放獲取上下文。*/  ww_acquire_fini(ctx);}
責(zé)任編輯:haq

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

    關(guān)注

    35

    文章

    585

    瀏覽量

    87781
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11310

    瀏覽量

    209597

原文標題:傷害/等待互斥鎖

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

收藏 人收藏

    評論

    相關(guān)推薦

    華納云監(jiān)視Linux磁盤IO性能命令:iotop,iostat,vmstat,atop,dstat,ioping

    以下介紹6個監(jiān)視 Linux 磁盤IO性能的命令(工具),它們分別是iotop、iostat、vmstat、atop、dstat、ioping,以下將附上簡單的使用方法。 前言 磁盤IO
    的頭像 發(fā)表于 10-24 14:43 ?183次閱讀

    詳解Linux的權(quán)限控制

    本章將和大家分享Linux的權(quán)限控制。廢話不多說,下面我們直接進入主題。
    的頭像 發(fā)表于 08-05 15:32 ?587次閱讀
    詳解<b class='flag-5'>Linux</b><b class='flag-5'>中</b>的權(quán)限控制

    存器電路的中間是什么元件

    存器電路概述 定義與功能 存器(Latch)是數(shù)字電路的一種基本存儲元件,用于存儲一個位(1或0)的狀態(tài)。它能夠在特定輸入脈沖電平作用下改變狀態(tài),并保持該狀態(tài)直到下一個脈沖電平到來。
    的頭像 發(fā)表于 07-23 11:29 ?377次閱讀

    互斥和自旋的實現(xiàn)原理

    保護共享資源不被多個線程同時訪問。它的實現(xiàn)原理主要包括以下幾個方面: 1. 的初始化 互斥鎖在創(chuàng)建時需要進行初始化,通常包括設(shè)置的狀態(tài)為“未鎖定”。在某些實現(xiàn),還需要初始化
    的頭像 發(fā)表于 07-10 10:07 ?498次閱讀

    自旋互斥的使用場景是什么

    自旋互斥是兩種常見的同步機制,它們在多線程編程中被廣泛使用。在本文中,我們將介紹自旋互斥
    的頭像 發(fā)表于 07-10 10:05 ?1017次閱讀

    B系列推拉自連接器介紹

    電子發(fā)燒友網(wǎng)站提供《B系列推拉自連接器介紹.pdf》資料免費下載
    發(fā)表于 07-01 13:09 ?0次下載

    小米汽車推出等待關(guān)懷計劃,為用戶送上暖心禮遇

    在如今的汽車市場,消費者對于交付周期的長短越來越敏感。為了回饋那些因車輛交付周期長而需要耐心等待的用戶,小米汽車近日在其APP更新推出了一項備受矚目的新政策——“
    的頭像 發(fā)表于 06-29 15:54 ?1708次閱讀

    介紹一種嵌入式Linux的錄音降噪方案

    降噪不僅只能從硬件入手,本文為您介紹一種嵌入式Linux的錄音降噪方案。該方案完全依靠軟件實現(xiàn),最大程度上降低投入。
    的頭像 發(fā)表于 05-21 11:52 ?565次閱讀

    四個2輸入互斥NOR門,帶開路集電極輸出數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《四個2輸入互斥NOR門,帶開路集電極輸出數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 05-14 09:36 ?0次下載
    四個2輸入<b class='flag-5'>互斥</b>NOR門,帶開路集電極輸出數(shù)據(jù)表

    關(guān)于FreeRTOS互斥量的用法求解

    會引起死,比如當(dāng)同一個任務(wù)多次搶占時, 最后還是得換到互斥量, 基于串口中斷發(fā)送模式, 希望使用互斥量來訪問串口的話 , 該如何釋放發(fā)送完成信號呢? 在中斷函數(shù)釋放
    發(fā)表于 04-24 08:03

    使用 PREEMPT_RT 在 Ubuntu 構(gòu)建實時 Linux 內(nèi)核

    的實時內(nèi)核補丁來完成。簡介我們曾介紹過在Ubuntu22.04啟用實時Linux內(nèi)核有多簡單,因為Canonical已將該內(nèi)核列為一個選項。但要為默認Linux內(nèi)
    的頭像 發(fā)表于 04-12 08:36 ?2529次閱讀
    使用 PREEMPT_RT 在 Ubuntu <b class='flag-5'>中</b>構(gòu)建實時 <b class='flag-5'>Linux</b> 內(nèi)核

    藍牙在智能的應(yīng)用

    科技的飛速發(fā)展,智能家居產(chǎn)品開始逐步步入人們的視線,智能燈具、智能門鎖等不斷冒出來,為生活帶來更多的便利性。所謂智能門鎖是在傳統(tǒng)機械的基礎(chǔ)上改進,在用戶安全、識別、管理性方面更加智能化簡單化的鎖具
    的頭像 發(fā)表于 03-08 15:04 ?577次閱讀

    RTThread4.1.1在spiflash上掛dfs文件系統(tǒng)報互斥錯誤的原因?

    最近使用gd32f450vg芯片,在SPI4接口上掛了gd25q32,想使用dfs文件系統(tǒng),gd25q32能夠正常的識別,顯示文件系統(tǒng)掛載正常,但是只要操作文件系統(tǒng)就會出現(xiàn)報錯,看像是互斥的問題,請問這個要從哪個方向查原因
    發(fā)表于 03-05 07:39

    如何解決Linux系統(tǒng)的網(wǎng)絡(luò)連接問題?

    如何解決Linux系統(tǒng)的網(wǎng)絡(luò)連接問題? Linux系統(tǒng)的網(wǎng)絡(luò)連接問題是常見的技術(shù)難題之一,通常涉及在Linux上配置網(wǎng)絡(luò)接口、解決網(wǎng)絡(luò)故
    的頭像 發(fā)表于 01-12 15:17 ?1006次閱讀

    信號量實現(xiàn)原理介紹

    除了原子操作,中斷屏蔽,自旋以及自旋的衍生之外,在Linux內(nèi)核還存在著一些其他同步互斥
    的頭像 發(fā)表于 01-10 09:07 ?1203次閱讀
    主站蜘蛛池模板: 海量激情文学| ZZoo兽2皇| 日韩免费一级毛片| 久久精品热99看二| 国产电影无码午夜在线播放| 中国比基尼美女| 校园女教师之禁区| 日日夜夜影院在线播放| 秘密教学26我们在做一次吧免费| 精品国产乱码久久久久久免费| 国产精品午夜小视频观看| 嘟嘟嘟在线视频免费观看高清中文| 97亚洲狠狠色综合久久位| 综合色就爱涩涩涩综合婷婷| 一个人免费播放高清在线观看| 亚洲精品久久一区二区三区四区| 私密按摩师在线观看 百度网盘| 日韩中文网| 日本伦子欲| 色偷偷在线视频| 武汉美女洗澡| 亚洲精品视频在线观看免费| 香蕉尹人综合精品| 亚洲精品资源网在线观看| 妖精视频在线观看高清| 伊人伊人伊人| 69式国产真人免费视频| 99久久久无码国产精品免费人妻| Chinesetube国产中文| 大地影院在线播放| 国产精品高清在线观看地址| 国产亚洲精品久久无亚洲| 久久高清免费视频| 暖暖视频在线观看高清...| 日本无码免费久久久精品| 午夜不卡av免费| 孕妇bbwbbwbbwbbw超清| JAPANRCEP老熟妇乱子伦视频| 超嫩校花被灌醉在线观看| 国产午夜精品理论片久久影视| 久久精品亚洲热综合一本奇米|