chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

ARM系列--同步原語

安芯教育科技 ? 來源:老秦談芯 ? 2023-01-05 14:18 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在具有多個執(zhí)行線程的系統(tǒng)中,某些資源可能不能同時被訪問或者修改。這些資源可以是外圍設(shè)備或內(nèi)存緩沖區(qū)和數(shù)據(jù)結(jié)構(gòu),例如打印機不會在一個時刻響應(yīng)多個訪問。這就需要一些同步機制去處理這些資源的同時控制(concurrency control)問題。需要注意的是,這里說的“同步”,不是同時的意思,而是協(xié)同的意思。某個資源使用受限的情況下,你用完了我用,大家協(xié)同工作。

可以通過“鎖(lock)”機制來實現(xiàn)同步,對這些不能同時被訪問的共享資源提供一個鎖。線程在訪問這些資源之前必須先獲得鎖權(quán)限。這時,如果其它線程也想申請鎖,會發(fā)現(xiàn)鎖被占用,只能等待鎖被釋放。擁有鎖的線程在訪問結(jié)束后,必須釋放鎖,以便其它的線程可以繼續(xù)訪問。

可以使用內(nèi)存中的變量來實現(xiàn)簡單的鎖,該變量可以包含兩個值(狀態(tài)):LOCKED和UNLOCKED。進(jìn)程如果發(fā)現(xiàn)這個鎖是UNLOCKED狀態(tài),即可以修改為LOCKED,并擁有該資源的訪問權(quán)限。

5a0693ee-8cb5-11ed-bfe3-dac502259ad0.png

圖中的整個過程分為三個步驟:

讀內(nèi)存中的變量,并做狀態(tài)比較;

修改寄存器值;

寫內(nèi)存變量。

在具有多個核或線程的系統(tǒng)中,此方法容易受到另一個線程的攻擊,即在變量值的第一次讀取和回寫之間修改內(nèi)存中的值。

這個問題可以用軟件解決,也可以用額外的硬件功能來解決。一種解決方案可以是使“讀-比較-修改-寫(read-compare-modify-write)”的原子操作指令。ARM架構(gòu)的早期版本使用SWP指令實現(xiàn)類似的功能。

ARMv8-A使用下面要介紹的,一種特殊類型的加載和存儲指令來檢測內(nèi)存中的值自上次讀取以來是否發(fā)生了變化。ARMv8-A 64位指令集提供了兩條獨占指令LDXR(Load Exclusive)和STXR(Store Exclusive)。

當(dāng)使用LDXR指令讀取地址時,會將其標(biāo)記為獨占訪問。如果使用STXR指令向標(biāo)記為獨占的地址寫入,則會清除獨占狀態(tài)。嘗試使用STXR指令向未標(biāo)記為獨占的地址寫入將會失敗。地址的獨占狀態(tài)由稱為獨占監(jiān)視器(Exclusive Monitor)的硬件維護(hù)。

使用獨占load/store后的鎖實現(xiàn):

5a2e9326-8cb5-11ed-bfe3-dac502259ad0.png

鎖值的更新不能保證是原子的,但現(xiàn)在可以檢測到初始讀取和更新之間的任何更改。如果獨占存儲失敗,軟件可以再次嘗試獲取鎖。

前面提到過,需要對標(biāo)記為獨占的地址進(jìn)行監(jiān)控。獨占監(jiān)視器可以是一個簡單的狀態(tài)機,其狀態(tài)可以是開放的(open)和獨占的(exclusive)。ARM架構(gòu)定義了兩種不同的狀態(tài)機:本地獨占監(jiān)視器(Local Exclusive Monitor)和全局獨占監(jiān)視器(Global Exclusive Monitor)。

根據(jù)被訪問地址的可共享性屬性,檢查本地監(jiān)視器或全局監(jiān)視器的獨占訪問。

對于Non-shareable地址的獨占訪問檢查僅在本地獨監(jiān)視器。

對shareable地址的獨占訪問檢查在本地監(jiān)視器或全局監(jiān)視器。

每個處理器核都有一個與其關(guān)聯(lián)的本地監(jiān)視器。本地監(jiān)視器可以構(gòu)造為保存特定地址的獨占狀態(tài),也可以構(gòu)造為不保存該地址。本地監(jiān)視器作為處理器的一部分實現(xiàn)。

全局監(jiān)視器在多個處理器核之間共享。與本地監(jiān)視器一樣,它們只需要監(jiān)視一個地址,如果監(jiān)視器可以標(biāo)記多個地址,則每個地址都有自己的狀態(tài)機。

ARM體系結(jié)構(gòu)要求以下內(nèi)存類型能夠與全局監(jiān)視器一起工作:

5a3a7c36-8cb5-11ed-bfe3-dac502259ad0.png

如果程序無法獲得鎖,會不斷嘗試申請鎖。但是這樣會浪費處理器的資源,并且消耗不必要的功耗。有幾種方式可以改善這個問題。對于在釋放鎖之前等待時間相對較長的情況,鎖代碼可以返回給操作系統(tǒng)調(diào)度程序,這允許在釋放鎖之前調(diào)度其它線程。

對于鎖可能快速被釋放的情況,ARM架構(gòu)有一種機制,即允許處理器暫停執(zhí)行,進(jìn)入低功耗模式,等待鎖被釋放。ARM提供WFE(Wait For Event)指令,如果處理器申請鎖失敗,程序可以執(zhí)行WFE進(jìn)入等待。以前的做法是,負(fù)責(zé)釋放鎖的代碼中會執(zhí)行SEV(Send Event)指令,通過發(fā)送EVENT喚醒正在等待鎖資源的處理器核。現(xiàn)在ARMv8-A架構(gòu)中,清除全局監(jiān)視器會自動向所有連接的處理器核發(fā)送EVENT喚醒。

審核編輯 :李倩

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

    關(guān)注

    135

    文章

    9452

    瀏覽量

    385819
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5495

    瀏覽量

    127816
  • 變量
    +關(guān)注

    關(guān)注

    0

    文章

    615

    瀏覽量

    29286

原文標(biāo)題:技術(shù)分享 | ARM系列 -- 同步原語

文章出處:【微信號:Ithingedu,微信公眾號:安芯教育科技】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

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

    請問如何為 NuMicro? M451 系列中的 PWM 設(shè)置計數(shù)器同步?

    如何為 NuMicro? M451 系列中的 PWM 設(shè)置計數(shù)器同步
    發(fā)表于 08-29 06:48

    一文了解Arm神經(jīng)超級采樣 (Arm Neural Super Sampling, Arm NSS) 深入探索架構(gòu)、訓(xùn)練和推理

    本文將從訓(xùn)練、網(wǎng)絡(luò)架構(gòu)到后處理和推理等方面,深入探討 Arm 神經(jīng)超級采樣 (Arm Neural Super Sampling, Arm NSS) 的工作原理,希望為機器學(xué)習(xí) (ML) 工程師和移動端圖形開發(fā)者來詳細(xì)解釋
    的頭像 發(fā)表于 08-14 16:11 ?2245次閱讀

    ARM Mali GPU 深度解讀

    ARM Mali GPU 深度解讀 ARM Mali 是 Arm 公司面向移動設(shè)備、嵌入式系統(tǒng)和基礎(chǔ)設(shè)施市場設(shè)計的圖形處理器(GPU)IP 核,憑借其異構(gòu)計算架構(gòu)、能效優(yōu)化和生態(tài)協(xié)同,成為全球移動
    的頭像 發(fā)表于 05-29 10:12 ?2318次閱讀

    Arm 公司面向 PC 市場的 ?Arm Niva? 深度解讀

    面向 PC 市場的 ? Arm Niva ? 深度解讀 ? Arm Niva ? 是 Arm 公司為 PC 市場推出的核心計算平臺,屬于其“平臺優(yōu)先”戰(zhàn)略的關(guān)鍵布局。作為 ? Arm
    的頭像 發(fā)表于 05-29 09:56 ?1147次閱讀

    AD463x-24系列是否支持多個芯片同步采集信號?

    想詢問AD463x-24系列是否支持多個芯片同步采集信號,我現(xiàn)在有四個電壓信號需要同步采集,能否用兩片AD4630-24芯片同步采樣?如果可以的話,可以描敘一下具體是如何實現(xiàn)的嗎。如果
    發(fā)表于 04-28 06:09

    Arm助力開發(fā)者加速遷移至Arm架構(gòu)云平臺 Arm云遷移資源分享

    隨著基于 Arm 架構(gòu)的云實例日益擴展,越來越多的用戶正從傳統(tǒng)平臺遷移至 Arm 平臺上。
    的頭像 發(fā)表于 04-09 18:23 ?920次閱讀

    一文認(rèn)識ARM微控制器及瑞薩RA系列MCU

    俗稱單片機,如果有學(xué)過微機原理就會很熟悉這個概念了。而ARM微控制器,顧名思義,就是基于ARM的微控制器,或者說搭載了ARM處理器內(nèi)核的微控制器。
    的頭像 發(fā)表于 03-24 09:17 ?2012次閱讀
    一文認(rèn)識<b class='flag-5'>ARM</b>微控制器及瑞薩RA<b class='flag-5'>系列</b>MCU

    ISERDESE2原語端口及參數(shù)介紹

    前面在講解HDMI接口之前,講解過IDDR、ODDR、OSERDESE2、IBUF等原語,之后一直有讀者在問什么時候更新ISERDESE2這個原語。前文講解過這些原語都在HDMI或者RGMII中使用過,但是ISERDESE2這個
    的頭像 發(fā)表于 03-17 10:52 ?1934次閱讀
    ISERDESE2<b class='flag-5'>原語</b>端口及參數(shù)介紹

    消息稱Arm準(zhǔn)備提高授權(quán)許可費用

    調(diào)整授權(quán)許可費用。這一舉措預(yù)計將對三星Exynos芯片的未來發(fā)展產(chǎn)生重大影響。 三星曾有自己的定制CPU內(nèi)核研發(fā)團(tuán)隊,但因功耗和性能問題,2019年解散該團(tuán)隊,轉(zhuǎn)而采用Arm的公版設(shè)計。 原本三星計劃在Galaxy S26系列中“大量使用”改進(jìn)后的Exynos 2600芯
    的頭像 發(fā)表于 01-22 15:37 ?571次閱讀

    Arm原生Google Chrome增強Windows on Arm性能

    微軟 Windows 10 和 Windows 11 集成了 Arm 原生支持,這保證了為 Windows 開發(fā)更多 Arm 原生應(yīng)用。這種支持提供了額外的工具,以簡化應(yīng)用移植、增強應(yīng)用性能并降低功耗。因此,很多公司目前正在為 Windows 投資
    的頭像 發(fā)表于 12-17 10:25 ?1486次閱讀

    詳解CKS32F107xx系列的定時器同步功能

    CKS32F107xx系列部分定時器在內(nèi)部是相連的,可用于定時器同步或鏈接,方便用戶配置不同的同步模式,以便在電機控制、數(shù)據(jù)采集和PWM信號生成等應(yīng)用中,實現(xiàn)復(fù)雜的時間序列和多通道的同步
    的頭像 發(fā)表于 11-26 17:51 ?1284次閱讀
    詳解CKS32F107xx<b class='flag-5'>系列</b>的定時器<b class='flag-5'>同步</b>功能

    以RK3568為例,ARM核心板如何實現(xiàn)NTP精準(zhǔn)時間同步?

    網(wǎng)絡(luò)時間協(xié)議NTP(Network TimeProtocol)是用于互聯(lián)網(wǎng)中時間同步的標(biāo)準(zhǔn)互聯(lián)網(wǎng)協(xié)議,可以把計算機的時間同步到某些時間標(biāo)準(zhǔn)。NTP對于我們產(chǎn)品來說有什么用呢,簡單的講,當(dāng)你的設(shè)備時間不準(zhǔn)確了,你可以接入到互聯(lián)網(wǎng),從網(wǎng)上
    的頭像 發(fā)表于 11-07 10:20 ?1099次閱讀
    以RK3568為例,<b class='flag-5'>ARM</b>核心板如何實現(xiàn)NTP精準(zhǔn)時間<b class='flag-5'>同步</b>?

    ARM開發(fā)板與樹莓派的比較

    處理器 ARM開發(fā)板通常采用不同的ARM處理器,如Cortex-A系列、Cortex-M系列等,而樹莓派則主要使用博通的ARM處理器。樹莓
    的頭像 發(fā)表于 11-05 11:11 ?1731次閱讀

    立錡科技推出ACOT同步降壓轉(zhuǎn)換器系列

    立錡針對筆記型電腦、網(wǎng)絡(luò)設(shè)備、平板電視等應(yīng)用,推出4.5V至23V輸入、8A/10A/12A的ACOT同步降壓轉(zhuǎn)換器系列,提供多樣功能組合供選擇,滿足不同應(yīng)用需求。
    的頭像 發(fā)表于 11-01 16:21 ?939次閱讀

    Arm全面設(shè)計助力Arm架構(gòu)生態(tài)發(fā)展

    Arm 控股有限公司(納斯達(dá)克股票代碼:ARM,以下簡稱 Arm)近日分享了Arm 全面設(shè)計 (Arm Total Design) 生態(tài)項目
    的頭像 發(fā)表于 10-21 09:58 ?1044次閱讀