Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 105499
b: refs/heads/master
c: d9cad04
h: refs/heads/master
i:
  105497: b121b9a
  105495: b4839e9
v: v3
  • Loading branch information
Krzysztof Helt authored and Linus Torvalds committed Jul 24, 2008
1 parent 7360ab3 commit 46e055c
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 40 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: e0759a5fbba12e0f2c9149d85bea1ec7df0178fd
refs/heads/master: d9cad04bcde00411976402eda726199ac13b29ca
63 changes: 24 additions & 39 deletions trunk/drivers/video/tridentfb.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,12 @@ struct tridentfb_par {
u32 pseudo_pal[16];
int chip_id;
int flatpanel;
void (*init_accel) (struct tridentfb_par *, int, int);
void (*wait_engine) (struct tridentfb_par *);
void (*fill_rect)
(struct tridentfb_par *par, u32, u32, u32, u32, u32, u32);
void (*copy_rect)
(struct tridentfb_par *par, u32, u32, u32, u32, u32, u32);
};

static unsigned char eng_oper; /* engine operation... */
Expand Down Expand Up @@ -155,15 +161,6 @@ static inline u8 t_inb(struct tridentfb_par *p, u16 reg)
return fb_readb(p->io_virt + reg);
}

static struct accel_switch {
void (*init_accel) (struct tridentfb_par *, int, int);
void (*wait_engine) (struct tridentfb_par *);
void (*fill_rect)
(struct tridentfb_par *par, u32, u32, u32, u32, u32, u32);
void (*copy_rect)
(struct tridentfb_par *par, u32, u32, u32, u32, u32, u32);
} *acc;

static inline void writemmr(struct tridentfb_par *par, u16 r, u32 v)
{
fb_writel(v, par->io_virt + r);
Expand Down Expand Up @@ -259,13 +256,6 @@ static void blade_copy_rect(struct tridentfb_par *par,
writemmr(par, DR2, direction ? d1 : d2);
}

static struct accel_switch accel_blade = {
blade_init_accel,
blade_wait_engine,
blade_fill_rect,
blade_copy_rect,
};

/*
* BladeXP specific acceleration functions
*/
Expand Down Expand Up @@ -405,13 +395,6 @@ static void xp_copy_rect(struct tridentfb_par *par,
t_outb(par, 0x01, 0x2124);
}

static struct accel_switch accel_xp = {
xp_init_accel,
xp_wait_engine,
xp_fill_rect,
xp_copy_rect,
};

/*
* Image specific acceleration functions
*/
Expand Down Expand Up @@ -491,13 +474,6 @@ static void image_copy_rect(struct tridentfb_par *par,
0x80000000 | 1 << 22 | 1 << 10 | 1 << 7 | direction);
}

static struct accel_switch accel_image = {
image_init_accel,
image_wait_engine,
image_fill_rect,
image_copy_rect,
};

/*
* Accel functions called by the upper layers
*/
Expand All @@ -524,18 +500,18 @@ static void tridentfb_fillrect(struct fb_info *info,
break;
}

acc->fill_rect(par, fr->dx, fr->dy, fr->width,
par->fill_rect(par, fr->dx, fr->dy, fr->width,
fr->height, col, fr->rop);
acc->wait_engine(par);
par->wait_engine(par);
}
static void tridentfb_copyarea(struct fb_info *info,
const struct fb_copyarea *ca)
{
struct tridentfb_par *par = info->par;

acc->copy_rect(par, ca->sx, ca->sy, ca->dx, ca->dy,
par->copy_rect(par, ca->sx, ca->sy, ca->dx, ca->dy,
ca->width, ca->height);
acc->wait_engine(par);
par->wait_engine(par);
}
#else /* !CONFIG_FB_TRIDENT_ACCEL */
#define tridentfb_fillrect cfb_fillrect
Expand Down Expand Up @@ -1029,7 +1005,7 @@ static int tridentfb_set_par(struct fb_info *info)
write3X4(par, GraphEngReg, 0x80);

#ifdef CONFIG_FB_TRIDENT_ACCEL
acc->init_accel(par, info->var.xres, bpp);
par->init_accel(par, info->var.xres, bpp);
#endif

switch (bpp) {
Expand Down Expand Up @@ -1290,11 +1266,20 @@ static int __devinit trident_pci_probe(struct pci_dev *dev,
chip3D = is3Dchip(chip_id);

if (is_xp(chip_id)) {
acc = &accel_xp;
default_par->init_accel = xp_init_accel;
default_par->wait_engine = xp_wait_engine;
default_par->fill_rect = xp_fill_rect;
default_par->copy_rect = xp_copy_rect;
} else if (is_blade(chip_id)) {
acc = &accel_blade;
default_par->init_accel = blade_init_accel;
default_par->wait_engine = blade_wait_engine;
default_par->fill_rect = blade_fill_rect;
default_par->copy_rect = blade_copy_rect;
} else {
acc = &accel_image;
default_par->init_accel = image_init_accel;
default_par->wait_engine = image_wait_engine;
default_par->fill_rect = image_fill_rect;
default_par->copy_rect = image_copy_rect;
}

default_par->chip_id = chip_id;
Expand Down Expand Up @@ -1365,7 +1350,7 @@ static int __devinit trident_pci_probe(struct pci_dev *dev,
if (err < 0)
goto out_unmap2;

if (defaultaccel && acc)
if (defaultaccel && default_par->init_accel)
info->var.accel_flags |= FB_ACCELF_TEXT;
else
info->var.accel_flags &= ~FB_ACCELF_TEXT;
Expand Down

0 comments on commit 46e055c

Please sign in to comment.