<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<style type="text/css" style="display:none;"> P {margin-top:0;margin-bottom:0;} </style>
</head>
<body dir="ltr">
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Not much relationship between them, except that this functional change is to fix a IOCTL error printing. </div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Yong</div>
<div id="appendonsend"></div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> Kuehling, Felix <Felix.Kuehling@amd.com><br>
<b>Sent:</b> Monday, September 30, 2019 11:57 AM<br>
<b>To:</b> Zhao, Yong <Yong.Zhao@amd.com>; amd-gfx@lists.freedesktop.org <amd-gfx@lists.freedesktop.org><br>
<b>Subject:</b> Re: [PATCH 5/6] drm/amdgpu: Add the HDP flush support for Navi</font>
<div> </div>
</div>
<div class="BodyFragment"><font size="2"><span style="font-size:11pt;">
<div class="PlainText">As far as I can tell, this is the only patch with functional changes in
<br>
the patch series. The rest are purely clean-up. Any relation I'm missing?<br>
<br>
Anyway, patches 2,3,5 are<br>
<br>
Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com><br>
<br>
On 2019-09-27 11:41 p.m., Zhao, Yong wrote:<br>
> The HDP flush support code was missing in the nbio and nv files.<br>
><br>
> Change-Id: I046ff52567676b56bf16dc1728b02481233acb61<br>
> Signed-off-by: Yong Zhao <Yong.Zhao@amd.com><br>
> ---<br>
>   drivers/gpu/drm/amd/amdgpu/nbio_v2_3.c | 16 +++++++++++++---<br>
>   drivers/gpu/drm/amd/amdgpu/nv.c        |  9 +++++++++<br>
>   2 files changed, 22 insertions(+), 3 deletions(-)<br>
><br>
> diff --git a/drivers/gpu/drm/amd/amdgpu/nbio_v2_3.c b/drivers/gpu/drm/amd/amdgpu/nbio_v2_3.c<br>
> index e7e36fb6113d..c699cbfe015a 100644<br>
> --- a/drivers/gpu/drm/amd/amdgpu/nbio_v2_3.c<br>
> +++ b/drivers/gpu/drm/amd/amdgpu/nbio_v2_3.c<br>
> @@ -27,11 +27,21 @@<br>
>   #include "nbio/nbio_2_3_default.h"<br>
>   #include "nbio/nbio_2_3_offset.h"<br>
>   #include "nbio/nbio_2_3_sh_mask.h"<br>
> +#include <uapi/linux/kfd_ioctl.h><br>
>   <br>
>   #define smnPCIE_CONFIG_CNTL 0x11180044<br>
>   #define smnCPM_CONTROL              0x11180460<br>
>   #define smnPCIE_CNTL2               0x11180070<br>
>   <br>
> +<br>
> +static void nbio_v2_3_remap_hdp_registers(struct amdgpu_device *adev)<br>
> +{<br>
> +     WREG32_SOC15(NBIO, 0, mmREMAP_HDP_MEM_FLUSH_CNTL,<br>
> +             adev->rmmio_remap.reg_offset + KFD_MMIO_REMAP_HDP_MEM_FLUSH_CNTL);<br>
> +     WREG32_SOC15(NBIO, 0, mmREMAP_HDP_REG_FLUSH_CNTL,<br>
> +             adev->rmmio_remap.reg_offset + KFD_MMIO_REMAP_HDP_REG_FLUSH_CNTL);<br>
> +}<br>
> +<br>
>   static u32 nbio_v2_3_get_rev_id(struct amdgpu_device *adev)<br>
>   {<br>
>        u32 tmp = RREG32_SOC15(NBIO, 0, mmRCC_DEV0_EPF0_STRAP0);<br>
> @@ -56,10 +66,9 @@ static void nbio_v2_3_hdp_flush(struct amdgpu_device *adev,<br>
>                                struct amdgpu_ring *ring)<br>
>   {<br>
>        if (!ring || !ring->funcs->emit_wreg)<br>
> -             WREG32_SOC15_NO_KIQ(NBIO, 0, mmBIF_BX_PF_HDP_MEM_COHERENCY_FLUSH_CNTL, 0);<br>
> +             WREG32_NO_KIQ((adev->rmmio_remap.reg_offset + KFD_MMIO_REMAP_HDP_MEM_FLUSH_CNTL) >> 2, 0);<br>
>        else<br>
> -             amdgpu_ring_emit_wreg(ring, SOC15_REG_OFFSET(<br>
> -                     NBIO, 0, mmBIF_BX_PF_HDP_MEM_COHERENCY_FLUSH_CNTL), 0);<br>
> +             amdgpu_ring_emit_wreg(ring, (adev->rmmio_remap.reg_offset + KFD_MMIO_REMAP_HDP_MEM_FLUSH_CNTL) >> 2, 0);<br>
>   }<br>
>   <br>
>   static u32 nbio_v2_3_get_memsize(struct amdgpu_device *adev)<br>
> @@ -330,4 +339,5 @@ const struct amdgpu_nbio_funcs nbio_v2_3_funcs = {<br>
>        .ih_control = nbio_v2_3_ih_control,<br>
>        .init_registers = nbio_v2_3_init_registers,<br>
>        .detect_hw_virt = nbio_v2_3_detect_hw_virt,<br>
> +     .remap_hdp_registers = nbio_v7_4_remap_hdp_registers,<br>
>   };<br>
> diff --git a/drivers/gpu/drm/amd/amdgpu/nv.c b/drivers/gpu/drm/amd/amdgpu/nv.c<br>
> index b3e7756fcc4b..6699a45b88ec 100644<br>
> --- a/drivers/gpu/drm/amd/amdgpu/nv.c<br>
> +++ b/drivers/gpu/drm/amd/amdgpu/nv.c<br>
> @@ -587,8 +587,11 @@ static const struct amdgpu_asic_funcs nv_asic_funcs =<br>
>   <br>
>   static int nv_common_early_init(void *handle)<br>
>   {<br>
> +#define MMIO_REG_HOLE_OFFSET (0x80000 - PAGE_SIZE)<br>
>        struct amdgpu_device *adev = (struct amdgpu_device *)handle;<br>
>   <br>
> +     adev->rmmio_remap.reg_offset = MMIO_REG_HOLE_OFFSET;<br>
> +     adev->rmmio_remap.bus_addr = adev->rmmio_base + MMIO_REG_HOLE_OFFSET;<br>
>        adev->smc_rreg = NULL;<br>
>        adev->smc_wreg = NULL;<br>
>        adev->pcie_rreg = &nv_pcie_rreg;<br>
> @@ -714,6 +717,12 @@ static int nv_common_hw_init(void *handle)<br>
>        nv_program_aspm(adev);<br>
>        /* setup nbio registers */<br>
>        adev->nbio.funcs->init_registers(adev);<br>
> +     /* remap HDP registers to a hole in mmio space,<br>
> +      * for the purpose of expose those registers<br>
> +      * to process space<br>
> +      */<br>
> +     if (adev->nbio.funcs->remap_hdp_registers)<br>
> +             adev->nbio.funcs->remap_hdp_registers(adev);<br>
>        /* enable the doorbell aperture */<br>
>        nv_enable_doorbell_aperture(adev, true);<br>
>   <br>
</div>
</span></font></div>
</body>
</html>