Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp591923ybl; Fri, 23 Aug 2019 05:38:22 -0700 (PDT) X-Google-Smtp-Source: APXvYqwIPXs9eI07eOZQZTxlxYy5KcgW4aKTsVJRwOr3RsrfbpLSK5NCjqIo9oOsxrQC2cwY/nbA X-Received: by 2002:a17:90a:1b0d:: with SMTP id q13mr5106521pjq.102.1566563902359; Fri, 23 Aug 2019 05:38:22 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1566563902; cv=pass; d=google.com; s=arc-20160816; b=No+t/NuIS81999btL20DVtplWu94qpexPusJlRbO4HyTledt+GlxFQkCr3z1PMV0Kf w84DRbLgiXdJ1KONERM4YTy6pKTN9DI6OlRXhQEw1NOt3NpdI2tPLC4jA97KN4g4OEU5 5/MDm0w86N27xB7yNlVLea85RasF5moIfEKhdgSUD1v017irN0hUky3tAc5uwKhNPFjX kG4a650LadFqtgLjSKyVg1gucdzO6zoUs1pDakB9fs3e1mDHMjpFY4ylc+FUCOmo2Z5d AiRTPpN0XnmM7wFTgg8qKQ/3uyptWl+t7e82/+02q4IOU+FrDyZbzOo185N37avAU145 8yZg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :content-language:accept-language:in-reply-to:references:message-id :date:thread-index:thread-topic:subject:cc:to:from:dkim-signature; bh=e8tOYs/P0C1jrZrSMZd/iU96wMxYNdNq6HLU+AkCY90=; b=0SVgop3fgoJK9Zu+0Cz19G8TdtiI3zMMKTjcPlRc87NBuXScgfEhOY3fhToUnyUPtj 46kmpMxG1XI8SImNUyFSuB6tI56jT1yL3psoQOIWNEC5DVji4UHphhQQEyL7MV3+w/6N Hh33C62SOHRS/VOcLWzvVqYWA2E2m1aWw+lzJwQiDr6CgYs2mZatnffY3kwzq31s4177 40qj1Frzk/IvRFDUxGTeP32MAvXXXsbaMEx+IrHKqpoB80tmrVFP1UeXMcn8ns+5KOLA uNm47Oe+xltunKs+FJ++Hx8qSJD5REqmNk7YWdi+mjhUAnLnJe8WpSzC9QWGgYA1RTZj hQmQ== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amdcloud.onmicrosoft.com header.s=selector2-amdcloud-onmicrosoft-com header.b=RCYQHKM5; arc=pass (i=1 spf=pass spfdomain=amd.com dkim=pass dkdomain=amd.com dmarc=pass fromdomain=amd.com); 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p2si2500731pff.169.2019.08.23.05.38.04; Fri, 23 Aug 2019 05:38:22 -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=pass header.i=@amdcloud.onmicrosoft.com header.s=selector2-amdcloud-onmicrosoft-com header.b=RCYQHKM5; arc=pass (i=1 spf=pass spfdomain=amd.com dkim=pass dkdomain=amd.com dmarc=pass fromdomain=amd.com); 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391109AbfHVSwV (ORCPT + 99 others); Thu, 22 Aug 2019 14:52:21 -0400 Received: from mail-eopbgr820054.outbound.protection.outlook.com ([40.107.82.54]:47839 "EHLO NAM01-SN1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1729276AbfHVSwV (ORCPT ); Thu, 22 Aug 2019 14:52:21 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=fuP+N5O7Kw20YIUK94vOfra8fe+LR07lXg7RV8NrtIy+SgKll3s+2ffELEdWZ++QD/eGuDzY6HRFo+FGyIpCmyjxUg0P1tMXUC4rNEzORAKbXST3pVJzqAqhPFtXjSgq/15gy3iQ7mi+TqSd+LWU96z8CmWzneq2NgS6tS0/ydyKlvTNdQuG2zrUcr9MNFcSFKjR8HLWZcHY3564YQMfp7J2Lwi6yg4Pz4T+2WpgE1KhWQv7vzPscXTqZeZT9L4NHAZegbOdaU434nLqBo49u3pm7rfQeWA6SLOJwfKaPBNB85qSyyjccRUlAlg1HAj7TkacwEp3ntu5jjytYdZjIg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=e8tOYs/P0C1jrZrSMZd/iU96wMxYNdNq6HLU+AkCY90=; b=b7Hn00qtQO1krzEITl0y0JaUZxp+ILLicQ4rzyg0ZDe2avLR8NHlKA/E9sUKntlu5C+gOujq76w8Iflbh9pjFJkal/7NwrZpRKBlfQG55AU325qjLBpaxggelNZ9HAPVNrwLiyebyPIUUgIeWIMPLe3oPUnH1LU/kLbTxMzABX3yDJz5vth1q6+tEBY3Lr2X4JuXxPtboXazSK9mT3Ek4kWk2MdrV7t4UxyPtAFosWPpo0LSxiZmI6F++ck2GsuRLmATqxjNvNh5LKAvOaZtHs29xiMqOk9f+8k2HwlDxLScsa2kQHcim3ES6hbpItSEPQDaV6eaQT0yY07/DJllMg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=amd.com; dmarc=pass action=none header.from=amd.com; dkim=pass header.d=amd.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector2-amdcloud-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=e8tOYs/P0C1jrZrSMZd/iU96wMxYNdNq6HLU+AkCY90=; b=RCYQHKM5Dcr45m+33XB693lt199SKf5gLNomp6UPhGXL/eHqrsR/BhZW9sGSUOuvBufPcA9S+8g7i1QlIbCVFv/+J11BQp0NnfWZLLOJqqXHzF0sVhhlN6+S+snxROvIqqBIvJQ4WBTZ9OHuI2HrpYkXvZBT1klbpdz1i+/Pqek= Received: from SN6PR12MB2639.namprd12.prod.outlook.com (52.135.103.16) by SN6PR12MB2829.namprd12.prod.outlook.com (20.177.250.142) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2178.18; Thu, 22 Aug 2019 18:51:36 +0000 Received: from SN6PR12MB2639.namprd12.prod.outlook.com ([fe80::d0b4:a849:c22b:3b53]) by SN6PR12MB2639.namprd12.prod.outlook.com ([fe80::d0b4:a849:c22b:3b53%2]) with mapi id 15.20.2178.020; Thu, 22 Aug 2019 18:51:35 +0000 From: "Ghannam, Yazen" To: "linux-edac@vger.kernel.org" CC: "Ghannam, Yazen" , "linux-kernel@vger.kernel.org" , "bp@alien8.de" Subject: [RFC PATCH v2] EDAC/amd64: Check for memory before fully initializing an instance Thread-Topic: [RFC PATCH v2] EDAC/amd64: Check for memory before fully initializing an instance Thread-Index: AQHVWRqf0jl/DMf26EebTiGpQW84oA== Date: Thu, 22 Aug 2019 18:51:35 +0000 Message-ID: <20190822185123.189179-1-Yazen.Ghannam@amd.com> References: <20190821235938.118710-11-Yazen.Ghannam@amd.com> In-Reply-To: <20190821235938.118710-11-Yazen.Ghannam@amd.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-clientproxiedby: SN4PR0201CA0052.namprd02.prod.outlook.com (2603:10b6:803:20::14) To SN6PR12MB2639.namprd12.prod.outlook.com (2603:10b6:805:6f::16) authentication-results: spf=none (sender IP is ) smtp.mailfrom=Yazen.Ghannam@amd.com; x-ms-exchange-messagesentrepresentingtype: 1 x-mailer: git-send-email 2.17.1 x-originating-ip: [165.204.78.2] x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: 27c4371d-f897-41cc-6d9a-08d72731c1f6 x-ms-office365-filtering-ht: Tenant x-microsoft-antispam: BCL:0;PCL:0;RULEID:(2390118)(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600166)(711020)(4605104)(1401327)(4618075)(2017052603328)(7193020);SRVR:SN6PR12MB2829; x-ms-traffictypediagnostic: SN6PR12MB2829: x-ms-exchange-purlcount: 1 x-ms-exchange-transport-forked: True x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:7219; x-forefront-prvs: 01371B902F x-forefront-antispam-report: SFV:NSPM;SFS:(10009020)(4636009)(396003)(136003)(376002)(39860400002)(346002)(366004)(199004)(189003)(50226002)(2906002)(186003)(6116002)(36756003)(3846002)(8936002)(11346002)(478600001)(53936002)(14454004)(316002)(25786009)(26005)(6486002)(6506007)(7736002)(6916009)(102836004)(386003)(5640700003)(476003)(2616005)(486006)(446003)(6436002)(305945005)(6512007)(6306002)(81166006)(81156014)(8676002)(256004)(66446008)(14444005)(66556008)(64756008)(66476007)(66946007)(5660300002)(76176011)(54906003)(1076003)(2351001)(66066001)(52116002)(4326008)(86362001)(99286004)(2501003)(966005)(71190400001)(71200400001);DIR:OUT;SFP:1101;SCL:1;SRVR:SN6PR12MB2829;H:SN6PR12MB2639.namprd12.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;A:1;MX:1; received-spf: None (protection.outlook.com: amd.com does not designate permitted sender hosts) x-ms-exchange-senderadcheck: 1 x-microsoft-antispam-message-info: u9HzuiQp4LqAhQrxIyIHRwAe3T40MeYlZcYrCYqg3SvjVBIqNo9EIy15z2wd0RTzBV+BD3mmrpgIpq9SwtM1yuHz0R8sFzeZLROv6NW1QbaiPcuJWgBJDBTfCNGnr7xBQMIuNzOKx4D0PpvaTG/trLhwdnvfUzgGNlGivSHaKmiLE7ood2ilz4Gau/2W2oFIpnXKF1WPDzgzBfoQRlcQYA8MvSs2bwe77ZfYIauryOy2C51CDyjUkIrX/sweg8VMNEDLUO8TLrvfSeOJ22Qr57C0xi/kuDopzLc3WsvTKBY/IUGkTw1j8mFq8NlW76iuya/zuQinZgcoAqkUDc54ORlqDCDhOk4VAVMmOArl9d+/mX5W67Qa+30xSc2SNpDpkG5LSnfiEZzTpba9DGmr8wSGXbzzpXgsM+HfjmffDew= Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-Network-Message-Id: 27c4371d-f897-41cc-6d9a-08d72731c1f6 X-MS-Exchange-CrossTenant-originalarrivaltime: 22 Aug 2019 18:51:35.8856 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: QHsVHx5x23XqUuErwlmfi4IC+8r6u8ueBDe9Z+LB4cJpz4JUN2ohnpCNVgSXL4cDAUwuA3iRGia/w+5R4k3OrQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN6PR12MB2829 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Yazen Ghannam Return early before checking for ECC if the node does not have any populated memory. Free any cached hardware data before returning. Also, return 0 in this case since this is not a failure. Other nodes may have memory and the module should attempt to load an instance for them. Move printing of hardware information to after the instance is initialized, so that the information is only printed for nodes with memory. Signed-off-by: Yazen Ghannam --- Link: https://lkml.kernel.org/r/20190821235938.118710-11-Yazen.Ghannam@amd.com v1->v2: * Moved hardware info printing to after instance is initialized. * Added message for when instance has no memory. drivers/edac/amd64_edac.c | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/drivers/edac/amd64_edac.c b/drivers/edac/amd64_edac.c index c1cb0234f085..3f0fe6ed1fa3 100644 --- a/drivers/edac/amd64_edac.c +++ b/drivers/edac/amd64_edac.c @@ -2831,8 +2831,6 @@ static void read_mc_regs(struct amd64_pvt *pvt) edac_dbg(1, " DIMM type: %s\n", edac_mem_types[pvt->dram_type]); =20 determine_ecc_sym_sz(pvt); - - dump_misc_regs(pvt); } =20 /* @@ -3505,6 +3503,23 @@ static int init_one_instance(struct amd64_pvt *pvt, return ret; } =20 +static bool instance_has_memory(struct amd64_pvt *pvt) +{ + bool cs_enabled =3D false; + int num_channels =3D 2; + int cs =3D 0, dct =3D 0; + + if (pvt->umc) + num_channels =3D num_umcs; + + for (dct =3D 0; dct < num_channels; dct++) { + for_each_chip_select(cs, dct, pvt) + cs_enabled |=3D csrow_enabled(cs, dct, pvt); + } + + return cs_enabled; +} + static int probe_one_instance(unsigned int nid) { struct pci_dev *F3 =3D node_to_amd_nb(nid)->misc; @@ -3535,6 +3550,12 @@ static int probe_one_instance(unsigned int nid) if (ret < 0) goto err_enable; =20 + ret =3D 0; + if (!instance_has_memory(pvt)) { + amd64_warn("Node %d: DRAM ECC disabled. No DIMMs detected.\n", nid); + goto err_enable; + } + if (!ecc_enabled(pvt)) { ret =3D 0; =20 @@ -3561,6 +3582,8 @@ static int probe_one_instance(unsigned int nid) goto err_enable; } =20 + dump_misc_regs(pvt); + return ret; =20 err_enable: --=20 2.17.1