The KMD needs to access the clear-color value stored in the buffer via
the CPU. On small-bar systems reject any buffers that are potentially
not CPU accessible.
Signed-off-by: Matthew Auld <matthew.auld@intel.com>
Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Cc: Thomas Hellström <thomas.hellstrom@linux.intel.com>
Cc: Gwan-gyeong Mun <gwan-gyeong.mun@intel.com>
Cc: Lucas De Marchi <lucas.demarchi@intel.com>
Cc: José Roberto de Souza <jose.souza@intel.com>
Cc: Filip Hazubski <filip.hazubski@intel.com>
Cc: Carl Zhang <carl.zhang@intel.com>
Cc: Effie Yu <effie.yu@intel.com>
Reviewed-by: José Roberto de Souza <jose.souza@intel.com>
Reviewed-by: Gwan-gyeong Mun <gwan-gyeong.mun@intel.com>
[ Split display-related changes from small-bar support ]
Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com>
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
                goto err;
        }
 
+       if (IS_DGFX(to_xe_device(bo->ttm.base.dev)) &&
+           intel_fb_rc_ccs_cc_plane(&fb->base) >= 0 &&
+           !(bo->flags & XE_BO_NEEDS_CPU_ACCESS)) {
+               struct xe_tile *tile = xe_device_get_root_tile(xe);
+
+               /*
+                * If we need to able to access the clear-color value stored in
+                * the buffer, then we require that such buffers are also CPU
+                * accessible.  This is important on small-bar systems where
+                * only some subset of VRAM is CPU accessible.
+                */
+               if (tile->mem.vram.io_size < tile->mem.vram.usable_size) {
+                       ret = -EINVAL;
+                       goto err;
+               }
+       }
+
        /*
         * Pin the framebuffer, we can't use xe_bo_(un)pin functions as the
         * assumptions are incorrect for framebuffers