Fix race conditions in hyperv readiness checking

- Listen before starting the vm
- Fix a device race caused by lazy hv_vsock init by waiting on network manager

[NO NEW TESTS NEEDED]

Signed-off-by: Jason T. Greene <jason.greene@redhat.com>
This commit is contained in:
Jason T. Greene
2024-02-23 20:27:02 -06:00
parent 5a844511c8
commit b68d3c7a0e
3 changed files with 19 additions and 12 deletions

View File

@ -28,7 +28,9 @@ func CreateReadyUnitFile(provider define.VMType, opts *ReadyUnitOpts) (string, e
if opts == nil || opts.Port == 0 {
return "", errors.New("no port provided for hyperv ready unit")
}
readyUnit.Add("Unit", "Requires", "sys-devices-virtual-net-vsock0.device")
readyUnit.Add("Unit", "After", "systemd-user-sessions.service")
readyUnit.Add("Unit", "After", "vsock-network.service")
readyUnit.Add("Service", "ExecStart", fmt.Sprintf("/bin/sh -c '/usr/bin/echo Ready | socat - VSOCK-CONNECT:2:%d'", opts.Port))
case define.WSLVirt: // WSL does not use ignition
return "", nil