[PATCH v1] drivers/char/mem.c: fix null and zero dev lseek
From: David Timber
Date: Sun Mar 22 2026 - 07:52:47 EST
Return -EINVAL if whence is not understood by /dev/null or /dev/zero.
lseek() on /dev/null and /dev/zero always returns 0. This is
problematic for userland programs that detect holes and advancing the
offset by the calculated delta (SEEK_HOLE - SEEK_DATA), which will
always be calculated as zero.
Link: https://github.com/util-linux/util-linux/pull/4132
Signed-off-by: David Timber <dxdt@xxxxxxxxxxxx>
---
drivers/char/mem.c | 14 +++++++++++++-
1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/drivers/char/mem.c b/drivers/char/mem.c
index cca4529431f8..f0318e924db9 100644
--- a/drivers/char/mem.c
+++ b/drivers/char/mem.c
@@ -576,7 +576,19 @@ static ssize_t write_full(struct file *file, const char __user *buf,
*/
static loff_t null_lseek(struct file *file, loff_t offset, int orig)
{
- return file->f_pos = 0;
+ loff_t ret;
+
+ switch (orig) {
+ case SEEK_SET:
+ case SEEK_CUR:
+ case SEEK_END:
+ ret = file->f_pos = 0;
+ break;
+ default:
+ ret = -EINVAL;
+ }
+
+ return ret;
}
/*
--
2.53.0.1.ga224b40d3f.dirty