[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <YcQ5+76XpcbcsotJ@infradead.org>
Date: Thu, 23 Dec 2021 00:57:31 -0800
From: Christoph Hellwig <hch@...radead.org>
To: Qing Wang <wangqing@...o.com>
Cc: Jens Axboe <axboe@...nel.dk>, linux-block@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH] block: return specific error when pointer is NULL
On Wed, Dec 22, 2021 at 06:24:03PM -0800, Qing Wang wrote:
> From: Wang Qing <wangqing@...o.com>
>
> loop_attr_backing_file_show() better return specific error than 0
> when pointer is NULL
Well, let's turn this into something that is not butt ugly then:
diff --git a/drivers/block/loop.c b/drivers/block/loop.c
index 7f4ea06534c2d..b9ee0a165b75e 100644
--- a/drivers/block/loop.c
+++ b/drivers/block/loop.c
@@ -666,15 +666,15 @@ static ssize_t loop_attr_backing_file_show(struct loop_device *lo, char *buf)
p = file_path(lo->lo_backing_file, buf, PAGE_SIZE - 1);
spin_unlock_irq(&lo->lo_lock);
- if (IS_ERR_OR_NULL(p))
- ret = PTR_ERR(p);
- else {
- ret = strlen(p);
- memmove(buf, p, ret);
- buf[ret++] = '\n';
- buf[ret] = 0;
- }
-
+ if (!p)
+ return -ENOENT;
+ if (IS_ERR(p))
+ return PTR_ERR(p);
+
+ ret = strlen(p);
+ memmove(buf, p, ret);
+ buf[ret++] = '\n';
+ buf[ret] = 0;
return ret;
}
Powered by blists - more mailing lists