2023-08-23 15:44:12 +02:00
|
|
|
From: Ignaz Forster <iforster@suse.com>
|
|
|
|
Date: Thu, 9 Feb 2023 16:05:27 +0100
|
2023-03-07 16:49:53 +01:00
|
|
|
Upstream: Ticket opened [gh#coreos/ignition#1556]
|
|
|
|
|
|
|
|
Continue with empty config on missing QEMU device
|
|
|
|
|
|
|
|
The two QEMU provider implementations (fwcfg for platforms with
|
|
|
|
native support and blockdev for the others) have slightly different
|
|
|
|
behaviour: If fwcfg doesn't contain any configuration, it will just
|
|
|
|
skip ("QEMU firmware config was not found. Ignoring..."). The blockdev
|
|
|
|
provider would error out if it can't read the configuration.
|
|
|
|
|
|
|
|
Change the behavior of the blockdev provider to match the fwcfg one
|
|
|
|
and continue with an empty configuration if the device is not there.
|
|
|
|
|
|
|
|
diff --git a/internal/providers/qemu/qemu_blockdev.go b/internal/providers/qemu/qemu_blockdev.go
|
|
|
|
index 911eb973..11739f3e 100644
|
|
|
|
--- a/internal/providers/qemu/qemu_blockdev.go
|
|
|
|
+++ b/internal/providers/qemu/qemu_blockdev.go
|
2023-03-10 16:36:17 +01:00
|
|
|
@@ -22,7 +22,6 @@ package qemu
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
- "fmt"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"time"
|
2023-03-10 16:04:09 +01:00
|
|
|
@@ -83,7 +83,7 @@ func fetchConfigFromBlockDevice(logger *log.Logger) ([]byte, error) {
|
2023-03-07 16:49:53 +01:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
case <-time.After(blockDeviceTimeout):
|
|
|
|
- return nil, fmt.Errorf("timed out after %v waiting for block device %q to appear", blockDeviceTimeout, ignitionBlockDevicePath)
|
|
|
|
+ logger.Info("timed out after %v waiting for block device %q to appear. Ignoring...", blockDeviceTimeout, ignitionBlockDevicePath)
|
|
|
|
}
|
|
|
|
|
|
|
|
return bytes.TrimRight(data, "\x00"), nil
|