On Wed, 2011-04-27 at 10:36 +0200, Michel D?nzer wrote:
> On Mit, 2011-04-27 at 16:10 +1000, christopher.halse.rogers at canonical.com 
> wrote:
> > From: Christopher James Halse Rogers <christopher.halse.rogers at 
> > canonical.com>
> > 
> > Signed-off-by: Christopher James Halse Rogers <christopher.halse.rogers at 
> > canonical.com>
> > ---
> >  drivers/gpu/drm/drm_irq.c |   39 ++++++++++++++++-----------------------
> >  1 files changed, 16 insertions(+), 23 deletions(-)
> > 
> > diff --git a/drivers/gpu/drm/drm_irq.c b/drivers/gpu/drm/drm_irq.c
> > index 72407fa..485714b 100644
> > --- a/drivers/gpu/drm/drm_irq.c
> > +++ b/drivers/gpu/drm/drm_irq.c
> > @@ -930,6 +930,18 @@ void drm_vblank_put(struct drm_device *dev, int crtc)
> >  }
> >  EXPORT_SYMBOL(drm_vblank_put);
> >  
> > +static void drm_emit_vblank_event (struct drm_pending_vblank_event *e,
> > +                              unsigned int seq, struct timeval *now)
> > +{
> > +   e->event.sequence = seq;
> > +   e->event.tv_sec = now->tv_sec;
> > +   e->event.tv_usec = now->tv_usec;
> > +   list_move_tail(&e->base.link, &e->base.file_priv->event_list);
> > +   wake_up_interruptible(&e->base.file_priv->event_wait);
> > +   trace_drm_vblank_event_delivered(e->base.pid, e->pipe,
> > +                                    e->event.sequence);
> > +}
> > +
> >  void drm_vblank_off(struct drm_device *dev, int crtc)
> >  {
> >     struct drm_pending_vblank_event *e, *t;
> > @@ -950,14 +962,8 @@ void drm_vblank_off(struct drm_device *dev, int crtc)
> >                       wanted %d, current %d\n",
> >                       e->event.sequence, seq);
> >  
> > -           e->event.sequence = seq;
> > -           e->event.tv_sec = now.tv_sec;
> > -           e->event.tv_usec = now.tv_usec;
> >             drm_vblank_put(dev, e->pipe);
> > -           list_move_tail(&e->base.link, &e->base.file_priv->event_list);
> > -           wake_up_interruptible(&e->base.file_priv->event_wait);
> > -           trace_drm_vblank_event_delivered(e->base.pid, e->pipe,
> > -                                            e->event.sequence);
> > +           drm_emit_vblank_event(e, seq, &now);
> >     }
> 
> Makes sense, but shouldn't the drm_vblank_put() calls move into
> drm_emit_vblank_event() as well?

Possibly.  I felt that dropping the vblank reference was a conceptually
distinct action from emitting the vblank event, which is why I left it
out.  I'd be happy enough to have it as a part of drm_emit_vblank_event,
though.


-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 490 bytes
Desc: This is a digitally signed message part
URL: 
<http://lists.freedesktop.org/archives/dri-devel/attachments/20110427/07e6dded/attachment.pgp>

Reply via email to