From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 69AA8F3C9AC for ; Tue, 24 Feb 2026 16:10:49 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id C6CD910E5D2; Tue, 24 Feb 2026 16:10:48 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (2048-bit key; unprotected) header.d=kernel.org header.i=@kernel.org header.b="NF0SFbZj"; dkim-atps=neutral Received: from tor.source.kernel.org (tor.source.kernel.org [172.105.4.254]) by gabe.freedesktop.org (Postfix) with ESMTPS id CD2DE10E5D2 for ; Tue, 24 Feb 2026 16:10:44 +0000 (UTC) Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by tor.source.kernel.org (Postfix) with ESMTP id 4C46A6111B; Tue, 24 Feb 2026 16:10:44 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 9CEC2C19422; Tue, 24 Feb 2026 16:10:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1771949444; bh=h8cVjJ4PhHPG05vRMcMBUdaJ853tii2+rF35JscCHXc=; h=From:Date:Subject:References:In-Reply-To:To:Cc:From; b=NF0SFbZjnt6ZrEZrPMsQZ42B91LO7TFQi+qwEohgjWZCHEDnbHAT28WcPr8zbEhUf rOL6eOodNvNs5uSbnN/DwpmUx2Wsijads1LJDueNfwhecb77Smi9uzQqv4Qe1aDrEl lNY0LIvYc/nx1zok3TTySfB8o71kBrjPqXelU1dKLalO57CRxcwA+XPPbJ0m17zPOg MtRkkri5Eivw7x8g8h3BD6CHzuXKQBfH5XZynZrlG50QBpz6+p3Ni2FDMomEXgO3pN ru/FuMqKQ2/FZBbAaBsl5qdEr1DEFvI9YFQBxxQy6jbVTBOo1BT+gmj63Hw2jr/eJU pHiRjE+cDHszg== From: Maxime Ripard Date: Tue, 24 Feb 2026 17:10:27 +0100 Subject: [PATCH v5 2/4] drm/omapdrm: Switch private_obj initialization to atomic_create_state MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Message-Id: <20260224-drm-private-obj-reset-v5-2-5a72f8ec9934@kernel.org> References: <20260224-drm-private-obj-reset-v5-0-5a72f8ec9934@kernel.org> In-Reply-To: <20260224-drm-private-obj-reset-v5-0-5a72f8ec9934@kernel.org> To: Maarten Lankhorst , Thomas Zimmermann , David Airlie , Simona Vetter Cc: dri-devel@lists.freedesktop.org, Maxime Ripard , Tomi Valkeinen X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=2099; i=mripard@kernel.org; h=from:subject:message-id; bh=h8cVjJ4PhHPG05vRMcMBUdaJ853tii2+rF35JscCHXc=; b=owGbwMvMwCmsHn9OcpHtvjLG02pJDJlzz1alz18jspDpt+R0X9MffVblrOZOc08Efj86uyozx +Lm/ItmHVNZGIQ5GWTFFFmeyISdXt6+uMrBfuUPmDmsTCBDGLg4BWAihecZG74H7iureuY/L7Xe d5XiyvzqHZsqp5tXHKz/5BYaY6K3ZYqJo4fVxmUXppyTXv94RmbJA8aG9nOzq5ltS68XXMvkL5v 7+fIjvYxTs/3fTRbxkq/Y07DmpcwNLrM+/73pk+fvS58sJ5IGAA== X-Developer-Key: i=mripard@kernel.org; a=openpgp; fpr=BE5675C37E818C8B5764241C254BCFC56BF6CE8D X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" The omapdrm driver relies on a drm_private_obj, that is initialized by allocating and initializing a state, and then passing it to drm_private_obj_init. Since we're gradually moving away from that pattern to the more established one relying on a atomic_create_state implementation, let's migrate this instance to the new pattern. Signed-off-by: Maxime Ripard --- Cc: Tomi Valkeinen --- drivers/gpu/drm/omapdrm/omap_drv.c | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/drivers/gpu/drm/omapdrm/omap_drv.c b/drivers/gpu/drm/omapdrm/omap_drv.c index bf0bad8c8cf120baa124b439f3fcbfe36c976d12..90832b4b8c9dd540c8778cb39de7cf80e8796857 100644 --- a/drivers/gpu/drm/omapdrm/omap_drv.c +++ b/drivers/gpu/drm/omapdrm/omap_drv.c @@ -273,25 +273,35 @@ static void omap_global_destroy_state(struct drm_private_obj *obj, struct omap_global_state *omap_state = to_omap_global_state(state); kfree(omap_state); } +static struct drm_private_state * +omap_global_atomic_create_state(struct drm_private_obj *obj) +{ + struct omap_global_state *state; + + state = kzalloc_obj(*state); + if (!state) + return ERR_PTR(-ENOMEM); + + __drm_atomic_helper_private_obj_create_state(obj, &state->base); + + return &state->base; +} + static const struct drm_private_state_funcs omap_global_state_funcs = { + .atomic_create_state = omap_global_atomic_create_state, .atomic_duplicate_state = omap_global_duplicate_state, .atomic_destroy_state = omap_global_destroy_state, }; static int omap_global_obj_init(struct drm_device *dev) { struct omap_drm_private *priv = dev->dev_private; - struct omap_global_state *state; - state = kzalloc_obj(*state); - if (!state) - return -ENOMEM; - - drm_atomic_private_obj_init(dev, &priv->glob_obj, &state->base, + drm_atomic_private_obj_init(dev, &priv->glob_obj, NULL, &omap_global_state_funcs); return 0; } static void omap_global_obj_fini(struct omap_drm_private *priv) -- 2.52.0