On Thu, Apr 27, 2023 at 11:56:22AM +1000, Dave Airlie wrote:
> On Thu, 20 Apr 2023 at 05:19, Rodrigo Vivi <rodrigo.v...@intel.com> wrote:
> >
> > Let’s establish a merge plan for Xe, by writing down clear pre-merge goals, 
> > in
> > order to avoid unnecessary delays.
> 
> LGTM,
> 
> Acked-by: Dave Airlie <airl...@redhat.com>

Thanks, pushed to drm-misc-next

> 
> >
> > This initial document starts with a TODO list containing items with clear 
> > and
> > measurable key results. Xe’s initial pull request should only be sent to
> > dri-devel after all the items are clearly resolved.
> >
> > Since many of them involve some level of a community consensus, in many 
> > cases,
> > the consensus will be reached in follow-up patches to this document with 
> > more
> > details of the API or helpers that will be developed or modified.
> >
> > Besides of the items that are highlighted in this document, it is important
> > to highlight that Oded, has been volunteered to give the overall ack on Xe
> > driver as the way to confirm that it looks good for upstream.
> >
> > v2: Incorporated Daniel's feedback:
> >     - Do not make long-running compute a blocker.
> >     - Add a mention to drm-exec that that ties to vm_bind and long-running
> >       compute jobs. Then I also added GPUVA since I recently noticed that 
> > this
> >       ties also to the work Matt is doing on that front.
> >     - Added the devcoredump section.
> >     - Add the mention to Oded being volunteered for the overall ack.
> >
> > v3: Reword a bit the Async VM_BIND to incorporate Daniel's feedback on 
> > ensuring
> >     the async vmbind consensus explicitly include Mesa, besides other kernel
> >     drivers.
> >
> > Cc: Dave Airlie <airl...@redhat.com>
> > Cc: Daniel Vetter <daniel.vet...@ffwll.ch>
> > Cc: Oded Gabbay <ogab...@kernel.org>
> > Signed-off-by: Rodrigo Vivi <rodrigo.v...@intel.com>
> > Signed-off-by: Francois Dugast <francois.dug...@intel.com>
> > Signed-off-by: Luis Strano <luis.str...@intel.com>
> > Signed-off-by: Matthew Brost <matthew.br...@intel.com>
> > Signed-off-by: Thomas Hellström <thomas.hellst...@linux.intel.com>
> > Signed-off-by: Maarten Lankhorst <maarten.lankho...@linux.intel.com>
> > Acked-by: Daniel Vetter <daniel.vet...@ffwll.ch>
> > Signed-off-by: Rodrigo Vivi <rodrigo.v...@intel.com>
> > ---
> >  Documentation/gpu/rfc/index.rst |   4 +
> >  Documentation/gpu/rfc/xe.rst    | 235 ++++++++++++++++++++++++++++++++
> >  2 files changed, 239 insertions(+)
> >  create mode 100644 Documentation/gpu/rfc/xe.rst
> >
> > diff --git a/Documentation/gpu/rfc/index.rst 
> > b/Documentation/gpu/rfc/index.rst
> > index 476719771eef..e4f7b005138d 100644
> > --- a/Documentation/gpu/rfc/index.rst
> > +++ b/Documentation/gpu/rfc/index.rst
> > @@ -31,3 +31,7 @@ host such documentation:
> >  .. toctree::
> >
> >      i915_vm_bind.rst
> > +
> > +.. toctree::
> > +
> > +   xe.rst
> > diff --git a/Documentation/gpu/rfc/xe.rst b/Documentation/gpu/rfc/xe.rst
> > new file mode 100644
> > index 000000000000..2516fe141db6
> > --- /dev/null
> > +++ b/Documentation/gpu/rfc/xe.rst
> > @@ -0,0 +1,235 @@
> > +==========================
> > +Xe – Merge Acceptance Plan
> > +==========================
> > +Xe is a new driver for Intel GPUs that supports both integrated and
> > +discrete platforms starting with Tiger Lake (first Intel Xe Architecture).
> > +
> > +This document aims to establish a merge plan for the Xe, by writing down 
> > clear
> > +pre-merge goals, in order to avoid unnecessary delays.
> > +
> > +Xe – Overview
> > +=============
> > +The main motivation of Xe is to have a fresh base to work from that is
> > +unencumbered by older platforms, whilst also taking the opportunity to
> > +rearchitect our driver to increase sharing across the drm subsystem, both
> > +leveraging and allowing us to contribute more towards other shared 
> > components
> > +like TTM and drm/scheduler.
> > +
> > +This is also an opportunity to start from the beginning with a clean uAPI 
> > that is
> > +extensible by design and already aligned with the modern userspace needs. 
> > For
> > +this reason, the memory model is solely based on GPU Virtual Address space
> > +bind/unbind (‘VM_BIND’) of GEM buffer objects (BOs) and execution only 
> > supporting
> > +explicit synchronization. With persistent mapping across the execution, the
> > +userspace does not need to provide a list of all required mappings during 
> > each
> > +submission.
> > +
> > +The new driver leverages a lot from i915. As for display, the intent is to 
> > share
> > +the display code with the i915 driver so that there is maximum reuse there.
> > +
> > +As for the power management area, the goal is to have a much-simplified 
> > support
> > +for the system suspend states (S-states), PCI device suspend states 
> > (D-states),
> > +GPU/Render suspend states (R-states) and frequency management. It should 
> > leverage
> > +as much as possible all the existent PCI-subsystem infrastructure (pm and
> > +runtime_pm) and underlying firmware components such PCODE and GuC for the 
> > power
> > +states and frequency decisions.
> > +
> > +Repository:
> > +
> > +https://gitlab.freedesktop.org/drm/xe/kernel (branch drm-xe-next)
> > +
> > +Xe – Platforms
> > +==============
> > +Currently, Xe is already functional and has experimental support for 
> > multiple
> > +platforms starting from Tiger Lake, with initial support in userspace 
> > implemented
> > +in Mesa (for Iris and Anv, our OpenGL and Vulkan drivers), as well as in 
> > NEO
> > +(for OpenCL and Level0).
> > +
> > +During a transition period, platforms will be supported by both Xe and 
> > i915.
> > +However, the force_probe mechanism existent in both drivers will allow 
> > only one
> > +official and by-default probe at a given time.
> > +
> > +For instance, in order to probe a DG2 which PCI ID is 0x5690 by Xe instead 
> > of
> > +i915, the following set of parameters need to be used:
> > +
> > +```
> > +i915.force_probe=!5690 xe.force_probe=5690
> > +```
> > +
> > +In both drivers, the ‘.require_force_probe’ protection forces the user to 
> > use the
> > +force_probe parameter while the driver is under development. This 
> > protection is
> > +only removed when the support for the platform and the uAPI are stable. 
> > Stability
> > +which needs to be demonstrated by CI results.
> > +
> > +In order to avoid user space regressions, i915 will continue to support 
> > all the
> > +current platforms that are already out of this protection. Xe support will 
> > be
> > +forever experimental and dependent on the usage of force_probe for these
> > +platforms.
> > +
> > +When the time comes for Xe, the protection will be lifted on Xe and kept 
> > in i915.
> > +
> > +Xe driver will be protected with both STAGING Kconfig and force_probe. 
> > Changes in
> > +the uAPI are expected while the driver is behind these protections. 
> > STAGING will
> > +be removed when the driver uAPI gets to a mature state where we can 
> > guarantee the
> > +‘no regression’ rule. Then force_probe will be lifted only for future 
> > platforms
> > +that will be productized with Xe driver, but not with i915.
> > +
> > +Xe – Pre-Merge Goals
> > +====================
> > +
> > +Drm_scheduler
> > +-------------
> > +Xe primarily uses Firmware based scheduling (GuC FW). However, it will use
> > +drm_scheduler as the scheduler ‘frontend’ for userspace submission in 
> > order to
> > +resolve syncobj and dma-buf implicit sync dependencies. However, 
> > drm_scheduler is
> > +not yet prepared to handle the 1-to-1 relationship between 
> > drm_gpu_scheduler and
> > +drm_sched_entity.
> > +
> > +Deeper changes to drm_scheduler should *not* be required to get Xe 
> > accepted, but
> > +some consensus needs to be reached between Xe and other community drivers 
> > that
> > +could also benefit from this work, for coupling FW based/assisted 
> > submission such
> > +as the ARM’s new Mali GPU driver, and others.
> > +
> > +As a key measurable result, the patch series introducing Xe itself shall 
> > not
> > +depend on any other patch touching drm_scheduler itself that was not yet 
> > merged
> > +through drm-misc. This, by itself, already includes the reach of an 
> > agreement for
> > +uniform 1 to 1 relationship implementation / usage across drivers.
> > +
> > +GPU VA
> > +------
> > +Two main goals of Xe are meeting together here:
> > +
> > +1) Have an uAPI that aligns with modern UMD needs.
> > +
> > +2) Early upstream engagement.
> > +
> > +RedHat engineers working on Nouveau proposed a new DRM feature to handle 
> > keeping
> > +track of GPU virtual address mappings. This is still not merged upstream, 
> > but
> > +this aligns very well with our goals and with our VM_BIND. The engagement 
> > with
> > +upstream and the port of Xe towards GPUVA is already ongoing.
> > +
> > +As a key measurable result, Xe needs to be aligned with the GPU VA and 
> > working in
> > +our tree. Missing Nouveau patches should *not* block Xe and any needed 
> > GPUVA
> > +related patch should be independent and present on dri-devel or acked by
> > +maintainers to go along with the first Xe pull request towards drm-next.
> > +
> > +DRM_VM_BIND
> > +-----------
> > +Nouveau, and Xe are all implementing ‘VM_BIND’ and new ‘Exec’ uAPIs in 
> > order to
> > +fulfill the needs of the modern uAPI. Xe merge should *not* be blocked on 
> > the
> > +development of a common new drm_infrastructure. However, the Xe team needs 
> > to
> > +engage with the community to explore the options of a common API.
> > +
> > +As a key measurable result, the DRM_VM_BIND needs to be documented in this 
> > file
> > +below, or this entire block deleted if the consensus is for independent 
> > drivers
> > +vm_bind ioctls.
> > +
> > +Although having a common DRM level IOCTL for VM_BIND is not a requirement 
> > to get
> > +Xe merged, it is mandatory to enforce the overall locking scheme for all 
> > major
> > +structs and list (so vm and vma). So, a consensus is needed, and possibly 
> > some
> > +common helpers. If helpers are needed, they should be also documented in 
> > this
> > +document.
> > +
> > +ASYNC VM_BIND
> > +-------------
> > +Although having a common DRM level IOCTL for VM_BIND is not a requirement 
> > to get
> > +Xe merged, it is mandatory to have a consensus with other drivers and Mesa.
> > +It needs to be clear how to handle async VM_BIND and interactions with 
> > userspace
> > +memory fences. Ideally with helper support so people don't get it wrong in 
> > all
> > +possible ways.
> > +
> > +As a key measurable result, the benefits of ASYNC VM_BIND and a discussion 
> > of
> > +various flavors, error handling and a sample API should be documented here 
> > or in
> > +a separate document pointed to by this document.
> > +
> > +Userptr integration and vm_bind
> > +-------------------------------
> > +Different drivers implement different ways of dealing with execution of 
> > userptr.
> > +With multiple drivers currently introducing support to VM_BIND, the goal 
> > is to
> > +aim for a DRM consensus on what’s the best way to have that support. To 
> > some
> > +extent this is already getting addressed itself with the GPUVA where 
> > likely the
> > +userptr will be a GPUVA with a NULL GEM call VM bind directly on the 
> > userptr.
> > +However, there are more aspects around the rules for that and the usage of
> > +mmu_notifiers, locking and other aspects.
> > +
> > +This task here has the goal of introducing a documentation of the basic 
> > rules.
> > +
> > +The documentation *needs* to first live in this document (API session 
> > below) and
> > +then moved to another more specific document or at Xe level or at DRM 
> > level.
> > +
> > +Documentation should include:
> > +
> > + * The userptr part of the VM_BIND api.
> > +
> > + * Locking, including the page-faulting case.
> > +
> > + * O(1) complexity under VM_BIND.
> > +
> > +Some parts of userptr like mmu_notifiers should become GPUVA or DRM 
> > helpers when
> > +the second driver supporting VM_BIND+userptr appears. Details to be 
> > defined when
> > +the time comes.
> > +
> > +Long running compute: minimal data structure/scaffolding
> > +--------------------------------------------------------
> > +The generic scheduler code needs to include the handling of endless compute
> > +contexts, with the minimal scaffolding for preempt-ctx fences (probably on 
> > the
> > +drm_sched_entity) and making sure drm_scheduler can cope with the lack of 
> > job
> > +completion fence.
> > +
> > +The goal is to achieve a consensus ahead of Xe initial pull-request, 
> > ideally with
> > +this minimal drm/scheduler work, if needed, merged to drm-misc in a way 
> > that any
> > +drm driver, including Xe, could re-use and add their own individual needs 
> > on top
> > +in a next stage. However, this should not block the initial merge.
> > +
> > +This is a non-blocker item since the driver without the support for the 
> > long
> > +running compute enabled is not a showstopper.
> > +
> > +Display integration with i915
> > +-----------------------------
> > +In order to share the display code with the i915 driver so that there is 
> > maximum
> > +reuse, the i915/display/ code is built twice, once for i915.ko and then for
> > +xe.ko. Currently, the i915/display code in Xe tree is polluted with many 
> > 'ifdefs'
> > +depending on the build target. The goal is to refactor both Xe and 
> > i915/display
> > +code simultaneously in order to get a clean result before they land 
> > upstream, so
> > +that display can already be part of the initial pull request towards 
> > drm-next.
> > +
> > +However, display code should not gate the acceptance of Xe in upstream. Xe
> > +patches will be refactored in a way that display code can be removed, if 
> > needed,
> > +from the first pull request of Xe towards drm-next. The expectation is 
> > that when
> > +both drivers are part of the drm-tip, the introduction of cleaner patches 
> > will be
> > +easier and speed up.
> > +
> > +Drm_exec
> > +--------
> > +Helper to make dma_resv locking for a big number of buffers is getting 
> > removed in
> > +the drm_exec series proposed in 
> > https://patchwork.freedesktop.org/patch/524376/
> > +If that happens, Xe needs to change and incorporate the changes in the 
> > driver.
> > +The goal is to engage with the Community to understand if the best 
> > approach is to
> > +move that to the drivers that are using it or if we should keep the 
> > helpers in
> > +place waiting for Xe to get merged.
> > +
> > +This item ties into the GPUVA, VM_BIND, and even long-running compute 
> > support.
> > +
> > +As a key measurable result, we need to have a community consensus 
> > documented in
> > +this document and the Xe driver prepared for the changes, if necessary.
> > +
> > +Dev_coredump
> > +------------
> > +
> > +Xe needs to align with other drivers on the way that the error states are
> > +dumped, avoiding a Xe only error_state solution. The goal is to use 
> > devcoredump
> > +infrastructure to report error states, since it produces a standardized way
> > +by exposing a virtual and temporary /sys/class/devcoredump device.
> > +
> > +As the key measurable result, Xe driver needs to provide GPU snapshots 
> > captured
> > +at hang time through devcoredump, but without depending on any core 
> > modification
> > +of devcoredump infrastructure itself.
> > +
> > +Later, when we are in-tree, the goal is to collaborate with devcoredump
> > +infrastructure with overall possible improvements, like multiple file 
> > support
> > +for better organization of the dumps, snapshot support, dmesg extra print,
> > +and whatever may make sense and help the overall infrastructure.
> > +
> > +Xe – uAPI high level overview
> > +=============================
> > +
> > +...Warning: To be done in follow up patches after/when/where the main 
> > consensus in various items are individually reached.
> > --
> > 2.39.2
> >

Reply via email to