xref: /freebsd/lib/geom/multipath/gmultipath.8 (revision fa9896e082a1046ff4fbc75fcba4d18d1f2efc19)
1e4b0a90eSBrooks Davis.\" Copyright (c) 2007 Matthew Jacob
2e4b0a90eSBrooks Davis.\" All rights reserved.
3e4b0a90eSBrooks Davis.\"
4e4b0a90eSBrooks Davis.\" Redistribution and use in source and binary forms, with or without
5e4b0a90eSBrooks Davis.\" modification, are permitted provided that the following conditions
6e4b0a90eSBrooks Davis.\" are met:
7e4b0a90eSBrooks Davis.\" 1. Redistributions of source code must retain the above copyright
8e4b0a90eSBrooks Davis.\"    notice, this list of conditions and the following disclaimer.
9e4b0a90eSBrooks Davis.\" 2. Redistributions in binary form must reproduce the above copyright
10e4b0a90eSBrooks Davis.\"    notice, this list of conditions and the following disclaimer in the
11e4b0a90eSBrooks Davis.\"    documentation and/or other materials provided with the distribution.
12e4b0a90eSBrooks Davis.\"
13e4b0a90eSBrooks Davis.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
14e4b0a90eSBrooks Davis.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15e4b0a90eSBrooks Davis.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16e4b0a90eSBrooks Davis.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
17e4b0a90eSBrooks Davis.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18e4b0a90eSBrooks Davis.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19e4b0a90eSBrooks Davis.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20e4b0a90eSBrooks Davis.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21e4b0a90eSBrooks Davis.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22e4b0a90eSBrooks Davis.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23e4b0a90eSBrooks Davis.\" SUCH DAMAGE.
24e4b0a90eSBrooks Davis.\"
25*fd061175SMateusz Piotrowski.Dd March 17, 2022
26e4b0a90eSBrooks Davis.Dt GMULTIPATH 8
27e4b0a90eSBrooks Davis.Os
28e4b0a90eSBrooks Davis.Sh NAME
29e4b0a90eSBrooks Davis.Nm gmultipath
30e4b0a90eSBrooks Davis.Nd "disk multipath control utility"
31e4b0a90eSBrooks Davis.Sh SYNOPSIS
32e4b0a90eSBrooks Davis.Nm
33e4b0a90eSBrooks Davis.Cm create
34e4b0a90eSBrooks Davis.Op Fl ARv
35e4b0a90eSBrooks Davis.Ar name
36e4b0a90eSBrooks Davis.Ar prov ...
37e4b0a90eSBrooks Davis.Nm
38e4b0a90eSBrooks Davis.Cm label
39e4b0a90eSBrooks Davis.Op Fl ARv
40e4b0a90eSBrooks Davis.Ar name
41e4b0a90eSBrooks Davis.Ar prov ...
42e4b0a90eSBrooks Davis.Nm
43e4b0a90eSBrooks Davis.Cm configure
44e4b0a90eSBrooks Davis.Op Fl APRv
45e4b0a90eSBrooks Davis.Ar name
46e4b0a90eSBrooks Davis.Nm
47e4b0a90eSBrooks Davis.Cm add
48e4b0a90eSBrooks Davis.Op Fl v
49e4b0a90eSBrooks Davis.Ar name prov
50e4b0a90eSBrooks Davis.Nm
51e4b0a90eSBrooks Davis.Cm remove
52e4b0a90eSBrooks Davis.Op Fl v
53e4b0a90eSBrooks Davis.Ar name prov
54e4b0a90eSBrooks Davis.Nm
55e4b0a90eSBrooks Davis.Cm fail
56e4b0a90eSBrooks Davis.Op Fl v
57e4b0a90eSBrooks Davis.Ar name prov
58e4b0a90eSBrooks Davis.Nm
59e4b0a90eSBrooks Davis.Cm restore
60e4b0a90eSBrooks Davis.Op Fl v
61e4b0a90eSBrooks Davis.Ar name prov
62e4b0a90eSBrooks Davis.Nm
63e4b0a90eSBrooks Davis.Cm rotate
64e4b0a90eSBrooks Davis.Op Fl v
65e4b0a90eSBrooks Davis.Ar name
66e4b0a90eSBrooks Davis.Nm
67e4b0a90eSBrooks Davis.Cm prefer
68e4b0a90eSBrooks Davis.Op Fl v
69e4b0a90eSBrooks Davis.Ar name
70e4b0a90eSBrooks Davis.Ar prov
71e4b0a90eSBrooks Davis.Nm
72e4b0a90eSBrooks Davis.Cm getactive
73e4b0a90eSBrooks Davis.Op Fl v
74e4b0a90eSBrooks Davis.Ar name
75e4b0a90eSBrooks Davis.Nm
76e4b0a90eSBrooks Davis.Cm destroy
77e4b0a90eSBrooks Davis.Op Fl v
78e4b0a90eSBrooks Davis.Ar name
79e4b0a90eSBrooks Davis.Nm
80e4b0a90eSBrooks Davis.Cm stop
81e4b0a90eSBrooks Davis.Op Fl v
82e4b0a90eSBrooks Davis.Ar name
83e4b0a90eSBrooks Davis.Nm
84e4b0a90eSBrooks Davis.Cm clear
85e4b0a90eSBrooks Davis.Op Fl v
86e4b0a90eSBrooks Davis.Ar prov ...
87e4b0a90eSBrooks Davis.Nm
88e4b0a90eSBrooks Davis.Cm list
89e4b0a90eSBrooks Davis.Nm
90e4b0a90eSBrooks Davis.Cm status
91e4b0a90eSBrooks Davis.Nm
92e4b0a90eSBrooks Davis.Cm load
93e4b0a90eSBrooks Davis.Nm
94e4b0a90eSBrooks Davis.Cm unload
95e4b0a90eSBrooks Davis.Sh DESCRIPTION
96e4b0a90eSBrooks DavisThe
97e4b0a90eSBrooks Davis.Nm
98e4b0a90eSBrooks Davisutility is used for device multipath configuration.
99e4b0a90eSBrooks Davis.Pp
100e4b0a90eSBrooks DavisThe multipath device can be configured using two different methods:
101e4b0a90eSBrooks Davis.Dq manual
102e4b0a90eSBrooks Davisor
103e4b0a90eSBrooks Davis.Dq automatic .
104e4b0a90eSBrooks DavisWhen using the
105e4b0a90eSBrooks Davis.Dq manual
106e4b0a90eSBrooks Davismethod, no metadata are stored on the devices, so the multipath
107e4b0a90eSBrooks Davisdevice has to be configured by hand every time it is needed.
108e4b0a90eSBrooks DavisAdditional device paths also will not be detected automatically.
109e4b0a90eSBrooks DavisThe
110e4b0a90eSBrooks Davis.Dq automatic
111e4b0a90eSBrooks Davismethod uses on-disk metadata to detect device and all its paths.
112e4b0a90eSBrooks DavisMetadata use the last sector of the underlying disk device and
113e4b0a90eSBrooks Davisinclude device name and UUID.
114e4b0a90eSBrooks DavisThe UUID guarantees uniqueness in a shared storage environment
115e4b0a90eSBrooks Davisbut is in general too cumbersome to use.
116e4b0a90eSBrooks DavisThe name is what is exported via the device interface.
117e4b0a90eSBrooks Davis.Pp
118e4b0a90eSBrooks DavisThe first argument to
119e4b0a90eSBrooks Davis.Nm
120e4b0a90eSBrooks Davisindicates an action to be performed:
121e4b0a90eSBrooks Davis.Bl -tag -width ".Cm destroy"
122e4b0a90eSBrooks Davis.It Cm create
123e4b0a90eSBrooks DavisCreate multipath device with
124e4b0a90eSBrooks Davis.Dq manual
125e4b0a90eSBrooks Davismethod without writing any on-disk metadata.
126e4b0a90eSBrooks DavisIt is up to administrator, how to properly identify device paths.
127e4b0a90eSBrooks DavisKernel will only check that all given providers have same media and
128e4b0a90eSBrooks Davissector sizes.
129e4b0a90eSBrooks Davis.Pp
130e4b0a90eSBrooks Davis.Fl A
131e4b0a90eSBrooks Davisoption enables Active/Active mode,
132e4b0a90eSBrooks Davis.Fl R
133e4b0a90eSBrooks Davisoption enables Active/Read mode, otherwise Active/Passive mode is used
134e4b0a90eSBrooks Davisby default.
135e4b0a90eSBrooks Davis.It Cm label
136e4b0a90eSBrooks DavisCreate multipath device with
137e4b0a90eSBrooks Davis.Dq automatic
138e4b0a90eSBrooks Davismethod.
139e4b0a90eSBrooks DavisLabel the first given provider with on-disk metadata using the specified
140e4b0a90eSBrooks Davis.Ar name .
141e4b0a90eSBrooks DavisThe rest of given providers will be retasted to detect these metadata.
142e4b0a90eSBrooks DavisIt reliably protects against specifying unrelated providers.
143e4b0a90eSBrooks DavisProviders with no matching metadata detected will not be added to the device.
144e4b0a90eSBrooks Davis.Pp
145e4b0a90eSBrooks Davis.Fl A
146e4b0a90eSBrooks Davisoption enables Active/Active mode,
147e4b0a90eSBrooks Davis.Fl R
148e4b0a90eSBrooks Davisoption enables Active/Read mode, otherwise Active/Passive mode is used
149e4b0a90eSBrooks Davisby default.
150e4b0a90eSBrooks Davis.It Cm configure
151e4b0a90eSBrooks DavisConfigure the given multipath device.
152e4b0a90eSBrooks Davis.Pp
153e4b0a90eSBrooks Davis.Fl A
154e4b0a90eSBrooks Davisoption enables Active/Active mode,
155e4b0a90eSBrooks Davis.Fl P
156e4b0a90eSBrooks Davisoption enables Active/Passive mode,
157e4b0a90eSBrooks Davis.Fl R
158e4b0a90eSBrooks Davisoption enables Active/Read mode.
159e4b0a90eSBrooks Davis.It Cm add
160e4b0a90eSBrooks DavisAdd the given provider as a path to the given multipath device.
161e4b0a90eSBrooks DavisShould normally be used only for devices created with
162e4b0a90eSBrooks Davis.Dq manual
163e4b0a90eSBrooks Davismethod, unless you know what you are doing (you are sure that it is another
164e4b0a90eSBrooks Davisdevice path, but tasting its metadata in regular
165e4b0a90eSBrooks Davis.Dq automatic
166e4b0a90eSBrooks Davisway is not possible).
167e4b0a90eSBrooks Davis.It Cm remove
168e4b0a90eSBrooks DavisRemove the given provider as a path from the given multipath device.
169e4b0a90eSBrooks DavisIf the last path removed, the multipath device will be destroyed.
170e4b0a90eSBrooks Davis.It Cm fail
171e4b0a90eSBrooks DavisMark specified provider as a path of the specified multipath device as failed.
172e4b0a90eSBrooks DavisIf there are other paths present, new requests will be forwarded there.
173e4b0a90eSBrooks Davis.It Cm restore
174e4b0a90eSBrooks DavisMark specified provider as a path of the specified multipath device as
175e4b0a90eSBrooks Davisoperational, allowing it to handle requests.
176e4b0a90eSBrooks Davis.It Cm rotate
177e4b0a90eSBrooks DavisChange the active provider/path to the next available provider in Active/Passive mode.
178e4b0a90eSBrooks Davis.It Cm prefer
179e4b0a90eSBrooks DavisChange the active provider/path to the specified provider in Active/Passive mode.
180e4b0a90eSBrooks Davis.It Cm getactive
181e4b0a90eSBrooks DavisGet the currently active provider(s)/path(s).
182e4b0a90eSBrooks Davis.It Cm destroy
183e4b0a90eSBrooks DavisDestroy the given multipath device clearing metadata.
184e4b0a90eSBrooks Davis.It Cm stop
185e4b0a90eSBrooks DavisStop the given multipath device without clearing metadata.
186e4b0a90eSBrooks Davis.It Cm clear
187e4b0a90eSBrooks DavisClear metadata on the given provider.
188e4b0a90eSBrooks Davis.It Cm list
189e4b0a90eSBrooks DavisSee
190e4b0a90eSBrooks Davis.Xr geom 8 .
191e4b0a90eSBrooks Davis.It Cm status
192e4b0a90eSBrooks DavisSee
193e4b0a90eSBrooks Davis.Xr geom 8 .
194e4b0a90eSBrooks Davis.It Cm load
195e4b0a90eSBrooks DavisSee
196e4b0a90eSBrooks Davis.Xr geom 8 .
197e4b0a90eSBrooks Davis.It Cm unload
198e4b0a90eSBrooks DavisSee
199e4b0a90eSBrooks Davis.Xr geom 8 .
200e4b0a90eSBrooks Davis.El
201e4b0a90eSBrooks Davis.Sh SYSCTL VARIABLES
202e4b0a90eSBrooks DavisThe following
203e4b0a90eSBrooks Davis.Xr sysctl 8
204e4b0a90eSBrooks Davisvariable can be used to control the behavior of the
205e4b0a90eSBrooks Davis.Nm MULTIPATH
206e4b0a90eSBrooks DavisGEOM class.
207e4b0a90eSBrooks Davis.Bl -tag -width indent
208e4b0a90eSBrooks Davis.It Va kern.geom.multipath.debug : No 0
209e4b0a90eSBrooks DavisDebug level of the
210e4b0a90eSBrooks Davis.Nm MULTIPATH
211e4b0a90eSBrooks DavisGEOM class.
212e4b0a90eSBrooks DavisThis can be set to 0 (default) or 1 to disable or enable various
213e4b0a90eSBrooks Davisforms of chattiness.
214e4b0a90eSBrooks Davis.It Va kern.geom.multipath.exclusive : No 1
215e4b0a90eSBrooks DavisOpen underlying providers exclusively, preventing individual paths access.
216e4b0a90eSBrooks Davis.El
217e4b0a90eSBrooks Davis.Sh EXIT STATUS
218e4b0a90eSBrooks DavisExit status is 0 on success, and 1 if the command fails.
219e4b0a90eSBrooks Davis.Sh MULTIPATH ARCHITECTURE
220e4b0a90eSBrooks DavisThis is a multiple path architecture with no device knowledge or
221e4b0a90eSBrooks Davispresumptions other than size matching built in.
222e4b0a90eSBrooks DavisTherefore the user must exercise some care
223e4b0a90eSBrooks Davisin selecting providers that do indeed represent multiple paths to the
224e4b0a90eSBrooks Davissame underlying disk device.
225e4b0a90eSBrooks DavisThe reason for this is that there are several
226e4b0a90eSBrooks Daviscriteria across multiple underlying transport types that can
227e4b0a90eSBrooks Davis.Ar indicate
228e4b0a90eSBrooks Davisidentity, but in all respects such identity can rarely be considered
229e4b0a90eSBrooks Davis.Ar definitive .
230e4b0a90eSBrooks Davis.Pp
23158d60030SMateusz PiotrowskiFor example, if you use the World Wide Port Name of a Fibre Channel
232e4b0a90eSBrooks Davisdisk object you might believe that two disks that have the same WWPN
233e4b0a90eSBrooks Davison different paths (or even disjoint fabrics) might be considered
234e4b0a90eSBrooks Davisthe same disk.
235e4b0a90eSBrooks DavisNearly always this would be a safe assumption, until
236e4b0a90eSBrooks Davisyou realize that a WWPN, like an Ethernet MAC address, is a soft
237e4b0a90eSBrooks Davisprogrammable entity, and that a misconfigured Director Class switch
238e4b0a90eSBrooks Daviscould lead you to believe incorrectly that you have found multiple
239e4b0a90eSBrooks Davispaths to the same device.
240e4b0a90eSBrooks DavisThis is an extreme and theoretical case, but
241e4b0a90eSBrooks Davisit is possible enough to indicate that the policy for deciding which
242e4b0a90eSBrooks Davisof multiple pathnames refer to the same device should be left to the
243e4b0a90eSBrooks Davissystem operator who will use tools and knowledge of their own storage
244e4b0a90eSBrooks Davissubsystem to make the correct configuration selection.
245e4b0a90eSBrooks Davis.Pp
246e4b0a90eSBrooks DavisThere are Active/Passive, Active/Read and Active/Active operation modes
247e4b0a90eSBrooks Davissupported.
248e4b0a90eSBrooks DavisIn Active/Passive mode only one path has I/O moving on it
249e4b0a90eSBrooks Davisat any point in time.
250e4b0a90eSBrooks DavisThis I/O continues until an I/O is returned with
251e4b0a90eSBrooks Davisa generic I/O error or a "Nonexistent Device" error.
252e4b0a90eSBrooks DavisWhen this occurs, that path is marked FAIL, the next path
253e4b0a90eSBrooks Davisin a list is selected as active and the failed I/O reissued.
254e4b0a90eSBrooks DavisIn Active/Active mode all paths not marked FAIL may handle I/O at the same time.
255e4b0a90eSBrooks DavisRequests are distributed between paths to equalize load.
256e4b0a90eSBrooks DavisFor capable devices it allows the utilisation of the bandwidth available on all paths.
257e4b0a90eSBrooks DavisIn Active/Read mode all paths not marked FAIL may handle reads at the same time,
258e4b0a90eSBrooks Davisbut unlike in Active/Active mode only one path handles write requests at any
259e4b0a90eSBrooks Davispoint in time; closely following the original write request order if the layer
260e4b0a90eSBrooks Davisabove needs it for data consistency (not waiting for requisite write completion
261e4b0a90eSBrooks Davisbefore sending dependent write).
262e4b0a90eSBrooks Davis.Pp
263e4b0a90eSBrooks DavisWhen new devices are added to the system the
264e4b0a90eSBrooks Davis.Nm MULTIPATH
265e4b0a90eSBrooks DavisGEOM class is given an opportunity to taste these new devices.
266e4b0a90eSBrooks DavisIf a new
267e4b0a90eSBrooks Davisdevice has a
268e4b0a90eSBrooks Davis.Nm MULTIPATH
269e4b0a90eSBrooks Davison-disk metadata label, the device is either used to create a new
270e4b0a90eSBrooks Davis.Nm MULTIPATH
271e4b0a90eSBrooks DavisGEOM, or added to the list of paths for an existing
272e4b0a90eSBrooks Davis.Nm MULTIPATH
273e4b0a90eSBrooks DavisGEOM.
274e4b0a90eSBrooks Davis.Pp
275e4b0a90eSBrooks DavisIt is this mechanism that works reasonably with
276e4b0a90eSBrooks Davis.Xr isp 4
277e4b0a90eSBrooks Davisand
278e4b0a90eSBrooks Davis.Xr mpt 4
279e4b0a90eSBrooks Davisbased Fibre Channel disk devices.
280e4b0a90eSBrooks DavisFor these devices, when a device disappears
281e4b0a90eSBrooks Davis(due to e.g., a cable pull or power failure to a switch), the device is
282e4b0a90eSBrooks Davisproactively marked as gone and I/O to it failed.
283e4b0a90eSBrooks DavisThis causes the
284e4b0a90eSBrooks Davis.Nm MULTIPATH
285e4b0a90eSBrooks Davisfailure event just described.
286e4b0a90eSBrooks Davis.Pp
287e4b0a90eSBrooks DavisWhen Fibre Channel events inform either
288e4b0a90eSBrooks Davis.Xr isp 4
289e4b0a90eSBrooks Davisor
290e4b0a90eSBrooks Davis.Xr mpt 4
291e4b0a90eSBrooks Davishost bus adapters that new devices may have arrived (e.g., the arrival
292e4b0a90eSBrooks Davisof an RSCN event from the Fabric Domain Controller), they can cause
293e4b0a90eSBrooks Davisa rescan to occur and cause the attachment and configuration of any
294e4b0a90eSBrooks Davis(now) new devices to occur, causing the taste event described above.
295e4b0a90eSBrooks Davis.Pp
296e4b0a90eSBrooks DavisThis means that this multipath architecture is not a one-shot path
297e4b0a90eSBrooks Davisfailover, but can be considered to be steady state as long as failed
298e4b0a90eSBrooks Davispaths are repaired (automatically or otherwise).
299e4b0a90eSBrooks Davis.Pp
300e4b0a90eSBrooks DavisAutomatic rescanning is not a requirement.
301e4b0a90eSBrooks DavisNor is Fibre Channel.
302e4b0a90eSBrooks DavisThe
303e4b0a90eSBrooks Davissame failover mechanisms work equally well for traditional "Parallel"
304e4b0a90eSBrooks DavisSCSI but may require manual intervention with
305e4b0a90eSBrooks Davis.Xr camcontrol 8
306e4b0a90eSBrooks Davisto cause the reattachment of repaired device links.
307e4b0a90eSBrooks Davis.Sh EXAMPLES
308e4b0a90eSBrooks DavisThe following example shows how to use
309e4b0a90eSBrooks Davis.Xr camcontrol 8
310e4b0a90eSBrooks Davisto find possible multiple path devices and to create a
311e4b0a90eSBrooks Davis.Nm MULTIPATH
312e4b0a90eSBrooks DavisGEOM class for them.
313e4b0a90eSBrooks Davis.Bd -literal -offset indent
314e4b0a90eSBrooks Davismysys# camcontrol devlist
315e4b0a90eSBrooks Davis<ECNCTX @WESTVILLE >   at scbus0 target 0 lun 0 (da0,pass0)
316e4b0a90eSBrooks Davis<ECNCTX @WESTVILLE >   at scbus0 target 0 lun 1 (da1,pass1)
317e4b0a90eSBrooks Davis<ECNCTX @WESTVILLE >   at scbus1 target 0 lun 0 (da2,pass2)
318e4b0a90eSBrooks Davis<ECNCTX @WESTVILLE >   at scbus1 target 0 lun 1 (da3,pass3)
319e4b0a90eSBrooks Davismysys# camcontrol inquiry da0 -S
320e4b0a90eSBrooks DavisECNTX0LUN000000SER10ac0d01
321e4b0a90eSBrooks Davismysys# camcontrol inquiry da2 -S
322e4b0a90eSBrooks DavisECNTX0LUN000000SER10ac0d01
323e4b0a90eSBrooks Davis.Ed
324e4b0a90eSBrooks Davis.Pp
325e4b0a90eSBrooks DavisNow that you have used the Serial Number to compare two disk paths
326e4b0a90eSBrooks Davisit is not entirely unreasonable to conclude that these are multiple
327e4b0a90eSBrooks Davispaths to the same device.
328e4b0a90eSBrooks DavisHowever, only the user who is familiar
329e4b0a90eSBrooks Daviswith their storage is qualified to make this judgement.
330e4b0a90eSBrooks Davis.Pp
331e4b0a90eSBrooks DavisYou can then use the
332e4b0a90eSBrooks Davis.Nm
333e4b0a90eSBrooks Daviscommand to label and create a
334e4b0a90eSBrooks Davis.Nm MULTIPATH
335e4b0a90eSBrooks DavisGEOM provider named
336e4b0a90eSBrooks Davis.Ar FRED .
337e4b0a90eSBrooks Davis.Bd -literal -offset indent
338e4b0a90eSBrooks Davisgmultipath label -v FRED /dev/da0 /dev/da2
339*fd061175SMateusz Piotrowskidisklabel -Bw /dev/multipath/FRED auto
340e4b0a90eSBrooks Davisnewfs /dev/multipath/FREDa
341e4b0a90eSBrooks Davismount /dev/multipath/FREDa /mnt....
342e4b0a90eSBrooks Davis.Ed
343e4b0a90eSBrooks Davis.Pp
344e4b0a90eSBrooks DavisThe resultant console output looks something like:
345e4b0a90eSBrooks Davis.Bd -literal -offset indent
346e4b0a90eSBrooks DavisGEOM_MULTIPATH: da0 added to FRED
347e4b0a90eSBrooks DavisGEOM_MULTIPATH: da0 is now active path in FRED
348e4b0a90eSBrooks DavisGEOM_MULTIPATH: da2 added to FRED
349e4b0a90eSBrooks Davis.Ed
350e4b0a90eSBrooks Davis.Pp
351e4b0a90eSBrooks DavisTo load the
352e4b0a90eSBrooks Davis.Nm
353e4b0a90eSBrooks Davismodule at boot time, add this entry to
354e4b0a90eSBrooks Davis.Pa /boot/loader.conf :
355e4b0a90eSBrooks Davis.Bd -literal -offset ident
356e4b0a90eSBrooks Davisgeom_multipath_load="YES"
357e4b0a90eSBrooks Davis.Ed
358e4b0a90eSBrooks Davis.Sh SEE ALSO
359e4b0a90eSBrooks Davis.Xr geom 4 ,
360e4b0a90eSBrooks Davis.Xr isp 4 ,
361e4b0a90eSBrooks Davis.Xr mpt 4 ,
362e4b0a90eSBrooks Davis.Xr loader.conf 5 ,
363e4b0a90eSBrooks Davis.Xr camcontrol 8 ,
364e4b0a90eSBrooks Davis.Xr geom 8 ,
365e4b0a90eSBrooks Davis.Xr mount 8 ,
366e4b0a90eSBrooks Davis.Xr newfs 8 ,
367e4b0a90eSBrooks Davis.Xr sysctl 8
368e4b0a90eSBrooks Davis.Sh HISTORY
369e4b0a90eSBrooks DavisThe
370e4b0a90eSBrooks Davis.Nm
371e4b0a90eSBrooks Davisutility first appeared in
372e4b0a90eSBrooks Davis.Fx 7.0
373e4b0a90eSBrooks Davis.Sh AUTHORS
374e4b0a90eSBrooks Davis.An Matthew Jacob Aq Mt mjacob@FreeBSD.org
375e4b0a90eSBrooks Davis.An Alexander Motin Aq Mt mav@FreeBSD.org
376