QP/C
qeq_lifo.c
Go to the documentation of this file.
00001 /*****************************************************************************
00002 * Product: QF/C
00003 * Last Updated for Version: 4.4.00
00004 * Date of the Last Update:  Jan 14, 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 software may be distributed and modified under the terms of the GNU
00013 * General Public License version 2 (GPL) as published by the Free Software
00014 * Foundation and appearing in the file GPL.TXT included in the packaging of
00015 * this file. Please note that GPL Section 2[b] requires that all works based
00016 * on this software must also be made publicly available under the terms of
00017 * the GPL ("Copyleft").
00018 *
00019 * Alternatively, this software may be distributed and modified under the
00020 * terms of Quantum Leaps commercial licenses, which expressly supersede
00021 * the GPL and are specifically designed for licensees interested in
00022 * retaining the proprietary status of their code.
00023 *
00024 * Contact information:
00025 * Quantum Leaps Web site:  http://www.quantum-leaps.com
00026 * e-mail:                  info@quantum-leaps.com
00027 *****************************************************************************/
00028 #include "qf_pkg.h"
00029 #include "qassert.h"
00030 
00031 Q_DEFINE_THIS_MODULE("qeq_lifo")
00032 
00033 
00040 /*..........................................................................*/
00041 void QEQueue_postLIFO(QEQueue *me, QEvent const *e) {
00042     QF_CRIT_STAT_
00043     QF_CRIT_ENTRY_();
00044 
00045     QS_BEGIN_NOCRIT_(QS_QF_EQUEUE_POST_LIFO, QS_eqObj_, me)
00046         QS_TIME_();                                            /* timestamp */
00047         QS_SIG_(e->sig);                        /* the signal of this event */
00048         QS_OBJ_(me);                                   /* this queue object */
00049         QS_U8_(QF_EVT_POOL_ID_(e));             /* the pool Id of the event */
00050         QS_U8_(QF_EVT_REF_CTR_(e));           /* the ref count of the event */
00051         QS_EQC_(me->nFree);                       /* number of free entries */
00052         QS_EQC_(me->nMin);                    /* min number of free entries */
00053     QS_END_NOCRIT_()
00054 
00055     if (QF_EVT_POOL_ID_(e) != (uint8_t)0) {          /* is it a pool event? */
00056         QF_EVT_REF_CTR_INC_(e);          /* increment the reference counter */
00057     }
00058 
00059     if (me->frontEvt != (QEvent *)0) {           /* is the queue not empty? */
00060             /* the queue must be able to accept the event (cannot overflow) */
00061         Q_ASSERT(me->nFree != (QEQueueCtr)0);
00062 
00063         ++me->tail;
00064         if (me->tail == me->end) {                /* need to wrap the tail? */
00065             me->tail = (QEQueueCtr)0;                        /* wrap around */
00066         }
00067 
00068         QF_PTR_AT_(me->ring, me->tail) = me->frontEvt;/* save old front evt */
00069 
00070         --me->nFree;                        /* update number of free events */
00071         if (me->nMin > me->nFree) {
00072             me->nMin = me->nFree;                  /* update minimum so far */
00073         }
00074     }
00075 
00076     me->frontEvt = e;                   /* stick the new event to the front */
00077 
00078     QF_CRIT_EXIT_();
00079 }