struct imx8mp_hdmi_pvi {
struct drm_bridge bridge;
struct device *dev;
- struct drm_bridge *next_bridge;
void __iomem *regs;
};
{
struct imx8mp_hdmi_pvi *pvi = to_imx8mp_hdmi_pvi(bridge);
- return drm_bridge_attach(encoder, pvi->next_bridge,
+ return drm_bridge_attach(encoder, pvi->bridge.next_bridge,
bridge, flags);
}
if (mode->flags & DRM_MODE_FLAG_PHSYNC)
val |= PVI_CTRL_OP_HSYNC_POL | PVI_CTRL_INP_HSYNC_POL;
- if (pvi->next_bridge->timings)
- bus_flags = pvi->next_bridge->timings->input_bus_flags;
+ if (pvi->bridge.next_bridge->timings)
+ bus_flags = pvi->bridge.next_bridge->timings->input_bus_flags;
else if (bridge_state)
bus_flags = bridge_state->input_bus_cfg.flags;
unsigned int *num_input_fmts)
{
struct imx8mp_hdmi_pvi *pvi = to_imx8mp_hdmi_pvi(bridge);
- struct drm_bridge *next_bridge = pvi->next_bridge;
+ struct drm_bridge *next_bridge = pvi->bridge.next_bridge;
struct drm_bridge_state *next_state;
if (!next_bridge->funcs->atomic_get_input_bus_fmts)
if (!remote)
return -EINVAL;
- pvi->next_bridge = of_drm_find_bridge(remote);
+ pvi->bridge.next_bridge = of_drm_find_and_get_bridge(remote);
of_node_put(remote);
- if (!pvi->next_bridge)
+ if (!pvi->bridge.next_bridge)
return dev_err_probe(&pdev->dev, -EPROBE_DEFER,
"could not find next bridge\n");
/* Register the bridge. */
pvi->bridge.of_node = pdev->dev.of_node;
- pvi->bridge.timings = pvi->next_bridge->timings;
+ pvi->bridge.timings = pvi->bridge.next_bridge->timings;
drm_bridge_add(&pvi->bridge);