diff options
author | jkh <jkh@FreeBSD.org> | 2000-02-25 20:55:15 +0000 |
---|---|---|
committer | jkh <jkh@FreeBSD.org> | 2000-02-25 20:55:15 +0000 |
commit | 056294e1461659ca4550427c91cc02241a37657a (patch) | |
tree | ad4a62bf3c576c6a0844fd9c13d57254de935acd /usr.sbin/sade | |
parent | 37325dc4d2abf0e9c0b5e80933d3e0d4e955e0d1 (diff) | |
download | FreeBSD-src-056294e1461659ca4550427c91cc02241a37657a.zip FreeBSD-src-056294e1461659ca4550427c91cc02241a37657a.tar.gz |
Make sysinstall use the new debug.boothowto OID. It will now go
straight into debug mode if you boot -v. Also conditionalize some
annoying debugging output now that we have this ability.
Partially submitted by: msmith
Approved by: jkh [to make certain wise-acres happy ;)]
Diffstat (limited to 'usr.sbin/sade')
-rw-r--r-- | usr.sbin/sade/devices.c | 37 | ||||
-rw-r--r-- | usr.sbin/sade/system.c | 12 |
2 files changed, 36 insertions, 13 deletions
diff --git a/usr.sbin/sade/devices.c b/usr.sbin/sade/devices.c index e6a5227..0a1dde3 100644 --- a/usr.sbin/sade/devices.c +++ b/usr.sbin/sade/devices.c @@ -165,24 +165,36 @@ deviceTry(struct _devname dev, char *try, int i) snprintf(unit, sizeof unit, dev.name, i); snprintf(try, FILENAME_MAX, "/dev/%s", unit); + if (isDebug()) + msgDebug("deviceTry: attempting to open %s\n", try); fd = open(try, O_RDONLY); - if (fd >= 0) + if (fd >= 0) { + if (isDebug()) + msgDebug("deviceTry: open of %s succeeded on first try.\n", try); return fd; + } m = 0640; if (dev.dev_type == 'c') m |= S_IFCHR; else m |= S_IFBLK; d = makedev(dev.major, dev.minor + (i * dev.delta)); + if (isDebug()) + msgDebug("deviceTry: Making %s device for %s [%d, %d]\n", m & S_IFCHR ? "raw" : "block", try, dev.major, dev.minor + (i * dev.delta)); fail = mknod(try, m, d); fd = open(try, O_RDONLY); - if (fd >= 0) + if (fd >= 0) { + if (isDebug()) + msgDebug("deviceTry: open of %s succeeded on second try.\n", try); return fd; + } else if (!fail) (void)unlink(try); /* Don't try a "make-under" here since we're using a fixit floppy in this case */ snprintf(try, FILENAME_MAX, "/mnt/dev/%s", unit); fd = open(try, O_RDONLY); + if (isDebug()) + msgDebug("deviceTry: final attempt for %s returns %d\n", try, fd); return fd; } @@ -291,7 +303,8 @@ deviceGetAll(void) deviceRegister(ifptr->ifr_name, descr, strdup(ifptr->ifr_name), DEVICE_TYPE_NETWORK, TRUE, mediaInitNetwork, NULL, mediaShutdownNetwork, NULL); - msgDebug("Found a network device named %s\n", ifptr->ifr_name); + if (isDebug()) + msgDebug("Found a network device named %s\n", ifptr->ifr_name); close(s); if ((s = socket(AF_INET, SOCK_DGRAM, 0)) < 0) continue; @@ -320,7 +333,8 @@ skipif: deviceRegister(strdup(n), device_names[i].description, strdup(try), DEVICE_TYPE_CDROM, TRUE, mediaInitCDROM, mediaGetCDROM, mediaShutdownCDROM, NULL); - msgDebug("Found a CDROM device for %s\n", try); + if (isDebug()) + msgDebug("Found a CDROM device for %s\n", try); } break; @@ -333,7 +347,8 @@ skipif: snprintf(n, sizeof n, device_names[i].name, j); deviceRegister(strdup(n), device_names[i].description, strdup(try), DEVICE_TYPE_TAPE, TRUE, mediaInitTape, mediaGetTape, mediaShutdownTape, NULL); - msgDebug("Found a TAPE device for %s\n", try); + if (isDebug()) + msgDebug("Found a TAPE device for %s\n", try); } break; @@ -377,7 +392,8 @@ skipif: deviceRegister(strdup(n), device_names[i].description, strdup(try), DEVICE_TYPE_FLOPPY, TRUE, mediaInitFloppy, mediaGetFloppy, mediaShutdownFloppy, NULL); - msgDebug("Found a floppy device for %s\n", try); + if (isDebug()) + msgDebug("Found a floppy device for %s\n", try); } break; @@ -399,7 +415,8 @@ skipif: sprintf(newdesc, cp, "PPP interface", try, j + 1); deviceRegister("ppp0", newdesc, strdup(try), DEVICE_TYPE_NETWORK, TRUE, mediaInitNetwork, NULL, mediaShutdownNetwork, NULL); - msgDebug("Add mapping for %s to ppp0\n", try); + if (isDebug()) + msgDebug("Add mapping for %s to ppp0\n", try); } break; @@ -423,7 +440,8 @@ skipif: deviceRegister(names[i], names[i], d->name, DEVICE_TYPE_DISK, FALSE, dummyInit, dummyGet, dummyShutdown, d); - msgDebug("Found a disk device named %s\n", names[i]); + if (isDebug()) + msgDebug("Found a disk device named %s\n", names[i]); /* Look for existing DOS partitions to register as "DOS media devices" */ for (c1 = d->chunks->part; c1; c1 = c1->next) { @@ -436,7 +454,8 @@ skipif: dev = deviceRegister(c1->name, c1->name, strdup(devname), DEVICE_TYPE_DOS, TRUE, mediaInitDOS, mediaGetDOS, mediaShutdownDOS, NULL); dev->private = c1; - msgDebug("Found a DOS partition %s on drive %s\n", c1->name, d->name); + if (isDebug()) + msgDebug("Found a DOS partition %s on drive %s\n", c1->name, d->name); } } } diff --git a/usr.sbin/sade/system.c b/usr.sbin/sade/system.c index dfe3889..aaca077 100644 --- a/usr.sbin/sade/system.c +++ b/usr.sbin/sade/system.c @@ -72,13 +72,16 @@ expand(char *fname) void systemInitialize(int argc, char **argv) { -#ifdef __alpha__ - int i; -#endif + int i, boothowto; signal(SIGINT, SIG_IGN); globalsInit(); + i = sizeof(boothowto); + if (!sysctlbyname("debug.boothowto", &boothowto, &i, NULL, NULL) && + (i == sizeof(boothowto)) && (boothowto & RB_VERBOSE)) + variable_set2(VAR_DEBUG, "YES", 0); + /* Are we running as init? */ if (getpid() == 1) { int fd, type; @@ -243,7 +246,8 @@ systemHelpFile(char *file, char *buf) { if (!file) return NULL; - + if (file[0] == '/') + return file; snprintf(buf, FILENAME_MAX, "/stand/help/%s.hlp.gz", file); if (file_readable(buf)) return expand(buf); |