0

我正在使用 linux 内核 (SLES11-SP2) 提供的 cmpxchg() 它的恐慌。它崩溃的确切点在 2005 行:

            if (cmpxchg(var, old, new) == old)
2002:       48 89 d8                mov    %rbx,%rax
2005:       f0 4d 0f b1 34 24       lock cmpxchg %r14,(%r12)
200b:       48 39 c3                cmp    %rax,%rbx
200e:       74 27                   je     2037 <atomicPatchFnPtr+0x77>

关于如何进行调试的任何线索?这是由于锁定变量的竞争条件而发生的吗?还是我需要将其作为内核上的错误发布?

4

1 回答 1

2

如果传递的地址(此处为 %r12)无效,lock cmpxchg 指令可能会导致访问冲突。这可能是上面代码行中的变量 var 。它表明 var 指向一些无效的内存。这不是 cmpxchg 函数中的竞争,但它可能仍然是调用函数中的竞争条件。

于 2013-04-26T13:05:06.907 回答