diff --git a/ChangeLog b/ChangeLog index f940a6617..5e422bf26 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2013-10-19 Vladimir Serbinenko + + Add haiku-specific functions. + 2013-10-19 Vladimir Serbinenko * grub-core/kern/emu/hostdisk.c: Remove few leftover includes. diff --git a/conf/Makefile.extra-dist b/conf/Makefile.extra-dist index c8413da22..bf52487f8 100644 --- a/conf/Makefile.extra-dist +++ b/conf/Makefile.extra-dist @@ -71,6 +71,7 @@ EXTRA_DIST += grub-core/osdep/hurd/hostdisk.c EXTRA_DIST += grub-core/osdep/linux/hostdisk.c EXTRA_DIST += grub-core/osdep/windows/hostdisk.c EXTRA_DIST += grub-core/osdep/sun/hostdisk.c +EXTRA_DIST += grub-core/osdep/haiku/hostdisk.c EXTRA_DIST += grub-core/osdep/basic/init.c EXTRA_DIST += grub-core/osdep/windows/init.c @@ -84,6 +85,7 @@ EXTRA_DIST += grub-core/osdep/freebsd/getroot.c EXTRA_DIST += grub-core/osdep/hurd/getroot.c EXTRA_DIST += grub-core/osdep/linux/getroot.c EXTRA_DIST += grub-core/osdep/sun/getroot.c +EXTRA_DIST += grub-core/osdep/haiku/getroot.c EXTRA_DIST += grub-core/osdep/basic/random.c EXTRA_DIST += grub-core/osdep/basic/ofpath.c diff --git a/grub-core/osdep/getroot.c b/grub-core/osdep/getroot.c index 6392a29d1..69a80e9a8 100644 --- a/grub-core/osdep/getroot.c +++ b/grub-core/osdep/getroot.c @@ -14,6 +14,8 @@ #include "windows/getroot.c" #elif defined(__AROS__) #include "aros/getroot.c" +#elif defined (__HAIKU__) +#include "haiku/getroot.c" #else # warning "No getroot OS-specific functions is available for your system. Device detection may not work properly." #include "basic/getroot.c" diff --git a/grub-core/osdep/haiku/getroot.c b/grub-core/osdep/haiku/getroot.c new file mode 100644 index 000000000..0852c5e5e --- /dev/null +++ b/grub-core/osdep/haiku/getroot.c @@ -0,0 +1,105 @@ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +enum grub_dev_abstraction_types +grub_util_get_dev_abstraction_os (const char *os_dev __attribute__((unused))) +{ + return GRUB_DEV_ABSTRACTION_NONE; +} + +int +grub_util_pull_device_os (const char *os_dev __attribute__ ((unused)), + enum grub_dev_abstraction_types ab __attribute__ ((unused))) +{ + return 0; +} + +char * +grub_util_get_grub_dev_os (const char *os_dev __attribute__ ((unused))) +{ + return NULL; +} + +char ** +grub_guess_root_devices (const char *dir_in) +{ + dev_t dv = dev_for_path (dir_in); + fs_info inf; + char **ret; + if (fs_stat_dev (dv, &inf) != B_OK) + return NULL; + ret = xmalloc (2 * sizeof (ret[0])); + ret[0] = xstrdup (inf.device_name); + ret[1] = NULL; + return ret; +} + +grub_disk_addr_t +grub_util_find_partition_start_os (const char *dev) +{ + partition_info part; + grub_disk_addr_t ret; + int fd = open (dev, O_RDONLY); + if (fd < 0) + return 0; + if (ioctl (fd, B_GET_PARTITION_INFO, &part, sizeof (part)) < 0) + { + close (fd); + return 0; + } + ret = part.offset; + close (fd); + fd = open (part.device, O_RDONLY); + + device_geometry geo; + if (ioctl (fd, B_GET_GEOMETRY, &geo, sizeof (geo)) < 0) + return 0; + ret /= geo.bytes_per_sector; + close (fd); + return ret; +} + +char * +grub_util_part_to_disk (const char *os_dev, + struct stat *st __attribute__ ((unused)), + int *is_part) +{ + char *ret; + partition_info part; + int fd = open (os_dev, O_RDONLY); + *is_part = 0; + + if (fd < 0) + return xstrdup (os_dev); + if (ioctl (fd, B_GET_PARTITION_INFO, &part, sizeof (part)) < 0) + { + close (fd); + return xstrdup (os_dev); + } + ret = xstrdup (part.device); + close (fd); + *is_part=1; + return ret; +} + +int +grub_util_biosdisk_is_floppy (grub_disk_t disk) +{ + const char *dname; + + dname = grub_util_biosdisk_get_osdev (disk); + + return (strncmp (dname, "/dev/disk/floppy/", sizeof ("/dev/disk/floppy/") - 1) + == 0); +} diff --git a/grub-core/osdep/haiku/hostdisk.c b/grub-core/osdep/haiku/hostdisk.c new file mode 100644 index 000000000..562353956 --- /dev/null +++ b/grub-core/osdep/haiku/hostdisk.c @@ -0,0 +1,69 @@ +/* + * GRUB -- GRand Unified Bootloader + * Copyright (C) 1999,2000,2001,2002,2003,2004,2006,2007,2008,2009,2010,2011,2012,2013 Free Software Foundation, Inc. + * + * GRUB is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * GRUB is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with GRUB. If not, see . + */ + +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +grub_int64_t +grub_util_get_fd_size_os (grub_util_fd_t fd, + const char *name __attribute__ ((unused)), + unsigned *log_secsize) +{ + device_geometry part; + unsigned lg; + if (ioctl (fd, B_GET_GEOMETRY, &part, sizeof (part)) < 0) + return -1; + for (lg = 0; (1 << lg) < part.bytes_per_sector; lg++); + if (log_secsize) + *log_secsize= lg; + return ((grub_uint64_t) part.cylinder_count + * (grub_uint64_t) part.head_count + * (grub_uint64_t) part.sectors_per_track + * (grub_uint64_t) part.bytes_per_sector); +} + +void +grub_hostdisk_flush_initial_buffer (const char *os_dev __attribute__ ((unused))) +{ +} diff --git a/grub-core/osdep/hostdisk.c b/grub-core/osdep/hostdisk.c index ae491b5bf..185397915 100644 --- a/grub-core/osdep/hostdisk.c +++ b/grub-core/osdep/hostdisk.c @@ -14,6 +14,8 @@ #include "windows/hostdisk.c" #elif defined(__AROS__) #include "aros/hostdisk.c" +#elif defined (__HAIKU__) +#include "haiku/hostdisk.c" #else # warning "No hostdisk OS-specific functions is available for your system. Device detection may not work properly." #include "basic/hostdisk.c" diff --git a/grub-core/osdep/unix/getroot.c b/grub-core/osdep/unix/getroot.c index 410d58ddd..ef3803748 100644 --- a/grub-core/osdep/unix/getroot.c +++ b/grub-core/osdep/unix/getroot.c @@ -40,7 +40,7 @@ #include #include -#if !defined (__MINGW32__) && !defined (__CYGWIN__) && !defined (__AROS__) +#if !defined (__MINGW32__) && !defined (__CYGWIN__) && !defined (__AROS__) && !defined (__HAIKU__) #ifdef __linux__ #include /* ioctl */ diff --git a/grub-core/osdep/unix/relpath.c b/grub-core/osdep/unix/relpath.c index 8489a16d9..56d3923a8 100644 --- a/grub-core/osdep/unix/relpath.c +++ b/grub-core/osdep/unix/relpath.c @@ -49,10 +49,12 @@ grub_make_system_path_relative_to_its_root (const char *path) grub_util_error (_("failed to get canonical path of `%s'"), path); /* For ZFS sub-pool filesystems, could be extended to others (btrfs?). */ +#ifndef __HAIKU__ { char *dummy; grub_find_zpool_from_dir (p, &dummy, &poolfs); } +#endif len = strlen (p) + 1; buf = xstrdup (p); diff --git a/include/grub/osdep/hostfile_unix.h b/include/grub/osdep/hostfile_unix.h index 8a0d52acd..50883f44f 100644 --- a/include/grub/osdep/hostfile_unix.h +++ b/include/grub/osdep/hostfile_unix.h @@ -97,7 +97,7 @@ typedef int grub_util_fd_t; #define GRUB_UTIL_FD_IS_VALID(x) ((x) >= 0) #define GRUB_UTIL_FD_STAT_IS_FUNCTIONAL 1 -#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__APPLE__) || defined(__NetBSD__) || defined (__sun__) || defined(__OpenBSD__) +#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__APPLE__) || defined(__NetBSD__) || defined (__sun__) || defined(__OpenBSD__) || defined(__HAIKU__) #define GRUB_DISK_DEVS_ARE_CHAR 1 #else #define GRUB_DISK_DEVS_ARE_CHAR 0