162306a36Sopenharmony_ci.. include:: ../disclaimer-zh_CN.rst 262306a36Sopenharmony_ci 362306a36Sopenharmony_ci:Original: Documentation/doc-guide/kernel-doc.rst 462306a36Sopenharmony_ci 562306a36Sopenharmony_ci:译者: 吴想成 Wu XiangCheng <bobwxc@email.cn> 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci编写kernel-doc注释 862306a36Sopenharmony_ci================== 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ciLinux内核源文件可以包含kernel-doc格式的结构化文档注释,用以描述代码的函数、 1162306a36Sopenharmony_ci类型和设计。将文档嵌入源文件更容易保持文档最新。 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci.. note:: 内核文档格式与javadoc、gtk-doc或Doxygen看似很相似,但由于历史原因, 1462306a36Sopenharmony_ci 实际有着明显的不同。内核源包含成千上万个kernel-doc注释。请坚持遵循 1562306a36Sopenharmony_ci 此处描述的风格。 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci.. note:: kernel-doc无法包含Rust代码:请参考 Documentation/rust/general-information.rst 。 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci从注释中提取kernel-doc结构,并从中生成适当的 `Sphinx C 域`_ 函数和带有锚点的 2062306a36Sopenharmony_ci类型描述。这些注释将被过滤以生成特殊kernel-doc高亮和交叉引用。详见下文。 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci.. _Sphinx C 域: http://www.sphinx-doc.org/en/stable/domains.html 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci使用 ``EXPORT_SYMBOL`` 或 ``EXPORT_SYMBOL_GPL`` 导出到可加载模块的每个函数都 2562306a36Sopenharmony_ci应该有一个kernel-doc注释。模块使用的头文件中的函数和数据结构也应该有 2662306a36Sopenharmony_cikernel-doc注释。 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci对于其他内核文件(未标记为 ``static`` )中外部可见的函数,提供kernel-doc格式 2962306a36Sopenharmony_ci的文档是一个很好的实践。我们也建议为私有(文件 ``static`` )程序提供kernel-doc 3062306a36Sopenharmony_ci格式的文档,以确保内核源代码布局的一致性。此建议优先级较低,由内核源文件的 3162306a36Sopenharmony_ci维护者自行决定。 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci如何格式化kernel-doc注释 3462306a36Sopenharmony_ci------------------------ 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_cikernel-doc注释用 ``/**`` 作为开始标记。 ``kernel-doc`` 工具将提取以这种方式 3762306a36Sopenharmony_ci标记的注释。注释其余部分的格式类似于一个普通的多行注释,左侧有一列星号,以 3862306a36Sopenharmony_ci``*/`` 行结束。 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci函数和类型的kernel-doc注释应该放在所描述的函数或类型之前,以便最大限度地提高 4162306a36Sopenharmony_ci更改代码的人同时更改文档的可能性。概述kernel-doc注释可以放在最顶部的任何地方。 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci用详细模式和不生成实际输出来运行 ``kernel-doc`` 工具,可以验证文档注释的格式 4462306a36Sopenharmony_ci是否正确。例如:: 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci scripts/kernel-doc -v -none drivers/foo/bar.c 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ci当请求执行额外的gcc检查时,内核构建将验证文档格式:: 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_ci make W=n 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci函数文档 5362306a36Sopenharmony_ci-------- 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci函数和函数式宏的kernel-doc注释的一般格式是:: 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci /** 5862306a36Sopenharmony_ci * 函数名() - 函数简要说明. 5962306a36Sopenharmony_ci * @参数1: 描述第一个参数. 6062306a36Sopenharmony_ci * @参数2: 描述第二个参数. 6162306a36Sopenharmony_ci * 可以为参数提供一段 6262306a36Sopenharmony_ci * 多行描述. 6362306a36Sopenharmony_ci * 6462306a36Sopenharmony_ci * 更详细的描述,进一步讨论函数 函数名(), 这可能对使用或修改它的人有用. 6562306a36Sopenharmony_ci * 以空注释行开始, 内部可以包含空注释行. 6662306a36Sopenharmony_ci * 6762306a36Sopenharmony_ci * 详细描述可以有多个段落. 6862306a36Sopenharmony_ci * 6962306a36Sopenharmony_ci * Context: 描述函数是否可以休眠, 它需要、释放或期望持有什么锁. 7062306a36Sopenharmony_ci * 可以写多行. 7162306a36Sopenharmony_ci * Return: 描述函数返回值. 7262306a36Sopenharmony_ci * 7362306a36Sopenharmony_ci * 返回值描述也可以有多个段落, 7462306a36Sopenharmony_ci * 并且应该放在注释块的末尾. 7562306a36Sopenharmony_ci */ 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci函数名后面的简短描述可以跨多行,并以参数描述、空注释行或注释块结尾结束。 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci函数参数 8062306a36Sopenharmony_ci~~~~~~~~ 8162306a36Sopenharmony_ci 8262306a36Sopenharmony_ci每个函数参数都应该按照顺序描述,紧跟在函数简要说明之后。不要在函数描述和参数 8362306a36Sopenharmony_ci之间,也不要在参数之间留空。 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci每个 ``@参数:`` 描述可以跨多行。 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_ci.. note:: 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci 如果 ``@参数`` 描述有多行,则说明的续行应该从上一行的同一列开始:: 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_ci * @参数: 较长说明 9262306a36Sopenharmony_ci * 的续行 9362306a36Sopenharmony_ci 9462306a36Sopenharmony_ci 或:: 9562306a36Sopenharmony_ci 9662306a36Sopenharmony_ci * @参数: 9762306a36Sopenharmony_ci * 较长说明 9862306a36Sopenharmony_ci * 的续行 9962306a36Sopenharmony_ci 10062306a36Sopenharmony_ci如果函数的参数数目可变,则需用kernel-doc格式对其进行描述:: 10162306a36Sopenharmony_ci 10262306a36Sopenharmony_ci * @...: 描述 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ci函数上下文 10562306a36Sopenharmony_ci~~~~~~~~~~ 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_ci可调用函数的上下文应该在 ``Context`` 节中描述。此节应该包括函数是休眠的还是 10862306a36Sopenharmony_ci可以从中断上下文调用的,以及它需要什么锁、释放什么锁和期望它的调用者持有什么 10962306a36Sopenharmony_ci锁。 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_ci例如:: 11262306a36Sopenharmony_ci 11362306a36Sopenharmony_ci * Context: Any context. 11462306a36Sopenharmony_ci * Context: Any context. Takes and releases the RCU lock. 11562306a36Sopenharmony_ci * Context: Any context. Expects <lock> to be held by caller. 11662306a36Sopenharmony_ci * Context: Process context. May sleep if @gfp flags permit. 11762306a36Sopenharmony_ci * Context: Process context. Takes and releases <mutex>. 11862306a36Sopenharmony_ci * Context: Softirq or process context. Takes and releases <lock>, BH-safe. 11962306a36Sopenharmony_ci * Context: Interrupt context. 12062306a36Sopenharmony_ci 12162306a36Sopenharmony_ci返回值 12262306a36Sopenharmony_ci~~~~~~ 12362306a36Sopenharmony_ci 12462306a36Sopenharmony_ci如有返回值,应在 ``Return`` 节中描述。 12562306a36Sopenharmony_ci 12662306a36Sopenharmony_ci.. note:: 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_ci #) 您提供的多行描述文本 *不会* 识别换行符,因此如果您想将某些文本预格式化, 12962306a36Sopenharmony_ci 如:: 13062306a36Sopenharmony_ci 13162306a36Sopenharmony_ci * Return: 13262306a36Sopenharmony_ci * 0 - OK 13362306a36Sopenharmony_ci * -EINVAL - invalid argument 13462306a36Sopenharmony_ci * -ENOMEM - out of memory 13562306a36Sopenharmony_ci 13662306a36Sopenharmony_ci 它们在最终文档中变成一行:: 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci Return: 0 - OK -EINVAL - invalid argument -ENOMEM - out of memory 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ci 因此,为了在需要的地方换行,您需要使用ReST列表,例如:: 14162306a36Sopenharmony_ci 14262306a36Sopenharmony_ci * Return: 14362306a36Sopenharmony_ci * * 0 - OK to runtime suspend the device 14462306a36Sopenharmony_ci * * -EBUSY - Device should not be runtime suspended 14562306a36Sopenharmony_ci 14662306a36Sopenharmony_ci #) 如果您提供的描述性文本中的行以某个后跟冒号的短语开头,则每一个这种短语 14762306a36Sopenharmony_ci 都将被视为新的节标题,可能会产生意料不到的效果。 14862306a36Sopenharmony_ci 14962306a36Sopenharmony_ci结构体、共用体、枚举类型文档 15062306a36Sopenharmony_ci---------------------------- 15162306a36Sopenharmony_ci 15262306a36Sopenharmony_ci结构体(struct)、共用体(union)、枚举(enum)类型kernel-doc注释的一般格式为:: 15362306a36Sopenharmony_ci 15462306a36Sopenharmony_ci /** 15562306a36Sopenharmony_ci * struct 结构体名 - 简要描述. 15662306a36Sopenharmony_ci * @成员1: 成员1描述. 15762306a36Sopenharmony_ci * @成员2: 成员2描述. 15862306a36Sopenharmony_ci * 可以为成员提供 15962306a36Sopenharmony_ci * 多行描述. 16062306a36Sopenharmony_ci * 16162306a36Sopenharmony_ci * 结构体的描述. 16262306a36Sopenharmony_ci */ 16362306a36Sopenharmony_ci 16462306a36Sopenharmony_ci可以用 ``union`` 或 ``enum`` 替换上面示例中的 ``struct`` ,以描述共用体或枚举。 16562306a36Sopenharmony_ci``成员`` 用于表示枚举中的元素或共用体成员。 16662306a36Sopenharmony_ci 16762306a36Sopenharmony_ci结构体名称后面的简要说明可以跨多行,并以成员说明、空白注释行或注释块结尾结束。 16862306a36Sopenharmony_ci 16962306a36Sopenharmony_ci成员 17062306a36Sopenharmony_ci~~~~ 17162306a36Sopenharmony_ci 17262306a36Sopenharmony_ci结构体、共用体和枚举的成员应以与函数参数相同的方式记录;它们后紧跟简短的描述, 17362306a36Sopenharmony_ci并且为多行。 17462306a36Sopenharmony_ci 17562306a36Sopenharmony_ci在结构体或共用体描述中,可以使用 ``private:`` 和 ``public:`` 注释标签。 17662306a36Sopenharmony_ci``private:`` 域内的字段不会列在生成的文档中。 17762306a36Sopenharmony_ci 17862306a36Sopenharmony_ci``private:`` 和 ``public:`` 标签必须紧跟在 ``/*`` 注释标记之后。可以选择是否 17962306a36Sopenharmony_ci在 ``:`` 和 ``*/`` 结束标记之间包含注释。 18062306a36Sopenharmony_ci 18162306a36Sopenharmony_ci例子:: 18262306a36Sopenharmony_ci 18362306a36Sopenharmony_ci /** 18462306a36Sopenharmony_ci * struct 张三 - 简短描述 18562306a36Sopenharmony_ci * @a: 第一个成员 18662306a36Sopenharmony_ci * @b: 第二个成员 18762306a36Sopenharmony_ci * @d: 第三个成员 18862306a36Sopenharmony_ci * 18962306a36Sopenharmony_ci * 详细描述 19062306a36Sopenharmony_ci */ 19162306a36Sopenharmony_ci struct 张三 { 19262306a36Sopenharmony_ci int a; 19362306a36Sopenharmony_ci int b; 19462306a36Sopenharmony_ci /* private: 仅内部使用 */ 19562306a36Sopenharmony_ci int c; 19662306a36Sopenharmony_ci /* public: 下一个是公有的 */ 19762306a36Sopenharmony_ci int d; 19862306a36Sopenharmony_ci }; 19962306a36Sopenharmony_ci 20062306a36Sopenharmony_ci嵌套的结构体/共用体 20162306a36Sopenharmony_ci~~~~~~~~~~~~~~~~~~~ 20262306a36Sopenharmony_ci 20362306a36Sopenharmony_ci嵌套的结构体/共用体可像这样记录:: 20462306a36Sopenharmony_ci 20562306a36Sopenharmony_ci /** 20662306a36Sopenharmony_ci * struct nested_foobar - a struct with nested unions and structs 20762306a36Sopenharmony_ci * @memb1: first member of anonymous union/anonymous struct 20862306a36Sopenharmony_ci * @memb2: second member of anonymous union/anonymous struct 20962306a36Sopenharmony_ci * @memb3: third member of anonymous union/anonymous struct 21062306a36Sopenharmony_ci * @memb4: fourth member of anonymous union/anonymous struct 21162306a36Sopenharmony_ci * @bar: non-anonymous union 21262306a36Sopenharmony_ci * @bar.st1: struct st1 inside @bar 21362306a36Sopenharmony_ci * @bar.st2: struct st2 inside @bar 21462306a36Sopenharmony_ci * @bar.st1.memb1: first member of struct st1 on union bar 21562306a36Sopenharmony_ci * @bar.st1.memb2: second member of struct st1 on union bar 21662306a36Sopenharmony_ci * @bar.st2.memb1: first member of struct st2 on union bar 21762306a36Sopenharmony_ci * @bar.st2.memb2: second member of struct st2 on union bar 21862306a36Sopenharmony_ci */ 21962306a36Sopenharmony_ci struct nested_foobar { 22062306a36Sopenharmony_ci /* Anonymous union/struct*/ 22162306a36Sopenharmony_ci union { 22262306a36Sopenharmony_ci struct { 22362306a36Sopenharmony_ci int memb1; 22462306a36Sopenharmony_ci int memb2; 22562306a36Sopenharmony_ci }; 22662306a36Sopenharmony_ci struct { 22762306a36Sopenharmony_ci void *memb3; 22862306a36Sopenharmony_ci int memb4; 22962306a36Sopenharmony_ci }; 23062306a36Sopenharmony_ci }; 23162306a36Sopenharmony_ci union { 23262306a36Sopenharmony_ci struct { 23362306a36Sopenharmony_ci int memb1; 23462306a36Sopenharmony_ci int memb2; 23562306a36Sopenharmony_ci } st1; 23662306a36Sopenharmony_ci struct { 23762306a36Sopenharmony_ci void *memb1; 23862306a36Sopenharmony_ci int memb2; 23962306a36Sopenharmony_ci } st2; 24062306a36Sopenharmony_ci } bar; 24162306a36Sopenharmony_ci }; 24262306a36Sopenharmony_ci 24362306a36Sopenharmony_ci.. note:: 24462306a36Sopenharmony_ci 24562306a36Sopenharmony_ci #) 在记录嵌套结构体或共用体时,如果结构体/共用体 ``张三`` 已命名,则其中 24662306a36Sopenharmony_ci 的成员 ``李四`` 应记录为 ``@张三.李四:`` 24762306a36Sopenharmony_ci 24862306a36Sopenharmony_ci #) 当嵌套结构体/共用体是匿名的时,其中的成员 ``李四`` 应记录为 ``@李四:`` 24962306a36Sopenharmony_ci 25062306a36Sopenharmony_ci行间注释文档 25162306a36Sopenharmony_ci~~~~~~~~~~~~ 25262306a36Sopenharmony_ci 25362306a36Sopenharmony_ci结构成员也可在定义时以行间注释形式记录。有两种样式,一种是单行注释,其中开始 25462306a36Sopenharmony_ci``/**`` 和结束 ``*/`` 位于同一行;另一种是多行注释,开头结尾各自位于一行,就 25562306a36Sopenharmony_ci像所有其他核心文档注释一样:: 25662306a36Sopenharmony_ci 25762306a36Sopenharmony_ci /** 25862306a36Sopenharmony_ci * struct 张三 - 简短描述. 25962306a36Sopenharmony_ci * @张三: 成员张三. 26062306a36Sopenharmony_ci */ 26162306a36Sopenharmony_ci struct 张三 { 26262306a36Sopenharmony_ci int 张三; 26362306a36Sopenharmony_ci /** 26462306a36Sopenharmony_ci * @李四: 成员李四. 26562306a36Sopenharmony_ci */ 26662306a36Sopenharmony_ci int 李四; 26762306a36Sopenharmony_ci /** 26862306a36Sopenharmony_ci * @王五: 成员王五. 26962306a36Sopenharmony_ci * 27062306a36Sopenharmony_ci * 此处,成员描述可以为好几段. 27162306a36Sopenharmony_ci */ 27262306a36Sopenharmony_ci int 王五; 27362306a36Sopenharmony_ci union { 27462306a36Sopenharmony_ci /** @儿子: 单行描述. */ 27562306a36Sopenharmony_ci int 儿子; 27662306a36Sopenharmony_ci }; 27762306a36Sopenharmony_ci /** @赵六: 描述@张三里面的结构体@赵六 */ 27862306a36Sopenharmony_ci struct { 27962306a36Sopenharmony_ci /** 28062306a36Sopenharmony_ci * @赵六.女儿: 描述@张三.赵六里面的@女儿 28162306a36Sopenharmony_ci */ 28262306a36Sopenharmony_ci int 女儿; 28362306a36Sopenharmony_ci } 赵六; 28462306a36Sopenharmony_ci }; 28562306a36Sopenharmony_ci 28662306a36Sopenharmony_ciTypedef文档 28762306a36Sopenharmony_ci----------- 28862306a36Sopenharmony_ci 28962306a36Sopenharmony_ciTypedef的kernel-doc文档注释的一般格式为:: 29062306a36Sopenharmony_ci 29162306a36Sopenharmony_ci /** 29262306a36Sopenharmony_ci * typedef 类型名称 - 简短描述. 29362306a36Sopenharmony_ci * 29462306a36Sopenharmony_ci * 类型描述. 29562306a36Sopenharmony_ci */ 29662306a36Sopenharmony_ci 29762306a36Sopenharmony_ci还可以记录带有函数原型的typedef:: 29862306a36Sopenharmony_ci 29962306a36Sopenharmony_ci /** 30062306a36Sopenharmony_ci * typedef 类型名称 - 简短描述. 30162306a36Sopenharmony_ci * @参数1: 参数1的描述 30262306a36Sopenharmony_ci * @参数2: 参数2的描述 30362306a36Sopenharmony_ci * 30462306a36Sopenharmony_ci * 类型描述. 30562306a36Sopenharmony_ci * 30662306a36Sopenharmony_ci * Context: 锁(Locking)上下文. 30762306a36Sopenharmony_ci * Return: 返回值的意义. 30862306a36Sopenharmony_ci */ 30962306a36Sopenharmony_ci typedef void (*类型名称)(struct v4l2_ctrl *参数1, void *参数2); 31062306a36Sopenharmony_ci 31162306a36Sopenharmony_ci高亮与交叉引用 31262306a36Sopenharmony_ci-------------- 31362306a36Sopenharmony_ci 31462306a36Sopenharmony_ci在kernel-doc注释的描述文本中可以识别以下特殊模式,并将其转换为正确的 31562306a36Sopenharmony_cireStructuredText标记和 `Sphinx C 域`_ 引用。 31662306a36Sopenharmony_ci 31762306a36Sopenharmony_ci.. attention:: 以下内容 **仅** 在kernel-doc注释中识别, **不会** 在普通的 31862306a36Sopenharmony_ci reStructuredText文档中识别。 31962306a36Sopenharmony_ci 32062306a36Sopenharmony_ci``funcname()`` 32162306a36Sopenharmony_ci 函数引用。 32262306a36Sopenharmony_ci 32362306a36Sopenharmony_ci``@parameter`` 32462306a36Sopenharmony_ci 函数参数的名称(未交叉引用,仅格式化)。 32562306a36Sopenharmony_ci 32662306a36Sopenharmony_ci``%CONST`` 32762306a36Sopenharmony_ci 常量的名称(未交叉引用,仅格式化)。 32862306a36Sopenharmony_ci 32962306a36Sopenharmony_ci````literal```` 33062306a36Sopenharmony_ci 预格式化文本块。输出将使用等距字体。 33162306a36Sopenharmony_ci 33262306a36Sopenharmony_ci 若你需要使用在kernel-doc脚本或reStructuredText中有特殊含义的字符,则此功能 33362306a36Sopenharmony_ci 非常有用。 33462306a36Sopenharmony_ci 33562306a36Sopenharmony_ci 若你需要在函数描述中使用类似于 ``%ph`` 的东西,这特别有用。 33662306a36Sopenharmony_ci 33762306a36Sopenharmony_ci``$ENVVAR`` 33862306a36Sopenharmony_ci 环境变量名称(未交叉引用,仅格式化)。 33962306a36Sopenharmony_ci 34062306a36Sopenharmony_ci``&struct name`` 34162306a36Sopenharmony_ci 结构体引用。 34262306a36Sopenharmony_ci 34362306a36Sopenharmony_ci``&enum name`` 34462306a36Sopenharmony_ci 枚举引用。 34562306a36Sopenharmony_ci 34662306a36Sopenharmony_ci``&typedef name`` 34762306a36Sopenharmony_ci Typedef引用。 34862306a36Sopenharmony_ci 34962306a36Sopenharmony_ci``&struct_name->member`` or ``&struct_name.member`` 35062306a36Sopenharmony_ci 结构体或共用体成员引用。交叉引用将链接到结构体或共用体定义,而不是直接到成员。 35162306a36Sopenharmony_ci 35262306a36Sopenharmony_ci``&name`` 35362306a36Sopenharmony_ci 泛类型引用。请首选上面描述的完整引用方式。此法主要是为了可能未描述的注释。 35462306a36Sopenharmony_ci 35562306a36Sopenharmony_ci从reStructuredText交叉引用 35662306a36Sopenharmony_ci~~~~~~~~~~~~~~~~~~~~~~~~~~ 35762306a36Sopenharmony_ci 35862306a36Sopenharmony_ci无需额外的语法来从reStructuredText文档交叉引用kernel-do注释中定义的函数和类型。 35962306a36Sopenharmony_ci只需以 ``()`` 结束函数名,并在类型之前写上 ``struct`` , ``union`` , ``enum`` 36062306a36Sopenharmony_ci或 ``typedef`` 。 36162306a36Sopenharmony_ci例如:: 36262306a36Sopenharmony_ci 36362306a36Sopenharmony_ci See foo(). 36462306a36Sopenharmony_ci See struct foo. 36562306a36Sopenharmony_ci See union bar. 36662306a36Sopenharmony_ci See enum baz. 36762306a36Sopenharmony_ci See typedef meh. 36862306a36Sopenharmony_ci 36962306a36Sopenharmony_ci若要在交叉引用链接中使用自定义文本,可以通过以下语法进行:: 37062306a36Sopenharmony_ci 37162306a36Sopenharmony_ci See :c:func:`my custom link text for function foo <foo>`. 37262306a36Sopenharmony_ci See :c:type:`my custom link text for struct bar <bar>`. 37362306a36Sopenharmony_ci 37462306a36Sopenharmony_ci有关更多详细信息,请参阅 `Sphinx C 域`_ 文档。 37562306a36Sopenharmony_ci 37662306a36Sopenharmony_ci总述性文档注释 37762306a36Sopenharmony_ci-------------- 37862306a36Sopenharmony_ci 37962306a36Sopenharmony_ci为了促进源代码和注释紧密联合,可以将kernel-doc文档块作为自由形式的注释,而 38062306a36Sopenharmony_ci不是函数、结构、联合、枚举或typedef的绑定kernel-doc。例如,这可以用于解释 38162306a36Sopenharmony_ci驱动程序或库代码的操作理论。 38262306a36Sopenharmony_ci 38362306a36Sopenharmony_ci这是通过使用带有节标题的 ``DOC:`` 节关键字来实现的。 38462306a36Sopenharmony_ci 38562306a36Sopenharmony_ci总述或高层级文档注释的一般格式为:: 38662306a36Sopenharmony_ci 38762306a36Sopenharmony_ci /** 38862306a36Sopenharmony_ci * DOC: Theory of Operation 38962306a36Sopenharmony_ci * 39062306a36Sopenharmony_ci * The whizbang foobar is a dilly of a gizmo. It can do whatever you 39162306a36Sopenharmony_ci * want it to do, at any time. It reads your mind. Here's how it works. 39262306a36Sopenharmony_ci * 39362306a36Sopenharmony_ci * foo bar splat 39462306a36Sopenharmony_ci * 39562306a36Sopenharmony_ci * The only drawback to this gizmo is that is can sometimes damage 39662306a36Sopenharmony_ci * hardware, software, or its subject(s). 39762306a36Sopenharmony_ci */ 39862306a36Sopenharmony_ci 39962306a36Sopenharmony_ci``DOC:`` 后面的标题用作源文件中的标题,但也用作提取文档注释的标识符。因此, 40062306a36Sopenharmony_ci文件中的标题必须是唯一的。 40162306a36Sopenharmony_ci 40262306a36Sopenharmony_ci包含kernel-doc注释 40362306a36Sopenharmony_ci================== 40462306a36Sopenharmony_ci 40562306a36Sopenharmony_ci文档注释可以被包含在任何使用专用kernel-doc Sphinx指令扩展的reStructuredText 40662306a36Sopenharmony_ci文档中。 40762306a36Sopenharmony_ci 40862306a36Sopenharmony_cikernel-doc指令的格式如下:: 40962306a36Sopenharmony_ci 41062306a36Sopenharmony_ci .. kernel-doc:: source 41162306a36Sopenharmony_ci :option: 41262306a36Sopenharmony_ci 41362306a36Sopenharmony_ci*source* 是相对于内核源代码树的源文件路径。 41462306a36Sopenharmony_ci支持以下指令选项: 41562306a36Sopenharmony_ci 41662306a36Sopenharmony_ciexport: *[source-pattern ...]* 41762306a36Sopenharmony_ci 包括 *source* 中使用 ``EXPORT_SYMBOL`` 或 ``EXPORT_SYMBOL_GPL`` 导出的所有 41862306a36Sopenharmony_ci 函数的文档,无论是在 *source* 中还是在 *source-pattern* 指定的任何文件中。 41962306a36Sopenharmony_ci 42062306a36Sopenharmony_ci 当kernel-doc注释被放置在头文件中,而 ``EXPORT_SYMBOL`` 和 ``EXPORT_SYMBOL_GPL`` 42162306a36Sopenharmony_ci 位于函数定义旁边时, *source-pattern* 非常有用。 42262306a36Sopenharmony_ci 42362306a36Sopenharmony_ci 例子:: 42462306a36Sopenharmony_ci 42562306a36Sopenharmony_ci .. kernel-doc:: lib/bitmap.c 42662306a36Sopenharmony_ci :export: 42762306a36Sopenharmony_ci 42862306a36Sopenharmony_ci .. kernel-doc:: include/net/mac80211.h 42962306a36Sopenharmony_ci :export: net/mac80211/*.c 43062306a36Sopenharmony_ci 43162306a36Sopenharmony_ciinternal: *[source-pattern ...]* 43262306a36Sopenharmony_ci 包括 *source* 中所有在 *source* 或 *source-pattern* 的任何文件中都没有使用 43362306a36Sopenharmony_ci ``EXPORT_SYMBOL`` 或 ``EXPORT_SYMBOL_GPL`` 导出的函数和类型的文档。 43462306a36Sopenharmony_ci 43562306a36Sopenharmony_ci 例子:: 43662306a36Sopenharmony_ci 43762306a36Sopenharmony_ci .. kernel-doc:: drivers/gpu/drm/i915/intel_audio.c 43862306a36Sopenharmony_ci :internal: 43962306a36Sopenharmony_ci 44062306a36Sopenharmony_ciidentifiers: *[ function/type ...]* 44162306a36Sopenharmony_ci 在 *source* 中包含每个 *function* 和 *type* 的文档。如果没有指定 *function* , 44262306a36Sopenharmony_ci 则 *source* 中所有函数和类型的文档都将包含在内。 44362306a36Sopenharmony_ci 44462306a36Sopenharmony_ci 例子:: 44562306a36Sopenharmony_ci 44662306a36Sopenharmony_ci .. kernel-doc:: lib/bitmap.c 44762306a36Sopenharmony_ci :identifiers: bitmap_parselist bitmap_parselist_user 44862306a36Sopenharmony_ci 44962306a36Sopenharmony_ci .. kernel-doc:: lib/idr.c 45062306a36Sopenharmony_ci :identifiers: 45162306a36Sopenharmony_ci 45262306a36Sopenharmony_cino-identifiers: *[ function/type ...]* 45362306a36Sopenharmony_ci 排除 *source* 中所有 *function* 和 *type* 的文档。 45462306a36Sopenharmony_ci 45562306a36Sopenharmony_ci 例子:: 45662306a36Sopenharmony_ci 45762306a36Sopenharmony_ci .. kernel-doc:: lib/bitmap.c 45862306a36Sopenharmony_ci :no-identifiers: bitmap_parselist 45962306a36Sopenharmony_ci 46062306a36Sopenharmony_cifunctions: *[ function/type ...]* 46162306a36Sopenharmony_ci 这是“identifiers”指令的别名,已弃用。 46262306a36Sopenharmony_ci 46362306a36Sopenharmony_cidoc: *title* 46462306a36Sopenharmony_ci 包含 *source* 中由 *title* 标题标识的 ``DOC:`` 文档段落。 *title* 中允许 46562306a36Sopenharmony_ci 空格;不要在 *title* 上加引号。 *title* 仅用作段落的标识符,不包含在输出中。 46662306a36Sopenharmony_ci 请确保在所附的reStructuredText文档中有适当的标题。 46762306a36Sopenharmony_ci 46862306a36Sopenharmony_ci 例子:: 46962306a36Sopenharmony_ci 47062306a36Sopenharmony_ci .. kernel-doc:: drivers/gpu/drm/i915/intel_audio.c 47162306a36Sopenharmony_ci :doc: High Definition Audio over HDMI and Display Port 47262306a36Sopenharmony_ci 47362306a36Sopenharmony_ci如果没有选项,kernel-doc指令将包含源文件中的所有文档注释。 47462306a36Sopenharmony_ci 47562306a36Sopenharmony_cikernel-doc扩展包含在内核源代码树中,位于 ``Documentation/sphinx/kerneldoc.py`` 。 47662306a36Sopenharmony_ci在内部,它使用 ``scripts/kernel-doc`` 脚本从源代码中提取文档注释。 47762306a36Sopenharmony_ci 47862306a36Sopenharmony_ci.. _kernel_doc_zh: 47962306a36Sopenharmony_ci 48062306a36Sopenharmony_ci如何使用kernel-doc生成手册(man)页 48162306a36Sopenharmony_ci----------------------------------- 48262306a36Sopenharmony_ci 48362306a36Sopenharmony_ci如果您只想使用kernel-doc生成手册页,可以从内核git树这样做:: 48462306a36Sopenharmony_ci 48562306a36Sopenharmony_ci $ scripts/kernel-doc -man \ 48662306a36Sopenharmony_ci $(git grep -l '/\*\*' -- :^Documentation :^tools) \ 48762306a36Sopenharmony_ci | scripts/split-man.pl /tmp/man 48862306a36Sopenharmony_ci 48962306a36Sopenharmony_ci一些旧版本的git不支持路径排除语法的某些变体。 49062306a36Sopenharmony_ci以下命令之一可能适用于这些版本:: 49162306a36Sopenharmony_ci 49262306a36Sopenharmony_ci $ scripts/kernel-doc -man \ 49362306a36Sopenharmony_ci $(git grep -l '/\*\*' -- . ':!Documentation' ':!tools') \ 49462306a36Sopenharmony_ci | scripts/split-man.pl /tmp/man 49562306a36Sopenharmony_ci 49662306a36Sopenharmony_ci $ scripts/kernel-doc -man \ 49762306a36Sopenharmony_ci $(git grep -l '/\*\*' -- . ":(exclude)Documentation" ":(exclude)tools") \ 49862306a36Sopenharmony_ci | scripts/split-man.pl /tmp/man 49962306a36Sopenharmony_ci 500