/* ---------------------------------------------------------------------------- * Copyright (c) Huawei Technologies Co., Ltd. 2018-2019. All rights reserved. * Description: Lock Dependency Check. * Author: Huawei LiteOS Team * Create: 2018-10-18 * 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_lockdep lockdep * @ingroup kernel */ #ifndef _LOS_LOCKDEP_H #define _LOS_LOCKDEP_H #include "los_config.h" #ifdef __cplusplus #if __cplusplus extern "C" { #endif /* __cplusplus */ #endif /* __cplusplus */ typedef struct Spinlock SPIN_LOCK_S; #ifdef LOSCFG_KERNEL_SMP_LOCKDEP #define MAX_LOCK_DEPTH 16U enum LockDepErrType { LOCKDEP_SUCEESS = 0, LOCKDEP_ERR_DOUBLE_LOCK, LOCKDEP_ERR_DEAD_LOCK, LOCKDEP_ERR_UNLOCK_WITHOUT_LOCK, /* overflow, needs expand */ LOCKDEP_ERR_OVERFLOW, }; /*这是一个枚举类型 LockDepErrType,用于表示在锁依赖性检查中可能发生的不同错误类型。下面是该枚举类型定义的各个取值及其含义: LOCKDEP_SUCCESS:锁依赖性检查成功,没有发现错误。 LOCKDEP_ERR_DOUBLE_LOCK:发现了重复加锁的错误。表示在某个线程中多次对同一把锁进行了加锁操作。 LOCKDEP_ERR_DEAD_LOCK:发现了死锁的错误。表示在不同线程之间存在循环的锁依赖关系,导致了死锁的发生。 LOCKDEP_ERR_UNLOCK_WITHOUT_LOCK:发现了未解锁的错误。表示在某个线程中出现了解锁操作,但该线程之前并未对对应的锁进行过加锁操作。 LOCKDEP_ERR_OVERFLOW:溢出错误。表示枚举类型需要扩展,因为当前定义的取值已经无法满足需求。*/ typedef struct { VOID *lockPtr; VOID *lockAddr; UINT64 waitTime; UINT64 holdTime; } HeldLocks; /*这个结构体主要用于在锁依赖性分析和调试过程中记录当前线程持有的锁的相关信息。通过记录这些信息, 可以对锁的使用情况进行监控和分析,以便发现潜在的死锁、竞争条件等问题。 lockPtr:表示持有的锁的指针。它是一个 VOID* 类型的指针,通常用于指向被持有的锁的内存地址。 lockAddr:表示持有的锁的地址。它是一个 VOID* 类型的指针,通常用于指向锁对象的内存地址。 waitTime:表示等待该锁的时间。它是一个 UINT64 类型的变量,通常表示在获取该锁之前,当前线程等待该锁的时间。 holdTime:表示持有该锁的时间。它是一个 UINT64 类型的变量,通常表示当前线程已经持有该锁的时间。*/ typedef struct { VOID *waitLock; INT32 lockDepth; HeldLocks heldLocks[MAX_LOCK_DEPTH]; } LockDep; /*这个结构体主要用于在锁依赖性分析和调试过程中记录当前线程的锁依赖关系。 通过记录当前线程正在等待的锁、持有的锁的深度以及每个层次的锁的详细信息, 可以对锁的使用情况进行监控和分析,以便发现潜在的死锁、竞争条件等问题。*/ /** * @ingroup los_lockdep * * @par Description: * This API is used to check dead lock in spinlock. * @attention *