Follow-up on UEFI/Grub2 job

Makes some minor requested changes to the
devstack script that were added/changed
in order to support UEFI/GRUB2 booting
in CI.

Change-Id: I6a582cc2970911c9c827309d034e4553a09b66df
This commit is contained in:
Julia Kreger 2019-06-06 10:03:53 -07:00
parent 55e8d3fde1
commit 5f8cb199d1

View File

@ -517,7 +517,7 @@ if [[ "$IRONIC_BOOT_MODE" == "uefi" ]]; then
if [[ "$IRONIC_IPXE_ENABLED" == "False" ]]; then if [[ "$IRONIC_IPXE_ENABLED" == "False" ]]; then
# NOTE(TheJulia): While we no longer directly copy the # NOTE(TheJulia): While we no longer directly copy the
# IRONIC_GRUB2_FILE, we still check the exisstence as # IRONIC_GRUB2_FILE, we still check the existence as
# without the bootloader package we would be unable to build # without the bootloader package we would be unable to build
# the netboot core image. # the netboot core image.
if [[ -z $IRONIC_GRUB2_SHIM_FILE ]] || [[ -z $IRONIC_GRUB2_FILE ]] || [[ ! -f $IRONIC_GRUB2_SHIM_FILE ]] || [[ ! -f $IRONIC_GRUB2_FILE ]]; then if [[ -z $IRONIC_GRUB2_SHIM_FILE ]] || [[ -z $IRONIC_GRUB2_FILE ]] || [[ ! -f $IRONIC_GRUB2_SHIM_FILE ]] || [[ ! -f $IRONIC_GRUB2_FILE ]]; then
@ -985,6 +985,12 @@ function install_ironic {
sudo dpkg -i "$temp_deb" sudo dpkg -i "$temp_deb"
rm -f "$temp_deb" rm -f "$temp_deb"
# NOTE(TheJulia): This no longer seems required as the ovmf images
# DO correctly network boot. The effect of this is making the
# default boot loader iPXE, which is not always desired nor
# realistic for hardware in the field.
# If it is after Train, we should likely just delete the lines
# below and consider the same for Fedora.
# sudo rm /usr/share/qemu/pxe-virtio.rom # sudo rm /usr/share/qemu/pxe-virtio.rom
# sudo ln -s /usr/lib/ipxe/qemu/efi-virtio.rom /usr/share/qemu/pxe-virtio.rom # sudo ln -s /usr/lib/ipxe/qemu/efi-virtio.rom /usr/share/qemu/pxe-virtio.rom
elif is_fedora; then elif is_fedora; then
@ -1113,7 +1119,6 @@ function configure_ironic_dirs {
local uefi_loader local uefi_loader
local uefi_nvram local uefi_nvram
uefi_boot_file=$(get_uefi_ipxe_boot_file) uefi_boot_file=$(get_uefi_ipxe_boot_file)
if [ ! -f $uefi_boot_file ]; then if [ ! -f $uefi_boot_file ]; then
die $LINENO "UEFI boot file $uefi_boot_file not found." die $LINENO "UEFI boot file $uefi_boot_file not found."
@ -1803,7 +1808,7 @@ SUBSHELL
vbmc_port=$((vbmc_port+1)) vbmc_port=$((vbmc_port+1))
pdu_outlet=$((pdu_outlet+1)) pdu_outlet=$((pdu_outlet+1))
# It is sometimes useful to dump out the VM configuration to validate it. # It is sometimes useful to dump out the VM configuration to validate it.
# sudo virsh dumpxml $vm_name sudo virsh dumpxml $vm_name
done done
if [[ -z "${IRONIC_PROVISION_NETWORK_NAME}" ]]; then if [[ -z "${IRONIC_PROVISION_NETWORK_NAME}" ]]; then
@ -2355,18 +2360,17 @@ function configure_tftpd {
if is_fedora; then if is_fedora; then
grub_subdir="EFI/fedora" grub_subdir="EFI/fedora"
grub_dir=$IRONIC_TFTPBOOT_DIR/EFI/fedora
elif is_ubuntu; then elif is_ubuntu; then
grub_subdir="boot/grub" grub_subdir="boot/grub"
grub_dir=$IRONIC_TFTPBOOT_DIR/boot/grub
fi fi
grub_dir=$IRONIC_TFTPBOOT_DIR/$grub_subdir
mkdir -p $grub_dir mkdir -p $grub_dir
# Grub looks for numerous files when the grubnetx.efi binary is used :\ # Grub looks for numerous files when the grubnetx.efi binary is used :\
# specifically .lst files which define module lists which we can't seem # specifically .lst files which define module lists which we can't seem
# to find on disk. That being said, the grub-mknetdir utility generates # to find on disk. That being said, the grub-mknetdir utility generates
# these files for us. # these files for us.
grub-mknetdir --net-directory="$IRONIC_TFTPBOOT_DIR" --subdir="$grub_subdir" grub-mknetdir --net-directory="$IRONIC_TFTPBOOT_DIR" --subdir="$grub_subdir"
sudo cp $IRONIC_TFTPBOOT_DIR/$grub_subdir/x86_64-efi/core.efi $IRONIC_TFTPBOOT_DIR/grubx64.efi sudo cp $grub_dir/x86_64-efi/core.efi $IRONIC_TFTPBOOT_DIR/grubx64.efi
cat << EOF > $grub_dir/grub.cfg cat << EOF > $grub_dir/grub.cfg
set default=master set default=master
set timeout=1 set timeout=1