123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (c) 2022-2023, Qualcomm Innovation Center, Inc. All rights reserved.
- * Copyright (c) 2017-2021, The Linux Foundation. All rights reserved.
- */
- #ifndef _DP_DEBUG_H_
- #define _DP_DEBUG_H_
- #include "dp_panel.h"
- #include "dp_ctrl.h"
- #include "dp_link.h"
- #include "dp_aux.h"
- #include "dp_display.h"
- #include "dp_pll.h"
- #include <linux/ipc_logging.h>
- #define DP_IPC_LOG(fmt, ...) \
- do { \
- void *ipc_logging_context = get_ipc_log_context(); \
- ipc_log_string(ipc_logging_context, fmt, ##__VA_ARGS__); \
- } while (0)
- #define DP_DEBUG(fmt, ...) \
- do { \
- DP_IPC_LOG("[d][%-4d]"fmt, current->pid, ##__VA_ARGS__); \
- DP_DEBUG_V(fmt, ##__VA_ARGS__); \
- } while (0)
- #define DP_INFO(fmt, ...) \
- do { \
- DP_IPC_LOG("[i][%-4d]"fmt, current->pid, ##__VA_ARGS__); \
- DP_INFO_V(fmt, ##__VA_ARGS__); \
- } while (0)
- #define DP_WARN(fmt, ...) \
- do { \
- DP_IPC_LOG("[w][%-4d]"fmt, current->pid, ##__VA_ARGS__); \
- DP_WARN_V(fmt, ##__VA_ARGS__); \
- } while (0)
- #define DP_ERR(fmt, ...) \
- do { \
- DP_IPC_LOG("[e][%-4d]"fmt, current->pid, ##__VA_ARGS__); \
- DP_ERR_V(fmt, ##__VA_ARGS__); \
- } while (0)
- #if !defined(CONFIG_SECDP)
- #define DP_DEBUG_V(fmt, ...) \
- do { \
- if (drm_debug_enabled(DRM_UT_KMS)) \
- DRM_DEBUG("[msm-dp-debug][%-4d]"fmt, current->pid, \
- ##__VA_ARGS__); \
- else \
- pr_debug("[drm:%s][msm-dp-debug][%-4d]"fmt, __func__,\
- current->pid, ##__VA_ARGS__); \
- } while (0)
- #define DP_INFO_V(fmt, ...) \
- do { \
- if (drm_debug_enabled(DRM_UT_KMS)) \
- DRM_INFO("[msm-dp-info][%-4d]"fmt, current->pid, \
- ##__VA_ARGS__); \
- else \
- pr_info("[drm:%s][msm-dp-info][%-4d]"fmt, __func__, \
- current->pid, ##__VA_ARGS__); \
- } while (0)
- #define DP_WARN_V(fmt, ...) \
- pr_warn("[drm:%s][msm-dp-warn][%-4d]"fmt, __func__, \
- current->pid, ##__VA_ARGS__)
- #define DP_WARN_RATELIMITED_V(fmt, ...) \
- pr_warn_ratelimited("[drm:%s][msm-dp-warn][%-4d]"fmt, __func__, \
- current->pid, ##__VA_ARGS__)
- #define DP_ERR_V(fmt, ...) \
- pr_err("[drm:%s][msm-dp-err][%-4d]"fmt, __func__, \
- current->pid, ##__VA_ARGS__)
- #define DP_ERR_RATELIMITED_V(fmt, ...) \
- pr_err_ratelimited("[drm:%s][msm-dp-err][%-4d]"fmt, __func__, \
- current->pid, ##__VA_ARGS__)
- #else
- #define DP_DEBUG_V(fmt, ...) \
- do { \
- if (drm_debug_enabled(DRM_UT_KMS)) \
- DRM_DEBUG("[msm-dp-debug][%-4d]"fmt, current->pid, \
- ##__VA_ARGS__); \
- else \
- pr_debug(fmt, ##__VA_ARGS__); \
- } while (0)
- #define DP_INFO_V(fmt, ...) \
- do { \
- if (drm_debug_enabled(DRM_UT_KMS)) \
- DRM_INFO("[msm-dp-info][%-4d]"fmt, current->pid, \
- ##__VA_ARGS__); \
- else \
- pr_info(fmt, ##__VA_ARGS__); \
- } while (0)
- #define DP_WARN_V(fmt, ...) pr_warn(fmt, ##__VA_ARGS__)
- #define DP_WARN_RATELIMITED_V(fmt, ...) pr_warn(fmt, ##__VA_ARGS__)
- #define DP_ERR_V(fmt, ...) pr_err(fmt, ##__VA_ARGS__)
- #define DP_ERR_RATELIMITED_V(fmt, ...) pr_err(fmt, ##__VA_ARGS__)
- #endif
- #if defined(CONFIG_SECDP_DBG)
- extern bool secdp_func_trace;
- #define DP_ENTER(fmt, ...) \
- do { \
- if (secdp_func_trace) \
- pr_debug("+++ " pr_fmt(fmt), ##__VA_ARGS__); \
- } while (0)
- #define DP_LEAVE(fmt, ...) \
- do { \
- if (secdp_func_trace) \
- pr_debug("--- " pr_fmt(fmt), ##__VA_ARGS__); \
- } while (0)
- #else
- #define DP_ENTER(fmt, ...) do {} while (0)
- #define DP_LEAVE(fmt, ...) do {} while (0)
- #endif
- #define DEFAULT_DISCONNECT_DELAY_MS 0
- #define MAX_DISCONNECT_DELAY_MS 10000
- #define DEFAULT_CONNECT_NOTIFICATION_DELAY_MS 150
- #define MAX_CONNECT_NOTIFICATION_DELAY_MS 5000
- /**
- * struct dp_debug
- * @sim_mode: specifies whether sim mode enabled
- * @psm_enabled: specifies whether psm enabled
- * @hdcp_disabled: specifies if hdcp is disabled
- * @hdcp_wait_sink_sync: used to wait for sink synchronization before HDCP auth
- * @tpg_pattern: selects tpg pattern on the controller
- * @max_pclk_khz: max pclk supported
- * @force_encryption: enable/disable forced encryption for HDCP 2.2
- * @skip_uevent: skip hotplug uevent to the user space
- * @hdcp_status: string holding hdcp status information
- * @mst_sim_add_con: specifies whether new sim connector is to be added
- * @mst_sim_remove_con: specifies whether sim connector is to be removed
- * @mst_sim_remove_con_id: specifies id of sim connector to be removed
- * @connect_notification_delay_ms: time (in ms) to wait for any attention
- * messages before sending the connect notification uevent
- * @disconnect_delay_ms: time (in ms) to wait before turning off the mainlink
- * in response to HPD low of cable disconnect event
- */
- struct dp_debug {
- bool sim_mode;
- bool psm_enabled;
- bool hdcp_disabled;
- bool hdcp_wait_sink_sync;
- u32 tpg_pattern;
- u32 max_pclk_khz;
- bool force_encryption;
- bool skip_uevent;
- char hdcp_status[SZ_128];
- bool mst_sim_add_con;
- bool mst_sim_remove_con;
- int mst_sim_remove_con_id;
- unsigned long connect_notification_delay_ms;
- u32 disconnect_delay_ms;
- void (*abort)(struct dp_debug *dp_debug);
- void (*set_mst_con)(struct dp_debug *dp_debug, int con_id);
- };
- /**
- * struct dp_debug_in
- * @dev: device instance of the caller
- * @panel: instance of panel module
- * @hpd: instance of hpd module
- * @link: instance of link module
- * @aux: instance of aux module
- * @connector: double pointer to display connector
- * @catalog: instance of catalog module
- * @parser: instance of parser module
- * @ctrl: instance of controller module
- * @pll: instance of pll module
- * @display: instance of display module
- */
- struct dp_debug_in {
- struct device *dev;
- struct dp_panel *panel;
- struct dp_hpd *hpd;
- struct dp_link *link;
- struct dp_aux *aux;
- struct drm_connector **connector;
- struct dp_catalog *catalog;
- struct dp_parser *parser;
- struct dp_ctrl *ctrl;
- struct dp_pll *pll;
- struct dp_display *display;
- };
- /**
- * dp_debug_get() - configure and get the DisplayPlot debug module data
- *
- * @in: input structure containing data to initialize the debug module
- * return: pointer to allocated debug module data
- *
- * This function sets up the debug module and provides a way
- * for debugfs input to be communicated with existing modules
- */
- struct dp_debug *dp_debug_get(struct dp_debug_in *in);
- /**
- * dp_debug_put()
- *
- * Cleans up dp_debug instance
- *
- * @dp_debug: instance of dp_debug
- */
- void dp_debug_put(struct dp_debug *dp_debug);
- #endif /* _DP_DEBUG_H_ */
|