Lines Matching +full:charge +full:- +full:integration

4  * Permission is hereby granted, free of charge, to any person obtaining a
17 * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
25 #include <linux/media-bus-format.h>
50 * [ CRTC ---> ] Encoder ---> Bridge A ---> Bridge B
64 * DOC: display driver integration
88 * drm_atomic_helper_commit_modeset_disables() (either directly in hand-rolled
89 * commit check and commit tail handlers, or through the higher-level
98 * connector-related operations exposed by the bridge (see the overview
110 * - The upstream driver doesn't use the component framework and isn't a
111 * MIPI-DSI host. In this case, the bridge driver will probe at some
115 * - The upstream driver doesn't use the component framework, but is a
116 * MIPI-DSI host. The bridge device uses the MIPI-DCS commands to be
119 * device (and MIPI-DSI host) is present. The upstream driver will be
126 * - The upstream driver uses the component framework and is a MIPI-DSI
127 * host. The bridge device uses the MIPI-DCS commands to be
131 * - The upstream driver uses the component framework and is a MIPI-DSI
139 * MIPI-DSI host driver case) is to split the operations like this:
141 * - The MIPI-DSI host driver must run mipi_dsi_host_register() in its
142 * probe hook. It will make sure that the MIPI-DSI host sticks around,
145 * - In its probe hook, the bridge driver must try to find its MIPI-DSI
146 * host, register as a MIPI-DSI device and attach the MIPI-DSI device
149 * - In its &struct mipi_dsi_host_ops.attach hook, the MIPI-DSI host can
155 * the bridge driver are functional and we can't have a deadlock-like
168 * must not be assumed that it is LP-11.
169 * pre_enable should initialise the PHY, set the data lanes to LP-11, and the
170 * clock lane to either LP-11 or HS depending on the mode_flag
174 * called before the DSI host. If the DSI peripheral requires LP-11 and/or
183 * should stop transmitting video, and the data lanes should return to the LP-11
202 * drm_bridge_add - add the given bridge to the global bridge list
208 mutex_init(&bridge->hpd_mutex); in drm_bridge_add()
211 list_add_tail(&bridge->list, &bridge_list); in drm_bridge_add()
222 * devm_drm_bridge_add - devm managed version of drm_bridge_add()
240 * drm_bridge_remove - remove the given bridge from the global bridge list
247 list_del_init(&bridge->list); in drm_bridge_remove()
250 mutex_destroy(&bridge->hpd_mutex); in drm_bridge_remove()
260 state = bridge->funcs->atomic_duplicate_state(bridge); in drm_bridge_atomic_duplicate_priv_state()
261 return state ? &state->base : NULL; in drm_bridge_atomic_duplicate_priv_state()
271 bridge->funcs->atomic_destroy_state(bridge, state); in drm_bridge_atomic_destroy_priv_state()
280 * drm_bridge_attach - attach the bridge to an encoder's chain
292 * If non-NULL the previous bridge must be already attached by a call to this
295 * Note that bridges attached to encoders are auto-detached during encoder
309 return -EINVAL; in drm_bridge_attach()
311 if (previous && (!previous->dev || previous->encoder != encoder)) in drm_bridge_attach()
312 return -EINVAL; in drm_bridge_attach()
314 if (bridge->dev) in drm_bridge_attach()
315 return -EBUSY; in drm_bridge_attach()
317 bridge->dev = encoder->dev; in drm_bridge_attach()
318 bridge->encoder = encoder; in drm_bridge_attach()
321 list_add(&bridge->chain_node, &previous->chain_node); in drm_bridge_attach()
323 list_add(&bridge->chain_node, &encoder->bridge_chain); in drm_bridge_attach()
325 if (bridge->funcs->attach) { in drm_bridge_attach()
326 ret = bridge->funcs->attach(bridge, flags); in drm_bridge_attach()
331 if (bridge->funcs->atomic_reset) { in drm_bridge_attach()
334 state = bridge->funcs->atomic_reset(bridge); in drm_bridge_attach()
340 drm_atomic_private_obj_init(bridge->dev, &bridge->base, in drm_bridge_attach()
341 &state->base, in drm_bridge_attach()
348 if (bridge->funcs->detach) in drm_bridge_attach()
349 bridge->funcs->detach(bridge); in drm_bridge_attach()
352 bridge->dev = NULL; in drm_bridge_attach()
353 bridge->encoder = NULL; in drm_bridge_attach()
354 list_del(&bridge->chain_node); in drm_bridge_attach()
358 bridge->of_node, encoder->name, ret); in drm_bridge_attach()
361 encoder->name, ret); in drm_bridge_attach()
373 if (WARN_ON(!bridge->dev)) in drm_bridge_detach()
376 if (bridge->funcs->atomic_reset) in drm_bridge_detach()
377 drm_atomic_private_obj_fini(&bridge->base); in drm_bridge_detach()
379 if (bridge->funcs->detach) in drm_bridge_detach()
380 bridge->funcs->detach(bridge); in drm_bridge_detach()
382 list_del(&bridge->chain_node); in drm_bridge_detach()
383 bridge->dev = NULL; in drm_bridge_detach()
394 * - The encoder-related operations support control of the bridges in the
403 * finer-grained control.
410 * Mixing atomic and non-atomic versions of the operations is not supported.
412 * - The bus format negotiation operations
420 * encoder-related operations. This feature is not supported by the legacy
423 * - The connector-related operations support implementing a &drm_connector
434 * an externally-implemented &drm_connector. Those operations are
442 * Bridge drivers shall implement the connector-related operations for all
447 * controller of the SoC. Support for the connector-related operations on the
458 * read-only memory.
462 * connected-related bridge operations. Connector creation is then controlled
476 * drm_bridge_chain_mode_fixup - fixup proposed mode for all bridges in the
499 encoder = bridge->encoder; in drm_bridge_chain_mode_fixup()
500 list_for_each_entry_from(bridge, &encoder->bridge_chain, chain_node) { in drm_bridge_chain_mode_fixup()
501 if (!bridge->funcs->mode_fixup) in drm_bridge_chain_mode_fixup()
504 if (!bridge->funcs->mode_fixup(bridge, mode, adjusted_mode)) in drm_bridge_chain_mode_fixup()
513 * drm_bridge_chain_mode_valid - validate the mode against all bridges in the
538 encoder = bridge->encoder; in drm_bridge_chain_mode_valid()
539 list_for_each_entry_from(bridge, &encoder->bridge_chain, chain_node) { in drm_bridge_chain_mode_valid()
542 if (!bridge->funcs->mode_valid) in drm_bridge_chain_mode_valid()
545 ret = bridge->funcs->mode_valid(bridge, info, mode); in drm_bridge_chain_mode_valid()
555 * drm_bridge_chain_mode_set - set proposed mode for all bridges in the
575 encoder = bridge->encoder; in drm_bridge_chain_mode_set()
576 list_for_each_entry_from(bridge, &encoder->bridge_chain, chain_node) { in drm_bridge_chain_mode_set()
577 if (bridge->funcs->mode_set) in drm_bridge_chain_mode_set()
578 bridge->funcs->mode_set(bridge, mode, adjusted_mode); in drm_bridge_chain_mode_set()
584 * drm_atomic_bridge_chain_disable - disables all bridges in the encoder chain
604 encoder = bridge->encoder; in drm_atomic_bridge_chain_disable()
605 list_for_each_entry_reverse(iter, &encoder->bridge_chain, chain_node) { in drm_atomic_bridge_chain_disable()
606 if (iter->funcs->atomic_disable) { in drm_atomic_bridge_chain_disable()
615 iter->funcs->atomic_disable(iter, old_bridge_state); in drm_atomic_bridge_chain_disable()
616 } else if (iter->funcs->disable) { in drm_atomic_bridge_chain_disable()
617 iter->funcs->disable(iter); in drm_atomic_bridge_chain_disable()
629 if (old_state && bridge->funcs->atomic_post_disable) { in drm_atomic_bridge_call_post_disable()
638 bridge->funcs->atomic_post_disable(bridge, in drm_atomic_bridge_call_post_disable()
640 } else if (bridge->funcs->post_disable) { in drm_atomic_bridge_call_post_disable()
641 bridge->funcs->post_disable(bridge); in drm_atomic_bridge_call_post_disable()
646 * drm_atomic_bridge_chain_post_disable - cleans up after disabling all bridges
671 encoder = bridge->encoder; in drm_atomic_bridge_chain_post_disable()
673 list_for_each_entry_from(bridge, &encoder->bridge_chain, chain_node) { in drm_atomic_bridge_chain_post_disable()
676 if (!list_is_last(&bridge->chain_node, &encoder->bridge_chain)) { in drm_atomic_bridge_chain_post_disable()
679 if (next->pre_enable_prev_first) { in drm_atomic_bridge_chain_post_disable()
688 list_for_each_entry_from(next, &encoder->bridge_chain, in drm_atomic_bridge_chain_post_disable()
690 if (!next->pre_enable_prev_first) { in drm_atomic_bridge_chain_post_disable()
696 if (list_is_last(&next->chain_node, in drm_atomic_bridge_chain_post_disable()
697 &encoder->bridge_chain)) { in drm_atomic_bridge_chain_post_disable()
704 list_for_each_entry_from_reverse(next, &encoder->bridge_chain, in drm_atomic_bridge_chain_post_disable()
727 if (old_state && bridge->funcs->atomic_pre_enable) { in drm_atomic_bridge_call_pre_enable()
736 bridge->funcs->atomic_pre_enable(bridge, old_bridge_state); in drm_atomic_bridge_call_pre_enable()
737 } else if (bridge->funcs->pre_enable) { in drm_atomic_bridge_call_pre_enable()
738 bridge->funcs->pre_enable(bridge); in drm_atomic_bridge_call_pre_enable()
743 * drm_atomic_bridge_chain_pre_enable - prepares for enabling all bridges in
767 encoder = bridge->encoder; in drm_atomic_bridge_chain_pre_enable()
769 list_for_each_entry_reverse(iter, &encoder->bridge_chain, chain_node) { in drm_atomic_bridge_chain_pre_enable()
770 if (iter->pre_enable_prev_first) { in drm_atomic_bridge_chain_pre_enable()
774 &encoder->bridge_chain, in drm_atomic_bridge_chain_pre_enable()
779 if (!next->pre_enable_prev_first) { in drm_atomic_bridge_chain_pre_enable()
788 list_for_each_entry_from(next, &encoder->bridge_chain, chain_node) { in drm_atomic_bridge_chain_pre_enable()
804 if (iter->pre_enable_prev_first) in drm_atomic_bridge_chain_pre_enable()
815 * drm_atomic_bridge_chain_enable - enables all bridges in the encoder chain
834 encoder = bridge->encoder; in drm_atomic_bridge_chain_enable()
835 list_for_each_entry_from(bridge, &encoder->bridge_chain, chain_node) { in drm_atomic_bridge_chain_enable()
836 if (bridge->funcs->atomic_enable) { in drm_atomic_bridge_chain_enable()
845 bridge->funcs->atomic_enable(bridge, old_bridge_state); in drm_atomic_bridge_chain_enable()
846 } else if (bridge->funcs->enable) { in drm_atomic_bridge_chain_enable()
847 bridge->funcs->enable(bridge); in drm_atomic_bridge_chain_enable()
857 if (bridge->funcs->atomic_check) { in drm_atomic_bridge_check()
861 bridge_state = drm_atomic_get_new_bridge_state(crtc_state->state, in drm_atomic_bridge_check()
864 return -EINVAL; in drm_atomic_bridge_check()
866 ret = bridge->funcs->atomic_check(bridge, bridge_state, in drm_atomic_bridge_check()
870 } else if (bridge->funcs->mode_fixup) { in drm_atomic_bridge_check()
871 if (!bridge->funcs->mode_fixup(bridge, &crtc_state->mode, in drm_atomic_bridge_check()
872 &crtc_state->adjusted_mode)) in drm_atomic_bridge_check()
873 return -EINVAL; in drm_atomic_bridge_check()
892 cur_state = drm_atomic_get_new_bridge_state(crtc_state->state, in select_bus_fmt_recursive()
901 if (!cur_bridge->funcs->atomic_get_input_bus_fmts) { in select_bus_fmt_recursive()
916 cur_state->input_bus_cfg.format = MEDIA_BUS_FMT_FIXED; in select_bus_fmt_recursive()
917 cur_state->output_bus_cfg.format = out_bus_fmt; in select_bus_fmt_recursive()
924 * If the driver implements ->atomic_get_input_bus_fmts() it in select_bus_fmt_recursive()
928 return -EINVAL; in select_bus_fmt_recursive()
930 in_bus_fmts = cur_bridge->funcs->atomic_get_input_bus_fmts(cur_bridge, in select_bus_fmt_recursive()
937 return -ENOTSUPP; in select_bus_fmt_recursive()
939 return -ENOMEM; in select_bus_fmt_recursive()
942 cur_state->input_bus_cfg.format = in_bus_fmts[0]; in select_bus_fmt_recursive()
943 cur_state->output_bus_cfg.format = out_bus_fmt; in select_bus_fmt_recursive()
952 if (ret != -ENOTSUPP) in select_bus_fmt_recursive()
957 cur_state->input_bus_cfg.format = in_bus_fmts[i]; in select_bus_fmt_recursive()
958 cur_state->output_bus_cfg.format = out_bus_fmt; in select_bus_fmt_recursive()
977 * support transcoding into a specific output format -ENOTSUPP is returned and
979 * combinations worked, -ENOTSUPP is returned and the atomic modeset will fail.
1004 struct drm_connector *conn = conn_state->connector; in drm_atomic_bridge_chain_select_bus_fmts()
1005 struct drm_encoder *encoder = bridge->encoder; in drm_atomic_bridge_chain_select_bus_fmts()
1012 last_bridge = list_last_entry(&encoder->bridge_chain, in drm_atomic_bridge_chain_select_bus_fmts()
1014 last_bridge_state = drm_atomic_get_new_bridge_state(crtc_state->state, in drm_atomic_bridge_chain_select_bus_fmts()
1017 if (last_bridge->funcs->atomic_get_output_bus_fmts) { in drm_atomic_bridge_chain_select_bus_fmts()
1018 const struct drm_bridge_funcs *funcs = last_bridge->funcs; in drm_atomic_bridge_chain_select_bus_fmts()
1021 * If the driver implements ->atomic_get_output_bus_fmts() it in drm_atomic_bridge_chain_select_bus_fmts()
1025 return -EINVAL; in drm_atomic_bridge_chain_select_bus_fmts()
1027 out_bus_fmts = funcs->atomic_get_output_bus_fmts(last_bridge, in drm_atomic_bridge_chain_select_bus_fmts()
1033 return -ENOTSUPP; in drm_atomic_bridge_chain_select_bus_fmts()
1035 return -ENOMEM; in drm_atomic_bridge_chain_select_bus_fmts()
1040 return -ENOMEM; in drm_atomic_bridge_chain_select_bus_fmts()
1042 if (conn->display_info.num_bus_formats && in drm_atomic_bridge_chain_select_bus_fmts()
1043 conn->display_info.bus_formats) in drm_atomic_bridge_chain_select_bus_fmts()
1044 out_bus_fmts[0] = conn->display_info.bus_formats[0]; in drm_atomic_bridge_chain_select_bus_fmts()
1052 if (ret != -ENOTSUPP) in drm_atomic_bridge_chain_select_bus_fmts()
1089 output_flags = conn->display_info.bus_flags; in drm_atomic_bridge_propagate_bus_flags()
1098 output_flags = next_bridge_state->input_bus_cfg.flags; in drm_atomic_bridge_propagate_bus_flags()
1101 bridge_state->output_bus_cfg.flags = output_flags; in drm_atomic_bridge_propagate_bus_flags()
1109 bridge_state->input_bus_cfg.flags = output_flags; in drm_atomic_bridge_propagate_bus_flags()
1113 * drm_atomic_bridge_chain_check() - Do an atomic check on the bridge chain
1131 struct drm_connector *conn = conn_state->connector; in drm_atomic_bridge_chain_check()
1144 encoder = bridge->encoder; in drm_atomic_bridge_chain_check()
1145 list_for_each_entry_reverse(iter, &encoder->bridge_chain, chain_node) { in drm_atomic_bridge_chain_check()
1156 crtc_state->state); in drm_atomic_bridge_chain_check()
1171 * drm_bridge_detect - check if anything is attached to the bridge output
1185 if (!(bridge->ops & DRM_BRIDGE_OP_DETECT)) in drm_bridge_detect()
1188 return bridge->funcs->detect(bridge); in drm_bridge_detect()
1193 * drm_bridge_get_modes - fill all modes currently valid for the sink into the
1209 if (!(bridge->ops & DRM_BRIDGE_OP_MODES)) in drm_bridge_get_modes()
1212 return bridge->funcs->get_modes(bridge, connector); in drm_bridge_get_modes()
1217 * drm_bridge_edid_read - read the EDID data of the connected display
1234 if (!(bridge->ops & DRM_BRIDGE_OP_EDID)) in drm_bridge_edid_read()
1237 /* Transitional: Fall back to ->get_edid. */ in drm_bridge_edid_read()
1238 if (!bridge->funcs->edid_read) { in drm_bridge_edid_read()
1246 drm_edid = drm_edid_alloc(edid, (edid->extensions + 1) * EDID_LENGTH); in drm_bridge_edid_read()
1253 return bridge->funcs->edid_read(bridge, connector); in drm_bridge_edid_read()
1258 * drm_bridge_get_edid - get the EDID data of the connected display
1274 if (!(bridge->ops & DRM_BRIDGE_OP_EDID)) in drm_bridge_get_edid()
1277 return bridge->funcs->get_edid(bridge, connector); in drm_bridge_get_edid()
1282 * drm_bridge_hpd_enable - enable hot plug detection for the bridge
1284 * @cb: hot-plug detection callback
1285 * @data: data to be passed to the hot-plug detection callback
1293 * bridge->ops. This function shall not be called when the flag is not set.
1304 if (!(bridge->ops & DRM_BRIDGE_OP_HPD)) in drm_bridge_hpd_enable()
1307 mutex_lock(&bridge->hpd_mutex); in drm_bridge_hpd_enable()
1309 if (WARN(bridge->hpd_cb, "Hot plug detection already enabled\n")) in drm_bridge_hpd_enable()
1312 bridge->hpd_cb = cb; in drm_bridge_hpd_enable()
1313 bridge->hpd_data = data; in drm_bridge_hpd_enable()
1315 if (bridge->funcs->hpd_enable) in drm_bridge_hpd_enable()
1316 bridge->funcs->hpd_enable(bridge); in drm_bridge_hpd_enable()
1319 mutex_unlock(&bridge->hpd_mutex); in drm_bridge_hpd_enable()
1324 * drm_bridge_hpd_disable - disable hot plug detection for the bridge
1333 * bridge->ops. This function shall not be called when the flag is not set.
1337 if (!(bridge->ops & DRM_BRIDGE_OP_HPD)) in drm_bridge_hpd_disable()
1340 mutex_lock(&bridge->hpd_mutex); in drm_bridge_hpd_disable()
1341 if (bridge->funcs->hpd_disable) in drm_bridge_hpd_disable()
1342 bridge->funcs->hpd_disable(bridge); in drm_bridge_hpd_disable()
1344 bridge->hpd_cb = NULL; in drm_bridge_hpd_disable()
1345 bridge->hpd_data = NULL; in drm_bridge_hpd_disable()
1346 mutex_unlock(&bridge->hpd_mutex); in drm_bridge_hpd_disable()
1351 * drm_bridge_hpd_notify - notify hot plug detection events
1364 mutex_lock(&bridge->hpd_mutex); in drm_bridge_hpd_notify()
1365 if (bridge->hpd_cb) in drm_bridge_hpd_notify()
1366 bridge->hpd_cb(bridge->hpd_data, status); in drm_bridge_hpd_notify()
1367 mutex_unlock(&bridge->hpd_mutex); in drm_bridge_hpd_notify()
1373 * of_drm_find_bridge - find the bridge corresponding to the device node in
1388 if (bridge->of_node == np) { in of_drm_find_bridge()
1403 struct drm_debugfs_entry *entry = m->private; in drm_bridge_chains_info()
1404 struct drm_device *dev = entry->dev; in drm_bridge_chains_info()
1406 struct drm_mode_config *config = &dev->mode_config; in drm_bridge_chains_info()
1410 list_for_each_entry(encoder, &config->encoder_list, head) { in drm_bridge_chains_info()
1413 drm_printf(&p, "encoder[%u]\n", encoder->base.id); in drm_bridge_chains_info()
1417 bridge_idx, bridge->type, bridge->ops); in drm_bridge_chains_info()
1420 if (bridge->of_node) in drm_bridge_chains_info()
1421 drm_printf(&p, ", OF: %pOFfc", bridge->of_node); in drm_bridge_chains_info()
1439 drm_debugfs_add_files(minor->dev, drm_bridge_debugfs_list, in drm_bridge_debugfs_init()