~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/translations/zh_CN/admin-guide/bootconfig.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 .. SPDX-License-Identifier: GPL-2.0
  2 
  3 .. include:: ../disclaimer-zh_CN.rst
  4 
  5 :Original: Documentation/admin-guide/bootconfig.rst
  6 
  7 :译者: 吴想成 Wu XiangCheng <bobwxc@email.cn>
  8 
  9 ========
 10 引导配置
 11 ========
 12 
 13 :作者: Masami Hiramatsu <mhiramat@kernel.org>
 14 
 15 概述
 16 ====
 17 
 18 引导配置扩展了现有的内核命令行,以一种更有效率的方式在引导内核时进一步支持
 19 键值数据。这允许管理员传递一份结构化关键字的配置文件。
 20 
 21 配置文件语法
 22 ============
 23 
 24 引导配置文件的语法采用非常简单的键值结构。每个关键字由点连接的单词组成,键
 25 和值由 ``=`` 连接。值以分号( ``;`` )或换行符( ``\n`` )结尾。数组值中每
 26 个元素由逗号( ``,`` )分隔。::
 27 
 28   KEY[.WORD[...]] = VALUE[, VALUE2[...]][;]
 29 
 30 与内核命令行语法不同,逗号和 ``=`` 周围允许有空格。
 31 
 32 关键字只允许包含字母、数字、连字符( ``-`` )和下划线( ``_`` )。值可包含
 33 可打印字符和空格,但分号( ``;`` )、换行符( ``\n`` )、逗号( ``,`` )、
 34 井号( ``#`` )和右大括号( ``}`` )等分隔符除外。
 35 
 36 如果你需要在值中使用这些分隔符,可以用双引号( ``"VALUE"`` )或单引号
 37 ( ``'VALUE'`` )括起来。注意,引号无法转义。
 38 
 39 键的值可以为空或不存在。这些键用于检查该键是否存在(类似布尔值)。
 40 
 41 键值语法
 42 --------
 43 
 44 引导配置文件语法允许用户通过大括号合并键名部分相同的关键字。例如::
 45 
 46  foo.bar.baz = value1
 47  foo.bar.qux.quux = value2
 48 
 49 也可以写成::
 50 
 51  foo.bar {
 52     baz = value1
 53     qux.quux = value2
 54  }
 55 
 56 或者更紧凑一些,写成::
 57 
 58  foo.bar { baz = value1; qux.quux = value2 }
 59 
 60 在这两种样式中,引导解析时相同的关键字都会自动合并。因此可以追加类似的树或
 61 键值。
 62 
 63 相同关键字的值
 64 --------------
 65 
 66 禁止两个或多个值或数组共享同一个关键字。例如::
 67 
 68  foo = bar, baz
 69  foo = qux  # !错误! 我们不可以重定义相同的关键字
 70 
 71 如果你想要更新值,必须显式使用覆盖操作符 ``:=`` 。例如::
 72 
 73  foo = bar, baz
 74  foo := qux
 75 
 76 这样 ``foo`` 关键字的值就变成了 ``qux`` 。这对于通过添加(部分)自定义引导
 77 配置来覆盖默认值非常有用,免于解析默认引导配置。
 78 
 79 如果你想对现有关键字追加值作为数组成员,可以使用 ``+=`` 操作符。例如::
 80 
 81  foo = bar, baz
 82  foo += qux
 83 
 84 这样, ``foo`` 关键字就同时拥有了 ``bar`` , ``baz`` 和 ``qux`` 。
 85 
 86 此外,父关键字下可同时存在值和子关键字。
 87 例如,下列配置是可行的。::
 88 
 89  foo = value1
 90  foo.bar = value2
 91  foo := value3 # 这会更新foo的值。
 92 
 93 注意,裸值不能直接放进结构化关键字中,必须在大括号外定义它。例如::
 94 
 95  foo {
 96      bar = value1
 97      bar {
 98          baz = value2
 99          qux = value3
100      }
101  }
102 
103 同时,关键字下值节点的顺序是固定的。如果值和子关键字同时存在,值永远是该关
104 键字的第一个子节点。因此如果用户先指定子关键字,如::
105 
106  foo.bar = value1
107  foo = value2
108 
109 则在程序(和/proc/bootconfig)中,它会按如下显示::
110 
111  foo = value2
112  foo.bar = value1
113 
114 注释
115 ----
116 
117 配置语法接受shell脚本风格的注释。注释以井号( ``#`` )开始,到换行符
118 ( ``\n`` )结束。
119 
120 ::
121 
122  # comment line
123  foo = value # value is set to foo.
124  bar = 1, # 1st element
125        2, # 2nd element
126        3  # 3rd element
127 
128 会被解析为::
129 
130  foo = value
131  bar = 1, 2, 3
132 
133 注意你不能把注释放在值和分隔符( ``,`` 或 ``;`` )之间。如下配置语法是错误的::
134 
135  key = 1 # comment
136        ,2
137 
138 
139 /proc/bootconfig
140 ================
141 
142 /proc/bootconfig是引导配置的用户空间接口。与/proc/cmdline不同,此文件内容以
143 键值列表样式显示。
144 每个键值对一行,样式如下::
145 
146  KEY[.WORDS...] = "[VALUE]"[,"VALUE2"...]
147 
148 
149 用引导配置引导内核
150 ==================
151 
152 用引导配置引导内核有两种方法:将引导配置附加到initrd镜像或直接嵌入内核中。
153 
154 *initrd: initial RAM disk,初始内存磁盘*
155 
156 将引导配置附加到initrd
157 ----------------------
158 
159 由于默认情况下引导配置文件是用initrd加载的,因此它将被添加到initrd(initramfs)
160 镜像文件的末尾,其中包含填充、大小、校验值和12字节幻数,如下所示::
161 
162  [initrd][bootconfig][padding][size(le32)][checksum(le32)][#BOOTCONFIG\n]
163 
164 大小和校验值为小端序存放的32位无符号值。
165 
166 当引导配置被加到initrd镜像时,整个文件大小会对齐到4字节。空字符( ``\0`` )
167 会填补对齐空隙。因此 ``size`` 就是引导配置文件的长度+填充的字节。
168 
169 Linux内核在内存中解码initrd镜像的最后部分以获取引导配置数据。由于这种“背负式”
170 的方法,只要引导加载器传递了正确的initrd文件大小,就无需更改或更新引导加载器
171 和内核镜像本身。如果引导加载器意外传递了更长的大小,内核将无法找到引导配置数
172 据。
173 
174 Linux内核在tools/bootconfig下提供了 ``bootconfig`` 命令来完成此操作,管理员
175 可以用它从initrd镜像中删除或追加配置文件。你可以用以下命令来构建它::
176 
177  # make -C tools/bootconfig
178 
179 要向initrd镜像添加你的引导配置文件,请按如下命令操作(旧数据会自动移除)::
180 
181  # tools/bootconfig/bootconfig -a your-config /boot/initrd.img-X.Y.Z
182 
183 要从镜像中移除配置,可以使用-d选项::
184 
185  # tools/bootconfig/bootconfig -d /boot/initrd.img-X.Y.Z
186 
187 然后在内核命令行上添加 ``bootconfig`` 告诉内核去initrd文件末尾寻找内核配置。
188 
189 将引导配置嵌入内核
190 ------------------
191 
192 如果你不能使用initrd,也可以通过Kconfig选项将引导配置文件嵌入内核中。在此情
193 况下,你需要用以下选项重新编译内核::
194 
195  CONFIG_BOOT_CONFIG_EMBED=y
196  CONFIG_BOOT_CONFIG_EMBED_FILE="/引导配置/文件/的/路径"
197 
198 ``CONFIG_BOOT_CONFIG_EMBED_FILE`` 需要从源码树或对象树开始的引导配置文件的
199 绝对/相对路径。内核会将其嵌入作为默认引导配置。
200 
201 与将引导配置附加到initrd一样,你也需要在内核命令行上添加 ``bootconfig`` 告诉
202 内核去启用内嵌的引导配置。
203 
204 注意,即使你已经设置了此选项,仍可用附加到initrd的其他引导配置覆盖内嵌的引导
205 配置。
206 
207 通过引导配置传递内核参数
208 ========================
209 
210 除了内核命令行,引导配置也可以用于传递内核参数。所有 ``kernel`` 关键字下的键
211 值对都将直接传递给内核命令行。此外, ``init`` 下的键值对将通过命令行传递给
212 init进程。参数按以下顺序与用户给定的内核命令行字符串相连,因此命令行参数可以
213 覆盖引导配置参数(这取决于子系统如何处理参数,但通常前面的参数将被后面的参数
214 覆盖)::
215 
216  [bootconfig params][cmdline params] -- [bootconfig init params][cmdline init params]
217 
218 如果引导配置文件给出的kernel/init参数是::
219 
220  kernel {
221    root = 01234567-89ab-cdef-0123-456789abcd
222  }
223  init {
224   splash
225  }
226 
227 这将被复制到内核命令行字符串中,如下所示::
228 
229  root="01234567-89ab-cdef-0123-456789abcd" -- splash
230 
231 如果用户给出的其他命令行是::
232 
233  ro bootconfig -- quiet
234 
235 则最后的内核命令行如下::
236 
237  root="01234567-89ab-cdef-0123-456789abcd" ro bootconfig -- splash quiet
238 
239 
240 配置文件的限制
241 ==============
242 
243 当前最大的配置大小是32KB,关键字总数(不是键值条目)必须少于1024个节点。
244 注意:这不是条目数而是节点数,条目必须消耗超过2个节点(一个关键字和一个值)。
245 所以从理论上讲最多512个键值对。如果关键字平均包含3个单词,则可有256个键值对。
246 在大多数情况下,配置项的数量将少于100个条目,小于8KB,因此这应该足够了。如果
247 节点数超过1024,解析器将返回错误,即使文件大小小于32KB。(请注意,此最大尺寸
248 不包括填充的空字符。)
249 无论如何,因为 ``bootconfig`` 命令在附加启动配置到initrd映像时会验证它,用户
250 可以在引导之前注意到它。
251 
252 
253 引导配置API
254 ===========
255 
256 用户可以查询或遍历键值对,也可以查找(前缀)根关键字节点,并在查找该节点下的
257 键值。
258 
259 如果您有一个关键字字符串,则可以直接使用 xbc_find_value() 查询该键的值。如果
260 你想知道引导配置里有哪些关键字,可以使用 xbc_for_each_key_value() 迭代键值对。
261 请注意,您需要使用 xbc_array_for_each_value() 访问数组的值,例如::
262 
263  vnode = NULL;
264  xbc_find_value("key.word", &vnode);
265  if (vnode && xbc_node_is_array(vnode))
266     xbc_array_for_each_value(vnode, value) {
267       printk("%s ", value);
268     }
269 
270 如果您想查找具有前缀字符串的键,可以使用 xbc_find_node() 通过前缀字符串查找
271 节点,然后用 xbc_node_for_each_key_value() 迭代前缀节点下的键。
272 
273 但最典型的用法是获取前缀下的命名值或前缀下的命名数组,例如::
274 
275  root = xbc_find_node("key.prefix");
276  value = xbc_node_find_value(root, "option", &vnode);
277  ...
278  xbc_node_for_each_array_value(root, "array-option", value, anode) {
279     ...
280  }
281 
282 这将访问值“key.prefix.option”的值和“key.prefix.array-option”的数组。
283 
284 锁是不需要的,因为在初始化之后配置只读。如果需要修改,必须复制所有数据和关键字。
285 
286 
287 函数与结构体
288 ============
289 
290 相关定义的kernel-doc参见:
291 
292  - include/linux/bootconfig.h
293  - lib/bootconfig.c

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php