From: Caleb Connolly <caleb@connolly.tech>
To: Rob Clark <robdclark@gmail.com>,
dri-devel@lists.freedesktop.org,
iommu@lists.linux-foundation.org, linux-arm-msm@vger.kernel.org,
Will Deacon <will@kernel.org>,
Robin Murphy <robin.murphy@arm.com>
Cc: Bjorn Andersson <bjorn.andersson@linaro.org>,
Sibi Sankar <sibis@codeaurora.org>,
Vivek Gautam <vivek.gautam@codeaurora.org>,
Stephen Boyd <swboyd@chromium.org>,
Akhil P Oommen <akhilpo@codeaurora.org>,
Rob Clark <robdclark@chromium.org>,
AngeloGioacchino Del Regno <kholk11@gmail.com>,
Ben Dooks <ben.dooks@codethink.co.uk>,
Brian Masney <masneyb@onstation.org>,
"open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS"
<devicetree@vger.kernel.org>,
Emil Velikov <emil.velikov@collabora.com>,
Eric Anholt <eric@anholt.net>,
"open list:DRM DRIVER FOR MSM ADRENO GPU"
<freedreno@lists.freedesktop.org>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Hanna Hawa <hannah@marvell.com>, Joerg Roedel <jroedel@suse.de>,
John Stultz <john.stultz@linaro.org>,
Jonathan Marek <jonathan@marek.ca>,
Jordan Crouse <jcrouse@codeaurora.org>,
Krishna Reddy <vdumpa@nvidia.com>,
"moderated list:ARM SMMU DRIVERS"
<linux-arm-kernel@lists.infradead.org>,
open list <linux-kernel@vger.kernel.org>,
Sai Prakash Ranjan <saiprakash.ranjan@codeaurora.org>,
Sean Paul <seanpaul@chromium.org>,
Sharat Masetty <smasetty@codeaurora.org>,
Shawn Guo <shawn.guo@linaro.org>,
Thierry Reding <thierry.reding@gmail.com>,
Wambui Karuga <wambui.karugax@gmail.com>
Subject: Re: [PATCH v16 00/20] iommu/arm-smmu + drm/msm: per-process GPU pgtables
Date: Mon, 07 Sep 2020 19:02:24 +0000 [thread overview]
Message-ID: <1eb7f10c-1504-158c-d25c-18a73b9a1607@connolly.tech> (raw)
On 2020-09-01 17:46, Rob Clark wrote:
> From: Rob Clark <robdclark@chromium.org>
>
> NOTE: I have re-ordered the series, and propose that we could merge this
> series in the following order:
>
> 1) 01-11 - merge via drm / msm-next
> 2) 12-15 - merge via iommu, no dependency on msm-next pull req
> 3) 16-18 - patch 16 has a dependency on 02 and 04, so it would
> need to come post -rc1 or on following cycle, but I
> think it would be unlikely to conflict with other
> arm-smmu patches (other than Bjorn's smmu handover
> series?)
> 4) 19-20 - dt bits should be safe to land in any order without
> breaking anything
>
> ----
>
> This series adds an Adreno SMMU implementation to arm-smmu to allow GPU hardware
> pagetable switching.
>
> The Adreno GPU has built in capabilities to switch the TTBR0 pagetable during
> runtime to allow each individual instance or application to have its own
> pagetable. In order to take advantage of the HW capabilities there are certain
> requirements needed of the SMMU hardware.
>
> This series adds support for an Adreno specific arm-smmu implementation. The new
> implementation 1) ensures that the GPU domain is always assigned context bank 0,
> 2) enables split pagetable support (TTBR1) so that the instance specific
> pagetable can be swapped while the global memory remains in place and 3) shares
> the current pagetable configuration with the GPU driver to allow it to create
> its own io-pgtable instances.
>
> The series then adds the drm/msm code to enable these features. For targets that
> support it allocate new pagetables using the io-pgtable configuration shared by
> the arm-smmu driver and swap them in during runtime.
>
> This version of the series merges the previous patchset(s) [1] and [2]
> with the following improvements:
>
> v16: (Respin by Rob)
> - Fix indentation
> - Re-order series to split drm and iommu parts
> v15: (Respin by Rob)
> - Adjust dt bindings to keep SoC specific compatible (Doug)
> - Add dts workaround for cheza fw limitation
> - Add missing 'select IOMMU_IO_PGTABLE' (Guenter)
> v14: (Respin by Rob)
> - Minor update to 16/20 (only force ASID to zero in one place)
> - Addition of sc7180 dtsi patch.
> v13: (Respin by Rob)
> - Switch to a private interface between adreno-smmu and GPU driver,
> dropping the custom domain attr (Will Deacon)
> - Rework the SCTLR.HUPCF patch to add new fields in smmu_domain->cfg
> rather than adding new impl hook (Will Deacon)
> - Drop for_each_cfg_sme() in favor of plain for() loop (Will Deacon)
> - Fix context refcnt'ing issue which was causing problems with GPU
> crash recover stress testing.
> - Spiff up $debugfs/gem to show process information associated with
> VMAs
> v12:
> - Nitpick cleanups in gpu/drm/msm/msm_iommu.c (Rob Clark)
> - Reorg in gpu/drm/msm/msm_gpu.c (Rob Clark)
> - Use the default asid for the context bank so that iommu_tlb_flush_all works
> - Flush the UCHE after a page switch
> - Add the SCTLR.HUPCF patch at the end of the series
> v11:
> - Add implementation specific get_attr/set_attr functions (per Rob Clark)
> - Fix context bank allocation (per Bjorn Andersson)
> v10:
> - arm-smmu: add implementation hook to allocate context banks
> - arm-smmu: Match the GPU domain by stream ID instead of compatible string
> - arm-smmu: Make DOMAIN_ATTR_PGTABLE_CFG bi-directional. The leaf driver
> queries the configuration to create a pagetable and then sends the newly
> created configuration back to the smmu-driver to enable TTBR0
> - drm/msm: Add context reference counting for submissions
> - drm/msm: Use dummy functions to skip TLB operations on per-instance
> pagetables
>
> [1] https://lists.linuxfoundation.org/pipermail/iommu/2020-June/045653.html
> [2] https://lists.linuxfoundation.org/pipermail/iommu/2020-June/045659.html
>
> Jordan Crouse (12):
> drm/msm: Add a context pointer to the submitqueue
> drm/msm: Drop context arg to gpu->submit()
> drm/msm: Set the global virtual address range from the IOMMU domain
> drm/msm: Add support to create a local pagetable
> drm/msm: Add support for private address space instances
> drm/msm/a6xx: Add support for per-instance pagetables
> iommu/arm-smmu: Pass io-pgtable config to implementation specific
> function
> iommu/arm-smmu: Add support for split pagetables
> iommu/arm-smmu: Prepare for the adreno-smmu implementation
> iommu/arm-smmu-qcom: Add implementation for the adreno GPU SMMU
> dt-bindings: arm-smmu: Add compatible string for Adreno GPU SMMU
> arm: dts: qcom: sm845: Set the compatible string for the GPU SMMU
>
> Rob Clark (8):
> drm/msm: Remove dangling submitqueue references
> drm/msm: Add private interface for adreno-smmu
> drm/msm/gpu: Add dev_to_gpu() helper
> drm/msm: Set adreno_smmu as gpu's drvdata
> drm/msm: Show process names in gem_describe
> iommu/arm-smmu: Constify some helpers
> iommu/arm-smmu: Add a way for implementations to influence SCTLR
> arm: dts: qcom: sc7180: Set the compatible string for the GPU SMMU
>
> .../devicetree/bindings/iommu/arm,smmu.yaml | 9 +-
> arch/arm64/boot/dts/qcom/sc7180.dtsi | 2 +-
> arch/arm64/boot/dts/qcom/sdm845-cheza.dtsi | 9 +
> arch/arm64/boot/dts/qcom/sdm845.dtsi | 2 +-
> drivers/gpu/drm/msm/Kconfig | 1 +
> drivers/gpu/drm/msm/adreno/a5xx_gpu.c | 12 +-
> drivers/gpu/drm/msm/adreno/a6xx_gpu.c | 68 +++++-
> drivers/gpu/drm/msm/adreno/a6xx_gpu.h | 1 +
> drivers/gpu/drm/msm/adreno/adreno_device.c | 12 +-
> drivers/gpu/drm/msm/adreno/adreno_gpu.c | 18 +-
> drivers/gpu/drm/msm/adreno/adreno_gpu.h | 3 +-
> drivers/gpu/drm/msm/msm_drv.c | 16 +-
> drivers/gpu/drm/msm/msm_drv.h | 25 +++
> drivers/gpu/drm/msm/msm_gem.c | 25 ++-
> drivers/gpu/drm/msm/msm_gem.h | 6 +
> drivers/gpu/drm/msm/msm_gem_submit.c | 8 +-
> drivers/gpu/drm/msm/msm_gem_vma.c | 10 +
> drivers/gpu/drm/msm/msm_gpu.c | 41 +++-
> drivers/gpu/drm/msm/msm_gpu.h | 21 +-
> drivers/gpu/drm/msm/msm_gpummu.c | 2 +-
> drivers/gpu/drm/msm/msm_iommu.c | 206 +++++++++++++++++-
> drivers/gpu/drm/msm/msm_mmu.h | 16 +-
> drivers/gpu/drm/msm/msm_ringbuffer.h | 1 +
> drivers/gpu/drm/msm/msm_submitqueue.c | 7 +-
> drivers/iommu/arm/arm-smmu/arm-smmu-impl.c | 6 +-
> drivers/iommu/arm/arm-smmu/arm-smmu-qcom.c | 155 ++++++++++++-
> drivers/iommu/arm/arm-smmu/arm-smmu.c | 100 ++++-----
> drivers/iommu/arm/arm-smmu/arm-smmu.h | 87 +++++++-
> include/linux/adreno-smmu-priv.h | 36 +++
> 29 files changed, 771 insertions(+), 134 deletions(-)
> create mode 100644 include/linux/adreno-smmu-priv.h
>
Tested in combination with
https://lore.kernel.org/linux-arm-msm/20200904155513.282067-1-bjorn.andersson@linaro.org/
Fixes booting on the OnePlus 6 (SDM845) with the display enabled.
next reply other threads:[~2020-09-07 19:02 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-09-07 19:02 Caleb Connolly [this message]
-- strict thread matches above, loose matches on Subject: below --
2020-09-01 16:46 [PATCH v16 00/20] iommu/arm-smmu + drm/msm: per-process GPU pgtables Rob Clark
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1eb7f10c-1504-158c-d25c-18a73b9a1607@connolly.tech \
--to=caleb@connolly.tech \
--cc=akhilpo@codeaurora.org \
--cc=ben.dooks@codethink.co.uk \
--cc=bjorn.andersson@linaro.org \
--cc=devicetree@vger.kernel.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=emil.velikov@collabora.com \
--cc=eric@anholt.net \
--cc=freedreno@lists.freedesktop.org \
--cc=gregkh@linuxfoundation.org \
--cc=hannah@marvell.com \
--cc=iommu@lists.linux-foundation.org \
--cc=jcrouse@codeaurora.org \
--cc=john.stultz@linaro.org \
--cc=jonathan@marek.ca \
--cc=jroedel@suse.de \
--cc=kholk11@gmail.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=masneyb@onstation.org \
--cc=robdclark@chromium.org \
--cc=robdclark@gmail.com \
--cc=robin.murphy@arm.com \
--cc=saiprakash.ranjan@codeaurora.org \
--cc=seanpaul@chromium.org \
--cc=shawn.guo@linaro.org \
--cc=sibis@codeaurora.org \
--cc=smasetty@codeaurora.org \
--cc=swboyd@chromium.org \
--cc=thierry.reding@gmail.com \
--cc=vdumpa@nvidia.com \
--cc=vivek.gautam@codeaurora.org \
--cc=wambui.karugax@gmail.com \
--cc=will@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).