mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-23 01:48:21 +08:00
113 lines
5.7 KiB
C
113 lines
5.7 KiB
C
/// \copyright SPDX-License-Identifier: Apache-2.0
|
|
/// \author Леонид Юрьев aka Leonid Yuriev <leo@yuriev.ru> \date 2015-2024
|
|
|
|
#pragma once
|
|
|
|
#include "essentials.h"
|
|
|
|
MDBX_INTERNAL int lck_setup(MDBX_env *env, mdbx_mode_t mode);
|
|
#if MDBX_LOCKING > MDBX_LOCKING_SYSV
|
|
MDBX_INTERNAL int lck_ipclock_stubinit(osal_ipclock_t *ipc);
|
|
MDBX_INTERNAL int lck_ipclock_destroy(osal_ipclock_t *ipc);
|
|
#endif /* MDBX_LOCKING > MDBX_LOCKING_SYSV */
|
|
|
|
/// \brief Initialization of synchronization primitives linked with MDBX_env
|
|
/// instance both in LCK-file and within the current process.
|
|
/// \param
|
|
/// global_uniqueness_flag = true - denotes that there are no other processes
|
|
/// working with DB and LCK-file. Thus the function MUST initialize
|
|
/// shared synchronization objects in memory-mapped LCK-file.
|
|
/// global_uniqueness_flag = false - denotes that at least one process is
|
|
/// already working with DB and LCK-file, including the case when DB
|
|
/// has already been opened in the current process. Thus the function
|
|
/// MUST NOT initialize shared synchronization objects in memory-mapped
|
|
/// LCK-file that are already in use.
|
|
/// \return Error code or zero on success.
|
|
MDBX_INTERNAL int lck_init(MDBX_env *env, MDBX_env *inprocess_neighbor,
|
|
int global_uniqueness_flag);
|
|
|
|
/// \brief Disconnects from shared interprocess objects and destructs
|
|
/// synchronization objects linked with MDBX_env instance
|
|
/// within the current process.
|
|
/// \param
|
|
/// inprocess_neighbor = nullptr - if the current process does not have other
|
|
/// instances of MDBX_env linked with the DB being closed.
|
|
/// Thus the function MUST check for other processes working with DB or
|
|
/// LCK-file, and keep or destroy shared synchronization objects in
|
|
/// memory-mapped LCK-file depending on the result.
|
|
/// inprocess_neighbor = not-nullptr - pointer to another instance of MDBX_env
|
|
/// (anyone of there is several) working with DB or LCK-file within the
|
|
/// current process. Thus the function MUST NOT try to acquire exclusive
|
|
/// lock and/or try to destruct shared synchronization objects linked with
|
|
/// DB or LCK-file. Moreover, the implementation MUST ensure correct work
|
|
/// of other instances of MDBX_env within the current process, e.g.
|
|
/// restore POSIX-fcntl locks after the closing of file descriptors.
|
|
/// \return Error code (MDBX_PANIC) or zero on success.
|
|
MDBX_INTERNAL int lck_destroy(MDBX_env *env, MDBX_env *inprocess_neighbor,
|
|
const uint32_t current_pid);
|
|
|
|
/// \brief Connects to shared interprocess locking objects and tries to acquire
|
|
/// the maximum lock level (shared if exclusive is not available)
|
|
/// Depending on implementation or/and platform (Windows) this function may
|
|
/// acquire the non-OS super-level lock (e.g. for shared synchronization
|
|
/// objects initialization), which will be downgraded to OS-exclusive or
|
|
/// shared via explicit calling of lck_downgrade().
|
|
/// \return
|
|
/// MDBX_RESULT_TRUE (-1) - if an exclusive lock was acquired and thus
|
|
/// the current process is the first and only after the last use of DB.
|
|
/// MDBX_RESULT_FALSE (0) - if a shared lock was acquired and thus
|
|
/// DB has already been opened and now is used by other processes.
|
|
/// Otherwise (not 0 and not -1) - error code.
|
|
MDBX_INTERNAL int lck_seize(MDBX_env *env);
|
|
|
|
/// \brief Downgrades the level of initially acquired lock to
|
|
/// operational level specified by argument. The reason for such downgrade:
|
|
/// - unblocking of other processes that are waiting for access, i.e.
|
|
/// if (env->flags & MDBX_EXCLUSIVE) != 0, then other processes
|
|
/// should be made aware that access is unavailable rather than
|
|
/// wait for it.
|
|
/// - freeing locks that interfere file operation (especially for Windows)
|
|
/// (env->flags & MDBX_EXCLUSIVE) == 0 - downgrade to shared lock.
|
|
/// (env->flags & MDBX_EXCLUSIVE) != 0 - downgrade to exclusive
|
|
/// operational lock.
|
|
/// \return Error code or zero on success
|
|
MDBX_INTERNAL int lck_downgrade(MDBX_env *env);
|
|
|
|
MDBX_MAYBE_UNUSED MDBX_INTERNAL int lck_upgrade(MDBX_env *env, bool dont_wait);
|
|
|
|
/// \brief Locks LCK-file or/and table of readers for (de)registering.
|
|
/// \return Error code or zero on success
|
|
MDBX_INTERNAL int lck_rdt_lock(MDBX_env *env);
|
|
|
|
/// \brief Unlocks LCK-file or/and table of readers after (de)registering.
|
|
MDBX_INTERNAL void lck_rdt_unlock(MDBX_env *env);
|
|
|
|
/// \brief Acquires write-transaction lock.
|
|
/// \return Error code or zero on success
|
|
MDBX_INTERNAL int lck_txn_lock(MDBX_env *env, bool dont_wait);
|
|
|
|
/// \brief Releases write-transaction lock..
|
|
MDBX_INTERNAL void lck_txn_unlock(MDBX_env *env);
|
|
|
|
/// \brief Sets alive-flag of reader presence (indicative lock) for PID of
|
|
/// the current process. The function does no more than needed for
|
|
/// the correct working of lck_rpid_check() in other processes.
|
|
/// \return Error code or zero on success
|
|
MDBX_INTERNAL int lck_rpid_set(MDBX_env *env);
|
|
|
|
/// \brief Resets alive-flag of reader presence (indicative lock)
|
|
/// for PID of the current process. The function does no more than needed
|
|
/// for the correct working of lck_rpid_check() in other processes.
|
|
/// \return Error code or zero on success
|
|
MDBX_INTERNAL int lck_rpid_clear(MDBX_env *env);
|
|
|
|
/// \brief Checks for reading process status with the given pid with help of
|
|
/// alive-flag of presence (indicative lock) or using another way.
|
|
/// \return
|
|
/// MDBX_RESULT_TRUE (-1) - if the reader process with the given PID is alive
|
|
/// and working with DB (indicative lock is present).
|
|
/// MDBX_RESULT_FALSE (0) - if the reader process with the given PID is absent
|
|
/// or not working with DB (indicative lock is not present).
|
|
/// Otherwise (not 0 and not -1) - error code.
|
|
MDBX_INTERNAL int lck_rpid_check(MDBX_env *env, uint32_t pid);
|