summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sbin/savecore/savecore.c22
-rw-r--r--sbin/savecore/savecore_old.c25
2 files changed, 26 insertions, 21 deletions
diff --git a/sbin/savecore/savecore.c b/sbin/savecore/savecore.c
index 53fec980979..419a07bb4e7 100644
--- a/sbin/savecore/savecore.c
+++ b/sbin/savecore/savecore.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: savecore.c,v 1.19 1999/08/16 18:38:50 art Exp $ */
+/* $OpenBSD: savecore.c,v 1.20 2000/05/31 17:09:17 millert Exp $ */
/* $NetBSD: savecore.c,v 1.26 1996/03/18 21:16:05 leo Exp $ */
/*-
@@ -44,7 +44,7 @@ static char copyright[] =
#if 0
static char sccsid[] = "@(#)savecore.c 8.3 (Berkeley) 1/2/94";
#else
-static char rcsid[] = "$OpenBSD: savecore.c,v 1.19 1999/08/16 18:38:50 art Exp $";
+static char rcsid[] = "$OpenBSD: savecore.c,v 1.20 2000/05/31 17:09:17 millert Exp $";
#endif
#endif /* not lint */
@@ -333,20 +333,22 @@ check_kmem()
KREAD(kd_dump, dump_nl[X_PANICSTR].n_value, &panicstr);
if (panicstr) {
char c, visout[5];
+ size_t vislen;
cp = panic_mesg;
panicloc = panicstr;
- do {
- KREAD(kd_dump, panicloc, &c);
+ for (;;) {
+ if (KREAD(kd_dump, panicloc, &c) != 0 || c == '\0')
+ break;
panicloc++;
vis(visout, c, VIS_SAFE|VIS_NOSLASH, 0);
- if (c && cp + strlen(visout) <
- &panic_mesg[sizeof(panic_mesg)]) {
- strcat(cp, visout);
- cp += strlen(visout);
- }
- } while (c && cp < &panic_mesg[sizeof(panic_mesg)]);
+ vislen = strlen(visout);
+ if (cp - panic_mesg + vislen >= sizeof(panic_mesg))
+ break;
+ strcat(cp, visout);
+ cp += vislen;
+ }
}
}
diff --git a/sbin/savecore/savecore_old.c b/sbin/savecore/savecore_old.c
index 172856750a7..6a62358e0e9 100644
--- a/sbin/savecore/savecore_old.c
+++ b/sbin/savecore/savecore_old.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: savecore_old.c,v 1.15 1999/07/01 15:41:59 deraadt Exp $ */
+/* $OpenBSD: savecore_old.c,v 1.16 2000/05/31 17:09:17 millert Exp $ */
/* $NetBSD: savecore_old.c,v 1.1.1.1 1996/03/16 10:25:11 leo Exp $ */
/*-
@@ -44,7 +44,7 @@ static char copyright[] =
#if 0
static char sccsid[] = "@(#)savecore.c 8.3 (Berkeley) 1/2/94";
#else
-static char rcsid[] = "$OpenBSD: savecore_old.c,v 1.15 1999/07/01 15:41:59 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: savecore_old.c,v 1.16 2000/05/31 17:09:17 millert Exp $";
#endif
#endif /* not lint */
@@ -325,19 +325,22 @@ check_kmem()
(void)fread(&panicstr, sizeof(panicstr), 1, fp);
if (panicstr) {
char c, visout[5];
+ size_t vislen;
- cp = panic_mesg;
- (void)fseek(fp, dumplo + ok(panicstr), SEEK_SET);
cp = panic_mesg;
- do {
+ (void)fseek(fp, dumplo + ok(panicstr), SEEK_SET);
+ for (;;) {
c = getc(fp);
+ if (c == EOF || c == '\0')
+ break;
+
vis(visout, c, VIS_SAFE|VIS_NOSLASH, 0);
- if (c && cp + strlen(visout) <
- &panic_mesg[sizeof(panic_mesg)]) {
- strcat(cp, visout);
- cp += strlen(visout);
- }
- } while (c && cp < &panic_mesg[sizeof(panic_mesg)]);
+ vislen = strlen(visout);
+ if (cp - panic_mesg + vislen >= sizeof(panic_mesg))
+ break;
+ strcat(cp, visout);
+ cp += vislen;
+ }
}
/* Don't fclose(fp), we use dumpfd later. */
}