* Memory allocation problem @ 2003-04-30 22:14 anand kumar 2003-04-30 22:28 ` Greg KH 2003-04-30 22:36 ` Dave Hansen 0 siblings, 2 replies; 5+ messages in thread From: anand kumar @ 2003-04-30 22:14 UTC (permalink / raw) To: linux-mm; +Cc: kernelnewbies Hi, We are developing a PCI driver for a specialized hardware which needs blocks of physically contiguous memory regions of 32 KB. We need to allocate 514 such blocks for a total of 16 MB We were using an ioctl implementation in the driver which uses kmalloc() to allocate the required memory blocks. kmalloc()(GFP_KERNEL) fails after allocating some 250 blocks of memory (probably due to fragmentation). We then tried using __get_free_pages() and the result was the same. Even though the free pages in zone NORMAL and DMA were 10000 and 1500 respectively. Are we hitting some limit because of fragmentation and are not able to allocate 8 contiguous physical pages? We tried moving the memory allocation in init_module and made the driver load during boot time, during which allocation succeeds. The kernel version we are using is 2.4.18 (Redhat 8.0) and the total amount of memory available in the box is 128MB Is there any other mechanism to allocate large amount of physically contiguous memory blocks during normal run time of the driver? Is this being addressed in later kernels. Rgds Anand -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"aart@kvack.org"> aart@kvack.org </a> ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Memory allocation problem 2003-04-30 22:14 Memory allocation problem anand kumar @ 2003-04-30 22:28 ` Greg KH 2003-04-30 22:29 ` Christoph Hellwig 2003-04-30 22:36 ` Dave Hansen 1 sibling, 1 reply; 5+ messages in thread From: Greg KH @ 2003-04-30 22:28 UTC (permalink / raw) To: anand kumar; +Cc: linux-mm, kernelnewbies On Wed, Apr 30, 2003 at 10:14:38PM -0000, anand kumar wrote: > > Is there any other mechanism to allocate large amount of > physically contiguous memory blocks during normal run time of the > driver? Is this being addressed in later kernels. Look at vmalloc(). It should do what you are looking for. greg k-h -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"aart@kvack.org"> aart@kvack.org </a> ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Memory allocation problem 2003-04-30 22:28 ` Greg KH @ 2003-04-30 22:29 ` Christoph Hellwig 0 siblings, 0 replies; 5+ messages in thread From: Christoph Hellwig @ 2003-04-30 22:29 UTC (permalink / raw) To: Greg KH; +Cc: anand kumar, linux-mm, kernelnewbies On Wed, Apr 30, 2003 at 03:28:25PM -0700, Greg KH wrote: > On Wed, Apr 30, 2003 at 10:14:38PM -0000, anand kumar wrote: > > > > Is there any other mechanism to allocate large amount of > > physically contiguous memory blocks during normal run time of the > > driver? Is this being addressed in later kernels. > > Look at vmalloc(). It should do what you are looking for. vmalloc is not physically continguos, He could use bootmem unless he wants his driver to work modular. -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"aart@kvack.org"> aart@kvack.org </a> ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Memory allocation problem 2003-04-30 22:14 Memory allocation problem anand kumar 2003-04-30 22:28 ` Greg KH @ 2003-04-30 22:36 ` Dave Hansen 1 sibling, 0 replies; 5+ messages in thread From: Dave Hansen @ 2003-04-30 22:36 UTC (permalink / raw) To: anand kumar; +Cc: linux-mm, kernelnewbies [-- Attachment #1: Type: text/plain, Size: 1079 bytes --] anand kumar wrote: > We are developing a PCI driver for a specialized hardware which > needs blocks of physically contiguous memory regions of > 32 KB. We need to allocate 514 such blocks for a total of 16 MB > We were using an ioctl implementation in the driver which uses > kmalloc() to allocate the required memory blocks. > kmalloc()(GFP_KERNEL) > fails after allocating some 250 blocks of memory (probably due to > fragmentation). > We then tried using __get_free_pages() and the result was the > same. Well, kmalloc() falls back to __get_free_pages() eventually (after going through the slab cache), so it isn't much of a surprise that both failed. > Even though the free pages in zone NORMAL and DMA were 10000 and > 1500 respectively. Can you try this on a kernel that has /proc/buddyinfo? It exports the buddy allocators internal structures so that you can see the fragmentation. buddyinfo has been in 2.5 since ~2.5.35. There may even be a 2.4 version floating around... If you can post some code too, it might be helpful. -- Dave Hansen haveblue@us.ibm.com [-- Attachment #2: buddyinfo-2.5.34-0.patch --] [-- Type: text/plain, Size: 3439 bytes --] # This is a BitKeeper generated patch for the following project: # Project Name: Linux kernel tree # This patch format is intended for GNU patch command version 2.5 or higher. # This patch includes the following deltas: # ChangeSet 1.508.1.116 -> 1.513 # mm/page_alloc.c 1.89.1.8 -> 1.92 # fs/proc/proc_misc.c 1.34.1.2 -> 1.36 # # The following is the BitKeeper ChangeSet Log # -------------------------------------------- # 02/09/09 haveblue@elm3b96.(none) 1.513 # Merge elm3b96.(none):/work/dave/bk/linux-2.5 # into elm3b96.(none):/work/dave/bk/linux-2.5-buddyinfo # -------------------------------------------- # diff -Nru a/fs/proc/proc_misc.c b/fs/proc/proc_misc.c --- a/fs/proc/proc_misc.c Wed Sep 11 10:45:01 2002 +++ b/fs/proc/proc_misc.c Wed Sep 11 10:45:01 2002 @@ -208,6 +208,20 @@ #undef K } +extern struct seq_operations fragmentation_op; +static int fragmentation_open(struct inode *inode, struct file *file) +{ + (void)inode; + return seq_open(file, &fragmentation_op); +} + +static struct file_operations fragmentation_file_operations = { + open: fragmentation_open, + read: seq_read, + llseek: seq_lseek, + release: seq_release, +}; + static int version_read_proc(char *page, char **start, off_t off, int count, int *eof, void *data) { @@ -624,6 +638,7 @@ create_seq_entry("partitions", 0, &proc_partitions_operations); create_seq_entry("interrupts", 0, &proc_interrupts_operations); create_seq_entry("slabinfo",S_IWUSR|S_IRUGO,&proc_slabinfo_operations); + create_seq_entry("buddyinfo",S_IRUGO, &fragmentation_file_operations); #ifdef CONFIG_MODULES create_seq_entry("modules", 0, &proc_modules_operations); create_seq_entry("ksyms", 0, &proc_ksyms_operations); diff -Nru a/mm/page_alloc.c b/mm/page_alloc.c --- a/mm/page_alloc.c Wed Sep 11 10:45:01 2002 +++ b/mm/page_alloc.c Wed Sep 11 10:45:01 2002 @@ -949,3 +949,69 @@ } __setup("memfrac=", setup_mem_frac); + +#ifdef CONFIG_PROC_FS + +#include <linux/seq_file.h> + +static void *frag_start(struct seq_file *m, loff_t *pos) +{ + pg_data_t *pgdat; + loff_t node = *pos; + + for (pgdat = pgdat_list; pgdat && node; pgdat = pgdat->pgdat_next) + --node; + + return pgdat; +} + +static void *frag_next(struct seq_file *m, void *arg, loff_t *pos) +{ + pg_data_t *pgdat = (pg_data_t *)arg; + + (*pos)++; + return pgdat->pgdat_next; +} + +static void frag_stop(struct seq_file *m, void *arg) +{ +} + +/* + * This walks the freelist for each zone. Whilst this is slow, I'd rather + * be slow here than slow down the fast path by keeping stats - mjbligh + */ +static int frag_show(struct seq_file *m, void *arg) +{ + pg_data_t *pgdat = (pg_data_t *)arg; + zone_t *zone, *node_zones = pgdat->node_zones; + unsigned long flags; + int order; + + for (zone = node_zones; zone - node_zones < MAX_NR_ZONES; ++zone) { + if (!zone->size) + continue; + + spin_lock_irqsave(&zone->lock, flags); + seq_printf(m, "Node %d, zone %8s ", pgdat->node_id, zone->name); + for (order = 0; order < MAX_ORDER; ++order) { + unsigned long nr_bufs = 0; + list_t *elem; + list_for_each(elem, &zone->free_area[order].free_list) + ++nr_bufs; + seq_printf(m, "%6lu ", nr_bufs); + } + spin_unlock_irqrestore(&zone->lock, flags); + seq_putc(m, '\n'); + } + return 0; +} + +struct seq_operations fragmentation_op = { + start: frag_start, + next: frag_next, + stop: frag_stop, + show: frag_show, +}; + +#endif /* CONFIG_PROC_FS */ ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Memory allocation problem @ 2003-05-01 13:20 Mark_H_Johnson 0 siblings, 0 replies; 5+ messages in thread From: Mark_H_Johnson @ 2003-05-01 13:20 UTC (permalink / raw) To: anand kumar; +Cc: kernelnewbies, linux-mm >The kernel version we are using is 2.4.18 (Redhat 8.0) and the total >amount of memory available in the box is 128MB >Is there any other mechanism to allocate large amount of physically >contiguous memory blocks during normal run time of the driver? Is this >being addressed in later kernels. I regularly use a patch (bigphysarea) recommended by Dolphin for use with their SCI cards. The copy I use is from a relatively old kernel (2.4.4) which applies with a few warnings but is otherwise OK. I did a quick search with Google for bigphysarea linux 2.4.18 and found http://frmb.home.cern.ch/frmb/download/bigphysarea-2.4.18.patch or a more readable page at http://frmb.home.cern.ch/frmb/linux.html which appears to be a version updated for 2.4.18. I believe the original patch is maintained at http://www.uni-paderborn.de/fachbereich/AG/heiss/linux/bigphysarea.html There are apparently several drivers that already use this interface, but it does require a patched kernel. I am not aware of any effort to merge this into the main line kernel (though I would certainly appreciate that). --Mark H Johnson <mailto:Mark_H_Johnson@raytheon.com> -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"aart@kvack.org"> aart@kvack.org </a> ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2003-05-01 13:20 UTC | newest] Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2003-04-30 22:14 Memory allocation problem anand kumar 2003-04-30 22:28 ` Greg KH 2003-04-30 22:29 ` Christoph Hellwig 2003-04-30 22:36 ` Dave Hansen 2003-05-01 13:20 Mark_H_Johnson
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox