1
0
mirror of https://github.com/DCC-EX/CommandStation-EX.git synced 2024-11-26 17:46:14 +01:00

On <E> commmand, output EEPROM size and amount used.

Also, formatting and indentation fixed.
This commit is contained in:
Neil McKechnie 2021-08-27 12:56:27 +01:00
parent 0aea9169b1
commit 1dd574dc03

View File

@ -19,10 +19,11 @@
* along with CommandStation. If not, see <https://www.gnu.org/licenses/>. * along with CommandStation. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "EEStore.h" #include "EEStore.h"
#include "Turnouts.h"
#include "Sensors.h"
#include "Outputs.h"
#include "DIAG.h" #include "DIAG.h"
#include "Outputs.h"
#include "Sensors.h"
#include "Turnouts.h"
#if defined(ARDUINO_ARCH_SAMD) #if defined(ARDUINO_ARCH_SAMD)
ExternalEEPROM EEPROM; ExternalEEPROM EEPROM;
@ -30,15 +31,19 @@ ExternalEEPROM EEPROM;
void EEStore::init() { void EEStore::init() {
#if defined(ARDUINO_ARCH_SAMD) #if defined(ARDUINO_ARCH_SAMD)
EEPROM.begin(0x50); // Address for Microchip 24-series EEPROM with all three A pins grounded (0b1010000 = 0x50) EEPROM.begin(0x50); // Address for Microchip 24-series EEPROM with all three
// A pins grounded (0b1010000 = 0x50)
#endif #endif
eeStore = (EEStore *)calloc(1, sizeof(EEStore)); eeStore = (EEStore *)calloc(1, sizeof(EEStore));
EEPROM.get(0, eeStore->data); // get eeStore data EEPROM.get(0, eeStore->data); // get eeStore data
if(strncmp(eeStore->data.id,EESTORE_ID,sizeof(EESTORE_ID))!=0){ // check to see that eeStore contains valid DCC++ ID // check to see that eeStore contains valid DCC++ ID
sprintf(eeStore->data.id,EESTORE_ID); // if not, create blank eeStore structure (no turnouts, no sensors) and save it back to EEPROM if (strncmp(eeStore->data.id, EESTORE_ID, sizeof(EESTORE_ID)) != 0) {
// if not, create blank eeStore structure (no
// turnouts, no sensors) and save it back to EEPROM
strncpy(eeStore->data.id, EESTORE_ID, sizeof(EESTORE_ID));
eeStore->data.nTurnouts = 0; eeStore->data.nTurnouts = 0;
eeStore->data.nSensors = 0; eeStore->data.nSensors = 0;
eeStore->data.nOutputs = 0; eeStore->data.nOutputs = 0;
@ -49,19 +54,18 @@ void EEStore::init(){
Turnout::load(); // load turnout definitions Turnout::load(); // load turnout definitions
Sensor::load(); // load sensor definitions Sensor::load(); // load sensor definitions
Output::load(); // load output definitions Output::load(); // load output definitions
} }
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
void EEStore::clear() { void EEStore::clear() {
sprintf(eeStore->data.id,
sprintf(eeStore->data.id,EESTORE_ID); // create blank eeStore structure (no turnouts, no sensors) and save it back to EEPROM EESTORE_ID); // create blank eeStore structure (no turnouts, no
// sensors) and save it back to EEPROM
eeStore->data.nTurnouts = 0; eeStore->data.nTurnouts = 0;
eeStore->data.nSensors = 0; eeStore->data.nSensors = 0;
eeStore->data.nOutputs = 0; eeStore->data.nOutputs = 0;
EEPROM.put(0, eeStore->data); EEPROM.put(0, eeStore->data);
} }
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
@ -72,25 +76,19 @@ void EEStore::store(){
Sensor::store(); Sensor::store();
Output::store(); Output::store();
EEPROM.put(0, eeStore->data); EEPROM.put(0, eeStore->data);
DIAG(F("EEPROM used: %d bytes"), EEStore::pointer()); DIAG(F("EEPROM used: %d/%d bytes"), EEStore::pointer(), EEPROM.length());
} }
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
void EEStore::advance(int n){ void EEStore::advance(int n) { eeAddress += n; }
eeAddress+=n;
}
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
void EEStore::reset(){ void EEStore::reset() { eeAddress = sizeof(EEStore); }
eeAddress=sizeof(EEStore);
}
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
int EEStore::pointer(){ int EEStore::pointer() { return (eeAddress); }
return(eeAddress);
}
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
void EEStore::dump(int num) { void EEStore::dump(int num) {