Commit 4bf690c2 authored by Eric Sandeen's avatar Eric Sandeen Committed by Stephen Lord

[XFS] Re-work pagebuf stats macros to help support per-cpu data

SGI Modid: 2.5.x-xfs:slinx:158653a
parent 00d4d5a9
...@@ -293,7 +293,7 @@ _pagebuf_initialize( ...@@ -293,7 +293,7 @@ _pagebuf_initialize(
atomic_set(&pb->pb_pin_count, 0); atomic_set(&pb->pb_pin_count, 0);
init_waitqueue_head(&pb->pb_waiters); init_waitqueue_head(&pb->pb_waiters);
PB_STATS_INC(pbstats.pb_create); PB_STATS_INC(pb_create);
PB_TRACE(pb, PB_TRACE_REC(get), target); PB_TRACE(pb, PB_TRACE_REC(get), target);
} }
...@@ -485,7 +485,7 @@ _pagebuf_lookup_pages( ...@@ -485,7 +485,7 @@ _pagebuf_lookup_pages(
page = find_or_create_page(aspace, index, gfp_mask); page = find_or_create_page(aspace, index, gfp_mask);
if (!page) { if (!page) {
if (--retry_count > 0) { if (--retry_count > 0) {
PB_STATS_INC(pbstats.pb_page_retries); PB_STATS_INC(pb_page_retries);
pagebuf_daemon_wakeup(1); pagebuf_daemon_wakeup(1);
current->state = TASK_UNINTERRUPTIBLE; current->state = TASK_UNINTERRUPTIBLE;
schedule_timeout(10); schedule_timeout(10);
...@@ -495,7 +495,7 @@ _pagebuf_lookup_pages( ...@@ -495,7 +495,7 @@ _pagebuf_lookup_pages(
all_mapped = 0; all_mapped = 0;
continue; continue;
} }
PB_STATS_INC(pbstats.pb_page_found); PB_STATS_INC(pb_page_found);
mark_page_accessed(page); mark_page_accessed(page);
pb->pb_pages[pi] = page; pb->pb_pages[pi] = page;
} else { } else {
...@@ -645,7 +645,7 @@ _pagebuf_find( /* find buffer for block */ ...@@ -645,7 +645,7 @@ _pagebuf_find( /* find buffer for block */
h->pb_count++; h->pb_count++;
list_add(&new_pb->pb_hash_list, &h->pb_hash); list_add(&new_pb->pb_hash_list, &h->pb_hash);
} else { } else {
PB_STATS_INC(pbstats.pb_miss_locked); PB_STATS_INC(pb_miss_locked);
} }
spin_unlock(&h->pb_hash_lock); spin_unlock(&h->pb_hash_lock);
...@@ -665,7 +665,7 @@ _pagebuf_find( /* find buffer for block */ ...@@ -665,7 +665,7 @@ _pagebuf_find( /* find buffer for block */
/* wait for buffer ownership */ /* wait for buffer ownership */
PB_TRACE(pb, PB_TRACE_REC(get_lk), 0); PB_TRACE(pb, PB_TRACE_REC(get_lk), 0);
pagebuf_lock(pb); pagebuf_lock(pb);
PB_STATS_INC(pbstats.pb_get_locked_waited); PB_STATS_INC(pb_get_locked_waited);
} else { } else {
/* We asked for a trylock and failed, no need /* We asked for a trylock and failed, no need
* to look at file offset and length here, we * to look at file offset and length here, we
...@@ -675,7 +675,7 @@ _pagebuf_find( /* find buffer for block */ ...@@ -675,7 +675,7 @@ _pagebuf_find( /* find buffer for block */
*/ */
pagebuf_rele(pb); pagebuf_rele(pb);
PB_STATS_INC(pbstats.pb_busy_locked); PB_STATS_INC(pb_busy_locked);
return (NULL); return (NULL);
} }
} else { } else {
...@@ -691,7 +691,7 @@ _pagebuf_find( /* find buffer for block */ ...@@ -691,7 +691,7 @@ _pagebuf_find( /* find buffer for block */
_PBF_ADDR_ALLOCATED | \ _PBF_ADDR_ALLOCATED | \
_PBF_MEM_ALLOCATED; _PBF_MEM_ALLOCATED;
PB_TRACE(pb, PB_TRACE_REC(got_lk), 0); PB_TRACE(pb, PB_TRACE_REC(got_lk), 0);
PB_STATS_INC(pbstats.pb_get_locked); PB_STATS_INC(pb_get_locked);
return (pb); return (pb);
} }
...@@ -747,7 +747,7 @@ pagebuf_get( /* allocate a buffer */ ...@@ -747,7 +747,7 @@ pagebuf_get( /* allocate a buffer */
return (NULL); return (NULL);
} }
PB_STATS_INC(pbstats.pb_get); PB_STATS_INC(pb_get);
/* fill in any missing pages */ /* fill in any missing pages */
error = _pagebuf_lookup_pages(pb, pb->pb_target->pbr_mapping, flags); error = _pagebuf_lookup_pages(pb, pb->pb_target->pbr_mapping, flags);
...@@ -766,7 +766,7 @@ pagebuf_get( /* allocate a buffer */ ...@@ -766,7 +766,7 @@ pagebuf_get( /* allocate a buffer */
if (flags & PBF_READ) { if (flags & PBF_READ) {
if (PBF_NOT_DONE(pb)) { if (PBF_NOT_DONE(pb)) {
PB_TRACE(pb, PB_TRACE_REC(get_read), flags); PB_TRACE(pb, PB_TRACE_REC(get_read), flags);
PB_STATS_INC(pbstats.pb_get_read); PB_STATS_INC(pb_get_read);
pagebuf_iostart(pb, flags); pagebuf_iostart(pb, flags);
} else if (flags & PBF_ASYNC) { } else if (flags & PBF_ASYNC) {
/* /*
......
...@@ -37,6 +37,7 @@ ...@@ -37,6 +37,7 @@
#ifndef __PAGE_BUF_PRIVATE_H__ #ifndef __PAGE_BUF_PRIVATE_H__
#define __PAGE_BUF_PRIVATE_H__ #define __PAGE_BUF_PRIVATE_H__
#include <linux/percpu.h>
#include "page_buf.h" #include "page_buf.h"
#define _PAGE_BUF_INTERNAL_ #define _PAGE_BUF_INTERNAL_
...@@ -120,9 +121,9 @@ struct pbstats { ...@@ -120,9 +121,9 @@ struct pbstats {
u_int32_t pb_get_read; u_int32_t pb_get_read;
}; };
extern struct pbstats pbstats; DECLARE_PER_CPU(struct pbstats, pbstats);
#define PB_STATS_INC(count) ( count ++ ) #define PB_STATS_INC(count) ( get_cpu_var(pbstats).count++ )
#ifndef STATIC #ifndef STATIC
# define STATIC static # define STATIC static
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment