From: Tigran Mkrtchyan <kofemann@xxxxxxxxx> This is yet another update of current stateid handling currently tested to work in a single compound: OPEN+CLOSE LOCK+WRITE+LOCKU+CLOSE On the way ( not tested yet ): OPEN+LAYOUTGET TODO: dispose current stateid on operations which provide CFH, but do not provide stateid. Internals: 1. struct nfsd4_compound_state contains pointer to current stateid 2. operations marked to PROVIDE, CONSUME or CLEAR current stateid. 3. during compound processing before operation execution current stateid copied into operations stateid if it's equal to corresponding value ( 0, 1). 4. after operation execution current stateid changed to: a) point to stateid of last operation or b) point to NULL, if operation is marked to do so. Probably all patches have to be squashed into a single one before merged as none of the changes makes sense without others. Tigran. Tigran Mkrtchyan (5): nfsd41: handle current stateid in open and close nfsd41: handle current stateid on lock and locku nfsd41: update operations's stateid iff current stateid is set nfsd41: consume current stateid on read and write nfsd41: use pinter to current stateid to avoid extra copy fs/nfsd/current_stateid.h | 22 +++++++++++++++ fs/nfsd/nfs4proc.c | 55 +++++++++++++++++++++++++++++------- fs/nfsd/nfs4state.c | 67 +++++++++++++++++++++++++++++++++++++++++++++ fs/nfsd/xdr4.h | 1 + 4 files changed, 134 insertions(+), 11 deletions(-) create mode 100644 fs/nfsd/current_stateid.h -- 1.7.7.4 -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html