All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH RFC] Simplifying linux_find_partition()
@ 2008-05-12  0:34 Pavel Roskin
  2008-05-12 15:32 ` Robert Millan
  0 siblings, 1 reply; 5+ messages in thread
From: Pavel Roskin @ 2008-05-12  0:34 UTC (permalink / raw)
  To: The development of GRUB 2

Hello!

linux_find_partition() is used to make it possible to access partitions
using the native OS devices for the partitions, rather than the device
for the whole drive.

As new devices are supported by GRUB, linux_find_partition() should be
updated to support them, but this is not always done.  The reason is
that the problem is not obvious and doesn't prevent the basic
functionality.

This patch simplifies the code and makes it handle all devices supported
by Linux, perhaps even all devices that will be supported.

I'm assuming that linux_find_partition() is only called for whole
drives, not for partitions, so the code doesn't need to strip anything
from the device name.  We only need to strip "disc" from devfs names.

Also, I checked devices.txt from Linux, and I see a simple pattern
there.  If the device ends in a number, the partitions are made by
adding "p" and the number.  Otherwise, only the number is added.

ChangeLog:

	* util/biosdisk.c (linux_find_partition): Don't try to handle
	anything but whole drives.  Simplify logic.  Add "p%d" after
	numbers and "%d" after other characters.


diff --git a/util/biosdisk.c b/util/biosdisk.c
index fcf01a4..7079a97 100644
--- a/util/biosdisk.c
+++ b/util/biosdisk.c
@@ -226,40 +226,16 @@ linux_find_partition (char *dev, unsigned long sector)
       p = real_dev + len - 4;
       format = "part%d";
     }
-  else if ((strncmp (real_dev + 5, "hd", 2) == 0
-	    || strncmp (real_dev + 5, "vd", 2) == 0
-	    || strncmp (real_dev + 5, "sd", 2) == 0)
-	   && real_dev[7] >= 'a' && real_dev[7] <= 'z')
+  else if (real_dev[len - 1] >= '0' && real_dev[len - 1] <= '9')
     {
-      p = real_dev + 8;
-      format = "%d";
-    }
-  else if (strncmp (real_dev + 5, "rd/c", 4) == 0)	/* dac960 */
-    {
-      p = strchr (real_dev + 9, 'd');
-      if (! p)
-	return 0;
-
-      p++;
-      while (*p && isdigit (*p))
-	p++;
-
+      p = real_dev + len;
       format = "p%d";
     }
-  else if (strncmp (real_dev + 5, "cciss/c", sizeof("cciss/c")-1) == 0)
+  else
     {
-      p = strchr (real_dev + 5 + sizeof("cciss/c")-1, 'd');
-      if (! p)
-	return 0;
-
-      p++;
-      while (*p && isdigit (*p))
-	p++;
-
-      format = "p%d";
+      p = real_dev + len;
+      format = "%d";
     }
-  else
-    return 0;
 
   for (i = 1; i < 10000; i++)
     {


-- 
Regards,
Pavel Roskin



^ permalink raw reply related	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2008-05-30 21:56 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-05-12  0:34 [PATCH RFC] Simplifying linux_find_partition() Pavel Roskin
2008-05-12 15:32 ` Robert Millan
2008-05-15 22:10   ` Pavel Roskin
2008-05-28 13:46     ` Robert Millan
2008-05-30 21:55       ` Pavel Roskin

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.