Skip to content
This repository has been archived by the owner on Feb 9, 2022. It is now read-only.

Change hostedEngine VM bios_type to q35 #331

Closed
wants to merge 1 commit into from

Conversation

eslutsky
Copy link
Contributor

Change hostedEngine VM bios_type to q35

Bug-Url: https://bugzilla.redhat.com/show_bug.cgi?id=1847880

Signed-off-by: Evgeny Slutsky [email protected]

@eslutsky
Copy link
Contributor Author

@arachmani , can you also verify its solve your deployment issue

@arachmani
Copy link
Member

@arachmani , can you also verify its solve your deployment issue

@eslutsky, verified.

@eslutsky
Copy link
Contributor Author

changing the bios_type value in DB is not very good solution (only as a temp workaround),
there is merged PR to the ovirt-ansible-collection, adding bios_type support for ovirt_vm module:
oVirt/ovirt-ansible-collection#15
when will be able to consume it in HE deployments tasks?
@sandrobonazzola @oVirt/ovirt-infra

@mnecas
Copy link
Member

mnecas commented Jun 22, 2020

Hi,
because it is RFE it will not be added to Ansible 2.9 and in 2.10 there will be no oVirt module in Ansible core and everything moved to the collection.
The collection is not yet integrated into any role nor engine.

But if you need the parameter ASAP you can create library.

  • Create folder library in role
  • Add the ovirt_vm module from latest 2.9 to the folder (recommend to rename it also to something like ovirt_vm210)
  • Add the patch from Add Bios Type option ovirt-ansible-collection#15
  • Use the updated module in task

Example of the library in role https://github.com/oVirt/ovirt-ansible-vm-infra/tree/ovirt-ansible-vm-infra-1.1

@eslutsky
Copy link
Contributor Author

we don't need this PR anymore, the issue being handled from the engine side:
https://gerrit.ovirt.org/#/c/109825/

@eslutsky eslutsky closed this Jun 23, 2020
@gmarcy
Copy link

gmarcy commented Jun 28, 2020

@eslutsky This may still be needed. I'm running the latest code with the fix on the engine side and it's still choosing pc-i440fx-rhel7.6.0 for the machine type because vm.getEffectiveBiosType() returns the default bios type which is still "pc" not "q35". searching the ovirt-hosted-engine-setup-ansible-create_target_vm log for bios_type shows that the value is "q35_sea_bios" but that isn't making it into the effective bios type. Other values from the logs which seem to indicate that something is slipping through the cracks are:

v_supported_emulated_machines=q35,pc-i440fx-rhel7.3.0,pc,pc-i440fx-rhel7.6.0,pc-q35-rhel8.2.0,pc-q35-rhel7.5.0,pc-i440fx-rhel7.4.0,pc-q35-rhel8.1.0,pc-q35-rhel8.0.0,pc-q35-rhel7.3.0,pc-i440fx-rhel7.0.0,pc-i440fx-rhel7.1.0,pc-i440fx-rhel7.5.0,pc-q35-rhel7.6.0,pc-i440fx-rhel7.2.0,pc-q35-rhel7.4.0

v_emulated_machine=pc-i440fx-rhel7.6.0;pc-q35-rhel8.1.0, v_cpu_name=Secure Intel IvyBridge Family

Yet, when the ovf:Envelope is sent, it contains:

<CustomEmulatedMachine>pc-i440fx-rhel7.6.0</CustomEmulatedMachine><CustomCpuName>IvyBridge,+pcid,+spec-ctrl,+ssbd,+md-clear</CustomCpuName>

and the <EngineXML> value includes

&lt;type arch="x86_64" machine="pc-i440fx-rhel7.6.0"&gt;hvm&lt;/type&gt;

I've tried pausing the install script and connecting to the HostedEngineLocal VM and changing all the log levels in /usr/share/ovirt-engine/services/ovirt-engine/* from INFO to DEBUG, but it just looks like there isn't enough logging in the engine within this area to get the logs to show precisely what's happening.

@gmarcy
Copy link

gmarcy commented Jun 28, 2020

FYI, this is running the ovirt-node-ng-installer-4.4.1-2020062707.el8.iso master snapshot and using the ovirt-engine-appliance-4.4-20200626174650.1.el8.x86_64 package.

@gmarcy
Copy link

gmarcy commented Jun 29, 2020

I confirm that this works with the latest level, pc-q35-rhel8.1.0 is chosen instead of pc-i440fx-rhel7.6.0 and the hosted engine install worked without any other errors. That said, I also agree that it feels wrong to address the problem in this way of hard-wiring the bios_type to 2 in the DB. What stumped me is why this works but adding something like this to the setup script using --config-append didn't

[environment:default]
OVEHOSTED_VM/emulatedMachine=str:q35

@michalskrivanek
Copy link
Member

Hi Glenn, thank you for testing it out. The problem was in the specific code (we have a lot of those from the past) of handling HE VM's OVF, in this case it was overwriting the configured BiosType (which is q35+seabios in 4.4) and writing the wrong one which was then picked up on followup restart where the OVF is used to launch the HE.

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

Successfully merging this pull request may close these issues.

5 participants