fallback when devfs names aren't found

SVN-Revision: 6541
This commit is contained in:
Mike Baker 2007-03-09 08:58:37 +00:00
parent ed1a641e15
commit 99c848c555

View File

@ -197,13 +197,18 @@ mtd_open(const char *mtd, int flags)
FILE *fp; FILE *fp;
char dev[PATH_MAX]; char dev[PATH_MAX];
int i; int i;
int ret;
if ((fp = fopen("/proc/mtd", "r"))) { if ((fp = fopen("/proc/mtd", "r"))) {
while (fgets(dev, sizeof(dev), fp)) { while (fgets(dev, sizeof(dev), fp)) {
if (sscanf(dev, "mtd%d:", &i) && strstr(dev, mtd)) { if (sscanf(dev, "mtd%d:", &i) && strstr(dev, mtd)) {
snprintf(dev, sizeof(dev), "/dev/mtd/%d", i); snprintf(dev, sizeof(dev), "/dev/mtd/%d", i);
if ((ret=open(dev, flags))<0) {
snprintf(dev, sizeof(dev), "/dev/mtd%d", i);
ret=open(dev, flags);
}
fclose(fp); fclose(fp);
return open(dev, flags); return ret;
} }
} }
fclose(fp); fclose(fp);