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