2020-08-27 14:16:55 -07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2012-2020, The Linux Foundation. All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _DP_CTRL_H_
|
|
|
|
#define _DP_CTRL_H_
|
|
|
|
|
|
|
|
#include "dp_aux.h"
|
|
|
|
#include "dp_panel.h"
|
|
|
|
#include "dp_link.h"
|
|
|
|
|
2024-10-29 22:28:24 +02:00
|
|
|
struct msm_dp_ctrl {
|
2022-02-25 13:23:12 -08:00
|
|
|
bool wide_bus_en;
|
2020-08-27 14:16:55 -07:00
|
|
|
};
|
|
|
|
|
2024-01-26 20:26:34 +02:00
|
|
|
struct phy;
|
|
|
|
|
2024-10-29 22:28:24 +02:00
|
|
|
int msm_dp_ctrl_on_link(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
int msm_dp_ctrl_on_stream(struct msm_dp_ctrl *msm_dp_ctrl, bool force_link_train);
|
|
|
|
void msm_dp_ctrl_off_link_stream(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_off_link(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_off(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_push_idle(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
irqreturn_t msm_dp_ctrl_isr(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_handle_sink_request(struct msm_dp_ctrl *msm_dp_ctrl);
|
2025-05-18 14:21:44 +03:00
|
|
|
struct msm_dp_ctrl *msm_dp_ctrl_get(struct device *dev,
|
|
|
|
struct msm_dp_link *link,
|
|
|
|
struct msm_dp_panel *panel,
|
|
|
|
struct drm_dp_aux *aux,
|
|
|
|
struct phy *phy,
|
|
|
|
void __iomem *ahb_base,
|
|
|
|
void __iomem *link_base);
|
2020-08-27 14:16:55 -07:00
|
|
|
|
2025-05-18 14:21:43 +03:00
|
|
|
void msm_dp_ctrl_reset(struct msm_dp_ctrl *msm_dp_ctrl);
|
2024-10-29 22:28:24 +02:00
|
|
|
void msm_dp_ctrl_phy_init(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_phy_exit(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_irq_phy_exit(struct msm_dp_ctrl *msm_dp_ctrl);
|
2022-01-18 10:47:25 -08:00
|
|
|
|
2024-10-29 22:28:24 +02:00
|
|
|
void msm_dp_ctrl_set_psr(struct msm_dp_ctrl *msm_dp_ctrl, bool enable);
|
|
|
|
void msm_dp_ctrl_config_psr(struct msm_dp_ctrl *msm_dp_ctrl);
|
2023-03-02 22:03:12 +05:30
|
|
|
|
2024-10-29 22:28:24 +02:00
|
|
|
int msm_dp_ctrl_core_clk_enable(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_core_clk_disable(struct msm_dp_ctrl *msm_dp_ctrl);
|
2024-01-26 20:26:24 +02:00
|
|
|
|
2025-05-18 14:21:43 +03:00
|
|
|
void msm_dp_ctrl_enable_irq(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
void msm_dp_ctrl_disable_irq(struct msm_dp_ctrl *msm_dp_ctrl);
|
|
|
|
|
2020-08-27 14:16:55 -07:00
|
|
|
#endif /* _DP_CTRL_H_ */
|