12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
- * Copyright (c) 2012-2021, 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"
- #include "dp_parser.h"
- #include "dp_power.h"
- #include "dp_catalog.h"
- #include "dp_debug.h"
- struct dp_ctrl {
- int (*init)(struct dp_ctrl *dp_ctrl, bool flip, bool reset);
- void (*deinit)(struct dp_ctrl *dp_ctrl);
- int (*on)(struct dp_ctrl *dp_ctrl, bool mst_mode, bool fec_en,
- bool dsc_en, bool shallow);
- void (*off)(struct dp_ctrl *dp_ctrl);
- void (*abort)(struct dp_ctrl *dp_ctrl, bool abort);
- void (*isr)(struct dp_ctrl *dp_ctrl);
- bool (*handle_sink_request)(struct dp_ctrl *dp_ctrl);
- void (*process_phy_test_request)(struct dp_ctrl *dp_ctrl);
- int (*link_maintenance)(struct dp_ctrl *dp_ctrl);
- int (*stream_on)(struct dp_ctrl *dp_ctrl, struct dp_panel *panel);
- void (*stream_off)(struct dp_ctrl *dp_ctrl, struct dp_panel *panel);
- void (*stream_pre_off)(struct dp_ctrl *dp_ctrl, struct dp_panel *panel);
- void (*set_mst_channel_info)(struct dp_ctrl *dp_ctrl,
- enum dp_stream_id strm,
- u32 ch_start_slot, u32 ch_tot_slots);
- void (*set_sim_mode)(struct dp_ctrl *dp_ctrl, bool en);
- int (*setup_misr)(struct dp_ctrl *dp_ctrl);
- int (*read_misr)(struct dp_ctrl *dp_ctrl, struct dp_misr40_data *data);
- };
- struct dp_ctrl_in {
- struct device *dev;
- struct dp_panel *panel;
- struct dp_aux *aux;
- struct dp_link *link;
- struct dp_parser *parser;
- struct dp_power *power;
- struct dp_catalog_ctrl *catalog;
- struct dp_pll *pll;
- #if defined(CONFIG_SECDP)
- struct secdp_misc *sec;
- #endif
- };
- struct dp_ctrl *dp_ctrl_get(struct dp_ctrl_in *in);
- void dp_ctrl_put(struct dp_ctrl *dp_ctrl);
- #if defined(CONFIG_SECDP)
- bool secdp_get_link_train_status(struct dp_ctrl *dp_ctrl);
- #endif
- #endif /* _DP_CTRL_H_ */
|