📄 philo.cpp
字号:
//////////////////////////////////////////////////////////////////////////////// Product: QDPP example// Last Updated for Version: 3.2.04// Date of the Last Update: Nov 23, 2006//// Q u a n t u m L e a P s// ---------------------------// innovating embedded systems//// Copyright (C) 2002-2006 Quantum Leaps, LLC. All rights reserved.//// This software may be distributed and modified under the terms of the GNU// General Public License version 2 (GPL) as published by the Free Software// Foundation and appearing in the file GPL.TXT included in the packaging of// this file. Please note that GPL Section 2[b] requires that all works based// on this software must also be made publicly available under the terms of// the GPL ("Copyleft").//// Alternatively, this software may be distributed and modified under the// terms of Quantum Leaps commercial licenses, which expressly supersede// the GPL and are specifically designed for licensees interested in// retaining the proprietary status of their code.//// Contact information:// Quantum Leaps Web site: http://www.quantum-leaps.com// e-mail: sales@quantum-leaps.com//////////////////////////////////////////////////////////////////////////////#include "qf_port.h"#include "qassert.h"#include "qdpp.h"#include <stdlib.h>#include <time.h>Q_DEFINE_THIS_FILEclass Philosopher : public QActive {private: uint8_t num_; // number of this philosopher QTimeEvt timeEvt_; // to timeout thining or eatingpublic: Philosopher();protected: static void initial(Philosopher *me, QEvent const *e); static QSTATE thinking(Philosopher *me, QEvent const *e); static QSTATE hungry(Philosopher *me, QEvent const *e); static QSTATE eating(Philosopher *me, QEvent const *e);private: friend void philosopherStart(uint8_t prio, QEvent const *qSto[], uint32_t qLen);};enum { THINK_TIME = 7, EAT_TIME = 5, // internal events (not published to the QF) TIMEOUT_SIG = MAX_PUB_SIG};//............................................................................Philosopher::Philosopher() : QActive((QState)&Philosopher::initial), timeEvt_(TIMEOUT_SIG){}//............................................................................void philosopherStart(uint8_t n, uint8_t prio, QEvent const *qSto[], uint32_t qLen){ static Philosopher philo[N]; TableEvt ie; // initialization event Q_REQUIRE(n < N); ie.philNum = n; philo[n].start(prio, qSto, qLen, (void *)0, // no thread-local storage QK_FPU_THREAD, // this thread uses FPU, say (QEvent *)&ie);}//............................................................................void Philosopher::initial(Philosopher *me, QEvent const *e) { me->num_ = ((TableEvt const *)e)->philNum; me->subscribe(EAT_SIG); Q_INIT(&Philosopher::thinking);}//............................................................................QSTATE Philosopher::thinking(Philosopher *me, QEvent const *e) { switch (e->sig) { case Q_ENTRY_SIG: { me->timeEvt_.postIn(me, THINK_TIME); return 0; } case TIMEOUT_SIG: { busyDelay(); Q_TRAN(&Philosopher::hungry); return 0; } } return (QSTATE)&QHsm::top;}//............................................................................QSTATE Philosopher::hungry(Philosopher *me, QEvent const *e) { TableEvt *pe; switch (e->sig) { case Q_ENTRY_SIG: { pe = Q_NEW(TableEvt, HUNGRY_SIG); pe->philNum = me->num_; QDPP_table->postFIFO(pe); return 0; } case EAT_SIG: { if (((TableEvt *)e)->philNum == me->num_) { busyDelay(); Q_TRAN(&Philosopher::eating); } return 0; } } return (QSTATE)&QHsm::top;}//............................................................................QSTATE Philosopher::eating(Philosopher *me, QEvent const *e) { TableEvt *pe; switch (e->sig) { case Q_ENTRY_SIG: { me->timeEvt_.postIn(me, EAT_TIME); return 0; } case TIMEOUT_SIG: { Q_TRAN(&Philosopher::thinking); return 0; } case Q_EXIT_SIG: { busyDelay(); pe = Q_NEW(TableEvt, DONE_SIG); pe->philNum = me->num_; QF::publish(pe); return 0; } } return (QSTATE)&QHsm::top;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -