Magellan Linux

Diff of /trunk/grubby/grubby.8

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2966 by niro, Wed Jun 29 14:53:04 2016 UTC revision 3148 by niro, Tue Jul 7 11:23:07 2020 UTC
# Line 1  Line 1 
1  .TH GRUBBY 8 "Tue Jan 18 2005"  .TH GRUBBY 8 "Tue Jan 18 2005"
2    
3  .SH NAME  .SH NAME
4  grubby \- command line tool for configuring grub, lilo, elilo, yaboot and zipl  
5    grubby \- command line tool used to configure bootloader menu entries across
6    multiple architectures
7    
8  .SH SYNOPSIS  .SH SYNOPSIS
9  \fBgrubby\fR [--add-kernel=\fIkernel-path\fR] [--args=\fIargs\fR]  
10         [--bad-image-okay] [--boot-filesystem=\fIbootfs\fR]  \fBgrubby\fR [\fIOPTIONS\fR]
        [--bootloader-probe] [--config-file \fIpath\fR] [--copy-default]  
        [--debug] [--default-kernel] [--default-index] [--default-title]  
        [--devtree=\fIdevicetree.dtb\fR]  
        [--grub] [--lilo] [--yaboot] [--silo] [--zipl]  
        [--info=\fIkernel-path\fR] [--initrd=\fIinitrd-path\fR]  
        [--make-default] [-o path] [--version]  
        [--remove-kernel=\fIkernel-path\fR] [--remove-args=\fIargs\fR]  
        [--set-default=\fIkernel-path\fR] [--set-default-index=\fientry-index\fR]  
        [--title=entry-title] [--add-multiboot=\fImultiboot-path\fR]  
        [--mbargs=\fIargs\fR] [--remove-multiboot=\fImultiboot-path\fR]  
        [--remove-mbargs=\fIargs\fR]  
11    
12  .SH DESCRIPTION  .SH DESCRIPTION
13    
14    .SS General Information
15    
16  \fBgrubby\fR is a command line tool for updating and displaying information  \fBgrubby\fR is a command line tool for updating and displaying information
17  about the configuration files for the \fBgrub\fR, \fBlilo\fR, \fBelilo\fR  about the configuration files for various architecture specific bootloaders.
18  (ia64), \fByaboot\fR (powerpc) and \fBzipl\fR (s390) boot loaders. It  It is primarily designed to be used from scripts which install new kernels
19  is primarily designed to be used from scripts which install new  and need to find information about the current boot environment.
20  kernels and need to find information about the current boot environment.  
21    .SS Architecture Support
22  On BIOS-based Intel x86 platforms, \fBgrub2\fR is the default bootloader and  
23  the configuration file is in \fB/boot/grub2/grub.cfg\fR.  On UEFI-based Intel  The \fBgrubby\fR executable has full support for the \fBgrub2\fR
24  x86 platforms, \fBgrub2\fR is the default bootloader, and the configuration  bootloader on \fBx86_64\fR systems using legacy BIOS or modern
25  file is in \fB/boot/efi/EFI/redhat/grub.cfg\fR.  On Intel ia64 platforms,  UEFI firmware and \fBppc64\fR and \fBppc64le\fR hardware using
26  \fBelilo\fR mode is used and the default location for the configuration file  OPAL or SLOF as firmware.
27  is \fB/boot/efi/EFI/redhat/elilo.conf\fR. On PowerPC platforms, systems based  
28  on Power8 now support \fBgrub2\fR as a bootloader and store using a default  Legacy \fBs390\fR and the current \fBs390x\fR architectures
29  config stored in \fB/boot/grub2/grub.cfg\fR. The earlier Power7 systems use \fByaboot\fR  and their \fBzipl\fR bootloader are fully supported.
30  parsing and the configuration file should be in \fB/etc/yaboot.conf\fR.  
31    Support for \fByaboot\fR has been deprecated as all ppc architecture
32    hardware since the Power8 uses \fBgrub2\fR or petitboot
33    which both use the grub2 configuration file format.
34    
35    Legacy bootloaders \fBLILO\fR, \fBSILO\fR, and \fBELILO\fR
36    are deprecated and no longer receiving active support in favor of
37    previously mentioned bootloaders.
38    
39    .SS Default Behavior
40    
41    The default bootloader target is primarily determined by the architecture
42    for which grubby has been built.  Each architecture has a preferred
43    bootloader, and each bootloader has its own configuration file.  If no
44    bootloader is selected on the command line, grubby will use these default
45    settings to search for an existing configuration.  If no bootloader
46    configuration file is found, grubby will use the default value for that
47    architecture.  These defaults are listed in the table below.
48    
49    .TS
50    allbox;
51    lbw6 lbw10 lbw18
52    l l l.
53     Arch Bootloader Configuration File
54     x86_64 [BIOS] grub2 /boot/grub2/grub.cfg
55     x86_64 [UEFI] grub2 /boot/efi/EFI/redhat/grub.cfg
56     i386 grub2 /boot/grub2/grub.cfg
57     ia64 elilo /boot/efi/EFI/redhat/elilo.conf
58     ppc [>=Power8] grub2 /boot/grub2/grub.cfg
59     ppc [<=Power7] yaboot /etc/yaboot.conf
60     s390 zipl /etc/zipl.conf
61     s390x zipl /etc/zipl.conf
62    .TE
63    
64    
65    .SS Special Arguments
66    
67  There are a number of ways to specify the kernel used for \fB-\-info\fR,  There are a number of ways to specify the kernel used for \fB-\-info\fR,
68  \fB-\-remove-kernel\fR, and \fB-\-update-kernel\fR. Specificying \fBDEFAULT\fR  \fB-\-remove-kernel\fR, and \fB-\-update-kernel\fR. Specifying \fBDEFAULT\fR
69  or \fBALL\fR selects the default entry and all of the entries, respectively.  or \fBALL\fR selects the default entry and all of the entries, respectively.
70  If a comma separated list of numbers is given, the boot entries indexed  If a comma separated list of numbers is given, the boot entries indexed
71  by those numbers are selected. Finally, the title of a boot entry may  by those numbers are selected. Finally, the title of a boot entry may
# Line 43  be specified by using \fBTITLE=\fItitle\ Line 73  be specified by using \fBTITLE=\fItitle\
73  with that title are used.  with that title are used.
74    
75  .SH OPTIONS  .SH OPTIONS
76    
77    .SS Basic Options
78    
79  .TP  .TP
80  \fB-\-add-kernel\fR=\fIkernel-path\fR  \fB-\-add-kernel\fR=\fIkernel-path\fR
81  Add a new boot entry for the kernel located at \fIkernel-path\fR.  Add a new boot entry for the kernel located at \fIkernel-path\fR. A title for
82    the boot entry must be set using \fB-\-title\fR. Most invocations should also
83    include \fB-\-initrd\fR with memtest86 as a notable exception.
84    
85    The \fB-\-update-kernel\fR option may not be used in the same invocation.
86    
87    .TP
88    \fB-\-remove-kernel\fR=\fIkernel-path\fR
89    Remove all boot entries which match \fIkernel-path\fR. This may be used
90    along with \fB-\-add-kernel\fR, in which case the new entry being added will
91    not be removed.
92    
93    .TP
94    \fB-\-update-kernel\fR=\fIkernel-path\fR
95    Update the entries for kernels matching \fRkernel-path\fR. Currently
96    the only item that can be updated is the kernel argument list, which is
97    modified via the \fB-\-args\fR and \fB-\-remove-args\fR options.
98    
99  .TP  .TP
100  \fB-\-args\fR=\fIkernel-args\fR  \fB-\-args\fR=\fIkernel-args\fR
# Line 60  file has special handling for specifying Line 109  file has special handling for specifying
109  lilo.conf does).  lilo.conf does).
110    
111  .TP  .TP
112  \fB-\-bad-image-okay\fR  \fB-\-remove-args\fR=\fIkernel-args\fR
113  When \fBgrubby\fR is looking for a entry to use for something (such  The arguments specified by \fIkernel-args\fR are removed from the
114  as a template or a default boot entry) it uses sanity checks, such as  kernels specified by \fB-\-update-kernel\fR. The \fBroot\fR argument
115  ensuring that the kernel exists in the filesystem, to make sure  gets special handling for configuration files that support separate root
116  entries that obviously won't work aren't selected. This option overrides  filesystem configuration.
 that behavior, and is designed primarily for testing.  
117    
118  .TP  .TP
119  \fB-\-boot-filesystem\fR=\fIbootfs\fR  \fB-\-copy-default\fR
120  The \fBgrub\fR boot loader expects file paths listed in it's configuration  \fBgrubby\fR will copy as much information (such as kernel arguments and
121  path to be relative to the top of the filesystem they are on, rather then  root device) as possible from the current default kernel. The kernel path
122  relative to the current root filesystem. By default \fBgrubby\fR searches  and initrd path will never be copied.
 the list of currently mounted filesystems to determine this. If this option  
 is given \fBgrubby\fR acts as if the specified filesystem was the filesystem  
 containing the kernel (this option is designed primarily for testing).  
123    
124  .TP  .TP
125  \fB-\-bootloader-probe\fR  \fB-\-title\fR=\fIentry-title\fR
126  \fBgrubby\fR tries to determine if \fBgrub\fR or \fBlilo\fR is currently  When a new kernel entry is added \fIentry-title\fR is used as the title
127  installed. When one of those bootloaders is found the name of that bootloader  (\fBlilo\fR label) for the entry. If \fIentry-title\fR is longer then maximum
128  is displayed on stdout.  Both could be installed (on different devices), and  length allowed by the bootloader (15 for lilo, unlimited for grub and elilo)
129  grubby will print out the names of both bootloaders, one per line. The probe  the title is shortened to a (unique) entry.
 for \fBgrub\fR requires a commented out boot directive \fBgrub.conf\fR  
 identical to the standard directive in the lilo configuration file. If this  
 is not present \fBgrubby\fR will assume grub is not installed (note  
 that \fBanaconda\fR places this directive in \fBgrub.conf\fR files it creates).  
 This option is only available on ia32 platforms.  
130    
131    .TP
132    \fB-\-initrd\fR=\fIinitrd-path\fR
133    Use \fIinitrd-path\fR as the path to an initial ram disk for a new kernel
134    being added.
135    
136  .TP  .TP
137  \fB-\-config-file\fR=\fIpath\fR  \fB-\-efi\fR
138  Use \fIpath\fR as the configuration file rather then the default.  Use appropriate bootloader commands for EFI on this architecture.
139    
140  .TP  .TP
141  \fB-\-copy-default\fR  \fB-\-set-default\fR=\fIkernel-path\fR
142  \fBgrubby\fR will copy as much information (such as kernel arguments and  The first entry which boots the specified kernel is made the default
143  root device) as possible from the current default kernel. The kernel path  boot entry. This may not be invoked with \fB-\-set-default-index\fR.
144  and initrd path will never be copied.  
145    .TP
146    \fB-\-set-default-index\fR=\fIentry-index\fR
147    Makes the given entry number the default boot entry. This may not be invoked
148    with \fB-\-set-default\fR.  The given value represents the index in the
149    post-modification boot entry list.
150    
151    .TP
152    \fB-\-make-default\fR
153    Make the new kernel entry being added the default entry.
154    
155    .TP
156    \fB-\-set-index\fR=\fIentry-index\fR
157    Set the position at which to add a new entry created with \fB-\-add-kernel\fR.
158    
159  .TP  .TP
160  \fB-\-debug\fR  \fB-\-debug\fR
161  Display extra debugging information for failures.  Display extra debugging information for failures.
162    
163  .TP  .TP
164    \fB-i\fR, \fB-\-extra-initrd\fR=\fIinitrd-path\fR
165    Use \fIinitrd-path\fR as the path for an auxiliary initrd image.
166    
167    .SS Display Options
168    
169    Passing the display option to grubby will cause it to print out the
170    requested information about the current bootloader configuration and
171    then immediately exit.  These options should not be used in any
172    script intended to update the bootloader configuration.
173    
174    .TP
175  \fB-\-default-kernel\fR  \fB-\-default-kernel\fR
176  Display the full path to the current default kernel and exit.  Display the full path to the current default kernel and exit.
177    
# Line 116  Display the numeric index of the current Line 184  Display the numeric index of the current
184  Display the title of the current default boot entry and exit.  Display the title of the current default boot entry and exit.
185    
186  .TP  .TP
187  \fB-\-devtree\fR=\fIpath\fR  \fB-\-info\fR=\fIkernel-path\fR
188  Use \fIpath\fR for device tree path in place of the path of any devicetree  Display information on all boot entries which match \fIkernel-path\fR. If
189  directive found in the template stanza.  \fIkernel-path\fR is \fBDEFAULT\fR, then information on the default kernel
190    is displayed. If \fIkernel-path\fR is \fBALL\fR, then information on all boot
191    entries are displayed.
192    
193    .TP
194    \fB-\-bootloader-probe\fR
195    Attempt to probe for installed bootloaders.  If this option is specified,
196    \fBgrubby\fR tries to determine if \fBgrub\fR or \fBlilo\fR is currently
197    installed. When one of those bootloaders is found the name of that
198    bootloader is displayed on stdout.  Both could be installed (on different
199    devices), and grubby will print out the names of both bootloaders, one per
200    line. The probe for \fBgrub\fR requires a commented out boot directive
201    \fBgrub.conf\fR identical to the standard directive in the lilo
202    configuration file. If this is not present \fBgrubby\fR will assume grub is
203    not installed (note that \fBanaconda\fR places this directive in
204    \fBgrub.conf\fR files it creates).
205    
206    \fIThis option is only available on x86 BIOS platforms.\fR
207    
208    .TP
209    \fB-v\fR, \fB-\-version\fR
210    Display the version of \fBgrubby\fR being run and then exit immediately.
211    
212    .SS Output Format Options
213    
214    Sane default options for the current platform are compiled into grubby on
215    a per platform basis. These defaults determine the format and layout of
216    the generated bootloader configuration file. A different configuration file
217    format may be specified on the command line if the system uses a supported
218    alternative bootloader.
219    
220  .TP  .TP
221  \fB-\-elilo\fR  \fB-\-elilo\fR
222  Use an \fBelilo\fR style configuration file.  Use an \fBelilo\fR style configuration file. This is the default on ia64
223    platforms. This format is deprecated.
224    
225  .TP  .TP
226  \fB-\-grub\fR  \fB-\-extlinux\fR
227  Use a \fBgrub\fR style configuration file instead of \fBlilo\fR style. This  Use an \fBextlinux\fR style configuration file. This format is deprecated.
 is the default on ia32 platforms.  
228    
229  .TP  .TP
230  \fB-\-info\fR=\fIkernel-path\fR  \fB-\-grub\fR
231  Display information on all boot entries which match \fIkernel-path\fR. I  Use a \fBgrub\fR style configuration file. This is the default on the i386
232    architecture.
233    
234  .TP  .TP
235  \fB-\-initrd\fR=\fIinitrd-path\fR  \fB-\-grub2\fR
236  Use \fIinitrd-path\fR as the path to an initial ram disk for a new kernel  Use a \fBgrub2\fR style configuration file. This is the default on
237  being added.  \fBx86_64\fR architecture as well as the \fBppc64\fR and \fBppc64le\fR
238    architectures running on Power8 or later hardware.
239    
240  .TP  .TP
241  \fB-\-lilo\fR  \fB-\-lilo\fR
242  Use a \fBlilo\fR style configuration file.  Use a \fBlilo\fR style configuration file.
243    
244  .TP  .TP
245  \fB-\-make-default\fR  \fB-\-silo\fR
246  Make the new kernel entry being added the default entry.  Use a \fBsilo\fR style configuration file. This is the default on SPARC
247    systems. This format is legacy, deprecated, and unsupported.
248    
249  .TP  .TP
250  \fB-\-remove-args\fR=\fIkernel-args\fR  \fB-\-yaboot\fR
251  The arguments specified by \fIkernel-args\fR are removed from the  Use a \fByaboot\fR style configuration file. This is the default for
252  kernels specified by \fB-\-update-kernel\fR. The \fBroot\fR argument  the \fBppc\fR architecture on on Power7 and earlier hardware.
 gets special handling for configuration files that support separate root  
 filesystem configuration.  
253    
254  .TP  .TP
255  \fB-\-remove-kernel\fR=\fIkernel-path\fR  \fB-\-zipl\fR
256  Removes all boot entries which match \fIkernel-path\fR. This may be used  Use a \fBzipl\fR style configuration file. This is the default on the
257  along with -\-add-kernel, in which case the new kernel being added will  legacy s390 and current s390x architectures.
258  never be removed.  
259    .SS Override Options
260    
261  .TP  .TP
262  \fB-\-set-default\fR=\fIkernel-path\fR  \fB-\-bad-image-okay\fR
263  The first entry which boots the specified kernel is made the default  When \fBgrubby\fR is looking for a entry to use for something (such
264  boot entry.  as a template or a default boot entry) it uses sanity checks, such as
265    ensuring that the kernel exists in the filesystem, to make sure
266    entries that obviously won't work aren't selected. This option overrides
267    that behavior, and is designed primarily for testing.
268    
269  .TP  .TP
270  \fB-\-set-default-index\fR=\fIentry-index\fR  \fB-\-boot-filesystem\fR=\fIbootfs\fR
271  Makes the given entry number the default boot entry.  The \fBgrub\fR boot loader expects file paths listed in its configuration
272    path to be relative to the top of the filesystem they are on, rather then
273    relative to the current root filesystem. By default \fBgrubby\fR searches
274    the list of currently mounted filesystems to determine this. If this option
275    is given \fBgrubby\fR acts as if the specified filesystem was the filesystem
276    containing the kernel (this option is designed primarily for testing).
277    
278  .TP  .TP
279  \fB-\-title\fR=\fIentry-title\fR  \fB-\-env\fR=\fIpath\fR
280  When a new kernel entry is added \fIentry-title\fR is used as the title  Path for the file where grub environment data is stored.
 (\fBlilo\fR label) for the entry. If \fIentry-title\fR is longer then maximum  
 length allowed by the bootloader (15 for lilo, unlimited for grub and elilo)  
 the title is shortened to a (unique) entry.  
281    
282  .TP  .TP
283  \fB-\-update-kernel\fR=\fIkernel-path\fR  \fB-c\fR, \fB-\-config-file\fR=\fIpath\fR
284  The entries for kernels matching \fRkernel-path\fR are updated. Currently  Use \fIpath\fR as the configuration file rather then the default.
 the only items that can be updated is the kernel argument list, which is  
 modified via the \fB-\-args\fR and \fB-\-remove-args\fR options.  
285    
286  .TP  .TP
287  \fB-\-version\fR  \fB-o\fR, \fB-\-output-file\fR=\fIfile_path\fR
288  Display the version of \fBgrubby\fR being run and then exit immediately.  The destination path for the updated configuration file. Use "-" to
289    send it to stdout.
290    
291  .TP  .TP
292  \fB-\-yaboot\fR  \fB-\-devtree\fR=\fIfile_path\fR
293  Use an \fByaboot\fR style configuration file.  Use \fIpath\fR for device tree path in place of the path of any devicetree
294    directive found in the template stanza.
295    
296  .TP  .TP
297  \fB-\-zipl\fR  \fB-\-devtreedir\fR=\fIfile_path\fR
298  Use an \fBzipl\fR style configuration file.  Use the specified \fIfile path\fR to load the devicetree definition. This is
299    for platforms where a flat file is used instead of firmware to instruct the
300    kernel how to communicate with devices.
301    
302    .SS Multiboot Options
303    
304  .SH MULTIBOOT OPTIONS  The Multiboot Specification provides a generic interface for boot
 The Multiboot Specification provides a genreic interface for boot  
305  loaders and operating systems.  It is supported by the GRUB bootloader.  loaders and operating systems.  It is supported by the GRUB bootloader.
306    
307  .TP  .TP
308  \fB-\-add-multiboot\fR=\fImultiboot-path\fR  \fB-\-add-multiboot\fR=\fImultiboot-path\fR
309  Add a new boot entry for the multiboot kernel located at  Add a new boot entry for the multiboot kernel located at
310  \fImultiboot-path\fR.  Note that this is generally accompanied with a  \fImultiboot-path\fR.  Note that this is generally accompanied with a
311  \fI--add-kernel\fR option.  \fB--add-kernel\fR option.
312    
313  .TP  .TP
314  \fB-\-remove-multiboot\fR=\fImultiboot-path\fR  \fB-\-remove-multiboot\fR=\fImultiboot-path\fR
315  Removes all boot entries which match \fImultiboot-path\fR.  Removes all boot entries which match \fImultiboot-path\fR.
316    
317  .TP  .TP
318  \fB-\-mbargs\fR=\fImultiboot-args\fR  \fB-\-mbargs\fR=\fImultiboot-args\fR
319  When a new multiboot kernel is added, this specifies the command line  When a new multiboot kernel is added, this specifies the command line
320  arguments which should be passed to that kernel by default  arguments which should be passed to that kernel by default
321  When \fB-\-update-kernel\fR is used, this specifies new arguments to add  When \fB-\-update-kernel\fR is used, this specifies new arguments to add
322  to the argument list. Multiple, space separated arguments may be used. If  to the argument list. Multiple, space separated arguments may be used. If
323  an argument already exists the new value replaces the old values.  an argument already exists the new value replaces the old values.
324    
325  .TP  .TP
326  \fB-\-remove-mbargs\fR=\fImultiboot-args\fR  \fB-\-remove-mbargs\fR=\fImultiboot-args\fR
327  The arguments specified by \fImultiboot-args\fR are removed from the  The arguments specified by \fImultiboot-args\fR are removed from the
328  kernels specified by \fB-\-update-kernel\fR.  kernels specified by \fB-\-update-kernel\fR.
   
329    
330  .SH "BUGS"  .SH "BUGS"
331    
332  The command line syntax is more than a little baroque. This probably  The command line syntax is more than a little baroque. This probably
333  won't be fixed as \fBgrubby\fR is only intended to be called from shell  won't be fixed as \fBgrubby\fR is only intended to be called from shell
334  scripts which can get it right.  scripts which can get it right.
335    
336    .SH EXAMPLE
337    
338    The following examples assume the following:
339    
340    .TS
341    allbox;
342    rbw15 l.
343    cfg_file Full path to bootloader config file
344    new_kernel Full path to kernel image to be installed
345    old_kernel Full path to old kernel image to be removed
346    current_kernel Full path to a currently installed kernel
347    entry_title Title that appears on bootloader menu
348    new_initrd Full path to initrd for a new kernel
349    kernel_args Set of arguments for the kernel
350    menu_index Index number of a menu entry
351    .TE
352    
353    The examples below quote strings that may have spaces or other whitespace in
354    them. It is also perfectly valid to backslash escape these strings if that
355    is more convenient.
356    
357    .PP
358    Add a new kernel entry and copy all options from the current default kernel.
359    This is the behavior that most users will want.
360    .IP
361    \fBgrubby\fR --add-kernel=\fInew_kernel\fR --title="\fIentry_title\fR" --initrd="\fInew_initrd\fR" --copy-default
362    .PP
363    Add a new kernel entry with custom arguments
364    .IP
365    \fBgrubby\fR --add-kernel=\fInew_kernel\fR --title="\fIentry_title\fR" --initrd="\fInew_initrd\fR" --args=\fIkernel_args\fR
366    .PP
367    Remove \fBall menu entries\fR for a specified kernel.
368    .IP
369    \fBgrubby\fR --remove-kernel=\fIold_kernel\fR
370    .PP
371    Target a single menu entry to remove without targetting other entries with
372    the same kernel.
373    .IP
374    \fBgrubby\fR --info=\fIold_kernel\fR
375    
376    \fBgrubby\fR --remove-kernel=\fImenu_index\fR
377    .PP
378    Update the arguments for all entries of a specific kernel. New arguments get
379    added while existing arguments get updated values.
380    .IP
381    \fBgrubby\fR --update-kernel=\fIcurrent_kernel\fR --args="\fIkernel_args\fR"
382    .PP
383    Remove the arguments for a single entry of a specific kernel.
384    .IP
385    \fBgrubby\fR --info=\fIcurrent_kernel\fR
386    
387    \fBgrubby\fR --remove-args=\fImenu_index\fR --args="\fIkernel_args\fR"
388    
389  .SH "SEE ALSO"  .SH "SEE ALSO"
390    
391  .BR grub (8),  .BR grub (8),
392  .BR lilo (8),  .BR lilo (8),
393  .BR yaboot (8),  .BR yaboot (8),
394    .BR zipl (8),
395    .BR dracut (8),
396  .BR mkinitrd (8)  .BR mkinitrd (8)
397    
398  .SH AUTHORS  .SH AUTHORS
399    
400  .nf  .nf
401  Erik Troan  Erik Troan
402  Jeremy Katz  Jeremy Katz
403  Peter Jones  Peter Jones
404    Robert Marshall
405  .fi  .fi

Legend:
Removed from v.2966  
changed lines
  Added in v.3148