Re: [PATCH 2/2] drm/amdgpu: Disable MCBP from soc21 for SRIOV

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

 



On Tue, Nov 1, 2022 at 4:41 AM Yiqing Yao <yiqing.yao@xxxxxxx> wrote:
>
> [why]
> Start from soc21, CP does not support MCBP, so disable it.
>
> [how]
> Used amgpu_mcbp flag alone instead of checking if is in SRIOV to
> enable/disable MCBP.
> Only set flag to enable on asic_type prior to soc21 in SRIOV.
>
> Signed-off-by: Yiqing Yao <yiqing.yao@xxxxxxx>

Series is:
Reviewed-by: Alex Deucher <alexander.deucher@xxxxxxx>

> ---
>  drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 2 +-
>  drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c    | 6 +++---
>  drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c   | 4 ++++
>  drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c     | 4 ++--
>  drivers/gpu/drm/amd/amdgpu/gfx_v11_0.c     | 2 +-
>  5 files changed, 11 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> index ae10acede495..522820eeaa59 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
> @@ -2397,7 +2397,7 @@ static int amdgpu_device_ip_init(struct amdgpu_device *adev)
>                         adev->ip_blocks[i].status.hw = true;
>
>                         /* right after GMC hw init, we create CSA */
> -                       if (amdgpu_mcbp || amdgpu_sriov_vf(adev)) {
> +                       if (amdgpu_mcbp) {
>                                 r = amdgpu_allocate_static_csa(adev, &adev->virt.csa_obj,
>                                                                 AMDGPU_GEM_DOMAIN_VRAM,
>                                                                 AMDGPU_CSA_SIZE);
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
> index 363946de78f1..c9595cf1dd0a 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
> @@ -796,7 +796,7 @@ int amdgpu_info_ioctl(struct drm_device *dev, void *data, struct drm_file *filp)
>                 dev_info->ids_flags = 0;
>                 if (adev->flags & AMD_IS_APU)
>                         dev_info->ids_flags |= AMDGPU_IDS_FLAGS_FUSION;
> -               if (amdgpu_mcbp || amdgpu_sriov_vf(adev))
> +               if (amdgpu_mcbp)
>                         dev_info->ids_flags |= AMDGPU_IDS_FLAGS_PREEMPTION;
>                 if (amdgpu_is_tmz(adev))
>                         dev_info->ids_flags |= AMDGPU_IDS_FLAGS_TMZ;
> @@ -1172,7 +1172,7 @@ int amdgpu_driver_open_kms(struct drm_device *dev, struct drm_file *file_priv)
>                 goto error_vm;
>         }
>
> -       if (amdgpu_mcbp || amdgpu_sriov_vf(adev)) {
> +       if (amdgpu_mcbp) {
>                 uint64_t csa_addr = amdgpu_csa_vaddr(adev) & AMDGPU_GMC_HOLE_MASK;
>
>                 r = amdgpu_map_static_csa(adev, &fpriv->vm, adev->virt.csa_obj,
> @@ -1236,7 +1236,7 @@ void amdgpu_driver_postclose_kms(struct drm_device *dev,
>         if (amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_VCE) != NULL)
>                 amdgpu_vce_free_handles(adev, file_priv);
>
> -       if (amdgpu_mcbp || amdgpu_sriov_vf(adev)) {
> +       if (amdgpu_mcbp) {
>                 /* TODO: how to handle reserve failure */
>                 BUG_ON(amdgpu_bo_reserve(adev->virt.csa_obj, true));
>                 amdgpu_vm_bo_del(adev, fpriv->csa_va);
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
> index c73abe54d974..dc032c44e924 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
> @@ -64,6 +64,10 @@ void amdgpu_virt_init_setting(struct amdgpu_device *adev)
>         ddev->driver_features &= ~DRIVER_ATOMIC;
>         adev->cg_flags = 0;
>         adev->pg_flags = 0;
> +
> +       /* enable mcbp for sriov asic_type before soc21 */
> +       amdgpu_mcbp = (adev->asic_type < CHIP_IP_DISCOVERY) ? 1 : 0;
> +
>  }
>
>  void amdgpu_virt_kiq_reg_write_reg_wait(struct amdgpu_device *adev,
> diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c
> index af94ac580d3e..ff3c127cf70d 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v10_0.c
> @@ -8489,7 +8489,7 @@ static void gfx_v10_0_ring_emit_ib_gfx(struct amdgpu_ring *ring,
>
>         control |= ib->length_dw | (vmid << 24);
>
> -       if ((amdgpu_sriov_vf(ring->adev) || amdgpu_mcbp) && (ib->flags & AMDGPU_IB_FLAG_PREEMPT)) {
> +       if (amdgpu_mcbp && (ib->flags & AMDGPU_IB_FLAG_PREEMPT)) {
>                 control |= INDIRECT_BUFFER_PRE_ENB(1);
>
>                 if (flags & AMDGPU_IB_PREEMPTED)
> @@ -8664,7 +8664,7 @@ static void gfx_v10_0_ring_emit_cntxcntl(struct amdgpu_ring *ring,
>  {
>         uint32_t dw2 = 0;
>
> -       if (amdgpu_mcbp || amdgpu_sriov_vf(ring->adev))
> +       if (amdgpu_mcbp)
>                 gfx_v10_0_ring_emit_ce_meta(ring,
>                                     (!amdgpu_sriov_vf(ring->adev) && flags & AMDGPU_IB_PREEMPTED) ? true : false);
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v11_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v11_0.c
> index f68e13b6282c..84a76c36d9a7 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gfx_v11_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v11_0.c
> @@ -5326,7 +5326,7 @@ static void gfx_v11_0_ring_emit_ib_gfx(struct amdgpu_ring *ring,
>
>         control |= ib->length_dw | (vmid << 24);
>
> -       if ((amdgpu_sriov_vf(ring->adev) || amdgpu_mcbp) && (ib->flags & AMDGPU_IB_FLAG_PREEMPT)) {
> +       if (amdgpu_mcbp && (ib->flags & AMDGPU_IB_FLAG_PREEMPT)) {
>                 control |= INDIRECT_BUFFER_PRE_ENB(1);
>
>                 if (flags & AMDGPU_IB_PREEMPTED)
> --
> 2.34.1
>



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

  Powered by Linux