From f0d59b078bafe20709df5477e65b3e4ad7040316 Mon Sep 17 00:00:00 2001 From: Xaver Hugl Date: Sun, 24 Jul 2022 00:05:04 +0200 Subject: [PATCH] backends/drm: explicitly initialize all fields of drmModeModeInfo --- src/backends/drm/drm_object_connector.cpp | 28 ++++++++++++----------- 1 file changed, 15 insertions(+), 13 deletions(-) diff --git a/src/backends/drm/drm_object_connector.cpp b/src/backends/drm/drm_object_connector.cpp index 7497182a9f..179ea104dd 100644 --- a/src/backends/drm/drm_object_connector.cpp +++ b/src/backends/drm/drm_object_connector.cpp @@ -445,20 +445,22 @@ std::shared_ptr DrmConnector::generateMode(const QSize &size, { auto modeInfo = libxcvt_gen_mode_info(size.width(), size.height(), refreshRate, false, false); - drmModeModeInfo mode; - mode.vdisplay = modeInfo->vdisplay; - mode.hdisplay = modeInfo->hdisplay; - mode.clock = modeInfo->dot_clock; - mode.hsync_start = modeInfo->hsync_start; - mode.hsync_end = modeInfo->hsync_end; - mode.htotal = modeInfo->htotal; - mode.vsync_start = modeInfo->vsync_start; - mode.vsync_end = modeInfo->vsync_end; - mode.vtotal = modeInfo->vtotal; - mode.vrefresh = modeInfo->vrefresh; - mode.flags = modeInfo->mode_flags; + drmModeModeInfo mode{ + .clock = uint32_t(modeInfo->dot_clock), + .hdisplay = uint16_t(modeInfo->hdisplay), + .hsync_start = modeInfo->hsync_start, + .hsync_end = modeInfo->hsync_end, + .htotal = modeInfo->htotal, + .vdisplay = uint16_t(modeInfo->vdisplay), + .vsync_start = modeInfo->vsync_start, + .vsync_end = modeInfo->vsync_end, + .vtotal = modeInfo->vtotal, + .vscan = 1, + .vrefresh = uint32_t(modeInfo->vrefresh), + .flags = modeInfo->mode_flags, + .type = DRM_MODE_TYPE_USERDEF, + }; - mode.type = DRM_MODE_TYPE_USERDEF; sprintf(mode.name, "%dx%d@%d", size.width(), size.height(), mode.vrefresh); free(modeInfo);