From 74c22c83fceaee83ad96aa7ebe09fe29e5e295a0 Mon Sep 17 00:00:00 2001 From: Asbelos Date: Wed, 9 Dec 2020 11:57:38 +0000 Subject: [PATCH] FlasString and Timers for Uno Wifi ALL these changes should be portable back to master --- ATMEGA4809/Timer.h | 5 +++-- AnalogReadFast.h | 13 +++++++++++-- ArduinoTimers.h | 2 +- DCC.cpp | 10 +++++----- DCC.h | 10 +++++----- DCCWaveform.cpp | 2 +- DIAG.h | 1 + FSH.h | 9 +++++++++ StringFormatter.cpp | 18 +++++++++--------- StringFormatter.h | 16 +++++++--------- Timer.cpp | 13 +++++++++++++ WifiInterface.cpp | 14 +++++++------- WifiInterface.h | 15 ++++++++------- 13 files changed, 80 insertions(+), 48 deletions(-) create mode 100644 FSH.h diff --git a/ATMEGA4809/Timer.h b/ATMEGA4809/Timer.h index 1690ad5..dd44933 100644 --- a/ATMEGA4809/Timer.h +++ b/ATMEGA4809/Timer.h @@ -1,5 +1,5 @@ -#ifndef ATMEGA328Timer_h -#define ATMEGA328Timer_h +#ifndef ATMEGA4809Timer_h +#define ATMEGA4809imer_h #include "../VirtualTimer.h" #include @@ -128,4 +128,5 @@ public: extern Timer TimerA; + #endif \ No newline at end of file diff --git a/AnalogReadFast.h b/AnalogReadFast.h index cc474ee..445b233 100644 --- a/AnalogReadFast.h +++ b/AnalogReadFast.h @@ -25,7 +25,16 @@ #include int inline analogReadFast(uint8_t ADCpin); +#if defined(ARDUINO_ARCH_MEGAAVR) +int inline analogReadFast(uint8_t ADCpin) +{ byte ADC0CTRLCoriginal = ADC0.CTRLC; + ADC0.CTRLC = (ADC0CTRLCoriginal & 0b00110000) + 0b01000011; + int adc = analogRead(ADCpin); + ADC0.CTRLC = ADC0CTRLCoriginal; + return adc; +} +#else int inline analogReadFast(uint8_t ADCpin) { byte ADCSRAoriginal = ADCSRA; ADCSRA = (ADCSRA & B11111000) | 4; @@ -33,5 +42,5 @@ int inline analogReadFast(uint8_t ADCpin) ADCSRA = ADCSRAoriginal; return adc; } - -#endif // COMMANDSTATION_DCC_ANALOGREADFAST_H_ \ No newline at end of file +#endif +#endif // COMMANDSTATION_DCC_ANALOGREADFAST_H_ diff --git a/ArduinoTimers.h b/ArduinoTimers.h index 85e3644..84fb17b 100644 --- a/ArduinoTimers.h +++ b/ArduinoTimers.h @@ -11,7 +11,7 @@ #include "ATMEGA2560/Timer.h" #elif defined(ARDUINO_AVR_UNO) #include "ATMEGA328/Timer.h" -#elif defined(ARDUINO_AVR_UNO_WIFI_DEV_ED) +#elif defined(ARDUINO_AVR_UNO_WIFI_REV2) #include "ATMEGA4809/Timer.h" #else #error "Cannot compile - ArduinoTimers library does not support your board, or you are missing compatible build flags." diff --git a/DCC.cpp b/DCC.cpp index 96868ca..6eca2e2 100644 --- a/DCC.cpp +++ b/DCC.cpp @@ -17,9 +17,9 @@ * You should have received a copy of the GNU General Public License * along with CommandStation. If not, see . */ +#include "DIAG.h" #include "DCC.h" #include "DCCWaveform.h" -#include "DIAG.h" #include "EEStore.h" #include "GITHUB_SHA.h" #include "version.h" @@ -43,10 +43,10 @@ const byte FN_GROUP_3=0x04; const byte FN_GROUP_4=0x08; const byte FN_GROUP_5=0x10; -__FlashStringHelper* DCC::shieldName=NULL; +FSH* DCC::shieldName=NULL; -void DCC::begin(const __FlashStringHelper* motorShieldName, MotorDriver * mainDriver, MotorDriver* progDriver, byte timerNumber) { - shieldName=(__FlashStringHelper*)motorShieldName; +void DCC::begin(const FSH* motorShieldName, MotorDriver * mainDriver, MotorDriver* progDriver, byte timerNumber) { + shieldName=(FSH*)motorShieldName; DIAG(F("\n"), F(VERSION), F(ARDUINO_TYPE), shieldName, F(GITHUB_SHA)); // Load stuff from EEprom @@ -228,7 +228,7 @@ void DCC::setProgTrackBoost(bool on) { DCCWaveform::progTrackBoosted=on; } -__FlashStringHelper* DCC::getMotorShieldName() { +FSH* DCC::getMotorShieldName() { return shieldName; } diff --git a/DCC.h b/DCC.h index 05c50e1..9fbdaf7 100644 --- a/DCC.h +++ b/DCC.h @@ -21,7 +21,7 @@ #include #include "MotorDriver.h" #include "MotorDrivers.h" - +#include "FSH.h" typedef void (*ACK_CALLBACK)(int result); enum ackOp @@ -60,7 +60,7 @@ const byte MAX_LOCOS = 50; class DCC { public: - static void begin(const __FlashStringHelper *motorShieldName, MotorDriver *mainDriver, MotorDriver *progDriver, byte timerNumber = 1); + static void begin(const FSH *motorShieldName, MotorDriver *mainDriver, MotorDriver *progDriver, byte timerNumber = 1); static void loop(); // Public DCC API functions @@ -94,7 +94,7 @@ public: static void forgetAllLocos(); // removes all speed reminders static void displayCabList(Print *stream); - static __FlashStringHelper *getMotorShieldName(); + static FSH *getMotorShieldName(); private: struct LOCO @@ -110,7 +110,7 @@ private: static void setFunctionInternal(int cab, byte fByte, byte eByte); static bool issueReminder(int reg); static int nextLoco; - static __FlashStringHelper *shieldName; + static FSH *shieldName; static LOCO speedTable[MAX_LOCOS]; static byte cv1(byte opcode, int cv); @@ -155,7 +155,7 @@ private: #define ARDUINO_TYPE "NANO" #elif defined(ARDUINO_AVR_MEGA2560) #define ARDUINO_TYPE "MEGA" -#elif defined(ARDUINO_AVR_UNO_WIFI_DEV_ED) +#elif defined(ARDUINO_AVR_UNO_WIFI_REV2) #define ARDUINO_TYPE "UNOWIFIR2" #else #error CANNOT COMPILE - DCC++ EX ONLY WORKS WITH AN ARDUINO UNO, NANO 328, OR ARDUINO MEGA 1280/2560 diff --git a/DCCWaveform.cpp b/DCCWaveform.cpp index 6c71696..19b71ee 100644 --- a/DCCWaveform.cpp +++ b/DCCWaveform.cpp @@ -41,7 +41,7 @@ void DCCWaveform::begin(MotorDriver * mainDriver, MotorDriver * progDriver, byte progTrack.setPowerMode(POWERMODE::OFF); switch (timerNumber) { case 1: interruptTimer= &TimerA; break; -#ifndef ARDUINO_AVR_UNO_WIFI_DEV_ED +#ifndef ARDUINO_AVR_UNO_WIFI_REV2 case 2: interruptTimer= &TimerB; break; #ifndef ARDUINO_AVR_UNO case 3: interruptTimer= &TimerC; break; diff --git a/DIAG.h b/DIAG.h index 6d16f78..1457796 100644 --- a/DIAG.h +++ b/DIAG.h @@ -18,6 +18,7 @@ */ #ifndef DIAG_h #define DIAG_h + #include "StringFormatter.h" #define DIAG StringFormatter::diag #define LCD StringFormatter::lcd diff --git a/FSH.h b/FSH.h new file mode 100644 index 0000000..04f2c9b --- /dev/null +++ b/FSH.h @@ -0,0 +1,9 @@ +#ifndef FSH_h +#define FSH_h +#include +#if defined(ARDUINO_ARCH_MEGAAVR) +typedef char FSH; +#else +typedef __FlashStringHelper FSH; +#endif +#endif diff --git a/StringFormatter.cpp b/StringFormatter.cpp index a8ab5cf..32e1ee4 100644 --- a/StringFormatter.cpp +++ b/StringFormatter.cpp @@ -28,7 +28,7 @@ Print * StringFormatter::diagSerial= &Serial; #elif defined(ARDUINO_ARCH_MEGAAVR) Print * StringFormatter::diagSerial=&Serial; - #define __FlashStringHelper char + #define FSH char #endif #include "LCDDisplay.h" @@ -40,14 +40,14 @@ bool Diag::WITHROTTLE=false; bool Diag::ETHERNET=false; -void StringFormatter::diag( const __FlashStringHelper* input...) { +void StringFormatter::diag( const FSH* input...) { if (!diagSerial) return; va_list args; va_start(args, input); send2(diagSerial,input,args); } -void StringFormatter::lcd(byte row, const __FlashStringHelper* input...) { +void StringFormatter::lcd(byte row, const FSH* input...) { va_list args; // Issue the LCD as a diag first @@ -62,19 +62,19 @@ void StringFormatter::lcd(byte row, const __FlashStringHelper* input...) { send2(LCDDisplay::lcdDisplay,input,args); } -void StringFormatter::send(Print * stream, const __FlashStringHelper* input...) { +void StringFormatter::send(Print * stream, const FSH* input...) { va_list args; va_start(args, input); send2(stream,input,args); } -void StringFormatter::send(Print & stream, const __FlashStringHelper* input...) { +void StringFormatter::send(Print & stream, const FSH* input...) { va_list args; va_start(args, input); send2(&stream,input,args); } -void StringFormatter::send2(Print * stream,const __FlashStringHelper* format, va_list args) { +void StringFormatter::send2(Print * stream,const FSH* format, va_list args) { // thanks to Jan TuroĊˆ https://arduino.stackexchange.com/questions/56517/formatting-strings-in-arduino-for-output @@ -97,8 +97,8 @@ void StringFormatter::send2(Print * stream,const __FlashStringHelper* format, va case 'c': stream->print((char) va_arg(args, int)); break; case 's': stream->print(va_arg(args, char*)); break; case 'e': printEscapes(stream,va_arg(args, char*)); break; - case 'E': printEscapes(stream,(const __FlashStringHelper*)va_arg(args, char*)); break; - case 'S': stream->print((const __FlashStringHelper*)va_arg(args, char*)); break; + case 'E': printEscapes(stream,(const FSH*)va_arg(args, char*)); break; + case 'S': stream->print((const FSH*)va_arg(args, char*)); break; case 'd': printPadded(stream,va_arg(args, int), formatWidth, formatLeft); break; case 'l': printPadded(stream,va_arg(args, long), formatWidth, formatLeft); break; case 'b': stream->print(va_arg(args, int), BIN); break; @@ -138,7 +138,7 @@ void StringFormatter::printEscapes(Print * stream,char * input) { } } -void StringFormatter::printEscapes(Print * stream, const __FlashStringHelper * input) { +void StringFormatter::printEscapes(Print * stream, const FSH * input) { if (!stream) return; char* flash=(char*)input; diff --git a/StringFormatter.h b/StringFormatter.h index 5be513f..a3ba7fd 100644 --- a/StringFormatter.h +++ b/StringFormatter.h @@ -19,12 +19,10 @@ #ifndef StringFormatter_h #define StringFormatter_h #include - +#include "FSH.h" #if defined(ARDUINO_ARCH_SAMD) // Some processors use a gcc compiler that renames va_list!!! #include -#elif defined(ARDUINO_ARCH_MEGAAVR) - #define __FlashStringHelper char #endif #include "LCDDisplay.h" @@ -41,22 +39,22 @@ class Diag { class StringFormatter { public: - static void send(Print * serial, const __FlashStringHelper* input...); - static void send(Print & serial, const __FlashStringHelper* input...); + static void send(Print * serial, const FSH* input...); + static void send(Print & serial, const FSH* input...); static void printEscapes(Print * serial,char * input); - static void printEscapes(Print * serial,const __FlashStringHelper* input); + static void printEscapes(Print * serial,const FSH* input); static void printEscape(Print * serial, char c); // DIAG support static Print * diagSerial; - static void diag( const __FlashStringHelper* input...); - static void lcd(byte row, const __FlashStringHelper* input...); + static void diag( const FSH* input...); + static void lcd(byte row, const FSH* input...); static void printEscapes(char * input); static void printEscape( char c); private: - static void send2(Print * serial, const __FlashStringHelper* input,va_list args); + static void send2(Print * serial, const FSH* input,va_list args); static void printPadded(Print* stream, long value, byte width, bool formatLeft); }; diff --git a/Timer.cpp b/Timer.cpp index 10673ec..9c6ad3f 100644 --- a/Timer.cpp +++ b/Timer.cpp @@ -32,6 +32,19 @@ ISR(TIMER5_OVF_vect) TimerD.isrCallback(); } +#elif defined(ARDUINO_ARCH_MEGAAVR) // Todo: add other 328 boards for compatibility + +#include "ATMEGA4809/Timer.h" + +Timer TimerA(1); + + +ISR(TIMER1_OVF_vect) +{ + TimerA.isrCallback(); +} + + #elif defined(ARDUINO_AVR_UNO) // Todo: add other 328 boards for compatibility #include "ATMEGA328/Timer.h" diff --git a/WifiInterface.cpp b/WifiInterface.cpp index 8020d85..e9150dc 100644 --- a/WifiInterface.cpp +++ b/WifiInterface.cpp @@ -52,9 +52,9 @@ Stream * WifiInterface::wifiStream; #endif bool WifiInterface::setup(long serial_link_speed, - const __FlashStringHelper *wifiESSID, - const __FlashStringHelper *wifiPassword, - const __FlashStringHelper *hostname, + const FSH *wifiESSID, + const FSH *wifiPassword, + const FSH *hostname, const int port) { wifiSerialState wifiUp = WIFI_NOAT; @@ -103,8 +103,8 @@ bool WifiInterface::setup(long serial_link_speed, return connected; } -wifiSerialState WifiInterface::setup(Stream & setupStream, const __FlashStringHelper* SSid, const __FlashStringHelper* password, - const __FlashStringHelper* hostname, int port) { +wifiSerialState WifiInterface::setup(Stream & setupStream, const FSH* SSid, const FSH* password, + const FSH* hostname, int port) { wifiSerialState wifiState; static uint8_t ntry = 0; ntry++; @@ -135,8 +135,8 @@ wifiSerialState WifiInterface::setup(Stream & setupStream, const __FlashStringH #pragma GCC diagnostic ignored "-Wunused-variable" #pragma GCC diagnostic ignored "-Wunused-parameter" #endif -wifiSerialState WifiInterface::setup2(const __FlashStringHelper* SSid, const __FlashStringHelper* password, - const __FlashStringHelper* hostname, int port) { +wifiSerialState WifiInterface::setup2(const FSH* SSid, const FSH* password, + const FSH* hostname, int port) { bool ipOK = false; bool oldCmd = false; diff --git a/WifiInterface.h b/WifiInterface.h index 390a85f..191b56f 100644 --- a/WifiInterface.h +++ b/WifiInterface.h @@ -19,6 +19,7 @@ */ #ifndef WifiInterface_h #define WifiInterface_h +#include "FSH.h" #include "config.h" #include "DCCEXParser.h" #include @@ -31,20 +32,20 @@ class WifiInterface public: static bool setup(long serial_link_speed, - const __FlashStringHelper *wifiESSID, - const __FlashStringHelper *wifiPassword, - const __FlashStringHelper *hostname, + const FSH *wifiESSID, + const FSH *wifiPassword, + const FSH *hostname, const int port = 2560); static void loop(); static void ATCommand(const byte *command); private: - static wifiSerialState setup(Stream &setupStream, const __FlashStringHelper *SSSid, const __FlashStringHelper *password, - const __FlashStringHelper *hostname, int port); + static wifiSerialState setup(Stream &setupStream, const FSH *SSSid, const FSH *password, + const FSH *hostname, int port); static Stream *wifiStream; static DCCEXParser parser; - static wifiSerialState setup2(const __FlashStringHelper *SSSid, const __FlashStringHelper *password, - const __FlashStringHelper *hostname, int port); + static wifiSerialState setup2(const FSH *SSSid, const FSH *password, + const FSH *hostname, int port); static bool checkForOK(const unsigned int timeout, const char *waitfor, bool echo, bool escapeEcho = true); static bool connected; static bool closeAfter;