c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * CDDL HEADER START
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * The contents of this file are subject to the terms of the
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Common Development and Distribution License (the "License").
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * You may not use this file except in compliance with the License.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * See the License for the specific language governing permissions
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * and limitations under the License.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * When distributing Covered Code, include this CDDL HEADER in each
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * If applicable, add the following below this CDDL HEADER, with the
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * fields enclosed by brackets "[]" replaced with your own identifying
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * information: Portions Copyright [yyyy] [name of copyright owner]
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * CDDL HEADER END
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Copyright 2012 Milan Jurik. All rights reserved.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Copyright 2015 Nexenta Systems, Inc. All rights reserved.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Copyright 2016 Toomas Soome <tsoome@me.com>
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Loader menu management.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomestatic error_t set_option(struct menu_lst *, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomestatic error_t list_entry(struct menu_lst *, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomestatic error_t update_entry(struct menu_lst *, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomestatic error_t update_temp(struct menu_lst *, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomestatic error_t list_setting(struct menu_lst *menu, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomestatic error_t disable_hyper(struct menu_lst *, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomestatic error_t enable_hyper(struct menu_lst *, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome/* Menu related sub commands */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "set_option", OPT_ABSENT, set_option, 0, /* PUB */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "list_entry", OPT_OPTIONAL, list_entry, 1, /* PUB */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "update_entry", OPT_REQ, update_entry, 0, /* menu */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "update_temp", OPT_OPTIONAL, update_temp, 0, /* reboot */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "list_setting", OPT_OPTIONAL, list_setting, 1, /* menu */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "disable_hypervisor", OPT_ABSENT, disable_hyper, 0, /* menu */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "enable_hypervisor", OPT_ABSENT, enable_hyper, 0, /* menu */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * all columns output format
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome for (i = 0; i < NUM_COLS; i++) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome struct col_info *col_info = &hdr_info->cols[i];
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome for (i = 0; i < NUM_COLS; i++) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome size_t sz = mbstowcs(wname, name, sizeof (wname) /
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomecount_widths(struct hdr_info *hdr, struct menu_lst *menu)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome for (i = 0; i < NUM_COLS; i++)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome for (i = 0; i < NUM_COLS; i++)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomeprint_menu_nodes(boolean_t parsable, struct hdr_info *hdr,
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (strcmp(be_node->be_root_ds, entry->bootfs) == 0)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome be_node->be_active_on_boot == B_TRUE? "*" : "-",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome be_node->be_active_on_boot == B_TRUE? "*" : "-",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomeprint_nodes(boolean_t parsable, struct menu_lst *menu)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomemenu_read(struct menu_lst *menu, char *menu_path)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * menu.lst entry is on two lines, one for title, one for bootfs
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * so we process both lines in succession.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if ((mp = malloc(sizeof (struct menu_entry))) == NULL) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomebam_loader_menu(char *subcmd, char *opt, int largc, char *largv[])
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome error_t (*f)(struct menu_lst *, char *, char *);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Check arguments
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome ret = check_subcmd_and_options(subcmd, opt, menu_subcmds, &f);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) strlcpy(menu_root, bam_root, sizeof (menu_root));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome /* fixup bam_root so that it points at osroot */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome INJECT_ERROR1("Z_MENU_GET_SPECIAL", special = NULL);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("cant find special file for mount-point %s\n"),
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("cant find pool for mount-point %s\n"), menu_root);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome BAM_DPRINTF(("%s: derived pool=%s from special\n", fcn, pool));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome INJECT_ERROR1("Z_MENU_MOUNT_TOP_DATASET", zmntpt = NULL);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("cannot mount pool dataset for pool: %s\n"), pool);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome BAM_DPRINTF(("%s: top dataset mountpoint=%s\n", fcn, zmntpt));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) strlcpy(menu_root, zmntpt, sizeof (menu_root));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome BAM_DPRINTF(("%s: zfs menu_root=%s\n", fcn, menu_root));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome elide_trailing_slash(menu_root, clean_menu_root,
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome BAM_DPRINTF(("%s: cleaned menu root is <%s>\n", fcn, clean_menu_root));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) strlcpy(menu_path, clean_menu_root, sizeof (menu_path));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) strlcat(menu_path, MENU, sizeof (menu_path));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome BAM_DPRINTF(("%s: menu path is: %s\n", fcn, menu_path));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * update_entry is special case, its used by installer
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * and needs to create menu.lst file for loader
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (menu_read(&menu, menu_path) == BAM_ERROR &&
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("cannot find menu file: %s\n"), menu_path);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * If listing the menu, display the menu location
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_print(_("the location for the active menu is: %s\n"),
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * We already checked the following case in
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * check_subcmd_and_suboptions() above. Complete the
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * final step now.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome assert(largc == 1 && largv[0] && largv[1] == NULL);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if ((strcmp(subcmd, "enable_hypervisor") != 0) &&
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Once the sub-cmd handler has run
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * only the line field is guaranteed to have valid values
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcmp(subcmd, "list_entry") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcmp(subcmd, "list_setting") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcmp(subcmd, "disable_hypervisor") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("%s operation unsupported on SPARC "
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcmp(subcmd, "enable_hypervisor") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("%s operation unsupported on SPARC "
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Compress all arguments passed in the largv[] array
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * into one string that can then be appended to the
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * end of the kernel$ string the routine to enable the
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * hypervisor will build.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * This allows the caller to supply arbitrary unparsed
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * arguments, such as dom0 memory settings or APIC
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * This concatenation will be done without ANY syntax
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * checking whatsoever, so it's the responsibility of
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * the caller to make sure the arguments are valid and
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * do not duplicate arguments the conversion routines
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * may create.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Allocate space for argument strings,
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * intervening spaces and terminating NULL.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome BAM_DPRINTF(("%s: writing menu to clean-menu-root: <%s>\n",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome /* ret = menu_write(clean_menu_root, menu); */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) umount_top_dataset(pool, zmnted, zmntpt);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * To suppress output from ficl. We do not want to see messages
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * from interpreting loader config.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomeset_option(struct menu_lst *menu, char *dummy, char *opt)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("invalid boot entry number: %s\n"), val);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("invalid boot entry number: %s\n"), val);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (nvlist_alloc(&be_attrs, NV_UNIQUE_NAME, 0) != 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (nvlist_add_string(be_attrs, BE_ATTR_ORIG_BE_NAME,
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(path, PATH_MAX, "%s" CONF_DIR "/timeout",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * timeout=-1 is to disable auto boot in illumos, but
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * loader needs "NO" to disable auto boot.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome rv = fprintf(fp, "autoboot_delay=\"%d\"\n", optval);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomebam_mount_be(struct menu_entry *entry, char **dir)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (nvlist_alloc(&be_attrs, NV_UNIQUE_NAME, 0) != 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (strcmp(be_node->be_root_ds, entry->bootfs) == 0)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (nvlist_add_string(be_attrs, BE_ATTR_ORIG_BE_NAME,
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (nvlist_add_string(be_attrs, BE_ATTR_MOUNTPOINT, *dir) != 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * if BE is mounted, dir does not point to correct directory
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (nvlist_alloc(&be_attrs, NV_UNIQUE_NAME, 0) != 0)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (nvlist_add_string(be_attrs, BE_ATTR_ORIG_BE_NAME, dir) != 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * display details of menu entry or single property
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomelist_menu_entry(struct menu_entry *entry, char *setting)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (mounted != BE_SUCCESS && mounted != BE_ERR_MOUNTED) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("%s is not mounted\n"), entry->title);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("error setting up forth interpreter\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome /* should only get FICL_VM_STATUS_OUT_OF_TEXT */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(buf, MAX_INPUT, "set currdev=zfs:%s:",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(buf, MAX_INPUT, "include /boot/forth/loader.4th");
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome else if (strcasecmp(setting, "timeout") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome else if (strcasecmp(setting, "console") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcasecmp(setting, "xen_kernel") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcasecmp(setting, "xen_cmdline") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcasecmp(setting, "kernel") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome } else if (strcasecmp(setting, "boot-args") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (*setting == '\0' || strcasecmp(setting, "modules") == 0) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome ficlVmSetTextOut(vm, ficlCallbackDefaultTextOut);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(buf, MAX_INPUT, "show-module-options");
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome /* if we got here with setting string, its unknown property */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("unknown property: %s\n"), setting);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomelist_entry(struct menu_lst *menu, char *menu_root, char *opt)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome int i, e = -1;
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * For now this is just stub entry to support grub interface, the
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * known consumer is installer ict.py code, calling as:
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * bootadm update-menu -R /a -Z -o rdisk
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * Later this can be converted to do something useful.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomeupdate_entry(struct menu_lst *menu, char *menu_root, char *osdev)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(path, PATH_MAX, "%s%s", menu_root, MENU);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome for (be_node = be_nodes; be_node; be_node = be_node->be_next_node) {
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "title %s\n", be_node->be_node_name);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "bootfs %s\n", be_node->be_root_ds);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomeupdate_temp(struct menu_lst *menu, char *dummy, char *opt)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(path, PATH_MAX, "%s" TRANSIENT, bam_root);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * if opt == NULL, remove transient config
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error setting up forth interpreter\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * need to check current boot config, so fire up the ficl
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * if its xen setup, we add option to boot-args list, not replacing it.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(buf, MAX_INPUT, "set currdev=zfs:%s:", mp.mnt_special);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(buf, MAX_INPUT, "include /boot/forth/loader.4th");
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "boot-args=\"%s %s\"\n", env, opt);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * it should be the case with "kernel args"
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * so, we split the opt at first space
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * and store bootfile= and boot-args=
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome *o++ = '\0';
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "boot-args=\"%s %s\"\n", env, opt);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomelist_setting(struct menu_lst *menu, char *which, char *setting)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * which can be:
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * "" - list default entry
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * number - use for entry number
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * property name
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("invalid boot entry number: %s\n"),
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome /* find default entry */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome if (strcmp(be_node->be_root_ds, m->bootfs) == 0)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome break; /* found active node */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("None of BE nodes is marked active\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomedisable_hyper(struct menu_lst *menu, char *osroot, char *opt)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(path, PATH_MAX, "%s" XEN_CONFIG, bam_root);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soomeenable_hyper(struct menu_lst *menu, char *osroot, char *opt)
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error setting up forth interpreter\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * need to check current boot config, so fire up the ficl
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * if its xen setup, we add option to boot-args list, not replacing it.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(buf, MAX_INPUT, "set currdev=zfs:%s:", mp.mnt_special);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(buf, MAX_INPUT, "include /boot/forth/loader.4th");
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome bam_error(_("Error interpreting boot config\n"));
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) snprintf(path, PATH_MAX, "%s" XEN_CONFIG, bam_root);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome return (BAM_ERROR); /* error, cant write config */
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * on write error, remove file to ensure we have bootable config.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * note we dont mind if config exists, it will get updated
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "xen_kernel=\"/boot/${ISADIR}/xen\"\n");
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * really simple and stupid console conversion.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome * it really has to be gone, it belongs to milestone/xvm properties.
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "xen_cmdline=\"console=com1 %s\"\n",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "xen_cmdline=\"console=com2 %s\"\n",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "xen_cmdline=\"console=vga %s\"\n",
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome (void) fprintf(fp, "xen_cmdline=\"%s\"\n", opt);
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "bootfile=\"/platform/i86xpv/kernel/${ISADIR}/unix\"\n");
c262cbbc8301f7c884fd4800056ee51ba75d931cToomas Soome "boot-args=\"/platform/i86xpv/kernel/${ISADIR}/unix\"\n");