diff options
author | Eric Dumazet <dada1@cosmosbay.com> | 2005-09-04 00:55:06 +0200 |
---|---|---|
committer | Linus Torvalds <torvalds@evo.osdl.org> | 2005-09-05 09:05:48 +0200 |
commit | 34342e863c3143640c031760140d640a06c6a5f8 (patch) | |
tree | f2855e8ca82929859cb1fe249982b3ba1ccf9b5e /mm/slab.c | |
parent | [PATCH] x86_64: avoid some atomic operations during address space destruction (diff) | |
download | linux-34342e863c3143640c031760140d640a06c6a5f8.tar.xz linux-34342e863c3143640c031760140d640a06c6a5f8.zip |
[PATCH] mm/slab.c: prefetchw the start of new allocated objects
Mostobjects returned by __cache_alloc() will be written by the caller,
(but not all callers want to write all the object, but just at the
begining) prefetchw() tells the modern CPU to think about the future
writes, ie start some memory transactions in advance.
Signed-off-by: Eric Dumazet <dada1@cosmosbay.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'mm/slab.c')
-rw-r--r-- | mm/slab.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/mm/slab.c b/mm/slab.c index 59d382fbca1c..75127a6f1fd9 100644 --- a/mm/slab.c +++ b/mm/slab.c @@ -2166,7 +2166,9 @@ static inline void *__cache_alloc(kmem_cache_t *cachep, unsigned int __nocast fl objp = cache_alloc_refill(cachep, flags); } local_irq_restore(save_flags); - objp = cache_alloc_debugcheck_after(cachep, flags, objp, __builtin_return_address(0)); + objp = cache_alloc_debugcheck_after(cachep, flags, objp, + __builtin_return_address(0)); + prefetchw(objp); return objp; } |