Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp661821pxb; Wed, 6 Oct 2021 12:40:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzVueEB/sXQHXvmGyonj4NR4XtSlsfVV7CpzP+Y9lJ69o0iplWmsfOLKVffaaFtxbv11yFZ X-Received: by 2002:a17:903:1103:b0:13e:ec6d:524a with SMTP id n3-20020a170903110300b0013eec6d524amr8330974plh.85.1633549208784; Wed, 06 Oct 2021 12:40:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633549208; cv=none; d=google.com; s=arc-20160816; b=OMtGbiT/SAcP3jFKSjk7SQf+m1MRXYotbini6EfCl+5zLNLJA1X6aZXgS2nTyc4fUZ QhbbZ7yQbOWuyCcuokNoQK92x8K1UoG3jnYl2rfgxObtX3dr8mFPGAx2LeH2YcfAHjYV OZG9r4xCYTNbpcsux8j5f1JWXpkD4JJia0iLkkecTxHDunCAOIt1iinxzhPSTGFBiY2M gOW7OJ+1ZdNvdEL3kFN3xA5V2xPb0yFSTJanZiE8FEO9zAHPmjBgRSscKkiRP7WA3PWS uLjvK/YTzthBRvQ5HTN5pUO0Uc1KOs/xtGw+VhY0rU6VxaKplbq7m5U/VTxzUzPDRTZT NOqA== 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=g366T6z/wDv+u0z2UhkHLqZZ67YI06zaB4um2FhnwRI=; b=pcb8gUq2ukTdhBnZi/7g3rHMUnkU+iOq3Mebo+qfc8hAXBG4Mi/8DY/25thxAtv7KC dleIhKFvbdJ9ocpjdS7J8x8nwZK2m+7YrGdSn11CgWxPbwvZmzLcqL/rtyo50C7m0Ovh UCWa56VIMVOTlL33z6AW5VuooIedh3c/ddPklJjjB1eo0iDdKvB/OdZipaxu9s422yep ZyPcXrgD3eBYW0tQbaeLX6e88NbL05SJQ08ja2v4l8FcrEJWdcEFKyvN/t7QsW9pljwD w7070aCTtGYorkShk1xbkOrZy8QPwwCsKVt+844X5xYF3+wLx85rwjIDo/25viqshK4g WL1g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=OCjckHmg; 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 q24si13122481plr.194.2021.10.06.12.39.54; Wed, 06 Oct 2021 12:40:08 -0700 (PDT) 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=OCjckHmg; 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 S239566AbhJFTkn (ORCPT + 99 others); Wed, 6 Oct 2021 15:40:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53838 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239471AbhJFTk2 (ORCPT ); Wed, 6 Oct 2021 15:40:28 -0400 Received: from mail-pf1-x42f.google.com (mail-pf1-x42f.google.com [IPv6:2607:f8b0:4864:20::42f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E06ECC061755 for ; Wed, 6 Oct 2021 12:38:34 -0700 (PDT) Received: by mail-pf1-x42f.google.com with SMTP id m14so3268520pfc.9 for ; Wed, 06 Oct 2021 12:38:34 -0700 (PDT) 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=g366T6z/wDv+u0z2UhkHLqZZ67YI06zaB4um2FhnwRI=; b=OCjckHmgVomhirlm4yoY3Ii16VFEkoGpnVb/rg7YeA9Sjs5pjK51XrAmhnZUCGbp1/ rLuw8BarUAEtec6v5IBx/bM9/4DYawTek70dpAnQIfVDm1gxpDPo6TSS0cBAAUyed0XI Qi1hDriSwrnO6jbb9hK30iPFf3toj4LokQlbA= 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=g366T6z/wDv+u0z2UhkHLqZZ67YI06zaB4um2FhnwRI=; b=AB/RFoKAYncp0Ld4iPEq1rjSsA8KS4YFgtIluhi6RYuwt9qNxfLSBlrgrj2d9opJsy VqtfCpjLoictyEL2RsNl6j9yN4ePgr1rnVndBeltMhuGmFsbRY9rEc6aY8nly0y4XvY0 uK4gdY3Yir1p/V6SyDrg4cPFbRQjZfyqKiXY92soxOcJrCVjVTsvxA2vGqW5uP4kfG5U ZaEkHz5V3GOlTm3rEPf6pcR8Oxalg6t9/nNpCa+iQX1ODDfkF1XQ5o8ZhQw6nOO71ytZ w5M+d4aKSz/M683Q+/df15mNKh7GgZaLa0hyBFpj4gLFUxi9da4FCTvX6kgTNv98r73W YyAA== X-Gm-Message-State: AOAM532TnY0NmgWGSoZTk0NqBeeuoS7jwJkZLINtYjHAvz/wHozk2hna iU8xFwRUVXqr0ewcNy9PSAPQIg== X-Received: by 2002:a63:2484:: with SMTP id k126mr420094pgk.297.1633549114473; Wed, 06 Oct 2021 12:38:34 -0700 (PDT) Received: from smtp.gmail.com ([2620:15c:202:201:d412:c5eb:4aca:4738]) by smtp.gmail.com with ESMTPSA id o14sm22011296pfh.84.2021.10.06.12.38.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 06 Oct 2021 12:38:34 -0700 (PDT) From: Stephen Boyd To: Greg Kroah-Hartman 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 v2 10/34] drm/armada: Migrate to aggregate driver Date: Wed, 6 Oct 2021 12:37:55 -0700 Message-Id: <20211006193819.2654854-11-swboyd@chromium.org> X-Mailer: git-send-email 2.33.0.800.g4c38ced690-goog In-Reply-To: <20211006193819.2654854-1-swboyd@chromium.org> References: <20211006193819.2654854-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..b3559363ea43 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 = adev->parent; 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 = adev->parent; 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