]> xenbits.xensource.com Git - xen.git/commitdiff
tools/xl: fix channel configuration setting
authorJuergen Gross <jgross@suse.com>
Thu, 20 Mar 2025 12:32:19 +0000 (13:32 +0100)
committerJan Beulich <jbeulich@suse.com>
Thu, 20 Mar 2025 12:32:19 +0000 (13:32 +0100)
Channels work differently than other device types: their devid should
be -1 initially in order to distinguish them from the primary console
which has the devid of 0.

So when parsing the channel configuration, use
ARRAY_EXTEND_INIT_NODEVID() in order to avoid overwriting the devid
set by libxl_device_channel_init().

Fixes: 3a6679634766 ("libxl: set channel devid when not provided by application")
Signed-off-by: Juergen Gross <jgross@suse.com>
Reviewed-by: Anthony PERARD <anthony.perard@vates.tech>
master commit: e1ccced4afe465d6541c5825a0f8d1b8f5fa4253
master date: 2025-03-05 16:37:37 +0100

tools/xl/xl_parse.c

index ed983200c3f812c0960c6b474c2715702e43df3b..fd140e74243d6c7dfc045c8273d73a88c6694514 100644 (file)
@@ -2368,8 +2368,9 @@ void parse_config_data(const char *config_source,
             char *path = NULL;
             int len;
 
-            chn = ARRAY_EXTEND_INIT(d_config->channels, d_config->num_channels,
-                                   libxl_device_channel_init);
+            chn = ARRAY_EXTEND_INIT_NODEVID(d_config->channels,
+                                            d_config->num_channels,
+                                            libxl_device_channel_init);
 
             split_string_into_string_list(buf, ",", &pairs);
             len = libxl_string_list_length(&pairs);