linux/drivers/dma/fsl-edma-trace.h

/* SPDX-License-Identifier: GPL-2.0+ */
/*
 * Copyright 2023 NXP.
 */

#undef TRACE_SYSTEM
#define TRACE_SYSTEM

#if !defined(__LINUX_FSL_EDMA_TRACE) || defined(TRACE_HEADER_MULTI_READ)
#define __LINUX_FSL_EDMA_TRACE

#include <linux/types.h>
#include <linux/tracepoint.h>

DECLARE_EVENT_CLASS(edma_log_io,
	TP_PROTO(struct fsl_edma_engine *edma, void __iomem *addr, u32 value),
	TP_ARGS(edma, addr, value),
	TP_STRUCT__entry(
		__field(struct fsl_edma_engine *, edma)
		__field(void __iomem *, addr)
		__field(u32, value)
	),
	TP_fast_assign(
		__entry->edma = edma;
		__entry->addr = addr;
		__entry->value = value;
	),
	TP_printk("offset %08x: value %08x",
		(u32)(__entry->addr - __entry->edma->membase), __entry->value)
);

DEFINE_EVENT(edma_log_io, edma_readl,
	TP_PROTO(struct fsl_edma_engine *edma, void __iomem *addr, u32 value),
	TP_ARGS(edma, addr, value)
);

DEFINE_EVENT(edma_log_io, edma_writel,
	TP_PROTO(struct fsl_edma_engine *edma, void __iomem *addr,  u32 value),
	TP_ARGS(edma, addr, value)
);

DEFINE_EVENT(edma_log_io, edma_readw,
	TP_PROTO(struct fsl_edma_engine *edma, void __iomem *addr, u32 value),
	TP_ARGS(edma, addr, value)
);

DEFINE_EVENT(edma_log_io, edma_writew,
	TP_PROTO(struct fsl_edma_engine *edma, void __iomem *addr,  u32 value),
	TP_ARGS(edma, addr, value)
);

DEFINE_EVENT(edma_log_io, edma_readb,
	TP_PROTO(struct fsl_edma_engine *edma, void __iomem *addr, u32 value),
	TP_ARGS(edma, addr, value)
);

DEFINE_EVENT(edma_log_io, edma_writeb,
	TP_PROTO(struct fsl_edma_engine *edma, void __iomem *addr,  u32 value),
	TP_ARGS(edma, addr, value)
);

DECLARE_EVENT_CLASS(edma_log_tcd,
	TP_PROTO(struct fsl_edma_chan *chan, void *tcd),
	TP_ARGS(chan, tcd),
	TP_STRUCT__entry(
		__field(u64, saddr)
		__field(u16, soff)
		__field(u16, attr)
		__field(u32, nbytes)
		__field(u64, slast)
		__field(u64, daddr)
		__field(u16, doff)
		__field(u16, citer)
		__field(u64, dlast_sga)
		__field(u16, csr)
		__field(u16, biter)

	),
	TP_fast_assign(
		__entry->saddr = fsl_edma_get_tcd_to_cpu(chan, tcd, saddr),
		__entry->soff = fsl_edma_get_tcd_to_cpu(chan, tcd, soff),
		__entry->attr = fsl_edma_get_tcd_to_cpu(chan, tcd, attr),
		__entry->nbytes = fsl_edma_get_tcd_to_cpu(chan, tcd, nbytes),
		__entry->slast = fsl_edma_get_tcd_to_cpu(chan, tcd, slast),
		__entry->daddr = fsl_edma_get_tcd_to_cpu(chan, tcd, daddr),
		__entry->doff = fsl_edma_get_tcd_to_cpu(chan, tcd, doff),
		__entry->citer = fsl_edma_get_tcd_to_cpu(chan, tcd, citer),
		__entry->dlast_sga = fsl_edma_get_tcd_to_cpu(chan, tcd, dlast_sga),
		__entry->csr = fsl_edma_get_tcd_to_cpu(chan, tcd, csr),
		__entry->biter = fsl_edma_get_tcd_to_cpu(chan, tcd, biter);
	),
	TP_printk("\n==== TCD =====\n"
		  "  saddr:  0x%016llx\n"
		  "  soff:               0x%04x\n"
		  "  attr:               0x%04x\n"
		  "  nbytes:         0x%08x\n"
		  "  slast:  0x%016llx\n"
		  "  daddr:  0x%016llx\n"
		  "  doff:               0x%04x\n"
		  "  citer:              0x%04x\n"
		  "  dlast:  0x%016llx\n"
		  "  csr:                0x%04x\n"
		  "  biter:              0x%04x\n",
		__entry->saddr,
		__entry->soff,
		__entry->attr,
		__entry->nbytes,
		__entry->slast,
		__entry->daddr,
		__entry->doff,
		__entry->citer,
		__entry->dlast_sga,
		__entry->csr,
		__entry->biter)
);

DEFINE_EVENT(edma_log_tcd, edma_fill_tcd,
	TP_PROTO(struct fsl_edma_chan *chan, void *tcd),
	TP_ARGS(chan, tcd)
);

#endif

/* this part must be outside header guard */

#undef TRACE_INCLUDE_PATH
#define TRACE_INCLUDE_PATH

#undef TRACE_INCLUDE_FILE
#define TRACE_INCLUDE_FILE

#include <trace/define_trace.h>