dm ioctl: drop always-false condition
authorSergey Shtylyov <s.shtylyov@omp.ru>
Tue, 17 Jan 2023 20:59:55 +0000 (23:59 +0300)
committerMike Snitzer <snitzer@kernel.org>
Thu, 2 Feb 2023 19:26:09 +0000 (14:26 -0500)
The expression 'indata[3] > ULONG_MAX' always evaluates to false since
indata[] is declared as an array of *unsigned long* elements and #define
ULONG_MAX represents the max value of that exact type...

Note that gcc seems to be able to detect the dead code here and eliminate
this check anyway...

Found by Linux Verification Center (linuxtesting.org) with the SVACE static
analysis tool.

Signed-off-by: Sergey Shtylyov <s.shtylyov@omp.ru>
Reviewed-by: Mikulas Patocka <mpatocka@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@kernel.org>
drivers/md/dm-ioctl.c

index 36fc6ae4737a05ab53ab67a8ccee525cb5fda082..9160159ef8816198b2fae420258b00af32a9bd47 100644 (file)
@@ -1073,8 +1073,7 @@ static int dev_set_geometry(struct file *filp, struct dm_ioctl *param, size_t pa
                goto out;
        }
 
-       if (indata[0] > 65535 || indata[1] > 255 ||
-           indata[2] > 255 || indata[3] > ULONG_MAX) {
+       if (indata[0] > 65535 || indata[1] > 255 || indata[2] > 255) {
                DMERR("Geometry exceeds range limits.");
                goto out;
        }