Received: by 2002:ab2:6c55:0:b0:1fd:c486:4f03 with SMTP id v21csp53561lqp; Tue, 11 Jun 2024 14:28:46 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWWhvW2DAYO+YKyDHpP397ITk/e3jp8QI5c1OXD8n/UXpz8V6glcfmSaGLAGS6WHK3pMrvNRH5yS4UBSYRPRUeo5za+Jn1pKl3eLV+dlA== X-Google-Smtp-Source: AGHT+IG9YObelu6zsOVVU6SfC2SUeFwMxm2BFNAwtAPq3APUJdn3YIssZgYAEHx6PM8izcXaKK2B X-Received: by 2002:a05:6a21:6da4:b0:1b5:4c70:d682 with SMTP id adf61e73a8af0-1b8a9b75eb8mr280194637.6.1718141325796; Tue, 11 Jun 2024 14:28:45 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1718141325; cv=pass; d=google.com; s=arc-20160816; b=f8nhD6TqxAnlewq4YiJRwLJii1kJ5NtoRtP6td68i1gmTD3wy3ESl7FzfY+Pk16Ilh ubGFAs3Kvqe0Hytwdq0Vt+cxrbdZf9fDl8wLNJnyjEvNquud8I4xyP9077lwkldzmyw1 seByGq9gCqRqt5+Ct7A82NAKfgFd8rm4C9owTYcJ79k/rBtpLN3L/UbTU8IHrAvwuAPb tDlFDaJtGY9V+TCL3XLOb8q49kOSlr6HaepJAxVmjfNURgAkyX/T80EB4bw3te1omSx9 D1VrshqUILbqLF/cO1ZNHis/AkD8nqUtrLHmOiuR1V9ujij6qT2fTS7wK5CpVv/yHdx1 eFrA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date:dkim-signature; bh=r179f/hN3jW7QEDmLDP6ecz/tDv1Ijtp413HHY44mGQ=; fh=KMh7LmP9PRle7AOSi4ifQKnrULMKTSrcQROfZzz4iKI=; b=rV/sBpSf1se4vhMhDcfYDv+ccK6lZNzQ9hmQZSwbGV1NhbF2P+ffjWVIgWQZ5lcy3T 7inb/qRqfG1oPfb6KknFjz2TH0X5WiYcnLsLUCi5InOTb8ttJbwpPd33/4q0qaCXOq6+ DCaShfjPVSCZ+o1NsgLuHPcgyvI5jVpop98EVFIZZ867yH8JAZWftEop2kbN4ucVpGBU kqTVkVZVU2kyA8A2eMFo4qONnUE3VNM6ccTxbB/qRmPjh5umw/OpTyIHv2YxW203F08b bny9A0tMP/fsWVU7RXXYAa6yOkjnMHlxGoUc6hnQqBlKvFrdEXXjUcG2/2JnmCLpp70t ljuw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=RfggUeUd; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-210613-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-210613-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id d2e1a72fcca58-7042e8d2d89si5607450b3a.162.2024.06.11.14.28.45 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 11 Jun 2024 14:28:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-210613-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=RfggUeUd; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-210613-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-210613-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 7F788B232E6 for ; Tue, 11 Jun 2024 21:28:41 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id D1C83153828; Tue, 11 Jun 2024 21:28:34 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="RfggUeUd" Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2CDD2BA34; Tue, 11 Jun 2024 21:28:31 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=198.175.65.17 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718141313; cv=none; b=RBs+OZOMNjic0rfP+Uhe688u0gMAr7PXamzIuv/1U7ixfUwSk450nhPYcQOaSxkk/Zb7zB8OFrEN6UI3qKNwJAE+qSCgeTWWGbpI86twY1XBLvnAipXjbAqbD294LFRtmbLyxmkG0k3pQh1CveHke4hQuLOIgy90YkF/WfrW0aw= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718141313; c=relaxed/simple; bh=VdI6S68LyiZsWxsDBTb+e89IsuMpXESBq3qiJRD2tdg=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=SIcQTjCpZ0/kvKsDknVQELdfuUkOGkmNZTBMr+byEWqwZsPJdTsoGbVW9jgNxxygWLQG2icPF403+R8h6/5tGA5sgSZAGTrQ84u/bkxXKS8QD2HoitvmSOR/Y76pdKjdVjnUdEZvlZCd0s97RzVhrA5NOYmx4v45zW6xBv8jhsc= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=RfggUeUd; arc=none smtp.client-ip=198.175.65.17 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1718141312; x=1749677312; h=date:from:to:cc:subject:message-id:references: mime-version:in-reply-to; bh=VdI6S68LyiZsWxsDBTb+e89IsuMpXESBq3qiJRD2tdg=; b=RfggUeUdToNx0tQhInS2JNEx0HGxNwDyMieg3jvHrHHmYyHJ1sDILsQd LzdrC2ESKQRasnPTa9Hh6CE6CcLC0zMrQBMaonwIvGorMuATVfQG/i8b8 RM3hO+WKRO4czYZtVQqJKl/qpRB+xkJ4ptLpBAtyD4pp9nGOe9oTI7S8y X0e3jz7ixoOTTXFpdthf+YX/caJzH9YBq196kd/n1Y+TAoBiZL3SeRwBc ycLHPtnV7XIf0IjfKeV/d9157DMnx9JzNT/hjb+Pnx0r5sRa4hijBUrRQ H2bDY0Nqpoo5m5GdTOQ3tyfdad13T8i0MzXGwb2pkI6NDCypLnlAGecuG g==; X-CSE-ConnectionGUID: t8g9glXPQyOlVDcMGxeFVg== X-CSE-MsgGUID: v1Ujro89QYO+D1CoaaA5VQ== X-IronPort-AV: E=McAfee;i="6600,9927,11100"; a="15007423" X-IronPort-AV: E=Sophos;i="6.08,231,1712646000"; d="scan'208";a="15007423" Received: from orviesa006.jf.intel.com ([10.64.159.146]) by orvoesa109.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Jun 2024 14:28:32 -0700 X-CSE-ConnectionGUID: yarlTxuTRUqD+Pirm3/fsQ== X-CSE-MsgGUID: X7mvz3mPSOWh+c6ziTqZoQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.08,231,1712646000"; d="scan'208";a="40041002" Received: from aschofie-mobl2.amr.corp.intel.com (HELO aschofie-mobl2) ([10.209.70.181]) by orviesa006-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Jun 2024 14:28:31 -0700 Date: Tue, 11 Jun 2024 14:28:29 -0700 From: Alison Schofield To: Huang Ying Cc: Dan Williams , linux-cxl@vger.kernel.org, linux-kernel@vger.kernel.org, Andrew Morton , Jonathan Cameron , Dave Jiang , Bharata B Rao , Alistair Popple , "Aneesh Kumar K . V" Subject: Re: [PATCH -V2] cxl/region: Support to calculate memory tier abstract distance Message-ID: References: <20240611055423.470574-1-ying.huang@intel.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20240611055423.470574-1-ying.huang@intel.com> On Tue, Jun 11, 2024 at 01:54:23PM +0800, Ying Huang wrote: > To place memory nodes backed by CXL regions in the appropriate memory > tiers. So that, pages can be promoted/demoted with the existing > memory tiering mechanism. How about more context for the unfamiliar because my first lookup was what's an 'abstract distance'? (not sure I even got it right below ;)) An abstract distance value must be assigned by the driver that makes the memory available to the system. It reflects relative performance and is used to place memory nodes backed by CXL regions in the appropriate memory tiers allowing promotion/demotion within the existing memory tiering mechanism. > > The abstract distance is calculated based on the memory access latency > and bandwidth of CXL regions. Which in turn comes from the HMAT > and CDAT, etc. etc ? I think the latency and bandwidth were already calculated, so you don't need to explain those. Perhaps drop the whole 'While in turn come from..." part. a bit below... > > Signed-off-by: "Huang, Ying" > Cc: Andrew Morton > Cc: Jonathan Cameron > Cc: Dave Jiang > Cc: Dan Williams > Cc: Bharata B Rao > Cc: Alistair Popple > Cc: Aneesh Kumar K.V > --- > Changes: > > v2: > > - Added comments to struct cxl_region and minor fixes (Thanks Jonathan!) > - Link to v1: https://lore.kernel.org/linux-cxl/20240531024852.282767-1-ying.huang@intel.com/ > > --- > drivers/cxl/core/region.c | 40 +++++++++++++++++++++++++++++++++++---- > drivers/cxl/cxl.h | 2 ++ > 2 files changed, 38 insertions(+), 4 deletions(-) > > diff --git a/drivers/cxl/core/region.c b/drivers/cxl/core/region.c > index 3c2b6144be23..81d0910c0a02 100644 > --- a/drivers/cxl/core/region.c > +++ b/drivers/cxl/core/region.c > @@ -9,6 +9,7 @@ > #include > #include > #include > +#include > #include > #include > #include "core.h" > @@ -2304,14 +2305,20 @@ static bool cxl_region_update_coordinates(struct cxl_region *cxlr, int nid) > return true; > } > > +static int cxl_region_nid(struct cxl_region *cxlr) > +{ > + struct cxl_region_params *p = &cxlr->params; > + struct cxl_endpoint_decoder *cxled = p->targets[0]; > + struct cxl_decoder *cxld = &cxled->cxld; > + > + return phys_to_target_node(cxld->hpa_range.start); > +} > + I believe it's OK to send a resource_size_t to phys_to_target_node() like this: --- a/drivers/cxl/core/region.c +++ b/drivers/cxl/core/region.c @@ -2308,10 +2308,8 @@ static bool cxl_region_update_coordinates(struct cxl_region *cxlr, int nid) static int cxl_region_nid(struct cxl_region *cxlr) { struct cxl_region_params *p = &cxlr->params; - struct cxl_endpoint_decoder *cxled = p->targets[0]; - struct cxl_decoder *cxld = &cxled->cxld; - return phys_to_target_node(cxld->hpa_range.start); + return phys_to_target_node(p->res->start); } > static int cxl_region_perf_attrs_callback(struct notifier_block *nb, > unsigned long action, void *arg) > { > struct cxl_region *cxlr = container_of(nb, struct cxl_region, > memory_notifier); > - struct cxl_region_params *p = &cxlr->params; > - struct cxl_endpoint_decoder *cxled = p->targets[0]; > - struct cxl_decoder *cxld = &cxled->cxld; > struct memory_notify *mnb = arg; > int nid = mnb->status_change_nid; > int region_nid; > @@ -2319,7 +2326,7 @@ static int cxl_region_perf_attrs_callback(struct notifier_block *nb, > if (nid == NUMA_NO_NODE || action != MEM_ONLINE) > return NOTIFY_DONE; > > - region_nid = phys_to_target_node(cxld->hpa_range.start); > + region_nid = cxl_region_nid(cxlr); > if (nid != region_nid) > return NOTIFY_DONE; > > @@ -2329,6 +2336,27 @@ static int cxl_region_perf_attrs_callback(struct notifier_block *nb, > return NOTIFY_OK; > } > > +static int cxl_region_calculate_adistance(struct notifier_block *nb, > + unsigned long nid, void *data) > +{ > + struct cxl_region *cxlr = container_of(nb, struct cxl_region, > + adist_notifier); > + struct access_coordinate *perf; > + int *adist = data; > + int region_nid; > + > + region_nid = cxl_region_nid(cxlr); > + if (nid != region_nid) > + return NOTIFY_OK; > + > + perf = &cxlr->coord[ACCESS_COORDINATE_CPU]; > + > + if (mt_perf_to_adistance(perf, adist)) > + return NOTIFY_OK; > + > + return NOTIFY_STOP; > +} > + > /** > * devm_cxl_add_region - Adds a region to a decoder > * @cxlrd: root decoder > @@ -2371,6 +2399,10 @@ static struct cxl_region *devm_cxl_add_region(struct cxl_root_decoder *cxlrd, > cxlr->memory_notifier.priority = CXL_CALLBACK_PRI; > register_memory_notifier(&cxlr->memory_notifier); > > + cxlr->adist_notifier.notifier_call = cxl_region_calculate_adistance; > + cxlr->adist_notifier.priority = 100; > + register_mt_adistance_algorithm(&cxlr->adist_notifier); > + > rc = devm_add_action_or_reset(port->uport_dev, unregister_region, cxlr); > if (rc) > return ERR_PTR(rc); > diff --git a/drivers/cxl/cxl.h b/drivers/cxl/cxl.h > index 603c0120cff8..f46252373159 100644 > --- a/drivers/cxl/cxl.h > +++ b/drivers/cxl/cxl.h > @@ -522,6 +522,7 @@ struct cxl_region_params { > * @params: active + config params for the region > * @coord: QoS access coordinates for the region > * @memory_notifier: notifier for setting the access coordinates to node > + * @adist_notifier: notifier for calculating the abstract distance of node > */ > struct cxl_region { > struct device dev; > @@ -534,6 +535,7 @@ struct cxl_region { > struct cxl_region_params params; > struct access_coordinate coord[ACCESS_COORDINATE_MAX]; > struct notifier_block memory_notifier; > + struct notifier_block adist_notifier; > }; > > struct cxl_nvdimm_bridge { > -- > 2.39.2 > >