Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp758055pxb; Fri, 28 Jan 2022 09:19:18 -0800 (PST) X-Google-Smtp-Source: ABdhPJzbxKTXFRAjswKxZa7w32ac+++IZCFCBrX9127aD8wxVti3/ZMQZHas+Ek62ekEOIxj3f91 X-Received: by 2002:a17:902:d48e:: with SMTP id c14mr9780947plg.1.1643390357927; Fri, 28 Jan 2022 09:19:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643390357; cv=none; d=google.com; s=arc-20160816; b=fJ+CpFZkfP640Q10DIBf5Coh+XBXDyd/qDk9keZc3IutsjEZHtXNhgcpUaQh5dQ0C2 DB8/vKjLr0k4R0WVQDtDDh5MwNGWCTLoY9RbuPGpb4AIwdIydbgvvrrqCaJumqTnFj+x YD0c9ROtxLCyJQIyda+X8XRYYnW474fN1tmDkqxccgwbXVuT9ArwM2oRYbryzRygxX5v h8kkxI99fZazsKh7mQoRUZvkrLKhP0HD8z1do6POmAAerj6ecEl1KaFdl1w2/CO/BgYY cq9i/h1o4zqE3X7MtQH+FDKOOjZX51coLA03WTejc+7JzyRveTheliuD8hH2aC2SGNxD 3ESw== 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=ckuMr+Ncb/jcw9TvP8N13lANp/qUitpt+atxz271bCg=; b=wIyky2lBHOt2uJnh4LteApRyfJ1dU98Gr0OTj2K3MquwA0PmBPHtkKLsxgcxUegt41 hr4cGly92UGjKAmOvC05NS4gr4vwQ6nN7PHFccsSrmv9r9TUv8VWWRHZvYq7nAFyaBey F7K7gYGf5us1/fa1bXqkEA89yalj3jNb2Az3MU+A2ojtWn356vMloPKmQBM61gXa/Sye OMNZPhVTChfsdH406AcBHdXsrQdO7UqwhZRGugUCnbNPZ5b/b8cEteR1SwLoUGci/vbd yLXYq1r97FM2+M/+0xLYqcP4LqvGt4mRd+udN7UlNwqhwlrQUo3ok80aahL6jiJrwh69 nGsg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=VCDCJ2XX; 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 b23si5061542pls.7.2022.01.28.09.19.05; Fri, 28 Jan 2022 09:19:17 -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=VCDCJ2XX; 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 S1343773AbiA0UDM (ORCPT + 99 others); Thu, 27 Jan 2022 15:03:12 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43444 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343894AbiA0UCm (ORCPT ); Thu, 27 Jan 2022 15:02:42 -0500 Received: from mail-pg1-x52f.google.com (mail-pg1-x52f.google.com [IPv6:2607:f8b0:4864:20::52f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3A1DFC06177D for ; Thu, 27 Jan 2022 12:02:38 -0800 (PST) Received: by mail-pg1-x52f.google.com with SMTP id g2so3219055pgo.9 for ; Thu, 27 Jan 2022 12:02:38 -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=ckuMr+Ncb/jcw9TvP8N13lANp/qUitpt+atxz271bCg=; b=VCDCJ2XXoEo5R2boVBxoQIPLBYXRZ4ygF5m58BNpDlZWi0b2RKflooEmM0NvSKn47v M8K2o4X4DejnrnAjIJ9q3+1sECxzMIDHOFpFmOMgT91R+rXZdeyhn45ubWI9MY4y+lGt LQpRvpFof698nsHlX6PxiqwGND/FxZPe/vWmk= 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=ckuMr+Ncb/jcw9TvP8N13lANp/qUitpt+atxz271bCg=; b=RP8Ntov9hl6odgiIATU5ATORlm+TgnlQxlaEFXrZYoFbOtfiJPAVxdO+CSTuKKykCh 8Q635EEKiOl7p7lRATnIEV90ezNww/vjR0fG1G8CWW5SKHuAHhPMx6ikrLY1OTGov6n7 V5Vz279H+bPe2nQ4XECAq4Jtw30ClfhNyyGkEPri2Plq+CPvP/TJHcpLUzKPGBXfyEmZ BPgpxK63yu/NeGXceZO47vELEp9uk68OBBM1yZwi8oe9V2PaY0yckvC349zasiqRLOh/ MncKn71XSU/chzvXtvgWuM3DkabbqIt5nM/pci1ms6mk2qztZp3ks6X4TxRUN14lRVEl Hqrw== X-Gm-Message-State: AOAM530D0g8atGX2LJNGGAPFvQ4n9/a7YbgWVCII6f76YqGZ07gNhPDC o8/6JAzmlkq8dfOjKBpFDP2rEQ== X-Received: by 2002:a62:e116:: with SMTP id q22mr4473788pfh.48.1643313757782; Thu, 27 Jan 2022 12:02:37 -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.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 27 Jan 2022 12:02:37 -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, Heikki Krogerus , Daniel Vetter , "Rafael J. Wysocki" , Rob Clark , Russell King , Saravana Kannan Subject: [PATCH v6 32/35] usb: typec: port-mapper: Migrate to aggregate driver Date: Thu, 27 Jan 2022 12:01:38 -0800 Message-Id: <20220127200141.1295328-33-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: Heikki Krogerus Cc: Daniel Vetter Cc: "Rafael J. Wysocki" Cc: Rob Clark Cc: Russell King Cc: Saravana Kannan Signed-off-by: Stephen Boyd --- drivers/usb/typec/port-mapper.c | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/drivers/usb/typec/port-mapper.c b/drivers/usb/typec/port-mapper.c index 07d307418b47..33fbebc6a85b 100644 --- a/drivers/usb/typec/port-mapper.c +++ b/drivers/usb/typec/port-mapper.c @@ -11,19 +11,27 @@ #include "class.h" -static int typec_aggregate_bind(struct device *dev) +static int typec_aggregate_probe(struct aggregate_device *adev) { + struct device *dev = aggregate_device_parent(adev); + return component_bind_all(dev, NULL); } -static void typec_aggregate_unbind(struct device *dev) +static void typec_aggregate_remove(struct aggregate_device *adev) { + struct device *dev = aggregate_device_parent(adev); + component_unbind_all(dev, NULL); } -static const struct component_master_ops typec_aggregate_ops = { - .bind = typec_aggregate_bind, - .unbind = typec_aggregate_unbind, +static struct aggregate_driver typec_aggregate_driver = { + .probe = typec_aggregate_probe, + .remove = typec_aggregate_remove, + .driver = { + .name = "typec_aggregate", + .owner = THIS_MODULE, + }, }; struct each_port_arg { @@ -69,10 +77,10 @@ int typec_link_ports(struct typec_port *con) * improvements to the component framework. Right now you can only have * one master per device. */ - return component_master_add_with_match(&con->dev, &typec_aggregate_ops, arg.match); + return component_aggregate_register(&con->dev, &typec_aggregate_driver, arg.match); } void typec_unlink_ports(struct typec_port *con) { - component_master_del(&con->dev, &typec_aggregate_ops); + component_aggregate_unregister(&con->dev, &typec_aggregate_driver); } -- https://chromeos.dev