/// @file /// @brief QS long-long (64-bit) output /// @ingroup qs /// @cond ///*************************************************************************** /// Last updated for version 5.4.0 /// Last updated on 2015-04-29 /// /// 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 . /// /// Contact information: /// Web: www.state-machine.com /// Email: info@state-machine.com ///*************************************************************************** /// @endcond #define QP_IMPL // this is QF/QK implementation #include "qs_port.h" // QS port #if (QS_OBJ_PTR_SIZE == 8) || (QS_FUN_PTR_SIZE == 8) #include "qs_pkg.h" // QS package-scope internal interface namespace QP { //**************************************************************************** /// @note This function is only to be used through macros, never in the /// client code directly. /// void QS::u64_(uint64_t d) { uint8_t chksum_ = priv_.chksum; uint8_t *buf_ = priv_.buf; QSCtr head_ = priv_.head; QSCtr end_ = priv_.end; priv_.used += static_cast(8); // 8 bytes are about to be added for (int_fast8_t i = static_cast(8); i != static_cast(0); --i) { uint8_t b = static_cast(d); QS_INSERT_ESC_BYTE(b) d >>= 8; } priv_.head = head_; // save the head priv_.chksum = chksum_; // save the checksum } //**************************************************************************** /// @note This function is only to be used through macros, never in the /// client code directly. /// void QS::u64(uint8_t format, uint64_t d) { uint8_t chksum_ = priv_.chksum; uint8_t *buf_ = priv_.buf; QSCtr head_ = priv_.head; QSCtr end_ = priv_.end; priv_.used += static_cast(9); // 9 bytes are about to be added QS_INSERT_ESC_BYTE(format) // insert the format byte for (int_fast8_t i = static_cast(8); i != static_cast(0); --i) { format = static_cast(d); QS_INSERT_ESC_BYTE(format) d >>= 8; } priv_.head = head_; // save the head priv_.chksum = chksum_; // save the checksum } } // namespace QP #endif // (QS_OBJ_PTR_SIZE == 8) || (QS_FUN_PTR_SIZE == 8)