本文整理匯總了C++中ENTER_CRITICAL_SECTION函數的典型用法代碼示例。如果您正苦於以下問題:C++ ENTER_CRITICAL_SECTION函數的具體用法?C++ ENTER_CRITICAL_SECTION怎麽用?C++ ENTER_CRITICAL_SECTION使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了ENTER_CRITICAL_SECTION函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: ENTER_CRITICAL_SECTION
/**
* @brief get message that matches the header in the queue
*
* NOTE it matches only daddr, saddr, did, sid, type
* NOTE it only gets the first that matches the description
*/
Message *mq_get(mq_t *q, Message *m)
{
HAS_CRITICAL_SECTION;
Message *ret;
#ifdef SOS_USE_PREEMPTION
if(q->head == NULL) return NULL;
ENTER_CRITICAL_SECTION();
// Search the queue
ret = mq_real_get(&(q->head), m);
#else
if(q->msg_cnt == 0) return NULL;
ENTER_CRITICAL_SECTION();
//! first search high priority queue
ret = mq_real_get(&(q->hq_head), &(q->hq_tail), m);
if(ret) {
q->msg_cnt--;
LEAVE_CRITICAL_SECTION();
return ret;
}
//! search low priority queue
ret = mq_real_get(&(q->lq_head), &(q->lq_tail), m);
if(ret) {
q->msg_cnt--;
}
#endif
LEAVE_CRITICAL_SECTION();
return ret;
}
示例2: radio_msg_alloc
/*************************************************************************
* will be called by post_net, etc functions to send message *
*************************************************************************/
void radio_msg_alloc(Message *msg)
{
HAS_CRITICAL_SECTION;
uint16_t sleeptime = 0;
uint8_t resend_pack = 1;
ENTER_CRITICAL_SECTION();
if( Radio_Check_CCA() ) {
incSeq();
if(radio_msg_send(msg))
{
resend_pack = 0;
msg_send_senddone(msg, 1, RADIO_PID);
}
}
if(resend_pack)
{
if( getMsgNumOfQueue() < MAX_MSGS_IN_QUEUE ) //queue is full?
{
mq_enqueue(&vmac_pq, msg);
ENTER_CRITICAL_SECTION(); // most probably mq_enqueue calls LEAVE_CRITICAL_SECTION somewhere!
}
else
{
msg_send_senddone(msg, 0, RADIO_PID); //release the memory for the msg
ENTER_CRITICAL_SECTION(); // most probably msg_send_senddone calls LEAVE_CRITICAL_SECTION somewhere!
}
sleeptime = MacBackoff_congestionBackoff(retry_count);
ker_timer_restart(RADIO_PID, WAKEUP_TIMER_TID, sleeptime); // setup backoff timer
}
LEAVE_CRITICAL_SECTION();
}
示例3: FddpPushJobItem
static BOOL FddpPushJobItem(FDD_JOB_ITEM *pJobItem)
{
BOOL bResult = TRUE;
ENTER_CRITICAL_SECTION();
{
/* check up the remain space of Q */
if(m_JobItemQ.cnt >= FDD_JOB_ITEM_Q_SIZE) {
bResult = FALSE;
goto $exit;
}
/* process */
m_JobItemQ.cnt++;
m_JobItemQ.queue[m_JobItemQ.tail].type = pJobItem->type;
m_JobItemQ.queue[m_JobItemQ.tail].sector = pJobItem->sector;
m_JobItemQ.queue[m_JobItemQ.tail].numbers_of_sectors = pJobItem->numbers_of_sectors;
m_JobItemQ.queue[m_JobItemQ.tail].pt_data = pJobItem->pt_data;
m_JobItemQ.queue[m_JobItemQ.tail].thread = pJobItem->thread;
m_JobItemQ.tail++;
if(m_JobItemQ.tail >= FDD_JOB_ITEM_Q_SIZE)
m_JobItemQ.tail = 0;
}
$exit:
EXIT_CRITICAL_SECTION();
return bResult;
}
示例4: SafeRealloc
int SafeRealloc(void **Memory_ptr, size_t NewBytes)
{
void *New;
#ifdef WIN32
ENTER_CRITICAL_SECTION(AllocCS);
#else
LOCK_SPIN(AllocSpin);
#endif /* WIN32 */
New = realloc(*Memory_ptr, NewBytes);
#ifdef WIN32
LEAVE_CRITICAL_SECTION(AllocCS);
#else
UNLOCK_SPIN(AllocSpin);
#endif /* WIN32 */
if(New != NULL)
{
*Memory_ptr = New;
return 0;
} else {
return -1;
}
}
示例5: FddpPopJobItem
static BOOL FddpPopJobItem(FDD_JOB_ITEM *pJobItem)
{
BOOL bResult = TRUE;
ENTER_CRITICAL_SECTION();
{
/* check up count */
if(m_JobItemQ.cnt == 0) {
bResult = FALSE;
goto $exit;
}
/* process */
m_JobItemQ.cnt--;
pJobItem->type = m_JobItemQ.queue[m_JobItemQ.head].type;
pJobItem->sector = m_JobItemQ.queue[m_JobItemQ.head].sector;
pJobItem->numbers_of_sectors = m_JobItemQ.queue[m_JobItemQ.head].numbers_of_sectors;
pJobItem->pt_data = m_JobItemQ.queue[m_JobItemQ.head].pt_data;
pJobItem->thread = m_JobItemQ.queue[m_JobItemQ.head].thread;
m_JobItemQ.head++;
if(m_JobItemQ.head >= FDD_JOB_ITEM_Q_SIZE)
m_JobItemQ.head = 0;
}
$exit:
EXIT_CRITICAL_SECTION();
return bResult;
}
示例6: eMBRTUReceive
eMBErrorCode
eMBRTUReceive( UCHAR * pucRcvAddress, UCHAR ** pucFrame, USHORT * pusLength )
{
BOOL xFrameReceived = FALSE;
eMBErrorCode eStatus = MB_ENOERR;
ENTER_CRITICAL_SECTION();
assert( usRcvBufferPos < MB_SER_PDU_SIZE_MAX );
/* Length and CRC check */
if( ( usRcvBufferPos >= MB_SER_PDU_SIZE_MIN )
&& ( usMBCRC16( ( UCHAR * ) ucRTUBuf, usRcvBufferPos ) == 0 ) )
{
/* Save the address field. All frames are passed to the upper layed
* and the decision if a frame is used is done there.
*/
*pucRcvAddress = ucRTUBuf[MB_SER_PDU_ADDR_OFF];
/* Total length of Modbus-PDU is Modbus-Serial-Line-PDU minus
* size of address field and CRC checksum.
*/
*pusLength = ( USHORT )( usRcvBufferPos - MB_SER_PDU_PDU_OFF - MB_SER_PDU_SIZE_CRC );
/* Return the start of the Modbus PDU to the caller. */
*pucFrame = ( UCHAR * ) & ucRTUBuf[MB_SER_PDU_PDU_OFF];
xFrameReceived = TRUE;
}
else
{
eStatus = MB_EIO;
}
EXIT_CRITICAL_SECTION();
return eStatus;
}
示例7: eMBMasterRTUReceive
/*************************************************************************
* eMBMasterRTUReceive
* Функция приёма данных и проверка их целосности.
*************************************************************************/
eMBErrorCode
eMBMasterRTUReceive( UCHAR * pucRcvAddress, UCHAR ** pucFrame, USHORT * pusLength )
{
eMBErrorCode eStatus = MB_ENOERR;
ENTER_CRITICAL_SECTION( );
assert_param( usMasterRcvBufferPos < MB_SER_PDU_SIZE_MAX );
// Проверка длинны пакета и его CRC
if( ( usMasterRcvBufferPos >= MB_SER_PDU_SIZE_MIN )
&& ( usMBCRC16( ( UCHAR * ) ucMasterRTURcvBuf, usMasterRcvBufferPos ) == 0 ) )
{
// Save the address field. All frames are passed to the upper layed and the decision if a frame is used is done there.
*pucRcvAddress = ucMasterRTURcvBuf[MB_SER_PDU_ADDR_OFF];
// Общая длина данных(Modbus-PDU) без поля адреса и CRC.
*pusLength = ( USHORT )( usMasterRcvBufferPos - MB_SER_PDU_PDU_OFF - MB_SER_PDU_SIZE_CRC );
// Адрес начала данных(Modbus-PDU)
*pucFrame = ( UCHAR * ) & ucMasterRTURcvBuf[MB_SER_PDU_PDU_OFF];
}
else
{
eStatus = MB_EIO;
}
EXIT_CRITICAL_SECTION( );
return eStatus;
}
示例8: timer_init
/**
* Timer initialization
*/
void timer_init(uint8_t interval, uint8_t scale)
{
HAS_CRITICAL_SECTION;
ENTER_CRITICAL_SECTION();
scale &= 0x7;
scale |= 0x8;
cbi(TIMSK, TOIE0);
cbi(TIMSK, OCIE0);
//!< Disable TC0 interrupt
/**
* set Timer/Counter0 to be asynchronous
* from the CPU clock with a second external
* clock(32,768kHz)driving it
*/
sbi(ASSR, AS0);
outp(scale, TCCR0); //!< prescale the timer to be clock/128 to make it
outp(0, TCNT0);
outp(interval, OCR0);
sbi(TIMSK, OCIE0);
LEAVE_CRITICAL_SECTION();
}
示例9: vMBPortSerialEnable
/* ----------------------- Start implementation -----------------------------*/
void vMBPortSerialEnable( BOOL xRxEnable, BOOL xTxEnable )
{
/* If xRXEnable enable serial receive interrupts. If xTxENable enable
* transmitter empty interrupts.
*/
ENTER_CRITICAL_SECTION( );
if(xRxEnable){
//SciaRegs.SCICTL1.bit.RXENA = 1;
SciaRegs.SCICTL2.bit.RXBKINTENA =1;
}
else {
//SciaRegs.SCICTL1.bit.RXENA = 0;
SciaRegs.SCICTL2.bit.RXBKINTENA =0;
}
if(xTxEnable){
//SciaRegs.SCICTL1.bit.TXENA = 1;
SciaRegs.SCICTL2.bit.TXINTENA =1;
SciaRegs.SCICTL2.bit.TXEMPTY = 0;
SciaRegs.SCICTL1.bit.SWRESET = 0;
SciaRegs.SCICTL1.bit.SWRESET = 1;
//IFR = 0x0000;
}
else{
//SciaRegs.SCICTL1.bit.TXENA = 0;
SciaRegs.SCICTL2.bit.TXINTENA =0;
}
EXIT_CRITICAL_SECTION( );
}
示例10: __attribute__
/**
* Write a block of data into flash (block size is 64 bytes)
* Note: this routine has to be in the RAM.
*/
static void __attribute__ ((section(".data"))) flash_write_block( uint32_t addr, uint8_t* buf, uint16_t len )
{
HAS_CRITICAL_SECTION;
register uint16_t i;
register uint16_t* d = (uint16_t*) ((uint16_t)addr);
register uint16_t* b = (uint16_t*) buf;
ENTER_CRITICAL_SECTION();
while( FCTL3 & BUSY );
FCTL2 = FWKEY + FSSEL1 + FN2; // SMCLK / 5
FCTL3 = FWKEY; // Clear LOCK
FCTL1 = FWKEY + BLKWRT + WRT; // Enable block write
for( i = 0; i < 32; i++ ) {
*d = *b;
d++;
b++;
while( (FCTL3 & WAIT) == 0);
}
FCTL1 = FWKEY; // Clear WRT and BLKWRT
while( FCTL3 & BUSY ); // Test Busy
FCTL3 = FWKEY + LOCK; // Set LOCK
LEAVE_CRITICAL_SECTION();
}
示例11: ker_spi_send_data
/**
* Send data over the spi
*/
int8_t ker_spi_send_data(
uint8_t *msg,
uint8_t msg_size,
uint8_t calling_id) {
HAS_CRITICAL_SECTION;
if (s.state == SPI_SYS_IDLE) {
return -EINVAL;
}
if ((s.calling_mod_id != calling_id) || ((s.state != SPI_SYS_WAIT) && (s.state != SPI_SYS_DMA_WAIT))) {
return -EBUSY;
}
// ensure calling app gave us a message
if (NULL != msg) {
s.usrBuf = s.bufPtr = msg;
} else {
return -EINVAL;
}
// need to assert CS pin
if (s.flags & SPI_SYS_CS_HIGH_FLAG) {
spi_cs_high(s.addr);
} else {
spi_cs_low(s.addr);
}
ENTER_CRITICAL_SECTION();
s.len = msg_size;
s.state = SPI_SYS_TX;
LEAVE_CRITICAL_SECTION();
UART_DBG(a, 0x22, s.calling_mod_id, 0x01, 0x02, SPI_PID);
return spi_masterTxData(s.bufPtr, s.len, s.flags);
}
示例12: WritePATable
// *************************************************************************************************
// @fn WritePATable
// @brief Write data to power table
// @param unsigned char value Value to write
// @return none
// *************************************************************************************************
void WritePATable(unsigned char value)
{
unsigned char readbackPATableValue = 0;
u16 int_state;
ENTER_CRITICAL_SECTION(int_state);
while (readbackPATableValue != value)
{
while (!(RF1AIFCTL1 & RFINSTRIFG)) ;
RF1AINSTRW = 0x7E00 + value; // PA Table write (burst)
while (!(RF1AIFCTL1 & RFINSTRIFG)) ;
RF1AINSTRB = RF_SNOP; // reset pointer
while (!(RF1AIFCTL1 & RFINSTRIFG)) ;
RF1AINSTRB = 0xFE; // PA Table read (burst)
while (!(RF1AIFCTL1 & RFDINIFG)) ;
RF1ADINB = 0x00; //dummy write
while (!(RF1AIFCTL1 & RFDOUTIFG)) ;
readbackPATableValue = RF1ADOUT0B;
while (!(RF1AIFCTL1 & RFINSTRIFG)) ;
RF1AINSTRB = RF_SNOP;
}
EXIT_CRITICAL_SECTION(int_state);
}
示例13: protocolSendPacket
void protocolSendPacket(uint8 *buf, uint8 len)
{
uint16 checksum;
if ( (len!=PDU_SIZE) || (g_serialPortRecvState!=STATE_RX_IDLE) )
{
return ;
}
ENTER_CRITICAL_SECTION();
g_serialPortBufSendCnt = len;
g_serialPortSendPtr = g_serialPortBuf;
checksum = computeChecksum(buf, len-2);
buf[CSM_OFF] = (uint8)(checksum & 0xFF);
buf[CSM_OFF+1] = (uint8)(checksum >> 8);
g_serialPortSendState = STATE_TX_XMIT;
serialPortEnable(FALSE, TRUE);
EXIT_CRITICAL_SECTION();
return ;
}
示例14: eMBMasterRTUSend
/*************************************************************************
* eMBMasterRTUSend
* отправка пакета в MODBUS
*************************************************************************/
eMBErrorCode
eMBMasterRTUSend( UCHAR ucSlaveAddress, const UCHAR * pucFrame, USHORT usLength )
{
eMBErrorCode eStatus = MB_ENOERR;
USHORT usCRC16;
if ( ucSlaveAddress > MB_MASTER_TOTAL_SLAVE_NUM ) return MB_EINVAL;
ENTER_CRITICAL_SECTION( );
// Если приемник в режиме ожидания.
if( eRcvState == STATE_M_RX_IDLE )
{
// Первый байт до PDU это slave address.
pucMasterSndBufferCur = ( UCHAR * ) pucFrame - 1;
usMasterSndBufferCount = 1;
// Добавляем к пакету SlaveAddress
pucMasterSndBufferCur[MB_SER_PDU_ADDR_OFF] = ucSlaveAddress;
usMasterSndBufferCount += usLength;
// считаем CRC16
usCRC16 = usMBCRC16( ( UCHAR * ) pucMasterSndBufferCur, usMasterSndBufferCount );
ucMasterRTUSndBuf[usMasterSndBufferCount++] = ( UCHAR )( usCRC16 & 0xFF );
ucMasterRTUSndBuf[usMasterSndBufferCount++] = ( UCHAR )( usCRC16 >> 8 );
// Режим предачи.
eSndState = STATE_M_TX_XMIT;
xMBMasterPortSerialPutBUF(( CHAR *)pucMasterSndBufferCur,usMasterSndBufferCount); // передадим в порт весь блок сразу
xFrameIsBroadcast = ( ucMasterRTUSndBuf[MB_SER_PDU_ADDR_OFF] == MB_ADDRESS_BROADCAST ) ? TRUE : FALSE; // определяем широковещательный ли ?
}
示例15: eMBRTUStop
/**
-----------------------------------------------------------------------------------------------------------------------
eMBRTUStop
-----------------------------------------------------------------------------------------------------------------------
* Event Handler for GPI module
*
* @date DEC/02/2013
* @author FW_DEV_2
* @pre None
* @return None
************************************************************************************************************************
*/
void eMBRTUStop( void )
{
ENTER_CRITICAL_SECTION( );
vMBPortSerialEnable( FALSE, FALSE );
vMBPortTimersDisable( );
EXIT_CRITICAL_SECTION( );
}