diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/durango.c | 12 | ||||
-rw-r--r-- | src/geode.h | 59 | ||||
-rw-r--r-- | src/geode_driver.c | 71 | ||||
-rw-r--r-- | src/geode_msr.c | 1 | ||||
-rw-r--r-- | src/gfx/rndr_gu2.c | 3 | ||||
-rw-r--r-- | src/gx_accel.c | 6 | ||||
-rw-r--r-- | src/lx_driver.c | 6 | ||||
-rw-r--r-- | src/lx_exa.c | 6 | ||||
-rw-r--r-- | src/lx_rotate.c | 4 |
9 files changed, 64 insertions, 104 deletions
diff --git a/src/durango.c b/src/durango.c index 6861acc..9d6970b 100644 --- a/src/durango.c +++ b/src/durango.c @@ -79,8 +79,7 @@ #define FB4MB 1 /* Set to use 4Mb vid ram for Pyramid */ -#define GFX_NO_IO_IN_WAIT_MACROS 1 /* Set to remove I/O accesses in GP - * bit testing */ +#define GFX_NO_IO_IN_WAIT_MACROS 1 /* Set to remove I/O accesses in GP */ #define GFX_READ_ROUTINES 1 #include "gfx_rtns.h" @@ -107,6 +106,15 @@ unsigned char *gfx_phys_vipptr = (unsigned char *)0x40015000; #define OUTW(port,data) outw(port, data) #define OUTD(port,data) outl(port, data) +/* Squash warnings */ +unsigned char gfx_inb(unsigned short); +unsigned short gfx_inw(unsigned short); +unsigned long gfx_ind(unsigned short); + +void gfx_outb(unsigned short, unsigned char); +void gfx_outw(unsigned short, unsigned short); +void gfx_outd(unsigned short, unsigned long); + inline unsigned char gfx_inb(unsigned short port) { diff --git a/src/geode.h b/src/geode.h index 970bdc8..2490315 100644 --- a/src/geode.h +++ b/src/geode.h @@ -24,8 +24,8 @@ * software without specific prior written permission. */ -#ifndef _AMD_GEODE_H_ -#define _AMD_GEODE_H_ +#ifndef _GEODE_H_ +#define _GEODE_H_ #include "geode_pcirename.h" @@ -36,6 +36,7 @@ #include "vgaHW.h" #include "xf86int10.h" #include <X11/extensions/randr.h> +#include "randrstr.h" #include "xf86xv.h" @@ -53,13 +54,9 @@ #define INT10_SUPPORT 1 /* Existing Processor Models */ -#define GX1 0x1 -#define GX2 0x10 -#define GX2_CRT 0x11 -#define GX2_TFT 0x12 -#define LX 0x20 -#define LX_CRT 0x21 -#define LX_TFT 0x22 +#define GX1 0x01 +#define GX 0x10 +#define LX 0x20 #define PCI_VENDOR_ID_CYRIX 0x1078 #define PCI_VENDOR_ID_NS 0x100B @@ -68,9 +65,10 @@ #define PCI_CHIP_5530 0x0104 #define PCI_CHIP_SC1200 0x0504 #define PCI_CHIP_SC1400 0x0104 -#define PCI_CHIP_REDCLOUD 0x0030 +#define PCI_CHIP_GEODEGX 0x0030 #define PCI_CHIP_GEODELX 0x2081 -#define GFX_CPU_GEODELX 4 + +#define GFX_CPU_GEODELX 4 #ifdef HAVE_GX #define GX_FILL_RECT_SUPPORT 1 @@ -456,11 +454,11 @@ GX_GeodeOpts; #define DCON_DEFAULT_BPP 16 #define DCON_DEFAULT_REFRESH 50 -/* amd_dcon.c */ +/* geode_dcon.c */ extern Bool dcon_init(ScrnInfoPtr pScrni); extern int DCONDPMSSet(ScrnInfoPtr pScrni, int mode, int flags); -/* amd_common.c */ +/* geode_common.c */ void geode_memory_to_screen_blt(unsigned long, unsigned long, unsigned long, unsigned long, long, long, int); @@ -468,7 +466,7 @@ int GeodeGetRefreshRate(DisplayModePtr); void GeodeCopyGreyscale(unsigned char *, unsigned char *, int, int, int, int); int GeodeGetSizeFromFB(unsigned int *); -/* amd_gx_video.c */ +/* gx_video.c */ int GeodeQueryImageAttributes(ScrnInfoPtr, int id, unsigned short *w, @@ -476,7 +474,7 @@ GeodeQueryImageAttributes(ScrnInfoPtr, int id, unsigned short *w, Bool RegionsEqual(RegionPtr A, RegionPtr B); -/* amd_gx_driver.c */ +/* gx_driver.c */ void GeodeProbeDDC(ScrnInfoPtr pScrni, int index); xf86MonPtr GeodeDoDDC(ScrnInfoPtr pScrni, int index); @@ -484,49 +482,56 @@ int GeodeGetFPGeometry(const char *str, int *width, int *height); void GeodePointerMoved(int index, int x, int y); void GeodeFreeScreen(int scrnIndex, int flags); int GeodeCalculatePitchBytes(unsigned int width, unsigned int bpp); +void GXSetupChipsetFPtr(ScrnInfoPtr pScrn); -/* amd_msr.c */ +/* geode_msr.c */ int GeodeReadMSR(unsigned long addr, unsigned long *lo, unsigned long *hi); int GeodeWriteMSR(unsigned long addr, unsigned long lo, unsigned long hi); -/* amd_gx_cursor.c */ +/* gx_cursor.c */ Bool GXHWCursorInit(ScreenPtr pScrn); void GXLoadCursorImage(ScrnInfoPtr pScrni, unsigned char *src); void GXHideCursor(ScrnInfoPtr pScrni); void GXShowCursor(ScrnInfoPtr pScrni); -/* amd_gx_randr.c */ +/* gx_randr.c */ Rotation GXGetRotation(ScreenPtr pScreen); Bool GXRandRInit(ScreenPtr pScreen, int rotation); +Bool GXRandRSetConfig(ScreenPtr pScreen, Rotation rotation, int rate, RRScreenSizePtr pSize); -/* amd_gx_rotate.c */ +/* gx_rotate.c */ Bool GXRotate(ScrnInfoPtr pScrni, DisplayModePtr mode); -/* amd_gx_accel.c */ +/* gx_accel.c */ Bool GXAccelInit(ScreenPtr pScrn); +void GXAccelSync(ScrnInfoPtr pScrni); -/* amd_gx_video.c */ +/* gx_video.c */ void GXInitVideo(ScreenPtr pScrn); -/* amd_lx_cursor.c */ +/* lx_driver.c */ +void LXSetupChipsetFPtr(ScrnInfoPtr pScrn); + +/* lx_cursor.c */ Bool LXHWCursorInit(ScreenPtr pScrn); void LXLoadCursorImage(ScrnInfoPtr pScrni, unsigned char *src); void LXHideCursor(ScrnInfoPtr pScrni); void LXShowCursor(ScrnInfoPtr pScrni); -/* amd_lx_randr.c */ +/* lx_randr.c */ Rotation LXGetRotation(ScreenPtr pScreen); Bool LXRandRInit(ScreenPtr pScreen, int rotation); +Bool LXRandRSetConfig(ScreenPtr pScreen, Rotation rotation, int rate, RRScreenSizePtr pSize); -/* amd_lx_rotate.c */ +/* lx_rotate.c */ Bool LXSetRotatePitch(ScrnInfoPtr pScrni); Bool LXRotate(ScrnInfoPtr pScrni, DisplayModePtr mode); Bool LXAllocShadow(ScrnInfoPtr pScrni); -/* amd_lx_exa.c */ +/* lx_exa.c */ Bool LXExaInit(ScreenPtr pScreen); -/* amd_lx_video.c */ +/* lx_video.c */ void LXInitVideo(ScreenPtr pScrn); -#endif /* _AMD_GEODE_H_ */ +#endif diff --git a/src/geode_driver.c b/src/geode_driver.c index f04d5e4..8e467ec 100644 --- a/src/geode_driver.c +++ b/src/geode_driver.c @@ -96,7 +96,7 @@ static Bool AmdProbe(DriverPtr, int); #ifdef XSERVER_LIBPCIACCESS static const struct pci_id_match amdDeviceMatch[] = { - {PCI_VENDOR_ID_NS, PCI_CHIP_REDCLOUD, PCI_MATCH_ANY, PCI_MATCH_ANY, 0, 0, + {PCI_VENDOR_ID_NS, PCI_CHIP_GEODEGX, PCI_MATCH_ANY, PCI_MATCH_ANY, 0, 0, 0}, {PCI_VENDOR_ID_AMD, PCI_CHIP_GEODELX, PCI_MATCH_ANY, PCI_MATCH_ANY, 0, 0, 0}, @@ -158,7 +158,7 @@ DeviceModel ChipModel[] = { {PCI_CHIP_GEODELX, LX}, #endif #ifdef HAVE_GX - {PCI_CHIP_REDCLOUD, GX2}, + {PCI_CHIP_GEODEGX, GX}, #endif {-1, 0} }; @@ -166,10 +166,10 @@ DeviceModel ChipModel[] = { /* Supported chipsets */ SymTabRec GeodeChipsets[] = { #ifdef HAVE_LX - {PCI_CHIP_GEODELX, "GeodeLX"}, + {PCI_CHIP_GEODELX, "Geode LX"}, #endif #ifdef HAVE_GX - {PCI_CHIP_REDCLOUD, "REDCLOUD"}, + {PCI_CHIP_GEODEGX, "Geode GX"}, #endif {-1, NULL} }; @@ -179,13 +179,12 @@ PciChipsets GeodePCIchipsets[] = { {PCI_CHIP_GEODELX, PCI_CHIP_GEODELX, RES_SHARED_VGA}, #endif #ifdef HAVE_GX - {PCI_CHIP_REDCLOUD, PCI_CHIP_REDCLOUD, RES_SHARED_VGA}, + {PCI_CHIP_GEODEGX, PCI_CHIP_GEODEGX, RES_SHARED_VGA}, #endif {-1, -1, RES_UNDEFINED}, }; #ifdef HAVE_LX -void LXSetupChipsetFPtr(ScrnInfoPtr pScrni); OptionInfoRec LX_GeodeOptions[] = { {LX_OPTION_SW_CURSOR, "SWcursor", OPTV_BOOLEAN, {0}, FALSE}, @@ -208,7 +207,6 @@ OptionInfoRec LX_GeodeOptions[] = { #endif #ifdef HAVE_GX -void GXSetupChipsetFPtr(ScrnInfoPtr pScrni); OptionInfoRec GX_GeodeOptions[] = { {GX_OPTION_SW_CURSOR, "SWcursor", OPTV_BOOLEAN, {0}, FALSE}, @@ -410,55 +408,6 @@ AmdIdentify(int flags) GeodeChipsets); } -#ifdef XSERVER_LIBPCIACCESS - -static Bool -AmdPciProbe(DriverPtr driver, - int entity_num, - struct pci_device *device, - intptr_t match_data) -{ - ScrnInfoPtr scrn = NULL; - int cpu_detected; - - ErrorF("AmdPciProbe: Probing for supported devices!\n"); - - scrn = xf86ConfigPciEntity(scrn, 0, entity_num, GeodePCIchipsets, - NULL, NULL, NULL, NULL, NULL); - - if (scrn != NULL) - { - scrn->driverName = GEODE_DRIVER_NAME; - scrn->driverVersion = GEODE_VERSION; - scrn->name = GEODE_NAME; - scrn->Probe = NULL; - - switch (device->device_id) { -#ifdef HAVE_LX - case PCI_CHIP_GEODELX: - cpu_detected = LX; - LXSetupChipsetFPtr(scrn); - break; -#endif -#ifdef HAVE_GX - case PCI_CHIP_REDCLOUD: - cpu_detected = GX2; - GXSetupChipsetFPtr(scrn); - break; -#endif - default: - ErrorF("AmdPciProbe: unknown device ID\n"); - return FALSE; - } - - DEBUGMSG(1, (0, X_INFO, "AmdPciProbe: CPUDetected %d!\n", - cpu_detected)); - } - return scrn != NULL; -} - -#else /* XSERVER_LIBPCIACCESS */ - /*---------------------------------------------------------------------------- * AmdAvailableOptions. * @@ -483,7 +432,7 @@ AmdAvailableOptions(int chipid, int busid) return LX_GeodeOptions; #endif #ifdef HAVE_GX - case PCI_CHIP_REDCLOUD: + case PCI_CHIP_GEODEGX: return GX_GeodeOptions; #endif } @@ -518,8 +467,8 @@ AmdPciProbe(DriverPtr driver, break; #endif #ifdef HAVE_GX - case PCI_CHIP_REDCLOUD: - cpu_detected = GX2; + case PCI_CHIP_GEODEGX: + cpu_detected = GX; GXSetupChipsetFPtr(scrn); break; #endif @@ -613,8 +562,8 @@ AmdProbe(DriverPtr drv, int flags) break; #endif #ifdef HAVE_GX - case PCI_CHIP_REDCLOUD: - CPUDetected = GX2; + case PCI_CHIP_GEODEGX: + CPUDetected = GX; drvr_setup = &GXSetupChipsetFPtr; break; #endif diff --git a/src/geode_msr.c b/src/geode_msr.c index 0d31192..167ccd6 100644 --- a/src/geode_msr.c +++ b/src/geode_msr.c @@ -5,6 +5,7 @@ #include <sys/types.h> #include <sys/errno.h> #include "os.h" +#include "geode.h" static int _msr_open(void) diff --git a/src/gfx/rndr_gu2.c b/src/gfx/rndr_gu2.c index 31a26e7..db3ccf3 100644 --- a/src/gfx/rndr_gu2.c +++ b/src/gfx/rndr_gu2.c @@ -96,6 +96,9 @@ unsigned short gu2_bm_throttle = 0; unsigned short gu2_vm_throttle = 0; int gu2_current_line = 0; +/* Kill a warning */ +void gfx_reset_pitch(unsigned short pitch); + /*--------------------------------------------------------------------------- * GFX_RESET_PITCH (PRIVATE ROUTINE - NOT PART OF API) * diff --git a/src/gx_accel.c b/src/gx_accel.c index 35ca64e..025b06a 100644 --- a/src/gx_accel.c +++ b/src/gx_accel.c @@ -1757,9 +1757,9 @@ amd_gx_exa_Composite(PixmapPtr pxDst, int srcX, int srcY, int maskX, int maskY, int dstX, int dstY, int width, int height) { int op, current_line, max_lines, lines, pass, scratchPitch; - unsigned int srcOffset, srcOfs, srcPitch, srcPch, srcBpp; - unsigned int dstOffset, dstOfs, dstPitch, dstPch, dstBpp; - unsigned int sizes, strides, blt_mode, rop; + unsigned int srcOffset, srcOfs=0, srcPitch, srcPch=0, srcBpp; + unsigned int dstOffset, dstOfs=0, dstPitch, dstPch=0, dstBpp; + unsigned int sizes, strides, blt_mode = 0, rop = 0; GeodeRec *pGeode = GEODEPTR_FROM_PIXMAP(pxDst); //ErrorF("amd_gx_exa_Composite() from %d,%d to %d,%d %dx%d\n", diff --git a/src/lx_driver.c b/src/lx_driver.c index d77a682..973d54d 100644 --- a/src/lx_driver.c +++ b/src/lx_driver.c @@ -634,7 +634,7 @@ LXPreInit(ScrnInfoPtr pScrni, int flags) &pGeode->tryHWCursor); if (!xf86GetOptValInteger(GeodeOptions, LX_OPTION_FBSIZE, - &(pGeode->FBAvail))) + (int *) &(pGeode->FBAvail))) pGeode->FBAvail = 0; /* For compatability - allow SWCursor too */ @@ -664,7 +664,7 @@ LXPreInit(ScrnInfoPtr pScrni, int flags) } xf86GetOptValInteger(GeodeOptions, LX_OPTION_EXA_SCRATCH_BFRSZ, - &(pGeode->exaBfrSz)); + (int *) &(pGeode->exaBfrSz)); if (pGeode->exaBfrSz <= 0) pGeode->exaBfrSz = 0; @@ -1194,8 +1194,6 @@ LXLoadPalette(ScrnInfoPtr pScrni, static void LXDPMSSet(ScrnInfoPtr pScrni, int mode, int flags) { - GeodeRec *pGeode = GEODEPTR(pScrni); - if (!pScrni->vtSema) return; diff --git a/src/lx_exa.c b/src/lx_exa.c index bd63573..f6978d8 100644 --- a/src/lx_exa.c +++ b/src/lx_exa.c @@ -251,7 +251,7 @@ static unsigned int lx_get_source_color(PixmapPtr pSrc, int srcFormat, int dstFormat) { CARD32 in, out; - CARD16 red, green, blue, alpha; + CARD16 red = 0, green = 0, blue = 0, alpha = 0; /* Stall to avoid a race with the upload function */ /* for 1.4 and newer, the problem will be resolved within @@ -561,7 +561,6 @@ lx_prepare_composite(int op, PicturePtr pSrc, PicturePtr pMsk, exaScratch.bufferOffset = pGeode->exaBfrOffset; if (pMsk && op != PictOpClear) { - unsigned int srcColor; struct blend_ops_t *opPtr = &lx_alpha_ops[op * 2]; int direction = (opPtr->channel == CIMGP_CHANNEL_A_SOURCE) ? 0 : 1; @@ -881,9 +880,6 @@ static void lx_do_composite_mask(PixmapPtr pxDst, unsigned long dstOffset, unsigned int maskOffset, int width, int height) { - GeodeRec *pGeode = GEODEPTR_FROM_PIXMAP(pxDst); - unsigned char *data = pGeode->FBBase + maskOffset; - struct blend_ops_t *opPtr = &lx_alpha_ops[exaScratch.op * 2]; gp_declare_blt(0); diff --git a/src/lx_rotate.c b/src/lx_rotate.c index c63fb22..eee58c7 100644 --- a/src/lx_rotate.c +++ b/src/lx_rotate.c @@ -61,10 +61,10 @@ LXUpdateFunc(ScreenPtr pScreen, shadowBufPtr pBuf) int nbox = REGION_NUM_RECTS(damage); BoxPtr pbox = REGION_RECTS(damage); - int x, y, w, h, degrees; + int x, y, w, h, degrees = 0; FbStride shaStride; FbBits *shaBits; - int shaBpp, dx, dy, dw, dh; + int shaBpp, dx = 0, dy = 0, dw, dh; int shaXoff, shaYoff; unsigned int srcOffset, dstOffset; PixmapPtr pShadow = pBuf->pPixmap; |