Re: [PATCH] drm/amdgpu: Fix Gstreamer api vaapih264enc missing

2021-05-27 Thread Li, Xin (Justin)
Hi, friends.

My apologize for this patch.

I’ve ported this patch from another branch to fix gstreamer’s lack of 
“vaapi264enc”, currently this ported patch did fix that issue. However, since 
this patch is ported from another branch, I might need to do some alternations 
and audits mainly in its commit messages. I will file another review right 
after my fixes.

Thank you all for you time.

BR,
Justin

From: Liu, Monk 
Date: Thursday, May 27, 2021 at 07:57
To: Li, Xin (Justin) , amd-gfx@lists.freedesktop.org 

Cc: Li, Xin (Justin) , Deucher, Alexander 
, Min, Frank , Koenig, Christian 

Subject: RE: [PATCH] drm/amdgpu: Fix Gstreamer api vaapih264enc missing
[AMD Official Use Only]

Looks it lack enough background for people to review:


-   if (adev->vcn.inst[i].ring_dec.sched.ready)
+   if (adev->vcn.inst[i].ring_dec.sched.ready ||
+   (adev->asic_type == CHIP_NAVI12 &&
+   amdgpu_sriov_vf(adev)))
 ++num_rings;

[ml] why for SRIOV navi12 is forced to have those DEC rings ? since  SRIOV 
navi12 have no decode capability , any explain here ?


-   if (amdgpu_is_tmz(adev))
-   dev_info->ids_flags |= AMDGPU_IDS_FLAGS_TMZ;
[ML] why this is removed ? is it related to your issue ?


Thanks

--
Monk Liu | Cloud-GPU Core team
--

-Original Message-
From: amd-gfx  On Behalf Of Li, Xin 
(Justin)
Sent: Wednesday, May 26, 2021 6:13 PM
To: amd-gfx@lists.freedesktop.org
Cc: Li, Xin (Justin) ; Deucher, Alexander 
; Min, Frank ; Koenig, Christian 

Subject: [PATCH] drm/amdgpu: Fix Gstreamer api vaapih264enc missing

since vcn decoding ring is not required, so just disable it.

Cc: Alex.Deucher 
Cc: Christian.Konig 
Signed-off-by: Li.Xin.Justin 
Signed-off-by: Frank.Min 
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c |  6 +++---
 drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c   | 25 ++---
 2 files changed, 17 insertions(+), 14 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
index 524e4fe5efe8..614e6b06e94e 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
@@ -427,7 +427,9 @@ static int amdgpu_hw_ip_info(struct amdgpu_device *adev,
 if (adev->uvd.harvest_config & (1 << i))
 continue;

-   if (adev->vcn.inst[i].ring_dec.sched.ready)
+   if (adev->vcn.inst[i].ring_dec.sched.ready ||
+   (adev->asic_type == CHIP_NAVI12 &&
+   amdgpu_sriov_vf(adev)))
 ++num_rings;
 }
 ib_start_alignment = 16;
@@ -770,8 +772,6 @@ int amdgpu_info_ioctl(struct drm_device *dev, void *data, 
struct drm_file *filp)
 dev_info->ids_flags |= AMDGPU_IDS_FLAGS_FUSION;
 if (amdgpu_mcbp || amdgpu_sriov_vf(adev))
 dev_info->ids_flags |= AMDGPU_IDS_FLAGS_PREEMPTION;
-   if (amdgpu_is_tmz(adev))
-   dev_info->ids_flags |= AMDGPU_IDS_FLAGS_TMZ;

 vm_size = adev->vm_manager.max_pfn * AMDGPU_GPU_PAGE_SIZE;
 vm_size -= AMDGPU_VA_RESERVED_SIZE;
diff --git a/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c 
b/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c
index 8af567c546db..dc8a36766c4a 100644
--- a/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c
@@ -220,17 +220,20 @@ static int vcn_v2_0_hw_init(void *handle)
 {
 struct amdgpu_device *adev = (struct amdgpu_device *)handle;
 struct amdgpu_ring *ring = >vcn.inst->ring_dec;
-   int i, r;
+   int i, r = -1;

 adev->nbio.funcs->vcn_doorbell_range(adev, ring->use_doorbell,
  ring->doorbell_index, 0);

-   if (amdgpu_sriov_vf(adev))
+   if (amdgpu_sriov_vf(adev)) {
 vcn_v2_0_start_sriov(adev);
-
-   r = amdgpu_ring_test_helper(ring);
-   if (r)
-   goto done;
+   if (adev->asic_type == CHIP_NAVI12)
+   ring->sched.ready = false;
+   } else {
+   r = amdgpu_ring_test_helper(ring);
+   if (r)
+   goto done;
+   }

 //Disable vcn decode for sriov
 if (amdgpu_sriov_vf(adev))
@@ -245,8 +248,11 @@ static int vcn_v2_0_hw_init(void *handle)

 done:
 if (!r)
-   DRM_INFO("VCN decode and encode initialized successfully(under 
%s).\n",
-   (adev->pg_flags & AMD_PG_SUPPORT_VCN_DPG)?"DPG 
Mode":"SPG Mode");
+   

[PATCH] drm/amdgpu: Fix Gstreamer api vaapih264enc missing

2021-05-26 Thread Li, Xin (Justin)
since vcn decoding ring is not required, so just disable it.

Cc: Alex.Deucher 
Cc: Christian.Konig 
Signed-off-by: Li.Xin.Justin 
Signed-off-by: Frank.Min 
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c |  6 +++---
 drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c   | 25 ++---
 2 files changed, 17 insertions(+), 14 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
index 524e4fe5efe8..614e6b06e94e 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c
@@ -427,7 +427,9 @@ static int amdgpu_hw_ip_info(struct amdgpu_device *adev,
if (adev->uvd.harvest_config & (1 << i))
continue;
 
-   if (adev->vcn.inst[i].ring_dec.sched.ready)
+   if (adev->vcn.inst[i].ring_dec.sched.ready ||
+   (adev->asic_type == CHIP_NAVI12 &&
+   amdgpu_sriov_vf(adev)))
++num_rings;
}
ib_start_alignment = 16;
@@ -770,8 +772,6 @@ int amdgpu_info_ioctl(struct drm_device *dev, void *data, 
struct drm_file *filp)
dev_info->ids_flags |= AMDGPU_IDS_FLAGS_FUSION;
if (amdgpu_mcbp || amdgpu_sriov_vf(adev))
dev_info->ids_flags |= AMDGPU_IDS_FLAGS_PREEMPTION;
-   if (amdgpu_is_tmz(adev))
-   dev_info->ids_flags |= AMDGPU_IDS_FLAGS_TMZ;
 
vm_size = adev->vm_manager.max_pfn * AMDGPU_GPU_PAGE_SIZE;
vm_size -= AMDGPU_VA_RESERVED_SIZE;
diff --git a/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c 
b/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c
index 8af567c546db..dc8a36766c4a 100644
--- a/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/vcn_v2_0.c
@@ -220,17 +220,20 @@ static int vcn_v2_0_hw_init(void *handle)
 {
struct amdgpu_device *adev = (struct amdgpu_device *)handle;
struct amdgpu_ring *ring = >vcn.inst->ring_dec;
-   int i, r;
+   int i, r = -1;
 
adev->nbio.funcs->vcn_doorbell_range(adev, ring->use_doorbell,
 ring->doorbell_index, 0);
 
-   if (amdgpu_sriov_vf(adev))
+   if (amdgpu_sriov_vf(adev)) {
vcn_v2_0_start_sriov(adev);
-
-   r = amdgpu_ring_test_helper(ring);
-   if (r)
-   goto done;
+   if (adev->asic_type == CHIP_NAVI12)
+   ring->sched.ready = false;
+   } else {
+   r = amdgpu_ring_test_helper(ring);
+   if (r)
+   goto done;
+   }
 
//Disable vcn decode for sriov
if (amdgpu_sriov_vf(adev))
@@ -245,8 +248,11 @@ static int vcn_v2_0_hw_init(void *handle)
 
 done:
if (!r)
-   DRM_INFO("VCN decode and encode initialized successfully(under 
%s).\n",
-   (adev->pg_flags & AMD_PG_SUPPORT_VCN_DPG)?"DPG 
Mode":"SPG Mode");
+   DRM_INFO("VCN %s encode initialized successfully(under %s).\n",
+   (adev->asic_type == CHIP_NAVI12 &&
+   amdgpu_sriov_vf(adev))?"":"decode and",
+   (adev->pg_flags &
+   AMD_PG_SUPPORT_VCN_DPG)?"DPG Mode":"SPG Mode");
 
return r;
 }
@@ -1721,9 +1727,6 @@ int vcn_v2_0_dec_ring_test_ring(struct amdgpu_ring *ring)
unsigned i;
int r;
 
-   if (amdgpu_sriov_vf(adev))
-   return 0;
-
WREG32(adev->vcn.inst[ring->me].external.scratch9, 0xCAFEDEAD);
r = amdgpu_ring_alloc(ring, 4);
if (r)
-- 
2.25.1

___
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx


[PATCH] drm/amd/amdgpu: Add checksun check for pf2vf message

2020-11-02 Thread Li, Xin (Justin)
[AMD Official Use Only - Internal Distribution Only]

Add checksum checking for pf2vf message

Signed-off-by: Li, Xin (Justin) mailto:xin2...@amd.com>>
Signed-off-by: Zhou, Tiecheng 
mailto:thecheng.z...@amd.com>>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
index 836d784456e5..bfc74533b5ee 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
@@ -450,12 +450,11 @@ static int amdgpu_virt_read_pf2vf_data(struct 
amdgpu_device *adev)
 ((struct amdgim_pf2vf_info_v1 
*)pf2vf_info)->feature_flags;
 break;
 case 2:
-   /* TODO: missing key, need to add it later */
 checksum = ((struct amd_sriov_msg_pf2vf_info 
*)pf2vf_info)->checksum;
 checkval = amd_sriov_msg_checksum(
 adev->virt.fw_reserve.p_pf2vf, pf2vf_info->size,
-   0, checksum);
-   if (checksum != checkval) {
+   adev->virt.fw_reserve.checksum_key, checksum);
+   if (checksum != 0 && checksum != checkval) {
 DRM_ERROR("invalid pf2vf message\n");
 return -EINVAL;
 }
--
2.24.3 (Apple Git-128)

___
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx


Re: [PATCH] drm/amd/amdgpu: Add checksun check for pf2vf message

2020-10-28 Thread Li, Xin (Justin)
[AMD Official Use Only - Internal Distribution Only]

Any updates on this patch?

Best Regards,
Li, Xin (Justin)

From: Li, Xin (Justin) 
Date: Tuesday, October 27, 2020 at 14:36
To: amd-gfx@lists.freedesktop.org , Li, Xin 
(Justin) , Zhou, Tiecheng 
Subject: [PATCH] drm/amd/amdgpu: Add checksun check for pf2vf message

[AMD Official Use Only - Internal Distribution Only]

Add checksum checking for pf2vf message

Signed-off-by: Li, Xin (Justin) mailto:xin2...@amd.com>>
Signed-off-by: Zhou, Tiecheng 
mailto:tiecheng.z...@amd.com>>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
index 836d784456e5..bfc74533b5ee 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
@@ -450,12 +450,11 @@ static int amdgpu_virt_read_pf2vf_data(struct 
amdgpu_device *adev)
 ((struct amdgim_pf2vf_info_v1 
*)pf2vf_info)->feature_flags;
 break;
 case 2:
-   /* TODO: missing key, need to add it later */
 checksum = ((struct amd_sriov_msg_pf2vf_info 
*)pf2vf_info)->checksum;
 checkval = amd_sriov_msg_checksum(
 adev->virt.fw_reserve.p_pf2vf, pf2vf_info->size,
-   0, checksum);
-   if (checksum != checkval) {
+   adev->virt.fw_reserve.checksum_key, checksum);
+   if (checksum != 0 && checksum != checkval) {
 DRM_ERROR("invalid pf2vf message\n");
 return -EINVAL;
 }
--
2.24.3 (Apple Git-128)

___
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx


[PATCH] drm/amd/pm: Activate a more aggressive DPM policy while there's heavy load.

2020-10-27 Thread Li, Xin (Justin)
[AMD Official Use Only - Internal Distribution Only]

Fix performace drop while streaming Doom

Signed-off-by: Li, Xin (Justin) mailto:xin2...@amd.com>>
Signed-off-by: Zhao, Jiange mailto:jiange.z...@amd.com>>
---
 drivers/gpu/drm/amd/pm/powerplay/amd_powerplay.c | 14 ++
 1 file changed, 14 insertions(+)

diff --git a/drivers/gpu/drm/amd/pm/powerplay/amd_powerplay.c 
b/drivers/gpu/drm/amd/pm/powerplay/amd_powerplay.c
index eab9768029c1..5287ac4e8364 100644
--- a/drivers/gpu/drm/amd/pm/powerplay/amd_powerplay.c
+++ b/drivers/gpu/drm/amd/pm/powerplay/amd_powerplay.c
@@ -125,6 +125,20 @@ static int pp_hw_init(void *handle)

 ret = hwmgr_hw_init(hwmgr);

+   if (adev->pdev->device == 0x6860 && adev->pdev->revision == 0x07) {
+   long param[5];
+
+   param[0] = 5;  // busy_set_point
+   param[1] = 60; // FPS
+   param[2] = 0;  // use_rlc_busy
+   param[3] = 3;  // min_active_level
+   param[4] = PP_SMC_POWER_PROFILE_CUSTOM;
+
+   mutex_lock(>smu_lock);
+   ret = hwmgr->hwmgr_func->set_power_profile_mode(hwmgr, param, 
4);
+   mutex_unlock(>smu_lock);
+   }
+
 if (ret)
 pr_err("powerplay hw init failed\n");

--
2.24.3 (Apple Git-128)

___
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx


[PATCH] drm/amd/amdgpu: Add checksun check for pf2vf message

2020-10-27 Thread Li, Xin (Justin)
[AMD Official Use Only - Internal Distribution Only]

Add checksum checking for pf2vf message

Signed-off-by: Li, Xin (Justin) mailto:xin2...@amd.com>>
Signed-off-by: Zhou, Tiecheng 
mailto:tiecheng.z...@amd.com>>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
index 836d784456e5..bfc74533b5ee 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
@@ -450,12 +450,11 @@ static int amdgpu_virt_read_pf2vf_data(struct 
amdgpu_device *adev)
 ((struct amdgim_pf2vf_info_v1 
*)pf2vf_info)->feature_flags;
 break;
 case 2:
-   /* TODO: missing key, need to add it later */
 checksum = ((struct amd_sriov_msg_pf2vf_info 
*)pf2vf_info)->checksum;
 checkval = amd_sriov_msg_checksum(
 adev->virt.fw_reserve.p_pf2vf, pf2vf_info->size,
-   0, checksum);
-   if (checksum != checkval) {
+   adev->virt.fw_reserve.checksum_key, checksum);
+   if (checksum != 0 && checksum != checkval) {
 DRM_ERROR("invalid pf2vf message\n");
 return -EINVAL;
 }
--
2.24.3 (Apple Git-128)

___
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx


DROP: Re: [PATCH] drm/amd/amdgpu: Add checksun check for pf2vf message

2020-10-22 Thread Li, Xin (Justin)
[AMD Official Use Only - Internal Distribution Only]

Please drop this patch, there’s some typo in the commit message

Best Regards,
Li, Xin (Justin)

From: Li, Xin (Justin) 
Date: Friday, October 23, 2020 at 10:17
To: amd-gfx@lists.freedesktop.org 
Cc: Li, Xin (Justin) , Zhou, Tiecheng , 
Li, Xin (Justin) , l...@justins-mbp.amd.com 
, z...@justins-mbp.amd.com 
, Tiecheng 
Subject: [PATCH] drm/amd/amdgpu: Add checksun check for pf2vf message
Add checksum checking for pf2vf message

Signed-off-by: Li, Xin (Justin) 
Signed-off-by: Zhou, Tiecheng 
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
index 836d784456e5..bfc74533b5ee 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_virt.c
@@ -450,12 +450,11 @@ static int amdgpu_virt_read_pf2vf_data(struct 
amdgpu_device *adev)
 ((struct amdgim_pf2vf_info_v1 
*)pf2vf_info)->feature_flags;
 break;
 case 2:
-   /* TODO: missing key, need to add it later */
 checksum = ((struct amd_sriov_msg_pf2vf_info 
*)pf2vf_info)->checksum;
 checkval = amd_sriov_msg_checksum(
 adev->virt.fw_reserve.p_pf2vf, pf2vf_info->size,
-   0, checksum);
-   if (checksum != checkval) {
+   adev->virt.fw_reserve.checksum_key, checksum);
+   if (checksum != 0 && checksum != checkval) {
 DRM_ERROR("invalid pf2vf message\n");
 return -EINVAL;
 }
--
2.24.3 (Apple Git-128)
___
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx