Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp757519pxb; Fri, 28 Jan 2022 09:18:44 -0800 (PST) X-Google-Smtp-Source: ABdhPJxq5Qa4fkbSS6tmCDA2wK2zerSt8gXdbwS25Sm8FoABdyqp95DRG8gqNajM/0aIOA6DhsVj X-Received: by 2002:a17:902:f782:: with SMTP id q2mr9313380pln.81.1643390324751; Fri, 28 Jan 2022 09:18:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643390324; cv=none; d=google.com; s=arc-20160816; b=rxw8L8o9KW4qAFZJKV89n3ClvhP5I6w3Unx0jm3DTEo7gduj0IOc69gh/eTMPv9tCW AwUSqEzwBQ5AxpFGZAdOTEmn1x1w7JKBo2rAFvqthrmypbcEBu0sBc0mHQINlwR/Ah3u /4ibyZO33y61KnQ9eyOvGUBi613kZueuomaJ9tIJZz4L/OknqA3LycTmKKqWBN8zkcPL q77UwSeik6TmB3Jgz6jFIqg+6Lpyv9K5d3f6UFa4+xORj7i7cMvG4+mDIIVCERLKvsNd xdBc8wmUWKa+uljvOd44NdlyzzAZBU+miudSwQXIdDWyyQK2BuxIS9cTUPadjercGT96 dqdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=GBNCJskYdXfAX+d+IFXzB6ZhhAWcTNbUgQAvepRmgjg=; b=q4K43Aj+3Esx8BMTxLQ5gdMkAsWm5dvLAXMqrNaj6uc0ZGWw6yM3hns/6Bczvg6Kwb x8dX917rNPyZsVGsPWXez2E8vP+W2ZyuyNzYTEhF7XeiTf1YVXt03ipbZx2JWAGt2Kp3 OVqi5w5sDqxPEKyH+PkYEPm8ou06LZ2C+QjtF72YgKxEB7NssF4RFakec7kJeGZfPY0x VQacCYu7NRirvZoTERA1rvmsK1/8FbWwdG1+blDWcj3KXQSyJZF0RED0HNvHr9oR5uh0 Vb404rBIQDQmgL1trN2hcwZLcdqBuxpJJS0KB0Odcmqyuf5v72uZBDk+Dh4gWj/FbKaB WPiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=IxzF42Bj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l4si5542747pgu.185.2022.01.28.09.18.32; Fri, 28 Jan 2022 09:18:44 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=IxzF42Bj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1343653AbiA0UCK (ORCPT + 99 others); Thu, 27 Jan 2022 15:02:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43200 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343646AbiA0UCI (ORCPT ); Thu, 27 Jan 2022 15:02:08 -0500 Received: from mail-pg1-x52b.google.com (mail-pg1-x52b.google.com [IPv6:2607:f8b0:4864:20::52b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 155FBC06173B for ; Thu, 27 Jan 2022 12:02:08 -0800 (PST) Received: by mail-pg1-x52b.google.com with SMTP id e16so3238366pgn.4 for ; Thu, 27 Jan 2022 12:02:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=GBNCJskYdXfAX+d+IFXzB6ZhhAWcTNbUgQAvepRmgjg=; b=IxzF42BjOO2pquMk+0gv8AzrZphAavGJ0aSqJSR5mXo5r+dj56dPmYBUR0QILo7roS IXbnzV04OSgJkuxMxw54ooixm26YyHaYSuds9oMqzxbEb4y68B4fLJ0gM/lxcXafBprZ CSnK/dN9IGo4ps4eOLhOUWlUi5F2xJhNpB2K0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=GBNCJskYdXfAX+d+IFXzB6ZhhAWcTNbUgQAvepRmgjg=; b=frU0ZHtabkatuZn9trI20T8OMPuNgIy7zyV8smOWYYN+8bIm7keQg6/SiYki9fmC3x D7zUtXf7LUaSz9VAiX6risfIqFlAwmb1l/VJeD/OnC5bvLZ1KfQC4lxcUUF4TO/CEYmM aH8KXCTk9hP0V8TIbyzIE7B6oaMKIqDGpoZlP3CopdtGfHLxOSXBmfECLy7ESmJnybXC +VMMsG86/JX2UJKiNfEo9U8VUi88mFGs2UB7wTEtYxxz0FGah1ezTsSh0PCTtrMbZHYH fhyt62lVbWDpkJ54SksCyhfY6lvZDOeyndpANmZYCSBr3ufHPtluAArL6RgyNnSjCi+e LxpA== X-Gm-Message-State: AOAM533UiwwYq42Qsg4Vu/Bqi2fTjtoAPOlSdCv0vijw2lhd0gBMPCCd 2sXI+XCfurjJBTChhvyQqjNguw== X-Received: by 2002:a62:e409:: with SMTP id r9mr4463825pfh.44.1643313727593; Thu, 27 Jan 2022 12:02:07 -0800 (PST) Received: from smtp.gmail.com ([2620:15c:202:201:9246:1838:3243:3071]) by smtp.gmail.com with ESMTPSA id k21sm6561190pff.33.2022.01.27.12.02.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 27 Jan 2022 12:02:07 -0800 (PST) From: Stephen Boyd To: Greg Kroah-Hartman , Douglas Anderson Cc: linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, dri-devel@lists.freedesktop.org, freedreno@lists.freedesktop.org, Russell King , Daniel Vetter , "Rafael J. Wysocki" , Rob Clark , Saravana Kannan Subject: [PATCH v6 10/35] drm/armada: Migrate to aggregate driver Date: Thu, 27 Jan 2022 12:01:16 -0800 Message-Id: <20220127200141.1295328-11-swboyd@chromium.org> X-Mailer: git-send-email 2.35.0.rc0.227.g00780c9af4-goog In-Reply-To: <20220127200141.1295328-1-swboyd@chromium.org> References: <20220127200141.1295328-1-swboyd@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use an aggregate driver instead of component ops so that we can get proper driver probe ordering of the aggregate device with respect to all the component devices that make up the aggregate device. Cc: Russell King Cc: Daniel Vetter Cc: "Rafael J. Wysocki" Cc: Rob Clark Cc: Saravana Kannan Signed-off-by: Stephen Boyd --- drivers/gpu/drm/armada/armada_drv.c | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/drivers/gpu/drm/armada/armada_drv.c b/drivers/gpu/drm/armada/armada_drv.c index 8e3e98f13db4..27739cbe2291 100644 --- a/drivers/gpu/drm/armada/armada_drv.c +++ b/drivers/gpu/drm/armada/armada_drv.c @@ -60,8 +60,9 @@ static const struct drm_mode_config_funcs armada_drm_mode_config_funcs = { .atomic_commit = drm_atomic_helper_commit, }; -static int armada_drm_bind(struct device *dev) +static int armada_drm_bind(struct aggregate_device *adev) { + struct device *dev = aggregate_device_parent(adev); struct armada_private *priv; struct resource *mem = NULL; int ret, n; @@ -159,8 +160,9 @@ static int armada_drm_bind(struct device *dev) return ret; } -static void armada_drm_unbind(struct device *dev) +static void armada_drm_unbind(struct aggregate_device *adev) { + struct device *dev = aggregate_device_parent(adev); struct drm_device *drm = dev_get_drvdata(dev); struct armada_private *priv = drm_to_armada_dev(drm); @@ -202,9 +204,13 @@ static void armada_add_endpoints(struct device *dev, } } -static const struct component_master_ops armada_master_ops = { - .bind = armada_drm_bind, - .unbind = armada_drm_unbind, +static struct aggregate_driver armada_aggregate_driver = { + .probe = armada_drm_bind, + .remove = armada_drm_unbind, + .driver = { + .name = "armada_drm", + .owner = THIS_MODULE, + }, }; static int armada_drm_probe(struct platform_device *pdev) @@ -213,7 +219,7 @@ static int armada_drm_probe(struct platform_device *pdev) struct device *dev = &pdev->dev; int ret; - ret = drm_of_component_probe(dev, compare_dev_name, &armada_master_ops); + ret = drm_of_aggregate_probe(dev, compare_dev_name, &armada_aggregate_driver); if (ret != -EINVAL) return ret; @@ -240,13 +246,12 @@ static int armada_drm_probe(struct platform_device *pdev) } } - return component_master_add_with_match(&pdev->dev, &armada_master_ops, - match); + return component_aggregate_register(&pdev->dev, &armada_aggregate_driver, match); } static int armada_drm_remove(struct platform_device *pdev) { - component_master_del(&pdev->dev, &armada_master_ops); + component_aggregate_unregister(&pdev->dev, &armada_aggregate_driver); return 0; } -- https://chromeos.dev