xref: /freebsd/stand/i386/gptzfsboot/gptzfsboot.8 (revision cddbc3b40812213ff00041f79174cac0be360a2a)
1.\" Copyright (c) 2014 Andriy Gapon <avg@FreeBSD.org>
2.\" All rights reserved.
3.\"
4.\" Redistribution and use in source and binary forms, with or without
5.\" modification, are permitted provided that the following conditions
6.\" are met:
7.\" 1. Redistributions of source code must retain the above copyright
8.\"    notice, this list of conditions and the following disclaimer.
9.\" 2. Redistributions in binary form must reproduce the above copyright
10.\"    notice, this list of conditions and the following disclaimer in the
11.\"    documentation and/or other materials provided with the distribution.
12.\"
13.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
14.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
17.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23.\" SUCH DAMAGE.
24.\"
25.\" $FreeBSD$
26.\"
27.Dd September 15, 2014
28.Dt GPTZFSBOOT 8
29.Os
30.Sh NAME
31.Nm gptzfsboot
32.Nd GPT bootcode for ZFS on BIOS-based computers
33.Sh DESCRIPTION
34.Nm
35is used on BIOS-based computers to boot from a filesystem in
36a ZFS pool.
37.Nm
38is installed in a
39.Cm freebsd-boot
40partition of a GPT-partitioned disk with
41.Xr gpart 8 .
42.Sh IMPLEMENTATION NOTES
43The GPT standard allows a variable number of partitions, but
44.Nm
45only boots from tables with 128 partitions or less.
46.Sh BOOTING
47.Nm
48tries to find all ZFS pools that are composed of BIOS-visible
49hard disks or partitions on them.
50.Nm
51looks for ZFS device labels on all visible disks and in discovered
52supported partitions for all supported partition scheme types.
53The search starts with the disk from which
54.Nm
55itself was loaded.
56Other disks are probed in BIOS defined order.
57After a disk is probed and
58.Nm
59determines that the whole disk is not a ZFS pool member, the
60individual partitions are probed in their partition table order.
61Currently GPT and MBR partition schemes are supported.
62With the GPT scheme, only partitions of type
63.Cm freebsd-zfs
64are probed.
65The first pool seen during probing is used as a default boot pool.
66.Pp
67The filesystem specified by the
68.Cm bootfs
69property of the pool is used as a default boot filesystem.
70If the
71.Cm bootfs
72property is not set, then the root filesystem of the pool is used as
73the default.
74.Xr loader 8
75is loaded from the boot filesystem.
76If
77.Pa /boot.config
78or
79.Pa /boot/config
80is present in the boot filesystem, boot options are read from it
81in the same way as
82.Xr boot 8 .
83.Pp
84The ZFS GUIDs of the first successfully probed device and the first
85detected pool are made available to
86.Xr loader 8
87in the
88.Cm vfs.zfs.boot.primary_vdev
89and
90.Cm vfs.zfs.boot.primary_pool
91variables.
92.Sh USAGE
93Normally
94.Nm
95will boot in fully automatic mode.
96However, like
97.Xr boot 8 ,
98it is possible to interrupt the automatic boot process and interact with
99.Nm
100through a prompt.
101.Nm
102accepts all the options that
103.Xr boot 8
104supports.
105.Pp
106The filesystem specification and the path to
107.Xr loader 8
108are different from
109.Xr boot 8 .
110The format is
111.Pp
112.Sm off
113.Oo zfs:pool/filesystem: Oc Oo /path/to/loader Oc
114.Sm on
115.Pp
116Both the filesystem and the path can be specified.
117If only a path is specified, then the default filesystem is used.
118If only a pool and filesystem are specified, then
119.Pa /boot/loader
120is used as a path.
121.Pp
122Additionally, the
123.Ic status
124command can be used to query information about discovered pools.
125The output format is similar to that of
126.Cm zpool status
127.Pq see Xr zpool 8 .
128.Pp
129The configured or automatically determined ZFS boot filesystem is
130stored in the
131.Xr loader 8
132.Cm loaddev
133variable, and also set as the initial value of the
134.Cm currdev
135variable.
136.Sh FILES
137.Bl -tag -width /boot/gptzfsboot -compact
138.It Pa /boot/gptzfsboot
139boot code binary
140.It Pa /boot.config
141parameters for the boot block
142.Pq optional
143.It Pa /boot/config
144alternative parameters for the boot block
145.Pq optional
146.El
147.Sh EXAMPLES
148.Nm
149is typically installed in combination with a
150.Dq protective MBR
151.Po
152see
153.Xr gpart 8
154.Pc .
155To install
156.Nm
157on the
158.Pa ada0
159drive:
160.Bd -literal -offset indent
161gpart bootcode -b /boot/pmbr -p /boot/gptzfsboot -i 1 ada0
162.Ed
163.Pp
164.Nm
165can also be installed without the PMBR:
166.Bd -literal -offset indent
167gpart bootcode -p /boot/gptzfsboot -i 1 ada0
168.Ed
169.Sh SEE ALSO
170.Xr boot.config 5 ,
171.Xr boot 8 ,
172.Xr gpart 8 ,
173.Xr loader 8 ,
174.Xr zpool 8
175.Sh HISTORY
176.Nm
177appeared in FreeBSD 7.3.
178.Sh AUTHORS
179This manual page was written by
180.An Andriy Gapon Aq avg@FreeBSD.org .
181.Sh BUGS
182.Nm
183looks for ZFS meta-data only in MBR partitions
184.Pq known on FreeBSD as slices .
185It does not look into BSD
186.Xr disklabel 8
187partitions that are traditionally called partitions.
188If a disklabel partition happens to be placed so that ZFS meta-data can be
189found at the fixed offsets relative to a slice, then
190.Nm
191will recognize the partition as a part of a ZFS pool,
192but this is not guaranteed to happen.
193