staging: sm750: add missing spaces after ','

Fixes checkpatch.pl error:
"ERROR: space required after that ',' (ctx:VxV)"

Signed-off-by: Michel von Czettritz <michel.von.czettritz@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Michel von Czettritz 2015-03-26 23:24:53 +01:00 committed by Greg Kroah-Hartman
parent c52c3700d8
commit 45e3b3da82

View File

@ -50,26 +50,26 @@ static int g_noaccel;
#ifdef CONFIG_MTRR #ifdef CONFIG_MTRR
static int g_nomtrr; static int g_nomtrr;
#endif #endif
static const char * g_fbmode[] = {NULL,NULL}; static const char * g_fbmode[] = {NULL, NULL};
static const char * g_def_fbmode = "800x600-16@60"; static const char * g_def_fbmode = "800x600-16@60";
static char * g_settings = NULL; static char * g_settings = NULL;
static int g_dualview; static int g_dualview;
static char * g_option = NULL; static char * g_option = NULL;
static const struct fb_videomode lynx750_ext[] = { static const struct fb_videomode lynx750_ext[] = {
/* 1024x600-60 VESA [1.71:1] */ /* 1024x600-60 VESA [1.71:1] */
{NULL, 60, 1024, 600, 20423, 144, 40, 18, 1, 104, 3, {NULL, 60, 1024, 600, 20423, 144, 40, 18, 1, 104, 3,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED}, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
/* 1024x600-70 VESA */ /* 1024x600-70 VESA */
{NULL, 70, 1024, 600, 17211, 152, 48, 21, 1, 104, 3, {NULL, 70, 1024, 600, 17211, 152, 48, 21, 1, 104, 3,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED}, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
/* 1024x600-75 VESA */ /* 1024x600-75 VESA */
{NULL, 75, 1024, 600, 15822, 160, 56, 23, 1, 104, 3, {NULL, 75, 1024, 600, 15822, 160, 56, 23, 1, 104, 3,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED}, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
/* 1024x600-85 VESA */ /* 1024x600-85 VESA */
{NULL, 85, 1024, 600, 13730, 168, 56, 26, 1, 112, 3, {NULL, 85, 1024, 600, 13730, 168, 56, 26, 1, 112, 3,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED}, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
@ -79,13 +79,13 @@ static const struct fb_videomode lynx750_ext[] = {
/* 1280x720 [1.78:1] */ /* 1280x720 [1.78:1] */
{NULL, 60, 1280, 720, 13426, 162, 86, 22, 1, 136, 3, {NULL, 60, 1280, 720, 13426, 162, 86, 22, 1, 136, 3,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
/* 1280x768@60 */
{NULL, 60, 1280, 768, 12579, 192, 64, 20, 3, 128, 7,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,FB_VMODE_NONINTERLACED}, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,FB_VMODE_NONINTERLACED},
/* 1280x768@60 */ {NULL, 60, 1360, 768, 11804, 208, 64, 23, 1, 144, 3,
{NULL,60,1280,768,12579,192,64,20,3,128,7,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,FB_VMODE_NONINTERLACED},
{NULL,60,1360,768,11804,208,64,23,1,144,3,
FB_SYNC_HOR_HIGH_ACT|FB_VMODE_NONINTERLACED}, FB_SYNC_HOR_HIGH_ACT|FB_VMODE_NONINTERLACED},
/* 1360 x 768 [1.77083:1] */ /* 1360 x 768 [1.77083:1] */
@ -96,9 +96,9 @@ static const struct fb_videomode lynx750_ext[] = {
{NULL, 60, 1368, 768, 11647, 216, 72, 23, 1, 144, 3, {NULL, 60, 1368, 768, 11647, 216, 72, 23, 1, 144, 3,
FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED}, FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
/* 1440 x 900 [16:10] */ /* 1440 x 900 [16:10] */
{NULL, 60, 1440, 900, 9392, 232, 80, 28, 1, 152, 3, {NULL, 60, 1440, 900, 9392, 232, 80, 28, 1, 152, 3,
FB_SYNC_VERT_HIGH_ACT,FB_VMODE_NONINTERLACED}, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
/* 1440x960 [15:10] */ /* 1440x960 [15:10] */
{NULL, 60, 1440, 960, 8733, 240, 88, 30, 1, 152, 3, {NULL, 60, 1440, 960, 8733, 240, 88, 30, 1, 152, 3,
@ -106,14 +106,14 @@ static const struct fb_videomode lynx750_ext[] = {
/* 1920x1080 [16:9] */ /* 1920x1080 [16:9] */
{NULL, 60, 1920, 1080, 6734, 148, 88, 41, 1, 44, 3, {NULL, 60, 1920, 1080, 6734, 148, 88, 41, 1, 44, 3,
FB_SYNC_VERT_HIGH_ACT,FB_VMODE_NONINTERLACED}, FB_SYNC_VERT_HIGH_ACT, FB_VMODE_NONINTERLACED},
}; };
/* no hardware cursor supported under version 2.6.10, kernel bug */ /* no hardware cursor supported under version 2.6.10, kernel bug */
static int lynxfb_ops_cursor(struct fb_info* info,struct fb_cursor* fbcursor) static int lynxfb_ops_cursor(struct fb_info* info, struct fb_cursor* fbcursor)
{ {
struct lynxfb_par * par; struct lynxfb_par * par;
struct lynxfb_crtc * crtc; struct lynxfb_crtc * crtc;
@ -131,17 +131,17 @@ static int lynxfb_ops_cursor(struct fb_info* info,struct fb_cursor* fbcursor)
cursor->disable(cursor); cursor->disable(cursor);
if(fbcursor->set & FB_CUR_SETSIZE){ if(fbcursor->set & FB_CUR_SETSIZE){
cursor->setSize(cursor,fbcursor->image.width,fbcursor->image.height); cursor->setSize(cursor, fbcursor->image.width, fbcursor->image.height);
} }
if(fbcursor->set & FB_CUR_SETPOS){ if(fbcursor->set & FB_CUR_SETPOS){
cursor->setPos(cursor,fbcursor->image.dx - info->var.xoffset, cursor->setPos(cursor, fbcursor->image.dx - info->var.xoffset,
fbcursor->image.dy - info->var.yoffset); fbcursor->image.dy - info->var.yoffset);
} }
if(fbcursor->set & FB_CUR_SETCMAP){ if(fbcursor->set & FB_CUR_SETCMAP){
/* get the 16bit color of kernel means */ /* get the 16bit color of kernel means */
u16 fg,bg; u16 fg, bg;
fg = ((info->cmap.red[fbcursor->image.fg_color] & 0xf800))| fg = ((info->cmap.red[fbcursor->image.fg_color] & 0xf800))|
((info->cmap.green[fbcursor->image.fg_color] & 0xfc00) >> 5)| ((info->cmap.green[fbcursor->image.fg_color] & 0xfc00) >> 5)|
((info->cmap.blue[fbcursor->image.fg_color] & 0xf800) >> 11); ((info->cmap.blue[fbcursor->image.fg_color] & 0xf800) >> 11);
@ -150,7 +150,7 @@ static int lynxfb_ops_cursor(struct fb_info* info,struct fb_cursor* fbcursor)
((info->cmap.green[fbcursor->image.bg_color] & 0xfc00) >> 5)| ((info->cmap.green[fbcursor->image.bg_color] & 0xfc00) >> 5)|
((info->cmap.blue[fbcursor->image.bg_color] & 0xf800) >> 11); ((info->cmap.blue[fbcursor->image.bg_color] & 0xf800) >> 11);
cursor->setColor(cursor,fg,bg); cursor->setColor(cursor, fg, bg);
} }
@ -169,11 +169,11 @@ static int lynxfb_ops_cursor(struct fb_info* info,struct fb_cursor* fbcursor)
return 0; return 0;
} }
static void lynxfb_ops_fillrect(struct fb_info* info,const struct fb_fillrect* region) static void lynxfb_ops_fillrect(struct fb_info* info, const struct fb_fillrect* region)
{ {
struct lynxfb_par * par; struct lynxfb_par * par;
struct lynx_share * share; struct lynx_share * share;
unsigned int base,pitch,Bpp,rop; unsigned int base, pitch, Bpp, rop;
u32 color; u32 color;
if(info->state != FBINFO_STATE_RUNNING){ if(info->state != FBINFO_STATE_RUNNING){
@ -200,19 +200,19 @@ static void lynxfb_ops_fillrect(struct fb_info* info,const struct fb_fillrect* r
spin_lock(&share->slock); spin_lock(&share->slock);
share->accel.de_fillrect(&share->accel, share->accel.de_fillrect(&share->accel,
base,pitch,Bpp, base, pitch, Bpp,
region->dx,region->dy, region->dx, region->dy,
region->width,region->height, region->width, region->height,
color,rop); color, rop);
if (share->dual) if (share->dual)
spin_unlock(&share->slock); spin_unlock(&share->slock);
} }
static void lynxfb_ops_copyarea(struct fb_info * info,const struct fb_copyarea * region) static void lynxfb_ops_copyarea(struct fb_info * info, const struct fb_copyarea * region)
{ {
struct lynxfb_par * par; struct lynxfb_par * par;
struct lynx_share * share; struct lynx_share * share;
unsigned int base,pitch,Bpp; unsigned int base, pitch, Bpp;
par = info->par; par = info->par;
share = par->share; share = par->share;
@ -231,17 +231,17 @@ static void lynxfb_ops_copyarea(struct fb_info * info,const struct fb_copyarea *
spin_lock(&share->slock); spin_lock(&share->slock);
share->accel.de_copyarea(&share->accel, share->accel.de_copyarea(&share->accel,
base,pitch,region->sx,region->sy, base, pitch, region->sx, region->sy,
base,pitch,Bpp,region->dx,region->dy, base, pitch, Bpp, region->dx, region->dy,
region->width,region->height,HW_ROP2_COPY); region->width, region->height, HW_ROP2_COPY);
if (share->dual) if (share->dual)
spin_unlock(&share->slock); spin_unlock(&share->slock);
} }
static void lynxfb_ops_imageblit(struct fb_info*info,const struct fb_image* image) static void lynxfb_ops_imageblit(struct fb_info*info, const struct fb_image* image)
{ {
unsigned int base,pitch,Bpp; unsigned int base, pitch, Bpp;
unsigned int fgcol,bgcol; unsigned int fgcol, bgcol;
struct lynxfb_par * par; struct lynxfb_par * par;
struct lynx_share * share; struct lynx_share * share;
@ -277,11 +277,11 @@ _do_work:
spin_lock(&share->slock); spin_lock(&share->slock);
share->accel.de_imageblit(&share->accel, share->accel.de_imageblit(&share->accel,
image->data,image->width>>3,0, image->data, image->width>>3, 0,
base,pitch,Bpp, base, pitch, Bpp,
image->dx,image->dy, image->dx, image->dy,
image->width,image->height, image->width, image->height,
fgcol,bgcol,HW_ROP2_COPY); fgcol, bgcol, HW_ROP2_COPY);
if (share->dual) if (share->dual)
spin_unlock(&share->slock); spin_unlock(&share->slock);
} }
@ -329,9 +329,9 @@ static int lynxfb_ops_set_par(struct fb_info * info)
/* fix structur is not so FIX ... */ /* fix structur is not so FIX ... */
line_length = var->xres_virtual * var->bits_per_pixel / 8; line_length = var->xres_virtual * var->bits_per_pixel / 8;
line_length = PADDING(crtc->line_pad,line_length); line_length = PADDING(crtc->line_pad, line_length);
fix->line_length = line_length; fix->line_length = line_length;
pr_err("fix->line_length = %d\n",fix->line_length); pr_err("fix->line_length = %d\n", fix->line_length);
/* var->red,green,blue,transp are need to be set by driver /* var->red,green,blue,transp are need to be set by driver
* and these data should be set before setcolreg routine * and these data should be set before setcolreg routine
@ -381,13 +381,13 @@ static int lynxfb_ops_set_par(struct fb_info * info)
pr_err("pixel bpp format not satisfied\n."); pr_err("pixel bpp format not satisfied\n.");
return ret; return ret;
} }
ret = crtc->proc_setMode(crtc,var,fix); ret = crtc->proc_setMode(crtc, var, fix);
if(!ret) if(!ret)
ret = output->proc_setMode(output,var,fix); ret = output->proc_setMode(output, var, fix);
return ret; return ret;
} }
static inline unsigned int chan_to_field(unsigned int chan,struct fb_bitfield * bf) static inline unsigned int chan_to_field(unsigned int chan, struct fb_bitfield * bf)
{ {
chan &= 0xffff; chan &= 0xffff;
chan >>= 16 - bf->length; chan >>= 16 - bf->length;
@ -465,7 +465,7 @@ static int lynxfb_resume(struct pci_dev* pdev)
console_lock(); console_lock();
if((ret = pci_set_power_state(pdev, PCI_D0)) != 0){ if((ret = pci_set_power_state(pdev, PCI_D0)) != 0){
pr_err("error:%d occured in pci_set_power_state\n",ret); pr_err("error:%d occured in pci_set_power_state\n", ret);
return ret; return ret;
} }
@ -473,7 +473,7 @@ static int lynxfb_resume(struct pci_dev* pdev)
if(pdev->dev.power.power_state.event != PM_EVENT_FREEZE){ if(pdev->dev.power.power_state.event != PM_EVENT_FREEZE){
pci_restore_state(pdev); pci_restore_state(pdev);
if ((ret = pci_enable_device(pdev)) != 0){ if ((ret = pci_enable_device(pdev)) != 0){
pr_err("error:%d occured in pci_enable_device\n",ret); pr_err("error:%d occured in pci_enable_device\n", ret);
return ret; return ret;
} }
pci_set_master(pdev); pci_set_master(pdev);
@ -481,7 +481,7 @@ static int lynxfb_resume(struct pci_dev* pdev)
if(share->resume) if(share->resume)
(*share->resume)(share); (*share->resume)(share);
hw_sm750_inithw(share,pdev); hw_sm750_inithw(share, pdev);
info = share->fbinfo[0]; info = share->fbinfo[0];
@ -514,7 +514,7 @@ static int lynxfb_resume(struct pci_dev* pdev)
} }
#endif #endif
static int lynxfb_ops_check_var(struct fb_var_screeninfo* var,struct fb_info* info) static int lynxfb_ops_check_var(struct fb_var_screeninfo* var, struct fb_info* info)
{ {
struct lynxfb_par * par; struct lynxfb_par * par;
struct lynxfb_crtc * crtc; struct lynxfb_crtc * crtc;
@ -543,7 +543,7 @@ static int lynxfb_ops_check_var(struct fb_var_screeninfo* var,struct fb_info* in
case 32: case 32:
break; break;
default: default:
pr_err("bpp %d not supported\n",var->bits_per_pixel); pr_err("bpp %d not supported\n", var->bits_per_pixel);
ret = -EINVAL; ret = -EINVAL;
goto exit; goto exit;
} }
@ -592,24 +592,24 @@ static int lynxfb_ops_check_var(struct fb_var_screeninfo* var,struct fb_info* in
request = var->xres_virtual * (var->bits_per_pixel >> 3); request = var->xres_virtual * (var->bits_per_pixel >> 3);
/* defaulty crtc->channel go with par->index */ /* defaulty crtc->channel go with par->index */
request = PADDING(crtc->line_pad,request); request = PADDING(crtc->line_pad, request);
request = request * var->yres_virtual; request = request * var->yres_virtual;
if(crtc->vidmem_size < request){ if(crtc->vidmem_size < request){
pr_err("not enough video memory for mode\n"); pr_err("not enough video memory for mode\n");
return -ENOMEM; return -ENOMEM;
} }
ret = output->proc_checkMode(output,var); ret = output->proc_checkMode(output, var);
if(!ret) if(!ret)
ret = crtc->proc_checkMode(crtc,var); ret = crtc->proc_checkMode(crtc, var);
exit: exit:
return ret; return ret;
} }
static int lynxfb_ops_setcolreg(unsigned regno,unsigned red, static int lynxfb_ops_setcolreg(unsigned regno, unsigned red,
unsigned green,unsigned blue, unsigned green, unsigned blue,
unsigned transp,struct fb_info * info) unsigned transp, struct fb_info * info)
{ {
struct lynxfb_par * par; struct lynxfb_par * par;
struct lynxfb_crtc * crtc; struct lynxfb_crtc * crtc;
@ -623,7 +623,7 @@ static int lynxfb_ops_setcolreg(unsigned regno,unsigned red,
//pr_debug("regno=%d,red=%d,green=%d,blue=%d\n",regno,red,green,blue); //pr_debug("regno=%d,red=%d,green=%d,blue=%d\n",regno,red,green,blue);
if(regno > 256){ if(regno > 256){
pr_err("regno = %d\n",regno); pr_err("regno = %d\n", regno);
return -EINVAL; return -EINVAL;
} }
@ -635,7 +635,7 @@ static int lynxfb_ops_setcolreg(unsigned regno,unsigned red,
red >>= 8; red >>= 8;
green >>= 8; green >>= 8;
blue >>= 8; blue >>= 8;
ret = crtc->proc_setColReg(crtc,regno,red,green,blue); ret = crtc->proc_setColReg(crtc, regno, red, green, blue);
goto exit; goto exit;
} }
@ -647,9 +647,9 @@ static int lynxfb_ops_setcolreg(unsigned regno,unsigned red,
var->bits_per_pixel == 32 || var->bits_per_pixel == 32 ||
var->bits_per_pixel == 24) var->bits_per_pixel == 24)
{ {
val = chan_to_field(red,&var->red); val = chan_to_field(red, &var->red);
val |= chan_to_field(green,&var->green); val |= chan_to_field(green, &var->green);
val |= chan_to_field(blue,&var->blue); val |= chan_to_field(blue, &var->blue);
par->pseudo_palette[regno] = val; par->pseudo_palette[regno] = val;
goto exit; goto exit;
} }
@ -661,15 +661,15 @@ exit:
return ret; return ret;
} }
static int lynxfb_ops_blank(int blank,struct fb_info* info) static int lynxfb_ops_blank(int blank, struct fb_info* info)
{ {
struct lynxfb_par * par; struct lynxfb_par * par;
struct lynxfb_output * output; struct lynxfb_output * output;
pr_debug("blank = %d.\n",blank); pr_debug("blank = %d.\n", blank);
par = info->par; par = info->par;
output = &par->output; output = &par->output;
return output->proc_setBLANK(output,blank); return output->proc_setBLANK(output, blank);
} }
static int sm750fb_set_drv(struct lynxfb_par * par) static int sm750fb_set_drv(struct lynxfb_par * par)
@ -683,7 +683,7 @@ static int sm750fb_set_drv(struct lynxfb_par * par)
ret = 0; ret = 0;
share = par->share; share = par->share;
spec_share = container_of(share,struct sm750_share,share); spec_share = container_of(share, struct sm750_share, share);
output = &par->output; output = &par->output;
crtc = &par->crtc; crtc = &par->crtc;
@ -773,7 +773,7 @@ static struct fb_ops lynxfb_ops={
}; };
static int lynxfb_set_fbinfo(struct fb_info* info,int index) static int lynxfb_set_fbinfo(struct fb_info* info, int index)
{ {
int i; int i;
struct lynxfb_par * par; struct lynxfb_par * par;
@ -784,9 +784,9 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
struct fb_fix_screeninfo * fix; struct fb_fix_screeninfo * fix;
const struct fb_videomode * pdb[] = { const struct fb_videomode * pdb[] = {
lynx750_ext, NULL,vesa_modes, lynx750_ext, NULL, vesa_modes,
}; };
int cdb[] = {ARRAY_SIZE(lynx750_ext),0,VESA_MODEDB_SIZE}; int cdb[] = {ARRAY_SIZE(lynx750_ext), 0, VESA_MODEDB_SIZE};
static const char * mdb_desc[] ={ static const char * mdb_desc[] ={
"driver prepared modes", "driver prepared modes",
"kernel prepared default modedb", "kernel prepared default modedb",
@ -796,10 +796,10 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
static const char * fixId[2]= static const char * fixId[2]=
{ {
"sm750_fb1","sm750_fb2", "sm750_fb1", "sm750_fb2",
}; };
int ret,line_length; int ret, line_length;
ret = 0; ret = 0;
par = (struct lynxfb_par *)info->par; par = (struct lynxfb_par *)info->par;
@ -821,7 +821,7 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
crtc->cursor.offset = crtc->oScreen + crtc->vidmem_size - 1024; crtc->cursor.offset = crtc->oScreen + crtc->vidmem_size - 1024;
crtc->cursor.mmio = share->pvReg + 0x800f0 + (int)crtc->channel * 0x140; crtc->cursor.mmio = share->pvReg + 0x800f0 + (int)crtc->channel * 0x140;
pr_info("crtc->cursor.mmio = %p\n",crtc->cursor.mmio); pr_info("crtc->cursor.mmio = %p\n", crtc->cursor.mmio);
crtc->cursor.maxH = crtc->cursor.maxW = 64; crtc->cursor.maxH = crtc->cursor.maxW = 64;
crtc->cursor.size = crtc->cursor.maxH*crtc->cursor.maxW*2/8; crtc->cursor.size = crtc->cursor.maxH*crtc->cursor.maxW*2/8;
crtc->cursor.disable = hw_cursor_disable; crtc->cursor.disable = hw_cursor_disable;
@ -859,8 +859,8 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
for(i=0;i<3;i++){ for(i=0;i<3;i++){
ret = fb_find_mode(var,info,g_fbmode[index], ret = fb_find_mode(var, info, g_fbmode[index],
pdb[i],cdb[i],NULL,8); pdb[i], cdb[i], NULL, 8);
if(ret == 1){ if(ret == 1){
pr_info("success! use specified mode:%s in %s\n", pr_info("success! use specified mode:%s in %s\n",
@ -878,7 +878,7 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
}else if(ret == 4){ }else if(ret == 4){
pr_warn("fall back to any valid mode\n"); pr_warn("fall back to any valid mode\n");
}else{ }else{
pr_warn("ret = %d,fb_find_mode failed,with %s\n",ret,mdb_desc[i]); pr_warn("ret = %d,fb_find_mode failed,with %s\n", ret, mdb_desc[i]);
} }
} }
@ -892,8 +892,8 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
xoffset=%d\n\ xoffset=%d\n\
yoffset=%d\n\ yoffset=%d\n\
bits_per_pixel=%d\n \ bits_per_pixel=%d\n \
...\n",var->xres,var->yres,var->xres_virtual,var->yres_virtual, ...\n", var->xres, var->yres, var->xres_virtual, var->yres_virtual,
var->xoffset,var->yoffset,var->bits_per_pixel); var->xoffset, var->yoffset, var->bits_per_pixel);
/* set par */ /* set par */
par->info = info; par->info = info;
@ -904,7 +904,7 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
info->pseudo_palette = &par->pseudo_palette[0]; info->pseudo_palette = &par->pseudo_palette[0];
info->screen_base = crtc->vScreen; info->screen_base = crtc->vScreen;
pr_debug("screen_base vaddr = %p\n",info->screen_base); pr_debug("screen_base vaddr = %p\n", info->screen_base);
info->screen_size = line_length * var->yres_virtual; info->screen_size = line_length * var->yres_virtual;
info->flags = FBINFO_FLAG_DEFAULT|0; info->flags = FBINFO_FLAG_DEFAULT|0;
@ -916,11 +916,11 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
fix->ywrapstep = crtc->ywrapstep; fix->ywrapstep = crtc->ywrapstep;
fix->accel = FB_ACCEL_SMI; fix->accel = FB_ACCEL_SMI;
strlcpy(fix->id,fixId[index],sizeof(fix->id)); strlcpy(fix->id, fixId[index], sizeof(fix->id));
fix->smem_start = crtc->oScreen + share->vidmem_start; fix->smem_start = crtc->oScreen + share->vidmem_start;
pr_info("fix->smem_start = %lx\n",fix->smem_start); pr_info("fix->smem_start = %lx\n", fix->smem_start);
/* according to mmap experiment from user space application, /* according to mmap experiment from user space application,
* fix->mmio_len should not larger than virtual size * fix->mmio_len should not larger than virtual size
* (xres_virtual x yres_virtual x ByPP) * (xres_virtual x yres_virtual x ByPP)
@ -928,13 +928,13 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
* data into the bound over virtual size * data into the bound over virtual size
* */ * */
fix->smem_len = crtc->vidmem_size; fix->smem_len = crtc->vidmem_size;
pr_info("fix->smem_len = %x\n",fix->smem_len); pr_info("fix->smem_len = %x\n", fix->smem_len);
info->screen_size = fix->smem_len; info->screen_size = fix->smem_len;
fix->line_length = line_length; fix->line_length = line_length;
fix->mmio_start = share->vidreg_start; fix->mmio_start = share->vidreg_start;
pr_info("fix->mmio_start = %lx\n",fix->mmio_start); pr_info("fix->mmio_start = %lx\n", fix->mmio_start);
fix->mmio_len = share->vidreg_size; fix->mmio_len = share->vidreg_size;
pr_info("fix->mmio_len = %x\n",fix->mmio_len); pr_info("fix->mmio_len = %x\n", fix->mmio_len);
switch(var->bits_per_pixel) switch(var->bits_per_pixel)
{ {
case 8: case 8:
@ -952,28 +952,28 @@ static int lynxfb_set_fbinfo(struct fb_info* info,int index)
var->vmode = FB_VMODE_NONINTERLACED; var->vmode = FB_VMODE_NONINTERLACED;
pr_debug("#1 show info->cmap : \nstart=%d,len=%d,red=%p,green=%p,blue=%p,transp=%p\n", pr_debug("#1 show info->cmap : \nstart=%d,len=%d,red=%p,green=%p,blue=%p,transp=%p\n",
info->cmap.start,info->cmap.len, info->cmap.start, info->cmap.len,
info->cmap.red,info->cmap.green,info->cmap.blue, info->cmap.red, info->cmap.green, info->cmap.blue,
info->cmap.transp); info->cmap.transp);
if((ret = fb_alloc_cmap(&info->cmap,256,0)) < 0){ if((ret = fb_alloc_cmap(&info->cmap, 256, 0)) < 0){
pr_err("Could not allcate memory for cmap.\n"); pr_err("Could not allcate memory for cmap.\n");
goto exit; goto exit;
} }
pr_debug("#2 show info->cmap : \nstart=%d,len=%d,red=%p,green=%p,blue=%p,transp=%p\n", pr_debug("#2 show info->cmap : \nstart=%d,len=%d,red=%p,green=%p,blue=%p,transp=%p\n",
info->cmap.start,info->cmap.len, info->cmap.start, info->cmap.len,
info->cmap.red,info->cmap.green,info->cmap.blue, info->cmap.red, info->cmap.green, info->cmap.blue,
info->cmap.transp); info->cmap.transp);
exit: exit:
lynxfb_ops_check_var(var,info); lynxfb_ops_check_var(var, info);
// lynxfb_ops_set_par(info); // lynxfb_ops_set_par(info);
return ret; return ret;
} }
/* chip specific g_option configuration routine */ /* chip specific g_option configuration routine */
static void sm750fb_setup(struct lynx_share * share,char * src) static void sm750fb_setup(struct lynx_share * share, char * src)
{ {
struct sm750_share * spec_share; struct sm750_share * spec_share;
char * opt; char * opt;
@ -983,7 +983,7 @@ static void sm750fb_setup(struct lynx_share * share,char * src)
int swap; int swap;
spec_share = container_of(share,struct sm750_share,share); spec_share = container_of(share, struct sm750_share, share);
#ifdef CAP_EXPENSIION #ifdef CAP_EXPENSIION
exp_res = NULL; exp_res = NULL;
#endif #endif
@ -1004,45 +1004,45 @@ static void sm750fb_setup(struct lynx_share * share,char * src)
goto NO_PARAM; goto NO_PARAM;
} }
while((opt = strsep(&src,":")) != NULL && *opt != 0){ while((opt = strsep(&src, ":")) != NULL && *opt != 0){
pr_err("opt=%s\n",opt); pr_err("opt=%s\n", opt);
pr_err("src=%s\n",src); pr_err("src=%s\n", src);
if(!strncmp(opt,"swap",strlen("swap"))) if(!strncmp(opt, "swap", strlen("swap")))
swap = 1; swap = 1;
else if(!strncmp(opt,"nocrt",strlen("nocrt"))) else if(!strncmp(opt, "nocrt", strlen("nocrt")))
spec_share->state.nocrt = 1; spec_share->state.nocrt = 1;
else if(!strncmp(opt,"36bit",strlen("36bit"))) else if(!strncmp(opt, "36bit", strlen("36bit")))
spec_share->state.pnltype = sm750_doubleTFT; spec_share->state.pnltype = sm750_doubleTFT;
else if(!strncmp(opt,"18bit",strlen("18bit"))) else if(!strncmp(opt, "18bit", strlen("18bit")))
spec_share->state.pnltype = sm750_dualTFT; spec_share->state.pnltype = sm750_dualTFT;
else if(!strncmp(opt,"24bit",strlen("24bit"))) else if(!strncmp(opt, "24bit", strlen("24bit")))
spec_share->state.pnltype = sm750_24TFT; spec_share->state.pnltype = sm750_24TFT;
#ifdef CAP_EXPANSION #ifdef CAP_EXPANSION
else if(!strncmp(opt,"exp:",strlen("exp:"))) else if(!strncmp(opt, "exp:", strlen("exp:")))
exp_res = opt + strlen("exp:"); exp_res = opt + strlen("exp:");
#endif #endif
else if(!strncmp(opt,"nohwc0",strlen("nohwc0"))) else if(!strncmp(opt, "nohwc0", strlen("nohwc0")))
g_hwcursor &= ~0x1; g_hwcursor &= ~0x1;
else if(!strncmp(opt,"nohwc1",strlen("nohwc1"))) else if(!strncmp(opt, "nohwc1", strlen("nohwc1")))
g_hwcursor &= ~0x2; g_hwcursor &= ~0x2;
else if(!strncmp(opt,"nohwc",strlen("nohwc"))) else if(!strncmp(opt, "nohwc", strlen("nohwc")))
g_hwcursor = 0; g_hwcursor = 0;
else else
{ {
if(!g_fbmode[0]){ if(!g_fbmode[0]){
g_fbmode[0] = opt; g_fbmode[0] = opt;
pr_info("find fbmode0 : %s\n",g_fbmode[0]); pr_info("find fbmode0 : %s\n", g_fbmode[0]);
}else if(!g_fbmode[1]){ }else if(!g_fbmode[1]){
g_fbmode[1] = opt; g_fbmode[1] = opt;
pr_info("find fbmode1 : %s\n",g_fbmode[1]); pr_info("find fbmode1 : %s\n", g_fbmode[1]);
}else{ }else{
pr_warn("How many view you wann set?\n"); pr_warn("How many view you wann set?\n");
} }
} }
} }
#ifdef CAP_EXPANSION #ifdef CAP_EXPANSION
if(getExpRes(exp_res,&spec_share->state.xLCD,&spec_share->state.yLCD)) if(getExpRes(exp_res, &spec_share->state.xLCD, &spec_share->state.yLCD))
{ {
/* seems exp_res is not valid*/ /* seems exp_res is not valid*/
spec_share->state.xLCD = spec_share->state.yLCD = 0; spec_share->state.xLCD = spec_share->state.yLCD = 0;
@ -1074,7 +1074,7 @@ NO_PARAM:
static int lynxfb_pci_probe(struct pci_dev * pdev, static int lynxfb_pci_probe(struct pci_dev * pdev,
const struct pci_device_id * ent) const struct pci_device_id * ent)
{ {
struct fb_info * info[] = {NULL,NULL}; struct fb_info * info[] = {NULL, NULL};
struct lynx_share * share = NULL; struct lynx_share * share = NULL;
struct sm750_share *spec_share = NULL; struct sm750_share *spec_share = NULL;
@ -1090,9 +1090,9 @@ static int lynxfb_pci_probe(struct pci_dev * pdev,
/* though offset of share in sm750_share is 0, /* though offset of share in sm750_share is 0,
* we use this marcro as the same */ * we use this marcro as the same */
spec_offset = offsetof(struct sm750_share,share); spec_offset = offsetof(struct sm750_share, share);
spec_share = kzalloc(sizeof(*spec_share),GFP_KERNEL); spec_share = kzalloc(sizeof(*spec_share), GFP_KERNEL);
if(!spec_share){ if(!spec_share){
pr_err("Could not allocate memory for share.\n"); pr_err("Could not allocate memory for share.\n");
goto err_share; goto err_share;
@ -1104,7 +1104,7 @@ static int lynxfb_pci_probe(struct pci_dev * pdev,
share->devid = pdev->device; share->devid = pdev->device;
share->revid = pdev->revision; share->revid = pdev->revision;
pr_info("share->revid = %02x\n",share->revid); pr_info("share->revid = %02x\n", share->revid);
share->pdev = pdev; share->pdev = pdev;
#ifdef CONFIG_MTRR #ifdef CONFIG_MTRR
share->mtrr_off = g_nomtrr; share->mtrr_off = g_nomtrr;
@ -1130,10 +1130,10 @@ static int lynxfb_pci_probe(struct pci_dev * pdev,
} }
/* call chip specific setup routine */ /* call chip specific setup routine */
sm750fb_setup(share,g_settings); sm750fb_setup(share, g_settings);
/* call chip specific mmap routine */ /* call chip specific mmap routine */
if(hw_sm750_map(share,pdev)){ if(hw_sm750_map(share, pdev)){
pr_err("Memory map failed\n"); pr_err("Memory map failed\n");
goto err_map; goto err_map;
} }
@ -1143,7 +1143,7 @@ static int lynxfb_pci_probe(struct pci_dev * pdev,
pr_info("enable mtrr\n"); pr_info("enable mtrr\n");
share->mtrr.vram = mtrr_add(share->vidmem_start, share->mtrr.vram = mtrr_add(share->vidmem_start,
share->vidmem_size, share->vidmem_size,
MTRR_TYPE_WRCOMB,1); MTRR_TYPE_WRCOMB, 1);
if(share->mtrr.vram < 0){ if(share->mtrr.vram < 0){
/* don't block driver with the failure of MTRR */ /* don't block driver with the failure of MTRR */
@ -1157,20 +1157,20 @@ static int lynxfb_pci_probe(struct pci_dev * pdev,
memset_io(share->pvMem, 0, share->vidmem_size); memset_io(share->pvMem, 0, share->vidmem_size);
pr_info("sm%3x mmio address = %p\n",share->devid,share->pvReg); pr_info("sm%3x mmio address = %p\n", share->devid, share->pvReg);
pci_set_drvdata(pdev,share); pci_set_drvdata(pdev, share);
/* call chipInit routine */ /* call chipInit routine */
hw_sm750_inithw(share,pdev); hw_sm750_inithw(share, pdev);
/* allocate frame buffer info structor according to g_dualview */ /* allocate frame buffer info structor according to g_dualview */
fbidx = 0; fbidx = 0;
ALLOC_FB: ALLOC_FB:
info[fbidx] = framebuffer_alloc(sizeof(struct lynxfb_par),&pdev->dev); info[fbidx] = framebuffer_alloc(sizeof(struct lynxfb_par), &pdev->dev);
if(!info[fbidx]) if(!info[fbidx])
{ {
pr_err("Could not allocate framebuffer #%d.\n",fbidx); pr_err("Could not allocate framebuffer #%d.\n", fbidx);
if(fbidx == 0) if(fbidx == 0)
goto err_info0_alloc; goto err_info0_alloc;
else else
@ -1180,14 +1180,14 @@ ALLOC_FB:
{ {
struct lynxfb_par * par; struct lynxfb_par * par;
int errno; int errno;
pr_info("framebuffer #%d alloc okay\n",fbidx); pr_info("framebuffer #%d alloc okay\n", fbidx);
share->fbinfo[fbidx] = info[fbidx]; share->fbinfo[fbidx] = info[fbidx];
par = info[fbidx]->par; par = info[fbidx]->par;
par->share = share; par->share = share;
/* set fb_info structure */ /* set fb_info structure */
if(lynxfb_set_fbinfo(info[fbidx],fbidx)){ if(lynxfb_set_fbinfo(info[fbidx], fbidx)){
pr_err("Failed to initial fb_info #%d.\n",fbidx); pr_err("Failed to initial fb_info #%d.\n", fbidx);
if(fbidx == 0) if(fbidx == 0)
goto err_info0_set; goto err_info0_set;
else else
@ -1195,16 +1195,16 @@ ALLOC_FB:
} }
/* register frame buffer*/ /* register frame buffer*/
pr_info("Ready to register framebuffer #%d.\n",fbidx); pr_info("Ready to register framebuffer #%d.\n", fbidx);
errno = register_framebuffer(info[fbidx]); errno = register_framebuffer(info[fbidx]);
if (errno < 0) { if (errno < 0) {
pr_err("Failed to register fb_info #%d. err %d\n",fbidx, errno); pr_err("Failed to register fb_info #%d. err %d\n", fbidx, errno);
if(fbidx == 0) if(fbidx == 0)
goto err_register0; goto err_register0;
else else
goto err_register1; goto err_register1;
} }
pr_info("Accomplished register framebuffer #%d.\n",fbidx); pr_info("Accomplished register framebuffer #%d.\n", fbidx);
} }
/* no dual view by far */ /* no dual view by far */
@ -1256,16 +1256,16 @@ static void __exit lynxfb_pci_remove(struct pci_dev * pdev)
} }
#ifdef CONFIG_MTRR #ifdef CONFIG_MTRR
if(share->mtrr.vram_added) if(share->mtrr.vram_added)
mtrr_del(share->mtrr.vram,share->vidmem_start,share->vidmem_size); mtrr_del(share->mtrr.vram, share->vidmem_start, share->vidmem_size);
#endif #endif
// pci_release_regions(pdev); // pci_release_regions(pdev);
iounmap(share->pvReg); iounmap(share->pvReg);
iounmap(share->pvMem); iounmap(share->pvMem);
spec_share = container_of(share,struct sm750_share,share); spec_share = container_of(share, struct sm750_share, share);
kfree(g_settings); kfree(g_settings);
kfree(spec_share); kfree(spec_share);
pci_set_drvdata(pdev,NULL); pci_set_drvdata(pdev, NULL);
} }
static int __init lynxfb_setup(char * options) static int __init lynxfb_setup(char * options)
@ -1279,7 +1279,7 @@ static int __init lynxfb_setup(char * options)
return 0; return 0;
} }
pr_info("options:%s\n",options); pr_info("options:%s\n", options);
len = strlen(options) + 1; len = strlen(options) + 1;
g_settings = kzalloc(len, GFP_KERNEL); g_settings = kzalloc(len, GFP_KERNEL);
@ -1296,20 +1296,20 @@ static int __init lynxfb_setup(char * options)
strsep() updates @options to pointer after the first found token strsep() updates @options to pointer after the first found token
it also returns the pointer ahead the token. it also returns the pointer ahead the token.
*/ */
while((opt = strsep(&options,":"))!=NULL) while((opt = strsep(&options, ":"))!=NULL)
{ {
/* options that mean for any lynx chips are configured here */ /* options that mean for any lynx chips are configured here */
if(!strncmp(opt,"noaccel",strlen("noaccel"))) if(!strncmp(opt, "noaccel", strlen("noaccel")))
g_noaccel = 1; g_noaccel = 1;
#ifdef CONFIG_MTRR #ifdef CONFIG_MTRR
else if(!strncmp(opt,"nomtrr",strlen("nomtrr"))) else if(!strncmp(opt, "nomtrr", strlen("nomtrr")))
g_nomtrr = 1; g_nomtrr = 1;
#endif #endif
else if(!strncmp(opt,"dual",strlen("dual"))) else if(!strncmp(opt, "dual", strlen("dual")))
g_dualview = 1; g_dualview = 1;
else else
{ {
strcat(tmp,opt); strcat(tmp, opt);
tmp += strlen(opt); tmp += strlen(opt);
if(options != NULL) if(options != NULL)
*tmp++ = ':'; *tmp++ = ':';
@ -1319,7 +1319,7 @@ static int __init lynxfb_setup(char * options)
} }
/* misc g_settings are transport to chip specific routines */ /* misc g_settings are transport to chip specific routines */
pr_info("parameter left for chip specific analysis:%s\n",g_settings); pr_info("parameter left for chip specific analysis:%s\n", g_settings);
return 0; return 0;
} }
@ -1328,7 +1328,7 @@ static struct pci_device_id smi_pci_table[] = {
{0,} {0,}
}; };
MODULE_DEVICE_TABLE(pci,smi_pci_table); MODULE_DEVICE_TABLE(pci, smi_pci_table);
static struct pci_driver lynxfb_driver = { static struct pci_driver lynxfb_driver = {
.name = "sm750fb", .name = "sm750fb",
@ -1350,7 +1350,7 @@ static int __init lynxfb_init(void)
#ifdef MODULE #ifdef MODULE
option = g_option; option = g_option;
#else #else
if(fb_get_options("sm750fb",&option)) if(fb_get_options("sm750fb", &option))
return -ENODEV; return -ENODEV;
#endif #endif
@ -1366,7 +1366,7 @@ static void __exit lynxfb_exit(void)
} }
module_exit(lynxfb_exit); module_exit(lynxfb_exit);
module_param(g_option,charp,S_IRUGO); module_param(g_option, charp, S_IRUGO);
MODULE_PARM_DESC(g_option, MODULE_PARM_DESC(g_option,
"\n\t\tCommon options:\n" "\n\t\tCommon options:\n"