Commit 458a5513 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] fbdev: mode switching fix.

From: James Simmons <jsimmons@infradead.org>

This fixes the bugs that where in mode switch via stty.

The problem was we couldn't set the mode just by using the x and y
resolution.  We use modedb to fill in the rest.  There also was a bug that
allowed you to change the console resolution for drivers with fixed
resolutions.  This would mess up your display.  Now that is fixed.
parent ef7df33c
...@@ -776,17 +776,17 @@ int vc_resize(int currcons, unsigned int cols, unsigned int lines) ...@@ -776,17 +776,17 @@ int vc_resize(int currcons, unsigned int cols, unsigned int lines)
old_row_size = video_size_row; old_row_size = video_size_row;
old_screen_size = screenbuf_size; old_screen_size = screenbuf_size;
video_num_lines = new_rows;
video_num_columns = new_cols;
video_size_row = new_row_size;
screenbuf_size = new_screen_size;
err = resize_screen(currcons, new_cols, new_rows); err = resize_screen(currcons, new_cols, new_rows);
if (err) { if (err) {
kfree(newscreen); kfree(newscreen);
return err; return err;
} }
video_num_lines = new_rows;
video_num_columns = new_cols;
video_size_row = new_row_size;
screenbuf_size = new_screen_size;
rlth = min(old_row_size, new_row_size); rlth = min(old_row_size, new_row_size);
rrem = new_row_size - rlth; rrem = new_row_size - rlth;
old_origin = origin; old_origin = origin;
...@@ -811,8 +811,6 @@ int vc_resize(int currcons, unsigned int cols, unsigned int lines) ...@@ -811,8 +811,6 @@ int vc_resize(int currcons, unsigned int cols, unsigned int lines)
screenbuf = newscreen; screenbuf = newscreen;
kmalloced = 1; kmalloced = 1;
screenbuf_size = new_screen_size; screenbuf_size = new_screen_size;
if (IS_VISIBLE)
err = resize_screen(currcons, new_cols, new_rows);
set_origin(currcons); set_origin(currcons);
/* do part of a reset_terminal() */ /* do part of a reset_terminal() */
......
...@@ -1231,10 +1231,7 @@ static void atyfb_palette(int enter) ...@@ -1231,10 +1231,7 @@ static void atyfb_palette(int enter)
for (i = 0; i < FB_MAX; i++) { for (i = 0; i < FB_MAX; i++) {
info = registered_fb[i]; info = registered_fb[i];
if (info && if (info && info->fbops == &atyfb_ops) {
info->fbops == &atyfb_ops &&
info->display_fg &&
info->display_fg->vc_num == i) {
par = (struct atyfb_par *) info->par; par = (struct atyfb_par *) info->par;
atyfb_save_palette(par, enter); atyfb_save_palette(par, enter);
......
...@@ -1783,7 +1783,6 @@ static int __devinit radeon_set_fbinfo (struct radeonfb_info *rinfo) ...@@ -1783,7 +1783,6 @@ static int __devinit radeon_set_fbinfo (struct radeonfb_info *rinfo)
info->pseudo_palette = rinfo->pseudo_palette; info->pseudo_palette = rinfo->pseudo_palette;
info->flags = FBINFO_FLAG_DEFAULT; info->flags = FBINFO_FLAG_DEFAULT;
info->fbops = &radeonfb_ops; info->fbops = &radeonfb_ops;
info->display_fg = NULL;
info->screen_base = (char *)rinfo->fb_base; info->screen_base = (char *)rinfo->fb_base;
/* Fill fix common fields */ /* Fill fix common fields */
......
...@@ -115,6 +115,8 @@ static int softback_lines; ...@@ -115,6 +115,8 @@ static int softback_lines;
static int first_fb_vc; static int first_fb_vc;
static int last_fb_vc = MAX_NR_CONSOLES - 1; static int last_fb_vc = MAX_NR_CONSOLES - 1;
static int fbcon_is_default = 1; static int fbcon_is_default = 1;
/* font data */
static char fontname[40];
#define REFCOUNT(fd) (((int *)(fd))[-1]) #define REFCOUNT(fd) (((int *)(fd))[-1])
#define FNTSIZE(fd) (((int *)(fd))[-2]) #define FNTSIZE(fd) (((int *)(fd))[-2])
...@@ -168,9 +170,7 @@ static int fbcon_scrolldelta(struct vc_data *vc, int lines); ...@@ -168,9 +170,7 @@ static int fbcon_scrolldelta(struct vc_data *vc, int lines);
/* /*
* Internal routines * Internal routines
*/ */
static void fbcon_set_display(struct vc_data *vc, int init, int logo);
static __inline__ int real_y(struct display *p, int ypos); static __inline__ int real_y(struct display *p, int ypos);
static __inline__ void updatescrollmode(struct display *p, struct vc_data *vc);
static __inline__ void ywrap_up(struct vc_data *vc, int count); static __inline__ void ywrap_up(struct vc_data *vc, int count);
static __inline__ void ywrap_down(struct vc_data *vc, int count); static __inline__ void ywrap_down(struct vc_data *vc, int count);
static __inline__ void ypan_up(struct vc_data *vc, int count); static __inline__ void ypan_up(struct vc_data *vc, int count);
...@@ -233,18 +233,15 @@ static void cursor_timer_handler(unsigned long dev_addr) ...@@ -233,18 +233,15 @@ static void cursor_timer_handler(unsigned long dev_addr)
int __init fb_console_setup(char *this_opt) int __init fb_console_setup(char *this_opt)
{ {
int unit, i, j;
char *options; char *options;
int i, j;
if (!this_opt || !*this_opt) if (!this_opt || !*this_opt)
return 0; return 0;
while ((options = strsep(&this_opt, ",")) != NULL) { while ((options = strsep(&this_opt, ",")) != NULL) {
if (!strncmp(options, "font:", 5)) { if (!strncmp(options, "font:", 5))
for (unit = 0; unit < MAX_NR_CONSOLES; unit++) strcpy(fontname, options + 5);
strcpy(fb_display[unit].fontname,
options + 5);
}
if (!strncmp(options, "scrollback:", 11)) { if (!strncmp(options, "scrollback:", 11)) {
options += 11; options += 11;
...@@ -442,11 +439,13 @@ void accel_clear_margins(struct vc_data *vc, struct fb_info *info, ...@@ -442,11 +439,13 @@ void accel_clear_margins(struct vc_data *vc, struct fb_info *info,
static const char *fbcon_startup(void) static const char *fbcon_startup(void)
{ {
const char *display_desc = "frame buffer device"; const char *display_desc = "frame buffer device";
struct display *p = &fb_display[fg_console];
struct vc_data *vc = vc_cons[fg_console].d;
struct font_desc *font = NULL; struct font_desc *font = NULL;
struct module *owner; struct module *owner;
struct fb_info *info; struct fb_info *info;
struct vc_data *vc;
static int done = 0; static int done = 0;
int cols, rows;
int irqres; int irqres;
irqres = 1; irqres = 1;
...@@ -493,36 +492,34 @@ static const char *fbcon_startup(void) ...@@ -493,36 +492,34 @@ static const char *fbcon_startup(void)
softback_lines = 0; softback_lines = 0;
} }
font = get_default_font(info->var.xres, info->var.yres);
vc = (struct vc_data *) kmalloc(sizeof(struct vc_data), GFP_ATOMIC);
if (!vc) {
if (softback_buf)
kfree((void *) softback_buf);
return NULL;
}
/* Setup default font */ /* Setup default font */
vc->vc_font.data = font->data; if (!p->fontdata) {
if (!fontname[0] || !(font = find_font(fontname)))
font = get_default_font(info->var.xres,
info->var.yres);
vc->vc_font.width = font->width; vc->vc_font.width = font->width;
vc->vc_font.height = font->height; vc->vc_font.height = font->height;
vc->vc_font.data = p->fontdata = font->data;
vc->vc_font.charcount = 256; /* FIXME Need to support more fonts */ vc->vc_font.charcount = 256; /* FIXME Need to support more fonts */
}
vc->vc_cols = info->var.xres/vc->vc_font.width; /*
vc->vc_rows = info->var.yres/vc->vc_font.height; * We must always set the mode. The mode of the previous console
* driver could be in the same resolution but we are using different
/* We trust the mode the driver supplies. */ * hardware so we have to initialize the hardware.
*/
if (info->fbops->fb_set_par) if (info->fbops->fb_set_par)
info->fbops->fb_set_par(info); info->fbops->fb_set_par(info);
cols = info->var.xres/vc->vc_font.width;
rows = info->var.yres/vc->vc_font.height;
vc_resize(vc->vc_num, cols, rows);
DPRINTK("mode: %s\n", info->fix.id); DPRINTK("mode: %s\n", info->fix.id);
DPRINTK("visual: %d\n", info->fix.visual); DPRINTK("visual: %d\n", info->fix.visual);
DPRINTK("res: %dx%d-%d\n", info->var.xres, DPRINTK("res: %dx%d-%d\n", info->var.xres,
info->var.yres, info->var.yres,
info->var.bits_per_pixel); info->var.bits_per_pixel);
con_set_default_unimap(vc->vc_num);
info->display_fg = vc;
#ifdef CONFIG_ATARI #ifdef CONFIG_ATARI
if (MACH_IS_ATARI) { if (MACH_IS_ATARI) {
...@@ -597,100 +594,61 @@ static const char *fbcon_startup(void) ...@@ -597,100 +594,61 @@ static const char *fbcon_startup(void)
} }
static void fbcon_init(struct vc_data *vc, int init) static void fbcon_init(struct vc_data *vc, int init)
{
int unit = vc->vc_num;
struct fb_info *info;
/* on which frame buffer will we open this console? */
info = registered_fb[(int) con2fb_map[unit]];
if (info->var.accel_flags)
fb_display[unit].scrollmode = SCROLL_YNOMOVE;
else
fb_display[unit].scrollmode = SCROLL_YREDRAW;
con_set_default_unimap(unit);
fbcon_set_display(vc, init, !init);
}
static void fbcon_deinit(struct vc_data *vc)
{
struct display *p = &fb_display[vc->vc_num];
fbcon_free_font(p);
}
static __inline__ void updatescrollmode(struct display *p, struct vc_data *vc)
{ {
struct fb_info *info = registered_fb[(int) con2fb_map[vc->vc_num]]; struct fb_info *info = registered_fb[(int) con2fb_map[vc->vc_num]];
struct vc_data **default_mode = vc->vc_display_fg;
int m; struct display *t, *p = &fb_display[vc->vc_num];
if (p->scrollmode & __SCROLL_YFIXED) int display_fg = (*default_mode)->vc_num;
return; int logo = 1, rows, cols, charcnt = 256;
if (divides(info->fix.ywrapstep, vc->vc_font.height) &&
divides(vc->vc_font.height, info->var.yres_virtual))
m = __SCROLL_YWRAP;
else if (divides(info->fix.ypanstep, vc->vc_font.height) &&
info->var.yres_virtual >= info->var.yres + vc->vc_font.height)
m = __SCROLL_YPAN;
else if (p->scrollmode & __SCROLL_YNOMOVE)
m = __SCROLL_YREDRAW;
else
m = __SCROLL_YMOVE;
p->scrollmode = (p->scrollmode & ~__SCROLL_YMASK) | m;
}
static void fbcon_set_display(struct vc_data *vc, int init, int logo)
{
struct fb_info *info = registered_fb[(int) con2fb_map[vc->vc_num]];
int nr_rows, nr_cols, old_rows, old_cols, i, charcnt = 256;
struct display *p = &fb_display[vc->vc_num];
unsigned short *save = NULL, *r, *q; unsigned short *save = NULL, *r, *q;
struct font_desc *font;
if (vc->vc_num != fg_console || (info->flags & FBINFO_FLAG_MODULE) || if (vc->vc_num != display_fg || (info->flags & FBINFO_FLAG_MODULE) ||
(info->fix.type == FB_TYPE_TEXT)) (info->fix.type == FB_TYPE_TEXT))
logo = 0; logo = 0;
info->var.xoffset = info->var.yoffset = p->yscroll = 0; /* reset wrap/pan */ info->var.xoffset = info->var.yoffset = p->yscroll = 0; /* reset wrap/pan */
for (i = 0; i < MAX_NR_CONSOLES; i++)
if (vc && i != vc->vc_num && fb_display[i].fontdata)
break;
fbcon_free_font(p);
if (i < MAX_NR_CONSOLES) {
struct display *q = &fb_display[i];
struct vc_data *tmp = vc_cons[i].d;
/* If we are not the first console on this /* If we are not the first console on this
fb, copy the font from that console */ fb, copy the font from that console */
vc->vc_font.width = tmp->vc_font.width; t = &fb_display[display_fg];
vc->vc_font.height = tmp->vc_font.height; vc->vc_font.width = (*default_mode)->vc_font.width;
vc->vc_font.data = p->fontdata = q->fontdata; vc->vc_font.height = (*default_mode)->vc_font.height;
p->userfont = q->userfont; vc->vc_font.data = p->fontdata = t->fontdata;
p->userfont = t->userfont;
if (p->userfont) { if (p->userfont) {
REFCOUNT(p->fontdata)++; REFCOUNT(p->fontdata)++;
charcnt = FNTCHARCNT(p->fontdata); charcnt = FNTCHARCNT(p->fontdata);
} }
con_copy_unimap(vc->vc_num, i); con_copy_unimap(vc->vc_num, display_fg);
}
if (!p->fontdata) { vc->vc_can_do_color = info->var.bits_per_pixel != 1;
if (!p->fontname[0] || !(font = find_font(p->fontname))) vc->vc_complement_mask = vc->vc_can_do_color ? 0x7700 : 0x0800;
font = get_default_font(info->var.xres, if (charcnt == 256) {
info->var.yres); vc->vc_hi_font_mask = 0;
vc->vc_font.width = font->width; } else {
vc->vc_font.height = font->height; vc->vc_hi_font_mask = 0x100;
vc->vc_font.data = p->fontdata = font->data; if (vc->vc_can_do_color)
vc->vc_complement_mask <<= 1;
} }
updatescrollmode(p, vc); cols = info->var.xres / vc->vc_font.width;
rows = info->var.yres / vc->vc_font.height;
vc_resize(vc->vc_num, cols, rows);
old_cols = vc->vc_cols; if (info->var.accel_flags)
old_rows = vc->vc_rows; p->scrollmode = SCROLL_YNOMOVE;
else
p->scrollmode = SCROLL_YREDRAW;
nr_cols = info->var.xres / vc->vc_font.width; /*
nr_rows = info->var.yres / vc->vc_font.height; * ++guenther: console.c:vc_allocate() relies on initializing
* vc_{cols,rows}, but we must not set those if we are only
* resizing the console.
*/
if (init) {
vc->vc_cols = cols;
vc->vc_rows = rows;
}
if (logo) { if (logo) {
/* Need to make room for the logo */ /* Need to make room for the logo */
...@@ -701,34 +659,28 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo) ...@@ -701,34 +659,28 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo)
logo_lines = (logo_height + vc->vc_font.height - 1) / logo_lines = (logo_height + vc->vc_font.height - 1) /
vc->vc_font.height; vc->vc_font.height;
q = (unsigned short *) (vc->vc_origin + q = (unsigned short *) (vc->vc_origin +
vc->vc_size_row * old_rows); vc->vc_size_row * rows);
step = logo_lines * old_cols; step = logo_lines * cols;
for (r = q - logo_lines * old_cols; r < q; r++) for (r = q - logo_lines * cols; r < q; r++)
if (scr_readw(r) != vc->vc_video_erase_char) if (scr_readw(r) != vc->vc_video_erase_char)
break; break;
if (r != q && nr_rows >= old_rows + logo_lines) { if (r != q && rows >= rows + logo_lines) {
save = save = kmalloc(logo_lines * cols * 2, GFP_KERNEL);
kmalloc(logo_lines * nr_cols * 2, GFP_KERNEL);
if (save) { if (save) {
int i =
old_cols <
nr_cols ? old_cols : nr_cols;
scr_memsetw(save, vc->vc_video_erase_char, scr_memsetw(save, vc->vc_video_erase_char,
logo_lines * nr_cols * 2); logo_lines * cols * 2);
r = q - step; r = q - step;
for (cnt = 0; cnt < logo_lines; for (cnt = 0; cnt < logo_lines; cnt++, r += cols)
cnt++, r += i) scr_memcpyw(save + cnt * cols, r, 2 * cols);
scr_memcpyw(save + cnt * nr_cols,
r, 2 * i);
r = q; r = q;
} }
} }
if (r == q) { if (r == q) {
/* We can scroll screen down */ /* We can scroll screen down */
r = q - step - old_cols; r = q - step - cols;
for (cnt = old_rows - logo_lines; cnt > 0; cnt--) { for (cnt = rows - logo_lines; cnt > 0; cnt--) {
scr_memcpyw(r + step, r, vc->vc_size_row); scr_memcpyw(r + step, r, vc->vc_size_row);
r -= old_cols; r -= cols;
} }
if (!save) { if (!save) {
vc->vc_y += logo_lines; vc->vc_y += logo_lines;
...@@ -738,40 +690,16 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo) ...@@ -738,40 +690,16 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo)
scr_memsetw((unsigned short *) vc->vc_origin, scr_memsetw((unsigned short *) vc->vc_origin,
vc->vc_video_erase_char, vc->vc_video_erase_char,
vc->vc_size_row * logo_lines); vc->vc_size_row * logo_lines);
}
/*
* ++guenther: console.c:vc_allocate() relies on initializing
* vc_{cols,rows}, but we must not set those if we are only
* resizing the console.
*/
if (init) {
vc->vc_cols = nr_cols;
vc->vc_rows = nr_rows;
}
vc->vc_can_do_color = info->var.bits_per_pixel != 1;
vc->vc_complement_mask = vc->vc_can_do_color ? 0x7700 : 0x0800;
if (charcnt == 256) {
vc->vc_hi_font_mask = 0;
} else {
vc->vc_hi_font_mask = 0x100;
if (vc->vc_can_do_color)
vc->vc_complement_mask <<= 1;
}
if (logo) { if (CON_IS_VISIBLE(vc) && vt_cons[vc->vc_num]->vc_mode == KD_TEXT) {
if (vc->vc_cols != nr_cols || vc->vc_rows != nr_rows)
vc_resize(vc->vc_num, nr_cols, nr_rows);
else if (CON_IS_VISIBLE(vc) &&
vt_cons[vc->vc_num]->vc_mode == KD_TEXT) {
accel_clear_margins(vc, info, 0); accel_clear_margins(vc, info, 0);
update_screen(vc->vc_num); update_screen(vc->vc_num);
} }
if (save) { if (save) {
q = (unsigned short *) (vc->vc_origin + q = (unsigned short *) (vc->vc_origin +
vc->vc_size_row * vc->vc_size_row *
old_rows); rows);
scr_memcpyw(q, save, logo_lines * nr_cols * 2); scr_memcpyw(q, save, logo_lines * cols * 2);
vc->vc_y += logo_lines; vc->vc_y += logo_lines;
vc->vc_pos += logo_lines * vc->vc_size_row; vc->vc_pos += logo_lines * vc->vc_size_row;
kfree(save); kfree(save);
...@@ -786,7 +714,7 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo) ...@@ -786,7 +714,7 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo)
} }
} }
if (vc->vc_num == fg_console && softback_buf) { if (vc->vc_num == display_fg && softback_buf) {
int l = fbcon_softback_size / vc->vc_size_row; int l = fbcon_softback_size / vc->vc_size_row;
if (l > 5) if (l > 5)
softback_end = softback_buf + l * vc->vc_size_row; softback_end = softback_buf + l * vc->vc_size_row;
...@@ -798,6 +726,12 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo) ...@@ -798,6 +726,12 @@ static void fbcon_set_display(struct vc_data *vc, int init, int logo)
} }
} }
static void fbcon_deinit(struct vc_data *vc)
{
struct display *p = &fb_display[vc->vc_num];
fbcon_free_font(p);
}
/* ====================================================================== */ /* ====================================================================== */
...@@ -1531,6 +1465,25 @@ static void fbcon_bmove_rec(struct vc_data *vc, struct display *p, int sy, int s ...@@ -1531,6 +1465,25 @@ static void fbcon_bmove_rec(struct vc_data *vc, struct display *p, int sy, int s
height, width); height, width);
} }
static __inline__ void updatescrollmode(struct display *p, struct fb_info *info, struct vc_data *vc)
{
int m;
if (p->scrollmode & __SCROLL_YFIXED)
return;
if (divides(info->fix.ywrapstep, vc->vc_font.height) &&
divides(vc->vc_font.height, info->var.yres_virtual))
m = __SCROLL_YWRAP;
else if (divides(info->fix.ypanstep, vc->vc_font.height) &&
info->var.yres_virtual >= info->var.yres + vc->vc_font.height)
m = __SCROLL_YPAN;
else if (p->scrollmode & __SCROLL_YNOMOVE)
m = __SCROLL_YREDRAW;
else
m = __SCROLL_YMOVE;
p->scrollmode = (p->scrollmode & ~__SCROLL_YMASK) | m;
}
static int fbcon_resize(struct vc_data *vc, unsigned int width, static int fbcon_resize(struct vc_data *vc, unsigned int width,
unsigned int height) unsigned int height)
{ {
...@@ -1545,22 +1498,30 @@ static int fbcon_resize(struct vc_data *vc, unsigned int width, ...@@ -1545,22 +1498,30 @@ static int fbcon_resize(struct vc_data *vc, unsigned int width,
var.yres = height * fh; var.yres = height * fh;
x_diff = info->var.xres - var.xres; x_diff = info->var.xres - var.xres;
y_diff = info->var.yres - var.yres; y_diff = info->var.yres - var.yres;
if (x_diff < 0 || x_diff > fw || if (x_diff < 0 || x_diff > fw || (y_diff < 0 || y_diff > fh)) {
(y_diff < 0 || y_diff > fh)) { char mode[40];
var.activate = FB_ACTIVATE_TEST;
err = fb_set_var(info, &var); DPRINTK("attempting resize %ix%i\n", var.xres, var.yres);
if (err || width > var.xres/fw || if (!info->fbops->fb_set_par)
height > var.yres/fh) return -EINVAL;
sprintf(mode, "%dx%d", var.xres, var.yres);
err = fb_find_mode(&var, info, mode, NULL, 0, NULL,
info->var.bits_per_pixel);
if (!err || width > var.xres/fw || height > var.yres/fh)
return -EINVAL; return -EINVAL;
DPRINTK("resize now %ix%i\n", var.xres, var.yres); DPRINTK("resize now %ix%i\n", var.xres, var.yres);
if (CON_IS_VISIBLE(vc)) {
var.activate = FB_ACTIVATE_NOW; var.activate = FB_ACTIVATE_NOW;
fb_set_var(info, &var); fb_set_var(info, &var);
} }
}
p->vrows = var.yres_virtual/fh; p->vrows = var.yres_virtual/fh;
if (var.yres > (fh * (height + 1))) if (var.yres > (fh * (height + 1)))
p->vrows -= (var.yres - (fh * height)) / fh; p->vrows -= (var.yres - (fh * height)) / fh;
if ((var.yres % fh) && (var.yres_virtual % fh < var.yres % fh)) if ((var.yres % fh) && (var.yres_virtual % fh < var.yres % fh))
p->vrows--; p->vrows--;
updatescrollmode(p, info, vc);
return 0; return 0;
} }
...@@ -1830,7 +1791,6 @@ static int fbcon_do_set_font(struct vc_data *vc, struct console_font_op *op, ...@@ -1830,7 +1791,6 @@ static int fbcon_do_set_font(struct vc_data *vc, struct console_font_op *op,
if (resize) { if (resize) {
/* reset wrap/pan */ /* reset wrap/pan */
info->var.xoffset = info->var.yoffset = p->yscroll = 0; info->var.xoffset = info->var.yoffset = p->yscroll = 0;
updatescrollmode(p, vc);
vc_resize(vc->vc_num, info->var.xres / w, info->var.yres / h); vc_resize(vc->vc_num, info->var.xres / w, info->var.yres / h);
if (CON_IS_VISIBLE(vc) && softback_buf) { if (CON_IS_VISIBLE(vc) && softback_buf) {
int l = fbcon_softback_size / vc->vc_size_row; int l = fbcon_softback_size / vc->vc_size_row;
......
...@@ -27,7 +27,6 @@ struct display { ...@@ -27,7 +27,6 @@ struct display {
/* Filled in by the frame buffer device */ /* Filled in by the frame buffer device */
u_short inverse; /* != 0 text black on white as default */ u_short inverse; /* != 0 text black on white as default */
/* Filled in by the low-level console driver */ /* Filled in by the low-level console driver */
char fontname[40]; /* Font associated to this display */
u_char *fontdata; u_char *fontdata;
int userfont; /* != 0 if fontdata kmalloc()ed */ int userfont; /* != 0 if fontdata kmalloc()ed */
u_short scrollmode; /* Scroll Method */ u_short scrollmode; /* Scroll Method */
......
...@@ -391,7 +391,7 @@ static int my_atoi(const char *name) ...@@ -391,7 +391,7 @@ static int my_atoi(const char *name)
} }
/** /**
* __fb_try_mode - test a video mode * fb_try_mode - test a video mode
* @var: frame buffer user defined part of display * @var: frame buffer user defined part of display
* @info: frame buffer info structure * @info: frame buffer info structure
* @mode: frame buffer video mode structure * @mode: frame buffer video mode structure
...@@ -403,10 +403,10 @@ static int my_atoi(const char *name) ...@@ -403,10 +403,10 @@ static int my_atoi(const char *name)
* *
*/ */
int __fb_try_mode(struct fb_var_screeninfo *var, struct fb_info *info, int fb_try_mode(struct fb_var_screeninfo *var, struct fb_info *info,
const struct fb_videomode *mode, unsigned int bpp) const struct fb_videomode *mode, unsigned int bpp)
{ {
int err = 1; int err = 0;
DPRINTK("Trying mode %s %dx%d-%d@%d\n", mode->name ? mode->name : "noname", DPRINTK("Trying mode %s %dx%d-%d@%d\n", mode->name ? mode->name : "noname",
mode->xres, mode->yres, bpp, mode->refresh); mode->xres, mode->yres, bpp, mode->refresh);
...@@ -430,10 +430,9 @@ int __fb_try_mode(struct fb_var_screeninfo *var, struct fb_info *info, ...@@ -430,10 +430,9 @@ int __fb_try_mode(struct fb_var_screeninfo *var, struct fb_info *info,
if (info->fbops->fb_check_var) if (info->fbops->fb_check_var)
err = info->fbops->fb_check_var(var, info); err = info->fbops->fb_check_var(var, info);
var->activate &= ~FB_ACTIVATE_TEST; var->activate &= ~FB_ACTIVATE_TEST;
return !err; return err;
} }
/** /**
* fb_find_mode - finds a valid video mode * fb_find_mode - finds a valid video mode
* @var: frame buffer user defined part of display * @var: frame buffer user defined part of display
...@@ -536,18 +535,18 @@ int fb_find_mode(struct fb_var_screeninfo *var, ...@@ -536,18 +535,18 @@ int fb_find_mode(struct fb_var_screeninfo *var,
if ((name_matches(db[j], name, namelen) || if ((name_matches(db[j], name, namelen) ||
(res_specified && res_matches(db[j], xres, yres))) && (res_specified && res_matches(db[j], xres, yres))) &&
(!i || db[j].refresh == refresh) && (!i || db[j].refresh == refresh) &&
__fb_try_mode(var, info, &db[j], bpp)) !fb_try_mode(var, info, &db[j], bpp))
return 2-i; return 2-i;
} }
} }
DPRINTK("Trying default video mode\n"); DPRINTK("Trying default video mode\n");
if (__fb_try_mode(var, info, default_mode, default_bpp)) if (!fb_try_mode(var, info, default_mode, default_bpp))
return 3; return 3;
DPRINTK("Trying all modes\n"); DPRINTK("Trying all modes\n");
for (i = 0; i < dbsize; i++) for (i = 0; i < dbsize; i++)
if (__fb_try_mode(var, info, &db[i], default_bpp)) if (!fb_try_mode(var, info, &db[i], default_bpp))
return 4; return 4;
DPRINTK("No valid mode found\n"); DPRINTK("No valid mode found\n");
......
...@@ -2252,7 +2252,6 @@ static int __devinit radeon_set_fbinfo (struct radeonfb_info *rinfo) ...@@ -2252,7 +2252,6 @@ static int __devinit radeon_set_fbinfo (struct radeonfb_info *rinfo)
info->pseudo_palette = rinfo->pseudo_palette; info->pseudo_palette = rinfo->pseudo_palette;
info->flags = FBINFO_FLAG_DEFAULT; info->flags = FBINFO_FLAG_DEFAULT;
info->fbops = &radeonfb_ops; info->fbops = &radeonfb_ops;
info->display_fg = NULL;
info->screen_base = (char *)rinfo->fb_base; info->screen_base = (char *)rinfo->fb_base;
/* Fill fix common fields */ /* Fill fix common fields */
......
...@@ -516,7 +516,6 @@ struct fb_info { ...@@ -516,7 +516,6 @@ struct fb_info {
struct fb_cmap cmap; /* Current cmap */ struct fb_cmap cmap; /* Current cmap */
struct fb_ops *fbops; struct fb_ops *fbops;
char *screen_base; /* Virtual address */ char *screen_base; /* Virtual address */
struct vc_data *display_fg; /* Console visible on this display */
int currcon; /* Current VC. */ int currcon; /* Current VC. */
void *pseudo_palette; /* Fake palette of 16 colors */ void *pseudo_palette; /* Fake palette of 16 colors */
#define FBINFO_STATE_RUNNING 0 #define FBINFO_STATE_RUNNING 0
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment