mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 04:55:18 +07:00
staging: lustre: mdc: fixup MDS_SWAP_LAYOUTS ELC handling
In mdc_ioc_swap_layouts() cancel *any* unused locks with LAYOUT or XATTR IBITS set on the two files. (This matches the locks acquired in mdt_swap_layouts(). Previously only locks that conflicted with a CR LAYOUT lock were cancelled.) Signed-off-by: John L. Hammond <john.hammond@intel.com> Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-4320 Reviewed-on: http://review.whamcloud.com/9329 Reviewed-by: Andreas Dilger <andreas.dilger@intel.com> Reviewed-by: Faccini Bruno <bruno.faccini@intel.com> Reviewed-by: Oleg Drokin <oleg.drokin@intel.com> Signed-off-by: James Simmons <jsimmons@infradead.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
1d82425fbd
commit
29792c81f9
@ -1670,9 +1670,11 @@ static int mdc_ioc_swap_layouts(struct obd_export *exp,
|
||||
* with the request RPC to avoid extra RPC round trips
|
||||
*/
|
||||
count = mdc_resource_get_unused(exp, &op_data->op_fid1, &cancels,
|
||||
LCK_CR, MDS_INODELOCK_LAYOUT);
|
||||
LCK_CR, MDS_INODELOCK_LAYOUT |
|
||||
MDS_INODELOCK_XATTR);
|
||||
count += mdc_resource_get_unused(exp, &op_data->op_fid2, &cancels,
|
||||
LCK_CR, MDS_INODELOCK_LAYOUT);
|
||||
LCK_CR, MDS_INODELOCK_LAYOUT |
|
||||
MDS_INODELOCK_XATTR);
|
||||
|
||||
req = ptlrpc_request_alloc(class_exp2cliimp(exp),
|
||||
&RQF_MDS_SWAP_LAYOUTS);
|
||||
|
Loading…
Reference in New Issue
Block a user