/* * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved. * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list * of conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * * 3. Neither the name of the copyright holder nor the names of its contributors may be used * to endorse or promote products derived from this software without specific prior written * permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /** * @defgroup los_rwlock Rwlock * @ingroup kernel */ #ifndef _LOS_RWLOCK_H #define _LOS_RWLOCK_H #include "los_base.h" #ifdef __cplusplus #if __cplusplus extern "C" { #endif /* __cplusplus */ #endif /* __cplusplus */ /** * @ingroup los_rwlock * Rwlock object. */ typedef struct OsRwlock { INT32 magic : 24; /**< Magic number */ INT32 rwCount : 8; /**< Times of locking the rwlock, rwCount > 0 when rwkick is read mode, rwCount < 0 when the rwlock is write mode, rwCount = 0 when the lock is free. */ VOID *writeOwner; /**< The current write thread that is locking the rwlock */ LOS_DL_LIST readList; /**< Read waiting list */ LOS_DL_LIST writeList; /**< Write waiting list */ } LosRwlock; extern BOOL LOS_RwlockIsValid(const LosRwlock *rwlock); /** * @ingroup los_rwlock * @brief Init a rwlock. * * @par Description: * This API is used to Init a rwlock. A rwlock handle is assigned to rwlockHandle when the rwlock is init successfully. * Return LOS_OK on creating successful, return specific error code otherwise. * @param rwlock [IN] Handle pointer of the successfully init rwlock. * * @retval #LOS_EINVAL The rwlock pointer is NULL. * @retval #LOS_EPERM Multiply initialization. * @retval #LOS_OK The rwlock is successfully created. * @par Dependency: * * @see LOS_RwlockDestroy */ extern UINT32 LOS_RwlockInit(LosRwlock *rwlock); /** * @ingroup los_rwlock * @brief Destroy a rwlock. * * @par Description: * This API is used to delete a specified rwlock. Return LOS_OK on deleting successfully, return specific error code * otherwise. * @attention * * * @param rwlock [IN] Handle of the rwlock to be deleted. * * @retval #LOS_EINVAL The rwlock pointer is NULL. * @retval #LOS_EBUSY Tasks pended on this rwlock. * @retval #LOS_EBADF The lock has been destroyed or broken. * @retval #LOS_OK The rwlock is successfully deleted. * @par Dependency: * * @see LOS_RwlockInit */ extern UINT32 LOS_RwlockDestroy(LosRwlock *rwlock); /** * @ingroup los_rwlock * @brief Wait to lock a read lock. * * @par Description: * This API is used to wait for a specified period of time to lock a read lock. * @attention * * * @param rwlock [IN] Handle of the rwlock to be waited on. * @param timeout [IN] Waiting time. The value range is [0, LOS_WAIT_FOREVER](unit: Tick). * * @retval #LOS_EINVAL The rwlock pointer is NULL, The timeout is zero or Lock status error. * @retval #LOS_EINTR The rwlock is being locked during an interrupt. * @retval #LOS_EBADF The lock has been destroyed or broken. * @retval #LOS_EDEADLK Rwlock error check failed or System locked task scheduling. * @retval #LOS_ETIMEDOUT The rwlock waiting times out. * @retval #LOS_EPERM The rwlock is used in system tasks. * @retval #LOS_OK The rwlock is successfully locked. * @par Dependency: * * @see LOS_RwlockInit | LOS_RwlockUnLock */ extern UINT32 LOS_RwlockRdLock(LosRwlock *rwlock, UINT32 timeout); /** * @ingroup los_rwlock * @brief Try wait to lock a read lock. * * @par Description: * This API is used to wait for a specified period of time to lock a read lock. * @attention * * * @param rwlock [IN] Handle of the rwlock to be waited on. * * @retval #LOS_EINVAL The rwlock pointer is NULL or Lock status error. * @retval #LOS_EINTR The rwlock is being locked during an interrupt. * @retval #LOS_EBUSY Fail to get the rwlock, the rwlock has been used. * @retval #LOS_EBADF The lock has been destroyed or broken. * @retval #LOS_EDEADLK rwlock error check failed or System locked task scheduling. * @retval #LOS_ETIMEDOUT The rwlock waiting times out. * @retval #LOS_EPERM The rwlock is used in system tasks. * @retval #LOS_OK The rwlock is successfully locked. * @par Dependency: * * @see LOS_RwlockInit | LOS_RwlockUnLock */ extern UINT32 LOS_RwlockTryRdLock(LosRwlock *rwlock); /** * @ingroup los_rwlock * @brief Wait to lock a write lock. * * @par Description: * This API is used to wait for a specified period of time to lock a write lock. * @attention * * * @param rwlock [IN] Handle of the rwlock to be waited on. * @param timeout [IN] Waiting time. The value range is [0, LOS_WAIT_FOREVER](unit: Tick). * * @retval #LOS_EINVAL The rwlock pointer is NULL, The timeout is zero or Lock status error. * @retval #LOS_EINTR The rwlock is being locked during an interrupt. * @retval #LOS_EBADF The lock has been destroyed or broken. * @retval #LOS_EDEADLK Rwlock error check failed or System locked task scheduling. * @retval #LOS_ETIMEDOUT The rwlock waiting times out. * @retval #LOS_EPERM The rwlock is used in system tasks. * @retval #LOS_OK The rwlock is successfully locked. * @par Dependency: * * @see LOS_MuxInit | LOS_MuxUnlock */ extern UINT32 LOS_RwlockWrLock(LosRwlock *rwlock, UINT32 timeout); /** * @ingroup los_rwlock * @brief Try wait to lock a write lock. * * @par Description: * This API is used to wait for a specified period of time to lock a write lock. * @attention * * * @param rwlock [IN] Handle of the rwlock to be waited on. * * @retval #LOS_EINVAL The rwlock pointer is NULL or Lock status error. * @retval #LOS_EINTR The rwlock is being locked during an interrupt. * @retval #LOS_EBUSY Fail to get the rwlock, the rwlock has been used. * @retval #LOS_EBADF The lock has been destroyed or broken. * @retval #LOS_EDEADLK rwlock error check failed or System locked task scheduling. * @retval #LOS_ETIMEDOUT The rwlock waiting times out. * @retval #LOS_EPERM The rwlock is used in system tasks. * @retval #LOS_OK The rwlock is successfully locked. * @par Dependency: * * @see LOS_RwlockInit | LOS_RwlockUnLock */ extern UINT32 LOS_RwlockTryWrLock(LosRwlock *rwlock); /** * @ingroup los_rwlock * @brief Release a rwlock. * * @par Description: * This API is used to release a specified rwlock. * @attention * * * @param rwlock [IN] Handle of the rwlock to be released. * * @retval #LOS_EINVAL The rwlock pointer is NULL, The timeout is zero or Lock status error. * @retval #LOS_EINTR The rwlock is being locked during an interrupt. * @retval #LOS_EPERM The rwlock is not locked or has been used. * @retval #LOS_EBADF The lock has been destroyed or broken. * @retval #LOS_EDEADLK rwlock error check failed or System locked task scheduling. * @retval #LOS_ETIMEDOUT The rwlock waiting times out. * @retval #LOS_EPERM The rwlock is used in system tasks. * @retval #LOS_OK The rwlock is successfully locked. * @par Dependency: * * @see LOS_RwlockInit | LOS_ReadLock | LOS_WriteLock */ extern UINT32 LOS_RwlockUnLock(LosRwlock *rwlock); #ifdef __cplusplus #if __cplusplus } #endif #endif /* __cplusplus */ #endif /* _LOS_MUX_H */