Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Default shared configuration has incorrect assumptions #4040

Open
pevogam opened this issue Dec 16, 2024 · 3 comments
Open

Default shared configuration has incorrect assumptions #4040

pevogam opened this issue Dec 16, 2024 · 3 comments

Comments

@pevogam
Copy link
Contributor

pevogam commented Dec 16, 2024

The setting in

has preceding comment

        # Add -drive ...boot=yes unless qemu-kvm is 0.12.1.2 or newer
        # then kvm_vm will ignore this option.

but on most recent Qemu 8.2 it is not ignored and rather has a dramatic effect on our VT tests where the image will be strictly booted in cases of UEFI reinstallation and USB installation tests that previously relied on alternative boot order configuration using Avocado VT. Is this default really intended to be set? If not I would recommend

-         image_boot~=yes
+         # image_boot~=yes

which used to be the case long ago. Is there any other purpose behind this parameter and its meaning different then the above-mentioned comment?

@luckyh @YongxueHong Do you happen to know more about this choice?

@luckyh
Copy link
Contributor

luckyh commented Dec 18, 2024

@pevogam sorry, I cannot recall on that since it was introduced too long ago (more than 10 years)... anyway, I'd like to prefer to drop the setting as well due to

  • we don't apply such a setting to other kind of virtual block devices, that means we seems to be safe for dealing with boot orders in the case that image_boot not being present
  • nowadays, qemu don't even have the option (-drive ...,boot=) documented in the manual page
  • -blockdev was recommended to be the replacement of -drive from several years ago and the former don't support the boot option

does it sounds good to you?

@pevogam
Copy link
Contributor Author

pevogam commented Dec 20, 2024

@pevogam sorry, I cannot recall on that since it was introduced too long ago (more than 10 years)...

Indeed, the difference is that back then it was commented out and later through the years it got uncommented and now ended up affecting our test suite as it was still making use of -drive options via the virttest parameter qemu_force_use_drive_expression. The ~= must have only affected users that defined the image_boot parameter on the first place but in our case it seems it somehow comes up and as a result this setting completely modifies our previous behavior when we switched to virtio storage.

anyway, I'd like to prefer to drop the setting as well due to

* we don't apply such a setting to other kind of virtual block devices, that means we seems to be safe for dealing with boot orders in the case that `image_boot` not being present

* nowadays, qemu don't even have the option (`-drive ...,boot=`) documented in the manual page

* `-blockdev` was recommended to be the replacement of `-drive` from several years ago and the former don't support the `boot` option

does it sounds good to you?

Perhaps it is worth keeping it a while longer for backwards compatibility. My main point and worry was that it introduces unexpected behavior in comparison to other storage hardware variants since we were using -drives there and didn't end up forced to always boot the same image (e.g. when wanting to boot from a CD or USB instead). And I definitely can't find image_boot anywhere in our configs but it got triggered by this line when switching to virtio storage hardware variant.

@pevogam
Copy link
Contributor Author

pevogam commented Dec 27, 2024

Actually IIUC the ~= will set the parameter if not set before:

class LLazySet(LOperators):
    __slots__ = []
    identifier = "~="

    def apply_to_dict(self, d):
        if self.name not in _reserved_keys and self.name not in d:
            d[self.name] = _substitution(self.value, d)

which will always define this parameter for all users that use the legacy -devices together with VirtIO drivers and considering some users might have already defined multiple of many hard drives and which ones to boot from this could severely interfere with them. Note that this parameter used to be commented out before so the previous behavior was image_boot=no and along the way it was modified in an impactful way to image_boot~=yes which results in image_boot=yes for nearly everyone. I noticed for instance that the parameter is defined even when we use -blockdev instead of -drive because we rely on the virtio drivers.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants