Blame SOURCES/0009-mdadm-grow-correct-size-and-chunk_size-casting.patch

d922d5
From 5d518de84e7cd3382b4984cc1243ddb4102aa4f4 Mon Sep 17 00:00:00 2001
d922d5
From: Roman Sobanski <roman.sobanski@intel.com>
d922d5
Date: Fri, 27 Apr 2018 12:12:21 +0200
d922d5
Subject: [RHEL7.5 PATCH 09/26] mdadm/grow: correct size and chunk_size casting
d922d5
d922d5
With commit 4b74a905a67e
d922d5
("mdadm/grow: Component size must be larger than chunk size") mdadm returns
d922d5
incorrect message if size given to grow was greater than 2 147 483 647 K.
d922d5
Cast chunk_size to "unsigned long long" instead of casting size to "int".
d922d5
d922d5
Signed-off-by: Roman Sobanski <roman.sobanski@intel.com>
d922d5
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
d922d5
---
d922d5
 Grow.c | 2 +-
d922d5
 1 file changed, 1 insertion(+), 1 deletion(-)
d922d5
d922d5
diff --git a/Grow.c b/Grow.c
d922d5
index 8722969..a4be7e7 100644
d922d5
--- a/Grow.c
d922d5
+++ b/Grow.c
d922d5
@@ -1821,7 +1821,7 @@ int Grow_reshape(char *devname, int fd,
d922d5
 	}
d922d5
 
d922d5
 	if (array.level > 1 && s->size > 1 &&
d922d5
-	    (array.chunk_size / 1024) > (int)s->size) {
d922d5
+	    (unsigned long long) (array.chunk_size / 1024) > s->size) {
d922d5
 		pr_err("component size must be larger than chunk size.\n");
d922d5
 		return 1;
d922d5
 	}
d922d5
-- 
d922d5
2.7.4
d922d5