This repository has been archived on 2022-01-28. You can view files and clone it, but cannot push or open issues or pull requests.
Marlin-Artillery-M600/Marlin/src/libs/hex_print_routines.cpp

82 lines
2.5 KiB
C++
Raw Normal View History

2017-03-18 16:14:31 +01:00
/**
* Marlin 3D Printer Firmware
* Copyright (C) 2016 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
*
* Based on Sprinter and grbl.
* Copyright (C) 2011 Camiel Gubbels / Erik van der Zalm
*
* This program is free 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.
*
* 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/>.
*
*/
2017-09-06 13:28:32 +02:00
#include "../inc/MarlinConfig.h"
2017-09-30 23:06:43 +02:00
#include "../gcode/parser.h"
2017-05-20 10:03:08 +02:00
#if ENABLED(AUTO_BED_LEVELING_UBL) || ENABLED(M100_FREE_MEMORY_WATCHER) || ENABLED(DEBUG_GCODE_PARSER)
2017-03-18 16:14:31 +01:00
2017-09-06 13:28:32 +02:00
#include "hex_print_routines.h"
#ifdef CPU_32_BIT
constexpr int byte_start = 4;
static char _hex[] = "0x00000000";
2017-09-30 23:06:43 +02:00
#else
constexpr int byte_start = 0;
static char _hex[] = "0x0000";
2017-09-06 13:28:32 +02:00
#endif
char* hex_byte(const uint8_t b) {
_hex[byte_start + 4] = hex_nybble(b >> 4);
_hex[byte_start + 5] = hex_nybble(b);
2017-09-30 23:06:43 +02:00
return &_hex[byte_start + 4];
2017-09-06 13:28:32 +02:00
}
2017-09-30 23:06:43 +02:00
inline void _hex_word(const uint16_t w) {
2017-09-06 13:28:32 +02:00
_hex[byte_start + 2] = hex_nybble(w >> 12);
_hex[byte_start + 3] = hex_nybble(w >> 8);
_hex[byte_start + 4] = hex_nybble(w >> 4);
_hex[byte_start + 5] = hex_nybble(w);
2017-09-30 23:06:43 +02:00
}
char* hex_word(const uint16_t w) {
_hex_word(w);
return &_hex[byte_start + 2];
2017-09-06 13:28:32 +02:00
}
#ifdef CPU_32_BIT
2017-09-30 23:06:43 +02:00
char* hex_long(const uint32_t l) {
_hex[2] = hex_nybble(l >> 28);
_hex[3] = hex_nybble(l >> 24);
_hex[4] = hex_nybble(l >> 20);
_hex[5] = hex_nybble(l >> 16);
_hex_word((uint16_t)(l & 0xFFFF));
return &_hex[2];
2017-09-06 13:28:32 +02:00
}
#endif
char* hex_address(const void * const w) {
#ifdef CPU_32_BIT
(void)hex_long((ptr_int_t)w);
#else
(void)hex_word((ptr_int_t)w);
#endif
return _hex;
}
void print_hex_nybble(const uint8_t n) { SERIAL_CHAR(hex_nybble(n)); }
void print_hex_byte(const uint8_t b) { SERIAL_ECHO(hex_byte(b)); }
void print_hex_word(const uint16_t w) { SERIAL_ECHO(hex_word(w)); }
void print_hex_address(const void * const w) { SERIAL_ECHO(hex_address(w)); }
2017-03-29 02:45:54 +02:00
2017-05-20 10:03:08 +02:00
#endif // AUTO_BED_LEVELING_UBL || M100_FREE_MEMORY_WATCHER || DEBUG_GCODE_PARSER