+ sprintf(key, "inode-%016"PRIx64, inum);
+ BlueSkyRCStr *data = bluesky_store_get(fs->store, key);
+ if (data == NULL)
+ return;
+
+ BlueSkyInode *inode = bluesky_new_inode(inum, fs, BLUESKY_PENDING);
+ bluesky_inode_ref(inode);
+ g_mutex_lock(inode->lock);
+ bluesky_insert_inode(fs, inode);
+
+ if (!bluesky_deserialize_inode(inode, data->data)) {
+ g_hash_table_remove(fs->inodes, &inode->inum);
+ bluesky_inode_unref(inode);
+ }
+
+ g_mutex_unlock(inode->lock);
+ bluesky_inode_unref(inode);
+}
+
+/* Synchronize filesystem superblock to stable storage. */
+void bluesky_superblock_flush(BlueSkyFS *fs)
+{
+ GString *buf = g_string_new("");
+ bluesky_serialize_superblock(buf, fs);
+ BlueSkyRCStr *data = bluesky_string_new_from_gstring(buf);
+
+ BlueSkyStoreAsync *async = bluesky_store_async_new(fs->store);
+ async->op = STORE_OP_PUT;
+ async->key = g_strdup("superblock");
+ async->data = data;
+ bluesky_store_async_submit(async);
+ bluesky_store_async_unref(async);