mirror of
https://github.com/QuantumLeaps/qpc.git
synced 2025-01-21 06:53:11 +08:00
98 lines
3.8 KiB
C
98 lines
3.8 KiB
C
|
/*****************************************************************************
|
||
|
* Product: DPP example, ThreadX demo on Windows
|
||
|
* Last updated for version 5.3.0
|
||
|
* Last updated on 2014-05-07
|
||
|
*
|
||
|
* Q u a n t u m L e a P s
|
||
|
* ---------------------------
|
||
|
* innovating embedded systems
|
||
|
*
|
||
|
* Copyright (C) Quantum Leaps, www.state-machine.com.
|
||
|
*
|
||
|
* This program is open source software: you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU General Public License as published
|
||
|
* by the Free Software Foundation, either version 3 of the License, or
|
||
|
* (at your option) any later version.
|
||
|
*
|
||
|
* Alternatively, this program may be distributed and modified under the
|
||
|
* terms of Quantum Leaps commercial licenses, which expressly supersede
|
||
|
* the GNU General Public License and are specifically designed for
|
||
|
* licensees interested in retaining the proprietary status of their code.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*
|
||
|
* Contact information:
|
||
|
* Web: www.state-machine.com
|
||
|
* Email: info@state-machine.com
|
||
|
*****************************************************************************/
|
||
|
#include "qp_port.h"
|
||
|
#include "dpp.h"
|
||
|
#include "bsp.h"
|
||
|
|
||
|
/* Local-scope objects -----------------------------------------------------*/
|
||
|
static QEvt const *l_tableQueueSto[N_PHILO];
|
||
|
static QEvt const *l_philoQueueSto[N_PHILO][N_PHILO];
|
||
|
static QSubscrList l_subscrSto[MAX_PUB_SIG];
|
||
|
|
||
|
static union SmallEvents {
|
||
|
void *e0; /* minimum event size */
|
||
|
uint8_t e1[sizeof(TableEvt)];
|
||
|
/* ... other event types to go into this pool */
|
||
|
} l_smlPoolSto[2*N_PHILO + 10]; /* storage for the small event pool */
|
||
|
|
||
|
static ULONG l_philoStk[N_PHILO][256]; /* stacks for the Philosophers */
|
||
|
static ULONG l_tableStk[256]; /* stack for the Table */
|
||
|
|
||
|
/*..........................................................................*/
|
||
|
int main(int argc, char *argv[]) {
|
||
|
Philo_ctor(); /* instantiate all Philosopher active objects */
|
||
|
Table_ctor(); /* instantiate the Table active object */
|
||
|
|
||
|
BSP_init(argc, argv); /* initialize the Board Support Package */
|
||
|
|
||
|
tx_kernel_enter();
|
||
|
|
||
|
return 0; /* tx_kernel_enter() does not return */
|
||
|
}
|
||
|
/*..........................................................................*/
|
||
|
void tx_application_define(void *first_unused_memory) {
|
||
|
uint8_t n;
|
||
|
|
||
|
(void)first_unused_memory; /* avoid compiler warning about unused arg. */
|
||
|
|
||
|
QF_init(); /* initialize the framework and the underlying RT kernel */
|
||
|
|
||
|
QF_psInit(l_subscrSto, Q_DIM(l_subscrSto)); /* init publish-subscribe */
|
||
|
|
||
|
/* initialize event pools... */
|
||
|
QF_poolInit(l_smlPoolSto, sizeof(l_smlPoolSto), sizeof(l_smlPoolSto[0]));
|
||
|
|
||
|
QS_OBJ_DICTIONARY(l_smlPoolSto);
|
||
|
QS_OBJ_DICTIONARY(l_tableQueueSto);
|
||
|
QS_OBJ_DICTIONARY(l_philoQueueSto[0]);
|
||
|
/*
|
||
|
NOTE: can't use more active objects in the ThreadX Windows demo!
|
||
|
QS_OBJ_DICTIONARY(l_philoQueueSto[1]);
|
||
|
QS_OBJ_DICTIONARY(l_philoQueueSto[2]);
|
||
|
QS_OBJ_DICTIONARY(l_philoQueueSto[3]);
|
||
|
QS_OBJ_DICTIONARY(l_philoQueueSto[4]);
|
||
|
*/
|
||
|
|
||
|
for (n = 0; n < N_PHILO; ++n) { /* start the active objects... */
|
||
|
QActive_start(AO_Philo[n], (uint8_t)(n + 1),
|
||
|
l_philoQueueSto[n], Q_DIM(l_philoQueueSto[n]),
|
||
|
l_philoStk[n], sizeof(l_philoStk[n]), (QEvt *)0);
|
||
|
}
|
||
|
QActive_start(AO_Table, (uint8_t)(N_PHILO + 1),
|
||
|
l_tableQueueSto, Q_DIM(l_tableQueueSto),
|
||
|
l_tableStk, sizeof(l_tableStk), (QEvt *)0);
|
||
|
|
||
|
(void)QF_run(); /* run the QF application (does not return) */
|
||
|
}
|