Lines Matching +full:host +full:- +full:id

1 // SPDX-License-Identifier: GPL-2.0-only
35 #define IS_MASTER_DSI_LINK(id) (msm_dsim_glb.master_dsi_link_id == id) argument
37 static inline struct msm_dsi *dsi_mgr_get_dsi(int id) in dsi_mgr_get_dsi() argument
39 return msm_dsim_glb.dsi[id]; in dsi_mgr_get_dsi()
42 static inline struct msm_dsi *dsi_mgr_get_other_dsi(int id) in dsi_mgr_get_other_dsi() argument
44 return msm_dsim_glb.dsi[(id + 1) % DSI_MAX]; in dsi_mgr_get_other_dsi()
47 static int dsi_mgr_parse_of(struct device_node *np, int id) in dsi_mgr_parse_of() argument
52 * sync-mode, and only one node specifies master in case of bonded mode. in dsi_mgr_parse_of()
54 if (!msm_dsim->is_bonded_dsi) in dsi_mgr_parse_of()
55 msm_dsim->is_bonded_dsi = of_property_read_bool(np, "qcom,dual-dsi-mode"); in dsi_mgr_parse_of()
57 if (msm_dsim->is_bonded_dsi) { in dsi_mgr_parse_of()
58 if (of_property_read_bool(np, "qcom,master-dsi")) in dsi_mgr_parse_of()
59 msm_dsim->master_dsi_link_id = id; in dsi_mgr_parse_of()
60 if (!msm_dsim->is_sync_needed) in dsi_mgr_parse_of()
61 msm_dsim->is_sync_needed = of_property_read_bool( in dsi_mgr_parse_of()
62 np, "qcom,sync-dual-dsi"); in dsi_mgr_parse_of()
68 static int dsi_mgr_setup_components(int id) in dsi_mgr_setup_components() argument
70 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_setup_components()
71 struct msm_dsi *other_dsi = dsi_mgr_get_other_dsi(id); in dsi_mgr_setup_components()
77 ret = msm_dsi_host_register(msm_dsi->host); in dsi_mgr_setup_components()
81 msm_dsi_phy_set_usecase(msm_dsi->phy, MSM_DSI_PHY_STANDALONE); in dsi_mgr_setup_components()
82 msm_dsi_host_set_phy_mode(msm_dsi->host, msm_dsi->phy); in dsi_mgr_setup_components()
84 struct msm_dsi *master_link_dsi = IS_MASTER_DSI_LINK(id) ? in dsi_mgr_setup_components()
86 struct msm_dsi *slave_link_dsi = IS_MASTER_DSI_LINK(id) ? in dsi_mgr_setup_components()
88 /* Register slave host first, so that slave DSI device in dsi_mgr_setup_components()
91 * Also, do not check defer for the slave host, in dsi_mgr_setup_components()
95 ret = msm_dsi_host_register(slave_link_dsi->host); in dsi_mgr_setup_components()
98 ret = msm_dsi_host_register(master_link_dsi->host); in dsi_mgr_setup_components()
103 msm_dsi_phy_set_usecase(clk_master_dsi->phy, in dsi_mgr_setup_components()
105 msm_dsi_phy_set_usecase(clk_slave_dsi->phy, in dsi_mgr_setup_components()
107 msm_dsi_host_set_phy_mode(msm_dsi->host, msm_dsi->phy); in dsi_mgr_setup_components()
108 msm_dsi_host_set_phy_mode(other_dsi->host, other_dsi->phy); in dsi_mgr_setup_components()
120 msm_dsi_host_get_phy_clk_req(msm_dsi->host, &clk_req, is_bonded_dsi); in enable_phy()
122 return msm_dsi_phy_enable(msm_dsi->phy, &clk_req, shared_timings); in enable_phy()
126 dsi_mgr_phy_enable(int id, in dsi_mgr_phy_enable() argument
129 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_phy_enable()
140 if (!mdsi->phy_enabled && !sdsi->phy_enabled) { in dsi_mgr_phy_enable()
141 msm_dsi_host_reset_phy(mdsi->host); in dsi_mgr_phy_enable()
142 msm_dsi_host_reset_phy(sdsi->host); in dsi_mgr_phy_enable()
151 msm_dsi_phy_disable(mdsi->phy); in dsi_mgr_phy_enable()
156 msm_dsi_host_reset_phy(msm_dsi->host); in dsi_mgr_phy_enable()
157 ret = enable_phy(msm_dsi, &shared_timings[id]); in dsi_mgr_phy_enable()
162 msm_dsi->phy_enabled = true; in dsi_mgr_phy_enable()
167 static void dsi_mgr_phy_disable(int id) in dsi_mgr_phy_disable() argument
169 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_phy_disable()
177 msm_dsi->phy_enabled = false; in dsi_mgr_phy_disable()
179 if (!mdsi->phy_enabled && !sdsi->phy_enabled) { in dsi_mgr_phy_disable()
180 msm_dsi_phy_disable(sdsi->phy); in dsi_mgr_phy_disable()
181 msm_dsi_phy_disable(mdsi->phy); in dsi_mgr_phy_disable()
184 msm_dsi_phy_disable(msm_dsi->phy); in dsi_mgr_phy_disable()
190 int id; member
198 return dsi_bridge->id; in dsi_mgr_bridge_get_id()
201 static void msm_dsi_manager_set_split_display(u8 id) in msm_dsi_manager_set_split_display() argument
203 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in msm_dsi_manager_set_split_display()
204 struct msm_dsi *other_dsi = dsi_mgr_get_other_dsi(id); in msm_dsi_manager_set_split_display()
205 struct msm_drm_private *priv = msm_dsi->dev->dev_private; in msm_dsi_manager_set_split_display()
206 struct msm_kms *kms = priv->kms; in msm_dsi_manager_set_split_display()
209 if (IS_BONDED_DSI() && !IS_MASTER_DSI_LINK(id)) { in msm_dsi_manager_set_split_display()
217 if (!msm_dsi->external_bridge || !IS_BONDED_DSI()) in msm_dsi_manager_set_split_display()
224 if (other_dsi && other_dsi->external_bridge && kms->funcs->set_split_display) { in msm_dsi_manager_set_split_display()
225 kms->funcs->set_split_display(kms, master_dsi->encoder, in msm_dsi_manager_set_split_display()
226 slave_dsi->encoder, in msm_dsi_manager_set_split_display()
233 int id = dsi_mgr_bridge_get_id(bridge); in dsi_mgr_bridge_power_on() local
234 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_bridge_power_on()
236 struct mipi_dsi_host *host = msm_dsi->host; in dsi_mgr_bridge_power_on() local
241 DBG("id=%d", id); in dsi_mgr_bridge_power_on()
243 ret = dsi_mgr_phy_enable(id, phy_shared_timings); in dsi_mgr_bridge_power_on()
247 ret = msm_dsi_host_power_on(host, &phy_shared_timings[id], is_bonded_dsi, msm_dsi->phy); in dsi_mgr_bridge_power_on()
249 pr_err("%s: power on host %d failed, %d\n", __func__, id, ret); in dsi_mgr_bridge_power_on()
254 ret = msm_dsi_host_power_on(msm_dsi1->host, in dsi_mgr_bridge_power_on()
255 &phy_shared_timings[DSI_1], is_bonded_dsi, msm_dsi1->phy); in dsi_mgr_bridge_power_on()
267 msm_dsi_host_enable_irq(host); in dsi_mgr_bridge_power_on()
269 msm_dsi_host_enable_irq(msm_dsi1->host); in dsi_mgr_bridge_power_on()
274 msm_dsi_host_power_off(host); in dsi_mgr_bridge_power_on()
276 dsi_mgr_phy_disable(id); in dsi_mgr_bridge_power_on()
283 int id = dsi_mgr_bridge_get_id(bridge); in dsi_mgr_bridge_power_off() local
284 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_bridge_power_off()
286 struct mipi_dsi_host *host = msm_dsi->host; in dsi_mgr_bridge_power_off() local
289 msm_dsi_host_disable_irq(host); in dsi_mgr_bridge_power_off()
291 msm_dsi_host_disable_irq(msm_dsi1->host); in dsi_mgr_bridge_power_off()
292 msm_dsi_host_power_off(msm_dsi1->host); in dsi_mgr_bridge_power_off()
294 msm_dsi_host_power_off(host); in dsi_mgr_bridge_power_off()
295 dsi_mgr_phy_disable(id); in dsi_mgr_bridge_power_off()
300 int id = dsi_mgr_bridge_get_id(bridge); in dsi_mgr_bridge_pre_enable() local
301 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_bridge_pre_enable()
303 struct mipi_dsi_host *host = msm_dsi->host; in dsi_mgr_bridge_pre_enable() local
307 DBG("id=%d", id); in dsi_mgr_bridge_pre_enable()
311 /* Do nothing with the host if it is slave-DSI in case of bonded DSI */ in dsi_mgr_bridge_pre_enable()
312 if (is_bonded_dsi && !IS_MASTER_DSI_LINK(id)) in dsi_mgr_bridge_pre_enable()
317 dev_err(&msm_dsi->pdev->dev, "Power on failed: %d\n", ret); in dsi_mgr_bridge_pre_enable()
321 ret = msm_dsi_host_enable(host); in dsi_mgr_bridge_pre_enable()
323 pr_err("%s: enable host %d failed, %d\n", __func__, id, ret); in dsi_mgr_bridge_pre_enable()
328 ret = msm_dsi_host_enable(msm_dsi1->host); in dsi_mgr_bridge_pre_enable()
338 msm_dsi_host_disable(host); in dsi_mgr_bridge_pre_enable()
350 msm_dsi_host_test_pattern_en(m_dsi->host); in msm_dsi_manager_tpg_enable()
352 msm_dsi_host_test_pattern_en(s_dsi->host); in msm_dsi_manager_tpg_enable()
358 int id = dsi_mgr_bridge_get_id(bridge); in dsi_mgr_bridge_post_disable() local
359 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_bridge_post_disable()
361 struct mipi_dsi_host *host = msm_dsi->host; in dsi_mgr_bridge_post_disable() local
365 DBG("id=%d", id); in dsi_mgr_bridge_post_disable()
371 * Do nothing with the host if it is slave-DSI in case of bonded DSI. in dsi_mgr_bridge_post_disable()
375 if (is_bonded_dsi && !IS_MASTER_DSI_LINK(id)) in dsi_mgr_bridge_post_disable()
378 ret = msm_dsi_host_disable(host); in dsi_mgr_bridge_post_disable()
380 pr_err("%s: host %d disable failed, %d\n", __func__, id, ret); in dsi_mgr_bridge_post_disable()
383 ret = msm_dsi_host_disable(msm_dsi1->host); in dsi_mgr_bridge_post_disable()
388 msm_dsi_host_disable_irq(host); in dsi_mgr_bridge_post_disable()
390 msm_dsi_host_disable_irq(msm_dsi1->host); in dsi_mgr_bridge_post_disable()
393 msm_dsi_phy_pll_save_state(msm_dsi->phy); in dsi_mgr_bridge_post_disable()
395 ret = msm_dsi_host_power_off(host); in dsi_mgr_bridge_post_disable()
397 pr_err("%s: host %d power off failed,%d\n", __func__, id, ret); in dsi_mgr_bridge_post_disable()
400 ret = msm_dsi_host_power_off(msm_dsi1->host); in dsi_mgr_bridge_post_disable()
407 dsi_mgr_phy_disable(id); in dsi_mgr_bridge_post_disable()
414 int id = dsi_mgr_bridge_get_id(bridge); in dsi_mgr_bridge_mode_set() local
415 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_bridge_mode_set()
416 struct msm_dsi *other_dsi = dsi_mgr_get_other_dsi(id); in dsi_mgr_bridge_mode_set()
417 struct mipi_dsi_host *host = msm_dsi->host; in dsi_mgr_bridge_mode_set() local
422 if (is_bonded_dsi && !IS_MASTER_DSI_LINK(id)) in dsi_mgr_bridge_mode_set()
425 msm_dsi_host_set_display_mode(host, adjusted_mode); in dsi_mgr_bridge_mode_set()
427 msm_dsi_host_set_display_mode(other_dsi->host, adjusted_mode); in dsi_mgr_bridge_mode_set()
434 int id = dsi_mgr_bridge_get_id(bridge); in dsi_mgr_bridge_mode_valid() local
435 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in dsi_mgr_bridge_mode_valid()
436 struct mipi_dsi_host *host = msm_dsi->host; in dsi_mgr_bridge_mode_valid() local
437 struct platform_device *pdev = msm_dsi->pdev; in dsi_mgr_bridge_mode_valid()
441 byte_clk_rate = dsi_byte_clk_get_rate(host, IS_BONDED_DSI(), mode); in dsi_mgr_bridge_mode_valid()
443 opp = dev_pm_opp_find_freq_ceil(&pdev->dev, &byte_clk_rate); in dsi_mgr_bridge_mode_valid()
446 } else if (PTR_ERR(opp) == -ERANGE) { in dsi_mgr_bridge_mode_valid()
450 * -ERANGE in such case. in dsi_mgr_bridge_mode_valid()
452 if (dev_pm_opp_get_opp_count(&pdev->dev) != 0) in dsi_mgr_bridge_mode_valid()
458 return msm_dsi_host_check_dsc(host, mode); in dsi_mgr_bridge_mode_valid()
469 struct drm_bridge *msm_dsi_manager_bridge_init(u8 id) in msm_dsi_manager_bridge_init() argument
471 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in msm_dsi_manager_bridge_init()
477 dsi_bridge = devm_kzalloc(msm_dsi->dev->dev, in msm_dsi_manager_bridge_init()
480 ret = -ENOMEM; in msm_dsi_manager_bridge_init()
484 dsi_bridge->id = id; in msm_dsi_manager_bridge_init()
486 encoder = msm_dsi->encoder; in msm_dsi_manager_bridge_init()
488 bridge = &dsi_bridge->base; in msm_dsi_manager_bridge_init()
489 bridge->funcs = &dsi_mgr_bridge_funcs; in msm_dsi_manager_bridge_init()
506 int msm_dsi_manager_ext_bridge_init(u8 id) in msm_dsi_manager_ext_bridge_init() argument
508 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in msm_dsi_manager_ext_bridge_init()
509 struct drm_device *dev = msm_dsi->dev; in msm_dsi_manager_ext_bridge_init()
514 int_bridge = msm_dsi->bridge; in msm_dsi_manager_ext_bridge_init()
515 ext_bridge = devm_drm_of_get_bridge(&msm_dsi->pdev->dev, in msm_dsi_manager_ext_bridge_init()
516 msm_dsi->pdev->dev.of_node, 1, 0); in msm_dsi_manager_ext_bridge_init()
520 msm_dsi->external_bridge = ext_bridge; in msm_dsi_manager_ext_bridge_init()
522 encoder = msm_dsi->encoder; in msm_dsi_manager_ext_bridge_init()
531 if (ret == -EINVAL) { in msm_dsi_manager_ext_bridge_init()
555 msm_dsi_manager_set_split_display(id); in msm_dsi_manager_ext_bridge_init()
565 int msm_dsi_manager_cmd_xfer(int id, const struct mipi_dsi_msg *msg) in msm_dsi_manager_cmd_xfer() argument
567 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in msm_dsi_manager_cmd_xfer()
569 struct mipi_dsi_host *host = msm_dsi->host; in msm_dsi_manager_cmd_xfer() local
570 bool is_read = (msg->rx_buf && msg->rx_len); in msm_dsi_manager_cmd_xfer()
574 if (!msg->tx_buf || !msg->tx_len) in msm_dsi_manager_cmd_xfer()
578 * both DSI links. Host issues the command trigger to both links in msm_dsi_manager_cmd_xfer()
582 if (need_sync && (id == DSI_0)) in msm_dsi_manager_cmd_xfer()
583 return is_read ? msg->rx_len : msg->tx_len; in msm_dsi_manager_cmd_xfer()
586 ret = msm_dsi_host_xfer_prepare(msm_dsi0->host, msg); in msm_dsi_manager_cmd_xfer()
588 pr_err("%s: failed to prepare non-trigger host, %d\n", in msm_dsi_manager_cmd_xfer()
593 ret = msm_dsi_host_xfer_prepare(host, msg); in msm_dsi_manager_cmd_xfer()
595 pr_err("%s: failed to prepare host, %d\n", __func__, ret); in msm_dsi_manager_cmd_xfer()
599 ret = is_read ? msm_dsi_host_cmd_rx(host, msg) : in msm_dsi_manager_cmd_xfer()
600 msm_dsi_host_cmd_tx(host, msg); in msm_dsi_manager_cmd_xfer()
602 msm_dsi_host_xfer_restore(host, msg); in msm_dsi_manager_cmd_xfer()
606 msm_dsi_host_xfer_restore(msm_dsi0->host, msg); in msm_dsi_manager_cmd_xfer()
611 bool msm_dsi_manager_cmd_xfer_trigger(int id, u32 dma_base, u32 len) in msm_dsi_manager_cmd_xfer_trigger() argument
613 struct msm_dsi *msm_dsi = dsi_mgr_get_dsi(id); in msm_dsi_manager_cmd_xfer_trigger()
615 struct mipi_dsi_host *host = msm_dsi->host; in msm_dsi_manager_cmd_xfer_trigger() local
617 if (IS_SYNC_NEEDED() && (id == DSI_0)) in msm_dsi_manager_cmd_xfer_trigger()
621 msm_dsi_host_cmd_xfer_commit(msm_dsi0->host, dma_base, len); in msm_dsi_manager_cmd_xfer_trigger()
623 msm_dsi_host_cmd_xfer_commit(host, dma_base, len); in msm_dsi_manager_cmd_xfer_trigger()
631 int id = msm_dsi->id; in msm_dsi_manager_register() local
634 if (id >= DSI_MAX) { in msm_dsi_manager_register()
635 pr_err("%s: invalid id %d\n", __func__, id); in msm_dsi_manager_register()
636 return -EINVAL; in msm_dsi_manager_register()
639 if (msm_dsim->dsi[id]) { in msm_dsi_manager_register()
640 pr_err("%s: dsi%d already registered\n", __func__, id); in msm_dsi_manager_register()
641 return -EBUSY; in msm_dsi_manager_register()
644 msm_dsim->dsi[id] = msm_dsi; in msm_dsi_manager_register()
646 ret = dsi_mgr_parse_of(msm_dsi->pdev->dev.of_node, id); in msm_dsi_manager_register()
652 ret = dsi_mgr_setup_components(id); in msm_dsi_manager_register()
654 pr_err("%s: failed to register mipi dsi host for DSI %d: %d\n", in msm_dsi_manager_register()
655 __func__, id, ret); in msm_dsi_manager_register()
662 msm_dsim->dsi[id] = NULL; in msm_dsi_manager_register()
670 if (msm_dsi->host) in msm_dsi_manager_unregister()
671 msm_dsi_host_unregister(msm_dsi->host); in msm_dsi_manager_unregister()
673 if (msm_dsi->id >= 0) in msm_dsi_manager_unregister()
674 msm_dsim->dsi[msm_dsi->id] = NULL; in msm_dsi_manager_unregister()
684 return IS_MASTER_DSI_LINK(msm_dsi->id); in msm_dsi_is_master_dsi()