linux kernel的spinlock在armv7和armv8中的不同
生活随笔
收集整理的這篇文章主要介紹了
linux kernel的spinlock在armv7和armv8中的不同
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
- 在armv7中:spin_lock調(diào)用了wfe指令,讓cpu進入低功耗狀態(tài);在spin_unlock中調(diào)用了sev指令,讓cpu退出低功耗模式;
- 在armv8中,spin_lock調(diào)用了wfe指令,讓cpu進入低功耗狀態(tài); 在spin_unlock中確刪除了sev指令,為什么這樣呢?
我們在armv8的文檔中找到答案:
stlrh是帶有釋放語義的存儲指令,會改變global monitor的狀態(tài),等效于sevl指令
附上armv7和armv8的spin_lock和spin_unlock的底層代碼:
(armv7)
(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"); }總結(jié)
以上是生活随笔為你收集整理的linux kernel的spinlock在armv7和armv8中的不同的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [ARM-assembly]-A64的l
- 下一篇: [Skill]-Markdown编辑器技