Blame SOURCES/dosfstools-4.1-fix-cluster-size-auto-detect-for-4k-disks.patch

aa87ab
diff --git a/src/mkfs.fat.c b/src/mkfs.fat.c
aa87ab
index a7609b0..26ce3fd 100644
aa87ab
--- a/src/mkfs.fat.c
aa87ab
+++ b/src/mkfs.fat.c
aa87ab
@@ -517,6 +517,7 @@ static void establish_params(struct device_info *info)
aa87ab
     unsigned int heads = 255;
aa87ab
     unsigned int media = 0xf8;
aa87ab
     unsigned int cluster_size = 4;  /* starting point for FAT12 and FAT16 */
aa87ab
+    unsigned int sector_size_mult = 1; /* x 512 == sector_size */
aa87ab
     int def_root_dir_entries = 512;
aa87ab
 
aa87ab
     if (info->size < 512 * 1024 * 1024) {
aa87ab
@@ -590,11 +591,15 @@ static void establish_params(struct device_info *info)
aa87ab
 	 * fs size >   32G:  32k clusters
aa87ab
 	 *
aa87ab
 	 * This only works correctly for 512 byte sectors!
aa87ab
+	 * For other sector sizes it tries to approximate.
aa87ab
 	 */
aa87ab
 	uint32_t sz_mb = info->size / (1024 * 1024);
aa87ab
+	if (info->sector_size > 0)
aa87ab
+	    sector_size_mult = info->sector_size / 512;
aa87ab
 	cluster_size =
aa87ab
-	    sz_mb > 32 * 1024 ? 64 : sz_mb > 16 * 1024 ? 32 : sz_mb >
aa87ab
-	    8 * 1024 ? 16 : sz_mb > 260 ? 8 : 1;
aa87ab
+	    sz_mb > 32 * 1024 * sector_size_mult ? 64 : sz_mb >
aa87ab
+	    16 * 1024 * sector_size_mult ? 32 : sz_mb >
aa87ab
+	    8 * 1024 * sector_size_mult ? 16 : sz_mb > 260 * sector_size_mult ? 8 : 1;
aa87ab
     }
aa87ab
 
aa87ab
     if (info->geom_heads > 0) {