mirror of
https://github.com/DCC-EX/CommandStation-EX.git
synced 2024-12-25 05:31:24 +01:00
Added free memory detection
This commit is contained in:
parent
29b719ffd9
commit
87a82f7c18
@ -22,6 +22,15 @@
|
|||||||
#include <ArduinoTimers.h>
|
#include <ArduinoTimers.h>
|
||||||
|
|
||||||
#include "Config.h"
|
#include "Config.h"
|
||||||
|
#include "FreeMemory.h"
|
||||||
|
|
||||||
|
#if defined(ARDUINO_BOARD_UNO)
|
||||||
|
int ramLowWatermark = 16384;
|
||||||
|
#elif defined(ARDUINO_BOARD_MEGA_2560)
|
||||||
|
int ramLowWatermark = 64000;
|
||||||
|
#elif defined(ARDUINO_ARCH_SAMD) || defined(ARDUINO_ARCH_SAMC)
|
||||||
|
int ramLowWatermark = 256000;
|
||||||
|
#endif
|
||||||
|
|
||||||
const uint8_t kIRQmicros = 29;
|
const uint8_t kIRQmicros = 29;
|
||||||
const uint8_t kNumLocos = 50;
|
const uint8_t kNumLocos = 50;
|
||||||
@ -38,6 +47,8 @@ DCCService* progTrack = DCCService::Create_Arduino_L298Shield_Prog();
|
|||||||
#elif defined CONFIG_POLOLU_MOTOR_SHIELD
|
#elif defined CONFIG_POLOLU_MOTOR_SHIELD
|
||||||
DCCMain* mainTrack = DCCMain::Create_Pololu_MC33926Shield_Main(kNumLocos);
|
DCCMain* mainTrack = DCCMain::Create_Pololu_MC33926Shield_Main(kNumLocos);
|
||||||
DCCService* progTrack = DCCService::Create_Pololu_MC33926Shield_Prog();
|
DCCService* progTrack = DCCService::Create_Pololu_MC33926Shield_Prog();
|
||||||
|
#else
|
||||||
|
#error "Cannot compile - no board selected in Config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void waveform_IrqHandler() {
|
void waveform_IrqHandler() {
|
||||||
@ -73,8 +84,10 @@ void setup() {
|
|||||||
mainTrack->hdw.config_setTrackPowerCallback(DCCEXParser::trackPowerCallback);
|
mainTrack->hdw.config_setTrackPowerCallback(DCCEXParser::trackPowerCallback);
|
||||||
progTrack->hdw.config_setTrackPowerCallback(DCCEXParser::trackPowerCallback);
|
progTrack->hdw.config_setTrackPowerCallback(DCCEXParser::trackPowerCallback);
|
||||||
|
|
||||||
|
// Register the serial interface
|
||||||
#if defined (ARDUINO_ARCH_SAMD)
|
#if defined (ARDUINO_ARCH_SAMD)
|
||||||
CommManager::registerInterface(new USBInterface(SerialUSB));
|
CommManager::registerInterface(new USBInterface(SerialUSB));
|
||||||
|
while(!SerialUSB) {} // Wait for USB to come online (remove once wifi is implemented)
|
||||||
Wire.begin(); // Needed for EEPROM to work
|
Wire.begin(); // Needed for EEPROM to work
|
||||||
#elif defined (ARDUINO_ARCH_SAMC)
|
#elif defined (ARDUINO_ARCH_SAMC)
|
||||||
CommManager::registerInterface(new SerialInterface(Serial));
|
CommManager::registerInterface(new SerialInterface(Serial));
|
||||||
@ -95,4 +108,10 @@ void loop() {
|
|||||||
CommManager::update();
|
CommManager::update();
|
||||||
mainTrack->loop();
|
mainTrack->loop();
|
||||||
progTrack->loop();
|
progTrack->loop();
|
||||||
|
|
||||||
|
int freeNow=freeMemory();
|
||||||
|
if (freeNow<ramLowWatermark) {
|
||||||
|
ramLowWatermark=freeNow;
|
||||||
|
CommManager::printf(F("\nFree RAM=%d\n"),ramLowWatermark);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
4
Config.h
4
Config.h
@ -22,8 +22,8 @@
|
|||||||
|
|
||||||
// Choose the motor shield that you want to use.
|
// Choose the motor shield that you want to use.
|
||||||
|
|
||||||
//#define CONFIG_WSM_FIREBOX_MK1
|
#define CONFIG_WSM_FIREBOX_MK1
|
||||||
#define CONFIG_WSM_FIREBOX_MK1S
|
//#define CONFIG_WSM_FIREBOX_MK1S
|
||||||
//#define CONFIG_ARDUINO_MOTOR_SHIELD
|
//#define CONFIG_ARDUINO_MOTOR_SHIELD
|
||||||
//#define CONFIG_POLOLU_MOTOR_SHIELD
|
//#define CONFIG_POLOLU_MOTOR_SHIELD
|
||||||
|
|
||||||
|
20
FreeMemory.h
Normal file
20
FreeMemory.h
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#ifndef freeMemory_h
|
||||||
|
#define freeMemory_h
|
||||||
|
|
||||||
|
// thanks go to https://github.com/mpflaga/Arduino-MemoryFree
|
||||||
|
#ifdef __arm__
|
||||||
|
// should use uinstd.h to define sbrk but Due causes a conflict
|
||||||
|
extern "C" char* sbrk(int incr);
|
||||||
|
#else
|
||||||
|
extern char *__brkval;
|
||||||
|
#endif // __arm__
|
||||||
|
|
||||||
|
int freeMemory() {
|
||||||
|
char top;
|
||||||
|
#ifdef __arm__
|
||||||
|
return &top - reinterpret_cast<char*>(sbrk(0));
|
||||||
|
#else
|
||||||
|
return __brkval ? &top - __brkval : &top - __malloc_heap_start;
|
||||||
|
#endif // __arm__
|
||||||
|
}
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user