From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mgamail.intel.com (mgamail.intel.com [192.198.163.13]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 24A213E6390 for ; Tue, 5 May 2026 07:57:33 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=192.198.163.13 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777967856; cv=none; b=i+KrykmYdDpei7KvGd5Cj3xWyo6K/QrDLOOcQHsMqk0BQJG824tsYYT3P/iGAfX1DfErUCmdQzx2oyDSOjFPxJhovoztD2i98t6EW06AumFMUqpXWbagr4DpSbiGZXDXm9k+jL6b00XN8YrSybIlaGWkZ5jQ9mJT01/JUdQ0QKI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777967856; c=relaxed/simple; bh=NCB3YHmAvYTnstuCXubY2SrRns6dsmu8xcOHwMldl+4=; h=From:To:Cc:Subject:In-Reply-To:References:Date:Message-ID: MIME-Version:Content-Type; b=hpxYJOHwEow6vz4QyhXHOtQQjkio4qbt4JdfKxgSQgDVqtEZpKew1WIw0nCAWqLE41fYaRMoXwWgqtjAAaoDVfrNiY2bn+Yxg2lqG8Z6Tod7PFz1PGn1pfnCxY+cUw1nfr3R4It99b8bd+rrj58WxBCtV6wXQmNbCpCLUpnM1/4= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linux.intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=h6V8pNxE; arc=none smtp.client-ip=192.198.163.13 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linux.intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="h6V8pNxE" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1777967853; x=1809503853; h=from:to:cc:subject:in-reply-to:references:date: message-id:mime-version; bh=NCB3YHmAvYTnstuCXubY2SrRns6dsmu8xcOHwMldl+4=; b=h6V8pNxEJXtn3PERzhAQ2F3lWEi6O+H+VrtWkOQeY6c0gu1tNS3NN8cr zIJu0VCowxfI0/oUgNS+FjpsfqNg2FhJaGVChiDXoX+GTF1y0MwR3wm/N H6QEuMRvEwUh6PXWTZckyhsbv09Hs0oL783NhYHjcIYRK4edckjOy/e03 RkQnjsC6IagfZdAO5cf/oNkAnEdiPSROGB+1OGS59T1zVSEX9/5HaO9cj XIup3oO1QugATKf8tWiyHapkWX5Hzm0pEp6r0Jb5JYXE1nrR2lphrQEsD rSUn38OpUIDLegqbR3dsD9FELWynb4sP4QxEdQ6aTixRzW4WpZQ5x6FQz Q==; X-CSE-ConnectionGUID: W1qtaYU6Rpa2NRuK5jIlCQ== X-CSE-MsgGUID: tcelQH+KQo6bxrfWV1T9kw== X-IronPort-AV: E=McAfee;i="6800,10657,11776"; a="81394512" X-IronPort-AV: E=Sophos;i="6.23,217,1770624000"; d="scan'208";a="81394512" Received: from orviesa009.jf.intel.com ([10.64.159.149]) by fmvoesa107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 May 2026 00:57:32 -0700 X-CSE-ConnectionGUID: tAcso0lWSneBXzKqH2ziPw== X-CSE-MsgGUID: knr+IUz/TYyhWvQH1gQd6g== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.23,217,1770624000"; d="scan'208";a="235825491" Received: from amilburn-desk.amilburn-desk (HELO localhost) ([10.245.244.55]) by orviesa009-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 May 2026 00:57:29 -0700 From: Jani Nikula To: Leandro Ribeiro , dri-devel@lists.freedesktop.org Cc: airlied@gmail.com, daniels@collabora.com, maarten.lankhorst@linux.intel.com, mripard@kernel.org, pekka.paalanen@collabora.com, simona@ffwll.ch, tzimmermann@suse.de, ville.syrjala@linux.intel.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 2/2] drm: ensure blend mode supported if alpha exposed In-Reply-To: <20260504140630.68707-3-leandro.ribeiro@collabora.com> Organization: Intel Finland Oy - BIC 0357606-4 - c/o Alberga Business Park, 6 krs Bertel Jungin Aukio 5, 02600 Espoo, Finland References: <20260504140630.68707-1-leandro.ribeiro@collabora.com> <20260504140630.68707-3-leandro.ribeiro@collabora.com> Date: Tue, 05 May 2026 10:57:26 +0300 Message-ID: Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain On Mon, 04 May 2026, Leandro Ribeiro wrote: > Before "drm/drm_blend: allow blend mode property without PREMULTI", > userspace would have to assume that only PREMULTI was supported by > drivers that didn't expose the blend mode property. But now userspace > shouldn't relly on that, as they can't count with drivers always > supporting PREMULTI. > > Error out if a driver expose alpha property or pixel formats with alpha > and does not expose the blend mode property. This way userspace don't > have to guess. Drivers that hit such error must be fixed. > > Signed-off-by: Leandro Ribeiro > --- > drivers/gpu/drm/drm_crtc_internal.h | 1 + > drivers/gpu/drm/drm_drv.c | 7 ++++- > drivers/gpu/drm/drm_mode_config.c | 42 +++++++++++++++++++++++++++++ > 3 files changed, 49 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/drm_crtc_internal.h b/drivers/gpu/drm/drm_crtc_internal.h > index c09409229644..bdbb6b9b94ea 100644 > --- a/drivers/gpu/drm/drm_crtc_internal.h > +++ b/drivers/gpu/drm/drm_crtc_internal.h > @@ -96,6 +96,7 @@ int drm_mode_setcrtc(struct drm_device *dev, > int drm_modeset_register_all(struct drm_device *dev); > void drm_modeset_unregister_all(struct drm_device *dev); > void drm_mode_config_validate(struct drm_device *dev); > +int drm_mode_config_enforce(struct drm_device *dev); > > /* drm_modes.c */ > const char *drm_get_mode_status_name(enum drm_mode_status status); > diff --git a/drivers/gpu/drm/drm_drv.c b/drivers/gpu/drm/drm_drv.c > index 985c283cf59f..76766a370650 100644 > --- a/drivers/gpu/drm/drm_drv.c > +++ b/drivers/gpu/drm/drm_drv.c > @@ -1059,9 +1059,14 @@ int drm_dev_register(struct drm_device *dev, unsigned long flags) > const struct drm_driver *driver = dev->driver; > int ret; > > - if (!driver->load) > + if (!driver->load) { > drm_mode_config_validate(dev); > > + ret = drm_mode_config_enforce(dev); Reading the code, I'll have no idea what "enforce" means here. Reading the function itself isn't helping either. BR, Jani. > + if (ret) > + return ret; > + } > + > WARN_ON(!dev->managed.final_kfree); > > if (drm_dev_needs_global_mutex(dev)) > diff --git a/drivers/gpu/drm/drm_mode_config.c b/drivers/gpu/drm/drm_mode_config.c > index 66f7dc37b597..20fd26ecb957 100644 > --- a/drivers/gpu/drm/drm_mode_config.c > +++ b/drivers/gpu/drm/drm_mode_config.c > @@ -738,3 +738,45 @@ void drm_mode_config_validate(struct drm_device *dev) > "Must have as many primary planes as there are CRTCs, but have %u primary planes and %u CRTCs", > num_primary, dev->mode_config.num_crtc); > } > + > +static int plane_require_blend_mode_for_alpha(struct drm_plane *plane) > +{ > + struct drm_device *dev = plane->dev; > + const struct drm_format_info *fmt; > + u32 i; > + > + /* blend mode property supported, no need to check anything */ > + if (plane->blend_mode_property) > + return 0; > + > + if (plane->alpha_property) { > + drm_err(dev, "[PLANE:%d:%s] alpha property exposed but blend mode not setup", > + plane->base.id, plane->name); > + return -EINVAL; > + } > + > + for (i = 0; i < plane->format_count; i++) { > + fmt = drm_format_info(plane->format_types[i]); > + if (fmt->has_alpha) { > + drm_err(dev, "[PLANE:%d:%s] pixel format with alpha exposed but blend mode not setup", > + plane->base.id, plane->name); > + return -EINVAL; > + } > + } > + > + return 0; > +} > + > +int drm_mode_config_enforce(struct drm_device *dev) > +{ > + struct drm_plane *plane; > + int ret; > + > + drm_for_each_plane(plane, dev) { > + ret = plane_require_blend_mode_for_alpha(plane); > + if (ret) > + return ret; > + } > + > + return 0; > +} -- Jani Nikula, Intel