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 BF4F7CAC5BB for ; Wed, 8 Oct 2025 12:04:44 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 1E52B10E7E2; Wed, 8 Oct 2025 12:04:44 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (2048-bit key; unprotected) header.d=kernel.org header.i=@kernel.org header.b="EYb/Mjop"; 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 4A09610E7F2; Wed, 8 Oct 2025 12:04:43 +0000 (UTC) Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by tor.source.kernel.org (Postfix) with ESMTP id BFF3C61F89; Wed, 8 Oct 2025 12:04:42 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 22037C4CEF5; Wed, 8 Oct 2025 12:04:41 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1759925082; bh=dQpb2inAQE2qi53VS4O7rZWQ0ePvv4XDjSAml3tTFxM=; h=From:Date:Subject:References:In-Reply-To:To:Cc:From; b=EYb/Mjopp05tLsacamO4L4ckBNGXM/zxqJdMW82uEnfE5VJBmrSd2ilqLJAST+uu/ R3tacZ3fEJQ4pFb7h+y6us8JUOtofSIML7g2Z5J5rsr514Bhoq3Lah9xogLd3ymt3l BPbfmu2A6TU5xZgcRrmYN/A9qhtciLn+HfwCZWtbp3jHFAHLcv388usGSVeRdflqJ2 HLGUYqvrPvrbvRvHINI0M4wepDY/qjBg4oL/1NkbXOnPE7tdAHfNit3Q1Q3WVWqh6z StHby/emEtsZ/ZWWZdMRAnnhHARPplDh8JUxhKdwEBBiLvisN85SAipq1yneVnSXyb ubmdipKrWa3gQ== From: Maxime Ripard Date: Wed, 08 Oct 2025 14:04:08 +0200 Subject: [PATCH 10/16] drm/msm: mdp5: Switch private_obj initialization to reset MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Message-Id: <20251008-drm-private-obj-reset-v1-10-805ab43ae65a@kernel.org> References: <20251008-drm-private-obj-reset-v1-0-805ab43ae65a@kernel.org> In-Reply-To: <20251008-drm-private-obj-reset-v1-0-805ab43ae65a@kernel.org> To: Maarten Lankhorst , Thomas Zimmermann , David Airlie , Simona Vetter Cc: dri-devel@lists.freedesktop.org, Maxime Ripard , Rob Clark , Dmitry Baryshkov , Abhinav Kumar , Jessica Zhang , Sean Paul , Marijn Suijten , linux-arm-msm@vger.kernel.org, freedreno@lists.freedesktop.org X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=2925; i=mripard@kernel.org; h=from:subject:message-id; bh=dQpb2inAQE2qi53VS4O7rZWQ0ePvv4XDjSAml3tTFxM=; b=owGbwMvMwCmsHn9OcpHtvjLG02pJDBnPgs3vf1fr+j01PUXxiu/0XXHhZzd+ztVJ8L7xbv+Cb KUqqavRHVNZGIQ5GWTFFFmeyISdXt6+uMrBfuUPmDmsTCBDGLg4BWAi1g2MDZcK66wfiZ2p0Jj6 +dPk06b65Z3Ho71VbHxa9PwDhOoXFzww3mrYMed51syNNU80j+45xljF5NawaUoe0/RPyQoL4i5 zM4a0d1umCK7smdi6sPbjvSIm2+Nz3n6Mk+h+0HbhWajljVAA 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 MSM mdp5 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 reset implementation, let's migrate this instance to the new pattern. Signed-off-by: Maxime Ripard --- Cc: Rob Clark Cc: Dmitry Baryshkov Cc: Abhinav Kumar Cc: Jessica Zhang Cc: Sean Paul Cc: Marijn Suijten Cc: linux-arm-msm@vger.kernel.org Cc: freedreno@lists.freedesktop.org --- drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c | 31 ++++++++++++++++++++++--------- 1 file changed, 22 insertions(+), 9 deletions(-) diff --git a/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c b/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c index 5b6ca8dd929e1870b7228af93da03886524f5f20..44aef7eb8e9073bc9a4bab03c1d6c41313c56ac7 100644 --- a/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c +++ b/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c @@ -112,10 +112,30 @@ static void mdp5_global_destroy_state(struct drm_private_obj *obj, struct mdp5_global_state *mdp5_state = to_mdp5_global_state(state); kfree(mdp5_state); } +static void mdp5_global_reset(struct drm_private_obj *obj) +{ + struct drm_device *dev = obj->dev; + struct msm_drm_private *priv = dev->dev_private; + struct mdp5_kms *mdp5_kms = to_mdp5_kms(to_mdp_kms(priv->kms)); + struct mdp5_global_state *mdp5_state; + + if (obj->state) { + mdp5_global_destroy_state(obj, obj->state); + obj->state = NULL; + } + + mdp5_state = kzalloc(sizeof(*mdp5_state), GFP_KERNEL); + if (!mdp5_state) + return; + + __drm_atomic_helper_private_obj_reset(obj, &mdp5_state->base); + mdp5_state->mdp5_kms = mdp5_kms; +} + static void mdp5_global_print_state(struct drm_printer *p, const struct drm_private_state *state) { struct mdp5_global_state *mdp5_state = to_mdp5_global_state(state); @@ -125,24 +145,17 @@ static void mdp5_global_print_state(struct drm_printer *p, static const struct drm_private_state_funcs mdp5_global_state_funcs = { .atomic_duplicate_state = mdp5_global_duplicate_state, .atomic_destroy_state = mdp5_global_destroy_state, .atomic_print_state = mdp5_global_print_state, + .reset = mdp5_global_reset, }; static int mdp5_global_obj_init(struct mdp5_kms *mdp5_kms) { - struct mdp5_global_state *state; - - state = kzalloc(sizeof(*state), GFP_KERNEL); - if (!state) - return -ENOMEM; - - state->mdp5_kms = mdp5_kms; - drm_atomic_private_obj_init(mdp5_kms->dev, &mdp5_kms->glob_state, - &state->base, + NULL, &mdp5_global_state_funcs); return 0; } static void mdp5_enable_commit(struct msm_kms *kms) -- 2.51.0