summaryrefslogtreecommitdiffstats
path: root/usr.sbin/sade
diff options
context:
space:
mode:
authorjkh <jkh@FreeBSD.org>2000-02-25 20:55:15 +0000
committerjkh <jkh@FreeBSD.org>2000-02-25 20:55:15 +0000
commit056294e1461659ca4550427c91cc02241a37657a (patch)
treead4a62bf3c576c6a0844fd9c13d57254de935acd /usr.sbin/sade
parent37325dc4d2abf0e9c0b5e80933d3e0d4e955e0d1 (diff)
downloadFreeBSD-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.c37
-rw-r--r--usr.sbin/sade/system.c12
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);
OpenPOWER on IntegriCloud