本文基于5.10.198版本。其实现与当前6.x系列实现有较大差别。
可以看到,在不支持SMP特性的实现上,代码非常简单:
在支持SMP特性的实现上,其代码实现如下。
首先,函数进入屏蔽中断并保存中断屏蔽状态,函数退出前恢复。
原子变量dump_lock在dump_stack没有被调用的时候是-1。在被调用的时候记录当前CPU的ID。
如果dump_stack之前没有被调用,was_locked变量置0。调用栈dump后恢复为-1。
如果在当前CPU上,dump_stack已经被调用了,还没有恢复为-1,允许在当前CPU上再次调用dump_stack。这样输出的信息可能会被截为两段。这种情况应该是前一个调用dump_stack的进程被抢占了。是的,该函数就是这样设计的。代码中的注释特别说明了这一点。
这种情况下was_locked变量置1。
最后一种情况是dump_stack已经在一颗CPU上被调用了,其他CPU在这个时候也调用了这个函数,那就只能等待了。