[igt-dev] [PATCH i-g-t 1/3] lib/i915_blt: Remove src == dst pitch restriction
Karolina Stolarek
karolina.stolarek at intel.com
Thu Dec 15 10:43:54 UTC 2022
On 15.12.2022 09:41, Karolina Stolarek wrote:
> On 14.12.2022 19:57, Zbigniew Kempczyński wrote:
>> On Tue, Dec 13, 2022 at 04:37:26PM +0100, Karolina Stolarek wrote:
>>> On 12.12.2022 13:50, Zbigniew Kempczyński wrote:
>>>> During debugging phase we established there's not necessary to enforce
>>>> same pitch for destination surface in FULL_RESOLVE mode. Relax this
>>>> condition allowing caller to pass requirement surface configuration.
>>>>
>>>> Signed-off-by: Zbigniew Kempczyński <zbigniew.kempczynski at intel.com>
>>>> ---
>>>> lib/i915/i915_blt.c | 8 +++-----
>>>> 1 file changed, 3 insertions(+), 5 deletions(-)
>>>>
>>>> diff --git a/lib/i915/i915_blt.c b/lib/i915/i915_blt.c
>>>> index 3776c56c60..42c28623f9 100644
>>>> --- a/lib/i915/i915_blt.c
>>>> +++ b/lib/i915/i915_blt.c
>>>> @@ -317,13 +317,11 @@ static void fill_data(struct
>>>> gen12_block_copy_data *data,
>>>> data->dw00.special_mode = __special_mode(blt);
>>>> data->dw00.length = extended_command ? 20 : 10;
>>>> - if (__special_mode(blt) == SM_FULL_RESOLVE && blt->src.tiling
>>>> == T_TILE64) {
>>>> - data->dw01.dst_pitch = blt->src.pitch - 1;
>>>> + if (__special_mode(blt) == SM_FULL_RESOLVE)
>>>
>>> "blt->src.tiling == T_TILE64" part was introduced in commit cdc0258a4672
>>> ("lib/i915_blt: Narrow setting same pitch and aux-ccs to Tile64 only").
>>> I know it's a bit nit-picky, but could we revert that change (as it
>>> looks
>>> like it's not necessary), and have a separate commit that removes
>>> data->dw01.dst_pitch = blt->src.pitch - 1?
>>
>> Two reverts would be necessary: cdc0258a467 and 229bb0accbb7 so single
>> commit
>> against three looks better for me. Tiling inplace testing is still in
>> progress.
>> If you think better is to revert above and add another commit I'll do it.
>
> To me, some of the 229bb0accbb7 is still here (setting aux_mode), so I'd
> say the revert of it is not necessary. But, yeah, I think it would be
> better to revert cdc0258a467.
After further discussions with Zbigniew, we decided not to revert
cdc0258a467. The original implementation isn't correct, and reverting
two patches with a change on the top of it only muddies the waters.
Let's keep things simple, and go with this patch.
All the best,
Karolina
>>
>>>
>>> The question remains -- what actually caused the regression for Tile4
>>> and
>>> xmajor? Was it because of the pitch settings? I run the tests a
>>> couple of
>>> times in the row after applying this patch and everything worked as
>>> expected.
>>
>> Yes, dst pitch influences on destination surface state. For cascaded
>> src->mid->dst mid.pitch may differ from dst.pitch (tileX -> linear blit).
>> For inplace there's some side effect which we're debugging now.
>
> OK, so that seems like a root cause. As for inplace, I think it can be
> slightly different, but we can update the function once debugging is
> finished.
>
> All the best,
> Karolina
>
>>
>> --
>> Zbigniew
>>
>>>
>>> All the best,
>>> Karolina
>>>
>>>> data->dw01.dst_aux_mode = __aux_mode(&blt->src);
>>>> - } else {
>>>> - data->dw01.dst_pitch = blt->dst.pitch - 1;
>>>> + else
>>>> data->dw01.dst_aux_mode = __aux_mode(&blt->dst);
>>>> - }
>>>> + data->dw01.dst_pitch = blt->dst.pitch - 1;
>>>> data->dw01.dst_mocs = blt->dst.mocs;
>>>> data->dw01.dst_compression = blt->dst.compression;
More information about the igt-dev
mailing list