mirror of
https://github.com/Ralim/IronOS.git
synced 2025-07-23 20:30:38 +02:00
* Add SDK * fork * massaging makefile * Drop git module * Bring in sdk as its broken Far, Far to much crap to fix with regex now * Remove bl706 * rf_para_flash_t is missing defs * Remove crapton of junk * Remove yet more * Poking I2C * Update peripheral_config.h * Update pinmux_config.h * Update preRTOS.cpp * Update main.hpp * Setup template * Verbose boot * I2C ish * Update I2C_Wrapper.cpp * Update main.cpp * Turn off I2C reading for now * Display running * Roughing out scheduling timer0 * Starting ADC setup * Working scheduling of ADC 🎉 * Format adc headers * Update IRQ.cpp * Buttons working * Slow down I2C * Poking IRQ * Larger stack required * Accel on * Trying to chase down why __libc_init_array isnt working yet * Working c++ * Cleanup * Bump stacks * I2C wake part workaround * Cleanup * Working PWM init * qc draft * Hookup PWM * Stable enough ADC * ADC timing faster + timer without HAL * Silence * Remove boot banner * Tuning in ADC * Wake PID after ADC * Remove unused hal * Draft flash settings * Working settings save & restore * Update to prod model * Cleanup * NTC thermistor * Correct adc gain * Rough tip resistance progress * Scratch out resistance awareness of the tip * better adc settings * Tweaking ADC * ADC tweaking * Make adc range scalable * Update Dockerfile * Update configuration.h * Can read same ADC twice in a row * ADC Setup * Update PIDThread.cpp * Lesser adc backoff * Update USBPD.h * Add device ID * Update BSP_Power.h * Update BSP.cpp * DrawHex dynamicLength * Shorter ID padding * Show validation code * tip measurement * Create access for w0w1 * Expose w0 w1 * Enable debug * crc32 * Device validation * wip starting epr * Logic refactor * Safer PWM Init * PD cleanups * Update bl702_pwm.c * Update power.cpp * Update usb-pd * io * EPR decode * Better gui for showing pd specs * Rough handler for capabilities * EPR * Fix > 25V input * Perform pow step after PPS * Update BSP.cpp * Fix timer output * QC3 * Add tip resistance view * Hold PD negotiation until detection is done for tip res * Get Thermal mass * Tip res =0 protection * Update PIDThread.cpp * Update GUIThread.cpp * Rewrite tip resistance measurement * Update GUIThread.cpp * Fix fallback * Far better tip resistance measurement * Fix QC 0.6V D- * Convert the interpolator to int32 * Correct the NTC lookup * Update BSP.cpp * Update Setup.cpp * . Update configuration #defines More backported functions * Update usb-pd * More missed updates * Refactor BSP Magic BSP -> PinecilV2 Pine64 BSP -> Pinecil Update Makefile * Add Pinecilv2 to CI * Pinecil v2 multi-lang Update push.yml * Update HallSensor.md * Update README.md * Fix wrong prestartcheck default * Fix logo mapping * Update Makefile * Remove unused font block * Style * Style * Remove unused timer funcs * More culling TS80P * Revert "More culling TS80P" This reverts commit2078b89be7
. * Revert "Remove unused timer funcs" This reverts commit0c693a89cc
. * Make VBus check maskable * Remove DMA half transfer * Drop using brightness and invert icons and go back to text Saves flash space * Refactor settings UI drawing descriptions * Shorten setting function names * Store bin file assets * Fix MHP prestart
62 lines
2.3 KiB
C++
62 lines
2.3 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);
|
|
}
|
|
}
|
|
}
|