Commit 1341c7d2 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Jens Axboe

block: fix rootwait=

Failures to look up the gendisk must return -ENODEV so that rootwait
retries the lookup instead of -EINVAL which exits early.

Fixes: cf056a43 ("init: improve the name_to_dev_t interface")
Reported-by: default avatarFabio Estevam <festevam@gmail.com>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Tested-by: default avatarFabio Estevam <festevam@gmail.com>
Link: https://lore.kernel.org/r/20230607135746.92995-1-hch@lst.deSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 3d2af77e
...@@ -181,7 +181,7 @@ static int __init devt_from_devname(const char *name, dev_t *devt) ...@@ -181,7 +181,7 @@ static int __init devt_from_devname(const char *name, dev_t *devt)
*p = '\0'; *p = '\0';
*devt = blk_lookup_devt(s, part); *devt = blk_lookup_devt(s, part);
if (*devt) if (*devt)
return 0; return -ENODEV;
/* try disk name without p<part number> */ /* try disk name without p<part number> */
if (p < s + 2 || !isdigit(p[-2]) || p[-1] != 'p') if (p < s + 2 || !isdigit(p[-2]) || p[-1] != 'p')
...@@ -190,7 +190,7 @@ static int __init devt_from_devname(const char *name, dev_t *devt) ...@@ -190,7 +190,7 @@ static int __init devt_from_devname(const char *name, dev_t *devt)
*devt = blk_lookup_devt(s, part); *devt = blk_lookup_devt(s, part);
if (*devt) if (*devt)
return 0; return 0;
return -EINVAL; return -ENODEV;
} }
static int __init devt_from_devnum(const char *name, dev_t *devt) static int __init devt_from_devnum(const char *name, dev_t *devt)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment