|
@@ -284,6 +284,37 @@ int ocfs2_journal_dirty(handle_t *handle,
|
|
/* extended attribute block update */
|
|
/* extended attribute block update */
|
|
#define OCFS2_XATTR_BLOCK_UPDATE_CREDITS 1
|
|
#define OCFS2_XATTR_BLOCK_UPDATE_CREDITS 1
|
|
|
|
|
|
|
|
+/* global quotafile inode update, data block */
|
|
|
|
+#define OCFS2_QINFO_WRITE_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 1)
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * The two writes below can accidentally see global info dirty due
|
|
|
|
+ * to set_info() quotactl so make them prepared for the writes.
|
|
|
|
+ */
|
|
|
|
+/* quota data block, global info */
|
|
|
|
+/* Write to local quota file */
|
|
|
|
+#define OCFS2_QWRITE_CREDITS (OCFS2_QINFO_WRITE_CREDITS + 1)
|
|
|
|
+
|
|
|
|
+/* global quota data block, local quota data block, global quota inode,
|
|
|
|
+ * global quota info */
|
|
|
|
+#define OCFS2_QSYNC_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 3)
|
|
|
|
+
|
|
|
|
+static inline int ocfs2_quota_trans_credits(struct super_block *sb)
|
|
|
|
+{
|
|
|
|
+ int credits = 0;
|
|
|
|
+
|
|
|
|
+ if (OCFS2_HAS_RO_COMPAT_FEATURE(sb, OCFS2_FEATURE_RO_COMPAT_USRQUOTA))
|
|
|
|
+ credits += OCFS2_QWRITE_CREDITS;
|
|
|
|
+ if (OCFS2_HAS_RO_COMPAT_FEATURE(sb, OCFS2_FEATURE_RO_COMPAT_GRPQUOTA))
|
|
|
|
+ credits += OCFS2_QWRITE_CREDITS;
|
|
|
|
+ return credits;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+/* Number of credits needed for removing quota structure from file */
|
|
|
|
+int ocfs2_calc_qdel_credits(struct super_block *sb, int type);
|
|
|
|
+/* Number of credits needed for initialization of new quota structure */
|
|
|
|
+int ocfs2_calc_qinit_credits(struct super_block *sb, int type);
|
|
|
|
+
|
|
/* group extend. inode update and last group update. */
|
|
/* group extend. inode update and last group update. */
|
|
#define OCFS2_GROUP_EXTEND_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 1)
|
|
#define OCFS2_GROUP_EXTEND_CREDITS (OCFS2_INODE_UPDATE_CREDITS + 1)
|
|
|
|
|
|
@@ -294,8 +325,11 @@ int ocfs2_journal_dirty(handle_t *handle,
|
|
* prev. group desc. if we relink. */
|
|
* prev. group desc. if we relink. */
|
|
#define OCFS2_SUBALLOC_ALLOC (3)
|
|
#define OCFS2_SUBALLOC_ALLOC (3)
|
|
|
|
|
|
-#define OCFS2_INLINE_TO_EXTENTS_CREDITS (OCFS2_SUBALLOC_ALLOC \
|
|
|
|
- + OCFS2_INODE_UPDATE_CREDITS)
|
|
|
|
|
|
+static inline int ocfs2_inline_to_extents_credits(struct super_block *sb)
|
|
|
|
+{
|
|
|
|
+ return OCFS2_SUBALLOC_ALLOC + OCFS2_INODE_UPDATE_CREDITS +
|
|
|
|
+ ocfs2_quota_trans_credits(sb);
|
|
|
|
+}
|
|
|
|
|
|
/* dinode + group descriptor update. We don't relink on free yet. */
|
|
/* dinode + group descriptor update. We don't relink on free yet. */
|
|
#define OCFS2_SUBALLOC_FREE (2)
|
|
#define OCFS2_SUBALLOC_FREE (2)
|
|
@@ -304,16 +338,23 @@ int ocfs2_journal_dirty(handle_t *handle,
|
|
#define OCFS2_TRUNCATE_LOG_FLUSH_ONE_REC (OCFS2_SUBALLOC_FREE \
|
|
#define OCFS2_TRUNCATE_LOG_FLUSH_ONE_REC (OCFS2_SUBALLOC_FREE \
|
|
+ OCFS2_TRUNCATE_LOG_UPDATE)
|
|
+ OCFS2_TRUNCATE_LOG_UPDATE)
|
|
|
|
|
|
-#define OCFS2_REMOVE_EXTENT_CREDITS (OCFS2_TRUNCATE_LOG_UPDATE + OCFS2_INODE_UPDATE_CREDITS)
|
|
|
|
|
|
+static inline int ocfs2_remove_extent_credits(struct super_block *sb)
|
|
|
|
+{
|
|
|
|
+ return OCFS2_TRUNCATE_LOG_UPDATE + OCFS2_INODE_UPDATE_CREDITS +
|
|
|
|
+ ocfs2_quota_trans_credits(sb);
|
|
|
|
+}
|
|
|
|
|
|
/* data block for new dir/symlink, 2 for bitmap updates (bitmap fe +
|
|
/* data block for new dir/symlink, 2 for bitmap updates (bitmap fe +
|
|
* bitmap block for the new bit) */
|
|
* bitmap block for the new bit) */
|
|
#define OCFS2_DIR_LINK_ADDITIONAL_CREDITS (1 + 2)
|
|
#define OCFS2_DIR_LINK_ADDITIONAL_CREDITS (1 + 2)
|
|
|
|
|
|
/* parent fe, parent block, new file entry, inode alloc fe, inode alloc
|
|
/* parent fe, parent block, new file entry, inode alloc fe, inode alloc
|
|
- * group descriptor + mkdir/symlink blocks */
|
|
|
|
-#define OCFS2_MKNOD_CREDITS (3 + OCFS2_SUBALLOC_ALLOC \
|
|
|
|
- + OCFS2_DIR_LINK_ADDITIONAL_CREDITS)
|
|
|
|
|
|
+ * group descriptor + mkdir/symlink blocks + quota update */
|
|
|
|
+static inline int ocfs2_mknod_credits(struct super_block *sb)
|
|
|
|
+{
|
|
|
|
+ return 3 + OCFS2_SUBALLOC_ALLOC + OCFS2_DIR_LINK_ADDITIONAL_CREDITS +
|
|
|
|
+ ocfs2_quota_trans_credits(sb);
|
|
|
|
+}
|
|
|
|
|
|
/* local alloc metadata change + main bitmap updates */
|
|
/* local alloc metadata change + main bitmap updates */
|
|
#define OCFS2_WINDOW_MOVE_CREDITS (OCFS2_INODE_UPDATE_CREDITS \
|
|
#define OCFS2_WINDOW_MOVE_CREDITS (OCFS2_INODE_UPDATE_CREDITS \
|
|
@@ -323,13 +364,21 @@ int ocfs2_journal_dirty(handle_t *handle,
|
|
* for the dinode, one for the new block. */
|
|
* for the dinode, one for the new block. */
|
|
#define OCFS2_SIMPLE_DIR_EXTEND_CREDITS (2)
|
|
#define OCFS2_SIMPLE_DIR_EXTEND_CREDITS (2)
|
|
|
|
|
|
-/* file update (nlink, etc) + directory mtime/ctime + dir entry block */
|
|
|
|
-#define OCFS2_LINK_CREDITS (2*OCFS2_INODE_UPDATE_CREDITS + 1)
|
|
|
|
|
|
+/* file update (nlink, etc) + directory mtime/ctime + dir entry block + quota
|
|
|
|
+ * update on dir */
|
|
|
|
+static inline int ocfs2_link_credits(struct super_block *sb)
|
|
|
|
+{
|
|
|
|
+ return 2*OCFS2_INODE_UPDATE_CREDITS + 1 +
|
|
|
|
+ ocfs2_quota_trans_credits(sb);
|
|
|
|
+}
|
|
|
|
|
|
/* inode + dir inode (if we unlink a dir), + dir entry block + orphan
|
|
/* inode + dir inode (if we unlink a dir), + dir entry block + orphan
|
|
* dir inode link */
|
|
* dir inode link */
|
|
-#define OCFS2_UNLINK_CREDITS (2 * OCFS2_INODE_UPDATE_CREDITS + 1 \
|
|
|
|
- + OCFS2_LINK_CREDITS)
|
|
|
|
|
|
+static inline int ocfs2_unlink_credits(struct super_block *sb)
|
|
|
|
+{
|
|
|
|
+ /* The quota update from ocfs2_link_credits is unused here... */
|
|
|
|
+ return 2 * OCFS2_INODE_UPDATE_CREDITS + 1 + ocfs2_link_credits(sb);
|
|
|
|
+}
|
|
|
|
|
|
/* dinode + orphan dir dinode + inode alloc dinode + orphan dir entry +
|
|
/* dinode + orphan dir dinode + inode alloc dinode + orphan dir entry +
|
|
* inode alloc group descriptor */
|
|
* inode alloc group descriptor */
|
|
@@ -338,8 +387,10 @@ int ocfs2_journal_dirty(handle_t *handle,
|
|
/* dinode update, old dir dinode update, new dir dinode update, old
|
|
/* dinode update, old dir dinode update, new dir dinode update, old
|
|
* dir dir entry, new dir dir entry, dir entry update for renaming
|
|
* dir dir entry, new dir dir entry, dir entry update for renaming
|
|
* directory + target unlink */
|
|
* directory + target unlink */
|
|
-#define OCFS2_RENAME_CREDITS (3 * OCFS2_INODE_UPDATE_CREDITS + 3 \
|
|
|
|
- + OCFS2_UNLINK_CREDITS)
|
|
|
|
|
|
+static inline int ocfs2_rename_credits(struct super_block *sb)
|
|
|
|
+{
|
|
|
|
+ return 3 * OCFS2_INODE_UPDATE_CREDITS + 3 + ocfs2_unlink_credits(sb);
|
|
|
|
+}
|
|
|
|
|
|
/* global bitmap dinode, group desc., relinked group,
|
|
/* global bitmap dinode, group desc., relinked group,
|
|
* suballocator dinode, group desc., relinked group,
|
|
* suballocator dinode, group desc., relinked group,
|
|
@@ -377,18 +428,19 @@ static inline int ocfs2_calc_extend_credits(struct super_block *sb,
|
|
* credit for the dinode there. */
|
|
* credit for the dinode there. */
|
|
extent_blocks = 1 + 1 + le16_to_cpu(root_el->l_tree_depth);
|
|
extent_blocks = 1 + 1 + le16_to_cpu(root_el->l_tree_depth);
|
|
|
|
|
|
- return bitmap_blocks + sysfile_bitmap_blocks + extent_blocks;
|
|
|
|
|
|
+ return bitmap_blocks + sysfile_bitmap_blocks + extent_blocks +
|
|
|
|
+ ocfs2_quota_trans_credits(sb);
|
|
}
|
|
}
|
|
|
|
|
|
static inline int ocfs2_calc_symlink_credits(struct super_block *sb)
|
|
static inline int ocfs2_calc_symlink_credits(struct super_block *sb)
|
|
{
|
|
{
|
|
- int blocks = OCFS2_MKNOD_CREDITS;
|
|
|
|
|
|
+ int blocks = ocfs2_mknod_credits(sb);
|
|
|
|
|
|
/* links can be longer than one block so we may update many
|
|
/* links can be longer than one block so we may update many
|
|
* within our single allocated extent. */
|
|
* within our single allocated extent. */
|
|
blocks += ocfs2_clusters_to_blocks(sb, 1);
|
|
blocks += ocfs2_clusters_to_blocks(sb, 1);
|
|
|
|
|
|
- return blocks;
|
|
|
|
|
|
+ return blocks + ocfs2_quota_trans_credits(sb);
|
|
}
|
|
}
|
|
|
|
|
|
static inline int ocfs2_calc_group_alloc_credits(struct super_block *sb,
|
|
static inline int ocfs2_calc_group_alloc_credits(struct super_block *sb,
|
|
@@ -425,6 +477,8 @@ static inline int ocfs2_calc_tree_trunc_credits(struct super_block *sb,
|
|
/* update to the truncate log. */
|
|
/* update to the truncate log. */
|
|
credits += OCFS2_TRUNCATE_LOG_UPDATE;
|
|
credits += OCFS2_TRUNCATE_LOG_UPDATE;
|
|
|
|
|
|
|
|
+ credits += ocfs2_quota_trans_credits(sb);
|
|
|
|
+
|
|
return credits;
|
|
return credits;
|
|
}
|
|
}
|
|
|
|
|