aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Huth <thuth@redhat.com>2025-07-09 10:34:42 +0200
committerThomas Huth <thuth@redhat.com>2025-07-11 10:04:29 +0200
commitfc24fd9342ec5ddaeecdf2a28f7fc4c2cdf6b014 (patch)
treeb64f62ae0f680c7a49350b267513f1672f933d0b
parent47d68f7475feb86c9347f7013066b3b05b545cfc (diff)
downloadqemu-fc24fd9342ec5ddaeecdf2a28f7fc4c2cdf6b014.zip
qemu-fc24fd9342ec5ddaeecdf2a28f7fc4c2cdf6b014.tar.gz
qemu-fc24fd9342ec5ddaeecdf2a28f7fc4c2cdf6b014.tar.bz2
pc-bios/s390-ccw: Add a boot menu for booting via pxelinux.cfg
Show a simple boot menu for pxelinux.cfg, too, if the user requested it. Reviewed-by: Jared Rossi <jrossi@linux.ibm.com> Signed-off-by: Thomas Huth <thuth@redhat.com> Message-ID: <20250709083443.41574-5-thuth@redhat.com>
-rw-r--r--pc-bios/s390-ccw/netmain.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/pc-bios/s390-ccw/netmain.c b/pc-bios/s390-ccw/netmain.c
index 6f64323..a9521df 100644
--- a/pc-bios/s390-ccw/netmain.c
+++ b/pc-bios/s390-ccw/netmain.c
@@ -332,6 +332,28 @@ static int load_kernel_with_initrd(filename_ip_t *fn_ip,
return rc;
}
+static int net_boot_menu(int num_ent, int def_ent,
+ struct pl_cfg_entry *entries)
+{
+ bool valid_entries[MAX_BOOT_ENTRIES] = { false };
+ int idx;
+
+ puts("\ns390-ccw pxelinux.cfg boot menu:\n");
+ printf(" [0] default (%d)\n", def_ent + 1);
+ valid_entries[0] = true;
+
+ for (idx = 1; idx <= num_ent; idx++) {
+ printf(" [%d] %s\n", idx, entries[idx - 1].label);
+ valid_entries[idx] = true;
+ }
+ putchar('\n');
+
+ idx = menu_get_boot_index(valid_entries);
+ putchar('\n');
+
+ return idx;
+}
+
static int net_select_and_load_kernel(filename_ip_t *fn_ip,
int num_ent, int selected,
struct pl_cfg_entry *entries)
@@ -342,6 +364,10 @@ static int net_select_and_load_kernel(filename_ip_t *fn_ip,
return -1;
}
+ if (menu_is_enabled_enum() && num_ent > 1) {
+ loadparm = net_boot_menu(num_ent, selected, entries);
+ }
+
IPL_assert(loadparm <= num_ent,
"loadparm is set to an entry that is not available in the "
"pxelinux.cfg file!");