From fdb4ec2e2767359eb6b5309a0342492c70d206e4 Mon Sep 17 00:00:00 2001 From: Garrett Wollman Date: Fri, 27 Jul 2012 19:50:42 -0400 Subject: [PATCH] butc: don't pass NULL to strcpy in RcreateDump volumesetNamePtr can return a null pointer in certain error conditions. Check for this and return BUDB_BADARGUMENT rather than dumping core. Change-Id: If0ce509c964211ffa591d8e095b7c32c51ae7bc3 Reviewed-on: http://gerrit.openafs.org/7890 Tested-by: BuildBot Reviewed-by: Derrick Brashear --- src/butc/recoverDb.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/butc/recoverDb.c b/src/butc/recoverDb.c index 7bc6f7d65e..b1f5c90e4a 100644 --- a/src/butc/recoverDb.c +++ b/src/butc/recoverDb.c @@ -906,6 +906,7 @@ RcreateDump(struct tapeScanInfo *tapeScanInfoPtr, struct volumeHeader *volHeaderPtr) { afs_int32 code; + const char *volsetName; struct butm_tapeLabel *dumpLabelPtr = &tapeScanInfoPtr->dumpLabel; struct budb_dumpEntry *dumpEntryPtr = &tapeScanInfoPtr->dumpEntry; @@ -919,8 +920,10 @@ RcreateDump(struct tapeScanInfo *tapeScanInfoPtr, dumpEntryPtr->flags = 0; dumpEntryPtr->incTime = 0; dumpEntryPtr->nVolumes = 0; - strcpy(dumpEntryPtr->volumeSetName, - volumesetNamePtr(volHeaderPtr->dumpSetName)); + volsetName = volumesetNamePtr(volHeaderPtr->dumpSetName); + if (volsetName == NULL) + return BUDB_BADARGUMENT; + strcpy(dumpEntryPtr->volumeSetName, volsetName); strcpy(dumpEntryPtr->dumpPath, dumpLabelPtr->dumpPath); strcpy(dumpEntryPtr->name, volHeaderPtr->dumpSetName); default_tapeset(&dumpEntryPtr->tapes, volHeaderPtr->dumpSetName);