]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/bw: Rename struct intel_sa_info to intel_display_bw_params
authorGustavo Sousa <gustavo.sousa@intel.com>
Mon, 18 May 2026 16:14:03 +0000 (13:14 -0300)
committerGustavo Sousa <gustavo.sousa@intel.com>
Tue, 19 May 2026 17:25:04 +0000 (14:25 -0300)
To align with struct intel_platform_bw_params, rename struct
intel_sa_info to intel_display_bw_params.  Also add comments to contrast
their purposes.

v2:
  - Use gen11 and gen12 as prefixes for ICL's and TGL's display-specific
    parameters variables. (Matt)
  - Prefer to use "display" instead of "disp" in variable names. (Jani)
  - Drop the redundant "disp" from the variable names.

Cc: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Matt Roper <matthew.d.roper@intel.com>
Link: https://patch.msgid.link/20260518-separate-platform-from-diplay-ip-specific-bw-params-v4-4-918528006549@intel.com
Signed-off-by: Gustavo Sousa <gustavo.sousa@intel.com>
drivers/gpu/drm/i915/display/intel_bw.c

index 5f2f2b08b92f6dde228b30c33f0de3bf7bc0eb6c..26b294544d10f6c9f08cd6b01a01954cceb9df62 100644 (file)
@@ -372,6 +372,10 @@ static int icl_sagv_max_dclk(const struct intel_qgv_info *qi)
        return dclk;
 }
 
+/*
+ * Bandwidth parameters that are tied to the SoC (as opposed to struct
+ * intel_display_bw_params).
+ */
 struct intel_soc_bw_params {
        u8 deprogbwlimit;
        u8 derating;
@@ -454,22 +458,26 @@ static const struct intel_soc_bw_params *get_soc_bw_params(struct intel_display
        return NULL;
 }
 
-struct intel_sa_info {
+/*
+ * Bandwidth parameters that are tied to the display IP (as opposed to struct
+ * intel_soc_bw_params).
+ */
+struct intel_display_bw_params {
        u16 displayrtids;
        u8 deburst;
 };
 
-static const struct intel_sa_info icl_sa_info = {
+static const struct intel_display_bw_params gen11_bw_params = {
        .deburst = 8,
        .displayrtids = 128,
 };
 
-static const struct intel_sa_info tgl_sa_info = {
+static const struct intel_display_bw_params gen12_bw_params = {
        .deburst = 16,
        .displayrtids = 256,
 };
 
-static const struct intel_sa_info mtl_sa_info = {
+static const struct intel_display_bw_params xelpdp_bw_params = {
        .deburst = 32,
        .displayrtids = 256,
 };
@@ -477,7 +485,7 @@ static const struct intel_sa_info mtl_sa_info = {
 static int icl_get_bw_info(struct intel_display *display,
                           const struct dram_info *dram_info,
                           const struct intel_soc_bw_params *soc_bw_params,
-                          const struct intel_sa_info *sa)
+                          const struct intel_display_bw_params *display_bw_params)
 {
        struct intel_qgv_info qi = {};
        bool is_y_tile = true; /* assume y tile may be used */
@@ -497,7 +505,7 @@ static int icl_get_bw_info(struct intel_display *display,
 
        dclk_max = icl_sagv_max_dclk(&qi);
        maxdebw = min(soc_bw_params->deprogbwlimit * 1000, dclk_max * 16 * 6 / 10);
-       ipqdepth = min(ipqdepthpch, sa->displayrtids / num_channels);
+       ipqdepth = min(ipqdepthpch, display_bw_params->displayrtids / num_channels);
        qi.deinterleave = DIV_ROUND_UP(num_channels, is_y_tile ? 4 : 2);
 
        for (i = 0; i < num_groups; i++) {
@@ -505,7 +513,7 @@ static int icl_get_bw_info(struct intel_display *display,
                int clpchgroup;
                int j;
 
-               clpchgroup = (sa->deburst * qi.deinterleave / num_channels) << i;
+               clpchgroup = (display_bw_params->deburst * qi.deinterleave / num_channels) << i;
                bi->num_planes = (ipqdepth - clpchgroup) / clpchgroup + 1;
 
                bi->num_qgv_points = qi.num_points;
@@ -549,7 +557,7 @@ static int icl_get_bw_info(struct intel_display *display,
 static int tgl_get_bw_info(struct intel_display *display,
                           const struct dram_info *dram_info,
                           const struct intel_soc_bw_params *soc_bw_params,
-                          const struct intel_sa_info *sa)
+                          const struct intel_display_bw_params *display_bw_params)
 {
        struct intel_qgv_info qi = {};
        bool is_y_tile = true; /* assume y tile may be used */
@@ -587,7 +595,7 @@ static int tgl_get_bw_info(struct intel_display *display,
        peakbw = num_channels * DIV_ROUND_UP(qi.channel_width, 8) * dclk_max;
        maxdebw = min(soc_bw_params->deprogbwlimit * 1000, peakbw * DEPROGBWPCLIMIT / 100);
 
-       ipqdepth = min(ipqdepthpch, sa->displayrtids / num_channels);
+       ipqdepth = min(ipqdepthpch, display_bw_params->displayrtids / num_channels);
        /*
         * clperchgroup = 4kpagespermempage * clperchperblock,
         * clperchperblock = 8 / num_channels * interleave
@@ -600,7 +608,7 @@ static int tgl_get_bw_info(struct intel_display *display,
                int clpchgroup;
                int j;
 
-               clpchgroup = (sa->deburst * qi.deinterleave / num_channels) << i;
+               clpchgroup = (display_bw_params->deburst * qi.deinterleave / num_channels) << i;
 
                if (i < num_groups - 1) {
                        bi_next = &display->bw.max[i + 1];
@@ -843,7 +851,7 @@ void intel_bw_init_hw(struct intel_display *display)
        if (DISPLAY_VERx100(display) >= 1401 && display->platform.dgfx) {
                xe2_hpd_get_bw_info(display, dram_info, soc_bw_params);
        } else if (DISPLAY_VER(display) >= 14) {
-               tgl_get_bw_info(display, dram_info, soc_bw_params, &mtl_sa_info);
+               tgl_get_bw_info(display, dram_info, soc_bw_params, &xelpdp_bw_params);
        } else if (display->platform.dg2) {
                dg2_get_bw_info(display);
        } else if (DISPLAY_VER(display) >= 12) {
@@ -854,11 +862,11 @@ void intel_bw_init_hw(struct intel_display *display)
                 * parameters.
                 */
                if (display->platform.rocketlake)
-                       tgl_get_bw_info(display, dram_info, soc_bw_params, &icl_sa_info);
+                       tgl_get_bw_info(display, dram_info, soc_bw_params, &gen11_bw_params);
                else
-                       tgl_get_bw_info(display, dram_info, soc_bw_params, &tgl_sa_info);
+                       tgl_get_bw_info(display, dram_info, soc_bw_params, &gen12_bw_params);
        } else if (DISPLAY_VER(display) == 11) {
-               icl_get_bw_info(display, dram_info, soc_bw_params, &icl_sa_info);
+               icl_get_bw_info(display, dram_info, soc_bw_params, &gen11_bw_params);
        }
 }