1 /* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License (the "License"). 6 * You may not use this file except in compliance with the License. 7 * 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 * or http://www.opensolaris.org/os/licensing. 10 * See the License for the specific language governing permissions 11 * and limitations under the License. 12 * 13 * When distributing Covered Code, include this CDDL HEADER in each 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 * If applicable, add the following below this CDDL HEADER, with the 16 * fields enclosed by brackets "[]" replaced with your own identifying 17 * information: Portions Copyright [yyyy] [name of copyright owner] 18 * 19 * CDDL HEADER END 20 */ 21 /* 22 * Copyright (c) 1982, 2010, Oracle and/or its affiliates. All rights reserved. 23 * Copyright 2015 Nexenta Systems, Inc. All rights reserved. 24 */ 25 26 /* 27 * Configure root, swap and dump devices. 28 */ 29 30 #include <sys/types.h> 31 #include <sys/param.h> 32 #include <sys/sysmacros.h> 33 #include <sys/signal.h> 34 #include <sys/cred.h> 35 #include <sys/proc.h> 36 #include <sys/user.h> 37 #include <sys/conf.h> 38 #include <sys/buf.h> 39 #include <sys/systm.h> 40 #include <sys/vm.h> 41 #include <sys/reboot.h> 42 #include <sys/file.h> 43 #include <sys/vfs.h> 44 #include <sys/vnode.h> 45 #include <sys/errno.h> 46 #include <sys/kmem.h> 47 #include <sys/uio.h> 48 #include <sys/open.h> 49 #include <sys/mount.h> 50 #include <sys/kobj.h> 51 #include <sys/bootconf.h> 52 #include <sys/sysconf.h> 53 #include <sys/modctl.h> 54 #include <sys/autoconf.h> 55 #include <sys/debug.h> 56 #include <sys/fs/snode.h> 57 #include <fs/fs_subr.h> 58 #include <sys/socket.h> 59 #include <net/if.h> 60 61 #include <sys/mkdev.h> 62 #include <sys/cmn_err.h> 63 #include <sys/console.h> 64 65 #include <sys/conf.h> 66 #include <sys/ddi.h> 67 #include <sys/sunddi.h> 68 #include <sys/hwconf.h> 69 #include <sys/dc_ki.h> 70 #include <sys/promif.h> 71 #include <sys/bootprops.h> 72 73 /* 74 * Local routines 75 */ 76 static int preload_module(struct sysparam *, void *); 77 static struct vfssw *getfstype(char *, char *, size_t); 78 static int getphysdev(char *, char *, size_t); 79 static int load_bootpath_drivers(char *bootpath); 80 static int load_boot_driver(char *drv); 81 static int load_boot_platform_modules(char *drv); 82 static dev_info_t *path_to_devinfo(char *path); 83 static boolean_t netboot_over_ib(char *bootpath); 84 static boolean_t netboot_over_iscsi(void); 85 86 /* 87 * Module linkage information for the kernel. 88 */ 89 static struct modlmisc modlmisc = { 90 &mod_miscops, "root and swap configuration" 91 }; 92 93 static struct modlinkage modlinkage = { 94 MODREV_1, (void *)&modlmisc, NULL 95 }; 96 97 int 98 _init(void) 99 { 100 return (mod_install(&modlinkage)); 101 } 102 103 int 104 _fini(void) 105 { 106 return (mod_remove(&modlinkage)); 107 } 108 109 int 110 _info(struct modinfo *modinfop) 111 { 112 return (mod_info(&modlinkage, modinfop)); 113 } 114 115 extern ib_boot_prop_t *iscsiboot_prop; 116 /* 117 * Configure root file system. 118 */ 119 int 120 rootconf(void) 121 { 122 int error; 123 struct vfssw *vsw; 124 extern void pm_init(void); 125 int ret = -1; 126 BMDPRINTF(("rootconf: fstype %s\n", rootfs.bo_fstype)); 127 BMDPRINTF(("rootconf: name %s\n", rootfs.bo_name)); 128 BMDPRINTF(("rootconf: flags 0x%x\n", rootfs.bo_flags)); 129 BMDPRINTF(("rootconf: obp_bootpath %s\n", obp_bootpath)); 130 131 /* 132 * Install cluster modules that were only loaded during 133 * loadrootmodules(). 134 */ 135 if (error = clboot_rootconf()) 136 return (error); 137 138 if (root_is_svm) { 139 (void) strncpy(rootfs.bo_name, obp_bootpath, BO_MAXOBJNAME); 140 141 BMDPRINTF(("rootconf: svm: rootfs name %s\n", rootfs.bo_name)); 142 BMDPRINTF(("rootconf: svm: svm name %s\n", svm_bootpath)); 143 } 144 145 /* 146 * Run _init on the root filesystem (we already loaded it 147 * but we've been waiting until now to _init it) which will 148 * have the side-effect of running vsw_init() on this vfs. 149 * Because all the nfs filesystems are lumped into one 150 * module we need to special case it. 151 */ 152 if (strncmp(rootfs.bo_fstype, "nfs", 3) == 0) { 153 if (modload("fs", "nfs") == -1) { 154 cmn_err(CE_CONT, "Cannot initialize %s filesystem\n", 155 rootfs.bo_fstype); 156 return (ENXIO); 157 } 158 } else { 159 if (modload("fs", rootfs.bo_fstype) == -1) { 160 cmn_err(CE_CONT, "Cannot initialize %s filesystem\n", 161 rootfs.bo_fstype); 162 return (ENXIO); 163 } 164 } 165 RLOCK_VFSSW(); 166 vsw = vfs_getvfsswbyname(rootfs.bo_fstype); 167 RUNLOCK_VFSSW(); 168 if (vsw == NULL) { 169 cmn_err(CE_CONT, "Cannot find %s filesystem\n", 170 rootfs.bo_fstype); 171 return (ENXIO); 172 } 173 VFS_INIT(rootvfs, &vsw->vsw_vfsops, (caddr_t)0); 174 VFS_HOLD(rootvfs); 175 176 if (root_is_svm) { 177 rootvfs->vfs_flag |= VFS_RDONLY; 178 } 179 180 /* 181 * This pm-releated call has to occur before root is mounted since we 182 * need to power up all devices. It is placed after VFS_INIT() such 183 * that opening a device via ddi_lyr_ interface just before root has 184 * been mounted would work. 185 */ 186 pm_init(); 187 188 if (netboot && iscsiboot_prop) { 189 cmn_err(CE_WARN, "NFS boot and iSCSI boot" 190 " shouldn't happen in the same time"); 191 return (EINVAL); 192 } 193 194 if (netboot || iscsiboot_prop) { 195 ret = strplumb(); 196 if (ret != 0) { 197 cmn_err(CE_WARN, "Cannot plumb network device %d", ret); 198 return (EFAULT); 199 } 200 } 201 202 if ((ret == 0) && iscsiboot_prop) { 203 ret = modload("drv", "iscsi"); 204 /* -1 indicates fail */ 205 if (ret == -1) { 206 cmn_err(CE_WARN, "Failed to load iscsi module"); 207 iscsi_boot_prop_free(); 208 return (EINVAL); 209 } else { 210 if (!i_ddi_attach_pseudo_node("iscsi")) { 211 cmn_err(CE_WARN, 212 "Failed to attach iscsi driver"); 213 iscsi_boot_prop_free(); 214 return (ENODEV); 215 } 216 } 217 } 218 219 /* 220 * ufs_mountroot() ends up calling getrootdev() 221 * (below) which actually triggers the _init, identify, 222 * probe and attach of the drivers that make up root device 223 * bush; these are also quietly waiting in memory. 224 */ 225 BMDPRINTF(("rootconf: calling VFS_MOUNTROOT %s\n", rootfs.bo_fstype)); 226 227 error = VFS_MOUNTROOT(rootvfs, ROOT_INIT); 228 vfs_unrefvfssw(vsw); 229 rootdev = rootvfs->vfs_dev; 230 231 if (error) 232 cmn_err(CE_CONT, "Cannot mount root on %s fstype %s\n", 233 rootfs.bo_name, rootfs.bo_fstype); 234 else 235 cmn_err(CE_CONT, "?root on %s fstype %s\n", 236 rootfs.bo_name, rootfs.bo_fstype); 237 return (error); 238 } 239 240 /* 241 * Remount root on an SVM mirror root device 242 * Only supported on UFS filesystems at present 243 */ 244 int 245 svm_rootconf(void) 246 { 247 int error; 248 extern int ufs_remountroot(struct vfs *vfsp); 249 250 ASSERT(root_is_svm == 1); 251 252 if (strcmp(rootfs.bo_fstype, "ufs") != 0) { 253 cmn_err(CE_CONT, "Mounting root on %s with filesystem " 254 "type %s is not supported\n", 255 rootfs.bo_name, rootfs.bo_fstype); 256 return (EINVAL); 257 } 258 259 (void) strncpy(rootfs.bo_name, svm_bootpath, BO_MAXOBJNAME); 260 261 BMDPRINTF(("svm_rootconf: rootfs %s\n", rootfs.bo_name)); 262 263 error = ufs_remountroot(rootvfs); 264 265 if (error) { 266 cmn_err(CE_CONT, "Cannot remount root on %s fstype %s\n", 267 rootfs.bo_name, rootfs.bo_fstype); 268 } else { 269 cmn_err(CE_CONT, "?root remounted on %s fstype %s\n", 270 rootfs.bo_name, rootfs.bo_fstype); 271 } 272 return (error); 273 } 274 275 /* 276 * Under the assumption that our root file system is on a 277 * disk partition, get the dev_t of the partition in question. 278 * 279 * By now, boot has faithfully loaded all our modules into memory, and 280 * we've taken over resource management. Before we go any further, we 281 * have to fire up the device drivers and stuff we need to mount the 282 * root filesystem. That's what we do here. Fingers crossed. 283 */ 284 dev_t 285 getrootdev(void) 286 { 287 dev_t d; 288 289 d = ddi_pathname_to_dev_t(rootfs.bo_name); 290 if ((d == NODEV) && (iscsiboot_prop != NULL)) { 291 /* Give it another try with the 'disk' path */ 292 get_iscsi_bootpath_phy(rootfs.bo_name); 293 d = ddi_pathname_to_dev_t(rootfs.bo_name); 294 } 295 if (d == NODEV) 296 cmn_err(CE_CONT, "Cannot assemble drivers for root %s\n", 297 rootfs.bo_name); 298 return (d); 299 } 300 301 /* 302 * If booted with ASKNAME, prompt on the console for a filesystem 303 * name and return it. 304 */ 305 void 306 getfsname(char *askfor, char *name, size_t namelen) 307 { 308 if (boothowto & RB_ASKNAME) { 309 printf("%s name: ", askfor); 310 console_gets(name, namelen); 311 } 312 } 313 314 /*ARGSUSED1*/ 315 static int 316 preload_module(struct sysparam *sysp, void *p) 317 { 318 static char *wmesg = "forceload of %s failed"; 319 char *name; 320 321 name = sysp->sys_ptr; 322 BMDPRINTF(("preload_module: %s\n", name)); 323 if (modloadonly(NULL, name) < 0) 324 cmn_err(CE_WARN, wmesg, name); 325 return (0); 326 } 327 328 /* 329 * We want to load all the modules needed to mount the root filesystem, 330 * so that when we start the ball rolling in 'getrootdev', every module 331 * should already be in memory, just waiting to be init-ed. 332 */ 333 334 int 335 loadrootmodules(void) 336 { 337 struct vfssw *vsw; 338 char *this; 339 char *name; 340 int err; 341 int i, proplen; 342 extern char *impl_module_list[]; 343 extern char *platform_module_list[]; 344 345 /* Make sure that the PROM's devinfo tree has been created */ 346 ASSERT(ddi_root_node()); 347 348 BMDPRINTF(("loadrootmodules: fstype %s\n", rootfs.bo_fstype)); 349 BMDPRINTF(("loadrootmodules: name %s\n", rootfs.bo_name)); 350 BMDPRINTF(("loadrootmodules: flags 0x%x\n", rootfs.bo_flags)); 351 352 /* 353 * zzz We need to honor what's in rootfs if it's not null. 354 * non-null means use what's there. This way we can 355 * change rootfs with /etc/system AND with tunetool. 356 */ 357 if (root_is_svm) { 358 /* user replaced rootdev, record obp_bootpath */ 359 obp_bootpath[0] = '\0'; 360 (void) getphysdev("root", obp_bootpath, BO_MAXOBJNAME); 361 BMDPRINTF(("loadrootmodules: obp_bootpath %s\n", obp_bootpath)); 362 } else { 363 /* 364 * Get the root fstype and root device path from boot. 365 */ 366 rootfs.bo_fstype[0] = '\0'; 367 rootfs.bo_name[0] = '\0'; 368 } 369 370 /* 371 * This lookup will result in modloadonly-ing the root 372 * filesystem module - it gets _init-ed in rootconf() 373 */ 374 if ((vsw = getfstype("root", rootfs.bo_fstype, BO_MAXFSNAME)) == NULL) 375 return (ENXIO); /* in case we have no file system types */ 376 377 (void) strcpy(rootfs.bo_fstype, vsw->vsw_name); 378 379 vfs_unrefvfssw(vsw); 380 381 /* 382 * Load the favored drivers of the implementation. 383 * e.g. 'sbus' and possibly 'zs' (even). 384 * 385 * Called whilst boot is still loaded (because boot does 386 * the i/o for us), and DDI services are unavailable. 387 */ 388 BMDPRINTF(("loadrootmodules: impl_module_list\n")); 389 for (i = 0; (this = impl_module_list[i]) != NULL; i++) { 390 if ((err = load_boot_driver(this)) != 0) { 391 cmn_err(CE_WARN, "Cannot load drv/%s", this); 392 return (err); 393 } 394 } 395 /* 396 * Now load the platform modules (if any) 397 */ 398 BMDPRINTF(("loadrootmodules: platform_module_list\n")); 399 for (i = 0; (this = platform_module_list[i]) != NULL; i++) { 400 if ((err = load_boot_platform_modules(this)) != 0) { 401 cmn_err(CE_WARN, "Cannot load drv/%s", this); 402 return (err); 403 } 404 } 405 406 loop: 407 (void) getphysdev("root", rootfs.bo_name, BO_MAXOBJNAME); 408 /* 409 * Given a physical pathname, load the correct set of driver 410 * modules into memory, including all possible parents. 411 * 412 * NB: The code sets the variable 'name' for error reporting. 413 */ 414 err = 0; 415 BMDPRINTF(("loadrootmodules: rootfs %s\n", rootfs.bo_name)); 416 if (root_is_svm == 0) { 417 BMDPRINTF(("loadrootmodules: rootfs %s\n", rootfs.bo_name)); 418 name = rootfs.bo_name; 419 err = load_bootpath_drivers(rootfs.bo_name); 420 } 421 422 /* 423 * Load driver modules in obp_bootpath, this is always 424 * required for mountroot to succeed. obp_bootpath is 425 * is set if rootdev is set via /etc/system, which is 426 * the case if booting of a SVM/VxVM mirror. 427 */ 428 if ((err == 0) && obp_bootpath[0] != '\0') { 429 BMDPRINTF(("loadrootmodules: obp_bootpath %s\n", obp_bootpath)); 430 name = obp_bootpath; 431 err = load_bootpath_drivers(obp_bootpath); 432 } 433 434 if (err != 0) { 435 cmn_err(CE_CONT, "Cannot load drivers for %s\n", name); 436 goto out; 437 } 438 439 /* 440 * Check to see if the booter performed DHCP configuration 441 * ("bootp-response" boot property exists). If so, then before 442 * bootops disappears we need to save the value of this property 443 * such that the userland dhcpagent can adopt the DHCP management 444 * of our primary network interface. 445 */ 446 proplen = BOP_GETPROPLEN(bootops, "bootp-response"); 447 if (proplen > 0) { 448 dhcack = kmem_zalloc(proplen, KM_SLEEP); 449 if (BOP_GETPROP(bootops, "bootp-response", dhcack) == -1) { 450 cmn_err(CE_WARN, "BOP_GETPROP of " 451 "\"bootp-response\" failed\n"); 452 kmem_free(dhcack, dhcacklen); 453 dhcack = NULL; 454 goto out; 455 } 456 dhcacklen = proplen; 457 458 /* 459 * Fetch the "netdev-path" boot property (if it exists), and 460 * stash it for later use by sysinfo(SI_DHCP_CACHE, ...). 461 */ 462 proplen = BOP_GETPROPLEN(bootops, "netdev-path"); 463 if (proplen > 0) { 464 netdev_path = kmem_zalloc(proplen, KM_SLEEP); 465 if (BOP_GETPROP(bootops, "netdev-path", 466 (uchar_t *)netdev_path) == -1) { 467 cmn_err(CE_WARN, "BOP_GETPROP of " 468 "\"netdev-path\" failed\n"); 469 kmem_free(netdev_path, proplen); 470 goto out; 471 } 472 } 473 } 474 475 /* 476 * Preload (load-only, no init) all modules which 477 * were added to the /etc/system file with the 478 * FORCELOAD keyword. 479 */ 480 BMDPRINTF(("loadrootmodules: preload_module\n")); 481 (void) mod_sysctl_type(MOD_FORCELOAD, preload_module, NULL); 482 483 /* 484 * If we booted otw then load in the plumbing 485 * routine now while we still can. If we didn't 486 * boot otw then we will load strplumb in main(). 487 * 488 * NFS is actually a set of modules, the core routines, 489 * a diskless helper module, rpcmod, and the tli interface. Load 490 * them now while we still can. 491 * 492 * Because we glomb all versions of nfs into a single module 493 * we check based on the initial string "nfs". 494 * 495 * XXX: A better test for this is to see if device_type 496 * XXX: from the PROM is "network". 497 */ 498 499 if (strncmp(rootfs.bo_fstype, "nfs", 3) == 0) { 500 ++netboot; 501 502 /* 503 * Preload (load-only, no init) the dacf module. We cannot 504 * init the module because one of its requisite modules is 505 * dld whose _init function will call taskq_create(), which 506 * will panic the system at this point. 507 */ 508 if ((err = modloadonly("dacf", "net_dacf")) < 0) { 509 cmn_err(CE_CONT, "Cannot load dacf/net_dacf\n"); 510 goto out; 511 } 512 if ((err = modload("misc", "tlimod")) < 0) { 513 cmn_err(CE_CONT, "Cannot load misc/tlimod\n"); 514 goto out; 515 } 516 if ((err = modload("strmod", "rpcmod")) < 0) { 517 cmn_err(CE_CONT, "Cannot load strmod/rpcmod\n"); 518 goto out; 519 } 520 if ((err = modload("misc", "nfs_dlboot")) < 0) { 521 cmn_err(CE_CONT, "Cannot load misc/nfs_dlboot\n"); 522 goto out; 523 } 524 if ((err = modload("mac", "mac_ether")) < 0) { 525 cmn_err(CE_CONT, "Cannot load mac/mac_ether\n"); 526 goto out; 527 } 528 if ((err = modload("misc", "strplumb")) < 0) { 529 cmn_err(CE_CONT, "Cannot load misc/strplumb\n"); 530 goto out; 531 } 532 if ((err = strplumb_load()) < 0) { 533 goto out; 534 } 535 } 536 if (netboot_over_iscsi() == B_TRUE) { 537 /* iscsi boot */ 538 if ((err = modloadonly("dacf", "net_dacf")) < 0) { 539 cmn_err(CE_CONT, "Cannot load dacf/net_dacf\n"); 540 goto out; 541 } 542 if ((err = modload("misc", "tlimod")) < 0) { 543 cmn_err(CE_CONT, "Cannot load misc/tlimod\n"); 544 goto out; 545 } 546 if ((err = modload("mac", "mac_ether")) < 0) { 547 cmn_err(CE_CONT, "Cannot load mac/mac_ether\n"); 548 goto out; 549 } 550 if ((err = modloadonly("drv", "iscsi")) < 0) { 551 cmn_err(CE_CONT, "Cannot load drv/iscsi\n"); 552 goto out; 553 } 554 if ((err = modloadonly("drv", "ssd")) < 0) { 555 cmn_err(CE_CONT, "Cannot load drv/ssd\n"); 556 goto out; 557 } 558 if ((err = modloadonly("drv", "sd")) < 0) { 559 cmn_err(CE_CONT, "Cannot load drv/sd\n"); 560 goto out; 561 } 562 if ((err = modload("misc", "strplumb")) < 0) { 563 cmn_err(CE_CONT, "Cannot load misc/strplumb\n"); 564 goto out; 565 } 566 if ((err = strplumb_load()) < 0) { 567 goto out; 568 } 569 } 570 /* 571 * Preload modules needed for booting as a cluster. 572 */ 573 err = clboot_loadrootmodules(); 574 575 out: 576 if (err != 0 && (boothowto & RB_ASKNAME)) 577 goto loop; 578 579 return (err); 580 } 581 582 static int 583 get_bootpath_prop(char *bootpath) 584 { 585 if (root_is_ramdisk) { 586 if (BOP_GETPROP(bootops, "bootarchive", bootpath) == -1) 587 return (-1); 588 (void) strlcat(bootpath, ":a", BO_MAXOBJNAME); 589 } else { 590 /* 591 * Look for the 1275 compliant name 'bootpath' first, 592 * but make certain it has a non-NULL value as well. 593 */ 594 if ((BOP_GETPROP(bootops, "bootpath", bootpath) == -1) || 595 strlen(bootpath) == 0) { 596 if (BOP_GETPROP(bootops, 597 "boot-path", bootpath) == -1) 598 return (-1); 599 } 600 if (memcmp(bootpath, BP_ISCSI_DISK, 601 strlen(BP_ISCSI_DISK)) == 0) { 602 /* iscsi boot */ 603 get_iscsi_bootpath_vhci(bootpath); 604 } 605 } 606 return (0); 607 } 608 609 static int 610 get_fstype_prop(char *fstype) 611 { 612 char *prop = (root_is_ramdisk) ? "archive-fstype" : "fstype"; 613 614 return (BOP_GETPROP(bootops, prop, fstype)); 615 } 616 617 /* 618 * Get the name of the root or swap filesystem type, and return 619 * the corresponding entry in the vfs switch. 620 * 621 * If we're not asking the user, and we're trying to find the 622 * root filesystem type, we ask boot for the filesystem 623 * type that it came from and use that. Similarly, if we're 624 * trying to find the swap filesystem, we try and derive it from 625 * the root filesystem type. 626 * 627 * If we are booting via NFS we currently have these options: 628 * nfs - dynamically choose NFS V2. V3, or V4 (default) 629 * nfs2 - force NFS V2 630 * nfs3 - force NFS V3 631 * nfs4 - force NFS V4 632 * Because we need to maintain backward compatibility with the naming 633 * convention that the NFS V2 filesystem name is "nfs" (see vfs_conf.c) 634 * we need to map "nfs" => "nfsdyn" and "nfs2" => "nfs". The dynamic 635 * nfs module will map the type back to either "nfs", "nfs3", or "nfs4". 636 * This is only for root filesystems, all other uses will expect 637 * that "nfs" == NFS V2. 638 * 639 * If the filesystem isn't already loaded, vfs_getvfssw() will load 640 * it for us, but if (at the time we call it) modrootloaded is 641 * still not set, it won't run the filesystems _init routine (and 642 * implicitly it won't run the filesystems vsw_init() entry either). 643 * We do that explicitly in rootconf(). 644 */ 645 static struct vfssw * 646 getfstype(char *askfor, char *fsname, size_t fsnamelen) 647 { 648 struct vfssw *vsw; 649 static char defaultfs[BO_MAXFSNAME]; 650 int root = 0; 651 652 if (strcmp(askfor, "root") == 0) { 653 (void) get_fstype_prop(defaultfs); 654 root++; 655 } else { 656 (void) strcpy(defaultfs, "swapfs"); 657 } 658 659 if (boothowto & RB_ASKNAME) { 660 for (*fsname = '\0'; *fsname == '\0'; *fsname = '\0') { 661 printf("%s filesystem type [%s]: ", askfor, defaultfs); 662 console_gets(fsname, fsnamelen); 663 if (*fsname == '\0') 664 (void) strcpy(fsname, defaultfs); 665 if (root) { 666 if (strcmp(fsname, "nfs2") == 0) 667 (void) strcpy(fsname, "nfs"); 668 else if (strcmp(fsname, "nfs") == 0) 669 (void) strcpy(fsname, "nfsdyn"); 670 } 671 if ((vsw = vfs_getvfssw(fsname)) != NULL) 672 return (vsw); 673 printf("Unknown filesystem type '%s'\n", fsname); 674 } 675 } else if (*fsname == '\0') { 676 fsname = defaultfs; 677 } 678 if (*fsname == '\0') { 679 return (NULL); 680 } 681 682 if (root) { 683 if (strcmp(fsname, "nfs2") == 0) 684 (void) strcpy(fsname, "nfs"); 685 else if (strcmp(fsname, "nfs") == 0) 686 (void) strcpy(fsname, "nfsdyn"); 687 } 688 689 return (vfs_getvfssw(fsname)); 690 } 691 692 693 /* 694 * Get a physical device name, and maybe load and attach 695 * the driver. 696 * 697 * XXX Need better checking of whether or not a device 698 * actually exists if the user typed in a pathname. 699 * 700 * XXX Are we sure we want to expose users to this sort 701 * of physical namespace gobbledygook (now there's 702 * a word to conjure with..) 703 * 704 * XXX Note that on an OBP machine, we can easily ask the 705 * prom and pretty-print some plausible set of bootable 706 * devices. We can also user the prom to verify any 707 * such device. Later tim.. later. 708 */ 709 static int 710 getphysdev(char *askfor, char *name, size_t namelen) 711 { 712 static char fmt[] = "Enter physical name of %s device\n[%s]: "; 713 dev_t dev; 714 static char defaultpath[BO_MAXOBJNAME]; 715 716 /* 717 * Establish 'default' values - we get the root device from 718 * boot, and we infer the swap device is the same but with 719 * a 'b' on the end instead of an 'a'. A first stab at 720 * ease-of-use .. 721 */ 722 if (strcmp(askfor, "root") == 0) { 723 if (get_bootpath_prop(defaultpath) == -1) 724 boothowto |= RB_ASKNAME | RB_VERBOSE; 725 } else { 726 (void) strcpy(defaultpath, rootfs.bo_name); 727 defaultpath[strlen(defaultpath) - 1] = 'b'; 728 } 729 730 retry: 731 if (boothowto & RB_ASKNAME) { 732 printf(fmt, askfor, defaultpath); 733 console_gets(name, namelen); 734 } 735 if (*name == '\0') 736 (void) strcpy(name, defaultpath); 737 738 if (strcmp(askfor, "swap") == 0) { 739 740 /* 741 * Try to load and install the swap device driver. 742 */ 743 dev = ddi_pathname_to_dev_t(name); 744 745 if (dev == (dev_t)-1) { 746 printf("Not a supported device for swap.\n"); 747 boothowto |= RB_ASKNAME | RB_VERBOSE; 748 goto retry; 749 } 750 751 /* 752 * Ensure that we're not trying to swap on the floppy. 753 */ 754 if (strncmp(ddi_major_to_name(getmajor(dev)), "fd", 2) == 0) { 755 printf("Too dangerous to swap on the floppy\n"); 756 if (boothowto & RB_ASKNAME) 757 goto retry; 758 return (-1); 759 } 760 } 761 762 return (0); 763 } 764 765 766 /* 767 * Load a driver needed to boot. 768 */ 769 static int 770 load_boot_driver(char *drv) 771 { 772 char *drvname; 773 major_t major; 774 #ifdef sparc 775 struct devnames *dnp; 776 ddi_prop_t *propp; 777 char *module; 778 char *dir, *mf; 779 int plen; 780 int mlen; 781 #endif /* sparc */ 782 783 if ((major = ddi_name_to_major(drv)) == DDI_MAJOR_T_NONE) { 784 cmn_err(CE_CONT, "%s: no major number\n", drv); 785 return (-1); 786 } 787 /* 788 * resolve aliases 789 */ 790 drvname = ddi_major_to_name(major); 791 792 #ifdef DEBUG 793 if (strcmp(drv, drvname) == 0) { 794 BMDPRINTF(("load_boot_driver: %s\n", drv)); 795 } else { 796 BMDPRINTF(("load_boot_driver: %s -> %s\n", drv, drvname)); 797 } 798 #endif /* DEBUG */ 799 800 if (modloadonly("drv", drvname) == -1) { 801 cmn_err(CE_CONT, "%s: cannot load driver\n", drvname); 802 return (-1); 803 } 804 805 #ifdef sparc 806 /* 807 * NOTE: this can be removed when newboot-sparc is delivered. 808 * 809 * Check to see if the driver had a 'ddi-forceload' global driver.conf 810 * property to identify additional modules that need to be loaded. 811 * The driver still needs to use ddi_modopen() to open these modules, 812 * but the 'ddi-forceload' property allows the modules to be loaded 813 * into memory prior to lights-out, so that driver ddi_modopen() 814 * calls during lights-out (when mounting root) will work correctly. 815 * Use of 'ddi-forceload' is only required for drivers involved in 816 * getting root mounted. 817 */ 818 dnp = &devnamesp[major]; 819 if (dnp->dn_global_prop_ptr && dnp->dn_global_prop_ptr->prop_list && 820 ((propp = i_ddi_prop_search(DDI_DEV_T_ANY, 821 "ddi-forceload", DDI_PROP_TYPE_STRING, 822 &dnp->dn_global_prop_ptr->prop_list)) != NULL)) { 823 824 module = (char *)propp->prop_val; 825 plen = propp->prop_len; 826 while (plen > 0) { 827 mlen = strlen(module); 828 mf = strrchr(module, '/'); 829 if (mf) { 830 dir = module; 831 *mf++ = '\0'; /* '/' -> '\0' */ 832 } else { 833 dir = "misc"; 834 mf = module; 835 } 836 if (modloadonly(dir, mf) == -1) 837 cmn_err(CE_CONT, 838 "misc/%s: can't load module\n", mf); 839 if (mf != module) 840 *(mf - 1) = '/'; /* '\0' -> '/' */ 841 842 module += mlen + 1; 843 plen -= mlen + 1; 844 } 845 } 846 #endif /* sparc */ 847 848 return (0); 849 } 850 851 852 /* 853 * For a given instance, load that driver and its parents 854 */ 855 static int 856 load_parent_drivers(dev_info_t *dip, char *path) 857 { 858 int rval = 0; 859 major_t major = DDI_MAJOR_T_NONE; 860 char *drv; 861 char *p; 862 863 while (dip) { 864 /* check for path-oriented alias */ 865 if (path) 866 major = ddi_name_to_major(path); 867 else 868 major = DDI_MAJOR_T_NONE; 869 870 if (major != DDI_MAJOR_T_NONE) 871 drv = ddi_major_to_name(major); 872 else 873 drv = ddi_binding_name(dip); 874 875 if (load_boot_driver(drv) != 0) 876 rval = -1; 877 878 dip = ddi_get_parent(dip); 879 if (path) { 880 p = strrchr(path, '/'); 881 if (p) 882 *p = 0; 883 } 884 } 885 886 return (rval); 887 } 888 889 890 /* 891 * For a given path to a boot device, 892 * load that driver and all its parents. 893 */ 894 static int 895 load_bootpath_drivers(char *bootpath) 896 { 897 dev_info_t *dip; 898 char *pathcopy; 899 int pathcopy_len; 900 int rval; 901 char *p; 902 int proplen; 903 char iscsi_network_path[BO_MAXOBJNAME]; 904 905 if (bootpath == NULL || *bootpath == 0) 906 return (-1); 907 908 BMDPRINTF(("load_bootpath_drivers: %s\n", bootpath)); 909 #ifdef _OBP 910 if (netboot_over_iscsi()) { 911 /* iscsi boot */ 912 if (root_is_ramdisk) { 913 if (modloadonly("drv", "ramdisk") < 0) 914 return (-1); 915 } 916 proplen = BOP_GETPROPLEN(bootops, BP_ISCSI_NETWORK_BOOTPATH); 917 if (proplen > 0) { 918 if (BOP_GETPROP(bootops, BP_ISCSI_NETWORK_BOOTPATH, 919 iscsi_network_path) > 0) { 920 p = strchr(iscsi_network_path, ':'); 921 if (p != NULL) { 922 *p = '\0'; 923 } 924 pathcopy = i_ddi_strdup(iscsi_network_path, 925 KM_SLEEP); 926 pathcopy_len = strlen(pathcopy) + 1; 927 } else { 928 return (-1); 929 } 930 } else { 931 return (-1); 932 } 933 } else { 934 #endif 935 pathcopy = i_ddi_strdup(bootpath, KM_SLEEP); 936 pathcopy_len = strlen(pathcopy) + 1; 937 #ifdef _OBP 938 } 939 #endif 940 dip = path_to_devinfo(pathcopy); 941 942 #if defined(__i386) || defined(__amd64) 943 /* 944 * i386 does not provide stub nodes for all boot devices, 945 * but we should be able to find the node for the parent, 946 * and the leaf of the boot path should be the driver name, 947 * which we go ahead and load here. 948 */ 949 if (dip == NULL) { 950 char *leaf; 951 952 /* 953 * Find last slash to build the full path to the 954 * parent of the leaf boot device 955 */ 956 p = strrchr(pathcopy, '/'); 957 *p++ = 0; 958 959 /* 960 * Now isolate the driver name of the leaf device 961 */ 962 leaf = p; 963 p = strchr(leaf, '@'); 964 *p = 0; 965 966 BMDPRINTF(("load_bootpath_drivers: parent=%s leaf=%s\n", 967 bootpath, leaf)); 968 969 dip = path_to_devinfo(pathcopy); 970 if (leaf) { 971 rval = load_boot_driver(leaf, NULL); 972 if (rval == -1) { 973 kmem_free(pathcopy, pathcopy_len); 974 return (NULL); 975 } 976 } 977 } 978 #endif 979 980 if (dip == NULL) { 981 cmn_err(CE_WARN, "can't bind driver for boot path <%s>", 982 bootpath); 983 kmem_free(pathcopy, pathcopy_len); 984 return (NULL); 985 } 986 987 /* 988 * Load IP over IB driver when netbooting over IB. 989 * As per IB 1275 binding, IP over IB is represented as 990 * service on the top of the HCA node. So, there is no 991 * PROM node and generic framework cannot pre-load 992 * IP over IB driver based on the bootpath. The following 993 * code preloads IP over IB driver when doing netboot over 994 * InfiniBand. 995 */ 996 if (netboot_over_ib(bootpath) && 997 modloadonly("drv", "ibp") == -1) { 998 cmn_err(CE_CONT, "ibp: cannot load platform driver\n"); 999 kmem_free(pathcopy, pathcopy_len); 1000 return (NULL); 1001 } 1002 1003 /* 1004 * The PROM node for hubs have incomplete compatible 1005 * properties and therefore do not bind to the hubd driver. 1006 * As a result load_bootpath_drivers() loads the usb_mid driver 1007 * for hub nodes rather than the hubd driver. This causes 1008 * mountroot failures when booting off USB storage. To prevent 1009 * this, if we are booting via USB hubs, we preload the hubd driver. 1010 */ 1011 if (strstr(bootpath, "/hub@") && modloadonly("drv", "hubd") == -1) { 1012 cmn_err(CE_WARN, "bootpath contains a USB hub, " 1013 "but cannot load hubd driver"); 1014 } 1015 1016 /* get rid of minor node at end of copy (if not already done above) */ 1017 p = strrchr(pathcopy, '/'); 1018 if (p) { 1019 p = strchr(p, ':'); 1020 if (p) 1021 *p = 0; 1022 } 1023 1024 rval = load_parent_drivers(dip, pathcopy); 1025 kmem_free(pathcopy, pathcopy_len); 1026 return (rval); 1027 } 1028 1029 1030 1031 1032 /* 1033 * Load drivers required for a platform 1034 * Since all hardware nodes should be available in the device 1035 * tree, walk the per-driver list and load the parents of 1036 * each node found. If not a hardware node, try to load it. 1037 * Pseudo nexus is already loaded. 1038 */ 1039 static int 1040 load_boot_platform_modules(char *drv) 1041 { 1042 major_t major; 1043 dev_info_t *dip; 1044 char *drvname; 1045 int rval = 0; 1046 1047 if ((major = ddi_name_to_major(drv)) == DDI_MAJOR_T_NONE) { 1048 cmn_err(CE_CONT, "%s: no major number\n", drv); 1049 return (-1); 1050 } 1051 1052 /* 1053 * resolve aliases 1054 */ 1055 drvname = ddi_major_to_name(major); 1056 if ((major = ddi_name_to_major(drvname)) == DDI_MAJOR_T_NONE) 1057 return (-1); 1058 1059 #ifdef DEBUG 1060 if (strcmp(drv, drvname) == 0) { 1061 BMDPRINTF(("load_boot_platform_modules: %s\n", drv)); 1062 } else { 1063 BMDPRINTF(("load_boot_platform_modules: %s -> %s\n", 1064 drv, drvname)); 1065 } 1066 #endif /* DEBUG */ 1067 1068 dip = devnamesp[major].dn_head; 1069 if (dip == NULL) { 1070 /* pseudo node, not-enumerated, needs to be loaded */ 1071 if (modloadonly("drv", drvname) == -1) { 1072 cmn_err(CE_CONT, "%s: cannot load platform driver\n", 1073 drvname); 1074 rval = -1; 1075 } 1076 } else { 1077 while (dip) { 1078 if (load_parent_drivers(dip, NULL) != 0) 1079 rval = -1; 1080 dip = ddi_get_next(dip); 1081 } 1082 } 1083 1084 return (rval); 1085 } 1086 1087 1088 /* 1089 * i_find_node: Internal routine used by path_to_devinfo 1090 * to locate a given nodeid in the device tree. 1091 */ 1092 struct i_path_findnode { 1093 pnode_t nodeid; 1094 dev_info_t *dip; 1095 }; 1096 1097 static int 1098 i_path_find_node(dev_info_t *dev, void *arg) 1099 { 1100 struct i_path_findnode *f = (struct i_path_findnode *)arg; 1101 1102 1103 if (ddi_get_nodeid(dev) == (int)f->nodeid) { 1104 f->dip = dev; 1105 return (DDI_WALK_TERMINATE); 1106 } 1107 return (DDI_WALK_CONTINUE); 1108 } 1109 1110 /* 1111 * Return the devinfo node to a boot device 1112 */ 1113 static dev_info_t * 1114 path_to_devinfo(char *path) 1115 { 1116 struct i_path_findnode fn; 1117 extern dev_info_t *top_devinfo; 1118 1119 /* 1120 * Get the nodeid of the given pathname, if such a mapping exists. 1121 */ 1122 fn.dip = NULL; 1123 fn.nodeid = prom_finddevice(path); 1124 if (fn.nodeid != OBP_BADNODE) { 1125 /* 1126 * Find the nodeid in our copy of the device tree and return 1127 * whatever name we used to bind this node to a driver. 1128 */ 1129 ddi_walk_devs(top_devinfo, i_path_find_node, (void *)(&fn)); 1130 } 1131 1132 #ifdef DEBUG 1133 /* 1134 * If we're bound to something other than the nodename, 1135 * note that in the message buffer and system log. 1136 */ 1137 if (fn.dip) { 1138 char *p, *q; 1139 1140 p = ddi_binding_name(fn.dip); 1141 q = ddi_node_name(fn.dip); 1142 if (p && q && (strcmp(p, q) != 0)) { 1143 BMDPRINTF(("path_to_devinfo: %s bound to %s\n", 1144 path, p)); 1145 } 1146 } 1147 #endif /* DEBUG */ 1148 1149 return (fn.dip); 1150 } 1151 1152 /* 1153 * This routine returns B_TRUE if the bootpath corresponds to 1154 * IP over IB driver. 1155 * 1156 * The format of the bootpath for the IP over IB looks like 1157 * /pci@1f,700000/pci@1/ib@0:port=1,pkey=8001,protocol=ip 1158 * 1159 * The minor node portion "port=1,pkey=8001,protocol=ip" represents 1160 * IP over IB driver. 1161 */ 1162 static boolean_t 1163 netboot_over_ib(char *bootpath) 1164 { 1165 1166 char *temp; 1167 boolean_t ret = B_FALSE; 1168 pnode_t node = prom_finddevice(bootpath); 1169 int len; 1170 char devicetype[OBP_MAXDRVNAME]; 1171 1172 /* Is this IB node ? */ 1173 if (node == OBP_BADNODE || node == OBP_NONODE) { 1174 return (B_FALSE); 1175 } 1176 len = prom_getproplen(node, OBP_DEVICETYPE); 1177 if (len <= 1 || len >= OBP_MAXDRVNAME) 1178 return (B_FALSE); 1179 1180 (void) prom_getprop(node, OBP_DEVICETYPE, (caddr_t)devicetype); 1181 1182 if (strncmp("ib", devicetype, 2) == 0) { 1183 /* Check for proper IP over IB string */ 1184 if ((temp = strstr(bootpath, ":port=")) != NULL) { 1185 if ((temp = strstr(temp, ",pkey=")) != NULL) 1186 if ((temp = strstr(temp, 1187 ",protocol=ip")) != NULL) { 1188 ret = B_TRUE; 1189 } 1190 } 1191 } 1192 return (ret); 1193 } 1194 1195 static boolean_t 1196 netboot_over_iscsi(void) 1197 { 1198 int proplen; 1199 boolean_t ret = B_FALSE; 1200 char bootpath[OBP_MAXPATHLEN]; 1201 1202 proplen = BOP_GETPROPLEN(bootops, BP_BOOTPATH); 1203 if (proplen > 0) { 1204 if (BOP_GETPROP(bootops, BP_BOOTPATH, bootpath) > 0) { 1205 if (memcmp(bootpath, BP_ISCSI_DISK, 1206 strlen(BP_ISCSI_DISK)) == 0) { 1207 ret = B_TRUE; 1208 } 1209 } 1210 } 1211 return (ret); 1212 } 1213