|
QP/C++
|
00001 00002 // Product: QF/C++ 00003 // Last Updated for Version: 4.5.00 00004 // Date of the Last Update: May 19, 2012 00005 // 00006 // Q u a n t u m L e a P s 00007 // --------------------------- 00008 // innovating embedded systems 00009 // 00010 // Copyright (C) 2002-2012 Quantum Leaps, LLC. All rights reserved. 00011 // 00012 // This program is open source software: you can redistribute it and/or 00013 // modify it under the terms of the GNU General Public License as published 00014 // by the Free Software Foundation, either version 2 of the License, or 00015 // (at your option) any later version. 00016 // 00017 // Alternatively, this program may be distributed and modified under the 00018 // terms of Quantum Leaps commercial licenses, which expressly supersede 00019 // the GNU General Public License and are specifically designed for 00020 // licensees interested in retaining the proprietary status of their code. 00021 // 00022 // This program is distributed in the hope that it will be useful, 00023 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00024 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00025 // GNU General Public License for more details. 00026 // 00027 // You should have received a copy of the GNU General Public License 00028 // along with this program. If not, see <http://www.gnu.org/licenses/>. 00029 // 00030 // Contact information: 00031 // Quantum Leaps Web sites: http://www.quantum-leaps.com 00032 // http://www.state-machine.com 00033 // e-mail: info@quantum-leaps.com 00035 #include "qf_pkg.h" 00036 #include "qassert.h" 00037 00044 00045 QP_BEGIN_ 00046 00047 Q_DEFINE_THIS_MODULE("qa_lifo") 00048 00049 //............................................................................ 00050 void QActive::postLIFO(QEvt const * const e) { 00051 QF_CRIT_STAT_ 00052 QF_CRIT_ENTRY_(); 00053 00054 QS_BEGIN_NOCRIT_(QS_QF_ACTIVE_POST_LIFO, QS::aoObj_, this) 00055 QS_TIME_(); // timestamp 00056 QS_SIG_(e->sig); // the signal of this event 00057 QS_OBJ_(this); // this active object 00058 QS_U8_(QF_EVT_POOL_ID_(e)); // the pool Id of the event 00059 QS_U8_(QF_EVT_REF_CTR_(e)); // the ref count of the event 00060 QS_EQC_(m_eQueue.m_nFree); // number of free entries 00061 QS_EQC_(m_eQueue.m_nMin); // min number of free entries 00062 QS_END_NOCRIT_() 00063 00064 if (QF_EVT_POOL_ID_(e) != u8_0) { // is it a dynamic event? 00065 QF_EVT_REF_CTR_INC_(e); // increment the reference counter 00066 } 00067 00068 if (m_eQueue.m_frontEvt == null_evt) { // is the queue empty? 00069 m_eQueue.m_frontEvt = e; // deliver event directly 00070 QACTIVE_EQUEUE_SIGNAL_(this); // signal the event queue 00071 } 00072 else { // queue is not empty, leave event in the ring-buffer 00073 // queue must accept all posted events 00074 Q_ASSERT(m_eQueue.m_nFree != static_cast<QEQueueCtr>(0)); 00075 00076 ++m_eQueue.m_tail; 00077 if (m_eQueue.m_tail == m_eQueue.m_end) { // need to wrap the tail? 00078 m_eQueue.m_tail = static_cast<QEQueueCtr>(0); // wrap around 00079 } 00080 00081 QF_PTR_AT_(m_eQueue.m_ring, m_eQueue.m_tail) = m_eQueue.m_frontEvt; 00082 m_eQueue.m_frontEvt = e; // put event to front 00083 00084 --m_eQueue.m_nFree; // update number of free events 00085 if (m_eQueue.m_nMin > m_eQueue.m_nFree) { 00086 m_eQueue.m_nMin = m_eQueue.m_nFree; // update minimum so far 00087 } 00088 } 00089 QF_CRIT_EXIT_(); 00090 } 00091 00092 QP_END_
1.7.6.1