[patch][2.5] setup default dma_mask for cardbus devices

From: Zwane Mwaikambo (zwane@holomorphy.com)
Date: Fri Jan 10 2003 - 18:48:24 EST


Devices hanging off a cardbus bridge don't get a default dma mask which
causes problems later when doing pci_alloc_consistent. Patch has been
tested with tulip based ethernet.

Linux Tulip driver version 1.1.13 (May 11, 2002)
Unable to handle kernel NULL pointer dereference at virtual address
00000004
 printing eip:
c011100c
*pde = 00000000
Oops: 0000
CPU: 0
EIP: 0060:[<c011100c>] Not tainted
EFLAGS: 00010282
EIP is at dma_alloc_coherent+0x1c/0x90
eax: 00000000 ebx: 0000003c ecx: 00000020 edx: c767a9e0
esi: 00000300 edi: c767bc00 ebp: c113da6c esp: c113da5c
ds: 007b es: 007b ss: 0068
Process swapper (pid: 1, threadinfo=c113c000 task=c778e040)
Stack: c767bc4c 0000003c 00000080 c767bc00 c113dacc c02b0365 c767bc4c
00000300
       c767a9f0 c01922cc c767bc4c c769c78c 00000000 00000003 c800f000
c767a800
       c113dab4 00000009 c767a9e0 4167c694 c767c93c c769c89c c113dacc
c0192450
Call Trace:
 [<c02b0365>] tulip_init_one+0x1f5/0xde0
 [<c01922cc>] sysfs_get_inode+0x5c/0x110
 [<c0192450>] sysfs_create+0x20/0x30
 [<c0248ec5>] pci_device_probe+0x45/0x60
 [<c025fde5>] bus_match+0x35/0x60
 [<c025fe5a>] device_attach+0x4a/0x60
 [<c025ffde>] bus_add_device+0x6e/0xb0
 [<c025f2ac>] device_add+0xec/0x150
 [<c032eb6e>] cb_alloc+0x2ae/0x310
 [<c032b2d4>] get_socket_status+0x14/0x20
 [<c032b976>] unreset_socket+0x86/0x100
 [<c032b848>] setup_socket+0xa8/0xf0
 [<c032cf34>] pcmcia_register_client+0x254/0x280
 [<c01454c7>] cache_alloc_debugcheck_after+0x97/0xb0
 [<c0144418>] kmalloc+0x98/0xe0
 [<c032c11c>] pcmcia_bind_device+0x6c/0xe0
 [<c011c3b6>] edd_create_symlink_to_scsidev+0x16/0xb0
 [<c032f1e0>] ds_event+0x0/0xb0
 [<c011c546>] edd_device_register+0x76/0x80
 [<c01050c4>] init+0x84/0x1a0
 [<c0105040>] init+0x0/0x1a0
 [<c0105040>] init+0x0/0x1a0
 [<c0105040>] init+0x0/0x1a0
 [<c0107375>] kernel_thread_helper+0x5/0x10

Code: 8b 50 04 8b 00 83 fa 00 77 0a 83 f8 fe 77 05 b9 21 00 00 00
 <0>Kernel panic: Attempted to kill init!

Index: linux-2.5.56/drivers/pcmcia/cardbus.c
===================================================================
RCS file: /build/cvsroot/linux-2.5.56/drivers/pcmcia/cardbus.c,v
retrieving revision 1.1.1.1
diff -u -r1.1.1.1 cardbus.c
--- linux-2.5.56/drivers/pcmcia/cardbus.c 10 Jan 2003 21:22:48 -0000 1.1.1.1
+++ linux-2.5.56/drivers/pcmcia/cardbus.c 10 Jan 2003 23:38:24 -0000
@@ -281,6 +281,8 @@
                 dev->vendor = vend;
                 pci_readw(dev, PCI_DEVICE_ID, &dev->device);
                 dev->hdr_type = hdr & 0x7f;
+ dev->dma_mask = 0xffffffff;
+ dev->dev.dma_mask = &dev->dma_mask;

                 pci_setup_device(dev);
                 if (pci_enable_device(dev))

-- 
function.linuxpower.ca
-
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/



This archive was generated by hypermail 2b29 : Wed Jan 15 2003 - 22:00:35 EST