[PATCH] gxfb: Fixups for the AMD Geode GX framebuffer driver
We cannot assume that the BIOS will be correctly setting up the hardware, so set some bits in various display registers to enable video output. Allow an advanced user to specify a frambuffer size, rather then probing the BIOS. All of these fixes were prompted by the OLPC effort. [akpm@osdl.org: cleanups] Signed-off-by: Jordan Crouse <jordan.crouse@amd.com> Cc: "Antonino A. Daplas" <adaplas@pol.net> Acked-by: James Simmons <jsimmons@infradead.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:

committed by
Linus Torvalds

parent
4c1979c896
commit
f378819a19
@@ -21,6 +21,12 @@
|
||||
#include "geodefb.h"
|
||||
#include "display_gx.h"
|
||||
|
||||
#ifdef CONFIG_FB_GEODE_GX_SET_FBSIZE
|
||||
unsigned int gx_frame_buffer_size(void)
|
||||
{
|
||||
return CONFIG_FB_GEODE_GX_FBSIZE;
|
||||
}
|
||||
#else
|
||||
unsigned int gx_frame_buffer_size(void)
|
||||
{
|
||||
unsigned int val;
|
||||
@@ -35,6 +41,7 @@ unsigned int gx_frame_buffer_size(void)
|
||||
val = (unsigned int)(inw(0xAC1E)) & 0xFFl;
|
||||
return (val << 19);
|
||||
}
|
||||
#endif
|
||||
|
||||
int gx_line_delta(int xres, int bpp)
|
||||
{
|
||||
@@ -90,6 +97,7 @@ static void gx_set_mode(struct fb_info *info)
|
||||
writel(((info->var.xres * info->var.bits_per_pixel/8) >> 3) + 2,
|
||||
par->dc_regs + DC_LINE_SIZE);
|
||||
|
||||
|
||||
/* Enable graphics and video data and unmask address lines. */
|
||||
dcfg |= DC_DCFG_GDEN | DC_DCFG_VDEN | DC_DCFG_A20M | DC_DCFG_A18M;
|
||||
|
||||
|
Reference in New Issue
Block a user