本文整理汇总了C++中print_lock函数的典型用法代码示例。如果您正苦于以下问题:C++ print_lock函数的具体用法?C++ print_lock怎么用?C++ print_lock使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了print_lock函数的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的C++代码示例。
示例1: isc_rwlock_unlock
isc_result_t
isc_rwlock_unlock(isc_rwlock_t *rwl, isc_rwlocktype_t type) {
REQUIRE(VALID_RWLOCK(rwl));
LOCK(&rwl->lock);
REQUIRE(rwl->type == type);
UNUSED(type);
#ifdef ISC_RWLOCK_TRACE
print_lock(isc_msgcat_get(isc_msgcat, ISC_MSGSET_RWLOCK,
ISC_MSG_PREUNLOCK, "preunlock"), rwl, type);
#endif
INSIST(rwl->active > 0);
rwl->active--;
if (rwl->active == 0) {
if (rwl->original != isc_rwlocktype_none) {
rwl->type = rwl->original;
rwl->original = isc_rwlocktype_none;
}
if (rwl->type == isc_rwlocktype_read) {
rwl->granted = 0;
if (rwl->writers_waiting > 0) {
rwl->type = isc_rwlocktype_write;
SIGNAL(&rwl->writeable);
} else if (rwl->readers_waiting > 0) {
/* Does this case ever happen? */
BROADCAST(&rwl->readable);
}
} else {
if (rwl->readers_waiting > 0) {
if (rwl->writers_waiting > 0 &&
rwl->granted < rwl->write_quota) {
SIGNAL(&rwl->writeable);
} else {
rwl->granted = 0;
rwl->type = isc_rwlocktype_read;
BROADCAST(&rwl->readable);
}
} else if (rwl->writers_waiting > 0) {
rwl->granted = 0;
SIGNAL(&rwl->writeable);
} else {
rwl->granted = 0;
}
}
}
INSIST(rwl->original == isc_rwlocktype_none);
#ifdef ISC_RWLOCK_TRACE
print_lock(isc_msgcat_get(isc_msgcat, ISC_MSGSET_RWLOCK,
ISC_MSG_POSTUNLOCK, "postunlock"),
rwl, type);
#endif
UNLOCK(&rwl->lock);
return (ISC_R_SUCCESS);
}
开发者ID:each,项目名称:bind9-collab,代码行数:60,代码来源:rwlock.c
示例2: unlock_of_not_locked
static void
unlock_of_not_locked(erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck)
{
print_lock("Unlocking ", lck, " lock which is not locked by thread!\n");
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例3: unlock_of_required_lock
static void
unlock_of_required_lock(erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck)
{
print_lock("Unlocking required ", lck, " lock!\n");
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例4: unrequire_of_not_required_lock
static void
unrequire_of_not_required_lock(erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck)
{
print_lock("Unrequire on ", lck, " lock not required!\n");
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例5: require_twice
static void
require_twice(erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck)
{
print_lock("Require on ", lck, " lock already required!\n");
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例6: required_not_locked
static void
required_not_locked(lc_thread_t *thr, erts_lc_lock_t *lck)
{
print_lock("Required ", lck, " lock not locked!\n");
print_curr_locks(thr);
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例7: require_twice
static void
require_twice(lc_thread_t *thr, erts_lc_lock_t *lck)
{
print_lock("Require on ", lck, " lock already required!\n");
print_curr_locks(thr);
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例8: unrequire_of_not_required_lock
static void
unrequire_of_not_required_lock(lc_thread_t *thr, erts_lc_lock_t *lck)
{
print_lock("Unrequire on ", lck, " lock not required!\n");
print_curr_locks(thr);
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例9: unlock_of_required_lock
static void
unlock_of_required_lock(lc_thread_t *thr, erts_lc_lock_t *lck)
{
print_lock("Unlocking required ", lck, " lock!\n");
print_curr_locks(thr);
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例10: unlock_of_not_locked
static void
unlock_of_not_locked(lc_thread_t *thr, erts_lc_lock_t *lck)
{
print_lock("Unlocking ", lck, " lock which is not locked by thread!\n");
print_curr_locks(thr);
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例11: required_not_locked
static void
required_not_locked(erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck)
{
print_lock("Required ", lck, " lock not locked!\n");
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:7,代码来源:erl_lock_check.c
示例12: lock_order_violation
static void
lock_order_violation(erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck)
{
print_lock("Lock order violation occured when locking ", lck, "!\n");
print_curr_locks(l_lcks);
print_lock_order();
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:8,代码来源:erl_lock_check.c
示例13: lock_order_violation
static void
lock_order_violation(lc_thread_t *thr, erts_lc_lock_t *lck)
{
print_lock("Lock order violation occured when locking ", lck, "!\n");
print_curr_locks(thr);
print_lock_order();
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:8,代码来源:erl_lock_check.c
示例14: unlock_op_mismatch
static void
unlock_op_mismatch(lc_thread_t *thr, erts_lc_lock_t *lck,
erts_lock_options_t options)
{
erts_fprintf(stderr, "Unlocking (%s) ", rw_op_str(options));
print_lock("", lck, " lock which mismatch previous lock operation!\n");
print_curr_locks(thr);
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:9,代码来源:erl_lock_check.c
示例15: lock_twice
static void
lock_twice(char *prefix, lc_thread_t *thr, erts_lc_lock_t *lck,
erts_lock_options_t options)
{
erts_fprintf(stderr, "%s (%s)", prefix, rw_op_str(options));
print_lock(" ", lck, " lock which is already locked by thread!\n");
print_curr_locks(thr);
lc_abort();
}
开发者ID:RaimoNiskanen,项目名称:otp,代码行数:9,代码来源:erl_lock_check.c
示例16: unlock_op_mismatch
static void
unlock_op_mismatch(erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck,
Uint16 op_flags)
{
erts_fprintf(stderr, "Unlocking%s ", rw_op_str(op_flags));
print_lock("", lck, " lock which mismatch previous lock operation!\n");
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:9,代码来源:erl_lock_check.c
示例17: lock_twice
static void
lock_twice(char *prefix, erts_lc_locked_locks_t *l_lcks, erts_lc_lock_t *lck,
Uint16 op_flags)
{
erts_fprintf(stderr, "%s%s", prefix, rw_op_str(op_flags));
print_lock(" ", lck, " lock which is already locked by thread!\n");
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:9,代码来源:erl_lock_check.c
示例18: type_order_violation
static void
type_order_violation(char *op, erts_lc_locked_locks_t *l_lcks,
erts_lc_lock_t *lck)
{
erts_fprintf(stderr, "Lock type order violation occured when ");
print_lock(op, lck, "!\n");
ASSERT(l_lcks);
print_curr_locks(l_lcks);
lc_abort();
}
开发者ID:Argger,项目名称:otp,代码行数:10,代码来源:erl_lock_check.c
示例19: main
int main()
{
char InputPath[65535] ;
getcwd(InputPath , 65535);
//放要讀取檔案的資料夾路徑到InputPath字串裡
char szDir[65535];
char dir[65535];
WIN32_FIND_DATA FileData;
HANDLE hList;
sprintf(szDir, "%s\\*.nmf", InputPath );
if ( (hList = FindFirstFile(szDir, &FileData))==INVALID_HANDLE_VALUE ) {
printf("No nemofiles be found.\n\n");
}
else {
//get first *.nmf
//sprintf(dir, "%s\\%s", InputPath, FileData.cFileName);
//printf("%s\n", dir);
print_scanconfig(FileData.cFileName);
print_lock(FileData.cFileName);
while (1) {
if (!FindNextFile(hList, &FileData)) {
if (GetLastError() == ERROR_NO_MORE_FILES)
break;
}
//get next *.nmf
//sprintf(dir, "%s\\%s", InputPath, FileData.cFileName);
//printf("%s\n", dir);
print_scanconfig(FileData.cFileName);
print_lock(FileData.cFileName);
}
}
FindClose(hList);
system("pause");
return 0;
}
开发者ID:ticotico,项目名称:test-nmf,代码行数:40,代码来源:print+nemo+file+scan+config+and+lock+v1.06+.c
示例20: pcpui_trace_locks_handler
static void pcpui_trace_locks_handler(void *event, void *data)
{
struct pcpu_trace_event *te = (struct pcpu_trace_event*)event;
const char *func_name;
uintptr_t lock_addr = te->arg1;
if (lock_addr > KERN_LOAD_ADDR)
func_name = get_fn_name(lock_addr);
else
func_name = "Dynamic lock";
print_lock();
printk("Time %uus, lock %p (%s)\n", te->arg0, lock_addr, func_name);
printk("\t");
spinlock_debug((spinlock_t*)lock_addr);
print_unlock();
}
开发者ID:brho,项目名称:akaros,代码行数:16,代码来源:smp.c
注:本文中的print_lock函数示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论