Fixes for kernel of FreeBSD:
* grub/asmstub.c (get_diskinfo): Toggle "kern.geom.debugflags" sysctl before opening a device for writing. * util/grub-install.in: Devices don't have this "r" prefix anymore.
This commit is contained in:
parent
8a4848921a
commit
4ace38464e
3 changed files with 41 additions and 3 deletions
|
@ -1,3 +1,10 @@
|
|||
2006-04-20 Robert Millan <robertmh@gnu.org>
|
||||
|
||||
Fixes for kernel of FreeBSD:
|
||||
* grub/asmstub.c (get_diskinfo): Toggle "kern.geom.debugflags" sysctl
|
||||
before opening a device for writing.
|
||||
* util/grub-install.in: Devices don't have this "r" prefix anymore.
|
||||
|
||||
2006-04-16 Yoshinori K. Okuji <okuji@enbug.org>
|
||||
|
||||
* docs/multiboot.texi: Correct the offset of address
|
||||
|
|
|
@ -55,6 +55,10 @@ int grub_stage2 (void);
|
|||
# endif /* ! BLKFLSBUF */
|
||||
#endif /* __linux__ */
|
||||
|
||||
#if defined(__FreeBSD_kernel__) || defined(__FreeBSD__)
|
||||
# include <sys/sysctl.h>
|
||||
#endif
|
||||
|
||||
/* We want to prevent any circularararity in our stubs, as well as
|
||||
libc name clashes. */
|
||||
#define WITHOUT_LIBC_STUBS 1
|
||||
|
@ -777,7 +781,34 @@ get_diskinfo (int drive, struct geometry *geometry)
|
|||
|
||||
/* Open read/write, or read-only if that failed. */
|
||||
if (! read_only)
|
||||
disks[drive].flags = open (devname, O_RDWR);
|
||||
{
|
||||
/* By default, kernel of FreeBSD does not allow overwriting MBR */
|
||||
#if defined(__FreeBSD_kernel__) || defined(__FreeBSD__)
|
||||
#define GEOM_SYSCTL "kern.geom.debugflags"
|
||||
int old_flags, flags;
|
||||
size_t sizeof_int = sizeof (int);
|
||||
|
||||
if (sysctlbyname (GEOM_SYSCTL, &old_flags, &sizeof_int, NULL, 0) != 0)
|
||||
grub_printf ("failed to get " GEOM_SYSCTL "sysctl: %s\n", strerror (errno));
|
||||
|
||||
if ((old_flags & 0x10) == 0)
|
||||
{
|
||||
/* "allow foot shooting", see geom(4) */
|
||||
flags = old_flags | 0x10;
|
||||
|
||||
if (sysctlbyname (GEOM_SYSCTL, NULL, NULL, &flags, sizeof (int)) != 0)
|
||||
grub_printf ("failed to set " GEOM_SYSCTL "sysctl: %s\n", strerror (errno));
|
||||
}
|
||||
#endif
|
||||
disks[drive].flags = open (devname, O_RDWR);
|
||||
#if defined(__FreeBSD_kernel__) || defined(__FreeBSD__)
|
||||
if (flags != old_flags)
|
||||
{
|
||||
if (sysctlbyname (GEOM_SYSCTL, NULL, NULL, &old_flags, sizeof (int)) != 0)
|
||||
grub_printf ("failed to set " GEOM_SYSCTL "sysctl: %s\n", strerror (errno));
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
if (disks[drive].flags == -1)
|
||||
{
|
||||
|
|
|
@ -112,8 +112,8 @@ convert () {
|
|||
tmp_disk=`echo "$1" | sed 's%\([sh]d[0-9]*\).*%\1%'`
|
||||
tmp_part=`echo "$1" | sed "s%$tmp_disk%%"` ;;
|
||||
freebsd* | kfreebsd*-gnu)
|
||||
tmp_disk=`echo "$1" | sed 's%r\{0,1\}\([saw]d[0-9]*\).*$%r\1%' \
|
||||
| sed 's%r\{0,1\}\(da[0-9]*\).*$%r\1%'`
|
||||
tmp_disk=`echo "$1" | sed 's%r\{0,1\}\([saw]d[0-9]*\).*$%\1%' \
|
||||
| sed 's%r\{0,1\}\(da[0-9]*\).*$%\1%'`
|
||||
tmp_part=`echo "$1" \
|
||||
| sed "s%.*/r\{0,1\}[saw]d[0-9]\(s[0-9]*[a-h]\)%\1%" \
|
||||
| sed "s%.*/r\{0,1\}da[0-9]\(s[0-9]*[a-h]\)%\1%"`
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue