blob: 80b8131fc716ad833daba2c3e773b02cf791ad98 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0 */
#undef TRACE_SYSTEM
#define TRACE_SYSTEM ufshcd
#define TRACE_INCLUDE_PATH trace/hooks
#if !defined(_TRACE_HOOK_UFSHCD_H) || defined(TRACE_HEADER_MULTI_READ)
#define _TRACE_HOOK_UFSHCD_H
#include <trace/hooks/vendor_hooks.h>
/*
* Following tracepoints are not exported in tracefs and provide a
* mechanism for vendor modules to hook and extend functionality
*/
/* struct ufs_hba, struct ufshcd_lrb, struct uic_command */
#include <../drivers/scsi/ufs/ufshcd.h>
/* struct request */
#include <linux/blkdev.h>
/* struct scsi_device */
#include <scsi/scsi_device.h>
DECLARE_HOOK(android_vh_ufs_fill_prdt,
TP_PROTO(struct ufs_hba *hba, struct ufshcd_lrb *lrbp,
unsigned int segments, int *err),
TP_ARGS(hba, lrbp, segments, err));
DECLARE_HOOK(android_vh_ufs_prepare_command,
TP_PROTO(struct ufs_hba *hba, struct request *rq,
struct ufshcd_lrb *lrbp, int *err),
TP_ARGS(hba, rq, lrbp, err));
DECLARE_HOOK(android_vh_ufs_update_sysfs,
TP_PROTO(struct ufs_hba *hba),
TP_ARGS(hba));
DECLARE_HOOK(android_vh_ufs_send_command,
TP_PROTO(struct ufs_hba *hba, struct ufshcd_lrb *lrbp),
TP_ARGS(hba, lrbp));
DECLARE_HOOK(android_vh_ufs_compl_command,
TP_PROTO(struct ufs_hba *hba, struct ufshcd_lrb *lrbp),
TP_ARGS(hba, lrbp));
DECLARE_HOOK(android_vh_ufs_send_uic_command,
TP_PROTO(struct ufs_hba *hba, struct uic_command *ucmd, int str_t),
TP_ARGS(hba, ucmd, str_t));
DECLARE_HOOK(android_vh_ufs_send_tm_command,
TP_PROTO(struct ufs_hba *hba, int tag, int str_t),
TP_ARGS(hba, tag, str_t));
DECLARE_HOOK(android_vh_ufs_check_int_errors,
TP_PROTO(struct ufs_hba *hba, bool queue_eh_work),
TP_ARGS(hba, queue_eh_work));
DECLARE_HOOK(android_vh_ufs_update_sdev,
TP_PROTO(struct scsi_device *sdev),
TP_ARGS(sdev));
DECLARE_HOOK(android_vh_ufs_clock_scaling,
TP_PROTO(struct ufs_hba *hba, bool *force_out, bool *force_scaling, bool *scale_up),
TP_ARGS(hba, force_out, force_scaling, scale_up));
DECLARE_HOOK(android_vh_ufs_use_mcq_hooks,
TP_PROTO(struct ufs_hba *hba, bool *use_mcq),
TP_ARGS(hba, use_mcq));
DECLARE_HOOK(android_vh_ufs_mcq_max_tag,
TP_PROTO(struct ufs_hba *hba, int *max_tag),
TP_ARGS(hba, max_tag));
DECLARE_HOOK(android_vh_ufs_mcq_map_tag,
TP_PROTO(struct ufs_hba *hba, int index, int *tag),
TP_ARGS(hba, index, tag));
DECLARE_HOOK(android_vh_ufs_mcq_set_sqid,
TP_PROTO(struct ufs_hba *hba, int index, struct ufshcd_lrb *lrbp),
TP_ARGS(hba, index, lrbp));
DECLARE_HOOK(android_vh_ufs_mcq_handler,
TP_PROTO(struct ufs_hba *hba, u32 intr_status, irqreturn_t *retval),
TP_ARGS(hba, intr_status, retval));
DECLARE_HOOK(android_vh_ufs_mcq_make_hba_operational,
TP_PROTO(struct ufs_hba *hba, int *err),
TP_ARGS(hba, err));
DECLARE_HOOK(android_vh_ufs_mcq_hba_capabilities,
TP_PROTO(struct ufs_hba *hba, int *err),
TP_ARGS(hba, err));
DECLARE_HOOK(android_vh_ufs_mcq_print_trs,
TP_PROTO(struct ufs_hba *hba, bool pr_prdt),
TP_ARGS(hba, pr_prdt));
DECLARE_HOOK(android_vh_ufs_mcq_send_command,
TP_PROTO(struct ufs_hba *hba, unsigned int task_tag),
TP_ARGS(hba, task_tag));
DECLARE_HOOK(android_vh_ufs_mcq_config,
TP_PROTO(struct ufs_hba *hba, int *err),
TP_ARGS(hba, err));
DECLARE_HOOK(android_vh_ufs_mcq_has_oustanding_reqs,
TP_PROTO(struct ufs_hba *hba, bool *ret),
TP_ARGS(hba, ret));
DECLARE_HOOK(android_vh_ufs_mcq_get_outstanding_reqs,
TP_PROTO(struct ufs_hba *hba, unsigned long **outstanding, int *nr_tag),
TP_ARGS(hba, outstanding, nr_tag));
struct scsi_cmnd;
DECLARE_HOOK(android_vh_ufs_mcq_abort,
TP_PROTO(struct scsi_cmnd *cmd, int *ret),
TP_ARGS(cmd, ret));
DECLARE_HOOK(android_vh_ufs_mcq_clear_cmd,
TP_PROTO(struct ufs_hba *hba, int tag, int *ret),
TP_ARGS(hba, tag, ret));
DECLARE_HOOK(android_vh_ufs_mcq_clear_pending,
TP_PROTO(struct ufs_hba *hba, int *ret),
TP_ARGS(hba, ret));
#endif /* _TRACE_HOOK_UFSHCD_H */
/* This part must be outside protection */
#include <trace/define_trace.h>