summaryrefslogtreecommitdiff
path: root/usr/src/cmd/svc
diff options
context:
space:
mode:
Diffstat (limited to 'usr/src/cmd/svc')
-rw-r--r--usr/src/cmd/svc/startd/Makefile3
-rw-r--r--usr/src/cmd/svc/startd/graph.c45
2 files changed, 22 insertions, 26 deletions
diff --git a/usr/src/cmd/svc/startd/Makefile b/usr/src/cmd/svc/startd/Makefile
index 1a29300a68..0479bc97b8 100644
--- a/usr/src/cmd/svc/startd/Makefile
+++ b/usr/src/cmd/svc/startd/Makefile
@@ -21,6 +21,7 @@
#
# Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
# Copyright 2012 Milan Jurik. All rights reserved.
+# Copyright 2016 Toomas Soome <tsoome@me.com>
#
PROG = svc.startd
@@ -93,7 +94,7 @@ LDLIBS += \
-lumem \
-luutil
-LDLIBS_i386 += -lgrubmgmt
+LDLIBS_i386 += -lbe
LDLIBS += $(LDLIBS_$(MACH)) -L $(ROOT)/lib/fm -lfmevent
LDFLAGS += -R /lib/fm
diff --git a/usr/src/cmd/svc/startd/graph.c b/usr/src/cmd/svc/startd/graph.c
index 5a4e933220..fa20e56775 100644
--- a/usr/src/cmd/svc/startd/graph.c
+++ b/usr/src/cmd/svc/startd/graph.c
@@ -23,6 +23,7 @@
* Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
* Copyright 2013, Joyent, Inc. All rights reserved.
* Copyright (c) 2015, Syneto S.R.L. All rights reserved.
+ * Copyright 2016 Toomas Soome <tsoome@me.com>
*/
/*
@@ -162,9 +163,9 @@
#include <sys/statvfs.h>
#include <sys/uadmin.h>
#include <zone.h>
-#if defined(__i386)
-#include <libgrubmgmt.h>
-#endif /* __i386 */
+#if defined(__x86)
+#include <libbe.h>
+#endif /* __x86 */
#include "startd.h"
#include "protocol.h"
@@ -533,8 +534,8 @@ graph_walk_dependents(graph_vertex_t *v, void (*func)(graph_vertex_t *, void *),
}
static void
-graph_walk_dependencies(graph_vertex_t *v, void (*func)(graph_vertex_t *,
- void *), void *arg)
+graph_walk_dependencies(graph_vertex_t *v,
+ void (*func)(graph_vertex_t *, void *), void *arg)
{
graph_edge_t *e;
@@ -3588,9 +3589,9 @@ do_uadmin(void)
struct tm nowtm;
char down_buf[256], time_buf[256];
uintptr_t mdep;
-#if defined(__i386)
- grub_boot_args_t fbarg;
-#endif /* __i386 */
+#if defined(__x86)
+ char *fbarg = NULL;
+#endif /* __x86 */
mdep = NULL;
fd = creat(resetting, 0777);
@@ -3641,27 +3642,22 @@ do_uadmin(void)
* print warning and fall back to regular reboot.
*/
if (halting == AD_FASTREBOOT) {
-#if defined(__i386)
- int rc;
-
- if ((rc = grub_get_boot_args(&fbarg, NULL,
- GRUB_ENTRY_DEFAULT)) == 0) {
- mdep = (uintptr_t)&fbarg.gba_bootargs;
+#if defined(__x86)
+ if (be_get_boot_args(&fbarg, BE_ENTRY_DEFAULT) == 0) {
+ mdep = (uintptr_t)fbarg;
} else {
/*
- * Failed to read GRUB menu, fall back to normal reboot
+ * Failed to read BE info, fall back to normal reboot
*/
halting = AD_BOOT;
- uu_warn("Failed to process GRUB menu entry "
- "for fast reboot.\n\t%s\n"
- "Falling back to regular reboot.\n",
- grub_strerror(rc));
+ uu_warn("Failed to get fast reboot arguments.\n"
+ "Falling back to regular reboot.\n");
}
-#else /* __i386 */
+#else /* __x86 */
halting = AD_BOOT;
uu_warn("Fast reboot configured, but not supported by "
"this ISA\n");
-#endif /* __i386 */
+#endif /* __x86 */
}
fork_with_timeout("/sbin/umountall -l", 0, 5);
@@ -3717,11 +3713,10 @@ do_uadmin(void)
(void) uadmin(A_SHUTDOWN, halting, mdep);
uu_warn("uadmin() failed");
-#if defined(__i386)
- /* uadmin fail, cleanup grub_boot_args */
+#if defined(__x86)
if (halting == AD_FASTREBOOT)
- grub_cleanup_boot_args(&fbarg);
-#endif /* __i386 */
+ free(fbarg);
+#endif /* __x86 */
if (remove(resetting) != 0 && errno != ENOENT)
uu_warn("Could not remove \"%s\"", resetting);