struct nfsd4_sequence *seq)
 {
        struct nfsd4_slot *slot = resp->cstate.slot;
+       struct kvec *head = resp->xdr.iov;
        __be32 status;
 
        dprintk("--> %s slot %p\n", __func__, slot);
 
        resp->opcnt = slot->sl_opcnt;
        resp->xdr.p = resp->cstate.datap + XDR_QUADLEN(slot->sl_datalen);
+       head->iov_len = (void *)resp->xdr.p - head->iov_base;
+       resp->xdr.buf->len = head->iov_len;
        status = slot->sl_status;
 
        return status;
 
         * All that remains is to write the tag and operation count...
         */
        struct nfsd4_compound_state *cs = &resp->cstate;
-       struct kvec *iov;
+
        p = resp->tagp;
        *p++ = htonl(resp->taglen);
        memcpy(p, resp->tag, resp->taglen);
        p += XDR_QUADLEN(resp->taglen);
        *p++ = htonl(resp->opcnt);
 
-       if (rqstp->rq_res.page_len) 
-               iov = &rqstp->rq_res.tail[0];
-       else
-               iov = &rqstp->rq_res.head[0];
-       iov->iov_len = ((char *)resp->xdr.p) - (char *)iov->iov_base;
-       BUG_ON(iov->iov_len > PAGE_SIZE);
        if (nfsd4_has_session(cs)) {
                struct nfsd_net *nn = net_generic(SVC_NET(rqstp), nfsd_net_id);
                struct nfs4_client *clp = cs->session->se_client;