From 88aa5528b6cb857463243559126823ede9521476 Mon Sep 17 00:00:00 2001 From: kraai <kraai@69ca8d6d-28ef-0310-b511-8ec308f3f277> Date: Wed, 23 May 2001 14:45:09 +0000 Subject: Make more robust (patch by Larry Doolittle). git-svn-id: svn://busybox.net/trunk/busybox@2712 69ca8d6d-28ef-0310-b511-8ec308f3f277 --- libbb/find_root_device.c | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/libbb/find_root_device.c b/libbb/find_root_device.c index 75ed1a979..edfd7085a 100644 --- a/libbb/find_root_device.c +++ b/libbb/find_root_device.c @@ -39,16 +39,18 @@ extern char *find_real_root_device_name(const char* name) struct dirent *entry; struct stat statBuf, rootStat; char *fileName; + dev_t dev; if (stat("/", &rootStat) != 0) { - error_msg("could not stat '/'"); + perror_msg("could not stat '/'"); return NULL; } + if ((dev = rootStat.st_rdev)==0) dev=rootStat.st_dev; dir = opendir("/dev"); if (!dir) { - error_msg("could not open '/dev'"); - return NULL; + perror_msg("could not open '/dev'"); + goto fallback; } while((entry = readdir(dir)) != NULL) { @@ -64,14 +66,18 @@ extern char *find_real_root_device_name(const char* name) * devices, so make sure this is a block device */ if (stat(fileName, &statBuf) == 0 && S_ISBLK(statBuf.st_mode)!=0 && - statBuf.st_rdev == rootStat.st_rdev) { + statBuf.st_rdev == dev) { return fileName; } free(fileName); } closedir(dir); - return NULL; +fallback: + /* don't use stack space, caller expects to free() result */ + fileName=xmalloc(20); + sprintf(fileName,"(rdev %u)",(unsigned int) rootStat.st_rdev); + return fileName; } -- cgit v1.2.3-55-g6feb