/* Update an inode to indicate that a modification was made. This increases
* the change counter, updates the ctime to the current time, and optionally
- * updates the mtime. */
+ * updates the mtime. inode must already be locked. */
void bluesky_inode_update_ctime(BlueSkyInode *inode, gboolean update_mtime)
{
int64_t now = bluesky_get_current_time();
}
/* Allocate a fresh inode number which has not been used before within a
- * filesystem. */
+ * filesystem. fs must already be locked. */
uint64_t bluesky_fs_alloc_inode(BlueSkyFS *fs)
{
uint64_t inum;
- g_mutex_lock(fs->lock);
inum = fs->next_inum;
fs->next_inum++;
- g_mutex_unlock(fs->lock);
return inum;
}
/* Retrieve an inode from the filesystem. Eventually this will be a cache and
* so we might need to go fetch the inode from elsewhere; for now all
- * filesystem state is stored here. */
+ * filesystem state is stored here. inode is returned locked with a reference
+ * held. */
BlueSkyInode *bluesky_get_inode(BlueSkyFS *fs, uint64_t inum)
{
BlueSkyInode *inode = NULL;
g_mutex_lock(fs->lock);
inode = (BlueSkyInode *)g_hash_table_lookup(fs->inodes, &inum);
- g_mutex_unlock(fs->lock);
if (inode == NULL) {
bluesky_inode_fetch(fs, inum);
- g_mutex_lock(fs->lock);
inode = (BlueSkyInode *)g_hash_table_lookup(fs->inodes, &inum);
- g_mutex_unlock(fs->lock);
}
+ if (inode != NULL) {
+ g_mutex_lock(inode->lock);
+ bluesky_inode_ref(inode);
+ }
+
+ g_mutex_unlock(fs->lock);
+
return inode;
}
-/* Insert an inode into the filesystem inode cache. */
+/* Insert an inode into the filesystem inode cache. fs should be locked. */
void bluesky_insert_inode(BlueSkyFS *fs, BlueSkyInode *inode)
{
- g_mutex_lock(fs->lock);
g_hash_table_insert(fs->inodes, &inode->inum, inode);
- g_mutex_unlock(fs->lock);
}
/* Synchronize an inode to stable storage. */