return ERR_PTR(-ENOMEM);
 
        refcount_set(&req->usage, 1);
+       req->key = key_get(key);
        req->nr_pages = nr_pages;
        req->actual_len = i_size; /* May change */
        req->len = nr_pages * PAGE_SIZE; /* We can ask for more than there is */
 
        if (!test_bit(AFS_VNODE_DIR_VALID, &dvnode->flags)) {
                trace_afs_reload_dir(dvnode);
-               ret = afs_fetch_data(dvnode, key, req);
+               ret = afs_fetch_data(dvnode, req);
                if (ret < 0)
                        goto error_unlock;
 
 
                        if (req->pages != req->array)
                                kfree(req->pages);
                }
+               key_put(req->key);
                kfree(req);
        }
 }
 /*
  * Fetch file data from the volume.
  */
-int afs_fetch_data(struct afs_vnode *vnode, struct key *key, struct afs_read *req)
+int afs_fetch_data(struct afs_vnode *vnode, struct afs_read *req)
 {
        struct afs_operation *op;
 
               vnode->fid.vid,
               vnode->fid.vnode,
               vnode->fid.unique,
-              key_serial(key));
+              key_serial(req->key));
 
-       op = afs_alloc_operation(key, vnode->volume);
+       op = afs_alloc_operation(req->key, vnode->volume);
        if (IS_ERR(op))
                return PTR_ERR(op);
 
         * unmarshalling code will clear the unfilled space.
         */
        refcount_set(&req->usage, 1);
+       req->key = key_get(key);
        req->pos = (loff_t)page->index << PAGE_SHIFT;
        req->len = PAGE_SIZE;
        req->nr_pages = 1;
 
        /* read the contents of the file from the server into the
         * page */
-       ret = afs_fetch_data(vnode, key, req);
+       ret = afs_fetch_data(vnode, req);
        afs_put_read(req);
 
        if (ret < 0) {
        struct afs_read *req;
        struct list_head *p;
        struct page *first, *page;
-       struct key *key = afs_file_key(file);
        pgoff_t index;
        int ret, n, i;
 
 
        refcount_set(&req->usage, 1);
        req->vnode = vnode;
+       req->key = key_get(afs_file_key(file));
        req->page_done = afs_readpages_page_done;
        req->pos = first->index;
        req->pos <<= PAGE_SHIFT;
        } while (req->nr_pages < n);
 
        if (req->nr_pages == 0) {
-               kfree(req);
+               afs_put_read(req);
                return 0;
        }
 
-       ret = afs_fetch_data(vnode, key, req);
+       ret = afs_fetch_data(vnode, req);
        if (ret < 0)
                goto error;
 
 
        loff_t                  actual_len;     /* How much we're actually getting */
        loff_t                  remain;         /* Amount remaining */
        loff_t                  file_size;      /* File size returned by server */
+       struct key              *key;           /* The key to use to reissue the read */
        afs_dataversion_t       data_version;   /* Version number returned by server */
        refcount_t              usage;
        unsigned int            index;          /* Which page we're reading into */
 extern void afs_put_wb_key(struct afs_wb_key *);
 extern int afs_open(struct inode *, struct file *);
 extern int afs_release(struct inode *, struct file *);
-extern int afs_fetch_data(struct afs_vnode *, struct key *, struct afs_read *);
+extern int afs_fetch_data(struct afs_vnode *, struct afs_read *);
 extern int afs_page_filler(void *, struct page *);
 extern void afs_put_read(struct afs_read *);
 
 
 /*
  * partly or wholly fill a page that's under preparation for writing
  */
-static int afs_fill_page(struct afs_vnode *vnode, struct key *key,
+static int afs_fill_page(struct file *file,
                         loff_t pos, unsigned int len, struct page *page)
 {
+       struct afs_vnode *vnode = AFS_FS_I(file_inode(file));
        struct afs_read *req;
        size_t p;
        void *data;
                return -ENOMEM;
 
        refcount_set(&req->usage, 1);
+       req->key = key_get(afs_file_key(file));
        req->pos = pos;
        req->len = len;
        req->nr_pages = 1;
        req->pages[0] = page;
        get_page(page);
 
-       ret = afs_fetch_data(vnode, key, req);
+       ret = afs_fetch_data(vnode, req);
        afs_put_read(req);
        if (ret < 0) {
                if (ret == -ENOENT) {
 {
        struct afs_vnode *vnode = AFS_FS_I(file_inode(file));
        struct page *page;
-       struct key *key = afs_file_key(file);
        unsigned long priv;
        unsigned f, from = pos & (PAGE_SIZE - 1);
        unsigned t, to = from + len;
                return -ENOMEM;
 
        if (!PageUptodate(page) && len != PAGE_SIZE) {
-               ret = afs_fill_page(vnode, key, pos & PAGE_MASK, PAGE_SIZE, page);
+               ret = afs_fill_page(file, pos & PAGE_MASK, PAGE_SIZE, page);
                if (ret < 0) {
                        unlock_page(page);
                        put_page(page);
                  struct page *page, void *fsdata)
 {
        struct afs_vnode *vnode = AFS_FS_I(file_inode(file));
-       struct key *key = afs_file_key(file);
        unsigned long priv;
        unsigned int f, from = pos & (PAGE_SIZE - 1);
        unsigned int t, to = from + copied;
                         * unmarshalling routine will take care of clearing any
                         * bits that are beyond the EOF.
                         */
-                       ret = afs_fill_page(vnode, key, pos + copied,
+                       ret = afs_fill_page(file, pos + copied,
                                            len - copied, page);
                        if (ret < 0)
                                goto out;