[PATCH 1/3] UBUNTU: [Upstream] drm/nv04-nv40: Fix up the programmed horizontal sync pulse delay.

Christopher James Halse Rogers raof at ubuntu.com
Tue Mar 30 23:26:02 UTC 2010


On Tue, 2010-03-30 at 14:18 +0100, Andy Whitcroft wrote:
> On Fri, Mar 26, 2010 at 09:25:55AM +1100, Chris Halse Rogers wrote:
> > From: Christopher James Halse Rogers <raof at ubuntu.com>
> > 
> > The calculated values were a little bit off (~16 clocks), the only
> > effect it could have had is a slightly offset image with respect to
> > the blob on analog outputs (bug 26790).
> 
> I would love to know what the heck a blob is in this context and how I
> could tell my image was offset from it :).
> 
In this context the blob is the nvidia binary drivers.  The difference
in timing meant that for users of VGA outputs the display was offset
with nouveau after fiddling with the monitor to align it correctly when
run with the nvidia drivers.  This would be particularly annoying for
dual-booters, who'd need to re-align their monitor on each OS switch.

I don't miss having to fiddle with image alignment on analogue outputs!

> > BugLink: http://bugs.launchpad.net/bugs/529130
> > 
> > Signed-off-by: Francisco Jerez <currojerez at riseup.net>
> > Signed-off-by: Christopher James Halse Rogers <raof at ubuntu.com>
> > ---
> >  drivers/gpu/drm/nouveau/nv04_crtc.c |    6 +++---
> >  1 files changed, 3 insertions(+), 3 deletions(-)
> > 
> > diff --git a/drivers/gpu/drm/nouveau/nv04_crtc.c b/drivers/gpu/drm/nouveau/nv04_crtc.c
> > index d2f143e..9986aba 100644
> > --- a/drivers/gpu/drm/nouveau/nv04_crtc.c
> > +++ b/drivers/gpu/drm/nouveau/nv04_crtc.c
> > @@ -230,9 +230,9 @@ nv_crtc_mode_set_vga(struct drm_crtc *crtc, struct drm_display_mode *mode)
> >  	struct drm_framebuffer *fb = crtc->fb;
> >  
> >  	/* Calculate our timings */
> > -	int horizDisplay	= (mode->crtc_hdisplay >> 3) 	- 1;
> > -	int horizStart		= (mode->crtc_hsync_start >> 3) 	- 1;
> > -	int horizEnd		= (mode->crtc_hsync_end >> 3) 	- 1;
> > +	int horizDisplay	= (mode->crtc_hdisplay >> 3)		- 1;
> > +	int horizStart		= (mode->crtc_hsync_start >> 3) 	+ 1;
> > +	int horizEnd		= (mode->crtc_hsync_end >> 3)		+ 1;
> >  	int horizTotal		= (mode->crtc_htotal >> 3)		- 5;
> >  	int horizBlankStart	= (mode->crtc_hdisplay >> 3)		- 1;
> >  	int horizBlankEnd	= (mode->crtc_htotal >> 3)		- 1;
> 
> Looks like it might do what it says, and its upstreaming.
> 
> Acked-by: Andy Whitcroft <apw at canonical.com>
> 
> -apw


-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 490 bytes
Desc: This is a digitally signed message part
URL: <https://lists.ubuntu.com/archives/kernel-team/attachments/20100331/6d41a05a/attachment.sig>


More information about the kernel-team mailing list