XWOS API  4.0
XWOS C/C++ API参考手册
载入中...
搜索中...
未找到
xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList > 模板类 参考

独占读部分中断上锁模式的顺序锁RAII机制守卫 更多...

#include <Seqlock.hxx>

xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList > 的协作图:

Public 成员函数

 RdexLkIrqsGrd (Seqlock *seqlock)
 构造顺序锁的RAII机制守卫
 
 RdexLkIrqsGrd (Seqlock &seqlock)
 构造顺序锁的RAII机制守卫
 
 ~RdexLkIrqsGrd ()
 析构顺序锁的RAII机制守卫
 
void unlock ()
 解锁顺序锁
 
enum LockStatus getStatus ()
 获取锁状态
 
xwer_t wait (sync::Cond *cond)
 等待条件量
 
xwer_t wait (sync::Cond &cond)
 等待条件量
 
xwer_t wait (sync::Cond *cond, xwtm_t to)
 限时等待条件量
 
xwer_t wait (sync::Cond &cond, xwtm_t to)
 限时等待条件量
 

Protected 成员函数

 RdexLkIrqsGrd ()
 

Protected 属性

SeqlockmSeqlock
 
enum LockStatus mStatus
 
xwirq_t mIrqs [sizeof...(TIrqList)]
 
xwreg_t mIrqFlags [sizeof...(TIrqList)]
 

详细描述

template<xwirq_t... TIrqList>
class xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >

独占读部分中断上锁模式的顺序锁RAII机制守卫

  • 构造函数关闭并保存 TIrqList 列表内的中断,关闭当前CPU调度器的抢占,上锁顺序锁。 上锁失败会自旋等待,直到上锁成功为止。
  • 析构函数解锁顺序锁,开启当前CPU调度器的抢占, 用保存的中断标志恢复 TIrqList 列表内的中断。
    注解
  • 上下文:线程、TIrqList 列表中的中断

在文件 Seqlock.hxx1015 行定义.

构造及析构函数说明

◆ RdexLkIrqsGrd() [1/3]

template<xwirq_t... TIrqList>
xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::RdexLkIrqsGrd ( Seqlock seqlock)
inline

构造顺序锁的RAII机制守卫

参数
[in]seqlock顺序锁对象指针

在文件 Seqlock.hxx1028 行定义.

1029 : mSeqlock(seqlock)
1031 , mIrqs{ TIrqList... }
1032 {
1033 if (nullptr != mSeqlock) {
1035 sizeof...(TIrqList));
1037 }
1038 }
xwreg_t mIrqFlags[sizeof...(TIrqList)]
Definition Seqlock.hxx:1021
xwirq_t mIrqs[sizeof...(TIrqList)]
Definition Seqlock.hxx:1020
struct xwos_sqlk mLock
Definition Seqlock.hxx:2084
static void xwos_sqlk_rdex_lock_irqssv(struct xwos_sqlk *sql, const xwirq_t irqs[], xwreg_t flags[], xwsz_t num)
XWOS API:开启独占读临界区,保存部分中断的中断标志并关闭
Definition seqlock.h:389
函数调用图:

◆ RdexLkIrqsGrd() [2/3]

template<xwirq_t... TIrqList>
xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::RdexLkIrqsGrd ( Seqlock seqlock)
inline

构造顺序锁的RAII机制守卫

参数
[in]seqlock顺序锁对象引用

在文件 Seqlock.hxx1044 行定义.

1045 : mSeqlock(&seqlock)
1047 , mIrqs{ TIrqList... }
1048 {
1049 if (nullptr != mSeqlock) {
1051 sizeof...(TIrqList));
1053 }
1054 }
函数调用图:

◆ ~RdexLkIrqsGrd()

template<xwirq_t... TIrqList>
xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::~RdexLkIrqsGrd ( )
inline

析构顺序锁的RAII机制守卫

在文件 Seqlock.hxx1059 行定义.

1060 {
1061 if (nullptr != mSeqlock) {
1065 sizeof...(TIrqList));
1066 }
1067 }
1068 }
static void xwos_sqlk_rdex_unlock_irqsrs(struct xwos_sqlk *sql, const xwirq_t irqs[], xwreg_t flags[], xwsz_t num)
XWOS API:关闭独占读临界区,恢复部分中断的中断标志
Definition seqlock.h:429
函数调用图:

◆ RdexLkIrqsGrd() [3/3]

template<xwirq_t... TIrqList>
xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::RdexLkIrqsGrd ( )
inlineprotected

在文件 Seqlock.hxx1210 行定义.

1211 : mSeqlock(nullptr)
1213 {
1214 }

成员函数说明

◆ unlock()

template<xwirq_t... TIrqList>
void xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::unlock ( )
inline

解锁顺序锁

  • 主动解锁后,析构函数将不再解锁。

在文件 Seqlock.hxx1075 行定义.

1076 {
1077 if (nullptr != mSeqlock) {
1081 sizeof...(TIrqList));
1082 }
1083 }
1084 }
函数调用图:

◆ getStatus()

template<xwirq_t... TIrqList>
enum LockStatus xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::getStatus ( )
inline

获取锁状态

在文件 Seqlock.hxx1089 行定义.

1089{ return mStatus; }

◆ wait() [1/4]

template<xwirq_t... TIrqList>
xwer_t xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::wait ( sync::Cond cond)
inline

等待条件量

参数
[in]cond条件量对象的指针
返回
错误码
返回值
XWOK没有错误
-EFAULT无效的指针或空指针
-EINVAL参数无效
-ENOTTHDCTX不在线程上下文中
-ENOLCK未上锁
-EINTR等待被中断
注解
  • 上下文:线程
  • 调用此C++API的线程会阻塞等待条件量,等待的同时会解锁顺序锁。
  • 条件量被单播 sync::Cond::unicast() 或广播 sync::Cond::broadcast() 时,会唤醒正在等待的线程。
  • 线程被唤醒后,会重新用之前的上锁方式上锁顺序锁。
  • 重新上锁成功后将返回 XWOK
  • 线程的等待被中断后,此C++API返回 -EINTR
  • 如果此C++API返回 XWOK 的错误码后,应该 使用 getStatus() 确认是否上锁成功。

在文件 Seqlock.hxx1113 行定义.

1114 {
1115 xwer_t rc;
1116 if (nullptr != mSeqlock) {
1118 union xwos_ulock lock;
1119 xwsq_t lkst;
1120 lock.osal.sqlk = &mSeqlock->mLock;
1121 rc = xwos_cond_wait(cond->getXwosObj(), lock, XWOS_LK_SQLK_RDEX,
1122 nullptr, &lkst);
1123 if (rc < 0) {
1124 if (XWOS_LKST_UNLOCKED == lkst) {
1126 }
1127 }
1128 } else {
1129 rc = -ENOLCK;
1130 }
1131 } else {
1132 rc = -EFAULT;
1133 }
1134 return rc;
1135 }
#define EFAULT
Bad address
Definition errno.h:44
#define ENOLCK
No lock
Definition errno.h:76
signed long xwer_t
Definition type.h:554
unsigned long xwsq_t
Definition type.h:445
@ XWOS_LKST_UNLOCKED
Definition type.h:661
@ XWOS_LK_SQLK_RDEX
Definition type.h:644
static void xwos_sqlk_rdex_lock(struct xwos_sqlk *sql)
XWOS API:开启独占读临界区
Definition seqlock.h:189
static xwer_t xwos_cond_wait(struct xwos_cond *cond, union xwos_ulock lock, xwsq_t lktype, void *lkdata, xwsq_t *lkst)
XWOS API:等待条件量
Definition cond.h:432
所有锁的联合
Definition type.h:680
union xwos_ulock::@8 osal
struct xwmp_sqlk * sqlk
Definition type.h:684
函数调用图:

◆ wait() [2/4]

template<xwirq_t... TIrqList>
xwer_t xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::wait ( sync::Cond cond)
inline

等待条件量

参数
[in]cond条件量对象的引用
返回
错误码
注解
  • 上下文:线程

在文件 Seqlock.hxx1146 行定义.

1146{ return wait(&cond); }
xwer_t wait(sync::Cond *cond)
等待条件量
Definition Seqlock.hxx:1113
函数调用图:
这是这个函数的调用关系图:

◆ wait() [3/4]

template<xwirq_t... TIrqList>
xwer_t xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::wait ( sync::Cond cond,
xwtm_t  to 
)
inline

限时等待条件量

参数
[in]cond条件量对象的指针
[in]to期望唤醒的时间点
返回
错误码
返回值
XWOK没有错误
-EFAULT无效的指针或空指针
-EINVAL参数无效
-ENOTTHDCTX不在线程上下文中
-ENOLCK未上锁
-EINTR等待被中断
-ETIMEDOUT超时
注解
  • 上下文:线程
  • 调用此C++API的线程会限时阻塞等待条件量,等待的同时会解锁顺序锁。
  • 条件量被单播 sync::Cond::unicast() 或广播 sync::Cond::broadcast() 时,会唤醒正在等待的线程。
  • 线程被唤醒后,会重新用之前的上锁方式上锁顺序锁 。
  • 重新上锁成功后将返回 XWOK
  • 线程的等待被中断后,此C++API返回 -EINTR
  • 线程的等待超时后,此C++API返回 -ETIMEDOUT
  • 如果此C++API返回 XWOK 的错误码,应该 使用 getStatus() 确认是否上锁成功。

在文件 Seqlock.hxx1173 行定义.

1174 {
1175 xwer_t rc;
1176 if (nullptr != mSeqlock) {
1178 union xwos_ulock lock;
1179 xwsq_t lkst;
1180 lock.osal.sqlk = &mSeqlock->mLock;
1181 rc = xwos_cond_wait_to(cond->getXwosObj(), lock, XWOS_LK_SQLK_RDEX,
1182 nullptr, to, &lkst);
1183 if (rc < 0) {
1184 if (XWOS_LKST_UNLOCKED == lkst) {
1186 }
1187 }
1188 } else {
1189 rc = -ENOLCK;
1190 }
1191 } else {
1192 rc = -EFAULT;
1193 }
1194 return rc;
1195 }
static xwer_t xwos_cond_wait_to(struct xwos_cond *cond, union xwos_ulock lock, xwsq_t lktype, void *lkdata, xwtm_t to, xwsq_t *lkst)
XWOS API:限时等待条件量
Definition cond.h:492
函数调用图:

◆ wait() [4/4]

template<xwirq_t... TIrqList>
xwer_t xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::wait ( sync::Cond cond,
xwtm_t  to 
)
inline

限时等待条件量

参数
[in]cond条件量对象的引用
[in]to期望唤醒的时间点
返回
错误码
注解
  • 上下文:线程

在文件 Seqlock.hxx1207 行定义.

1207{ return wait(&cond, to); }
函数调用图:
这是这个函数的调用关系图:

结构体成员变量说明

◆ mSeqlock

template<xwirq_t... TIrqList>
Seqlock* xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::mSeqlock
protected

在文件 Seqlock.hxx1018 行定义.

◆ mStatus

template<xwirq_t... TIrqList>
enum LockStatus xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::mStatus
protected

在文件 Seqlock.hxx1019 行定义.

◆ mIrqs

template<xwirq_t... TIrqList>
xwirq_t xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::mIrqs[sizeof...(TIrqList)]
protected

在文件 Seqlock.hxx1020 行定义.

◆ mIrqFlags

template<xwirq_t... TIrqList>
xwreg_t xwos::lock::Seqlock::RdexLkIrqsGrd< TIrqList >::mIrqFlags[sizeof...(TIrqList)]
protected

在文件 Seqlock.hxx1021 行定义.


该类的文档由以下文件生成: