From: Ville Syrjälä <[email protected]>

We only have a single num_{qgv,psf}_points value, there is no
need to replicate it in each plane group.

And drop the somewhat misplaced comments about pcode behaviour
from {icl,tgl}_max_bw_index() while at it.

Signed-off-by: Ville Syrjälä <[email protected]>
---
 drivers/gpu/drm/i915/display/intel_bw.c       | 52 ++++++++-----------
 .../gpu/drm/i915/display/intel_display_core.h |  4 +-
 2 files changed, 25 insertions(+), 31 deletions(-)

diff --git a/drivers/gpu/drm/i915/display/intel_bw.c 
b/drivers/gpu/drm/i915/display/intel_bw.c
index 19717a45aee8..6495924d0be8 100644
--- a/drivers/gpu/drm/i915/display/intel_bw.c
+++ b/drivers/gpu/drm/i915/display/intel_bw.c
@@ -155,8 +155,8 @@ static int adls_pcode_read_psf_gv_point_info(struct 
intel_display *display,
 
 static u16 icl_qgv_points_mask(struct intel_display *display)
 {
-       unsigned int num_psf_gv_points = display->bw.max[0].num_psf_gv_points;
-       unsigned int num_qgv_points = display->bw.max[0].num_qgv_points;
+       unsigned int num_psf_gv_points = display->bw.num_psf_gv_points;
+       unsigned int num_qgv_points = display->bw.num_qgv_points;
        u16 qgv_points = 0, psf_points = 0;
 
        /*
@@ -536,6 +536,9 @@ static int icl_get_bw_info(struct intel_display *display,
        ipqdepth = min(ipqdepthpch, display_bw_params->displayrtids / 
num_channels);
        qi.deinterleave = DIV_ROUND_UP(num_channels, is_y_tile(display) ? 4 : 
2);
 
+       display->bw.num_qgv_points = qi.num_qgv_points;
+       display->bw.num_psf_gv_points = qi.num_psf_points;
+
        for (i = 0; i < num_groups; i++) {
                struct intel_bw_info *bi = &display->bw.max[i];
                int clpchgroup;
@@ -544,9 +547,6 @@ static int icl_get_bw_info(struct intel_display *display,
                clpchgroup = (display_bw_params->deburst * qi.deinterleave / 
num_channels) << i;
                bi->num_planes = (ipqdepth - clpchgroup) / clpchgroup + 1;
 
-               bi->num_qgv_points = qi.num_qgv_points;
-               bi->num_psf_gv_points = qi.num_psf_points;
-
                for (j = 0; j < qi.num_qgv_points; j++) {
                        const struct intel_qgv_point *sp = &qi.points[j];
                        int ct, bw;
@@ -629,6 +629,9 @@ static int tgl_get_bw_info(struct intel_display *display,
         */
        clperchgroup = 4 * (8 / num_channels) * qi.deinterleave;
 
+       display->bw.num_qgv_points = qi.num_qgv_points;
+       display->bw.num_psf_gv_points = qi.num_psf_points;
+
        display->bw.max[0].num_planes = U8_MAX;
 
        for (i = 0; i < num_groups; i++) {
@@ -647,9 +650,6 @@ static int tgl_get_bw_info(struct intel_display *display,
                                bi_next->num_planes = 0;
                }
 
-               bi->num_qgv_points = qi.num_qgv_points;
-               bi->num_psf_gv_points = qi.num_psf_points;
-
                for (j = 0; j < qi.num_qgv_points; j++) {
                        const struct intel_qgv_point *sp = &qi.points[j];
                        int ct, bw;
@@ -702,11 +702,12 @@ static void dg2_get_bw_info(struct intel_display *display)
 {
        int i;
 
+       display->bw.num_qgv_points = 1;
+
        display->bw.max[0].num_planes = U8_MAX;
        display->bw.max[0].deratedbw[0] = display->platform.dg2_g11 ? 38000 : 
50000;
 
        /* Bandwidth does not depend on # of planes; set all groups the same */
-       display->bw.max[0].num_qgv_points = 1;
        for (i = 1; i < ARRAY_SIZE(display->bw.max); i++)
                display->bw.max[i] = display->bw.max[0];
 
@@ -732,6 +733,8 @@ static int xe2_hpd_get_bw_info(struct intel_display 
*display,
        peakbw = tgl_peakbw(num_channels, qi.channel_width, 
icl_sagv_max_dclk(&qi));
        maxdebw = min(soc_bw_params->deprogbwlimit * 1000, peakbw * 
DEPROGBWPCLIMIT / 100);
 
+       display->bw.num_qgv_points = qi.num_qgv_points;
+
        display->bw.max[0].num_planes = U8_MAX;
 
        for (i = 0; i < qi.num_qgv_points; i++) {
@@ -748,7 +751,6 @@ static int xe2_hpd_get_bw_info(struct intel_display 
*display,
        }
 
        /* Bandwidth does not depend on # of planes; set all groups the same */
-       display->bw.max[0].num_qgv_points = qi.num_qgv_points;
        for (i = 1; i < ARRAY_SIZE(display->bw.max); i++)
                display->bw.max[i] = display->bw.max[0];
 
@@ -767,6 +769,9 @@ static unsigned int icl_max_bw_index(struct intel_display 
*display,
 {
        int i;
 
+       if (qgv_point >= display->bw.num_qgv_points)
+               return UINT_MAX;
+
        /*
         * Let's return max bw for 0 planes
         */
@@ -776,13 +781,6 @@ static unsigned int icl_max_bw_index(struct intel_display 
*display,
                const struct intel_bw_info *bi =
                        &display->bw.max[i];
 
-               /*
-                * Pcode will not expose all QGV points when
-                * SAGV is forced to off/min/med/max.
-                */
-               if (qgv_point >= bi->num_qgv_points)
-                       return UINT_MAX;
-
                if (num_planes >= bi->num_planes)
                        return i;
        }
@@ -795,17 +793,13 @@ static unsigned int tgl_max_bw_index(struct intel_display 
*display,
 {
        int i;
 
+       if (qgv_point >= display->bw.num_qgv_points)
+               return UINT_MAX;
+
        for (i = ARRAY_SIZE(display->bw.max) - 1; i >= 0; i--) {
                const struct intel_bw_info *bi =
                        &display->bw.max[i];
 
-               /*
-                * Pcode will not expose all QGV points when
-                * SAGV is forced to off/min/med/max.
-                */
-               if (qgv_point >= bi->num_qgv_points)
-                       return UINT_MAX;
-
                if (num_planes <= bi->num_planes)
                        return i;
        }
@@ -941,7 +935,7 @@ intel_atomic_get_bw_state(struct intel_atomic_state *state)
 static unsigned int icl_max_bw_qgv_point_mask(struct intel_display *display,
                                              int num_active_planes)
 {
-       unsigned int num_qgv_points = display->bw.max[0].num_qgv_points;
+       unsigned int num_qgv_points = display->bw.num_qgv_points;
        unsigned int max_bw_point = 0;
        unsigned int max_bw = 0;
        int i;
@@ -977,7 +971,7 @@ static u16 icl_prepare_qgv_points_mask(struct intel_display 
*display,
 
 static unsigned int icl_max_bw_psf_gv_point_mask(struct intel_display *display)
 {
-       unsigned int num_psf_gv_points = display->bw.max[0].num_psf_gv_points;
+       unsigned int num_psf_gv_points = display->bw.num_psf_gv_points;
        unsigned int max_bw_point_mask = 0;
        unsigned int max_bw = 0;
        int i;
@@ -1082,7 +1076,7 @@ static int mtl_find_qgv_points(struct intel_display 
*display,
                               struct intel_bw_state *new_bw_state)
 {
        unsigned int best_rate = UINT_MAX;
-       unsigned int num_qgv_points = display->bw.max[0].num_qgv_points;
+       unsigned int num_qgv_points = display->bw.num_qgv_points;
        unsigned int qgv_peak_bw  = 0;
        int i;
        int ret;
@@ -1153,8 +1147,8 @@ static int icl_find_qgv_points(struct intel_display 
*display,
                               const struct intel_bw_state *old_bw_state,
                               struct intel_bw_state *new_bw_state)
 {
-       unsigned int num_psf_gv_points = display->bw.max[0].num_psf_gv_points;
-       unsigned int num_qgv_points = display->bw.max[0].num_qgv_points;
+       unsigned int num_psf_gv_points = display->bw.num_psf_gv_points;
+       unsigned int num_qgv_points = display->bw.num_qgv_points;
        u16 psf_points = 0;
        u16 qgv_points = 0;
        int i;
diff --git a/drivers/gpu/drm/i915/display/intel_display_core.h 
b/drivers/gpu/drm/i915/display/intel_display_core.h
index 09ce25a6d4b1..f13fa810ccca 100644
--- a/drivers/gpu/drm/i915/display/intel_display_core.h
+++ b/drivers/gpu/drm/i915/display/intel_display_core.h
@@ -329,10 +329,10 @@ struct intel_display {
                        unsigned int psf_bw[I915_NUM_PSF_GV_POINTS];
                        /* Peak BW for each QGV point */
                        unsigned int peakbw[I915_NUM_QGV_POINTS];
-                       u8 num_qgv_points;
-                       u8 num_psf_gv_points;
                        u8 num_planes;
                } max[6];
+               u8 num_qgv_points;
+               u8 num_psf_gv_points;
        } bw;
 
        struct {
-- 
2.53.0

Reply via email to