linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 2/2] slab: optimize kmalloc_node the same way as kmalloc
@ 2006-08-04 15:15 Christoph Hellwig
  2006-08-04 15:59 ` Pekka Enberg
  2006-08-04 16:14 ` Christoph Lameter
  0 siblings, 2 replies; 3+ messages in thread
From: Christoph Hellwig @ 2006-08-04 15:15 UTC (permalink / raw)
  To: akpm, viro; +Cc: linux-mm

Signed-off-by: Christoph Hellwig <hch@lst.de>

Index: linux-2.6/include/linux/slab.h
===================================================================
--- linux-2.6.orig/include/linux/slab.h	2006-07-26 15:30:49.000000000 +0200
+++ linux-2.6/include/linux/slab.h	2006-07-26 15:42:49.000000000 +0200
@@ -213,7 +213,30 @@
 
 #ifdef CONFIG_NUMA
 extern void *kmem_cache_alloc_node(kmem_cache_t *, gfp_t flags, int node);
-extern void *kmalloc_node(size_t size, gfp_t flags, int node);
+extern void *__kmalloc_node(size_t size, gfp_t flags, int node);
+
+static inline void *kmalloc_node(size_t size, gfp_t flags, int node)
+{
+	if (__builtin_constant_p(size)) {
+		int i = 0;
+#define CACHE(x) \
+		if (size <= x) \
+			goto found; \
+		else \
+			i++;
+#include "kmalloc_sizes.h"
+#undef CACHE
+		{
+			extern void __you_cannot_kmalloc_that_much(void);
+			__you_cannot_kmalloc_that_much();
+		}
+found:
+		return kmem_cache_alloc_node((flags & GFP_DMA) ?
+			malloc_sizes[i].cs_dmacachep :
+			malloc_sizes[i].cs_cachep, flags, node);
+	}
+	return __kmalloc_node(size, flags, node);
+}
 #else
 static inline void *kmem_cache_alloc_node(kmem_cache_t *cachep, gfp_t flags, int node)
 {
Index: linux-2.6/mm/slab.c
===================================================================
--- linux-2.6.orig/mm/slab.c	2006-07-26 15:25:28.000000000 +0200
+++ linux-2.6/mm/slab.c	2006-07-26 15:42:49.000000000 +0200
@@ -3317,7 +3317,7 @@
 }
 EXPORT_SYMBOL(kmem_cache_alloc_node);
 
-void *kmalloc_node(size_t size, gfp_t flags, int node)
+void *__kmalloc_node(size_t size, gfp_t flags, int node)
 {
 	struct kmem_cache *cachep;
 

--
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:"dont@kvack.org"> email@kvack.org </a>

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH 2/2] slab: optimize kmalloc_node the same way as kmalloc
  2006-08-04 15:15 [PATCH 2/2] slab: optimize kmalloc_node the same way as kmalloc Christoph Hellwig
@ 2006-08-04 15:59 ` Pekka Enberg
  2006-08-04 16:14 ` Christoph Lameter
  1 sibling, 0 replies; 3+ messages in thread
From: Pekka Enberg @ 2006-08-04 15:59 UTC (permalink / raw)
  To: Christoph Hellwig; +Cc: akpm, viro, linux-mm, Christoph Lameter

On 8/4/06, Christoph Hellwig <hch@lst.de> wrote:
> +static inline void *kmalloc_node(size_t size, gfp_t flags, int node)

[snip]

I think the optimization was left out on purpose as kmalloc_node() is
slow anyway. No objections from me though.

--
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:"dont@kvack.org"> email@kvack.org </a>

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH 2/2] slab: optimize kmalloc_node the same way as kmalloc
  2006-08-04 15:15 [PATCH 2/2] slab: optimize kmalloc_node the same way as kmalloc Christoph Hellwig
  2006-08-04 15:59 ` Pekka Enberg
@ 2006-08-04 16:14 ` Christoph Lameter
  1 sibling, 0 replies; 3+ messages in thread
From: Christoph Lameter @ 2006-08-04 16:14 UTC (permalink / raw)
  To: Christoph Hellwig; +Cc: akpm, viro, linux-mm

On Fri, 4 Aug 2006, Christoph Hellwig wrote:

> Signed-off-by: Christoph Hellwig <hch@lst.de>

I actually posted almost the same patch a year ago. But note that 
kmalloc_node() does not use cpucaches and therefore does not
have the speed of kmalloc()

Acked-by: Christoph Lameter <clameter@sgi.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:"dont@kvack.org"> email@kvack.org </a>

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2006-08-04 16:14 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2006-08-04 15:15 [PATCH 2/2] slab: optimize kmalloc_node the same way as kmalloc Christoph Hellwig
2006-08-04 15:59 ` Pekka Enberg
2006-08-04 16:14 ` Christoph Lameter

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox