Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp679790rwb; Thu, 22 Sep 2022 05:14:02 -0700 (PDT) X-Google-Smtp-Source: AMsMyM7BslUaoq7igFTwolzgM1efdJVTftitcYO73vnUStrOViA+qrStKS8mQkPZ5gkOLADzd3uD X-Received: by 2002:a17:90b:3903:b0:202:affa:1c9f with SMTP id ob3-20020a17090b390300b00202affa1c9fmr3490546pjb.27.1663848842261; Thu, 22 Sep 2022 05:14:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663848842; cv=none; d=google.com; s=arc-20160816; b=fYcDmwN1gkCISD53oUFMD/DACUiIuHOqUzJ/isocF9m2P4MaKOwCirl8wOptszf9su fwZNMuKYoTNKWLekidkEDWWrM4vxiAAFjyqWjwC/yUcYJ9W48Q8UjUHNxigdSb/DOy3r XNUq49aFzxBT8J5e45p/4Y/iCN6VJTsU15c2ScYueuW2Tv8ev8UT9dtIXfqc1OI01XSM GyLIUpZlH5VEOCZyJ5IlrHbpXm93H+QaHp7qK2OogK/pmM+i1gDDB5dFVpxWcuhLVr0M doUOcQyS6So+wwbtZUk+JeFXp7KbRp5k4aM4FbImz4LPOBFqe2zEJWHmg0Reo6EXKbF4 s35w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=m/mVzhBb5em9/wOJQrl//hSj9IQUXAYMyIG16nGH6wA=; b=mA040ZU144k1iohjdmgbclcAA4tCAHFxJXJHBtpbLsvN7Biro2exW9q7GIA3HXDmKM tT6e51wTMjpL/cz69+7JEkiRH8ugOTSU0Ri8sisc7gq+4bWIAVgVAbF3kgGyXmOd3leo vVDlnGrIKeVsySdubsB7FuyAZh65cfPb3gLkjXnwf9yVbC/oGj8Xbhw0OV3sYA+2leIo gP7cWpdxvRK7xC8z/FFNAYQJk72UzxxfF2Ct7s50/438/rzn5zKHzmt4KNQvCbVL9AC+ GTXs85bvQo2zINuWKs0eOGuaoe3F6TMj/E6vCyEf0lfkAJFCICqQu/Yj5b5y86bFz5pZ 89NQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=JXmlWq7i; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 26-20020a63175a000000b0043a061cc079si5933891pgx.358.2022.09.22.05.13.50; Thu, 22 Sep 2022 05:14:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=JXmlWq7i; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229489AbiIVLPA (ORCPT + 99 others); Thu, 22 Sep 2022 07:15:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58388 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231486AbiIVLOv (ORCPT ); Thu, 22 Sep 2022 07:14:51 -0400 Received: from mga03.intel.com (mga03.intel.com [134.134.136.65]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C28D8DE0D4 for ; Thu, 22 Sep 2022 04:14:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1663845266; x=1695381266; h=date:from:to:cc:subject:message-id:references: mime-version:in-reply-to; bh=i5JTykQjkQrnv8/srjhrjiQdqD23bv6meNMcD41b40Y=; b=JXmlWq7iEiddEWAV6bLmuZAeQQ1FatDtXALu6AawT6SpnepjRVBkc+sP pc1eW44Z/LdNUnNRrcHh+pWjEqhnSP2lupeRsDgdGB8nxBJt4KN2wYgci SQQQ5lFy1TsATbCtRO5e7DzcXKvZIvJbt7gG+ytVnHvxO0Ga1mirOqQcR fEnDfwnMkyPCF5EcE6T+vMH65QS0LNmGFNHPiLq/H6OQ/v3z/TscEBMaY +hd0r1CB906kYQXjL+F8luf5+6UixBzo/KOx9n2VnuWYUoImlG/plL/Yi 7y7dkgLByOJN7MhO7e4RtPRtgte9nf7aosvEaO7OJyiDOf2C7AwjijVkU Q==; X-IronPort-AV: E=McAfee;i="6500,9779,10477"; a="301677556" X-IronPort-AV: E=Sophos;i="5.93,335,1654585200"; d="scan'208";a="301677556" Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Sep 2022 04:14:19 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.93,335,1654585200"; d="scan'208";a="762144417" Received: from kuha.fi.intel.com ([10.237.72.185]) by fmsmga001.fm.intel.com with SMTP; 22 Sep 2022 04:14:16 -0700 Received: by kuha.fi.intel.com (sSMTP sendmail emulation); Thu, 22 Sep 2022 14:14:15 +0300 Date: Thu, 22 Sep 2022 14:14:15 +0300 From: Heikki Krogerus To: Won Chung Cc: bleung@google.com, pmalani@chromium.org, imre.deak@intel.com, maarten.lankhorst@linux.intel.com, mripard@kernel.org, tzimmermann@suse.de, airlied@linux.ie, daniel@ffwll.ch, linux-kernel@vger.kernel.org Subject: Re: [PATCH] drm/sysfs: Link DRM connectors to corresponding Type-C connectors Message-ID: References: <20220921182637.4056670-1-wonchung@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220921182637.4056670-1-wonchung@google.com> X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Won, On Wed, Sep 21, 2022 at 06:26:37PM +0000, Won Chung wrote: > Create a symlink pointing to USB Type-C connector for DRM connectors > when they are created. The link will be created only if the firmware is > able to describe the connection beween the two connectors. > > Signed-off-by: Won Chung > --- > drivers/gpu/drm/drm_sysfs.c | 42 +++++++++++++++++++++++++++++++++++++ > 1 file changed, 42 insertions(+) > > diff --git a/drivers/gpu/drm/drm_sysfs.c b/drivers/gpu/drm/drm_sysfs.c > index 430e00b16eec..8270b02e6783 100644 > --- a/drivers/gpu/drm/drm_sysfs.c > +++ b/drivers/gpu/drm/drm_sysfs.c > @@ -11,12 +11,14 @@ > */ > > #include > +#include > #include > #include > #include > #include > #include > #include > +#include > #include > > #include > @@ -95,6 +97,36 @@ static char *drm_devnode(struct device *dev, umode_t *mode) > return kasprintf(GFP_KERNEL, "dri/%s", dev_name(dev)); > } > > +static int typec_connector_bind(struct device *dev, > + struct device *typec_connector, void *data) > +{ > + int ret; > + > + ret = sysfs_create_link(&dev->kobj, &typec_connector->kobj, > + "typec_connector"); One line is enough. > + if (ret) > + return ret; > + > + ret = sysfs_create_link(&typec_connector->kobj, &dev->kobj, > + "drm_connector"); Ditto. > + if (ret) > + sysfs_remove_link(&dev->kobj, "typec_connector"); > + > + return ret; > +} > + > +static void typec_connector_unbind(struct device *dev, > + struct device *typec_connector, void *data) > +{ > + sysfs_remove_link(&typec_connector->kobj, "drm_connector"); > + sysfs_remove_link(&dev->kobj, "typec_connector"); > +} > + > +static const struct component_ops typec_connector_ops = { > + .bind = typec_connector_bind, > + .unbind = typec_connector_unbind, > +}; > + > static CLASS_ATTR_STRING(version, S_IRUGO, "drm 1.1.0 20060810"); > > /** > @@ -355,6 +387,13 @@ int drm_sysfs_connector_add(struct drm_connector *connector) > if (connector->ddc) > return sysfs_create_link(&connector->kdev->kobj, > &connector->ddc->dev.kobj, "ddc"); > + > + if (dev_fwnode(kdev)) { > + r = component_add(kdev, &typec_connector_ops); > + if (r) > + drm_err(dev, "failed to add component\n"); > + } > + > return 0; > > err_free: > @@ -367,6 +406,9 @@ void drm_sysfs_connector_remove(struct drm_connector *connector) > if (!connector->kdev) > return; > > + if (dev_fwnode(connector->kdev)) > + component_del(connector->kdev, &typec_connector_ops); > + > if (connector->ddc) > sysfs_remove_link(&connector->kdev->kobj, "ddc"); > > -- > 2.37.2.789.g6183377224-goog -- heikki