<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
p.MsoPlainText, li.MsoPlainText, div.MsoPlainText
{mso-style-priority:99;
mso-style-link:"Plain Text Char";
margin:0in;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
span.EmailStyle17
{mso-style-type:personal-compose;
font-family:"Calibri",sans-serif;
color:windowtext;}
span.PlainTextChar
{mso-style-name:"Plain Text Char";
mso-style-priority:99;
mso-style-link:"Plain Text";
font-family:"Calibri",sans-serif;}
.MsoChpDefault
{mso-style-type:export-only;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoPlainText">On 2023-04-18 at 09:10 PM, Bhanuprakash Modem wrote:<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">kms_draw_crc is failing with xe changes, initially to collect CRC the draw function igt_draw_rect() is failing due to failure of<o:p></o:p></p>
<p class="MsoPlainText">xe_vm_bind_array function in xe_ioctl file.<o:p></o:p></p>
<p class="MsoPlainText"><span style="background:yellow;mso-highlight:yellow">Test assertion failure function xe_vm_bind_array, file ../lib/xe/xe_ioctl.c:88</span><o:p></o:p></p>
<p class="MsoPlainText">Are we missing something here?<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">>Add XE driver support for differnt draw methods.<o:p></o:p></p>
<p class="MsoPlainText">Spelling of “different” is not correct.<o:p></o:p></p>
<p class="MsoPlainText">><o:p> </o:p></p>
<p class="MsoPlainText">>Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem@intel.com><o:p></o:p></p>
<p class="MsoPlainText">>---<o:p></o:p></p>
<p class="MsoPlainText">>tests/i915/kms_draw_crc.c | 24 ++++++++++++++----------<o:p></o:p></p>
<p class="MsoPlainText">> 1 file changed, 14 insertions(+), 10 deletions(-)<o:p></o:p></p>
<p class="MsoPlainText">><o:p> </o:p></p>
<p class="MsoPlainText">>diff --git a/tests/i915/kms_draw_crc.c b/tests/i915/kms_draw_crc.c<o:p></o:p></p>
<p class="MsoPlainText">>index 3a3cd99a0..db6d71f2e 100644 <o:p>
</o:p></p>
<p class="MsoPlainText">>--- a/tests/i915/kms_draw_crc.c<o:p></o:p></p>
<p class="MsoPlainText">>+++ b/tests/i915/kms_draw_crc.c<o:p></o:p></p>
<p class="MsoPlainText">>@@ -149,8 +149,8 @@ static void draw_method_subtest(enum igt_draw_method method,<o:p></o:p></p>
<p class="MsoPlainText">> * comparison. Cache the value so we don't recompute it for every single<o:p></o:p></p>
<p class="MsoPlainText">> * subtest. */<o:p></o:p></p>
<p class="MsoPlainText">> if (!base_crcs[format_index].set) {<o:p></o:p></p>
<p class="MsoPlainText">>- get_method_crc(gem_has_mappable_ggtt(drm_fd) ? IGT_DRAW_MMAP_GTT :<o:p></o:p></p>
<p class="MsoPlainText">>- IGT_DRAW_MMAP_WC,<o:p></o:p></p>
<p class="MsoPlainText">>+ get_method_crc(igt_draw_supports_method(drm_fd, IGT_DRAW_MMAP_GTT) ?<o:p></o:p></p>
<p class="MsoPlainText">>+ IGT_DRAW_MMAP_GTT : IGT_DRAW_MMAP_WC,<o:p></o:p></p>
<p class="MsoPlainText">> formats[format_index],<o:p></o:p></p>
<p class="MsoPlainText">> DRM_FORMAT_MOD_LINEAR,<o:p></o:p></p>
<p class="MsoPlainText">> &base_crcs[format_index].crc);<o:p></o:p></p>
<p class="MsoPlainText">>@@ -195,8 +195,8 @@ static void fill_fb_subtest(void)<o:p></o:p></p>
<p class="MsoPlainText">> igt_plane_set_fb(primary, &fb);<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> igt_draw_rect_fb(drm_fd, bops, 0, &fb,<o:p></o:p></p>
<p class="MsoPlainText">>- gem_has_mappable_ggtt(drm_fd) ? IGT_DRAW_MMAP_GTT :<o:p></o:p></p>
<p class="MsoPlainText">>- IGT_DRAW_MMAP_WC,<o:p></o:p></p>
<p class="MsoPlainText">>+ igt_draw_supports_method(drm_fd, IGT_DRAW_MMAP_GTT) ?<o:p></o:p></p>
<p class="MsoPlainText">>+ IGT_DRAW_MMAP_GTT : IGT_DRAW_MMAP_WC,<o:p></o:p></p>
<p class="MsoPlainText">> 0, 0, fb.width, fb.height, 0xFF);<o:p></o:p></p>
<p class="MsoPlainText">Why igt_draw_supports_method is used here?<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">-Nidhi<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> rc = igt_display_commit2(&display, display.is_atomic ? COMMIT_ATOMIC : COMMIT_LEGACY);<o:p></o:p></p>
<p class="MsoPlainText">>@@ -222,7 +222,7 @@ static void fill_fb_subtest(void)<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">>static void setup_environment(void)<o:p></o:p></p>
<p class="MsoPlainText">> {<o:p></o:p></p>
<p class="MsoPlainText">>- drm_fd = drm_open_driver_master(DRIVER_INTEL);<o:p></o:p></p>
<p class="MsoPlainText">>+ drm_fd = drm_open_driver_master(DRIVER_INTEL | DRIVER_XE);<o:p></o:p></p>
<p class="MsoPlainText">> igt_require(drm_fd >= 0);<o:p></o:p></p>
<p class="MsoPlainText">> igt_display_require(&display, drm_fd);<o:p></o:p></p>
<p class="MsoPlainText">> igt_display_require_output(&display);<o:p></o:p></p>
<p class="MsoPlainText">>@@ -289,13 +289,17 @@ igt_main<o:p></o:p></p>
<p class="MsoPlainText">> "method (%s) with different modifiers & DRM formats.",<o:p></o:p></p>
<p class="MsoPlainText">> igt_draw_get_method_name(method));<o:p></o:p></p>
<p class="MsoPlainText">> igt_subtest_with_dynamic_f("draw-method-%s", igt_draw_get_method_name(method)) {<o:p></o:p></p>
<p class="MsoPlainText">>- igt_skip_on(method == IGT_DRAW_MMAP_WC && !gem_mmap__has_wc(drm_fd));<o:p></o:p></p>
<p class="MsoPlainText">>- igt_skip_on(method == IGT_DRAW_MMAP_GTT && !gem_has_mappable_ggtt(drm_fd));<o:p></o:p></p>
<p class="MsoPlainText">>+ if (!igt_draw_supports_method(drm_fd, method))<o:p></o:p></p>
<p class="MsoPlainText">>+ continue;<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">>- for (format_idx = 0; format_idx < ARRAY_SIZE(formats); format_idx++) {<o:p></o:p></p>
<p class="MsoPlainText">>- for (modifier_idx = 0; modifier_idx < ARRAY_SIZE(modifiers); modifier_idx++) {<o:p></o:p></p>
<p class="MsoPlainText">>- modifier = modifiers[modifier_idx];<o:p></o:p></p>
<p class="MsoPlainText">>+ for (modifier_idx = 0; modifier_idx < ARRAY_SIZE(modifiers); modifier_idx++) {<o:p></o:p></p>
<p class="MsoPlainText">>+ modifier = modifiers[modifier_idx];<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">>+ /* No tiling support in XE. */<o:p></o:p></p>
<p class="MsoPlainText">>+ if (is_xe_device(drm_fd) && modifier != DRM_FORMAT_MOD_LINEAR)<o:p></o:p></p>
<p class="MsoPlainText">>+ continue;<o:p></o:p></p>
<p class="MsoPlainText">>+<o:p></o:p></p>
<p class="MsoPlainText">>+ for (format_idx = 0; format_idx < ARRAY_SIZE(formats); format_idx++) {<o:p></o:p></p>
<p class="MsoPlainText">> if (!igt_display_has_format_mod(&display, formats[format_idx], modifier))<o:p></o:p></p>
<p class="MsoPlainText">> continue;<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</body>
</html>