pill->rc_fmt->rf_name,
field->rmf_name, offset, loc);
offset --;
- LASSERT(0 <= offset && offset < REQ_MAX_FIELD_NR);
+ LASSERT(0 <= offset && offset < (sizeof(pill->rc_swabbed) << 3));
return offset;
}
void *value;
int len;
int offset;
- int inout = loc == RCL_CLIENT;
void *(*getter)(struct lustre_msg *m, int n, int minlen);
value = getter(msg, offset, len);
swabber = swabber ?: field->rmf_swabber;
- if (ptlrpc_req_need_swab(pill->rc_req, inout, offset) &&
- swabber != NULL && value != NULL) {
+ if (!(pill->rc_swabbed & (1 << offset)) && loc != pill->rc_loc &&
+ swabber != NULL && value != NULL &&
+ lustre_msg_swabbed(msg)) {
swabber(value);
- ptlrpc_req_set_swabbed(pill->rc_req, inout, offset);
+ pill->rc_swabbed |= (1 << offset);
}
-
if (value == NULL) {
DEBUG_REQ(D_ERROR, pill->rc_req,
"Wrong buffer for field `%s' (%d of %d) "
FMT_FIELD(old, i, j)->rmf_size);
}
/* last field should be returned to the unswabbed state */
+ pill->rc_swabbed &= ~(__u32)(1 << j);
pill->rc_fmt = fmt;
}
EXPORT_SYMBOL(req_capsule_extend);