X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=bluesky%2Fdebug.c;h=77df84556f719fde77a856c83ecff48cf46127ae;hb=a82b60b3b683840a7074110831bcbaa16a40f0eb;hp=9d875bdf7342cb04cb47f9e46f4d2e7cd226ed2b;hpb=8ab9f6acce5bbc6e56d2f3fa1833be06faf46770;p=bluesky.git diff --git a/bluesky/debug.c b/bluesky/debug.c index 9d875bd..77df845 100644 --- a/bluesky/debug.c +++ b/bluesky/debug.c @@ -55,13 +55,36 @@ static void cache_dump(gpointer key, gpointer value, gpointer user_data) { BlueSkyCacheFile *cache = (BlueSkyCacheFile *)value; - g_print("%s addr=%p mapcount=%d", - cache->filename, cache->addr, cache->mapcount); + 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"); } + +void inode_map_dump(GSequence *inode_map) +{ + GSequenceIter *i, *j; + + g_print("\nInode map dump:\n"); + for (i = g_sequence_get_begin_iter(inode_map); + !g_sequence_iter_is_end(i); i = g_sequence_iter_next(i)) + { + InodeMapRange *range = (InodeMapRange *)g_sequence_get(i); + + g_print(" Range [%"PRIu64", %"PRIu64"]\n", range->start, range->end); + + for (j = g_sequence_get_begin_iter(range->map_entries); + !g_sequence_iter_is_end(j); j = g_sequence_iter_next(j)) + { + InodeMapEntry *entry = (InodeMapEntry *)g_sequence_get(j); + g_print(" Entry %"PRIu64"\n", entry->inum); + } + } +} /* Dump a summary of filesystem state as it is cached in memory. */ void bluesky_debug_dump(BlueSkyFS *fs) { @@ -100,6 +123,10 @@ void bluesky_debug_dump(BlueSkyFS *fs) g_print("\nJournal/Cache Files:\n"); g_hash_table_foreach(fs->log->mmap_cache, cache_dump, fs); g_print("\n"); + + g_mutex_lock(fs->lock); + inode_map_dump(fs->inode_map); + g_mutex_unlock(fs->lock); } /* Statistics counters: for operation counts, bytes transferred, etc. */