Re: [PATCH 1/8] drm/i915: Get rid of the synchronous flag in switch_mm

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

 



> -----Original Message-----
> From: Daniel Vetter [mailto:daniel.vetter@xxxxxxxx] On Behalf Of Daniel
> Vetter
> Sent: Wednesday, June 18, 2014 8:51 PM
> To: Mateo Lozano, Oscar
> Cc: intel-gfx@xxxxxxxxxxxxxxxxxxxxx
> Subject: Re:  [PATCH 1/8] drm/i915: Get rid of the synchronous flag
> in switch_mm
> 
> On Wed, Jun 18, 2014 at 05:15:35PM +0100, oscar.mateo@xxxxxxxxx wrote:
> > From: Oscar Mateo <oscar.mateo@xxxxxxxxx>
> >
> > As a first step, split switch_mm into two different functions:
> > sync_switch_mm (currently used by ppgtt_enable) and switch_mm (used by
> > the outside world).
> >
> > Signed-off-by: Oscar Mateo <oscar.mateo@xxxxxxxxx>
> 
> I guess that jira task description was a bit unclear - removing the bool
> synchronous argument isn't the goal itself. The idea was to rework the gpu
> reset sequence so that it matches the same sequence we use at driver load
> and so can use the same code. This patch removes the bool synchronous, but
> the logical split with two different ways to load ppgtt is still there.

No, I realized I didn´t really do anything, but I saw the possibility of saving one special casing in Execlists and I jumped for it, forgetting about the JIRA task (psychological fixation, I guess)
Anyway, I was going to ask for more details on the JIRA...

> The reason for aiming as hard as possible to use the exact same code for
> driver load, gpu reset and runtime pm/system resume is that we've simply
> seen too many bugs due to slight variations and unintended omissions.
> 
> If for some really odd reason this is impossible (e.g. when the gpu needs a
> special dance when coming out of reset) then we need a giant comment
> explaining the magic. But without such a clear reason the goal should always
> be to have just 1 single autorative piece of code for a given state transition.

Ok. How about this: on ring init, I manually set the Aliasing PPGTT and the default context object synchronously via MMIO writes (the Aliasing PPGTT via the ppgtt->sync_switch_mm() and the default context directly using the CCID). I assume that, whenever we are in ring init, the GPU is sufficiently idle to manually frob all the required registers. That way, I get rid of i915_gem_context_enable() completely and I don´t have to do any special casing at all.
Ring commands (PPGTT switch and MI_SET_CONTEXT) are then left completely for the normal do_switch().
What do you think?

-- Oscar
_______________________________________________
Intel-gfx mailing list
Intel-gfx@xxxxxxxxxxxxxxxxxxxxx
http://lists.freedesktop.org/mailman/listinfo/intel-gfx





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