18c2ecf20Sopenharmony_ci/* 28c2ecf20Sopenharmony_ci* Copyright(c) 2015, 2016 Intel Corporation. 38c2ecf20Sopenharmony_ci* 48c2ecf20Sopenharmony_ci* This file is provided under a dual BSD/GPLv2 license. When using or 58c2ecf20Sopenharmony_ci* redistributing this file, you may do so under either license. 68c2ecf20Sopenharmony_ci* 78c2ecf20Sopenharmony_ci* GPL LICENSE SUMMARY 88c2ecf20Sopenharmony_ci* 98c2ecf20Sopenharmony_ci* This program is free software; you can redistribute it and/or modify 108c2ecf20Sopenharmony_ci* it under the terms of version 2 of the GNU General Public License as 118c2ecf20Sopenharmony_ci* published by the Free Software Foundation. 128c2ecf20Sopenharmony_ci* 138c2ecf20Sopenharmony_ci* This program is distributed in the hope that it will be useful, but 148c2ecf20Sopenharmony_ci* WITHOUT ANY WARRANTY; without even the implied warranty of 158c2ecf20Sopenharmony_ci* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 168c2ecf20Sopenharmony_ci* General Public License for more details. 178c2ecf20Sopenharmony_ci* 188c2ecf20Sopenharmony_ci* BSD LICENSE 198c2ecf20Sopenharmony_ci* 208c2ecf20Sopenharmony_ci* Redistribution and use in source and binary forms, with or without 218c2ecf20Sopenharmony_ci* modification, are permitted provided that the following conditions 228c2ecf20Sopenharmony_ci* are met: 238c2ecf20Sopenharmony_ci* 248c2ecf20Sopenharmony_ci* - Redistributions of source code must retain the above copyright 258c2ecf20Sopenharmony_ci* notice, this list of conditions and the following disclaimer. 268c2ecf20Sopenharmony_ci* - Redistributions in binary form must reproduce the above copyright 278c2ecf20Sopenharmony_ci* notice, this list of conditions and the following disclaimer in 288c2ecf20Sopenharmony_ci* the documentation and/or other materials provided with the 298c2ecf20Sopenharmony_ci* distribution. 308c2ecf20Sopenharmony_ci* - Neither the name of Intel Corporation nor the names of its 318c2ecf20Sopenharmony_ci* contributors may be used to endorse or promote products derived 328c2ecf20Sopenharmony_ci* from this software without specific prior written permission. 338c2ecf20Sopenharmony_ci* 348c2ecf20Sopenharmony_ci* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 358c2ecf20Sopenharmony_ci* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 368c2ecf20Sopenharmony_ci* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 378c2ecf20Sopenharmony_ci* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 388c2ecf20Sopenharmony_ci* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 398c2ecf20Sopenharmony_ci* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 408c2ecf20Sopenharmony_ci* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 418c2ecf20Sopenharmony_ci* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 428c2ecf20Sopenharmony_ci* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 438c2ecf20Sopenharmony_ci* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 448c2ecf20Sopenharmony_ci* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 458c2ecf20Sopenharmony_ci* 468c2ecf20Sopenharmony_ci*/ 478c2ecf20Sopenharmony_ci#if !defined(__HFI1_TRACE_MISC_H) || defined(TRACE_HEADER_MULTI_READ) 488c2ecf20Sopenharmony_ci#define __HFI1_TRACE_MISC_H 498c2ecf20Sopenharmony_ci 508c2ecf20Sopenharmony_ci#include <linux/tracepoint.h> 518c2ecf20Sopenharmony_ci#include <linux/trace_seq.h> 528c2ecf20Sopenharmony_ci 538c2ecf20Sopenharmony_ci#include "hfi.h" 548c2ecf20Sopenharmony_ci 558c2ecf20Sopenharmony_ci#undef TRACE_SYSTEM 568c2ecf20Sopenharmony_ci#define TRACE_SYSTEM hfi1_misc 578c2ecf20Sopenharmony_ci 588c2ecf20Sopenharmony_ciTRACE_EVENT(hfi1_interrupt, 598c2ecf20Sopenharmony_ci TP_PROTO(struct hfi1_devdata *dd, const struct is_table *is_entry, 608c2ecf20Sopenharmony_ci int src), 618c2ecf20Sopenharmony_ci TP_ARGS(dd, is_entry, src), 628c2ecf20Sopenharmony_ci TP_STRUCT__entry(DD_DEV_ENTRY(dd) 638c2ecf20Sopenharmony_ci __array(char, buf, 64) 648c2ecf20Sopenharmony_ci __field(int, src) 658c2ecf20Sopenharmony_ci ), 668c2ecf20Sopenharmony_ci TP_fast_assign(DD_DEV_ASSIGN(dd) 678c2ecf20Sopenharmony_ci is_entry->is_name(__entry->buf, 64, 688c2ecf20Sopenharmony_ci src - is_entry->start); 698c2ecf20Sopenharmony_ci __entry->src = src; 708c2ecf20Sopenharmony_ci ), 718c2ecf20Sopenharmony_ci TP_printk("[%s] source: %s [%d]", __get_str(dev), __entry->buf, 728c2ecf20Sopenharmony_ci __entry->src) 738c2ecf20Sopenharmony_ci); 748c2ecf20Sopenharmony_ci 758c2ecf20Sopenharmony_ciDECLARE_EVENT_CLASS( 768c2ecf20Sopenharmony_ci hfi1_csr_template, 778c2ecf20Sopenharmony_ci TP_PROTO(void __iomem *addr, u64 value), 788c2ecf20Sopenharmony_ci TP_ARGS(addr, value), 798c2ecf20Sopenharmony_ci TP_STRUCT__entry( 808c2ecf20Sopenharmony_ci __field(void __iomem *, addr) 818c2ecf20Sopenharmony_ci __field(u64, value) 828c2ecf20Sopenharmony_ci ), 838c2ecf20Sopenharmony_ci TP_fast_assign( 848c2ecf20Sopenharmony_ci __entry->addr = addr; 858c2ecf20Sopenharmony_ci __entry->value = value; 868c2ecf20Sopenharmony_ci ), 878c2ecf20Sopenharmony_ci TP_printk("addr %p value %llx", __entry->addr, __entry->value) 888c2ecf20Sopenharmony_ci); 898c2ecf20Sopenharmony_ci 908c2ecf20Sopenharmony_ciDEFINE_EVENT( 918c2ecf20Sopenharmony_ci hfi1_csr_template, hfi1_write_rcvarray, 928c2ecf20Sopenharmony_ci TP_PROTO(void __iomem *addr, u64 value), 938c2ecf20Sopenharmony_ci TP_ARGS(addr, value)); 948c2ecf20Sopenharmony_ci 958c2ecf20Sopenharmony_ci#ifdef CONFIG_FAULT_INJECTION 968c2ecf20Sopenharmony_ciTRACE_EVENT(hfi1_fault_opcode, 978c2ecf20Sopenharmony_ci TP_PROTO(struct rvt_qp *qp, u8 opcode), 988c2ecf20Sopenharmony_ci TP_ARGS(qp, opcode), 998c2ecf20Sopenharmony_ci TP_STRUCT__entry(DD_DEV_ENTRY(dd_from_ibdev(qp->ibqp.device)) 1008c2ecf20Sopenharmony_ci __field(u32, qpn) 1018c2ecf20Sopenharmony_ci __field(u8, opcode) 1028c2ecf20Sopenharmony_ci ), 1038c2ecf20Sopenharmony_ci TP_fast_assign(DD_DEV_ASSIGN(dd_from_ibdev(qp->ibqp.device)) 1048c2ecf20Sopenharmony_ci __entry->qpn = qp->ibqp.qp_num; 1058c2ecf20Sopenharmony_ci __entry->opcode = opcode; 1068c2ecf20Sopenharmony_ci ), 1078c2ecf20Sopenharmony_ci TP_printk("[%s] qpn 0x%x opcode 0x%x", 1088c2ecf20Sopenharmony_ci __get_str(dev), __entry->qpn, __entry->opcode) 1098c2ecf20Sopenharmony_ci); 1108c2ecf20Sopenharmony_ci 1118c2ecf20Sopenharmony_ciTRACE_EVENT(hfi1_fault_packet, 1128c2ecf20Sopenharmony_ci TP_PROTO(struct hfi1_packet *packet), 1138c2ecf20Sopenharmony_ci TP_ARGS(packet), 1148c2ecf20Sopenharmony_ci TP_STRUCT__entry(DD_DEV_ENTRY(packet->rcd->ppd->dd) 1158c2ecf20Sopenharmony_ci __field(u64, eflags) 1168c2ecf20Sopenharmony_ci __field(u32, ctxt) 1178c2ecf20Sopenharmony_ci __field(u32, hlen) 1188c2ecf20Sopenharmony_ci __field(u32, tlen) 1198c2ecf20Sopenharmony_ci __field(u32, updegr) 1208c2ecf20Sopenharmony_ci __field(u32, etail) 1218c2ecf20Sopenharmony_ci ), 1228c2ecf20Sopenharmony_ci TP_fast_assign(DD_DEV_ASSIGN(packet->rcd->ppd->dd); 1238c2ecf20Sopenharmony_ci __entry->eflags = rhf_err_flags(packet->rhf); 1248c2ecf20Sopenharmony_ci __entry->ctxt = packet->rcd->ctxt; 1258c2ecf20Sopenharmony_ci __entry->hlen = packet->hlen; 1268c2ecf20Sopenharmony_ci __entry->tlen = packet->tlen; 1278c2ecf20Sopenharmony_ci __entry->updegr = packet->updegr; 1288c2ecf20Sopenharmony_ci __entry->etail = rhf_egr_index(packet->rhf); 1298c2ecf20Sopenharmony_ci ), 1308c2ecf20Sopenharmony_ci TP_printk( 1318c2ecf20Sopenharmony_ci "[%s] ctxt %d eflags 0x%llx hlen %d tlen %d updegr %d etail %d", 1328c2ecf20Sopenharmony_ci __get_str(dev), 1338c2ecf20Sopenharmony_ci __entry->ctxt, 1348c2ecf20Sopenharmony_ci __entry->eflags, 1358c2ecf20Sopenharmony_ci __entry->hlen, 1368c2ecf20Sopenharmony_ci __entry->tlen, 1378c2ecf20Sopenharmony_ci __entry->updegr, 1388c2ecf20Sopenharmony_ci __entry->etail 1398c2ecf20Sopenharmony_ci ) 1408c2ecf20Sopenharmony_ci); 1418c2ecf20Sopenharmony_ci#endif 1428c2ecf20Sopenharmony_ci 1438c2ecf20Sopenharmony_ci#endif /* __HFI1_TRACE_MISC_H */ 1448c2ecf20Sopenharmony_ci 1458c2ecf20Sopenharmony_ci#undef TRACE_INCLUDE_PATH 1468c2ecf20Sopenharmony_ci#undef TRACE_INCLUDE_FILE 1478c2ecf20Sopenharmony_ci#define TRACE_INCLUDE_PATH . 1488c2ecf20Sopenharmony_ci#define TRACE_INCLUDE_FILE trace_misc 1498c2ecf20Sopenharmony_ci#include <trace/define_trace.h> 150