From: Lennart Poettering Date: Fri, 7 Mar 2025 10:56:33 +0000 (+0100) Subject: virt: some modernizations X-Git-Tag: v258-rc1~1144^2~1 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=4d53d76f5e040a4dc5749aa2c401607933b957e5;p=thirdparty%2Fsystemd.git virt: some modernizations Reduce scope of certain allocations, add more debug logging, and improve some log messages. --- diff --git a/src/basic/virt.c b/src/basic/virt.c index 905a37e4a95..f5a88ed3d6f 100644 --- a/src/basic/virt.c +++ b/src/basic/virt.c @@ -103,32 +103,30 @@ static Virtualization detect_vm_device_tree(void) { r = read_one_line_file("/proc/device-tree/hypervisor/compatible", &hvtype); if (r == -ENOENT) { - _cleanup_closedir_ DIR *dir = NULL; - _cleanup_free_ char *compat = NULL; - if (access("/proc/device-tree/ibm,partition-name", F_OK) == 0 && access("/proc/device-tree/hmc-managed?", F_OK) == 0 && access("/proc/device-tree/chosen/qemu,graphic-width", F_OK) != 0) return VIRTUALIZATION_POWERVM; - dir = opendir("/proc/device-tree"); + _cleanup_closedir_ DIR *dir = opendir("/proc/device-tree"); if (!dir) { if (errno == ENOENT) { - log_debug_errno(errno, "/proc/device-tree: %m"); + log_debug_errno(errno, "/proc/device-tree/ does not exist"); return VIRTUALIZATION_NONE; } - return -errno; + return log_debug_errno(errno, "Opening /proc/device-tree/ failed: %m"); } - FOREACH_DIRENT(de, dir, return -errno) + FOREACH_DIRENT(de, dir, return log_debug_errno(errno, "Failed to enumerate /proc/device-tree/ contents: %m")) if (strstr(de->d_name, "fw-cfg")) { log_debug("Virtualization QEMU: \"fw-cfg\" present in /proc/device-tree/%s", de->d_name); return VIRTUALIZATION_QEMU; } + _cleanup_free_ char *compat = NULL; r = read_one_line_file("/proc/device-tree/compatible", &compat); if (r < 0 && r != -ENOENT) - return r; + return log_debug_errno(r, "Failed to read /proc/device-tree/compatible: %m"); if (r >= 0 && streq(compat, "qemu,pseries")) { log_debug("Virtualization %s found in /proc/device-tree/compatible", compat); return VIRTUALIZATION_QEMU;