Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp726438pxj; Thu, 17 Jun 2021 12:20:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwuvByIlRYpdcPJVi7a7coXn5Ks5I/Cje482nV4Dvhtsg0xGfgA23uNLYUSAW3E5GcUvxDh X-Received: by 2002:a05:6402:4404:: with SMTP id y4mr8944903eda.282.1623957646654; Thu, 17 Jun 2021 12:20:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623957646; cv=none; d=google.com; s=arc-20160816; b=JNvlaTQtlMbcyM2Kfwr0Fo8sInH4DEewxToPtz4cyEcjgbdWFRZDurmLio/YmrhVFZ CFWzpDzxFqtF/deAsmjdfF4a97X34/qsOwqZZ88hmJRVmWgFaHiiRZt502XYbHc5qsHy H+NaoF3u4Ljaaem8j2qHiF4fx+bnwnab3EI+FAMzMwKxinxNWoPIMun+oAtFVff58zoN A/iVJBvp5smKMMuwSGIjQWzbZ1gl8vpX2scPq0WL0NeJ9NWfiooXtheKA8WZYaVF8D7o STqDaHWf185Li40zjf8PzwMokNzu4UyRSMthOKUCoAP0pxV0RnKpYA0NYSV9taTIuRiU u1Cw== 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=zSc8eZU1LoYEJ9Tfw4fe9CMCWN75GDRLN/HSNEY/vBo=; b=iJ2LQBE8H1tz2b5x5JBoqX4CPCctlGCsPdspkKIiY1owgKHt0i1hsNHA4SI4FGeJsG ztXr2bcpHTKQJU+wxlDzimzvTS9XvfvZdp/QhcFV3aBrZA1QT3T26wnTuNm2kYQBcMeN Ivo6SHpZjVKOTRSwLPUzp3KRDha49cNWyUgu6ZP5jW6oFZFIT/pM9TrG/2/ZLvku1J6e icX/ViitHwdLH7e0jCxR8D+U5EAVYQSJxpAM74CFF0x3tg1W2Om7Pf5wINROD+Jhdqx6 gU0W7PCBDRPWByrRVg0UYChLOh5Q0JHtCglbAUGDzIukWOvh4antsd4IYvgIjqgmAaFt 7pBA== 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 fl21si6466530ejc.645.2021.06.17.12.20.23; Thu, 17 Jun 2021 12:20:46 -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 S233490AbhFQPsE (ORCPT + 99 others); Thu, 17 Jun 2021 11:48:04 -0400 Received: from mga04.intel.com ([192.55.52.120]:28059 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233468AbhFQPsD (ORCPT ); Thu, 17 Jun 2021 11:48:03 -0400 IronPort-SDR: 6nXa9aKCOzrlXkHWXdPeNkFHMi3nkH/DN9TguQY++X05jPw9lshns4t/22hm9PKzbRpOUf6YHs qhUfQlOxr5BQ== X-IronPort-AV: E=McAfee;i="6200,9189,10018"; a="204565833" X-IronPort-AV: E=Sophos;i="5.83,280,1616482800"; d="scan'208";a="204565833" Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Jun 2021 08:43:33 -0700 IronPort-SDR: cM++6v/5F8GNRQItj8P7rvTmxewnaKvYJz69NEzLtYBWlW7wpLk2kHbKj56G+DQ23ZzGyBM9kV gZhFug06MojA== X-IronPort-AV: E=Sophos;i="5.83,280,1616482800"; d="scan'208";a="472449913" Received: from mkalyani-mobl.amr.corp.intel.com (HELO intel.com) ([10.252.138.30]) by fmsmga004-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Jun 2021 08:43:32 -0700 Date: Thu, 17 Jun 2021 08:43:29 -0700 From: Ben Widawsky To: Alison Schofield Cc: Dan Williams , Ira Weiny , Vishal Verma , Jonathan Cameron , linux-cxl@vger.kernel.org, linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org Subject: Re: [PATCH v3 2/2] cxl/acpi: Use the ACPI CFMWS to create static decoder objects Message-ID: <20210617154329.5dvwuktoiu72wi54@intel.com> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 21-06-16 18:11:08, Alison Schofield wrote: > The ACPI CXL Early Discovery Table (CEDT) includes a list of CXL memory > resources in CXL Fixed Memory Window Structures (CFMWS). Retrieve each > CFMWS in the CEDT and add a cxl_decoder object to the root port (root0) > for each memory resource. > > Signed-off-by: Alison Schofield > --- > drivers/cxl/acpi.c | 119 +++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 119 insertions(+) > > diff --git a/drivers/cxl/acpi.c b/drivers/cxl/acpi.c > index 852b5c270464..018f5ac73b78 100644 > --- a/drivers/cxl/acpi.c > +++ b/drivers/cxl/acpi.c > @@ -10,6 +10,123 @@ > > static struct acpi_table_header *acpi_cedt; > > +/* Encode defined in CXL 2.0 8.2.5.12.7 HDM Decoder Control Register */ > +#define CFMWS_INTERLEAVE_WAYS(x) (1 << (x)->interleave_ways) > +#define CFMWS_INTERLEAVE_GRANULARITY(x) ((x)->granularity + 8) > + > +static unsigned long cfmws_to_decoder_flags(int restrictions) > +{ > + unsigned long flags = 0; > + > + if (restrictions & ACPI_CEDT_CFMWS_RESTRICT_TYPE2) > + flags |= CXL_DECODER_F_TYPE2; > + if (restrictions & ACPI_CEDT_CFMWS_RESTRICT_TYPE3) > + flags |= CXL_DECODER_F_TYPE3; > + if (restrictions & ACPI_CEDT_CFMWS_RESTRICT_VOLATILE) > + flags |= CXL_DECODER_F_RAM; > + if (restrictions & ACPI_CEDT_CFMWS_RESTRICT_PMEM) > + flags |= CXL_DECODER_F_PMEM; > + if (restrictions & ACPI_CEDT_CFMWS_RESTRICT_FIXED) > + flags |= CXL_DECODER_F_LOCK; > + > + return flags; > +} > + > +static int cxl_acpi_cfmws_verify(struct device *dev, > + struct acpi_cedt_cfmws *cfmws) > +{ > + int expected_len; > + > + if (cfmws->interleave_arithmetic != ACPI_CEDT_CFMWS_ARITHMETIC_MODULO) { > + dev_err(dev, "CFMWS Unsupported Interleave Arithmetic\n"); > + return -EINVAL; > + } > + > + if (!IS_ALIGNED(cfmws->base_hpa, SZ_256M)) { > + dev_err(dev, "CFMWS Base HPA not 256MB aligned\n"); > + return -EINVAL; > + } > + > + if (!IS_ALIGNED(cfmws->window_size, SZ_256M)) { > + dev_err(dev, "CFMWS Window Size not 256MB aligned\n"); > + return -EINVAL; > + } > + > + expected_len = struct_size((cfmws), interleave_targets, > + CFMWS_INTERLEAVE_WAYS(cfmws)); > + > + if (cfmws->header.length < expected_len) { > + dev_err(dev, "CFMWS length %d less than expected %d\n", > + cfmws->header.length, expected_len); > + return -EINVAL; > + } > + > + if (cfmws->header.length > expected_len) > + dev_dbg(dev, "CFMWS length %d greater than expected %d\n", > + cfmws->header.length, expected_len); > + > + return 0; > +} > + > +static void cxl_add_cfmws_decoders(struct device *dev, > + struct cxl_port *root_port) > +{ > + struct acpi_cedt_cfmws *cfmws; > + struct cxl_decoder *cxld; > + acpi_size len, cur = 0; > + void *cedt_subtable; > + int rc; > + > + len = acpi_cedt->length - sizeof(*acpi_cedt); > + cedt_subtable = acpi_cedt + 1; > + > + while (cur < len) { > + struct acpi_cedt_header *c = cedt_subtable + cur; > + > + if (c->type != ACPI_CEDT_TYPE_CFMWS) { > + cur += c->length; > + continue; > + } > + > + cfmws = cedt_subtable + cur; > + > + if (dev_WARN_ONCE(dev, cfmws->header.length < sizeof(*cfmws), > + "CFMWS entry skipped: invalid length:%u\n", > + cfmws->header.length)) { > + cur += c->length; > + continue; > + } > + > + rc = cxl_acpi_cfmws_verify(dev, cfmws); > + if (rc) { > + dev_err(dev, "CFMWS range %#llx-%#llx not registered\n", > + cfmws->base_hpa, cfmws->base_hpa + > + cfmws->window_size - 1); > + cur += c->length; > + continue; > + } > + > + cxld = devm_cxl_add_decoder(dev, root_port, > + CFMWS_INTERLEAVE_WAYS(cfmws), > + cfmws->base_hpa, cfmws->window_size, > + CFMWS_INTERLEAVE_WAYS(cfmws), > + CFMWS_INTERLEAVE_GRANULARITY(cfmws), > + CXL_DECODER_EXPANDER, > + cfmws_to_decoder_flags(cfmws->restrictions)); checkpatch complains here for me. CHECK: Alignment should match open parenthesis #122: FILE: drivers/cxl/acpi.c:110: + cxld = devm_cxl_add_decoder(dev, root_port, + CFMWS_INTERLEAVE_WAYS(cfmws), > + > + if (IS_ERR(cxld)) { > + dev_err(dev, "Failed to add decoder for %#llx-%#llx\n", > + cfmws->base_hpa, cfmws->base_hpa + > + cfmws->window_size - 1); > + } else { > + dev_dbg(dev, "add: %s range %#llx-%#llx\n", > + dev_name(&cxld->dev), cfmws->base_hpa, > + cfmws->base_hpa + cfmws->window_size - 1); > + } > + cur += c->length; > + } > +} > + > static struct acpi_cedt_chbs *cxl_acpi_match_chbs(struct device *dev, u32 uid) > { > struct acpi_cedt_chbs *chbs, *chbs_match = NULL; > @@ -271,6 +388,8 @@ static int cxl_acpi_probe(struct platform_device *pdev) > if (rc) > goto out; > > + cxl_add_cfmws_decoders(host, root_port); > + > /* > * Root level scanned with host-bridge as dports, now scan host-bridges > * for their role as CXL uports to their CXL-capable PCIe Root Ports. > -- > 2.26.2 >