enum iostat_type io_type)
 {
        struct address_space *mapping = cc->inode->i_mapping;
-       int _submitted, compr_blocks, ret;
-       int i = -1, err = 0;
+       int _submitted, compr_blocks, ret, i;
 
        compr_blocks = f2fs_compressed_blocks(cc);
-       if (compr_blocks < 0) {
-               err = compr_blocks;
-               goto out_err;
+
+       for (i = 0; i < cc->cluster_size; i++) {
+               if (!cc->rpages[i])
+                       continue;
+
+               redirty_page_for_writepage(wbc, cc->rpages[i]);
+               unlock_page(cc->rpages[i]);
        }
 
+       if (compr_blocks < 0)
+               return compr_blocks;
+
        for (i = 0; i < cc->cluster_size; i++) {
                if (!cc->rpages[i])
                        continue;
 retry_write:
+               lock_page(cc->rpages[i]);
+
                if (cc->rpages[i]->mapping != mapping) {
+continue_unlock:
                        unlock_page(cc->rpages[i]);
                        continue;
                }
 
-               BUG_ON(!PageLocked(cc->rpages[i]));
+               if (!PageDirty(cc->rpages[i]))
+                       goto continue_unlock;
+
+               if (!clear_page_dirty_for_io(cc->rpages[i]))
+                       goto continue_unlock;
 
                ret = f2fs_write_single_data_page(cc->rpages[i], &_submitted,
                                                NULL, NULL, wbc, io_type,
                                 * avoid deadlock caused by cluster update race
                                 * from foreground operation.
                                 */
-                               if (IS_NOQUOTA(cc->inode)) {
-                                       err = 0;
-                                       goto out_err;
-                               }
+                               if (IS_NOQUOTA(cc->inode))
+                                       return 0;
                                ret = 0;
                                cond_resched();
                                congestion_wait(BLK_RW_ASYNC,
                                                DEFAULT_IO_TIMEOUT);
-                               lock_page(cc->rpages[i]);
-
-                               if (!PageDirty(cc->rpages[i])) {
-                                       unlock_page(cc->rpages[i]);
-                                       continue;
-                               }
-
-                               clear_page_dirty_for_io(cc->rpages[i]);
                                goto retry_write;
                        }
-                       err = ret;
-                       goto out_err;
+                       return ret;
                }
 
                *submitted += _submitted;
        f2fs_balance_fs(F2FS_M_SB(mapping), true);
 
        return 0;
-out_err:
-       for (++i; i < cc->cluster_size; i++) {
-               if (!cc->rpages[i])
-                       continue;
-               redirty_page_for_writepage(wbc, cc->rpages[i]);
-               unlock_page(cc->rpages[i]);
-       }
-       return err;
 }
 
 int f2fs_write_multi_pages(struct compress_ctx *cc,