tdb: fix an early release of the global lock that can cause data corruption
authorVolker Lendecke <vl@samba.org>
Fri, 29 Jan 2010 17:21:09 +0000 (18:21 +0100)
committerVolker Lendecke <vl@samba.org>
Mon, 1 Feb 2010 14:06:29 +0000 (15:06 +0100)
commit531059696e17d1ee538310d81af309c107d08e3e
treec33befb379b9237bb82b8f4340ee81d5e3488ee1
parent42f512552190396f69404a135d19e4325bde7d16
tdb: fix an early release of the global lock that can cause data corruption

There was a bug in tdb where the

                tdb_brlock(tdb, GLOBAL_LOCK, F_UNLCK, F_SETLKW, 0, 1);

(ending the transaction-"mutex") was done before the

                        /* remove the recovery marker */

This means that when a transaction is committed there is a window where another
opener of the file sees the transaction marker while the transaction committer
is still fully functional and working on it. This led to transaction being
rolled back by that second opener of the file while transaction_commit() gave
no error to the caller.

This patch moves the F_UNLCK to after the recovery marker was removed, closing
this window.
lib/tdb/common/transaction.c