const struct intel_cdclk_config *cdclk_config,
                          enum pipe pipe);
        int (*bw_calc_min_cdclk)(struct intel_atomic_state *state);
-       int (*get_fifo_size)(struct drm_i915_private *dev_priv,
-                            enum i9xx_plane_id i9xx_plane);
        int (*compute_pipe_wm)(struct intel_atomic_state *state,
                               struct intel_crtc *crtc);
        int (*compute_intermediate_wm)(struct intel_atomic_state *state,
 
        else
                wm_info = &i830_a_wm_info;
 
-       fifo_size = dev_priv->display.get_fifo_size(dev_priv, PLANE_A);
+       if (DISPLAY_VER(dev_priv) == 2)
+               fifo_size = i830_get_fifo_size(dev_priv, PLANE_A);
+       else
+               fifo_size = i9xx_get_fifo_size(dev_priv, PLANE_A);
        crtc = intel_get_crtc_for_plane(dev_priv, PLANE_A);
        if (intel_crtc_active(crtc)) {
                const struct drm_display_mode *pipe_mode =
        if (DISPLAY_VER(dev_priv) == 2)
                wm_info = &i830_bc_wm_info;
 
-       fifo_size = dev_priv->display.get_fifo_size(dev_priv, PLANE_B);
+       if (DISPLAY_VER(dev_priv) == 2)
+               fifo_size = i830_get_fifo_size(dev_priv, PLANE_B);
+       else
+               fifo_size = i9xx_get_fifo_size(dev_priv, PLANE_B);
        crtc = intel_get_crtc_for_plane(dev_priv, PLANE_B);
        if (intel_crtc_active(crtc)) {
                const struct drm_display_mode *pipe_mode =
        pipe_mode = &crtc->config->hw.pipe_mode;
        planea_wm = intel_calculate_wm(pipe_mode->crtc_clock,
                                       &i845_wm_info,
-                                      dev_priv->display.get_fifo_size(dev_priv, PLANE_A),
+                                      i845_get_fifo_size(dev_priv, PLANE_A),
                                       4, pessimal_latency_ns);
        fwater_lo = intel_uncore_read(&dev_priv->uncore, FW_BLC) & ~0xfff;
        fwater_lo |= (3<<8) | planea_wm;
                dev_priv->display.update_wm = i965_update_wm;
        } else if (DISPLAY_VER(dev_priv) == 3) {
                dev_priv->display.update_wm = i9xx_update_wm;
-               dev_priv->display.get_fifo_size = i9xx_get_fifo_size;
        } else if (DISPLAY_VER(dev_priv) == 2) {
-               if (INTEL_NUM_PIPES(dev_priv) == 1) {
+               if (INTEL_NUM_PIPES(dev_priv) == 1)
                        dev_priv->display.update_wm = i845_update_wm;
-                       dev_priv->display.get_fifo_size = i845_get_fifo_size;
-               } else {
+               else
                        dev_priv->display.update_wm = i9xx_update_wm;
-                       dev_priv->display.get_fifo_size = i830_get_fifo_size;
-               }
        } else {
                drm_err(&dev_priv->drm,
                        "unexpected fall-through in %s\n", __func__);