Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp747790ybp; Fri, 11 Oct 2019 03:49:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqyUGPvkduhu1WIPnymzNnHP/0WIrtRavBYUZzdD0aNBj5OEdIJY10Fj/352p4N899nROEEd X-Received: by 2002:a17:906:b817:: with SMTP id dv23mr13124734ejb.22.1570790990278; Fri, 11 Oct 2019 03:49:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570790990; cv=none; d=google.com; s=arc-20160816; b=qYqAW6cuww+zCDDrxUo+Dk0lUgOT7/UCi9BDLvvgy6Uhsswk+umRNhd9WO89EAUKPN A7QfNcpw7sca4/fEV4bPsmw4ucfB/AbXrASDv0oei+YIDjQ2Pd69GvokdXkgKpx/fK32 eHImxYcS7OeMVHSs9catJMsUrojrbtScUuigSGbni59g7TA7oSYc7sje9w4gnZR5cjY9 uKXF5W4ueDz8avoeLS7ZR7eM7egtZ0VVVhZOU4RX2ZYiE5RVFwMmwEqmUQp2X1pGd5Qh PTiwHTX2uOf/saSw/5G44ouypmvfLWQ+QPhN5AVx9s4SqTA7Ng6Qf/phu3AC53/lE4hM XMeA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=KpxDWPvz35a9kdqfFQphvMNey2YNc/+UfxTnv1nH9vc=; b=gSmxvbTvTmSL13KQNRaqrHA2PwF7vAlvg+WGMQJCk3BFO6+y2gJPLb5EAfw4smhxlQ aGImutyZ9MCLPcbK0aptnD2s9w/qScRHtNb0hOU6Eo7wZfpfcNVXEor9d792HGjw/kMo i6nFah2VLvfwnTqAt2sSY80G5dzVQHxl4SHHMMLtfqoNenu2h4MGxgzb1CnQv/62tv64 RXADR0BzaFoOMYCWzTY7i4VMyG5CduZwRhcYjHkSGRZUuOf5JqM03AIq/805YYIHD8vG SxsRR5Fiuahbp5yXk0ribdtvBT5hhl2eDkJyqJM4q784cIYDlBCHx3KPcy8Fm1g7Xmn0 +kJw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=uVjSIh28; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t10si5755779edd.447.2019.10.11.03.49.26; Fri, 11 Oct 2019 03:49:50 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=uVjSIh28; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727364AbfJKKtE (ORCPT + 99 others); Fri, 11 Oct 2019 06:49:04 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:57982 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726290AbfJKKtD (ORCPT ); Fri, 11 Oct 2019 06:49:03 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=Content-Transfer-Encoding: Content-Type:MIME-Version:References:In-Reply-To:Message-ID:Subject:Cc:To: From:Date:Sender:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=KpxDWPvz35a9kdqfFQphvMNey2YNc/+UfxTnv1nH9vc=; b=uVjSIh28fX7Nc49ea8x4QcaIh 2C2QtuT3kFValZ1SvZzLVM3CZ7jDU/uqdmBC2MxGtEBhhXlHO+tKCgFpUpokBqYCeuU6TYxoadmcU G52awsBZNCqhvz07y+WMuHUAJCr0jtfbRwSJVagfJW5v7tT8uiLMSuv7s7g5sj6iH7y6tuPbXYuFz eJ+Ihdha+2nbc7U2m+5nOUDoQllJz7CbpBRpLUXjb1TSYaVBQzHba1QESt0xvGLs+/1Ibj9yZkqWq r5iKJK/dHK6dflOCdqNe3xZ8Yy/OoPcHEtLynXvJ/SzxD6gquTPV5sY6uy9YvXXPJDvJO5Llx3KPC FHGqKAxog==; Received: from 177.17.141.107.dynamic.adsl.gvt.net.br ([177.17.141.107] helo=coco.lan) by bombadil.infradead.org with esmtpsa (Exim 4.92.3 #3 (Red Hat Linux)) id 1iIsTj-0000PI-7l; Fri, 11 Oct 2019 10:48:59 +0000 Date: Fri, 11 Oct 2019 07:48:55 -0300 From: Mauro Carvalho Chehab To: Robert Richter Cc: Borislav Petkov , Tony Luck , James Morse , "linux-edac@vger.kernel.org" , "linux-kernel@vger.kernel.org" Subject: Re: [PATCH 10/19] EDAC, mc: Rework edac_raw_mc_handle_error() to use struct dimm_info Message-ID: <20191011074855.30bd7e72@coco.lan> In-Reply-To: <20191010202418.25098-11-rrichter@marvell.com> References: <20191010202418.25098-1-rrichter@marvell.com> <20191010202418.25098-11-rrichter@marvell.com> X-Mailer: Claws Mail 3.17.4 (GTK+ 2.24.32; x86_64-redhat-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Thu, 10 Oct 2019 20:25:24 +0000 Robert Richter escreveu: > The error handling functions have the pos[] array argument for > determing the dimm handle. Rework those functions to use the dimm > handle directly. > > Signed-off-by: Robert Richter Reviewed-by: Mauro Carvalho Chehab > --- > drivers/edac/edac_mc.c | 28 +++++++++++++--------------- > drivers/edac/edac_mc.h | 2 ++ > drivers/edac/ghes_edac.c | 6 +++++- > 3 files changed, 20 insertions(+), 16 deletions(-) > > diff --git a/drivers/edac/edac_mc.c b/drivers/edac/edac_mc.c > index 6d880cf4d599..cdfb383f7a35 100644 > --- a/drivers/edac/edac_mc.c > +++ b/drivers/edac/edac_mc.c > @@ -925,11 +925,9 @@ const char *edac_layer_name[] = { > EXPORT_SYMBOL_GPL(edac_layer_name); > > static void edac_inc_ce_error(struct mem_ctl_info *mci, > - const int pos[EDAC_MAX_LAYERS], > + struct dimm_info *dimm, > const u16 count) > { > - struct dimm_info *dimm = edac_get_dimm(mci, pos[0], pos[1], pos[2]); > - > mci->ce_mc += count; > > if (dimm) > @@ -939,11 +937,9 @@ static void edac_inc_ce_error(struct mem_ctl_info *mci, > } > > static void edac_inc_ue_error(struct mem_ctl_info *mci, > - const int pos[EDAC_MAX_LAYERS], > - const u16 count) > + struct dimm_info *dimm, > + const u16 count) > { > - struct dimm_info *dimm = edac_get_dimm(mci, pos[0], pos[1], pos[2]); > - > mci->ue_mc += count; > > if (dimm) > @@ -953,8 +949,8 @@ static void edac_inc_ue_error(struct mem_ctl_info *mci, > } > > static void edac_ce_error(struct mem_ctl_info *mci, > + struct dimm_info *dimm, > const u16 error_count, > - const int pos[EDAC_MAX_LAYERS], > const char *msg, > const char *location, > const char *label, > @@ -982,7 +978,7 @@ static void edac_ce_error(struct mem_ctl_info *mci, > error_count, msg, msg_aux, label, > location, detail); > } > - edac_inc_ce_error(mci, pos, error_count); > + edac_inc_ce_error(mci, dimm, error_count); > > if (mci->scrub_mode == SCRUB_SW_SRC) { > /* > @@ -1006,8 +1002,8 @@ static void edac_ce_error(struct mem_ctl_info *mci, > } > > static void edac_ue_error(struct mem_ctl_info *mci, > + struct dimm_info *dimm, > const u16 error_count, > - const int pos[EDAC_MAX_LAYERS], > const char *msg, > const char *location, > const char *label, > @@ -1041,15 +1037,15 @@ static void edac_ue_error(struct mem_ctl_info *mci, > msg, msg_aux, label, location, detail); > } > > - edac_inc_ue_error(mci, pos, error_count); > + edac_inc_ue_error(mci, dimm, error_count); > } > > void edac_raw_mc_handle_error(const enum hw_event_mc_err_type type, > struct mem_ctl_info *mci, > + struct dimm_info *dimm, > struct edac_raw_error_desc *e) > { > char detail[80]; > - int pos[EDAC_MAX_LAYERS] = { e->top_layer, e->mid_layer, e->low_layer }; > > /* Memory type dependent details about the error */ > if (type == HW_EVENT_ERR_CORRECTED) { > @@ -1057,7 +1053,7 @@ void edac_raw_mc_handle_error(const enum hw_event_mc_err_type type, > "page:0x%lx offset:0x%lx grain:%ld syndrome:0x%lx", > e->page_frame_number, e->offset_in_page, > e->grain, e->syndrome); > - edac_ce_error(mci, e->error_count, pos, e->msg, e->location, > + edac_ce_error(mci, dimm, e->error_count, e->msg, e->location, > e->label, detail, e->other_detail, > e->page_frame_number, e->offset_in_page, e->grain); > } else { > @@ -1065,7 +1061,7 @@ void edac_raw_mc_handle_error(const enum hw_event_mc_err_type type, > "page:0x%lx offset:0x%lx grain:%ld", > e->page_frame_number, e->offset_in_page, e->grain); > > - edac_ue_error(mci, e->error_count, pos, e->msg, e->location, > + edac_ue_error(mci, dimm, e->error_count, e->msg, e->location, > e->label, detail, e->other_detail); > } > > @@ -1245,6 +1241,8 @@ void edac_mc_handle_error(const enum hw_event_mc_err_type type, > (e->page_frame_number << PAGE_SHIFT) | e->offset_in_page, > grain_bits, e->syndrome, e->other_detail); > > - edac_raw_mc_handle_error(type, mci, e); > + dimm = edac_get_dimm(mci, top_layer, mid_layer, low_layer); > + > + edac_raw_mc_handle_error(type, mci, dimm, e); > } > EXPORT_SYMBOL_GPL(edac_mc_handle_error); > diff --git a/drivers/edac/edac_mc.h b/drivers/edac/edac_mc.h > index 02aac5c61d00..2c3e2fbcedc4 100644 > --- a/drivers/edac/edac_mc.h > +++ b/drivers/edac/edac_mc.h > @@ -214,6 +214,7 @@ extern int edac_mc_find_csrow_by_page(struct mem_ctl_info *mci, > * > * @type: severity of the error (CE/UE/Fatal) > * @mci: a struct mem_ctl_info pointer > + * @dimm: a struct dimm_info pointer > * @e: error description > * > * This raw function is used internally by edac_mc_handle_error(). It should > @@ -222,6 +223,7 @@ extern int edac_mc_find_csrow_by_page(struct mem_ctl_info *mci, > */ > void edac_raw_mc_handle_error(const enum hw_event_mc_err_type type, > struct mem_ctl_info *mci, > + struct dimm_info *dimm, > struct edac_raw_error_desc *e); > > /** > diff --git a/drivers/edac/ghes_edac.c b/drivers/edac/ghes_edac.c > index e0b90c6d7d63..4f5721cf4380 100644 > --- a/drivers/edac/ghes_edac.c > +++ b/drivers/edac/ghes_edac.c > @@ -193,6 +193,7 @@ static void ghes_edac_dmidecode(const struct dmi_header *dh, void *arg) > > void ghes_edac_report_mem_error(int sev, struct cper_sec_mem_err *mem_err) > { > + struct dimm_info *dimm; > enum hw_event_mc_err_type type; > struct edac_raw_error_desc *e; > struct mem_ctl_info *mci; > @@ -437,7 +438,10 @@ void ghes_edac_report_mem_error(int sev, struct cper_sec_mem_err *mem_err) > (e->page_frame_number << PAGE_SHIFT) | e->offset_in_page, > grain_bits, e->syndrome, pvt->detail_location); > > - edac_raw_mc_handle_error(type, mci, e); > + dimm = edac_get_dimm_by_index(mci, e->top_layer); > + > + edac_raw_mc_handle_error(type, mci, dimm, e); > + > spin_unlock_irqrestore(&ghes_lock, flags); > } > Thanks, Mauro