# define VC4_HD_M_ENABLE                       BIT(0)
 
 #define CEC_CLOCK_FREQ 40000
-#define VC4_HSM_MID_CLOCK 149985000
 
 #define HDMI_14_MAX_TMDS_CLK   (340 * 1000 * 1000)
 
                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 pixel_rate, hsm_rate;
+       unsigned long bvb_rate, pixel_rate, hsm_rate;
        int ret;
 
        ret = pm_runtime_get_sync(&vc4_hdmi->pdev->dev);
 
        vc4_hdmi_cec_update_clk_div(vc4_hdmi);
 
-       /*
-        * FIXME: When the pixel freq is 594MHz (4k60), this needs to be setup
-        * at 300MHz.
-        */
-       ret = clk_set_min_rate(vc4_hdmi->pixel_bvb_clock,
-                              (hsm_rate > VC4_HSM_MID_CLOCK ? 150000000 : 75000000));
+       if (pixel_rate > 297000000)
+               bvb_rate = 300000000;
+       else if (pixel_rate > 148500000)
+               bvb_rate = 150000000;
+       else
+               bvb_rate = 75000000;
+
+       ret = clk_set_min_rate(vc4_hdmi->pixel_bvb_clock, bvb_rate);
        if (ret) {
                DRM_ERROR("Failed to set pixel bvb clock rate: %d\n", ret);
                clk_disable_unprepare(vc4_hdmi->hsm_clock);