📄 lock.c
字号:
/* Shared Memory Lock Routines * * This shared memory locked queue support routine need to be * able to lock the specified locked queue. Interrupts are * disabled while the queue is locked to prevent preemption * and deadlock when two tasks poll for the same lock. * previous level. * * COPYRIGHT (c) 1989-1999. * On-Line Applications Research Corporation (OAR). * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://www.rtems.com/license/LICENSE. * * $Id: lock.c,v 1.7.8.1 2003/09/04 18:43:57 joel Exp $ */#include <bsp.h>#include <shm_driver.h>/* * Shm_Initialize_lock * * Initialize the lock for the specified locked queue. */void Shm_Initialize_lock( Shm_Locked_queue_Control *lq_cb){ lq_cb->lock = LQ_UNLOCKED;}/* Shm_Lock( &lq_cb ) * * This shared memory locked queue support routine locks the * specified locked queue. It disables interrupts to prevent * a deadlock condition. */void Shm_Lock( Shm_Locked_queue_Control *lq_cb){ rtems_unsigned32 isr_level; vol_u32 *lockptr = &lq_cb->lock; rtems_unsigned32 lock_value; rtems_interrupt_disable( isr_level ); Shm_isrstat = isr_level; do { HPPA_ASM_LDCWS( 0, 0, lockptr, lock_value ); } while (lock_value == SHM_LOCK_VALUE);}/* * Shm_Unlock * * Unlock the lock for the specified locked queue. */void Shm_Unlock( Shm_Locked_queue_Control *lq_cb){ rtems_unsigned32 isr_level; lq_cb->lock = SHM_UNLOCK_VALUE; isr_level = Shm_isrstat; rtems_interrupt_enable( isr_level );}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -