Re: slub: Add statistics for this_cmpxchg_double failures

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, 22 Mar 2011, Christoph Lameter wrote:

> Index: linux-2.6/include/linux/slub_def.h
> ===================================================================
> --- linux-2.6.orig/include/linux/slub_def.h	2011-03-11 10:34:26.000000000 -0600
> +++ linux-2.6/include/linux/slub_def.h	2011-03-11 10:34:49.000000000 -0600
> @@ -32,6 +32,7 @@ enum stat_item {
>  	DEACTIVATE_TO_TAIL,	/* Cpu slab was moved to the tail of partials */
>  	DEACTIVATE_REMOTE_FREES,/* Slab contained remotely freed objects */
>  	ORDER_FALLBACK,		/* Number of times fallback was necessary */
> +	CMPXCHG_DOUBLE_CPU_FAIL,/* Failure of this_cpu_cmpxchg_double */
>  	NR_SLUB_STAT_ITEMS };
> 
>  struct kmem_cache_cpu {
> Index: linux-2.6/mm/slub.c
> ===================================================================
> --- linux-2.6.orig/mm/slub.c	2011-03-11 10:34:27.000000000 -0600
> +++ linux-2.6/mm/slub.c	2011-03-11 10:34:49.000000000 -0600
> @@ -217,7 +217,7 @@ static inline void sysfs_slab_remove(str
> 
>  #endif
> 
> -static inline void stat(struct kmem_cache *s, enum stat_item si)
> +static inline void stat(const struct kmem_cache *s, enum stat_item si)
>  {
>  #ifdef CONFIG_SLUB_STATS
>  	__this_cpu_inc(s->cpu_slab->stat[si]);
> @@ -1551,6 +1551,7 @@ static inline void note_cmpxchg_failure(
>  		printk("for unknown reason: actual=%lx was=%lx target=%lx\n",
>  			actual_tid, tid, next_tid(tid));
>  #endif
> +	stat(s, CMPXCHG_DOUBLE_CPU_FAIL);
>  }
> 
>  #endif

I see this has been merged as 4fdccdfbb465, but it seems pretty pointless 
unless you export the data to userspace with the necessary STAT_ATTR() and 
addition in slab_attrs.


slub: export CMPXCHG_DOUBLE_CPU_FAIL to userspace

4fdccdfbb465 ("slub: Add statistics for this_cmpxchg_double failures") 
added CMPXCHG_DOUBLE_CPU_FAIL to show how many times 
this_cpu_cmpxchg_double has failed, but it also needs to be exported to 
userspace for consumption.

This will always be 0 if CONFIG_CMPXCHG_LOCAL is disabled.

Signed-off-by: David Rientjes <rientjes@xxxxxxxxxx>
---
 mm/slub.c |    2 ++
 1 files changed, 2 insertions(+), 0 deletions(-)

diff --git a/mm/slub.c b/mm/slub.c
--- a/mm/slub.c
+++ b/mm/slub.c
@@ -4525,6 +4525,7 @@ STAT_ATTR(DEACTIVATE_TO_HEAD, deactivate_to_head);
 STAT_ATTR(DEACTIVATE_TO_TAIL, deactivate_to_tail);
 STAT_ATTR(DEACTIVATE_REMOTE_FREES, deactivate_remote_frees);
 STAT_ATTR(ORDER_FALLBACK, order_fallback);
+STAT_ATTR(CMPXCHG_DOUBLE_CPU_FAIL, cmpxchg_double_cpu_fail);
 #endif
 
 static struct attribute *slab_attrs[] = {
@@ -4582,6 +4583,7 @@ static struct attribute *slab_attrs[] = {
 	&deactivate_to_tail_attr.attr,
 	&deactivate_remote_frees_attr.attr,
 	&order_fallback_attr.attr,
+	&cmpxchg_double_cpu_fail_attr.attr,
 #endif
 #ifdef CONFIG_FAILSLAB
 	&failslab_attr.attr,

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@xxxxxxxxxx  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/
Don't email: <a href=mailto:"dont@xxxxxxxxx";> email@xxxxxxxxx </a>


[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]