* Testing clang-format style check using github CI
* github/push: implement check-style for clang-format as a separate build step
* github/push: add missing packages for check-style/clang-format build step
* source/Makefile: check-style - reduce files of interest; update .clang-format to keep enums init
* source/Makefile: empty lines, spaces & tabs refactoring to unify style - part 1 out of N
* source/Makefile: fix formatting for multi-line variables
* source/Makefile: update formatting for multi-line variables
* source/Makefile: remove spaces on vars assignments to unify style
* source/Makefile: remove unused target style
* source/Makefile: implement exclude vars for clang-format related files
* source/Makefile: exclude configuration.h from clang-format check
* Dockerfile: add diffutils in a container to make check-style target using advanced version of diff to get more advanced output to parse & navigate log more easily
* source/Makefile: implement parser for clang-format inside check-style target to make output compatible with gcc-like error compilation format for compatibility with IDEs/editors for easy navigation over files to fix style errors
* source/Makefile: probably final touches on unifying style
* source/Makefile: implement check-style-list target to only list affected file names with wrong code style for debug purposes
* source/Makefile: fix missed spaces
* deploy.sh: add helper routine to deal with clang-format error output logging from makefile
* gitignore: add clang-format log explicitly
* Refactoring for clang-format compiance
* Dockerfile: add sed
* Dockerfile: false alarm - remove sed since busybox-sed seems fine
* source/Makefile: reduce calls of clang-format & make error log more clean, clear, and tidy
* deploy.sh:check_style() - add removal of DOS EOLs for generated log
* source/Makefile:check-style: add more empty lines between blocks with errors for readability when suggestion is too long & heavy
* source/Makefile: add STOP var to check-style for exit on first failed file
* source/Makefile: check-style: make log looks more like traditional diff/patch output
* source/Core/BSP/Pinecilv2/MemMang/heap_5.c: clang-format refactoring using reasonable advises ... and then disable it in Makefile from scanning by clang-format
* Return headers include order
* clang-format config: disable warnings about non-alphabetic include order
* clang-format refactoring
* clang-format refactoring, part 2
* clang-format refactoring, part 3
* settingsGUI.cpp: refactoring, part 1
* settingsGUI.cpp: refactoring, part 2
* settingsGUI.cpp: refactoring, part 3
* settingsGUI.cpp: refactoring, part 4
* clang-format should be happy now
* workflows/push: put readme check into separate build step & update style
* clang-format: giving SortIncludes option second chance by tweaking a couple of headers a bit
* source/Makefile: check-style: add homebrew parser to check for { } in conditional blocks
* homebrew-format: add { } for if/else, while, and for & unify some comments style; left two errors intentionally to debug & improve parser
* source/Makefile: homebrew-format: fix false negative trigger for multi-line condition in if-s
* Sleep.cpp: unify style & comments
* source/Makefile: remove unused debug target
62 lines
2.4 KiB
C++
62 lines
2.4 KiB
C++
/*
|
|
* Debug.cpp
|
|
*
|
|
* Created on: 26 Jan. 2021
|
|
* Author: Ralim
|
|
*/
|
|
#include "Debug.h"
|
|
#include "FreeRTOS.h"
|
|
#include "Pins.h"
|
|
|
|
extern "C" {
|
|
|
|
#include "gd32vf103_usart.h"
|
|
}
|
|
char uartOutputBuffer[uartOutputBufferLength];
|
|
volatile uint32_t currentOutputPos = 0xFF;
|
|
volatile uint32_t outputLength = 0;
|
|
extern volatile uint8_t pendingPWM;
|
|
void log_system_state(int32_t PWMWattsx10) {
|
|
if (currentOutputPos == 0xFF) {
|
|
|
|
// Want to print a CSV log out the uart
|
|
// Tip_Temp_C,Handle_Temp_C,Output_Power_Wattx10,PWM,Tip_Raw\r\n
|
|
// 3+1+3+1+3+1+3+1+5+2 = 23, so sizing at 32 for now
|
|
|
|
outputLength = snprintf(uartOutputBuffer, uartOutputBufferLength, "%lu,%u,%li,%u,%lu\r\n",
|
|
TipThermoModel::getTipInC(false), // Tip temp in C
|
|
getHandleTemperature(0), // Handle temp in C X10
|
|
PWMWattsx10, // Output Wattage
|
|
pendingPWM, // PWM
|
|
TipThermoModel::convertTipRawADCTouV(getTipRawTemp(0), true) // Tip temp in uV
|
|
);
|
|
|
|
// Now print this out the uart via IRQ (DMA cant be used as oled has it)
|
|
currentOutputPos = 0;
|
|
/* enable USART1 Transmit Buffer Empty interrupt */
|
|
usart_interrupt_enable(UART_PERIF, USART_INT_TBE);
|
|
}
|
|
}
|
|
ssize_t _write(int fd, const void *ptr, size_t len) {
|
|
if (len > uartOutputBufferLength) {
|
|
len = uartOutputBufferLength;
|
|
}
|
|
outputLength = len;
|
|
currentOutputPos = 0;
|
|
memcpy(uartOutputBuffer, ptr, len);
|
|
/* enable USART1 Transmit Buffer Empty interrupt */
|
|
usart_interrupt_enable(UART_PERIF, USART_INT_TBE);
|
|
delay_ms(1);
|
|
return len;
|
|
}
|
|
void USART1_IRQHandler(void) {
|
|
if (RESET != usart_interrupt_flag_get(UART_PERIF, USART_INT_FLAG_TBE)) {
|
|
/* write one byte to the transmit data register */
|
|
usart_data_transmit(UART_PERIF, uartOutputBuffer[currentOutputPos++]);
|
|
if (currentOutputPos >= outputLength) {
|
|
currentOutputPos = 0xFF; // Mark done
|
|
usart_interrupt_disable(UART_PERIF, USART_INT_TBE);
|
|
}
|
|
}
|
|
}
|