Commit 38355eec authored by David Howells's avatar David Howells

afs: Set error flag rather than return error from file status decode

Set a flag in the call struct to indicate an unmarshalling error rather
than return and handle an error from the decoding of file statuses.  This
flag is checked on a successful return from the delivery function.
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
parent 8230fd82
...@@ -56,7 +56,7 @@ static void xdr_dump_bad(const __be32 *bp) ...@@ -56,7 +56,7 @@ static void xdr_dump_bad(const __be32 *bp)
/* /*
* decode an AFSFetchStatus block * decode an AFSFetchStatus block
*/ */
static int xdr_decode_AFSFetchStatus(const __be32 **_bp, static void xdr_decode_AFSFetchStatus(const __be32 **_bp,
struct afs_call *call, struct afs_call *call,
struct afs_status_cb *scb) struct afs_status_cb *scb)
{ {
...@@ -65,7 +65,6 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp, ...@@ -65,7 +65,6 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp,
bool inline_error = (call->operation_ID == afs_FS_InlineBulkStatus); bool inline_error = (call->operation_ID == afs_FS_InlineBulkStatus);
u64 data_version, size; u64 data_version, size;
u32 type, abort_code; u32 type, abort_code;
int ret;
abort_code = ntohl(xdr->abort_code); abort_code = ntohl(xdr->abort_code);
...@@ -79,7 +78,7 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp, ...@@ -79,7 +78,7 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp,
*/ */
status->abort_code = abort_code; status->abort_code = abort_code;
scb->have_error = true; scb->have_error = true;
goto good; goto advance;
} }
pr_warn("Unknown AFSFetchStatus version %u\n", ntohl(xdr->if_version)); pr_warn("Unknown AFSFetchStatus version %u\n", ntohl(xdr->if_version));
...@@ -89,7 +88,7 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp, ...@@ -89,7 +88,7 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp,
if (abort_code != 0 && inline_error) { if (abort_code != 0 && inline_error) {
status->abort_code = abort_code; status->abort_code = abort_code;
scb->have_error = true; scb->have_error = true;
goto good; goto advance;
} }
type = ntohl(xdr->type); type = ntohl(xdr->type);
...@@ -125,15 +124,13 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp, ...@@ -125,15 +124,13 @@ static int xdr_decode_AFSFetchStatus(const __be32 **_bp,
data_version |= (u64)ntohl(xdr->data_version_hi) << 32; data_version |= (u64)ntohl(xdr->data_version_hi) << 32;
status->data_version = data_version; status->data_version = data_version;
scb->have_status = true; scb->have_status = true;
good:
ret = 0;
advance: advance:
*_bp = (const void *)*_bp + sizeof(*xdr); *_bp = (const void *)*_bp + sizeof(*xdr);
return ret; return;
bad: bad:
xdr_dump_bad(*_bp); xdr_dump_bad(*_bp);
ret = afs_protocol_error(call, -EBADMSG, afs_eproto_bad_status); afs_protocol_error(call, -EBADMSG, afs_eproto_bad_status);
goto advance; goto advance;
} }
...@@ -254,9 +251,7 @@ static int afs_deliver_fs_fetch_status_vnode(struct afs_call *call) ...@@ -254,9 +251,7 @@ static int afs_deliver_fs_fetch_status_vnode(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSCallBack(&bp, call, call->out_scb); xdr_decode_AFSCallBack(&bp, call, call->out_scb);
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
...@@ -419,9 +414,7 @@ static int afs_deliver_fs_fetch_data(struct afs_call *call) ...@@ -419,9 +414,7 @@ static int afs_deliver_fs_fetch_data(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSCallBack(&bp, call, call->out_scb); xdr_decode_AFSCallBack(&bp, call, call->out_scb);
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
...@@ -577,12 +570,8 @@ static int afs_deliver_fs_create_vnode(struct afs_call *call) ...@@ -577,12 +570,8 @@ static int afs_deliver_fs_create_vnode(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
xdr_decode_AFSFid(&bp, call->out_fid); xdr_decode_AFSFid(&bp, call->out_fid);
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0) xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
return ret;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_AFSCallBack(&bp, call, call->out_scb); xdr_decode_AFSCallBack(&bp, call, call->out_scb);
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
...@@ -691,9 +680,7 @@ static int afs_deliver_fs_dir_status_and_vol(struct afs_call *call) ...@@ -691,9 +680,7 @@ static int afs_deliver_fs_dir_status_and_vol(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -784,12 +771,8 @@ static int afs_deliver_fs_link(struct afs_call *call) ...@@ -784,12 +771,8 @@ static int afs_deliver_fs_link(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0) xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
return ret;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -878,12 +861,8 @@ static int afs_deliver_fs_symlink(struct afs_call *call) ...@@ -878,12 +861,8 @@ static int afs_deliver_fs_symlink(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
xdr_decode_AFSFid(&bp, call->out_fid); xdr_decode_AFSFid(&bp, call->out_fid);
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0) xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
return ret;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -986,16 +965,12 @@ static int afs_deliver_fs_rename(struct afs_call *call) ...@@ -986,16 +965,12 @@ static int afs_deliver_fs_rename(struct afs_call *call)
if (ret < 0) if (ret < 0)
return ret; return ret;
bp = call->buffer;
/* If the two dirs are the same, we have two copies of the same status /* If the two dirs are the same, we have two copies of the same status
* report, so we just decode it twice. * report, so we just decode it twice.
*/ */
bp = call->buffer; xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb);
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_dir_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -1103,9 +1078,7 @@ static int afs_deliver_fs_store_data(struct afs_call *call) ...@@ -1103,9 +1078,7 @@ static int afs_deliver_fs_store_data(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -1283,9 +1256,7 @@ static int afs_deliver_fs_store_status(struct afs_call *call) ...@@ -1283,9 +1256,7 @@ static int afs_deliver_fs_store_status(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -1952,9 +1923,7 @@ static int afs_deliver_fs_fetch_status(struct afs_call *call) ...@@ -1952,9 +1923,7 @@ static int afs_deliver_fs_fetch_status(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSCallBack(&bp, call, call->out_scb); xdr_decode_AFSCallBack(&bp, call, call->out_scb);
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
...@@ -2060,10 +2029,7 @@ static int afs_deliver_fs_inline_bulk_status(struct afs_call *call) ...@@ -2060,10 +2029,7 @@ static int afs_deliver_fs_inline_bulk_status(struct afs_call *call)
bp = call->buffer; bp = call->buffer;
scb = &call->out_scb[call->count]; scb = &call->out_scb[call->count];
ret = xdr_decode_AFSFetchStatus(&bp, call, scb); xdr_decode_AFSFetchStatus(&bp, call, scb);
if (ret < 0)
return ret;
call->count++; call->count++;
if (call->count < call->count2) if (call->count < call->count2)
goto more_counts; goto more_counts;
...@@ -2241,9 +2207,7 @@ static int afs_deliver_fs_fetch_acl(struct afs_call *call) ...@@ -2241,9 +2207,7 @@ static int afs_deliver_fs_fetch_acl(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
call->unmarshall++; call->unmarshall++;
...@@ -2324,9 +2288,7 @@ static int afs_deliver_fs_file_status_and_vol(struct afs_call *call) ...@@ -2324,9 +2288,7 @@ static int afs_deliver_fs_file_status_and_vol(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_AFSFetchStatus(&bp, call, call->out_scb); xdr_decode_AFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_AFSVolSync(&bp, call->out_volsync); xdr_decode_AFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
......
...@@ -160,6 +160,7 @@ struct afs_call { ...@@ -160,6 +160,7 @@ struct afs_call {
bool upgrade; /* T to request service upgrade */ bool upgrade; /* T to request service upgrade */
bool have_reply_time; /* T if have got reply_time */ bool have_reply_time; /* T if have got reply_time */
bool intr; /* T if interruptible */ bool intr; /* T if interruptible */
bool unmarshalling_error; /* T if an unmarshalling error occurred */
u16 service_id; /* Actual service ID (after upgrade) */ u16 service_id; /* Actual service ID (after upgrade) */
unsigned int debug_id; /* Trace ID */ unsigned int debug_id; /* Trace ID */
u32 operation_ID; /* operation ID for an incoming call */ u32 operation_ID; /* operation ID for an incoming call */
......
...@@ -540,6 +540,8 @@ static void afs_deliver_to_call(struct afs_call *call) ...@@ -540,6 +540,8 @@ static void afs_deliver_to_call(struct afs_call *call)
ret = call->type->deliver(call); ret = call->type->deliver(call);
state = READ_ONCE(call->state); state = READ_ONCE(call->state);
if (ret == 0 && call->unmarshalling_error)
ret = -EBADMSG;
switch (ret) { switch (ret) {
case 0: case 0:
afs_queue_call_work(call); afs_queue_call_work(call);
...@@ -963,5 +965,7 @@ noinline int afs_protocol_error(struct afs_call *call, int error, ...@@ -963,5 +965,7 @@ noinline int afs_protocol_error(struct afs_call *call, int error,
enum afs_eproto_cause cause) enum afs_eproto_cause cause)
{ {
trace_afs_protocol_error(call, error, cause); trace_afs_protocol_error(call, error, cause);
if (call)
call->unmarshalling_error = true;
return error; return error;
} }
...@@ -179,21 +179,20 @@ static void xdr_dump_bad(const __be32 *bp) ...@@ -179,21 +179,20 @@ static void xdr_dump_bad(const __be32 *bp)
/* /*
* Decode a YFSFetchStatus block * Decode a YFSFetchStatus block
*/ */
static int xdr_decode_YFSFetchStatus(const __be32 **_bp, static void xdr_decode_YFSFetchStatus(const __be32 **_bp,
struct afs_call *call, struct afs_call *call,
struct afs_status_cb *scb) struct afs_status_cb *scb)
{ {
const struct yfs_xdr_YFSFetchStatus *xdr = (const void *)*_bp; const struct yfs_xdr_YFSFetchStatus *xdr = (const void *)*_bp;
struct afs_file_status *status = &scb->status; struct afs_file_status *status = &scb->status;
u32 type; u32 type;
int ret;
status->abort_code = ntohl(xdr->abort_code); status->abort_code = ntohl(xdr->abort_code);
if (status->abort_code != 0) { if (status->abort_code != 0) {
if (status->abort_code == VNOVNODE) if (status->abort_code == VNOVNODE)
status->nlink = 0; status->nlink = 0;
scb->have_error = true; scb->have_error = true;
goto good; goto advance;
} }
type = ntohl(xdr->type); type = ntohl(xdr->type);
...@@ -221,15 +220,13 @@ static int xdr_decode_YFSFetchStatus(const __be32 **_bp, ...@@ -221,15 +220,13 @@ static int xdr_decode_YFSFetchStatus(const __be32 **_bp,
status->size = xdr_to_u64(xdr->size); status->size = xdr_to_u64(xdr->size);
status->data_version = xdr_to_u64(xdr->data_version); status->data_version = xdr_to_u64(xdr->data_version);
scb->have_status = true; scb->have_status = true;
good:
ret = 0;
advance: advance:
*_bp += xdr_size(xdr); *_bp += xdr_size(xdr);
return ret; return;
bad: bad:
xdr_dump_bad(*_bp); xdr_dump_bad(*_bp);
ret = afs_protocol_error(call, -EBADMSG, afs_eproto_bad_status); afs_protocol_error(call, -EBADMSG, afs_eproto_bad_status);
goto advance; goto advance;
} }
...@@ -348,9 +345,7 @@ static int yfs_deliver_fs_status_cb_and_volsync(struct afs_call *call) ...@@ -348,9 +345,7 @@ static int yfs_deliver_fs_status_cb_and_volsync(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_YFSCallBack(&bp, call, call->out_scb); xdr_decode_YFSCallBack(&bp, call, call->out_scb);
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
...@@ -372,9 +367,7 @@ static int yfs_deliver_status_and_volsync(struct afs_call *call) ...@@ -372,9 +367,7 @@ static int yfs_deliver_status_and_volsync(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -534,9 +527,7 @@ static int yfs_deliver_fs_fetch_data64(struct afs_call *call) ...@@ -534,9 +527,7 @@ static int yfs_deliver_fs_fetch_data64(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_YFSCallBack(&bp, call, call->out_scb); xdr_decode_YFSCallBack(&bp, call, call->out_scb);
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
...@@ -644,12 +635,8 @@ static int yfs_deliver_fs_create_vnode(struct afs_call *call) ...@@ -644,12 +635,8 @@ static int yfs_deliver_fs_create_vnode(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
xdr_decode_YFSFid(&bp, call->out_fid); xdr_decode_YFSFid(&bp, call->out_fid);
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0) xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
return ret;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_YFSCallBack(&bp, call, call->out_scb); xdr_decode_YFSCallBack(&bp, call, call->out_scb);
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
...@@ -802,14 +789,9 @@ static int yfs_deliver_fs_remove_file2(struct afs_call *call) ...@@ -802,14 +789,9 @@ static int yfs_deliver_fs_remove_file2(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_YFSFid(&bp, &fid); xdr_decode_YFSFid(&bp, &fid);
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
/* Was deleted if vnode->status.abort_code == VNOVNODE. */ /* Was deleted if vnode->status.abort_code == VNOVNODE. */
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
...@@ -889,10 +871,7 @@ static int yfs_deliver_fs_remove(struct afs_call *call) ...@@ -889,10 +871,7 @@ static int yfs_deliver_fs_remove(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
return 0; return 0;
} }
...@@ -974,12 +953,8 @@ static int yfs_deliver_fs_link(struct afs_call *call) ...@@ -974,12 +953,8 @@ static int yfs_deliver_fs_link(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0) xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
return ret;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
return 0; return 0;
...@@ -1061,12 +1036,8 @@ static int yfs_deliver_fs_symlink(struct afs_call *call) ...@@ -1061,12 +1036,8 @@ static int yfs_deliver_fs_symlink(struct afs_call *call)
/* unmarshall the reply once we've received all of it */ /* unmarshall the reply once we've received all of it */
bp = call->buffer; bp = call->buffer;
xdr_decode_YFSFid(&bp, call->out_fid); xdr_decode_YFSFid(&bp, call->out_fid);
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0) xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
return ret;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0)
return ret;
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
...@@ -1154,13 +1125,11 @@ static int yfs_deliver_fs_rename(struct afs_call *call) ...@@ -1154,13 +1125,11 @@ static int yfs_deliver_fs_rename(struct afs_call *call)
return ret; return ret;
bp = call->buffer; bp = call->buffer;
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb); /* If the two dirs are the same, we have two copies of the same status
if (ret < 0) * report, so we just decode it twice.
return ret; */
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_dir_scb);
if (ret < 0) xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
return ret;
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
_leave(" = 0 [done]"); _leave(" = 0 [done]");
return 0; return 0;
...@@ -1845,9 +1814,7 @@ static int yfs_deliver_fs_inline_bulk_status(struct afs_call *call) ...@@ -1845,9 +1814,7 @@ static int yfs_deliver_fs_inline_bulk_status(struct afs_call *call)
bp = call->buffer; bp = call->buffer;
scb = &call->out_scb[call->count]; scb = &call->out_scb[call->count];
ret = xdr_decode_YFSFetchStatus(&bp, call, scb); xdr_decode_YFSFetchStatus(&bp, call, scb);
if (ret < 0)
return ret;
call->count++; call->count++;
if (call->count < call->count2) if (call->count < call->count2)
...@@ -2067,9 +2034,7 @@ static int yfs_deliver_fs_fetch_opaque_acl(struct afs_call *call) ...@@ -2067,9 +2034,7 @@ static int yfs_deliver_fs_fetch_opaque_acl(struct afs_call *call)
bp = call->buffer; bp = call->buffer;
yacl->inherit_flag = ntohl(*bp++); yacl->inherit_flag = ntohl(*bp++);
yacl->num_cleaned = ntohl(*bp++); yacl->num_cleaned = ntohl(*bp++);
ret = xdr_decode_YFSFetchStatus(&bp, call, call->out_scb); xdr_decode_YFSFetchStatus(&bp, call, call->out_scb);
if (ret < 0)
return ret;
xdr_decode_YFSVolSync(&bp, call->out_volsync); xdr_decode_YFSVolSync(&bp, call->out_volsync);
call->unmarshall++; call->unmarshall++;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment