* [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