drm/vc4: hdmi: Simplify the connector state retrieval
authorMaxime Ripard <maxime@cerno.tech>
Thu, 29 Apr 2021 19:58:27 +0000 (21:58 +0200)
committerPhil Elwell <8911409+pelwell@users.noreply.github.com>
Fri, 7 May 2021 15:48:29 +0000 (16:48 +0100)
When we have the entire DRM state, retrieving the connector state only
requires the drm_connector pointer. Fortunately for us, we have
allocated it as a part of the vc4_hdmi structure, so we can retrieve get
a pointer by simply accessing our field in that structure.

Signed-off-by: Maxime Ripard <maxime@cerno.tech>
drivers/gpu/drm/vc4/vc4_hdmi.c

index 5db4971a922035ee5f824384a6fdc29fe3346f9d..81c2c957183f81bc8785d93f67f578af0e32d612 100644 (file)
@@ -1184,31 +1184,16 @@ static void vc4_hdmi_recenter_fifo(struct vc4_hdmi *vc4_hdmi)
                  "VC4_HDMI_FIFO_CTL_RECENTER_DONE");
 }
 
-static struct drm_connector_state *
-vc4_hdmi_encoder_get_connector_state(struct drm_encoder *encoder,
-                                    struct drm_atomic_state *state)
-{
-       struct drm_connector_state *conn_state;
-       struct drm_connector *connector;
-       unsigned int i;
-
-       for_each_new_connector_in_state(state, connector, conn_state, i) {
-               if (conn_state->best_encoder == encoder)
-                       return conn_state;
-       }
-
-       return NULL;
-}
-
 static void vc4_hdmi_encoder_pre_crtc_configure(struct drm_encoder *encoder,
                                                struct drm_atomic_state *state)
 {
+       struct vc4_hdmi *vc4_hdmi = encoder_to_vc4_hdmi(encoder);
+       struct drm_connector *connector = &vc4_hdmi->connector;
        struct drm_connector_state *conn_state =
-               vc4_hdmi_encoder_get_connector_state(encoder, state);
+               drm_atomic_get_new_connector_state(state, connector);
        struct vc4_hdmi_connector_state *vc4_conn_state =
                conn_state_to_vc4_hdmi_conn_state(conn_state);
        struct drm_display_mode *mode = &encoder->crtc->state->adjusted_mode;
-       struct vc4_hdmi *vc4_hdmi = encoder_to_vc4_hdmi(encoder);
        unsigned long bvb_rate, pixel_rate, hsm_rate;
        int ret;