while (rc == 0 && !done) {
                struct lu_dirpage *dp;
                struct lu_dirent  *ent;
+               __u64 hash;
+               __u64 next;
+
+               if (IS_ERR(page)) {
+                       rc = PTR_ERR(page);
+                       break;
+               }
+
+               hash = MDS_DIR_END_OFF;
+               dp = page_address(page);
+               for (ent = lu_dirent_start(dp); ent && !done;
+                    ent = lu_dirent_next(ent)) {
+                       __u16     type;
+                       int         namelen;
+                       struct lu_fid  fid;
+                       __u64     lhash;
+                       __u64     ino;
 
-               if (!IS_ERR(page)) {
                        /*
-                        * If page is empty (end of directory is reached),
-                        * use this value.
+                        * XXX: implement correct swabbing here.
                         */
-                       __u64 hash = MDS_DIR_END_OFF;
-                       __u64 next;
-
-                       dp = page_address(page);
-                       for (ent = lu_dirent_start(dp); ent && !done;
-                            ent = lu_dirent_next(ent)) {
-                               __u16     type;
-                               int         namelen;
-                               struct lu_fid  fid;
-                               __u64     lhash;
-                               __u64     ino;
 
+                       hash = le64_to_cpu(ent->lde_hash);
+                       if (hash < pos)
                                /*
-                                * XXX: implement correct swabbing here.
+                                * Skip until we find target hash
+                                * value.
                                 */
+                               continue;
 
-                               hash = le64_to_cpu(ent->lde_hash);
-                               if (hash < pos)
-                                       /*
-                                        * Skip until we find target hash
-                                        * value.
-                                        */
-                                       continue;
-
-                               namelen = le16_to_cpu(ent->lde_namelen);
-                               if (namelen == 0)
-                                       /*
-                                        * Skip dummy record.
-                                        */
-                                       continue;
-
-                               if (api32 && hash64)
-                                       lhash = hash >> 32;
-                               else
-                                       lhash = hash;
-                               fid_le_to_cpu(&fid, &ent->lde_fid);
-                               ino = cl_fid_build_ino(&fid, api32);
-                               type = ll_dirent_type_get(ent);
-                               ctx->pos = lhash;
-                               /* For 'll_nfs_get_name_filldir()', it will try
-                                * to access the 'ent' through its 'lde_name',
-                                * so the parameter 'name' for 'ctx->actor()'
-                                * must be part of the 'ent'.
+                       namelen = le16_to_cpu(ent->lde_namelen);
+                       if (namelen == 0)
+                               /*
+                                * Skip dummy record.
                                 */
-                               done = !dir_emit(ctx, ent->lde_name,
-                                                namelen, ino, type);
-                       }
-                       next = le64_to_cpu(dp->ldp_hash_end);
-                       if (!done) {
-                               pos = next;
-                               if (pos == MDS_DIR_END_OFF) {
-                                       /*
-                                        * End of directory reached.
-                                        */
-                                       done = 1;
-                                       ll_release_page(page, 0);
-                               } else if (1 /* chain is exhausted*/) {
-                                       /*
-                                        * Normal case: continue to the next
-                                        * page.
-                                        */
-                                       ll_release_page(page,
-                                           le32_to_cpu(dp->ldp_flags) &
-                                                       LDF_COLLIDE);
-                                       next = pos;
-                                       page = ll_get_dir_page(inode, pos,
-                                                              &chain);
-                               } else {
-                                       /*
-                                        * go into overflow page.
-                                        */
-                                       LASSERT(le32_to_cpu(dp->ldp_flags) &
+                               continue;
+
+                       if (api32 && hash64)
+                               lhash = hash >> 32;
+                       else
+                               lhash = hash;
+                       fid_le_to_cpu(&fid, &ent->lde_fid);
+                       ino = cl_fid_build_ino(&fid, api32);
+                       type = ll_dirent_type_get(ent);
+                       ctx->pos = lhash;
+                       /* For 'll_nfs_get_name_filldir()', it will try
+                        * to access the 'ent' through its 'lde_name',
+                        * so the parameter 'name' for 'ctx->actor()'
+                        * must be part of the 'ent'.
+                        */
+                       done = !dir_emit(ctx, ent->lde_name,
+                                        namelen, ino, type);
+               }
+               next = le64_to_cpu(dp->ldp_hash_end);
+               if (!done) {
+                       pos = next;
+                       if (pos == MDS_DIR_END_OFF) {
+                               /*
+                                * End of directory reached.
+                                */
+                               done = 1;
+                               ll_release_page(page, 0);
+                       } else if (1 /* chain is exhausted*/) {
+                               /*
+                                * Normal case: continue to the next
+                                * page.
+                                */
+                               ll_release_page(page,
+                                               le32_to_cpu(dp->ldp_flags) &
                                                LDF_COLLIDE);
-                                       ll_release_page(page, 1);
-                               }
+                               next = pos;
+                               page = ll_get_dir_page(inode, pos,
+                                                      &chain);
                        } else {
-                               pos = hash;
-                               ll_release_page(page, 0);
+                               /*
+                                * go into overflow page.
+                                */
+                               LASSERT(le32_to_cpu(dp->ldp_flags) &
+                                       LDF_COLLIDE);
+                               ll_release_page(page, 1);
                        }
                } else {
-                       rc = PTR_ERR(page);
+                       pos = hash;
+                       ll_release_page(page, 0);
                }
        }