l值的c的奇怪语法(在linux内核中:percpu)



all。

当我浏览Linux内核源代码时,我发现了以下片段:

per_cpu(zcache_dstmem, cpu) = NULL;

如果我查找per_cpu的定义,它是这样的:

#define VERIFY_PERCPU_PTR(__p) ({                       
        __verify_pcpu_ptr((__p));                       
        (typeof(*(__p)) __kernel __force *)(__p);       
})
#define per_cpu(var, cpu)       (*((void)(cpu), VERIFY_PERCPU_PTR(&(var))))

如果我解析预处理器,它变成:

*((void)(cpu), { __verify_pcpu_ptr(&zcache_dstmem); (typeof(zcache_dstmem) __kernel _-force *)(__p); }) = NULL

我有一种强烈的感觉,我错误地解析了它,不知道如何理解这个片段。有什么帮助吗?

缺少一个替换项。

*((void)(cpu), { __verify_pcpu_ptr(&zcache_dstmem); (typeof(zcache_dstmem) __kernel __force *)(&zcache_dstmem); }) = NULL

这是逗号操作中的语句表达式示例。块的结果是最后一个表达式。我不知道它对(void)(cpu)部分做了什么,但&zcache_dstmem看起来像是被设置为NULL?祝你好运!

相关内容

  • 没有找到相关文章

最新更新