Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp763602pxj; Fri, 11 Jun 2021 10:49:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxqKmTl1R0Vk78OhP0IZV54/wV48xNN7kBIfUvRV25JiB3DgXh9IyCgyR1rvTsv22eY3Z/z X-Received: by 2002:a17:906:b06:: with SMTP id u6mr4852000ejg.199.1623433789220; Fri, 11 Jun 2021 10:49:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623433789; cv=none; d=google.com; s=arc-20160816; b=pcNYNu6NRP3q+RH3zvi1flxhK/id5M04uMFad3BcL0tGVeORcrNVYxhM713Y+3/FEO N4Ni5nTuKR4pjQ36qkPRZoqfY9Pm7nIGCDN7b0U5cwLacqCIFcxAlk491YtJxVzm39Eu P6sgfS/ycLhyVeRIWhqwaraOLcqaT0qyGjV3/8n7vlCxKTeE1tLk2qW0UNysXLDB0Kcz 81b9jXB9zXF+/Adjg46AI+e1TofZRjCXDr835hbQp5tv9JcpNd2R1gEbJl7R48ovZEJg QbpwPgeK00w95fP2GJEcy1o7fkHw8Sp7eRFE3eANGucMclzXrMnfpOnKfbb+d5wEgrki 5ezQ== 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:ironport-sdr :ironport-sdr; bh=iM6s5MIjGtmtEBSIhyFWLYEVKbaGHYZtbO5C6kFmR54=; b=fhQL3M4D/7zNm/U4fsfBPjHgOpWMgySa8GVbVAJBDS0mZ4fFSbvxIaGtgZMmd/728Z 4KvLBPxwvEuK1RS33kQePlWltxtD+znv6YDYrrflgmwhvOceirGH9sDxXwN0gssvTDOr YPJSUZu9hfY79OjfT3wUI4SW8iH5LjpjaC9jwwPSI9jCMO/K0evtKdeigDkFWZqzBUJX ek+9lfzqmPkJECwPMjqOqkRlRLkbmfvrWuqN7pU5ExkWN/swyruM391DwUC4JkRrITy6 IhCEspzCgoKSrwjqvCnAIUE6efAUv+MQiWwjuxTdlPdP8U6pYYfvLwPjo5dguS4nx1mQ vn2g== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u4si5337029eju.494.2021.06.11.10.49.24; Fri, 11 Jun 2021 10:49:49 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230129AbhFKRti (ORCPT + 99 others); Fri, 11 Jun 2021 13:49:38 -0400 Received: from mga09.intel.com ([134.134.136.24]:47107 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229951AbhFKRti (ORCPT ); Fri, 11 Jun 2021 13:49:38 -0400 IronPort-SDR: wi/N3XtsbggqUOEV5DaXlOtd/npLtGIG/gvpNFbEENaqC+1yy81F3Sc83mqg3jgXEKZCFqbZhe 8cvpIqaIaQKQ== X-IronPort-AV: E=McAfee;i="6200,9189,10012"; a="205532346" X-IronPort-AV: E=Sophos;i="5.83,267,1616482800"; d="scan'208";a="205532346" Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Jun 2021 10:47:38 -0700 IronPort-SDR: 0mTW6WPCqIp7pjzfsIK+utzJm2IXyzBYiCc2/K75E7sZZvJF489+kp3pRpM88R+1Bl6MsBRfnA 8xkABb+u/fHg== X-IronPort-AV: E=Sophos;i="5.83,267,1616482800"; d="scan'208";a="552756908" Received: from chtanaka-mobl2.amr.corp.intel.com (HELO intel.com) ([10.252.138.239]) by orsmga004-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Jun 2021 10:47:38 -0700 Date: Fri, 11 Jun 2021 10:47:36 -0700 From: Ben Widawsky To: Dan Williams Cc: linux-cxl@vger.kernel.org, nvdimm@lists.linux.dev, alison.schofield@intel.com, vishal.l.verma@intel.com, ira.weiny@intel.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/5] cxl/core: Add cxl-bus driver infrastructure Message-ID: <20210611174736.ttzpk5uniyoyd4vw@intel.com> References: <162336395765.2462439.11368504490069925374.stgit@dwillia2-desk3.amr.corp.intel.com> <162336396329.2462439.16556923116284874437.stgit@dwillia2-desk3.amr.corp.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <162336396329.2462439.16556923116284874437.stgit@dwillia2-desk3.amr.corp.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 21-06-10 15:26:03, Dan Williams wrote: > Enable devices on the 'cxl' bus to be attached to drivers. The initial > user of this functionality is a driver for an 'nvdimm-bridge' device > that anchors a libnvdimm hierarchy attached to CXL persistent memory > resources. Other device types that will leverage this include: > > cxl_port: map and use component register functionality (HDM Decoders) Since I'm looking at this now, perhaps I can open the discussion here. Have you thought about how this works yet? Right now I'm thinking there are two "drivers": cxl_port: Switches (and ACPI0016) cxl_mem: The memory device's HDM decoders For port, probe() will figure out that the thing is an upstream port, call cxl_probe_component_regs and then call devm_cxl_add_port(). I think that's straight forward. For the memory device we've already probed the thing via class code so there is no need to use this driver registration, however, I think it would be nice to do so. Is there a clean way to do that? Also, I'd like to make sure we're on the same page about struct cxl_decoder. Right now they are only created for active HDM decoders. Going forward, we can either maintain a count of unused decoders on the given CXL component, or we can instantiate a struct cxl_decoder that isn't active, ie. no interleave ways granularit, base, etc. What's your thinking there? > > cxl_nvdimm: translate CXL memory expander endpoints to libnvdimm > 'nvdimm' objects > > cxl_region: translate CXL interleave sets to libnvdimm 'region' objects > > The pairing of devices to drivers is handled through the cxl_device_id() > matching to cxl_driver.id values. A cxl_device_id() of '0' indicates no > driver support. > > In addition to ->match(), ->probe(), and ->remove() support for the > 'cxl' bus introduce MODULE_ALIAS_CXL() to autoload modules containing > cxl-drivers. Drivers are added in follow-on changes. > > Signed-off-by: Dan Williams > --- > drivers/cxl/core.c | 73 ++++++++++++++++++++++++++++++++++++++++++++++++++++ > drivers/cxl/cxl.h | 22 ++++++++++++++++ > 2 files changed, 95 insertions(+) > > diff --git a/drivers/cxl/core.c b/drivers/cxl/core.c > index 1b9ee0b08384..959cecc1f6bf 100644 > --- a/drivers/cxl/core.c > +++ b/drivers/cxl/core.c > @@ -767,8 +767,81 @@ int cxl_map_device_regs(struct pci_dev *pdev, > } > EXPORT_SYMBOL_GPL(cxl_map_device_regs); > > +/** > + * __cxl_driver_register - register a driver for the cxl bus > + * @cxl_drv: cxl driver structure to attach > + * @owner: owning module/driver > + * @modname: KBUILD_MODNAME for parent driver > + */ > +int __cxl_driver_register(struct cxl_driver *cxl_drv, struct module *owner, > + const char *modname) > +{ > + if (!cxl_drv->probe) { > + pr_debug("%s ->probe() must be specified\n", modname); > + return -EINVAL; > + } > + > + if (!cxl_drv->name) { > + pr_debug("%s ->name must be specified\n", modname); > + return -EINVAL; > + } > + > + if (!cxl_drv->id) { > + pr_debug("%s ->id must be specified\n", modname); > + return -EINVAL; > + } > + > + cxl_drv->drv.bus = &cxl_bus_type; > + cxl_drv->drv.owner = owner; > + cxl_drv->drv.mod_name = modname; > + cxl_drv->drv.name = cxl_drv->name; > + > + return driver_register(&cxl_drv->drv); > +} > +EXPORT_SYMBOL_GPL(__cxl_driver_register); > + > +void cxl_driver_unregister(struct cxl_driver *cxl_drv) > +{ > + driver_unregister(&cxl_drv->drv); > +} > +EXPORT_SYMBOL_GPL(cxl_driver_unregister); > + > +static int cxl_device_id(struct device *dev) > +{ > + return 0; > +} > + > +static int cxl_bus_uevent(struct device *dev, struct kobj_uevent_env *env) > +{ > + return add_uevent_var(env, "MODALIAS=" CXL_MODALIAS_FMT, > + cxl_device_id(dev)); > +} > + > +static int cxl_bus_match(struct device *dev, struct device_driver *drv) > +{ > + return cxl_device_id(dev) == to_cxl_drv(drv)->id; > +} > + > +static int cxl_bus_probe(struct device *dev) > +{ > + return to_cxl_drv(dev->driver)->probe(dev); > +} > + > +static int cxl_bus_remove(struct device *dev) > +{ > + struct cxl_driver *cxl_drv = to_cxl_drv(dev->driver); > + > + if (cxl_drv->remove) > + cxl_drv->remove(dev); > + return 0; > +} > + > struct bus_type cxl_bus_type = { > .name = "cxl", > + .uevent = cxl_bus_uevent, > + .match = cxl_bus_match, > + .probe = cxl_bus_probe, > + .remove = cxl_bus_remove, > }; > EXPORT_SYMBOL_GPL(cxl_bus_type); > > diff --git a/drivers/cxl/cxl.h b/drivers/cxl/cxl.h > index b988ea288f53..af2237d1c761 100644 > --- a/drivers/cxl/cxl.h > +++ b/drivers/cxl/cxl.h > @@ -261,4 +261,26 @@ devm_cxl_add_passthrough_decoder(struct device *host, struct cxl_port *port) > } > > extern struct bus_type cxl_bus_type; > + > +struct cxl_driver { > + const char *name; > + int (*probe)(struct device *dev); > + void (*remove)(struct device *dev); > + struct device_driver drv; > + int id; > +}; > + > +static inline struct cxl_driver *to_cxl_drv(struct device_driver *drv) > +{ > + return container_of(drv, struct cxl_driver, drv); > +} > + > +int __cxl_driver_register(struct cxl_driver *cxl_drv, struct module *owner, > + const char *modname); > +#define cxl_driver_register(x) __cxl_driver_register(x, THIS_MODULE, KBUILD_MODNAME) > +void cxl_driver_unregister(struct cxl_driver *cxl_drv); > + > +#define MODULE_ALIAS_CXL(type) MODULE_ALIAS("cxl:t" __stringify(type) "*") > +#define CXL_MODALIAS_FMT "cxl:t%d" > + > #endif /* __CXL_H__ */ >