Arjan: many thnx! It fixes the problem :-)
Joshua: here the fix :)
----------  Forwarded Message  ----------
Subject: Re: [OOPS] 2.4.20-rc4-ac1 (also occurs 2.4.20-rc2-ac3) in radeon DRI 
for XFree86
Date: Wed, 27 Nov 2002 04:08:25 -0500
From: Arjan van de Ven <arjanv@redhat.com>
To: Marc-Christian Petersen <m.c.p@wolk-project.de>
On Wed, Nov 27, 2002 at 09:39:38AM +0100, Marc-Christian Petersen wrote:
> Hi Joshua,
>
> > Ksymoops output follows.
> > I compiled Radeon DRM stuff into the kernel -- i845 agp support from
> > agapgart. I am using gcc-3.2 to compile. 100% reproducible (okay, i've
> > been spending too much time on bugzillas...) Feel the power of the oops.
>
> I've posted a similar oops with latest rc2 -AC kernel. I have an ATI
> Rage128 card and also got those oops if using DRI.
>
> I hope Arjan may find the bug :)
I did:
diff -u linux-2.4.19/drivers/char/drm.org/r128_drv.h
 linux-2.4.19/drivers/char/drm/r128_drv.h ---
 linux-2.4.19/drivers/char/drm.org/r128_drv.h	2002-11-26 22:13:52.000000000
 +0100 +++ linux-2.4.19/drivers/char/drm/r128_drv.h	2002-11-26
 22:15:23.000000000 +0100 @@ -36,7 +36,7 @@
 #include <asm/delay.h>
 #define GET_RING_HEAD(ring)		readl(  (volatile u32 *) (ring)->head )
-#define SET_RING_HEAD(ring,val)		writel( (volatile u32 *) (ring)->head,
 (val) ) +#define SET_RING_HEAD(ring,val)		writel( (val), (volatile u32 *)
 (ring)->head )
 typedef struct drm_r128_freelist {
    	unsigned int age;
@@ -386,10 +386,10 @@
 #define R128_ADDR(reg)		(R128_BASE( reg ) + reg)
 #define R128_READ(reg)		readl(  (volatile u32 *) R128_ADDR(reg) )
-#define R128_WRITE(reg,val)	writel( (volatile u32 *) R128_ADDR(reg), (val) )
+#define R128_WRITE(reg,val)	writel( (val) , (volatile u32 *) R128_ADDR(reg))
 #define R128_READ8(reg)		readb(  (volatile u8 *) R128_ADDR(reg) )
-#define R128_WRITE8(reg,val)	writeb( (volatile u8 *) R128_ADDR(reg), (val) )
+#define R128_WRITE8(reg,val)	writeb( (val), (volatile u8 *) R128_ADDR(reg) )
 #define R128_WRITE_PLL(addr,val)					\
 do {									\
diff -u linux-2.4.19/drivers/char/drm.org/radeon_cp.c
 linux-2.4.19/drivers/char/drm/radeon_cp.c ---
 linux-2.4.19/drivers/char/drm.org/radeon_cp.c	2002-11-26 22:13:52.000000000
 +0100 +++ linux-2.4.19/drivers/char/drm/radeon_cp.c	2002-11-26
 22:16:22.000000000 +0100 @@ -929,7 +929,7 @@
 	RADEON_WRITE( RADEON_SCRATCH_UMSK, 0x7 );
 	/* Writeback doesn't seem to work everywhere, test it first */
-	writel( &dev_priv->scratch[1], 0 );
+	writel(0, &dev_priv->scratch[1]);
 	RADEON_WRITE( RADEON_SCRATCH_REG1, 0xdeadbeef );
 	for ( tmp = 0 ; tmp < dev_priv->usec_timeout ; tmp++ ) {
diff -u linux-2.4.19/drivers/char/drm.org/radeon_drv.h
 linux-2.4.19/drivers/char/drm/radeon_drv.h ---
 linux-2.4.19/drivers/char/drm.org/radeon_drv.h	2002-11-26 22:13:53.000000000
 +0100 +++ linux-2.4.19/drivers/char/drm/radeon_drv.h	2002-11-26
 22:15:40.000000000 +0100 @@ -32,7 +32,7 @@
 #define __RADEON_DRV_H__
 #define GET_RING_HEAD(ring)		readl(  (volatile u32 *) (ring)->head )
-#define SET_RING_HEAD(ring,val)		writel( (volatile u32 *) (ring)->head ,
 (val)) +#define SET_RING_HEAD(ring,val)		writel( (val), (volatile u32 *)
 (ring)->head )
 typedef struct drm_radeon_freelist {
    	unsigned int age;
@@ -706,10 +706,10 @@
 #define RADEON_ADDR(reg)	(RADEON_BASE( reg ) + reg)
 #define RADEON_READ(reg)	readl(  (volatile u32 *) RADEON_ADDR(reg) )
-#define RADEON_WRITE(reg,val)	writel( (volatile u32 *) RADEON_ADDR(reg),
 (val) ) +#define RADEON_WRITE(reg,val)	writel( (val), (volatile u32 *)
 RADEON_ADDR(reg))
 #define RADEON_READ8(reg)	readb(  (volatile u8 *) RADEON_ADDR(reg) )
-#define RADEON_WRITE8(reg,val)	writeb( (volatile u8 *) RADEON_ADDR(reg),
 (val) ) +#define RADEON_WRITE8(reg,val)	writeb( (val), (volatile u8 *)
 RADEON_ADDR(reg))
 #define RADEON_WRITE_PLL( addr, val )					\
 do {									\
-------------------------------------------------------
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/