+2010-12-27 Vladimir Serbinenko <phcoder@gmail.com>
+
+ Don't use disk subsystem in freebsd_boot.
+
+ * grub-core/loader/i386/bsd.c (freebsd_bootdev): New variable.
+ (freebsd_biosdev): Likewise.
+ (grub_freebsd_boot): Use freebsd_bootdev and freebsd_biosdev.
+ (grub_cmd_freebsd): Set freebsd_bootdev and freebsd_biosdev.
+
2010-12-26 Vladimir Serbinenko <phcoder@gmail.com>
Handling of files of unknown size is currently limited. They can't be
/* This function would be here but it's under different license. */
#include "bsd_pagetable.c"
+static grub_uint32_t freebsd_bootdev, freebsd_biosdev;
+
static grub_err_t
grub_freebsd_boot (void)
{
grub_uint8_t *p, *p0;
grub_addr_t p_target;
grub_size_t p_size = 0;
- grub_uint32_t bootdev, biosdev, unit, slice, part;
grub_err_t err;
grub_size_t tag_buf_len = 0;
bi.version = FREEBSD_BOOTINFO_VERSION;
bi.length = sizeof (bi);
- grub_bsd_get_device (&biosdev, &unit, &slice, &part);
- bootdev = (FREEBSD_B_DEVMAGIC + ((slice + 1) << FREEBSD_B_SLICESHIFT) +
- (unit << FREEBSD_B_UNITSHIFT) + (part << FREEBSD_B_PARTSHIFT));
-
- bi.boot_device = biosdev;
+ bi.boot_device = freebsd_biosdev;
p_size = 0;
grub_env_iterate (iterate_env_count);
state.ebp = stack_target;
stack[0] = entry; /* "Return" address. */
stack[1] = bootflags | FREEBSD_RB_BOOTINFO;
- stack[2] = bootdev;
+ stack[2] = freebsd_bootdev;
stack[3] = 0;
stack[4] = 0;
stack[5] = 0;
if (grub_bsd_load (argc, argv) == GRUB_ERR_NONE)
{
+ grub_uint32_t unit, slice, part;
+
kern_end = ALIGN_PAGE (kern_end);
if (is_elf_kernel)
{
if (err)
return err;
}
+ grub_bsd_get_device (&freebsd_biosdev, &unit, &slice, &part);
+ freebsd_bootdev = (FREEBSD_B_DEVMAGIC + ((slice + 1) << FREEBSD_B_SLICESHIFT) +
+ (unit << FREEBSD_B_UNITSHIFT) + (part << FREEBSD_B_PARTSHIFT));
+
grub_loader_set (grub_freebsd_boot, grub_bsd_unload, 0);
}