162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/******************************************************************************
362306a36Sopenharmony_ci *
462306a36Sopenharmony_ci * Copyright(c) 2009 - 2014 Intel Corporation. All rights reserved.
562306a36Sopenharmony_ci * Copyright(c) 2016-2017 Intel Deutschland GmbH
662306a36Sopenharmony_ci *****************************************************************************/
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#if !defined(__IWLWIFI_DEVICE_TRACE_IO) || defined(TRACE_HEADER_MULTI_READ)
962306a36Sopenharmony_ci#define __IWLWIFI_DEVICE_TRACE_IO
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <linux/tracepoint.h>
1262306a36Sopenharmony_ci#include <linux/pci.h>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci#undef TRACE_SYSTEM
1562306a36Sopenharmony_ci#define TRACE_SYSTEM iwlwifi_io
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_ioread32,
1862306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u32 offs, u32 val),
1962306a36Sopenharmony_ci	TP_ARGS(dev, offs, val),
2062306a36Sopenharmony_ci	TP_STRUCT__entry(
2162306a36Sopenharmony_ci		DEV_ENTRY
2262306a36Sopenharmony_ci		__field(u32, offs)
2362306a36Sopenharmony_ci		__field(u32, val)
2462306a36Sopenharmony_ci	),
2562306a36Sopenharmony_ci	TP_fast_assign(
2662306a36Sopenharmony_ci		DEV_ASSIGN;
2762306a36Sopenharmony_ci		__entry->offs = offs;
2862306a36Sopenharmony_ci		__entry->val = val;
2962306a36Sopenharmony_ci	),
3062306a36Sopenharmony_ci	TP_printk("[%s] read io[%#x] = %#x",
3162306a36Sopenharmony_ci		  __get_str(dev), __entry->offs, __entry->val)
3262306a36Sopenharmony_ci);
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_iowrite8,
3562306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u32 offs, u8 val),
3662306a36Sopenharmony_ci	TP_ARGS(dev, offs, val),
3762306a36Sopenharmony_ci	TP_STRUCT__entry(
3862306a36Sopenharmony_ci		DEV_ENTRY
3962306a36Sopenharmony_ci		__field(u32, offs)
4062306a36Sopenharmony_ci		__field(u8, val)
4162306a36Sopenharmony_ci	),
4262306a36Sopenharmony_ci	TP_fast_assign(
4362306a36Sopenharmony_ci		DEV_ASSIGN;
4462306a36Sopenharmony_ci		__entry->offs = offs;
4562306a36Sopenharmony_ci		__entry->val = val;
4662306a36Sopenharmony_ci	),
4762306a36Sopenharmony_ci	TP_printk("[%s] write io[%#x] = %#x)",
4862306a36Sopenharmony_ci		  __get_str(dev), __entry->offs, __entry->val)
4962306a36Sopenharmony_ci);
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_iowrite32,
5262306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u32 offs, u32 val),
5362306a36Sopenharmony_ci	TP_ARGS(dev, offs, val),
5462306a36Sopenharmony_ci	TP_STRUCT__entry(
5562306a36Sopenharmony_ci		DEV_ENTRY
5662306a36Sopenharmony_ci		__field(u32, offs)
5762306a36Sopenharmony_ci		__field(u32, val)
5862306a36Sopenharmony_ci	),
5962306a36Sopenharmony_ci	TP_fast_assign(
6062306a36Sopenharmony_ci		DEV_ASSIGN;
6162306a36Sopenharmony_ci		__entry->offs = offs;
6262306a36Sopenharmony_ci		__entry->val = val;
6362306a36Sopenharmony_ci	),
6462306a36Sopenharmony_ci	TP_printk("[%s] write io[%#x] = %#x)",
6562306a36Sopenharmony_ci		  __get_str(dev), __entry->offs, __entry->val)
6662306a36Sopenharmony_ci);
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_iowrite64,
6962306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u64 offs, u64 val),
7062306a36Sopenharmony_ci	TP_ARGS(dev, offs, val),
7162306a36Sopenharmony_ci	TP_STRUCT__entry(
7262306a36Sopenharmony_ci		DEV_ENTRY
7362306a36Sopenharmony_ci		__field(u64, offs)
7462306a36Sopenharmony_ci		__field(u64, val)
7562306a36Sopenharmony_ci	),
7662306a36Sopenharmony_ci	TP_fast_assign(
7762306a36Sopenharmony_ci		DEV_ASSIGN;
7862306a36Sopenharmony_ci		__entry->offs = offs;
7962306a36Sopenharmony_ci		__entry->val = val;
8062306a36Sopenharmony_ci	),
8162306a36Sopenharmony_ci	TP_printk("[%s] write io[%llu] = %llu)",
8262306a36Sopenharmony_ci		  __get_str(dev), __entry->offs, __entry->val)
8362306a36Sopenharmony_ci);
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_iowrite_prph32,
8662306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u32 offs, u32 val),
8762306a36Sopenharmony_ci	TP_ARGS(dev, offs, val),
8862306a36Sopenharmony_ci	TP_STRUCT__entry(
8962306a36Sopenharmony_ci		DEV_ENTRY
9062306a36Sopenharmony_ci		__field(u32, offs)
9162306a36Sopenharmony_ci		__field(u32, val)
9262306a36Sopenharmony_ci	),
9362306a36Sopenharmony_ci	TP_fast_assign(
9462306a36Sopenharmony_ci		DEV_ASSIGN;
9562306a36Sopenharmony_ci		__entry->offs = offs;
9662306a36Sopenharmony_ci		__entry->val = val;
9762306a36Sopenharmony_ci	),
9862306a36Sopenharmony_ci	TP_printk("[%s] write PRPH[%#x] = %#x)",
9962306a36Sopenharmony_ci		  __get_str(dev), __entry->offs, __entry->val)
10062306a36Sopenharmony_ci);
10162306a36Sopenharmony_ci
10262306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_iowrite_prph64,
10362306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u64 offs, u64 val),
10462306a36Sopenharmony_ci	TP_ARGS(dev, offs, val),
10562306a36Sopenharmony_ci	TP_STRUCT__entry(
10662306a36Sopenharmony_ci		DEV_ENTRY
10762306a36Sopenharmony_ci		__field(u64, offs)
10862306a36Sopenharmony_ci		__field(u64, val)
10962306a36Sopenharmony_ci	),
11062306a36Sopenharmony_ci	TP_fast_assign(
11162306a36Sopenharmony_ci		DEV_ASSIGN;
11262306a36Sopenharmony_ci		__entry->offs = offs;
11362306a36Sopenharmony_ci		__entry->val = val;
11462306a36Sopenharmony_ci	),
11562306a36Sopenharmony_ci	TP_printk("[%s] write PRPH[%llu] = %llu)",
11662306a36Sopenharmony_ci		  __get_str(dev), __entry->offs, __entry->val)
11762306a36Sopenharmony_ci);
11862306a36Sopenharmony_ci
11962306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_ioread_prph32,
12062306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u32 offs, u32 val),
12162306a36Sopenharmony_ci	TP_ARGS(dev, offs, val),
12262306a36Sopenharmony_ci	TP_STRUCT__entry(
12362306a36Sopenharmony_ci		DEV_ENTRY
12462306a36Sopenharmony_ci		__field(u32, offs)
12562306a36Sopenharmony_ci		__field(u32, val)
12662306a36Sopenharmony_ci	),
12762306a36Sopenharmony_ci	TP_fast_assign(
12862306a36Sopenharmony_ci		DEV_ASSIGN;
12962306a36Sopenharmony_ci		__entry->offs = offs;
13062306a36Sopenharmony_ci		__entry->val = val;
13162306a36Sopenharmony_ci	),
13262306a36Sopenharmony_ci	TP_printk("[%s] read PRPH[%#x] = %#x",
13362306a36Sopenharmony_ci		  __get_str(dev), __entry->offs, __entry->val)
13462306a36Sopenharmony_ci);
13562306a36Sopenharmony_ci
13662306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_irq,
13762306a36Sopenharmony_ci	TP_PROTO(const struct device *dev),
13862306a36Sopenharmony_ci	TP_ARGS(dev),
13962306a36Sopenharmony_ci	TP_STRUCT__entry(
14062306a36Sopenharmony_ci		DEV_ENTRY
14162306a36Sopenharmony_ci	),
14262306a36Sopenharmony_ci	TP_fast_assign(
14362306a36Sopenharmony_ci		DEV_ASSIGN;
14462306a36Sopenharmony_ci	),
14562306a36Sopenharmony_ci	/* TP_printk("") doesn't compile */
14662306a36Sopenharmony_ci	TP_printk("%d", 0)
14762306a36Sopenharmony_ci);
14862306a36Sopenharmony_ci
14962306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_irq_msix,
15062306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, struct msix_entry *msix_entry,
15162306a36Sopenharmony_ci		 bool defirq, u32 inta_fh, u32 inta_hw),
15262306a36Sopenharmony_ci	TP_ARGS(dev, msix_entry, defirq, inta_fh, inta_hw),
15362306a36Sopenharmony_ci	TP_STRUCT__entry(
15462306a36Sopenharmony_ci		DEV_ENTRY
15562306a36Sopenharmony_ci		__field(u32, entry)
15662306a36Sopenharmony_ci		__field(u8, defirq)
15762306a36Sopenharmony_ci		__field(u32, inta_fh)
15862306a36Sopenharmony_ci		__field(u32, inta_hw)
15962306a36Sopenharmony_ci	),
16062306a36Sopenharmony_ci	TP_fast_assign(
16162306a36Sopenharmony_ci		DEV_ASSIGN;
16262306a36Sopenharmony_ci		__entry->entry = msix_entry->entry;
16362306a36Sopenharmony_ci		__entry->defirq = defirq;
16462306a36Sopenharmony_ci		__entry->inta_fh = inta_fh;
16562306a36Sopenharmony_ci		__entry->inta_hw = inta_hw;
16662306a36Sopenharmony_ci	),
16762306a36Sopenharmony_ci	TP_printk("entry:%d defirq:%d fh:0x%x, hw:0x%x",
16862306a36Sopenharmony_ci		  __entry->entry, __entry->defirq,
16962306a36Sopenharmony_ci		  __entry->inta_fh, __entry->inta_hw)
17062306a36Sopenharmony_ci);
17162306a36Sopenharmony_ci
17262306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_ict_read,
17362306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, u32 index, u32 value),
17462306a36Sopenharmony_ci	TP_ARGS(dev, index, value),
17562306a36Sopenharmony_ci	TP_STRUCT__entry(
17662306a36Sopenharmony_ci		DEV_ENTRY
17762306a36Sopenharmony_ci		__field(u32, index)
17862306a36Sopenharmony_ci		__field(u32, value)
17962306a36Sopenharmony_ci	),
18062306a36Sopenharmony_ci	TP_fast_assign(
18162306a36Sopenharmony_ci		DEV_ASSIGN;
18262306a36Sopenharmony_ci		__entry->index = index;
18362306a36Sopenharmony_ci		__entry->value = value;
18462306a36Sopenharmony_ci	),
18562306a36Sopenharmony_ci	TP_printk("[%s] read ict[%d] = %#.8x",
18662306a36Sopenharmony_ci		  __get_str(dev), __entry->index, __entry->value)
18762306a36Sopenharmony_ci);
18862306a36Sopenharmony_ci#endif /* __IWLWIFI_DEVICE_TRACE_IO */
18962306a36Sopenharmony_ci
19062306a36Sopenharmony_ci#undef TRACE_INCLUDE_PATH
19162306a36Sopenharmony_ci#define TRACE_INCLUDE_PATH .
19262306a36Sopenharmony_ci#undef TRACE_INCLUDE_FILE
19362306a36Sopenharmony_ci#define TRACE_INCLUDE_FILE iwl-devtrace-io
19462306a36Sopenharmony_ci#include <trace/define_trace.h>
195