|
QP/C
|
00001 /***************************************************************************** 00002 * Product: QF/C 00003 * Last Updated for Version: 4.4.00 00004 * Date of the Last Update: Jan 04, 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("qte_arm") 00032 00033 00039 /* Package-scope objects ---------------------------------------------------*/ 00040 QTimeEvt *QF_timeEvtListHead_; /* head of linked list of time events */ 00041 00042 /*..........................................................................*/ 00043 void QTimeEvt_arm_(QTimeEvt *me, QActive *act, QTimeEvtCtr nTicks) { 00044 QF_CRIT_STAT_ 00045 Q_REQUIRE((nTicks > (QTimeEvtCtr)0) /* cannot arm a timer with 0 ticks */ 00046 && (me->super.sig >= (QSignal)Q_USER_SIG) /* valid signal */ 00047 && (me->prev == (QTimeEvt *)0) /* time evt must NOT be used */ 00048 && (act != (QActive *)0)); /* active object must be provided */ 00049 me->ctr = nTicks; 00050 me->prev = me; /* mark the timer in use */ 00051 me->act = act; 00052 00053 QF_CRIT_ENTRY_(); 00054 00055 QS_BEGIN_NOCRIT_(QS_QF_TIMEEVT_ARM, QS_teObj_, me) 00056 QS_TIME_(); /* timestamp */ 00057 QS_OBJ_(me); /* this time event object */ 00058 QS_OBJ_(act); /* the active object */ 00059 QS_TEC_(nTicks); /* the number of ticks */ 00060 QS_TEC_(me->interval); /* the interval */ 00061 QS_END_NOCRIT_() 00062 00063 me->next = QF_timeEvtListHead_; 00064 if (QF_timeEvtListHead_ != (QTimeEvt *)0) { 00065 QF_timeEvtListHead_->prev = me; 00066 } 00067 QF_timeEvtListHead_ = me; 00068 QF_CRIT_EXIT_(); 00069 }
1.7.6.1