Mercurial > public > ostc_companion
diff HexFile.h @ 1:0b3630a29ad8
Initial version based on previous repository.
Project was ported to QT6 and in now cmake based.
| author | Ideenmodellierer <tiefenrauscher@web.de> |
|---|---|
| date | Thu, 27 Nov 2025 18:40:28 +0100 |
| parents | |
| children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/HexFile.h Thu Nov 27 18:40:28 2025 +0100 @@ -0,0 +1,92 @@ +////////////////////////////////////////////////////////////////////////////// +/// \file HexFile.h +/// \brief Read .hex file in "Intel HEX" format. +/// \author JD Gascuel. +/// +/// \copyright (c) 2012-2016, JD Gascuel. All rights reserved. +/// $Id$ +////////////////////////////////////////////////////////////////////////////// +// +// BSD 2-Clause License: +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions +// are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright notice, +// this list of conditions and the following disclaimer in the documentation +// and/or other materials provided with the distribution. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +// THE POSSIBILITY OF SUCH DAMAGE. +// +////////////////////////////////////////////////////////////////////////////// +// HISTORY +// 2012-02-12 : [jDG] Creation for Frog Companion firmware upload. +// 2012-09-22 : [jDG] Updated for OSTC Companion (OSTC3). +// 2014-07-07 : [jDG] Cleanups for Subsurface google-summer-of-code. +// 2014-07-25 : [jDG] BSD 2-clause license. + +#include <QtGlobal> +#include <QFile> + +class QProgressBar; + +///////////////////////////////////////////////////////////////////////////// +/// \brief Read .hex file in "Intel HEX" format. +/// +/// \note that OSTC3 firmware is NOT distributed in Intel HEX format, +/// but is first flatened, then encrypted, then written back +/// in a similar looking format. +class HexFile +{ + QFile _file; + size_t _memSize; + size_t _baseAddress; ///< Base for extended address modes. + + unsigned char* _buffer; + + /// \brief Read and interpret on line of the HEX file. + void readLine(); + +public: + /// \brief Create an empty object. + HexFile(); + ~HexFile(); + + /// \brief Allocate initialized space. + bool allocate(size_t memSize, unsigned char fill = 0xFF); + bool sqwiz(size_t newMemSize); + + /// \brief Load the .hex file into the internal buffer. + /// \return TRUE is ok, FAlSE if some error occurs. + void load(const QString& fileName); + + /// \brief Return a pointer to the loaded data. + const unsigned char* data() const; + + /// \brief Returns the 4 bytes checksum of the loaded data. + /// + /// This is a simple Adler32 checksum: The lower 16bits are the sum of + /// all the bytes (modulo 65536). And the second 16bits are the sum of + /// the running sum itself (also modulo 65536). + unsigned int checksum() const; + + /// \brief Save to encrypted HEX file. + void saveEncrypted(const QString& fileName, unsigned char secretKey[16]); + + /// \brief Reload encrypted HEX file. + void loadEncrypted(const QString& fileName, unsigned char secretKey[16]); +};
