//****************************************************************************
// Product: Simple Blinky example, POSIX
// Last updated for version 5.6.0
// Last updated on 2015-12-26
//
// Q u a n t u m L e a P s
// ---------------------------
// innovating embedded systems
//
// Copyright (C) Quantum Leaps, LLC. All rights reserved.
//
// 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 .
//
// Contact information:
// https://state-machine.com
// mailto:info@state-machine.com
//****************************************************************************
#include "qpcpp.h"
#include "bsp.h"
#include "blinky.h"
#include
#include
#include // for memcpy() and memset()
#include
#include
#include
using namespace std;
Q_DEFINE_THIS_FILE
#ifdef Q_SPY
#error Simple Blinky Application does not provide Spy build configuration
#endif
//............................................................................
static struct termios l_tsav; // structure with saved terminal attributes
//............................................................................
void BSP_init(void) {
cout << "Simple Blinky example" << endl
<< "QP version: " << QP_VERSION_STR << endl
<< "Press ESC to quit..." << endl;
}
//............................................................................
void BSP_ledOff(void) {
cout << "LED OFF" << endl;
}
//............................................................................
void BSP_ledOn(void) {
cout << "LED ON" << endl;
}
//............................................................................
void QF::onStartup(void) {
struct termios tio; // modified terminal attributes
tcgetattr(0, &l_tsav); // save the current terminal attributes
tcgetattr(0, &tio); // obtain the current terminal attributes
tio.c_lflag &= ~(ICANON | ECHO); // disable the canonical mode & echo
tcsetattr(0, TCSANOW, &tio); // set the new attributes
QF_setTickRate(BSP_TICKS_PER_SEC); // set the desired tick rate
}
//............................................................................
void QF::onCleanup(void) {
cout << endl << "Bye Bye!!!" << endl;
tcsetattr(0, TCSANOW, &l_tsav); // restore the saved terminal attributes
}
//............................................................................
void QP::QF_onClockTick(void) {
QF::TICK_X(0U, (void *)0); // perform the QF clock tick processing
struct timeval timeout = { 0, 0 }; // timeout for select()
fd_set con; // FD set representing the console FD_ZERO(&con);
FD_SET(0, &con);
// check if a console input is available, returns immediately
if (0 != select(1, &con, 0, 0, &timeout)) { // any descriptor set?
char ch;
read(0, &ch, 1);
if (ch == '\33') { // ESC pressed?
QF::stop();
}
}
}
//............................................................................
extern "C" void Q_onAssert(char const * const module, int loc) {
cout << "Assertion failed in " << module
<< "location " << loc << endl;
QS_ASSERTION(module, loc, static_cast(10000U));
exit(-1);
}