Clean up the computations in gfs2_write_revokes (no change in functionality).

Signed-off-by: Andreas Gruenbacher <agrue...@redhat.com>
---
 fs/gfs2/log.c | 7 ++++---
 1 file changed, 4 insertions(+), 3 deletions(-)

diff --git a/fs/gfs2/log.c b/fs/gfs2/log.c
index 2e9314091c81..c65fdb1a30a0 100644
--- a/fs/gfs2/log.c
+++ b/fs/gfs2/log.c
@@ -712,11 +712,12 @@ void gfs2_glock_remove_revoke(struct gfs2_glock *gl)
 void gfs2_write_revokes(struct gfs2_sbd *sdp)
 {
        /* number of revokes we still have room for */
-       int max_revokes = (sdp->sd_sb.sb_bsize - sizeof(struct 
gfs2_log_descriptor)) / sizeof(u64);
+       unsigned int max_revokes = sdp->sd_ldptrs;
 
        gfs2_log_lock(sdp);
-       while (sdp->sd_log_num_revoke > max_revokes)
-               max_revokes += (sdp->sd_sb.sb_bsize - sizeof(struct 
gfs2_meta_header)) / sizeof(u64);
+       if (sdp->sd_log_num_revoke > sdp->sd_ldptrs)
+               max_revokes += roundup(sdp->sd_log_num_revoke - sdp->sd_ldptrs,
+                                      sdp->sd_inptrs);
        max_revokes -= sdp->sd_log_num_revoke;
        if (!sdp->sd_log_num_revoke) {
                atomic_dec(&sdp->sd_log_blks_free);
-- 
2.26.2

Reply via email to