X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=bluesky%2Fdebug.c;h=207cb7b8031b5586d3a7963c178236d3c99d5cad;hb=97517d1bbc647846003d1a49b6ae97c69d856b90;hp=43b29be1d25a036fffe0284f6a60e1762c55cc3d;hpb=4a207da5eef9f87a702a011d003d5ad17b651085;p=bluesky.git diff --git a/bluesky/debug.c b/bluesky/debug.c index 43b29be..207cb7b 100644 --- a/bluesky/debug.c +++ b/bluesky/debug.c @@ -51,10 +51,23 @@ static void cloudlog_dump(gpointer key, gpointer value, gpointer user_data) log->location.sequence, log->location.offset); } +static void cache_dump(gpointer key, gpointer value, gpointer user_data) +{ + BlueSkyCacheFile *cache = (BlueSkyCacheFile *)value; + + int64_t age = bluesky_get_current_time() - cache->atime; + g_print("%s addr=%p mapcount=%d refcount=%d atime_age=%f", + cache->filename, cache->addr, cache->mapcount, cache->refcount, + age / 1e6); + if (cache->fetching) + g_print(" (fetching)"); + g_print("\n"); +} + /* Dump a summary of filesystem state as it is cached in memory. */ void bluesky_debug_dump(BlueSkyFS *fs) { - g_print("*** DEBUG DUMP FOR FILESYSTEM %s ***\n", fs->name); + g_print("\n*** DEBUG DUMP FOR FILESYSTEM %s ***\n", fs->name); g_print("Dirty blocks: %d\n", g_atomic_int_get(&fs->cache_dirty)); g_print("Cached inodes: %u\tNext inode: %"PRIu64"\n", g_hash_table_size(fs->inodes), fs->next_inum); @@ -85,6 +98,9 @@ void bluesky_debug_dump(BlueSkyFS *fs) g_print("\nLog Objects:\n"); g_hash_table_foreach(fs->locations, cloudlog_dump, fs); + + g_print("\nJournal/Cache Files:\n"); + g_hash_table_foreach(fs->log->mmap_cache, cache_dump, fs); g_print("\n"); }