
Added vendor hook to consider ufs host/device perf heuristic and error recovery according to different platform/design Vendor/Platform can take necessary action according to their design/implementation Added vendor hook before calling UFS command ops - trace_android_vh_ufs_perf_huristic_ctrl Added vendor hook after sending UFS command to host - trace_android_vh_ufs_send_command_post_change Added vendor hook for abort success case - trace_android_vh_ufs_abort_success_ctrl Added vendor hook for completion response check - trace_android_vh_ufs_compl_rsp_check_done Added vendor hook for vendor specific error handling - trace_android_vh_ufs_err_handler Added vendor hook for err logs printing control - trace_android_vh_ufs_err_print_ctrl Added vendor hook for error checking flow trigger - trace_android_vh_ufs_err_check_ctrl Bug: 312806167 Change-Id: I2190afe62b60da9d47001307f858f10fc8a59986 Signed-off-by: Sanjeev Yadav <sanjeev.y@mediatek.com> Signed-off-by: Browse Zhang <browse.zhang@mediatek.com>
115 lines
3.4 KiB
C
115 lines
3.4 KiB
C
/* 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 <linux/tracepoint.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
|
|
*/
|
|
#if defined(__GENKSYMS__) || !IS_ENABLED(CONFIG_SCSI_UFSHCD)
|
|
struct ufs_hba;
|
|
struct ufshcd_lrb;
|
|
struct uic_command;
|
|
struct request;
|
|
struct scsi_device;
|
|
#else
|
|
/* 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>
|
|
#endif /* __GENKSYMS__ */
|
|
|
|
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_RESTRICTED_HOOK(android_rvh_ufs_complete_init,
|
|
TP_PROTO(struct ufs_hba *hba),
|
|
TP_ARGS(hba), 1);
|
|
|
|
DECLARE_RESTRICTED_HOOK(android_rvh_ufs_reprogram_all_keys,
|
|
TP_PROTO(struct ufs_hba *hba, int *err),
|
|
TP_ARGS(hba, err), 1);
|
|
|
|
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,
|
|
const char *str),
|
|
TP_ARGS(hba, ucmd, str));
|
|
|
|
DECLARE_HOOK(android_vh_ufs_send_tm_command,
|
|
TP_PROTO(struct ufs_hba *hba, int tag, const char *str),
|
|
TP_ARGS(hba, tag, str));
|
|
|
|
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_send_command_post_change,
|
|
TP_PROTO(struct ufs_hba *hba, struct ufshcd_lrb *lrbp),
|
|
TP_ARGS(hba, lrbp));
|
|
|
|
DECLARE_HOOK(android_vh_ufs_perf_huristic_ctrl,
|
|
TP_PROTO(struct ufs_hba *hba,
|
|
struct ufshcd_lrb *lrbp, int *err),
|
|
TP_ARGS(hba, lrbp, err));
|
|
|
|
DECLARE_HOOK(android_vh_ufs_abort_success_ctrl,
|
|
TP_PROTO(struct ufs_hba *hba,
|
|
struct ufshcd_lrb *lrbp),
|
|
TP_ARGS(hba, lrbp));
|
|
|
|
DECLARE_HOOK(android_vh_ufs_err_handler,
|
|
TP_PROTO(struct ufs_hba *hba,
|
|
bool *err_handled),
|
|
TP_ARGS(hba, err_handled));
|
|
|
|
DECLARE_HOOK(android_vh_ufs_compl_rsp_check_done,
|
|
TP_PROTO(struct ufs_hba *hba,
|
|
struct ufshcd_lrb *lrbp, bool *done),
|
|
TP_ARGS(hba, lrbp, done));
|
|
|
|
DECLARE_HOOK(android_vh_ufs_err_print_ctrl,
|
|
TP_PROTO(struct ufs_hba *hba,
|
|
bool *skip),
|
|
TP_ARGS(hba, skip));
|
|
|
|
DECLARE_HOOK(android_vh_ufs_err_check_ctrl,
|
|
TP_PROTO(struct ufs_hba *hba,
|
|
bool *err_check),
|
|
TP_ARGS(hba, err_check));
|
|
#endif /* _TRACE_HOOK_UFSHCD_H */
|
|
/* This part must be outside protection */
|
|
#include <trace/define_trace.h>
|