Fix kfreebsd compile and behaviour.

* grub-core/kern/emu/hostdisk.c (grub_util_follow_gpart_up): Fix
	format-security.
	* util/getroot.c: Fix wait.h include.
	(grub_guess_root_devices): Error if grub_find_device fails.
	(grub_util_get_geom_abstraction): Fix shadowing and format-security.
	(grub_util_get_dev_abstraction): Likewise.
	(grub_util_pull_device): Likewise.
	(grub_util_get_grub_dev): Likewise.
	* util/lvm.c (grub_util_lvm_isvolume): Likewise.
This commit is contained in:
Vladimir 'phcoder' Serbinenko 2012-04-21 16:49:56 +02:00
parent 48143d96a6
commit 9a06490c07
4 changed files with 55 additions and 35 deletions

View file

@ -1,3 +1,17 @@
2012-04-21 Vladimir Serbinenko <phcoder@gmail.com>
Fix kfreebsd compile and behaviour.
* grub-core/kern/emu/hostdisk.c (grub_util_follow_gpart_up): Fix
format-security.
* util/getroot.c: Fix wait.h include.
(grub_guess_root_devices): Error if grub_find_device fails.
(grub_util_get_geom_abstraction): Fix shadowing and format-security.
(grub_util_get_dev_abstraction): Likewise.
(grub_util_pull_device): Likewise.
(grub_util_get_grub_dev): Likewise.
* util/lvm.c (grub_util_lvm_isvolume): Likewise.
2012-04-21 Vladimir Serbinenko <phcoder@gmail.com> 2012-04-21 Vladimir Serbinenko <phcoder@gmail.com>
Fix and unify wholedisk detection. Fix and unify wholedisk detection.

View file

@ -438,7 +438,7 @@ grub_util_follow_gpart_up (const char *name, grub_disk_addr_t *off_out, char **n
/* TRANSLATORS: geom is the name of (k)FreeBSD device framework. /* TRANSLATORS: geom is the name of (k)FreeBSD device framework.
Usually left untranslated. Usually left untranslated.
*/ */
grub_util_error (_("couldn't open geom")); grub_util_error ("%s", _("couldn't open geom"));
LIST_FOREACH (class, &mesh.lg_class, lg_class) LIST_FOREACH (class, &mesh.lg_class, lg_class)
if (strcasecmp (class->lg_name, "part") == 0) if (strcasecmp (class->lg_name, "part") == 0)
@ -447,7 +447,7 @@ grub_util_follow_gpart_up (const char *name, grub_disk_addr_t *off_out, char **n
/* TRANSLATORS: geom is the name of (k)FreeBSD device framework. /* TRANSLATORS: geom is the name of (k)FreeBSD device framework.
Usually left untranslated. "part" is the identifier of one of its Usually left untranslated. "part" is the identifier of one of its
classes. */ classes. */
grub_util_error (_("couldn't find geom `part' class")); grub_util_error ("%s", _("couldn't find geom `part' class"));
LIST_FOREACH (geom, &class->lg_geom, lg_geom) LIST_FOREACH (geom, &class->lg_geom, lg_geom)
{ {

View file

@ -51,10 +51,8 @@
#include <sys/mman.h> #include <sys/mman.h>
#endif #endif
#ifdef __linux__ #include <sys/types.h>
# include <sys/types.h> #include <sys/wait.h>
# include <sys/wait.h>
#endif
#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) #if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
# include <sys/mount.h> # include <sys/mount.h>
@ -1047,6 +1045,12 @@ grub_guess_root_devices (const char *dir)
/* This might be truly slow, but is there any better way? */ /* This might be truly slow, but is there any better way? */
os_dev[0] = grub_find_device ("/dev", dev); os_dev[0] = grub_find_device ("/dev", dev);
#endif #endif
if (!os_dev[0])
{
free (os_dev);
return 0;
}
os_dev[1] = 0; os_dev[1] = 0;
#endif /* !__GNU__ */ #endif /* !__GNU__ */
@ -1179,7 +1183,7 @@ grub_util_get_geom_abstraction (const char *dev)
struct gmesh mesh; struct gmesh mesh;
struct gclass *class; struct gclass *class;
const char *name; const char *name;
int error; int err;
if (strncmp (dev, "/dev/", sizeof ("/dev/") - 1) != 0) if (strncmp (dev, "/dev/", sizeof ("/dev/") - 1) != 0)
return 0; return 0;
@ -1188,12 +1192,12 @@ grub_util_get_geom_abstraction (const char *dev)
grub_util_info ("following geom '%s'", name); grub_util_info ("following geom '%s'", name);
error = geom_gettree (&mesh); err = geom_gettree (&mesh);
if (error != 0) if (err != 0)
/* TRANSLATORS: geom is the name of (k)FreeBSD device framework. /* TRANSLATORS: geom is the name of (k)FreeBSD device framework.
Usually left untranslated. Usually left untranslated.
*/ */
grub_util_error (_("couldn't open geom")); grub_util_error ("%s", _("couldn't open geom"));
LIST_FOREACH (class, &mesh.lg_class, lg_class) LIST_FOREACH (class, &mesh.lg_class, lg_class)
{ {
@ -1235,10 +1239,10 @@ grub_util_get_dev_abstraction (const char *os_dev)
#endif #endif
#if defined (__FreeBSD__) || defined(__FreeBSD_kernel__) #if defined (__FreeBSD__) || defined(__FreeBSD_kernel__)
const char *abs; const char *abstrac;
abs = grub_util_get_geom_abstraction (os_dev); abstrac = grub_util_get_geom_abstraction (os_dev);
grub_util_info ("abstraction of %s is %s", os_dev, abs); grub_util_info ("abstraction of %s is %s", os_dev, abstrac);
if (abs && grub_strcasecmp (abs, "eli") == 0) if (abstrac && grub_strcasecmp (abstrac, "eli") == 0)
return GRUB_DEV_ABSTRACTION_GELI; return GRUB_DEV_ABSTRACTION_GELI;
/* Check for LVM. */ /* Check for LVM. */
@ -1406,7 +1410,7 @@ grub_util_pull_device (const char *os_dev)
struct gmesh mesh; struct gmesh mesh;
struct gclass *class; struct gclass *class;
const char *name; const char *name;
int error; int err;
char *lastsubdev = NULL; char *lastsubdev = NULL;
if (strncmp (os_dev, "/dev/", sizeof ("/dev/") - 1) != 0) if (strncmp (os_dev, "/dev/", sizeof ("/dev/") - 1) != 0)
@ -1416,12 +1420,12 @@ grub_util_pull_device (const char *os_dev)
grub_util_info ("following geom '%s'", name); grub_util_info ("following geom '%s'", name);
error = geom_gettree (&mesh); err = geom_gettree (&mesh);
if (error != 0) if (err != 0)
/* TRANSLATORS: geom is the name of (k)FreeBSD device framework. /* TRANSLATORS: geom is the name of (k)FreeBSD device framework.
Usually left untranslated. Usually left untranslated.
*/ */
grub_util_error (_("couldn't open geom")); grub_util_error ("%s", _("couldn't open geom"));
LIST_FOREACH (class, &mesh.lg_class, lg_class) LIST_FOREACH (class, &mesh.lg_class, lg_class)
{ {
@ -1434,12 +1438,12 @@ grub_util_pull_device (const char *os_dev)
{ {
struct gconsumer *consumer; struct gconsumer *consumer;
char *fname; char *fname;
char *uuid;
LIST_FOREACH (consumer, &geom->lg_consumer, lg_consumer) LIST_FOREACH (consumer, &geom->lg_consumer, lg_consumer)
break; break;
if (!consumer) if (!consumer)
grub_util_error (_("couldn't find geli consumer")); grub_util_error ("%s",
_("couldn't find geli consumer"));
fname = xasprintf ("/dev/%s", consumer->lg_provider->lg_name); fname = xasprintf ("/dev/%s", consumer->lg_provider->lg_name);
grub_util_info ("consumer %s", consumer->lg_provider->lg_name); grub_util_info ("consumer %s", consumer->lg_provider->lg_name);
lastsubdev = consumer->lg_provider->lg_name; lastsubdev = consumer->lg_provider->lg_name;
@ -1456,9 +1460,9 @@ grub_util_pull_device (const char *os_dev)
if (grdev) if (grdev)
{ {
grub_err_t err; grub_err_t gr_err;
err = grub_cryptodisk_cheat_mount (grdev, os_dev); gr_err = grub_cryptodisk_cheat_mount (grdev, os_dev);
if (err) if (gr_err)
grub_util_error (_("can't mount encrypted volume `%s': %s"), grub_util_error (_("can't mount encrypted volume `%s': %s"),
lastsubdev, grub_errmsg); lastsubdev, grub_errmsg);
} }
@ -2390,7 +2394,7 @@ grub_util_get_grub_dev (const char *os_dev)
struct gmesh mesh; struct gmesh mesh;
struct gclass *class; struct gclass *class;
const char *name; const char *name;
int error; int err;
if (strncmp (os_dev, "/dev/", sizeof ("/dev/") - 1) != 0) if (strncmp (os_dev, "/dev/", sizeof ("/dev/") - 1) != 0)
return 0; return 0;
@ -2399,12 +2403,12 @@ grub_util_get_grub_dev (const char *os_dev)
grub_util_info ("following geom '%s'", name); grub_util_info ("following geom '%s'", name);
error = geom_gettree (&mesh); err = geom_gettree (&mesh);
if (error != 0) if (err != 0)
/* TRANSLATORS: geom is the name of (k)FreeBSD device framework. /* TRANSLATORS: geom is the name of (k)FreeBSD device framework.
Usually left untranslated. Usually left untranslated.
*/ */
grub_util_error (_("couldn't open geom")); grub_util_error ("%s", _("couldn't open geom"));
LIST_FOREACH (class, &mesh.lg_class, lg_class) LIST_FOREACH (class, &mesh.lg_class, lg_class)
{ {
@ -2422,11 +2426,13 @@ grub_util_get_grub_dev (const char *os_dev)
LIST_FOREACH (consumer, &geom->lg_consumer, lg_consumer) LIST_FOREACH (consumer, &geom->lg_consumer, lg_consumer)
break; break;
if (!consumer) if (!consumer)
grub_util_error (_("couldn't find geli consumer")); grub_util_error ("%s",
_("couldn't find geli consumer"));
fname = xasprintf ("/dev/%s", consumer->lg_provider->lg_name); fname = xasprintf ("/dev/%s", consumer->lg_provider->lg_name);
uuid = grub_util_get_geli_uuid (fname); uuid = grub_util_get_geli_uuid (fname);
if (!uuid) if (!uuid)
grub_util_error (_("couldn't retrieve geli UUID")); grub_util_error ("%s",
_("couldn't retrieve geli UUID"));
grub_dev = xasprintf ("cryptouuid/%s", uuid); grub_dev = xasprintf ("cryptouuid/%s", uuid);
free (fname); free (fname);
free (uuid); free (uuid);

View file

@ -28,17 +28,17 @@
int int
grub_util_lvm_isvolume (char *name) grub_util_lvm_isvolume (char *name)
{ {
char *devname; char *lvmdevname;
struct stat st; struct stat st;
int err; int err;
devname = xmalloc (strlen (name) + sizeof (LVM_DEV_MAPPER_STRING)); lvmdevname = xmalloc (strlen (name) + sizeof (LVM_DEV_MAPPER_STRING));
strcpy (devname, LVM_DEV_MAPPER_STRING); strcpy (lvmdevname, LVM_DEV_MAPPER_STRING);
strcpy (devname + sizeof(LVM_DEV_MAPPER_STRING) - 1, name); strcpy (lvmdevname + sizeof(LVM_DEV_MAPPER_STRING) - 1, name);
err = stat (devname, &st); err = stat (lvmdevname, &st);
free (devname); free (lvmdevname);
if (err) if (err)
return 0; return 0;