Commit 26ce92c6 authored by James Simmons's avatar James Simmons

[FBDEV] Accelerated functions pass in const structs.

[ATY128 FBDEV] Gcc compile issue fixes.
parent 1ea48bea
......@@ -1799,6 +1799,7 @@ static void * __init aty128_map_ROM(struct pci_dev *dev)
// no need to search for the ROM, just ask the card where it is.
struct resource *r = &dev->resource[PCI_ROM_RESOURCE];
unsigned char *addr;
// assign the ROM an address if it doesn't have one
if (r->start == 0)
......@@ -1808,7 +1809,7 @@ static void * __init aty128_map_ROM(struct pci_dev *dev)
if (!(r->flags & PCI_ROM_ADDRESS_ENABLE))
pci_write_config_dword(dev, dev->rom_base_reg, r->start | PCI_ROM_ADDRESS_ENABLE);
unsigned char *addr = ioremap(r->start, r->end - r->start + 1);
addr = ioremap(r->start, r->end - r->start + 1);
// Very simple test to make sure it appeared
if (addr && (*addr != 0x55)) {
......@@ -1821,15 +1822,15 @@ static void * __init aty128_map_ROM(struct pci_dev *dev)
static void __init aty128_unmap_ROM(struct pci_dev *dev, void * rom)
{
iounmap(rom);
// leave it disabled and unassigned
struct resource *r = &dev->resource[PCI_ROM_RESOURCE];
iounmap(rom);
r->flags &= !PCI_ROM_ADDRESS_ENABLE;
r->end -= r->start;
r->start = 0;
pci_write_config_dword(dev, dev->rom_base_reg, 0);
}
static void __init
......
......@@ -35,8 +35,8 @@ static int cg6_setcolreg(unsigned, unsigned, unsigned, unsigned,
unsigned, struct fb_info *);
static int cg6_blank(int, struct fb_info *);
static void cg6_imageblit(struct fb_info *, struct fb_image *);
static void cg6_fillrect(struct fb_info *, struct fb_fillrect *);
static void cg6_imageblit(struct fb_info *, const struct fb_image *);
static void cg6_fillrect(struct fb_info *, const struct fb_fillrect *);
static int cg6_sync(struct fb_info *);
static int cg6_mmap(struct fb_info *, struct file *, struct vm_area_struct *);
......@@ -290,7 +290,7 @@ static int cg6_sync(struct fb_info *info)
* @info: frame buffer structure that represents a single frame buffer
* @rect: structure defining the rectagle and operation.
*/
static void cg6_fillrect(struct fb_info *info, struct fb_fillrect *rect)
static void cg6_fillrect(struct fb_info *info, const struct fb_fillrect *rect)
{
struct cg6_par *par = (struct cg6_par *) info->par;
struct cg6_fbc *fbc = par->fbc;
......@@ -325,7 +325,7 @@ static void cg6_fillrect(struct fb_info *info, struct fb_fillrect *rect)
* @info: frame buffer structure that represents a single frame buffer
* @image: structure defining the image.
*/
static void cg6_imageblit(struct fb_info *info, struct fb_image *image)
static void cg6_imageblit(struct fb_info *info, const struct fb_image *image)
{
struct cg6_par *par = (struct cg6_par *) info->par;
struct cg6_fbc *fbc = par->fbc;
......
......@@ -113,7 +113,7 @@ static struct fb_info fb_info;
/* frame buffer operations */
static int dnfb_blank(int blank, struct fb_info *info);
static void dnfb_copyarea(struct fb_info *info, struct fb_copyarea *area);
static void dnfb_copyarea(struct fb_info *info, const struct fb_copyarea *area);
static struct fb_ops dn_fb_ops = {
.owner = THIS_MODULE,
......@@ -154,18 +154,17 @@ static int dnfb_blank(int blank, struct fb_info *info)
}
static
void dnfb_copyarea(struct fb_info *info, struct fb_copyarea *area)
void dnfb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
int incr, y_delta, pre_read = 0, x_end, x_word_count;
ushort *src, dummy;
uint start_mask, end_mask, dest;
ushort *src, dummy;
short i, j;
incr = (area->dy <= area->sy) ? 1 : -1;
src =
(ushort *) (info->screen_base + area->sy * info->fix.line_length +
src = (ushort *)(info->screen_base + area->sy * info->fix.line_length +
(area->sx >> 4));
dest = area->dy * (info->fix.line_length >> 1) + (area->dx >> 4);
......
......@@ -34,9 +34,9 @@ static int ffb_setcolreg(unsigned, unsigned, unsigned, unsigned,
static int ffb_blank(int, struct fb_info *);
static void ffb_init_fix(struct fb_info *);
static void ffb_imageblit(struct fb_info *, struct fb_image *);
static void ffb_fillrect(struct fb_info *, struct fb_fillrect *);
static void ffb_copyarea(struct fb_info *, struct fb_copyarea *);
static void ffb_imageblit(struct fb_info *, const struct fb_image *);
static void ffb_fillrect(struct fb_info *, const struct fb_fillrect *);
static void ffb_copyarea(struct fb_info *, const struct fb_copyarea *);
static int ffb_sync(struct fb_info *);
static int ffb_mmap(struct fb_info *, struct file *, struct vm_area_struct *);
......@@ -491,7 +491,7 @@ static void ffb_switch_from_graph(struct ffb_par *par)
* @info: frame buffer structure that represents a single frame buffer
* @rect: structure defining the rectagle and operation.
*/
static void ffb_fillrect(struct fb_info *info, struct fb_fillrect *rect)
static void ffb_fillrect(struct fb_info *info, const struct fb_fillrect *rect)
{
struct ffb_par *par = (struct ffb_par *) info->par;
struct ffb_fbc *fbc = par->fbc;
......@@ -540,7 +540,7 @@ static void ffb_fillrect(struct fb_info *info, struct fb_fillrect *rect)
*/
static void
ffb_copyarea(struct fb_info *info, struct fb_copyarea *area)
ffb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
struct ffb_par *par = (struct ffb_par *) info->par;
struct ffb_fbc *fbc = par->fbc;
......@@ -576,7 +576,7 @@ ffb_copyarea(struct fb_info *info, struct fb_copyarea *area)
* @info: frame buffer structure that represents a single frame buffer
* @image: structure defining the image.
*/
static void ffb_imageblit(struct fb_info *info, struct fb_image *image)
static void ffb_imageblit(struct fb_info *info, const struct fb_image *image)
{
struct ffb_par *par = (struct ffb_par *) info->par;
struct ffb_fbc *fbc = par->fbc;
......
......@@ -468,7 +468,7 @@ static void hgafb_fillrect(struct fb_info *info, const struct fb_fillrect *rect)
}
}
static void hgafb_copyarea(struct fb_info *info, struct fb_copyarea *area)
static void hgafb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
u_int rows, y1, y2;
u8 *src, *dest;
......@@ -498,9 +498,9 @@ static void hgafb_copyarea(struct fb_info *info, struct fb_copyarea *area)
}
}
static void hgafb_imageblit(struct fb_info *info, struct fb_image *image)
static void hgafb_imageblit(struct fb_info *info, const struct fb_image *image)
{
u8 *dest, *cdat = image->data;
u8 *dest, *cdat = (u8 *) image->data;
u_int rows, y = image->dy;
u8 d;
......
......@@ -86,7 +86,7 @@ static int hpfb_setcolreg(unsigned regno, unsigned red, unsigned green,
return 0;
}
void hpfb_copyarea(struct fb_info *info, struct fb_copyarea *area)
void hpfb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
while (in_8(fb_regs + BUSY) & fb_bitmask);
out_8(fb_regs + WMRR, 0x3);
......
......@@ -1359,33 +1359,30 @@ neo2200_fillrect(struct fb_info *info, const struct fb_fillrect *rect)
}
static void
neo2200_copyarea(struct fb_info *info, struct fb_copyarea *area)
neo2200_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
struct neofb_par *par = (struct neofb_par *) info->par;
u32 sx = area->sx, sy = area->sy, dx = area->dx, dy = area->dy;
u_long src, dst, bltCntl;
bltCntl = NEO_BC3_FIFO_EN | NEO_BC3_SKIP_MAPPING | 0x0C0000;
if (area->sy < area->dy) {
area->sy += (area->height - 1);
area->dy += (area->height - 1);
if (sy < dy) {
sy += (area->height - 1);
dy += (area->height - 1);
bltCntl |= NEO_BC0_DST_Y_DEC | NEO_BC0_SRC_Y_DEC;
}
if (area->sx < area->dx) {
area->sx += (area->width - 1);
area->dx += (area->width - 1);
sx += (area->width - 1);
dx += (area->width - 1);
bltCntl |= NEO_BC0_X_DEC;
}
src =
area->sx * (info->var.bits_per_pixel >> 3) +
area->sy * info->fix.line_length;
dst =
area->dx * (info->var.bits_per_pixel >> 3) +
area->dy * info->fix.line_length;
src = sx * (info->var.bits_per_pixel >> 3) + sy*info->fix.line_length;
dst = dx * (info->var.bits_per_pixel >> 3) + dy*info->fix.line_length;
neo2200_wait_fifo(info, 4);
......@@ -1399,7 +1396,7 @@ neo2200_copyarea(struct fb_info *info, struct fb_copyarea *area)
}
static void
neo2200_imageblit(struct fb_info *info, struct fb_image *image)
neo2200_imageblit(struct fb_info *info, const struct fb_image *image)
{
struct neofb_par *par = (struct neofb_par *) info->par;
......@@ -1452,7 +1449,7 @@ neofb_fillrect(struct fb_info *info, const struct fb_fillrect *rect)
}
static void
neofb_copyarea(struct fb_info *info, struct fb_copyarea *area)
neofb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
switch (info->fix.accel) {
case FB_ACCEL_NEOMAGIC_NM2200:
......@@ -1468,7 +1465,7 @@ neofb_copyarea(struct fb_info *info, struct fb_copyarea *area)
}
static void
neofb_imageblit(struct fb_info *info, struct fb_image *image)
neofb_imageblit(struct fb_info *info, const struct fb_image *image)
{
switch (info->fix.accel) {
case FB_ACCEL_NEOMAGIC_NM2200:
......@@ -1483,7 +1480,7 @@ neofb_imageblit(struct fb_info *info, struct fb_image *image)
}
}
static void
static int
neofb_sync(struct fb_info *info)
{
switch (info->fix.accel) {
......@@ -1495,7 +1492,8 @@ neofb_sync(struct fb_info *info)
break;
default:
break;
}
}
return 0;
}
static struct fb_ops neofb_ops = {
......
......@@ -289,7 +289,7 @@ int sisfb_initaccel(void)
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,34) /* --- KERNEL 2.5.34 and later --- */
void fbcon_sis_fillrect(struct fb_info *info, struct fb_fillrect *rect)
void fbcon_sis_fillrect(struct fb_info *info, const struct fb_fillrect *rect)
{
CRITFLAGS
......@@ -312,7 +312,7 @@ void fbcon_sis_fillrect(struct fb_info *info, struct fb_fillrect *rect)
}
void fbcon_sis_copyarea(struct fb_info *info, struct fb_copyarea *area)
void fbcon_sis_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
int xdir, ydir;
CRITFLAGS
......
......@@ -833,7 +833,7 @@ static int sstfb_ioctl(struct inode *inode, struct file *file,
* Screen-to-Screen BitBlt 2D command (for the bmove fb op.) - Voodoo2 only
*/
#if 0
static void sstfb_copyarea(struct fb_info *info, struct fb_copyarea *area)
static void sstfb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
struct sstfb_par *par = (struct sstfb_par *) info->par;
u32 stride = info->fix.line_length;
......
......@@ -163,8 +163,8 @@ static int tdfxfb_setcolreg(u_int regno, u_int red, u_int green, u_int blue,
static int tdfxfb_blank(int blank, struct fb_info *info);
static int tdfxfb_pan_display(struct fb_var_screeninfo *var, struct fb_info *info);
static void tdfxfb_fillrect(struct fb_info *info, const struct fb_fillrect *rect);
static void tdfxfb_copyarea(struct fb_info *info, struct fb_copyarea *area);
static void tdfxfb_imageblit(struct fb_info *info, struct fb_image *image);
static void tdfxfb_copyarea(struct fb_info *info, const struct fb_copyarea *area);
static void tdfxfb_imageblit(struct fb_info *info, const struct fb_image *image);
static int tdfxfb_cursor(struct fb_info *info, struct fb_cursor *cursor);
static int banshee_wait_idle(struct fb_info *info);
......@@ -897,25 +897,26 @@ static void tdfxfb_fillrect(struct fb_info *info, const struct fb_fillrect *rect
/*
* Screen-to-Screen BitBlt 2D command (for the bmove fb op.)
*/
static void tdfxfb_copyarea(struct fb_info *info, struct fb_copyarea *area)
static void tdfxfb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
struct tdfx_par *par = (struct tdfx_par *) info->par;
u32 sx = area->sx, sy = area->sy, dx = area->dx, dy = area->dy;
u32 bpp = info->var.bits_per_pixel;
u32 stride = info->fix.line_length;
u32 blitcmd = COMMAND_2D_S2S_BITBLT | (TDFX_ROP_COPY << 24);
u32 fmt = stride | ((bpp+((bpp==8) ? 0 : 8)) << 13);
if (area->sx <= area->dx) {
//-X
blitcmd |= BIT(14);
area->sx += area->width - 1;
area->dx += area->width - 1;
sx += area->width - 1;
dx += area->width - 1;
}
if (area->sy <= area->dy) {
//-Y
blitcmd |= BIT(15);
area->sy += area->height - 1;
area->dy += area->height - 1;
sy += area->height - 1;
dy += area->height - 1;
}
banshee_make_room(par, 6);
......@@ -924,12 +925,12 @@ static void tdfxfb_copyarea(struct fb_info *info, struct fb_copyarea *area)
tdfx_outl(par, DSTFORMAT, fmt);
tdfx_outl(par, COMMAND_2D, blitcmd);
tdfx_outl(par, DSTSIZE, area->width | (area->height << 16));
tdfx_outl(par, DSTXY, area->dx | (area->dy << 16));
tdfx_outl(par, LAUNCH_2D, area->sx | (area->sy << 16));
tdfx_outl(par, DSTXY, dx | (dy << 16));
tdfx_outl(par, LAUNCH_2D, sx | (sy << 16));
banshee_wait_idle(info);
}
static void tdfxfb_imageblit(struct fb_info *info, struct fb_image *pixmap)
static void tdfxfb_imageblit(struct fb_info *info, const struct fb_image *pixmap)
{
struct tdfx_par *par = (struct tdfx_par *) info->par;
int size = pixmap->height*((pixmap->width*pixmap->depth + 7)>>3);
......@@ -1069,7 +1070,7 @@ static int tdfxfb_cursor(struct fb_info *info, struct fb_cursor *cursor)
* the two monochrome patterns.
*/
u8 *cursorbase = (u8 *) info->cursor.image.data;
char *bitmap = cursor->image.data;
char *bitmap = (char *)cursor->image.data;
char *mask = cursor->mask;
int i, j, k, h = 0;
......
......@@ -22,12 +22,10 @@
#include <linux/delay.h>
#include <linux/init.h>
#include <linux/fb.h>
#include <linux/selection.h>
#include <linux/pci.h>
#include <asm/io.h>
#include <video/tgafb.h>
/*
* Local functions.
*/
......@@ -40,9 +38,9 @@ static int tgafb_setcolreg(unsigned, unsigned, unsigned, unsigned,
static int tgafb_blank(int, struct fb_info *);
static void tgafb_init_fix(struct fb_info *);
static void tgafb_imageblit(struct fb_info *, struct fb_image *);
static void tgafb_fillrect(struct fb_info *, struct fb_fillrect *);
static void tgafb_copyarea(struct fb_info *, struct fb_copyarea *);
static void tgafb_imageblit(struct fb_info *, const struct fb_image *);
static void tgafb_fillrect(struct fb_info *, const struct fb_fillrect *);
static void tgafb_copyarea(struct fb_info *, const struct fb_copyarea *);
static int tgafb_pci_register(struct pci_dev *, const struct pci_device_id *);
#ifdef MODULE
......@@ -520,7 +518,7 @@ tgafb_blank(int blank, struct fb_info *info)
* @image: structure defining the image.
*/
static void
tgafb_imageblit(struct fb_info *info, struct fb_image *image)
tgafb_imageblit(struct fb_info *info, const struct fb_image *image)
{
static unsigned char const bitrev[256] = {
0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0,
......@@ -779,7 +777,7 @@ tgafb_imageblit(struct fb_info *info, struct fb_image *image)
* @rect: structure defining the rectagle and operation.
*/
static void
tgafb_fillrect(struct fb_info *info, struct fb_fillrect *rect)
tgafb_fillrect(struct fb_info *info, const struct fb_fillrect *rect)
{
struct tga_par *par = (struct tga_par *) info->par;
int is8bpp = info->var.bits_per_pixel == 8;
......@@ -1162,7 +1160,7 @@ copyarea_foreward_8bpp(struct fb_info *info, u32 dx, u32 dy, u32 sx, u32 sy,
static inline void
copyarea_backward_8bpp(struct fb_info *info, u32 dx, u32 dy, u32 sx, u32 sy,
u32 height, u32 width, u32 line_length,
struct fb_copyarea *area)
const struct fb_copyarea *area)
{
struct tga_par *par = (struct tga_par *) info->par;
unsigned long i, left, yincr;
......@@ -1261,7 +1259,7 @@ copyarea_backward_8bpp(struct fb_info *info, u32 dx, u32 dy, u32 sx, u32 sy,
}
static void
tgafb_copyarea(struct fb_info *info, struct fb_copyarea *area)
tgafb_copyarea(struct fb_info *info, const struct fb_copyarea *area)
{
unsigned long dx, dy, width, height, sx, sy, vxres, vyres;
unsigned long line_length, bpp;
......
......@@ -468,7 +468,7 @@ static void tridentfb_fillrect(struct fb_info * info, const struct fb_fillrect *
acc->fill_rect(fr->dx, fr->dy, fr->width, fr->height, col, fr->rop);
acc->wait_engine();
}
static void tridentfb_copyarea(struct fb_info *info, struct fb_copyarea *ca)
static void tridentfb_copyarea(struct fb_info *info, const struct fb_copyarea *ca)
{
acc->copy_rect(ca->sx,ca->sy,ca->dx,ca->dy,ca->width,ca->height);
acc->wait_engine();
......
......@@ -1165,7 +1165,7 @@ static unsigned int transl_l[] =
#endif
#endif
void vga_8planes_imageblit(struct fb_info *info, struct fb_image *image)
void vga_8planes_imageblit(struct fb_info *info, const struct fb_image *image)
{
char oldindex = getindex();
char oldmode = setmode(0x40);
......@@ -1196,7 +1196,7 @@ void vga_8planes_imageblit(struct fb_info *info, struct fb_image *image)
setindex(oldindex);
}
void vga_imageblit_expand(struct fb_info *info, struct fb_image *image)
void vga_imageblit_expand(struct fb_info *info, const struct fb_image *image)
{
char *where = info->screen_base + (image->dx/8) +
image->dy * info->fix.line_length;
......@@ -1259,7 +1259,7 @@ void vga_imageblit_expand(struct fb_info *info, struct fb_image *image)
}
}
void vga_imageblit_color(struct fb_info *info, struct fb_image *image)
void vga_imageblit_color(struct fb_info *info, const struct fb_image *image)
{
/*
* Draw logo
......@@ -1302,14 +1302,12 @@ void vga_imageblit_color(struct fb_info *info, struct fb_image *image)
}
}
void vga16fb_imageblit(struct fb_info *info, const struct fb_image *img)
void vga16fb_imageblit(struct fb_info *info, const struct fb_image *image)
{
struct fb_image image = *img;
if (image.depth == 0)
vga_imageblit_expand(info, &image);
else if (image.depth == info->var.bits_per_pixel)
vga_imageblit_color(info, &image);
if (image->depth == 0)
vga_imageblit_expand(info, image);
else if (image->depth == info->var.bits_per_pixel)
vga_imageblit_color(info, image);
}
static struct fb_ops vga16fb_ops = {
......
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