hi, when taking a look at /proc/likely_prof i noticed the following
+unlikely | 40969931| 6228144 __slab_free()@:mm/[EMAIL PROTECTED] +unlikely | 47198075| 0 __slab_free()@:mm/[EMAIL PROTECTED] -likely | 0| 47198075 slab_free()@:mm/[EMAIL PROTECTED] +unlikely | 47280864| 0 __slab_alloc()@:mm/[EMAIL PROTECTED] +unlikely | 26857| 0 new_slab()@:mm/[EMAIL PROTECTED] +unlikely | 47280864| 0 slab_alloc()@:mm/[EMAIL PROTECTED] three of the unlikely cases are caused by "if (unlikely(SlabDebug(page)))" if SLUB_DEBUG is turned off, it really is unlikely, since SlabDebug() always returns 0, if SLUB_DEBUG is turned on it is likely (not sure if there are cases where it can return 0) therefore it makes sense to change this to likely for the SLUB_DEBUG case. The following patch changes the SlabDebug() functions to defines, so gcc can easily optimize the if away entirely and changes the unlikely() to a likely(). Remaining problem is, that if likely/unlikely profiling is turned on, gcc does not optimize away a likely(0), and they still show up in the stats... guess heisenbug is involved in this :-) Signed-off-by: Eric Sesterhenn <[EMAIL PROTECTED]> --- linux/mm/slub.c.orig 2007-06-11 09:04:15.000000000 +0000 +++ linux/mm/slub.c 2007-06-11 17:11:36.000000000 +0000 @@ -101,12 +101,6 @@ #define FROZEN (1 << PG_active) -#ifdef CONFIG_SLUB_DEBUG -#define SLABDEBUG (1 << PG_error) -#else -#define SLABDEBUG 0 -#endif - static inline int SlabFrozen(struct page *page) { return page->flags & FROZEN; @@ -122,6 +116,9 @@ static inline void ClearSlabFrozen(struc page->flags &= ~FROZEN; } +#ifdef CONFIG_SLUB_DEBUG + +#define SLABDEBUG (1 << PG_error) static inline int SlabDebug(struct page *page) { return page->flags & SLABDEBUG; @@ -136,6 +133,13 @@ static inline void ClearSlabDebug(struct { page->flags &= ~SLABDEBUG; } +#else + +#define SlabDebug(x) 0 +#define SetSlabDebug(x) +#define ClearSlabDebug(x) + +#endif /* * Issues still to be resolved: @@ -1129,7 +1133,7 @@ static void __free_slab(struct kmem_cach { int pages = 1 << s->order; - if (unlikely(SlabDebug(page))) { + if (likely(SlabDebug(page))) { void *p; slab_pad_check(s, page); @@ -1472,7 +1476,7 @@ load_freelist: object = page->freelist; if (unlikely(!object)) goto another_slab; - if (unlikely(SlabDebug(page))) + if (likely(SlabDebug(page))) goto debug; object = page->freelist; @@ -1596,7 +1600,7 @@ static void __slab_free(struct kmem_cach slab_lock(page); - if (unlikely(SlabDebug(page))) + if (likely(SlabDebug(page))) goto debug; checks_ok: prior = object[page->offset] = page->freelist; - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/