//**************************************************************************** // 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); }