Received: by 10.192.165.148 with SMTP id m20csp4302333imm; Tue, 8 May 2018 06:25:39 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrppcCAlZfQRXfS+aBOAAtQbKQX3OOucGTfmzZUPE4SNS+RNGljdev/FqKqmwLILUEnvrzz X-Received: by 2002:a65:4e03:: with SMTP id r3-v6mr33273477pgt.121.1525785939185; Tue, 08 May 2018 06:25:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525785939; cv=none; d=google.com; s=arc-20160816; b=apQlesa0LzfTS0M6JAzJJNLgAa0NyWXaVxkrJVq17GCiqlVXaQd7ufBS3vGr0W+PD7 nOVKjCuL1uC8iXxe4QCzurUd+xqFihNRZ4wrroPlsOJdaDxtO3DI/Wq1Jw2vycy5RlHl e/G5OdvGJMIoQWBnnYfsNUL+0mxZuA+1bKNWuWNEXqdeh7PjT65KYsC+DccmIYFHWoYW PANMzwGNJhV1CJ0uS+cQ8l6mqolvBVGaK6Ah59h1He609NefiLweqqfwtVsPZCxNWrtV iWNMYUAikEdbJ7clpwknh5bSCTlSwPN7r/mBNuWcDlh2x8zg9u+lP955eHqRQzZZL/dZ 32zw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:cc:to:subject :dkim-signature:arc-authentication-results; bh=qbS1fLG4drNy1K989LAKDAXCGDo99rFdNLinFXkjfD8=; b=yOwH8jln0fUUlT/SMGZlYkr2NQ0i4TOP/r8IOmakDvuww62BoDBrpE20vV8UVovQuy X3Iynsb9Le0mC2t9XHdxoZHmMCVw9l5JaLHyFrAmPWvdc7aQ36NUsEE/nS8vle5C6kEP r860o5GF+eLktJIxDG7M2R+Y8SkoP6odkeFyuo/SoB28m1uQQzi3/0QooFa3F8zH7bju ka8H0Jx+5p1Wj+bfHX0eKsidZfby2ZWlPli0b6UzW7R/7bJTe+N1GgRzWrdH5qwerLaa yjhUuyZ7Ktm37hqODS/BuSrl0KqS40oGRQU9e1e8g+2HfAvaGqplCGKp6ubHa5BCKSMu eQCw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2017-10-26 header.b=fW09hlvZ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l4-v6si19318806pgo.678.2018.05.08.06.25.24; Tue, 08 May 2018 06:25:39 -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=@oracle.com header.s=corp-2017-10-26 header.b=fW09hlvZ; 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=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754718AbeEHNZM (ORCPT + 99 others); Tue, 8 May 2018 09:25:12 -0400 Received: from aserp2120.oracle.com ([141.146.126.78]:34890 "EHLO aserp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751874AbeEHNZK (ORCPT ); Tue, 8 May 2018 09:25:10 -0400 Received: from pps.filterd (aserp2120.oracle.com [127.0.0.1]) by aserp2120.oracle.com (8.16.0.22/8.16.0.22) with SMTP id w48DLUlr122607; Tue, 8 May 2018 13:25:05 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=corp-2017-10-26; bh=qbS1fLG4drNy1K989LAKDAXCGDo99rFdNLinFXkjfD8=; b=fW09hlvZilRLf5ZVDJyJTWlDc2WIsdEsvQ/lAzLLjZR8aUMGi5hlwdaMqiWxHYVvi0Te aLT+yfaxBL7eSKyobPop6okLQCEuEMxf2B4fU7+r4HQtp0ks4MbREtY0C7/aco2rP40R 81yaOewQX3L5eK9y0Buza0lFarWF+zv/pbb/oRkaedWXW5HZBlBbdFNjpH+5KdJs6tI+ NPYtkojAh2yXIjG0rQgsd+gB7Kjbveh3WVYqwsV5lEP0q5So37L7oVPbZ5ey8FcDKyLX r2aaD3HN0ZQdqsV1M2B+8r3t7ecy8LoHcKRAz+K5lCFKZeFsUOVaH30op5yvRgC4/bt8 Jg== Received: from userv0021.oracle.com (userv0021.oracle.com [156.151.31.71]) by aserp2120.oracle.com with ESMTP id 2hs4k28j09-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 08 May 2018 13:25:05 +0000 Received: from userv0122.oracle.com (userv0122.oracle.com [156.151.31.75]) by userv0021.oracle.com (8.14.4/8.14.4) with ESMTP id w48DP4Ea018351 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 8 May 2018 13:25:04 GMT Received: from abhmp0002.oracle.com (abhmp0002.oracle.com [141.146.116.8]) by userv0122.oracle.com (8.14.4/8.14.4) with ESMTP id w48DP3dC032026; Tue, 8 May 2018 13:25:03 GMT Received: from [10.39.224.213] (/10.39.224.213) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Tue, 08 May 2018 06:25:03 -0700 Subject: Re: [PATCH] PCI/AER: add pcie TLP header information in the tracepoint To: Steven Rostedt , Bjorn Helgaas Cc: bhelgaas@google.com, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, Alexandru Gagniuc References: <20180402154708.5032-1-thomas.tai@oracle.com> <20180507222136.GD161390@bhelgaas-glaptop.roam.corp.google.com> <20180508090756.57f38d17@gandalf.local.home> From: Thomas Tai Organization: Oracle Corporation Message-ID: Date: Tue, 8 May 2018 09:25:01 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180508090756.57f38d17@gandalf.local.home> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=8886 signatures=668698 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 suspectscore=0 malwarescore=0 phishscore=0 bulkscore=0 spamscore=0 mlxscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1711220000 definitions=main-1805080129 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [ ... ] >>> --- a/include/ras/ras_event.h >>> +++ b/include/ras/ras_event.h >>> @@ -298,30 +298,42 @@ TRACE_EVENT(non_standard_event, >>> TRACE_EVENT(aer_event, >>> TP_PROTO(const char *dev_name, >>> const u32 status, >>> - const u8 severity), >>> + const u8 severity, >>> + const u32 tlp_header_valid, >>> + struct aer_header_log_regs *tlp), >>> >>> - TP_ARGS(dev_name, status, severity), >>> + TP_ARGS(dev_name, status, severity, tlp_header_valid, tlp), >>> >>> TP_STRUCT__entry( >>> __string( dev_name, dev_name ) >>> __field( u32, status ) >>> __field( u8, severity ) >>> + __field( u32, tlp_header_valid) > > I'm guessing tlp_header_valid is just a boolean. It's after severity > which is just one byte long. Why not make this one byte as well, > otherwise you are wasting 3 bytes. Thanks Steven. Yes boolean is fine. > > >>> + __array( u32, buf, 4 ) >>> ), >>> >>> TP_fast_assign( >>> __assign_str(dev_name, dev_name); >>> __entry->status = status; >>> __entry->severity = severity; >>> + __entry->tlp_header_valid = tlp_header_valid; > >>> + __entry->buf[0] = tlp->dw0; >>> + __entry->buf[1] = tlp->dw1; >>> + __entry->buf[2] = tlp->dw2; >>> + __entry->buf[3] = tlp->dw3; > > Should this assignment be dependent on whether or not tlp_header_valid > is true? Could tlp be pointing to some random memory if it isn't? What > about: Good catch! will do so. > > if ((__entry->tlp_header_valid = tlp_header_valid)) { > __entry->buf[0] = tlp->dw0; > __entry->buf[1] = tlp->dw1; > __entry->buf[2] = tlp->dw2; > __entry->buf[3] = tlp->dw3; > } > > >>> ), >>> >>> - TP_printk("%s PCIe Bus Error: severity=%s, %s\n", >>> + TP_printk("%s PCIe Bus Error: severity=%s, %s, TLP Header=%s\n", >>> __get_str(dev_name), >>> __entry->severity == AER_CORRECTABLE ? "Corrected" : >>> __entry->severity == AER_FATAL ? >>> "Fatal" : "Uncorrected, non-fatal", >>> __entry->severity == AER_CORRECTABLE ? >>> __print_flags(__entry->status, "|", aer_correctable_errors) : >>> - __print_flags(__entry->status, "|", aer_uncorrectable_errors)) >>> + __print_flags(__entry->status, "|", aer_uncorrectable_errors), >>> + __entry->tlp_header_valid ? >>> + __print_array(__entry->buf, 4, sizeof(unsigned int)) : > > Note, "sizeof" will be shown in the format file that perf and trace-cmd > read to parse this event. They currently do not know how to parse that > (although I could add that in the future). > > Since sizeof(unsigned int) is always 4 in Linux, just use 4. Yes, I will make the aboves changes and send out V2 patch. Thank you for your time and comments. Thomas > > __print_array(__entry->buf, 4, 4) > > -- Steve > > >>> + "Not available") >>> ); >>> >>> /* >>> -- >>> 2.14.1 >>> >