RE: [PATCH 04/11] drm/amdgpu/mes: centralize gfx_hqd mask management

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



[Public]

> From: amd-gfx <amd-gfx-bounces@xxxxxxxxxxxxxxxxxxxxx> On Behalf Of Alex
> Deucher
> Sent: Thursday, March 13, 2025 10:41 PM
> To: amd-gfx@xxxxxxxxxxxxxxxxxxxxx
> Cc: Deucher, Alexander <Alexander.Deucher@xxxxxxx>; Khatri, Sunil
> <Sunil.Khatri@xxxxxxx>
> Subject: [PATCH 04/11] drm/amdgpu/mes: centralize gfx_hqd mask management
>
> Move it to amdgpu_mes to align with the compute and sdma hqd masks. No
> functional change.
>
> v2: rebase on new changes
>
> Reviewed-by: Sunil Khatri<sunil.khatri@xxxxxxx>
> Signed-off-by: Alex Deucher <alexander.deucher@xxxxxxx>
> ---
>  drivers/gpu/drm/amd/amdgpu/amdgpu_mes.c | 22 ++++++++++++++++++++++
> drivers/gpu/drm/amd/amdgpu/mes_v11_0.c  | 16 +++-------------
> drivers/gpu/drm/amd/amdgpu/mes_v12_0.c  | 15 +++------------
>  3 files changed, 28 insertions(+), 25 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_mes.c
> b/drivers/gpu/drm/amd/amdgpu/amdgpu_mes.c
> index 6f5e272d7ded3..5abc1ca0fee98 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_mes.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_mes.c
> @@ -108,6 +108,28 @@ int amdgpu_mes_init(struct amdgpu_device *adev)
>       adev->mes.vmid_mask_mmhub = 0xffffff00;
>       adev->mes.vmid_mask_gfxhub = 0xffffff00;
>
> +     for (i = 0; i < AMDGPU_MES_MAX_GFX_PIPES; i++) {
> +             /* use only 1st ME pipe */
> +             if (i >= adev->gfx.me.num_pipe_per_me)
> +                     continue;
If only requires setting the 1st pipe MES mask here, it seems unnecessary to continue the rest setting loop.
Other than that, the patch is Reviewed-by: Prike Liang <Prike.Liang@xxxxxxx>.

Thanks,
Prike
> +             if (amdgpu_ip_version(adev, GC_HWIP, 0) >=
> +                 IP_VERSION(12, 0, 0))
> +                     /*
> +                      * GFX V12 has only one GFX pipe, but 8 queues in it.
> +                      * GFX pipe 0 queue 0 is being used by Kernel queue.
> +                      * Set GFX pipe 0 queue 1-7 for MES scheduling
> +                      * mask = 1111 1110b
> +                      */
> +                     adev->mes.gfx_hqd_mask[i] = 0xFE;
> +             else
> +                     /*
> +                      * GFX pipe 0 queue 0 is being used by Kernel queue.
> +                      * Set GFX pipe 0 queue 1 for MES scheduling
> +                      * mask = 10b
> +                      */
> +                     adev->mes.gfx_hqd_mask[i] = 0x2;
> +     }
> +
>       for (i = 0; i < AMDGPU_MES_MAX_COMPUTE_PIPES; i++) {
>               /* use only 1st MEC pipes */
>               if (i >= adev->gfx.mec.num_pipe_per_mec) diff --git
> a/drivers/gpu/drm/amd/amdgpu/mes_v11_0.c
> b/drivers/gpu/drm/amd/amdgpu/mes_v11_0.c
> index a569d09a1a748..39b45d8b5f049 100644
> --- a/drivers/gpu/drm/amd/amdgpu/mes_v11_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/mes_v11_0.c
> @@ -669,18 +669,6 @@ static int mes_v11_0_misc_op(struct amdgpu_mes
> *mes,
>                       offsetof(union MESAPI__MISC, api_status));  }
>
> -static void mes_v11_0_set_gfx_hqd_mask(union
> MESAPI_SET_HW_RESOURCES *pkt) -{
> -     /*
> -      * GFX pipe 0 queue 0 is being used by Kernel queue.
> -      * Set GFX pipe 0 queue 1 for MES scheduling
> -      * mask = 10b
> -      * GFX pipe 1 can't be used for MES due to HW limitation.
> -      */
> -     pkt->gfx_hqd_mask[0] = 0x2;
> -     pkt->gfx_hqd_mask[1] = 0;
> -}
> -
>  static int mes_v11_0_set_hw_resources(struct amdgpu_mes *mes)  {
>       int i;
> @@ -705,7 +693,9 @@ static int mes_v11_0_set_hw_resources(struct
> amdgpu_mes *mes)
>               mes_set_hw_res_pkt.compute_hqd_mask[i] =
>                       mes->compute_hqd_mask[i];
>
> -     mes_v11_0_set_gfx_hqd_mask(&mes_set_hw_res_pkt);
> +     for (i = 0; i < MAX_GFX_PIPES; i++)
> +             mes_set_hw_res_pkt.gfx_hqd_mask[i] =
> +                     mes->gfx_hqd_mask[i];
>
>       for (i = 0; i < MAX_SDMA_PIPES; i++)
>               mes_set_hw_res_pkt.sdma_hqd_mask[i] = mes-
> >sdma_hqd_mask[i]; diff --git a/drivers/gpu/drm/amd/amdgpu/mes_v12_0.c
> b/drivers/gpu/drm/amd/amdgpu/mes_v12_0.c
> index 96336652d14c5..519f054bec60d 100644
> --- a/drivers/gpu/drm/amd/amdgpu/mes_v12_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/mes_v12_0.c
> @@ -694,17 +694,6 @@ static int mes_v12_0_set_hw_resources_1(struct
> amdgpu_mes *mes, int pipe)
>                       offsetof(union MESAPI_SET_HW_RESOURCES_1,
> api_status));  }
>
> -static void mes_v12_0_set_gfx_hqd_mask(union
> MESAPI_SET_HW_RESOURCES *pkt) -{
> -     /*
> -      * GFX V12 has only one GFX pipe, but 8 queues in it.
> -      * GFX pipe 0 queue 0 is being used by Kernel queue.
> -      * Set GFX pipe 0 queue 1-7 for MES scheduling
> -      * mask = 1111 1110b
> -      */
> -     pkt->gfx_hqd_mask[0] = 0xFE;
> -}
> -
>  static int mes_v12_0_set_hw_resources(struct amdgpu_mes *mes, int pipe)  {
>       int i;
> @@ -727,7 +716,9 @@ static int mes_v12_0_set_hw_resources(struct
> amdgpu_mes *mes, int pipe)
>                       mes_set_hw_res_pkt.compute_hqd_mask[i] =
>                               mes->compute_hqd_mask[i];
>
> -             mes_v12_0_set_gfx_hqd_mask(&mes_set_hw_res_pkt);
> +             for (i = 0; i < MAX_GFX_PIPES; i++)
> +                     mes_set_hw_res_pkt.gfx_hqd_mask[i] =
> +                             mes->gfx_hqd_mask[i];
>
>               for (i = 0; i < MAX_SDMA_PIPES; i++)
>                       mes_set_hw_res_pkt.sdma_hqd_mask[i] =
> --
> 2.48.1





[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux