struct page *pages[NFS_MAX_READDIR_PAGES];
        struct nfs_entry entry;
        struct file     *file = desc->file;
-       struct nfs_cache_array *array;
        int status = -ENOMEM;
        unsigned int array_size = ARRAY_SIZE(pages);
 
                goto out;
        }
 
-       array = kmap(page);
-
        status = nfs_readdir_alloc_pages(pages, array_size);
        if (status < 0)
-               goto out_release_array;
+               goto out_release_label;
        do {
                unsigned int pglen;
                status = nfs_readdir_xdr_filler(pages, desc, &entry, file, inode);
                }
 
                status = nfs_readdir_page_filler(desc, &entry, pages, page, pglen);
-       } while (!status && !nfs_readdir_array_is_full(array));
+       } while (!status && nfs_readdir_page_needs_filling(page));
 
        nfs_readdir_free_pages(pages, array_size);
-out_release_array:
-       kunmap(page);
+out_release_label:
        nfs4_label_free(entry.label);
 out:
        nfs_free_fattr(entry.fattr);