2008-09-04 Felix Zielcke <fzielcke@z-51.de>
* util/getroot.c: Include <config.h>. (grub_util_get_grub_dev): Rewrite to use asprintf for mdraid devices, add support for /dev/md/N devices and handle LVM double dash escaping.
This commit is contained in:
parent
58b6645a8f
commit
4ee5592137
2 changed files with 36 additions and 39 deletions
|
@ -1,6 +1,12 @@
|
|||
2008-09-04 Felix Zielcke <fzielcke@z-51.de>
|
||||
|
||||
* config.guess: Update to latest version from config.git.
|
||||
* util/getroot.c: Include <config.h>.
|
||||
(grub_util_get_grub_dev): Rewrite to use asprintf for mdraid devices,
|
||||
add support for /dev/md/N devices and handle LVM double dash escaping.
|
||||
|
||||
2008-09-04 Felix Zielcke <fzielcke@z-51.de>
|
||||
|
||||
* config.guess: Update to latest version from config git.
|
||||
* config.sub: Likewise.
|
||||
|
||||
2008-09-03 Robert Millan <rmh@aybabtu.com>
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <config.h>
|
||||
#include <sys/stat.h>
|
||||
#include <unistd.h>
|
||||
#include <string.h>
|
||||
|
@ -417,58 +418,48 @@ grub_util_get_grub_dev (const char *os_dev)
|
|||
switch (grub_util_get_dev_abstraction (os_dev))
|
||||
{
|
||||
case GRUB_DEV_ABSTRACTION_LVM:
|
||||
grub_dev = xmalloc (strlen (os_dev) - 12 + 1);
|
||||
|
||||
strcpy (grub_dev, os_dev + 12);
|
||||
{
|
||||
unsigned short i, len;
|
||||
grub_size_t offset = sizeof ("/dev/mapper/") - 1;
|
||||
|
||||
len = strlen (os_dev) - offset + 1;
|
||||
grub_dev = xmalloc (len);
|
||||
|
||||
for (i = 0; i < len; i++, offset++)
|
||||
{
|
||||
grub_dev[i] = os_dev[offset];
|
||||
if (os_dev[offset] == '-' && os_dev[offset + 1] == '-')
|
||||
offset++;
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
case GRUB_DEV_ABSTRACTION_RAID:
|
||||
grub_dev = xmalloc (20);
|
||||
|
||||
if (os_dev[7] == '_' && os_dev[8] == 'd')
|
||||
{
|
||||
const char *p;
|
||||
|
||||
/* This a partitionable RAID device of the form /dev/md_dNNpMM. */
|
||||
int i;
|
||||
|
||||
grub_dev[0] = 'm';
|
||||
grub_dev[1] = 'd';
|
||||
i = 2;
|
||||
char *p , *q;
|
||||
|
||||
p = os_dev + 9;
|
||||
while (*p >= '0' && *p <= '9')
|
||||
{
|
||||
grub_dev[i] = *p;
|
||||
i++;
|
||||
p++;
|
||||
}
|
||||
p = strdup (os_dev + sizeof ("/dev/md_d") - 1);
|
||||
|
||||
if (*p == '\0')
|
||||
grub_dev[i] = '\0';
|
||||
else if (*p == 'p')
|
||||
{
|
||||
p++;
|
||||
grub_dev[i] = ',';
|
||||
i++;
|
||||
q = strchr (p, 'p');
|
||||
if (q)
|
||||
*q = ',';
|
||||
|
||||
while (*p >= '0' && *p <= '9')
|
||||
{
|
||||
grub_dev[i] = *p;
|
||||
i++;
|
||||
p++;
|
||||
}
|
||||
|
||||
grub_dev[i] = '\0';
|
||||
}
|
||||
else
|
||||
grub_util_error ("Unknown kind of RAID device `%s'", os_dev);
|
||||
asprintf (&grub_dev, "md%s", p);
|
||||
free (p);
|
||||
}
|
||||
else if (os_dev[7] >= '0' && os_dev[7] <= '9')
|
||||
{
|
||||
memcpy (grub_dev, os_dev + 5, 7);
|
||||
grub_dev[7] = '\0';
|
||||
asprintf (&grub_dev, "md%s", os_dev + sizeof ("/dev/md") - 1);
|
||||
}
|
||||
else if (os_dev[7] == '/' && os_dev[8] >= '0' && os_dev[8] <= '9')
|
||||
{
|
||||
asprintf (&grub_dev, "md%s", os_dev + sizeof ("/dev/md/") - 1);
|
||||
}
|
||||
else
|
||||
grub_util_error ("Unknown kind of RAID device `%s'", os_dev);
|
||||
|
|
Loading…
Reference in a new issue