Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp97894ybp; Thu, 3 Oct 2019 10:43:19 -0700 (PDT) X-Google-Smtp-Source: APXvYqzR3VKaz0HmZgtJk/NkSygWq/bXQB6PebTvbLCJqv4qhA9h7klxpIPQXIFMHYpYcT/p36uH X-Received: by 2002:a17:906:6d53:: with SMTP id a19mr1197681ejt.332.1570124599413; Thu, 03 Oct 2019 10:43:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570124599; cv=none; d=google.com; s=arc-20160816; b=D9/vZCQ6wloSe2UxIG/bLg/0cvmZ+LqqOKZWvS75/LoVBRhvdhzUr0UcF9+8igxBN8 hrxMBhN1aycm2hNWirR1p4h/z1L1W7blHFMGXr682sf5eTptMQ2WbToWbgWeVHNhmpXn NdJwNNlSkMztqRIHqTSZPaTwPRCxDwracbAlp9hZcPYd+5usnR7Idp0RTD10auoZM3Fu pC8TKOj/jxlPbuCHosX9nw9izL3ZfQW3z7RsgWBMocUPA2X1CTSHPRuDYfhvXNddq4OT hNmHrVSjxNnsG7P0CU8+bPRQqYtygbEByQrzKrNtMFyeQCAiCrmJQ/Vg5inCJex+bt6s Ertg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=x8UnZ6J2TF15JOMvF6wEOvAst/kEfkmVOElqBE+ICxM=; b=0ALfa2CnqNshCx2hOEPtsjW8XmdfQcHOal0eRp+LoRq1Pcz7YYWJzswoq1eUKAfS0u wkPHEVhS/apQLBbIJxXrgOX2ZiN2qJKtUnhJcsPhUvoSSBPBkyJjrpjE85DeGK9xCgiB NvzEvwBs53J5WBVGZzGd35zrbNZbEzdQSPlRgr/ad/r7fCcxWognXYkP/mZ7ZiLfzhVy BA0R1YdrWTPA4HWQLXALKmkV/Gtm4xUtJWWVzT2f2RDexF9kZvVKJrAbFbOS119H91ku wLJFW6bj4xfHVyQTXb+LMDOa40hZ83H4JM0aytbIHyqiBg0TlDhadu1mrrhUj9QvhEwa x9sQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=nGp4JxFN; 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 sa16si1664931ejb.356.2019.10.03.10.42.54; Thu, 03 Oct 2019 10:43:19 -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=@kernel.org header.s=default header.b=nGp4JxFN; 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 S2390780AbfJCRVv (ORCPT + 99 others); Thu, 3 Oct 2019 13:21:51 -0400 Received: from mail.kernel.org ([198.145.29.99]:42844 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389194AbfJCQRO (ORCPT ); Thu, 3 Oct 2019 12:17:14 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 908C6215EA; Thu, 3 Oct 2019 16:17:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1570119433; bh=UDD8sBr9Lf8VkPIkqzpY18KqMnR+dQy/Zhx49ox6gEE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=nGp4JxFNA1ctLuflu7TTW5hKTDAEEqkGQsWpvGb4KHbdwmmylUPjpxct38OlnQG/1 vs88IJ5aQ9kBmgwO1ycEeeFjNGGMKcO5kahAsCYOkkjiON+VLMzdYLuz5H3knf4MYO 3DIgwJpXm2zlumXUTQlwRLi3z9TjryvCcWXkvBGs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Xiaofei Tan , James Morse , Ard Biesheuvel , Sasha Levin Subject: [PATCH 4.19 062/211] efi: cper: print AER info of PCIe fatal error Date: Thu, 3 Oct 2019 17:52:08 +0200 Message-Id: <20191003154502.695723056@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191003154447.010950442@linuxfoundation.org> References: <20191003154447.010950442@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Xiaofei Tan [ Upstream commit b194a77fcc4001dc40aecdd15d249648e8a436d1 ] AER info of PCIe fatal error is not printed in the current driver. Because APEI driver will panic directly for fatal error, and can't run to the place of printing AER info. An example log is as following: {763}[Hardware Error]: Hardware error from APEI Generic Hardware Error Source: 11 {763}[Hardware Error]: event severity: fatal {763}[Hardware Error]: Error 0, type: fatal {763}[Hardware Error]: section_type: PCIe error {763}[Hardware Error]: port_type: 0, PCIe end point {763}[Hardware Error]: version: 4.0 {763}[Hardware Error]: command: 0x0000, status: 0x0010 {763}[Hardware Error]: device_id: 0000:82:00.0 {763}[Hardware Error]: slot: 0 {763}[Hardware Error]: secondary_bus: 0x00 {763}[Hardware Error]: vendor_id: 0x8086, device_id: 0x10fb {763}[Hardware Error]: class_code: 000002 Kernel panic - not syncing: Fatal hardware error! This issue was imported by the patch, '37448adfc7ce ("aerdrv: Move cper_print_aer() call out of interrupt context")'. To fix this issue, this patch adds print of AER info in cper_print_pcie() for fatal error. Here is the example log after this patch applied: {24}[Hardware Error]: Hardware error from APEI Generic Hardware Error Source: 10 {24}[Hardware Error]: event severity: fatal {24}[Hardware Error]: Error 0, type: fatal {24}[Hardware Error]: section_type: PCIe error {24}[Hardware Error]: port_type: 0, PCIe end point {24}[Hardware Error]: version: 4.0 {24}[Hardware Error]: command: 0x0546, status: 0x4010 {24}[Hardware Error]: device_id: 0000:01:00.0 {24}[Hardware Error]: slot: 0 {24}[Hardware Error]: secondary_bus: 0x00 {24}[Hardware Error]: vendor_id: 0x15b3, device_id: 0x1019 {24}[Hardware Error]: class_code: 000002 {24}[Hardware Error]: aer_uncor_status: 0x00040000, aer_uncor_mask: 0x00000000 {24}[Hardware Error]: aer_uncor_severity: 0x00062010 {24}[Hardware Error]: TLP Header: 000000c0 01010000 00000001 00000000 Kernel panic - not syncing: Fatal hardware error! Fixes: 37448adfc7ce ("aerdrv: Move cper_print_aer() call out of interrupt context") Signed-off-by: Xiaofei Tan Reviewed-by: James Morse [ardb: put parens around terms of && operator] Signed-off-by: Ard Biesheuvel Signed-off-by: Sasha Levin --- drivers/firmware/efi/cper.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/drivers/firmware/efi/cper.c b/drivers/firmware/efi/cper.c index 6090d25dce85e..4045098ddb860 100644 --- a/drivers/firmware/efi/cper.c +++ b/drivers/firmware/efi/cper.c @@ -402,6 +402,21 @@ static void cper_print_pcie(const char *pfx, const struct cper_sec_pcie *pcie, printk( "%s""bridge: secondary_status: 0x%04x, control: 0x%04x\n", pfx, pcie->bridge.secondary_status, pcie->bridge.control); + + /* Fatal errors call __ghes_panic() before AER handler prints this */ + if ((pcie->validation_bits & CPER_PCIE_VALID_AER_INFO) && + (gdata->error_severity & CPER_SEV_FATAL)) { + struct aer_capability_regs *aer; + + aer = (struct aer_capability_regs *)pcie->aer_info; + printk("%saer_uncor_status: 0x%08x, aer_uncor_mask: 0x%08x\n", + pfx, aer->uncor_status, aer->uncor_mask); + printk("%saer_uncor_severity: 0x%08x\n", + pfx, aer->uncor_severity); + printk("%sTLP Header: %08x %08x %08x %08x\n", pfx, + aer->header_log.dw0, aer->header_log.dw1, + aer->header_log.dw2, aer->header_log.dw3); + } } static void cper_print_tstamp(const char *pfx, -- 2.20.1