日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

linux kernel的spinlock在armv7和armv8中的不同

發布時間:2025/3/21 linux 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 linux kernel的spinlock在armv7和armv8中的不同 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
  • 在armv7中:spin_lock調用了wfe指令,讓cpu進入低功耗狀態;在spin_unlock中調用了sev指令,讓cpu退出低功耗模式;
  • 在armv8中,spin_lock調用了wfe指令,讓cpu進入低功耗狀態; 在spin_unlock中確刪除了sev指令,為什么這樣呢?

我們在armv8的文檔中找到答案:

stlrh是帶有釋放語義的存儲指令,會改變global monitor的狀態,等效于sevl指令

附上armv7和armv8的spin_lock和spin_unlock的底層代碼:
(armv7)

(linux/arch/arm/asm/spinlock.h) static inline void arch_spin_lock(arch_spinlock_t *lock) {unsigned long tmp;u32 newval;arch_spinlock_t lockval;prefetchw(&lock->slock);__asm__ __volatile__( "1: ldrex %0, [%3]\n" " add %1, %0, %4\n" " strex %2, %1, [%3]\n" " teq %2, #0\n" " bne 1b": "=&r" (lockval), "=&r" (newval), "=&r" (tmp): "r" (&lock->slock), "I" (1 << TICKET_SHIFT): "cc");while (lockval.tickets.next != lockval.tickets.owner) {wfe();lockval.tickets.owner = ACCESS_ONCE(lock->tickets.owner);}smp_mb(); } static inline void arch_spin_unlock(arch_spinlock_t *lock) {smp_mb();lock->tickets.owner++;dsb_sev(); }

(armv8)

(linux/arch/arm64/asm/spinlock.h) static inline void arch_spin_lock(arch_spinlock_t *lock) {unsigned int tmp;arch_spinlock_t lockval, newval;asm volatile(/* Atomically increment the next ticket. */ARM64_LSE_ATOMIC_INSN(/* LL/SC */ " prfm pstl1strm, %3\n" "1: ldaxr %w0, %3\n" " add %w1, %w0, %w5\n" " stxr %w2, %w1, %3\n" " cbnz %w2, 1b\n",/* LSE atomics */ " mov %w2, %w5\n" " ldadda %w2, %w0, %3\n" " nop\n" " nop\n" " nop\n")/* Did we get the lock? */ " eor %w1, %w0, %w0, ror #16\n" " cbz %w1, 3f\n"/** No: spin on the owner. Send a local event to avoid missing an* unlock before the exclusive load.*/ " sevl\n" "2: wfe\n" " ldaxrh %w2, %4\n" " eor %w1, %w2, %w0, lsr #16\n" " cbnz %w1, 2b\n"/* We got the lock. Critical section starts here. */ "3:": "=&r" (lockval), "=&r" (newval), "=&r" (tmp), "+Q" (*lock): "Q" (lock->owner), "I" (1 << TICKET_SHIFT): "memory"); }static inline void arch_spin_unlock(arch_spinlock_t *lock) {unsigned long tmp;asm volatile(ARM64_LSE_ATOMIC_INSN(/* LL/SC */" ldrh %w1, %0\n"" add %w1, %w1, #1\n"" stlrh %w1, %0",/* LSE atomics */" mov %w1, #1\n"" nop\n"" staddlh %w1, %0"): "=Q" (lock->owner), "=&r" (tmp):: "memory"); }

總結

以上是生活随笔為你收集整理的linux kernel的spinlock在armv7和armv8中的不同的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美性猛交久久久乱大交小说 | 爆操欧美美女 | 欧美一级性生活视频 | 亚洲国产成人在线观看 | 日本久久成人 | 久久嫩草精品久久久久 | 欧美日韩亚洲在线观看 | 欧美一区二区黄片 | 国产精品老熟女一区二区 | 青青伊人国产 | 免费精品国产 | 夜夜嗨av一区二区三区 | 人妻熟女一区二区三区app下载 | 88av视频 | 伊人黄色 | 成人国产精品免费观看视频 | 亚洲免费在线视频 | 中文天堂在线视频 | 国产乱淫av一区二区三区 | 好吊一区二区三区 | 久久精品999| xxx在线视频| 穿扒开跪着折磨屁股视频 | 欧美黄大片 | 久久国产精品无码一区二区 | 日本三级视频在线播放 | 欧美视频在线观看免费 | 久久精品国产亚洲av高清色欲 | 老司机黄色片 | 国产精品高清在线观看 | 女人床技48动态图 | 九九热精品视频在线观看 | 超碰在线观看97 | 久久久久久久久久久久97 | 污污视频在线免费观看 | 欧美日韩国产一区二区在线观看 | 狠狠艹av | 免费男女视频 | 国产v片在线观看 | 国产一级生活片 | 久久一区二区三区四区五区 | 欧美变态另类刺激 | 57pao国产成永久免费视频 | 91精品国产一区二区三区蜜臀 | 国产一区二区三区视频免费在线观看 | 在线中出 | 日本丰满熟妇bbxbbxhd | 中文字幕高清在线免费播放 | 视频区小说区图片区 | 青青青在线观看视频 | 亚洲精品成a人在线观看 | 色秀视频在线观看 | 欧美日韩在线播放 | 人妻熟女一区二区aⅴ水 | 国产夫妻在线观看 | 日本高清视频在线播放 | 97黄色网| 最新天堂在线视频 | 高清av一区 | 性色浪潮av | 99久久99久久精品国产片 | 爱爱视频在线免费观看 | 不卡欧美 | 亚洲精品一区二区三区新线路 | 中文久久字幕 | 国产精品久久久久久久久久久久久久久久 | 欧美一级黄色录像 | 国产午夜毛片 | 色多多av | 女女同性女同一区二区三区按摩 | 精品黄色av| 日韩和欧美的一区二区 | 樱井莉亚av| 黄视频网站在线观看 | 免费看一级黄色大全 | 视频一区二区欧美 | av污在线观看 | 中文字幕资源站 | 3d动漫精品啪啪一区二区下载 | 欧洲成人午夜精品无码区久久 | 亚洲v欧美v| 免费人成网站 | 超碰在线看| 日本少妇电影 | 美女扒开腿免费视频 | 国产女人18水真多18精品一级做 | 国产人人干| 六月丁香啪啪 | 草av| 欧美在线色 | 女人被男人躁得好爽免费视频 | 日韩欧美一区二区三区视频 | 日本激情电影 | 欧美老司机 | 亚洲在线免费看 | 青春草国产视频 | 特级毛片在线观看 | 日韩精品人妻一区二区中文字幕 | 一区二区在线免费观看视频 |