[英]How to add a counter in gcc asm?
在linux內核代碼中,當自旋鎖被鎖定時,spin_lock函數將旋轉。 spin_lock的代碼如下:
static __always_inline void __ticket_spin_lock(raw_spinlock_t *lock)
{
int inc = 0x00010000;
int tmp;
asm volatile(LOCK_PREFIX "xaddl %0, %1\n"
"movzwl %w0, %2\n\t"
"shrl $16, %0\n\t"
"1:\t"
"cmpl %0, %2\n\t"
"je 2f\n\t"
"rep ; nop\n\t"
"movzwl %1, %2\n\t"
/* don't need lfence here, because loads are in-order */
"jmp 1b\n"
"2:"
: "+r" (inc), "+m" (lock->slock), "=&r" (tmp)
:
: "memory", "cc");
}
我的問題是:
如何添加一個計時器來監視鎖的旋轉時間?請給我一些建議。
您可以使用rdtsc時間戳計數器來測量時間間隔,可以查看以下鏈接http://www.xml.com/ldd/chapter/book/ch06.html
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.