提交 2908f5e1 编写于 作者: D David Howells

fscache: Add a cookie debug ID and use that in traces

Add a cookie debug ID and use that in traces and in procfiles rather than
displaying the (hashed) pointer to the cookie.  This is easier to correlate
and we don't lose anything when interpreting oops output since that shows
unhashed addresses and registers that aren't comparable to the hashed
values.

Changes:

ver #2:
 - Fix the fscache_op tracepoint to handle a NULL cookie pointer.
Signed-off-by: NDavid Howells <dhowells@redhat.com>
Reviewed-by: NJeff Layton <jlayton@redhat.com>
cc: linux-cachefs@redhat.com
Link: https://lore.kernel.org/r/158861210988.340223.11688464116498247790.stgit@warthog.procyon.org.uk/ # rfc
Link: https://lore.kernel.org/r/159465769844.1376105.14119502774019865432.stgit@warthog.procyon.org.uk/
Link: https://lore.kernel.org/r/160588459097.3465195.1273313637721852165.stgit@warthog.procyon.org.uk/ # rfc
Link: https://lore.kernel.org/r/162431193544.2908479.17556704572948300790.stgit@warthog.procyon.org.uk/
上级 18598195
...@@ -29,21 +29,29 @@ static int fscache_attach_object(struct fscache_cookie *cookie, ...@@ -29,21 +29,29 @@ static int fscache_attach_object(struct fscache_cookie *cookie,
static void fscache_print_cookie(struct fscache_cookie *cookie, char prefix) static void fscache_print_cookie(struct fscache_cookie *cookie, char prefix)
{ {
struct hlist_node *object; struct fscache_object *object;
struct hlist_node *o;
const u8 *k; const u8 *k;
unsigned loop; unsigned loop;
pr_err("%c-cookie c=%p [p=%p fl=%lx nc=%u na=%u]\n", pr_err("%c-cookie c=%08x [p=%08x fl=%lx nc=%u na=%u]\n",
prefix, cookie, cookie->parent, cookie->flags, prefix,
cookie->debug_id,
cookie->parent ? cookie->parent->debug_id : 0,
cookie->flags,
atomic_read(&cookie->n_children), atomic_read(&cookie->n_children),
atomic_read(&cookie->n_active)); atomic_read(&cookie->n_active));
pr_err("%c-cookie d=%p n=%p\n", pr_err("%c-cookie d=%p{%s} n=%p\n",
prefix, cookie->def, cookie->netfs_data); prefix,
cookie->def,
cookie->def ? cookie->def->name : "?",
cookie->netfs_data);
object = READ_ONCE(cookie->backing_objects.first); o = READ_ONCE(cookie->backing_objects.first);
if (object) if (o) {
pr_err("%c-cookie o=%p\n", object = hlist_entry(o, struct fscache_object, cookie_link);
prefix, hlist_entry(object, struct fscache_object, cookie_link)); pr_err("%c-cookie o=%u\n", prefix, object->debug_id);
}
pr_err("%c-key=[%u] '", prefix, cookie->key_len); pr_err("%c-key=[%u] '", prefix, cookie->key_len);
k = (cookie->key_len <= sizeof(cookie->inline_key)) ? k = (cookie->key_len <= sizeof(cookie->inline_key)) ?
...@@ -129,6 +137,8 @@ static long fscache_compare_cookie(const struct fscache_cookie *a, ...@@ -129,6 +137,8 @@ static long fscache_compare_cookie(const struct fscache_cookie *a,
return memcmp(ka, kb, a->key_len); return memcmp(ka, kb, a->key_len);
} }
static atomic_t fscache_cookie_debug_id = ATOMIC_INIT(1);
/* /*
* Allocate a cookie. * Allocate a cookie.
*/ */
...@@ -163,6 +173,7 @@ struct fscache_cookie *fscache_alloc_cookie( ...@@ -163,6 +173,7 @@ struct fscache_cookie *fscache_alloc_cookie(
atomic_set(&cookie->usage, 1); atomic_set(&cookie->usage, 1);
atomic_set(&cookie->n_children, 0); atomic_set(&cookie->n_children, 0);
cookie->debug_id = atomic_inc_return(&fscache_cookie_debug_id);
/* We keep the active count elevated until relinquishment to prevent an /* We keep the active count elevated until relinquishment to prevent an
* attempt to wake up every time the object operations queue quiesces. * attempt to wake up every time the object operations queue quiesces.
......
...@@ -45,6 +45,7 @@ static struct fscache_cookie_def fscache_fsdef_index_def = { ...@@ -45,6 +45,7 @@ static struct fscache_cookie_def fscache_fsdef_index_def = {
}; };
struct fscache_cookie fscache_fsdef_index = { struct fscache_cookie fscache_fsdef_index = {
.debug_id = 1,
.usage = ATOMIC_INIT(1), .usage = ATOMIC_INIT(1),
.n_active = ATOMIC_INIT(1), .n_active = ATOMIC_INIT(1),
.lock = __SPIN_LOCK_UNLOCKED(fscache_fsdef_index.lock), .lock = __SPIN_LOCK_UNLOCKED(fscache_fsdef_index.lock),
......
...@@ -170,7 +170,7 @@ static int fscache_objlist_show(struct seq_file *m, void *v) ...@@ -170,7 +170,7 @@ static int fscache_objlist_show(struct seq_file *m, void *v)
if ((unsigned long) v == 1) { if ((unsigned long) v == 1) {
seq_puts(m, "OBJECT PARENT STAT CHLDN OPS OOP IPR EX READS" seq_puts(m, "OBJECT PARENT STAT CHLDN OPS OOP IPR EX READS"
" EM EV FL S" " EM EV FL S"
" | NETFS_COOKIE_DEF TY FL NETFS_DATA"); " | COOKIE NETFS_COOKIE_DEF TY FL NETFS_DATA");
if (config & (FSCACHE_OBJLIST_CONFIG_KEY | if (config & (FSCACHE_OBJLIST_CONFIG_KEY |
FSCACHE_OBJLIST_CONFIG_AUX)) FSCACHE_OBJLIST_CONFIG_AUX))
seq_puts(m, " "); seq_puts(m, " ");
...@@ -189,7 +189,7 @@ static int fscache_objlist_show(struct seq_file *m, void *v) ...@@ -189,7 +189,7 @@ static int fscache_objlist_show(struct seq_file *m, void *v)
if ((unsigned long) v == 2) { if ((unsigned long) v == 2) {
seq_puts(m, "======== ======== ==== ===== === === === == =====" seq_puts(m, "======== ======== ==== ===== === === === == ====="
" == == == =" " == == == ="
" | ================ == == ================"); " | ======== ================ == === ================");
if (config & (FSCACHE_OBJLIST_CONFIG_KEY | if (config & (FSCACHE_OBJLIST_CONFIG_KEY |
FSCACHE_OBJLIST_CONFIG_AUX)) FSCACHE_OBJLIST_CONFIG_AUX))
seq_puts(m, " ================"); seq_puts(m, " ================");
...@@ -231,9 +231,9 @@ static int fscache_objlist_show(struct seq_file *m, void *v) ...@@ -231,9 +231,9 @@ static int fscache_objlist_show(struct seq_file *m, void *v)
} }
seq_printf(m, seq_printf(m,
"%8x %8x %s %5u %3u %3u %3u %2u %5u %2lx %2lx %2lx %1x | ", "%08x %08x %s %5u %3u %3u %3u %2u %5u %2lx %2lx %2lx %1x | ",
obj->debug_id, obj->debug_id,
obj->parent ? obj->parent->debug_id : -1, obj->parent ? obj->parent->debug_id : UINT_MAX,
obj->state->short_name, obj->state->short_name,
obj->n_children, obj->n_children,
obj->n_ops, obj->n_ops,
...@@ -246,7 +246,7 @@ static int fscache_objlist_show(struct seq_file *m, void *v) ...@@ -246,7 +246,7 @@ static int fscache_objlist_show(struct seq_file *m, void *v)
obj->flags, obj->flags,
work_busy(&obj->work)); work_busy(&obj->work));
if (fscache_use_cookie(obj)) { if (obj->cookie) {
uint16_t keylen = 0, auxlen = 0; uint16_t keylen = 0, auxlen = 0;
switch (cookie->type) { switch (cookie->type) {
...@@ -263,7 +263,8 @@ static int fscache_objlist_show(struct seq_file *m, void *v) ...@@ -263,7 +263,8 @@ static int fscache_objlist_show(struct seq_file *m, void *v)
break; break;
} }
seq_printf(m, "%-16s %s %2lx %16p", seq_printf(m, "%08x %-16s %s %3lx %16p",
cookie->debug_id,
cookie->def->name, cookie->def->name,
type, type,
cookie->flags, cookie->flags,
...@@ -292,7 +293,6 @@ static int fscache_objlist_show(struct seq_file *m, void *v) ...@@ -292,7 +293,6 @@ static int fscache_objlist_show(struct seq_file *m, void *v)
} }
seq_puts(m, "\n"); seq_puts(m, "\n");
fscache_unuse_cookie(obj);
} else { } else {
seq_puts(m, "<no_netfs>\n"); seq_puts(m, "<no_netfs>\n");
} }
......
...@@ -126,6 +126,7 @@ struct fscache_cookie { ...@@ -126,6 +126,7 @@ struct fscache_cookie {
atomic_t usage; /* number of users of this cookie */ atomic_t usage; /* number of users of this cookie */
atomic_t n_children; /* number of children of this cookie */ atomic_t n_children; /* number of children of this cookie */
atomic_t n_active; /* number of active users of netfs ptrs */ atomic_t n_active; /* number of active users of netfs ptrs */
unsigned int debug_id;
spinlock_t lock; spinlock_t lock;
spinlock_t stores_lock; /* lock on page store tree */ spinlock_t stores_lock; /* lock on page store tree */
struct hlist_head backing_objects; /* object(s) backing this file/index */ struct hlist_head backing_objects; /* object(s) backing this file/index */
......
...@@ -78,20 +78,20 @@ TRACE_EVENT(cachefiles_ref, ...@@ -78,20 +78,20 @@ TRACE_EVENT(cachefiles_ref,
/* Note that obj may be NULL */ /* Note that obj may be NULL */
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(enum cachefiles_obj_ref_trace, why ) __field(enum cachefiles_obj_ref_trace, why )
__field(int, usage ) __field(int, usage )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->usage = usage; __entry->usage = usage;
__entry->why = why; __entry->why = why;
), ),
TP_printk("c=%p o=%p u=%d %s", TP_printk("c=%08x o=%08x u=%d %s",
__entry->cookie, __entry->obj, __entry->usage, __entry->cookie, __entry->obj, __entry->usage,
__print_symbolic(__entry->why, cachefiles_obj_ref_traces)) __print_symbolic(__entry->why, cachefiles_obj_ref_traces))
); );
...@@ -104,18 +104,18 @@ TRACE_EVENT(cachefiles_lookup, ...@@ -104,18 +104,18 @@ TRACE_EVENT(cachefiles_lookup,
TP_ARGS(obj, de, inode), TP_ARGS(obj, de, inode),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(struct inode *, inode ) __field(struct inode *, inode )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->inode = inode; __entry->inode = inode;
), ),
TP_printk("o=%p d=%p i=%p", TP_printk("o=%08x d=%p i=%p",
__entry->obj, __entry->de, __entry->inode) __entry->obj, __entry->de, __entry->inode)
); );
...@@ -126,18 +126,18 @@ TRACE_EVENT(cachefiles_mkdir, ...@@ -126,18 +126,18 @@ TRACE_EVENT(cachefiles_mkdir,
TP_ARGS(obj, de, ret), TP_ARGS(obj, de, ret),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(int, ret ) __field(int, ret )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->ret = ret; __entry->ret = ret;
), ),
TP_printk("o=%p d=%p r=%u", TP_printk("o=%08x d=%p r=%u",
__entry->obj, __entry->de, __entry->ret) __entry->obj, __entry->de, __entry->ret)
); );
...@@ -148,18 +148,18 @@ TRACE_EVENT(cachefiles_create, ...@@ -148,18 +148,18 @@ TRACE_EVENT(cachefiles_create,
TP_ARGS(obj, de, ret), TP_ARGS(obj, de, ret),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(int, ret ) __field(int, ret )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->ret = ret; __entry->ret = ret;
), ),
TP_printk("o=%p d=%p r=%u", TP_printk("o=%08x d=%p r=%u",
__entry->obj, __entry->de, __entry->ret) __entry->obj, __entry->de, __entry->ret)
); );
...@@ -172,18 +172,18 @@ TRACE_EVENT(cachefiles_unlink, ...@@ -172,18 +172,18 @@ TRACE_EVENT(cachefiles_unlink,
/* Note that obj may be NULL */ /* Note that obj may be NULL */
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(enum fscache_why_object_killed, why ) __field(enum fscache_why_object_killed, why )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->why = why; __entry->why = why;
), ),
TP_printk("o=%p d=%p w=%s", TP_printk("o=%08x d=%p w=%s",
__entry->obj, __entry->de, __entry->obj, __entry->de,
__print_symbolic(__entry->why, cachefiles_obj_kill_traces)) __print_symbolic(__entry->why, cachefiles_obj_kill_traces))
); );
...@@ -198,20 +198,20 @@ TRACE_EVENT(cachefiles_rename, ...@@ -198,20 +198,20 @@ TRACE_EVENT(cachefiles_rename,
/* Note that obj may be NULL */ /* Note that obj may be NULL */
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(struct dentry *, to ) __field(struct dentry *, to )
__field(enum fscache_why_object_killed, why ) __field(enum fscache_why_object_killed, why )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->to = to; __entry->to = to;
__entry->why = why; __entry->why = why;
), ),
TP_printk("o=%p d=%p t=%p w=%s", TP_printk("o=%08x d=%p t=%p w=%s",
__entry->obj, __entry->de, __entry->to, __entry->obj, __entry->de, __entry->to,
__print_symbolic(__entry->why, cachefiles_obj_kill_traces)) __print_symbolic(__entry->why, cachefiles_obj_kill_traces))
); );
...@@ -224,16 +224,16 @@ TRACE_EVENT(cachefiles_mark_active, ...@@ -224,16 +224,16 @@ TRACE_EVENT(cachefiles_mark_active,
/* Note that obj may be NULL */ /* Note that obj may be NULL */
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
), ),
TP_printk("o=%p d=%p", TP_printk("o=%08x d=%p",
__entry->obj, __entry->de) __entry->obj, __entry->de)
); );
...@@ -246,22 +246,22 @@ TRACE_EVENT(cachefiles_wait_active, ...@@ -246,22 +246,22 @@ TRACE_EVENT(cachefiles_wait_active,
/* Note that obj may be NULL */ /* Note that obj may be NULL */
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(unsigned int, xobj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(struct cachefiles_object *, xobj )
__field(u16, flags ) __field(u16, flags )
__field(u16, fsc_flags ) __field(u16, fsc_flags )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->xobj = xobj; __entry->xobj = xobj->fscache.debug_id;
__entry->flags = xobj->flags; __entry->flags = xobj->flags;
__entry->fsc_flags = xobj->fscache.flags; __entry->fsc_flags = xobj->fscache.flags;
), ),
TP_printk("o=%p d=%p wo=%p wf=%x wff=%x", TP_printk("o=%08x d=%p wo=%08x wf=%x wff=%x",
__entry->obj, __entry->de, __entry->xobj, __entry->obj, __entry->de, __entry->xobj,
__entry->flags, __entry->fsc_flags) __entry->flags, __entry->fsc_flags)
); );
...@@ -275,18 +275,18 @@ TRACE_EVENT(cachefiles_mark_inactive, ...@@ -275,18 +275,18 @@ TRACE_EVENT(cachefiles_mark_inactive,
/* Note that obj may be NULL */ /* Note that obj may be NULL */
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(struct inode *, inode ) __field(struct inode *, inode )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->inode = inode; __entry->inode = inode;
), ),
TP_printk("o=%p d=%p i=%p", TP_printk("o=%08x d=%p i=%p",
__entry->obj, __entry->de, __entry->inode) __entry->obj, __entry->de, __entry->inode)
); );
...@@ -299,18 +299,18 @@ TRACE_EVENT(cachefiles_mark_buried, ...@@ -299,18 +299,18 @@ TRACE_EVENT(cachefiles_mark_buried,
/* Note that obj may be NULL */ /* Note that obj may be NULL */
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct cachefiles_object *, obj ) __field(unsigned int, obj )
__field(struct dentry *, de ) __field(struct dentry *, de )
__field(enum fscache_why_object_killed, why ) __field(enum fscache_why_object_killed, why )
), ),
TP_fast_assign( TP_fast_assign(
__entry->obj = obj; __entry->obj = obj->fscache.debug_id;
__entry->de = de; __entry->de = de;
__entry->why = why; __entry->why = why;
), ),
TP_printk("o=%p d=%p w=%s", TP_printk("o=%08x d=%p w=%s",
__entry->obj, __entry->de, __entry->obj, __entry->de,
__print_symbolic(__entry->why, cachefiles_obj_kill_traces)) __print_symbolic(__entry->why, cachefiles_obj_kill_traces))
); );
......
...@@ -167,8 +167,8 @@ TRACE_EVENT(fscache_cookie, ...@@ -167,8 +167,8 @@ TRACE_EVENT(fscache_cookie,
TP_ARGS(cookie, where, usage), TP_ARGS(cookie, where, usage),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(struct fscache_cookie *, parent ) __field(unsigned int, parent )
__field(enum fscache_cookie_trace, where ) __field(enum fscache_cookie_trace, where )
__field(int, usage ) __field(int, usage )
__field(int, n_children ) __field(int, n_children )
...@@ -177,8 +177,8 @@ TRACE_EVENT(fscache_cookie, ...@@ -177,8 +177,8 @@ TRACE_EVENT(fscache_cookie,
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->parent = cookie->parent; __entry->parent = cookie->parent ? cookie->parent->debug_id : 0;
__entry->where = where; __entry->where = where;
__entry->usage = usage; __entry->usage = usage;
__entry->n_children = atomic_read(&cookie->n_children); __entry->n_children = atomic_read(&cookie->n_children);
...@@ -186,7 +186,7 @@ TRACE_EVENT(fscache_cookie, ...@@ -186,7 +186,7 @@ TRACE_EVENT(fscache_cookie,
__entry->flags = cookie->flags; __entry->flags = cookie->flags;
), ),
TP_printk("%s c=%p u=%d p=%p Nc=%d Na=%d f=%02x", TP_printk("%s c=%08x u=%d p=%08x Nc=%d Na=%d f=%02x",
__print_symbolic(__entry->where, fscache_cookie_traces), __print_symbolic(__entry->where, fscache_cookie_traces),
__entry->cookie, __entry->usage, __entry->cookie, __entry->usage,
__entry->parent, __entry->n_children, __entry->n_active, __entry->parent, __entry->n_children, __entry->n_active,
...@@ -199,17 +199,17 @@ TRACE_EVENT(fscache_netfs, ...@@ -199,17 +199,17 @@ TRACE_EVENT(fscache_netfs,
TP_ARGS(netfs), TP_ARGS(netfs),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__array(char, name, 8 ) __array(char, name, 8 )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = netfs->primary_index; __entry->cookie = netfs->primary_index->debug_id;
strncpy(__entry->name, netfs->name, 8); strncpy(__entry->name, netfs->name, 8);
__entry->name[7] = 0; __entry->name[7] = 0;
), ),
TP_printk("c=%p n=%s", TP_printk("c=%08x n=%s",
__entry->cookie, __entry->name) __entry->cookie, __entry->name)
); );
...@@ -219,8 +219,8 @@ TRACE_EVENT(fscache_acquire, ...@@ -219,8 +219,8 @@ TRACE_EVENT(fscache_acquire,
TP_ARGS(cookie), TP_ARGS(cookie),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(struct fscache_cookie *, parent ) __field(unsigned int, parent )
__array(char, name, 8 ) __array(char, name, 8 )
__field(int, p_usage ) __field(int, p_usage )
__field(int, p_n_children ) __field(int, p_n_children )
...@@ -228,8 +228,8 @@ TRACE_EVENT(fscache_acquire, ...@@ -228,8 +228,8 @@ TRACE_EVENT(fscache_acquire,
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->parent = cookie->parent; __entry->parent = cookie->parent->debug_id;
__entry->p_usage = atomic_read(&cookie->parent->usage); __entry->p_usage = atomic_read(&cookie->parent->usage);
__entry->p_n_children = atomic_read(&cookie->parent->n_children); __entry->p_n_children = atomic_read(&cookie->parent->n_children);
__entry->p_flags = cookie->parent->flags; __entry->p_flags = cookie->parent->flags;
...@@ -237,7 +237,7 @@ TRACE_EVENT(fscache_acquire, ...@@ -237,7 +237,7 @@ TRACE_EVENT(fscache_acquire,
__entry->name[7] = 0; __entry->name[7] = 0;
), ),
TP_printk("c=%p p=%p pu=%d pc=%d pf=%02x n=%s", TP_printk("c=%08x p=%08x pu=%d pc=%d pf=%02x n=%s",
__entry->cookie, __entry->parent, __entry->p_usage, __entry->cookie, __entry->parent, __entry->p_usage,
__entry->p_n_children, __entry->p_flags, __entry->name) __entry->p_n_children, __entry->p_flags, __entry->name)
); );
...@@ -248,8 +248,8 @@ TRACE_EVENT(fscache_relinquish, ...@@ -248,8 +248,8 @@ TRACE_EVENT(fscache_relinquish,
TP_ARGS(cookie, retire), TP_ARGS(cookie, retire),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(struct fscache_cookie *, parent ) __field(unsigned int, parent )
__field(int, usage ) __field(int, usage )
__field(int, n_children ) __field(int, n_children )
__field(int, n_active ) __field(int, n_active )
...@@ -258,8 +258,8 @@ TRACE_EVENT(fscache_relinquish, ...@@ -258,8 +258,8 @@ TRACE_EVENT(fscache_relinquish,
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->parent = cookie->parent; __entry->parent = cookie->parent->debug_id;
__entry->usage = atomic_read(&cookie->usage); __entry->usage = atomic_read(&cookie->usage);
__entry->n_children = atomic_read(&cookie->n_children); __entry->n_children = atomic_read(&cookie->n_children);
__entry->n_active = atomic_read(&cookie->n_active); __entry->n_active = atomic_read(&cookie->n_active);
...@@ -267,7 +267,7 @@ TRACE_EVENT(fscache_relinquish, ...@@ -267,7 +267,7 @@ TRACE_EVENT(fscache_relinquish,
__entry->retire = retire; __entry->retire = retire;
), ),
TP_printk("c=%p u=%d p=%p Nc=%d Na=%d f=%02x r=%u", TP_printk("c=%08x u=%d p=%08x Nc=%d Na=%d f=%02x r=%u",
__entry->cookie, __entry->usage, __entry->cookie, __entry->usage,
__entry->parent, __entry->n_children, __entry->n_active, __entry->parent, __entry->n_children, __entry->n_active,
__entry->flags, __entry->retire) __entry->flags, __entry->retire)
...@@ -279,7 +279,7 @@ TRACE_EVENT(fscache_enable, ...@@ -279,7 +279,7 @@ TRACE_EVENT(fscache_enable,
TP_ARGS(cookie), TP_ARGS(cookie),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(int, usage ) __field(int, usage )
__field(int, n_children ) __field(int, n_children )
__field(int, n_active ) __field(int, n_active )
...@@ -287,14 +287,14 @@ TRACE_EVENT(fscache_enable, ...@@ -287,14 +287,14 @@ TRACE_EVENT(fscache_enable,
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->usage = atomic_read(&cookie->usage); __entry->usage = atomic_read(&cookie->usage);
__entry->n_children = atomic_read(&cookie->n_children); __entry->n_children = atomic_read(&cookie->n_children);
__entry->n_active = atomic_read(&cookie->n_active); __entry->n_active = atomic_read(&cookie->n_active);
__entry->flags = cookie->flags; __entry->flags = cookie->flags;
), ),
TP_printk("c=%p u=%d Nc=%d Na=%d f=%02x", TP_printk("c=%08x u=%d Nc=%d Na=%d f=%02x",
__entry->cookie, __entry->usage, __entry->cookie, __entry->usage,
__entry->n_children, __entry->n_active, __entry->flags) __entry->n_children, __entry->n_active, __entry->flags)
); );
...@@ -305,7 +305,7 @@ TRACE_EVENT(fscache_disable, ...@@ -305,7 +305,7 @@ TRACE_EVENT(fscache_disable,
TP_ARGS(cookie), TP_ARGS(cookie),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(int, usage ) __field(int, usage )
__field(int, n_children ) __field(int, n_children )
__field(int, n_active ) __field(int, n_active )
...@@ -313,14 +313,14 @@ TRACE_EVENT(fscache_disable, ...@@ -313,14 +313,14 @@ TRACE_EVENT(fscache_disable,
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->usage = atomic_read(&cookie->usage); __entry->usage = atomic_read(&cookie->usage);
__entry->n_children = atomic_read(&cookie->n_children); __entry->n_children = atomic_read(&cookie->n_children);
__entry->n_active = atomic_read(&cookie->n_active); __entry->n_active = atomic_read(&cookie->n_active);
__entry->flags = cookie->flags; __entry->flags = cookie->flags;
), ),
TP_printk("c=%p u=%d Nc=%d Na=%d f=%02x", TP_printk("c=%08x u=%d Nc=%d Na=%d f=%02x",
__entry->cookie, __entry->usage, __entry->cookie, __entry->usage,
__entry->n_children, __entry->n_active, __entry->flags) __entry->n_children, __entry->n_active, __entry->flags)
); );
...@@ -333,8 +333,8 @@ TRACE_EVENT(fscache_osm, ...@@ -333,8 +333,8 @@ TRACE_EVENT(fscache_osm,
TP_ARGS(object, state, wait, oob, event_num), TP_ARGS(object, state, wait, oob, event_num),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(struct fscache_object *, object ) __field(unsigned int, object )
__array(char, state, 8 ) __array(char, state, 8 )
__field(bool, wait ) __field(bool, wait )
__field(bool, oob ) __field(bool, oob )
...@@ -342,15 +342,15 @@ TRACE_EVENT(fscache_osm, ...@@ -342,15 +342,15 @@ TRACE_EVENT(fscache_osm,
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = object->cookie; __entry->cookie = object->cookie->debug_id;
__entry->object = object; __entry->object = object->debug_id;
__entry->wait = wait; __entry->wait = wait;
__entry->oob = oob; __entry->oob = oob;
__entry->event_num = event_num; __entry->event_num = event_num;
memcpy(__entry->state, state->short_name, 8); memcpy(__entry->state, state->short_name, 8);
), ),
TP_printk("c=%p o=%p %s %s%sev=%d", TP_printk("c=%08x o=%08d %s %s%sev=%d",
__entry->cookie, __entry->cookie,
__entry->object, __entry->object,
__entry->state, __entry->state,
...@@ -370,18 +370,18 @@ TRACE_EVENT(fscache_page, ...@@ -370,18 +370,18 @@ TRACE_EVENT(fscache_page,
TP_ARGS(cookie, page, why), TP_ARGS(cookie, page, why),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(pgoff_t, page ) __field(pgoff_t, page )
__field(enum fscache_page_trace, why ) __field(enum fscache_page_trace, why )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->page = page->index; __entry->page = page->index;
__entry->why = why; __entry->why = why;
), ),
TP_printk("c=%p %s pg=%lx", TP_printk("c=%08x %s pg=%lx",
__entry->cookie, __entry->cookie,
__print_symbolic(__entry->why, fscache_page_traces), __print_symbolic(__entry->why, fscache_page_traces),
__entry->page) __entry->page)
...@@ -394,20 +394,20 @@ TRACE_EVENT(fscache_check_page, ...@@ -394,20 +394,20 @@ TRACE_EVENT(fscache_check_page,
TP_ARGS(cookie, page, val, n), TP_ARGS(cookie, page, val, n),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(void *, page ) __field(void *, page )
__field(void *, val ) __field(void *, val )
__field(int, n ) __field(int, n )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->page = page; __entry->page = page;
__entry->val = val; __entry->val = val;
__entry->n = n; __entry->n = n;
), ),
TP_printk("c=%p pg=%p val=%p n=%d", TP_printk("c=%08x pg=%p val=%p n=%d",
__entry->cookie, __entry->page, __entry->val, __entry->n) __entry->cookie, __entry->page, __entry->val, __entry->n)
); );
...@@ -417,14 +417,14 @@ TRACE_EVENT(fscache_wake_cookie, ...@@ -417,14 +417,14 @@ TRACE_EVENT(fscache_wake_cookie,
TP_ARGS(cookie), TP_ARGS(cookie),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
), ),
TP_printk("c=%p", __entry->cookie) TP_printk("c=%08x", __entry->cookie)
); );
TRACE_EVENT(fscache_op, TRACE_EVENT(fscache_op,
...@@ -434,18 +434,18 @@ TRACE_EVENT(fscache_op, ...@@ -434,18 +434,18 @@ TRACE_EVENT(fscache_op,
TP_ARGS(cookie, op, why), TP_ARGS(cookie, op, why),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(struct fscache_operation *, op ) __field(unsigned int, op )
__field(enum fscache_op_trace, why ) __field(enum fscache_op_trace, why )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie ? cookie->debug_id : 0;
__entry->op = op; __entry->op = op->debug_id;
__entry->why = why; __entry->why = why;
), ),
TP_printk("c=%p op=%p %s", TP_printk("c=%08x op=%08x %s",
__entry->cookie, __entry->op, __entry->cookie, __entry->op,
__print_symbolic(__entry->why, fscache_op_traces)) __print_symbolic(__entry->why, fscache_op_traces))
); );
...@@ -457,20 +457,20 @@ TRACE_EVENT(fscache_page_op, ...@@ -457,20 +457,20 @@ TRACE_EVENT(fscache_page_op,
TP_ARGS(cookie, page, op, what), TP_ARGS(cookie, page, op, what),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(unsigned int, op )
__field(pgoff_t, page ) __field(pgoff_t, page )
__field(struct fscache_operation *, op )
__field(enum fscache_page_op_trace, what ) __field(enum fscache_page_op_trace, what )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->page = page ? page->index : 0; __entry->page = page ? page->index : 0;
__entry->op = op; __entry->op = op->debug_id;
__entry->what = what; __entry->what = what;
), ),
TP_printk("c=%p %s pg=%lx op=%p", TP_printk("c=%08x %s pg=%lx op=%08x",
__entry->cookie, __entry->cookie,
__print_symbolic(__entry->what, fscache_page_op_traces), __print_symbolic(__entry->what, fscache_page_op_traces),
__entry->page, __entry->op) __entry->page, __entry->op)
...@@ -483,20 +483,20 @@ TRACE_EVENT(fscache_wrote_page, ...@@ -483,20 +483,20 @@ TRACE_EVENT(fscache_wrote_page,
TP_ARGS(cookie, page, op, ret), TP_ARGS(cookie, page, op, ret),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(unsigned int, op )
__field(pgoff_t, page ) __field(pgoff_t, page )
__field(struct fscache_operation *, op )
__field(int, ret ) __field(int, ret )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->page = page->index; __entry->page = page->index;
__entry->op = op; __entry->op = op->debug_id;
__entry->ret = ret; __entry->ret = ret;
), ),
TP_printk("c=%p pg=%lx op=%p ret=%d", TP_printk("c=%08x pg=%lx op=%08x ret=%d",
__entry->cookie, __entry->page, __entry->op, __entry->ret) __entry->cookie, __entry->page, __entry->op, __entry->ret)
); );
...@@ -507,22 +507,22 @@ TRACE_EVENT(fscache_gang_lookup, ...@@ -507,22 +507,22 @@ TRACE_EVENT(fscache_gang_lookup,
TP_ARGS(cookie, op, results, n, store_limit), TP_ARGS(cookie, op, results, n, store_limit),
TP_STRUCT__entry( TP_STRUCT__entry(
__field(struct fscache_cookie *, cookie ) __field(unsigned int, cookie )
__field(struct fscache_operation *, op ) __field(unsigned int, op )
__field(pgoff_t, results0 ) __field(pgoff_t, results0 )
__field(int, n ) __field(int, n )
__field(pgoff_t, store_limit ) __field(pgoff_t, store_limit )
), ),
TP_fast_assign( TP_fast_assign(
__entry->cookie = cookie; __entry->cookie = cookie->debug_id;
__entry->op = op; __entry->op = op->debug_id;
__entry->results0 = results[0] ? ((struct page *)results[0])->index : (pgoff_t)-1; __entry->results0 = results[0] ? ((struct page *)results[0])->index : (pgoff_t)-1;
__entry->n = n; __entry->n = n;
__entry->store_limit = store_limit; __entry->store_limit = store_limit;
), ),
TP_printk("c=%p op=%p r0=%lx n=%d sl=%lx", TP_printk("c=%08x op=%08x r0=%lx n=%d sl=%lx",
__entry->cookie, __entry->op, __entry->results0, __entry->n, __entry->cookie, __entry->op, __entry->results0, __entry->n,
__entry->store_limit) __entry->store_limit)
); );
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册