RTC difettoso o semplicemente collegato male?

Ciao a tutti, sono alle prese con una banalissima libreria per un RTC: RTC by Makuna.
Sto utilizzando un esempio per comprenderne meglio il funzionamento e per settare il componente alla data corrente. Compilo, carico il programma e il monitor seriale non risponde come mi aspetti: cifre sensa senso (o meglio magari riportate male) e ad ogni loop sempre lo stesso valore, il che mi fa pensare che RTC non cammini perché impostato male.

void setup () 
{
    Serial.begin(57600);

    Serial.print("compiled: ");
    Serial.print(__DATE__);
    Serial.println(__TIME__);

    //--------RTC SETUP ------------
    Rtc.Begin();

    // if you are using ESP-01 then uncomment the line below to reset the pins to
    // the available pins for SDA, SCL
    // Wire.begin(0, 2); // due to limited pins, use pin 0 and 2 for SDA, SCL

    RtcDateTime compiled = RtcDateTime(__DATE__, __TIME__);
    printDateTime(compiled);
    Serial.println();

    if (!Rtc.IsDateTimeValid()) 
    {
        // Common Cuases:
        //    1) first time you ran and the device wasn't running yet
        //    2) the battery on the device is low or even missing

        Serial.println("RTC lost confidence in the DateTime!");

        // following line sets the RTC to the date & time this sketch was compiled
        // it will also reset the valid flag internally unless the Rtc device is
        // having an issue

        Rtc.SetDateTime(compiled);
    }

    if (!Rtc.GetIsRunning())
    {
        Serial.println("RTC was not actively running, starting now");
        Rtc.SetIsRunning(true);
    }

    RtcDateTime now = Rtc.GetDateTime();
    if (now < compiled) 
    {
        Serial.println("RTC is older than compile time!  (Updating DateTime)");
        Rtc.SetDateTime(compiled);
    }
    else if (now > compiled) 
    {
        Serial.println("RTC is newer than compile time. (this is expected)");
    }
    else if (now == compiled) 
    {
        Serial.println("RTC is the same as compile time! (not expected but all is fine)");
    }

    // never assume the Rtc was last configured by you, so
    // just clear them to your needed state
    Rtc.Enable32kHzPin(false);
    Rtc.SetSquareWavePin(DS3231SquareWavePin_ModeNone); 
}

void loop () 
{
    if (!Rtc.IsDateTimeValid()) 
    {
        // Common Cuases:
        //    1) the battery on the device is low or even missing and the power line was disconnected
        Serial.println("RTC lost confidence in the DateTime!");
    }

    RtcDateTime now = Rtc.GetDateTime();
    printDateTime(now);
    Serial.println();

    RtcTemperature temp = Rtc.GetTemperature();
    Serial.print(temp.AsFloat());
    Serial.println("C");

    delay(10000); // ten seconds
}

#define countof(a) (sizeof(a) / sizeof(a[0]))

void printDateTime(const RtcDateTime& dt)
{
    char datestring[20];

    snprintf_P(datestring, 
            countof(datestring),
            PSTR("%02u/%02u/%04u %02u:%02u:%02u"),
            dt.Month(),
            dt.Day(),
            dt.Year(),
            dt.Hour(),
            dt.Minute(),
            dt.Second() );
    Serial.print(datestring);
}

Il monitor seriale mi riporta questo

compiled: Sep  2 201719:53:24
09/02/2017 19:53:24
RTC lost confidence in the DateTime!
RTC was not actively running, starting now
RTC is older than compile time!  (Updating DateTime)
RTC lost confidence in the DateTime!
85/165/2009 37:165:
-3.31C
RTC lost confidence in the DateTime!
85/165/2009 37:165:
-3.31C
RTC lost confidence in the DateTime!
85/165/2009 37:165:
-3.31C

Da notare la temperatura… -3.31C

Il tutto é caricato su un Arduino UNO dai connettori A4 e A5 rispettivamente SDA e SCL del DS3231 alimentato a 3.3V

Che RTC ? Come è collegato ? La batteria ce l'hai messa ? E' carica ? Il LINK alla libreria ?

Guglielmo

Sale91: Il tutto é caricato su un Arduino UNO dai connettori A4 e A5 rispettivamente SDA e SCL del DS3231 alimentato a 3.3V

Libreria: https://github.com/Makuna/Rtc Batteria nuova

Ma stai usando un modulo già fatto (... allora metti il LINK) o hai fatto tu il circuito con il DS3231 ?

Perché i moduli già fatti, di solito, vanno alimentati a 5V e, spesso, includono le resistenze di pull-up, se lo hai fatto tu, hai messo le pull-up ?

Guglielmo

Giusto, mi ero dimenticato di specificarlo : https://www.amazon.de/gp/product/B01M2B7HQB/ref=oh_aui_detailpage_o02_s00?ie=UTF8&psc=1

Classico modulino con il DS3231 e la vecchia AT24C32 (ormai non più in produzione) ... ... alimentalo a 5V e lancia l'I2C scanner per verificare che lo veda bene, così sei sicuro che il colloquio funziona ...

Guglielmo

Scanning...
I2C device found at address 0x57  !
done

Questo é il risultato

Mmmm ... strano, normalmente, quel modulo dovrebbe avere DUE indirizzi 0x68 (RTC) e 0x57 (AT24C32) ... ::)

Ecco cosa dovrebbe uscire

Scanning...
I2C device found at address 0x57  !
I2C device found at address 0x68  !
done

... probabilmente è guasto il DS3231 ::)

Guglielmo

Grazie Guglielmo, ora lo rispedisco indietro, dato che mi fanno il rimborso riprendo lo stesso modello o mi consigli un altro rtc (magari per le librerie)?

Sale91: .... dato che mi fanno il rimborso riprendo lo stesso modello o mi consigli un altro rtc (magari per le librerie)?

Il DS3231, in questa fascia di prodotti (e di costi), è sicuramente il migliore ... io resterei sullo stesso modulo.

Guglielmo