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) 2015        Intel Deutschland GmbH
662306a36Sopenharmony_ci * Copyright(c) 2018 - 2019 Intel Corporation
762306a36Sopenharmony_ci *****************************************************************************/
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#if !defined(__IWLWIFI_DEVICE_TRACE_DATA) || defined(TRACE_HEADER_MULTI_READ)
1062306a36Sopenharmony_ci#define __IWLWIFI_DEVICE_TRACE_DATA
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci#include <linux/tracepoint.h>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci#undef TRACE_SYSTEM
1562306a36Sopenharmony_ci#define TRACE_SYSTEM iwlwifi_data
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_tx_tb,
1862306a36Sopenharmony_ci	TP_PROTO(const struct device *dev, struct sk_buff *skb,
1962306a36Sopenharmony_ci		 u8 *data_src, dma_addr_t phys, size_t data_len),
2062306a36Sopenharmony_ci	TP_ARGS(dev, skb, data_src, phys, data_len),
2162306a36Sopenharmony_ci	TP_STRUCT__entry(
2262306a36Sopenharmony_ci		DEV_ENTRY
2362306a36Sopenharmony_ci		__field(u64, phys)
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci		__dynamic_array(u8, data,
2662306a36Sopenharmony_ci				iwl_trace_data(skb) ? data_len : 0)
2762306a36Sopenharmony_ci	),
2862306a36Sopenharmony_ci	TP_fast_assign(
2962306a36Sopenharmony_ci		DEV_ASSIGN;
3062306a36Sopenharmony_ci		__entry->phys = phys;
3162306a36Sopenharmony_ci		if (iwl_trace_data(skb))
3262306a36Sopenharmony_ci			memcpy(__get_dynamic_array(data), data_src, data_len);
3362306a36Sopenharmony_ci	),
3462306a36Sopenharmony_ci	TP_printk("[%s] TX frame data", __get_str(dev))
3562306a36Sopenharmony_ci);
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ciTRACE_EVENT(iwlwifi_dev_rx_data,
3862306a36Sopenharmony_ci	TP_PROTO(const struct device *dev,
3962306a36Sopenharmony_ci		 const struct iwl_trans *trans,
4062306a36Sopenharmony_ci		 void *rxbuf, size_t len),
4162306a36Sopenharmony_ci	TP_ARGS(dev, trans, rxbuf, len),
4262306a36Sopenharmony_ci	TP_STRUCT__entry(
4362306a36Sopenharmony_ci		DEV_ENTRY
4462306a36Sopenharmony_ci		__dynamic_array(u8, data,
4562306a36Sopenharmony_ci				len - iwl_rx_trace_len(trans, rxbuf, len, NULL))
4662306a36Sopenharmony_ci	),
4762306a36Sopenharmony_ci	TP_fast_assign(
4862306a36Sopenharmony_ci		size_t offs = iwl_rx_trace_len(trans, rxbuf, len, NULL);
4962306a36Sopenharmony_ci		DEV_ASSIGN;
5062306a36Sopenharmony_ci		if (offs < len)
5162306a36Sopenharmony_ci			memcpy(__get_dynamic_array(data),
5262306a36Sopenharmony_ci			       ((u8 *)rxbuf) + offs, len - offs);
5362306a36Sopenharmony_ci	),
5462306a36Sopenharmony_ci	TP_printk("[%s] RX frame data", __get_str(dev))
5562306a36Sopenharmony_ci);
5662306a36Sopenharmony_ci#endif /* __IWLWIFI_DEVICE_TRACE_DATA */
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci#undef TRACE_INCLUDE_PATH
5962306a36Sopenharmony_ci#define TRACE_INCLUDE_PATH .
6062306a36Sopenharmony_ci#undef TRACE_INCLUDE_FILE
6162306a36Sopenharmony_ci#define TRACE_INCLUDE_FILE iwl-devtrace-data
6262306a36Sopenharmony_ci#include <trace/define_trace.h>
63