On Mon, Mar 01, 2004 at 06:51:56PM +0100, Takashi Iwai wrote:
> a small concern about GFP_KERNEL is that i experienced the stall when
> the kernel tried to allocate large continuous pages with GFP_KERNEL,
> e.g. modprobe stops infinitely in the module init phase (and you
> cannot even interrupt that process).
>
> does dma_alloc_coherent(GFP_KERNEL) with big pages work without stall?
It depends where the stall was coming from. Do you have any further
details?
Also, on a similar note, I hope someone noticed one of the comments I
added in the second patch:
+ *
+ * Really, we want to move this type of thing into dma_alloc_coherent()
+ * so dma_mask doesn't have to be messed with.
(referring to the hack towards the top of memalloc.c.)
This is something which really needs solving more cleanly. What I
think you're trying to do is to allocate pages for devices whose
DMA mask indicates (eg) 28 bit addressing is possible, but without
the "ISA DMA" (<16MB) restriction? Could you confirm this?
If this is correct, I suspect it may be something which is not
limited to sound devices, and as such should probably be covered
by the generic code (iow, dma_alloc_coherent.) However, that's
going to require discussion with other several people.
Currently, x86 dma_alloc_coherent() is:
if (dev == NULL || (*dev->dma_mask < 0xffffffff))
gfp |= GFP_DMA;
ret = (void *)__get_free_pages(gfp, get_order(size));
if (ret != NULL) {
memset(ret, 0, size);
*dma_handle = virt_to_phys(ret);
}
return ret;
I'm thinking of something more like:
order = get_order(size);
mask = 16*1024*1024-1;
if (dev)
mask = dev->dma_mask;
while (1) {
ret = (void *)__get_free_pages(gfp, order);
if (ret == NULL || gfp & GFP_DMA)
break;
handle = virt_to_phys(ret);
if ((handle & ~mask) == 0) {
memset(ret, 0, size);
*dma_handle = handle;
break;
}
free_pages((unsigned long)ret, order);
gfp |= GFP_DMA;
}
return ret;
Does that look reasonable? If so, I'll float the idea around x86
people.
--
Russell King
Linux kernel 2.6 ARM Linux - http://www.arm.linux.org.uk/
maintainer of: 2.6 PCMCIA - http://pcmcia.arm.linux.org.uk/
2.6 Serial core
-------------------------------------------------------
SF.Net is sponsored by: Speed Start Your Linux Apps Now.
Build and deploy apps & Web services for Linux with
a free DVD software kit from IBM. Click Now!
http://ads.osdn.com/?ad_id=1356&alloc_id=3438&op=click
_______________________________________________
Alsa-devel mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/alsa-devel