Whamcloud - gitweb
LU-15776 tgt: fix transaction handling in tgt_brw_write() 71/47371/3
authorMikhail Pershin <mpershin@whamcloud.com>
Tue, 17 May 2022 09:57:28 +0000 (12:57 +0300)
committerOleg Drokin <green@whamcloud.com>
Wed, 1 Jun 2022 03:29:50 +0000 (03:29 +0000)
commit10a29ad7616aeaadabf6d96146f52ef348a3a6f1
treead183d2897f73788058e88e385032d0e5fad4169
parentc4ff4aef7eb939d536acffaac4465039f3cfa935
LU-15776 tgt: fix transaction handling in tgt_brw_write()

Hotfix to prevent possible data loss during WRITE replay.
Since commit f0f92773ee18 from LU-14187 the obd_commitrw()
may restart write transaction in OFD and MDT. That causes
transaction number to be assigned multiple times if such
restart happens. Without flag tti_mult_trans the first
transaction number is stored only so later one could remain
not applied causing data loss after recovery.

Patch sets tti_mult_trans for tgt_brw_write() so the latest
transaction number will be used as request transno.

Fixes: f0f92773ee ("LU-14187 osd-ldiskfs: fix locking in write commit")
Signed-off-by: Mikhail Pershin <mpershin@whamcloud.com>
Change-Id: I364b478591942be5562c3e98ee6e6aa487f3e0c5
Reviewed-on: https://review.whamcloud.com/47371
Tested-by: jenkins <devops@whamcloud.com>
Reviewed-by: Andreas Dilger <adilger@whamcloud.com>
Reviewed-by: Alex Zhuravlev <bzzz@whamcloud.com>
Tested-by: Maloo <maloo@whamcloud.com>
Reviewed-by: Wang Shilong <wangshilong1991@gmail.com>
Reviewed-by: Oleg Drokin <green@whamcloud.com>
lustre/target/tgt_handler.c