LK-RTC: Unterschied zwischen den Versionen

Aus Linkerkit.de

Wechseln zu: Navigation, Suche
(Codebeispiel Arduino)
(Codebeispiel Raspberry)
Zeile 115: Zeile 115:
 
}</pre>
 
}</pre>
  
==Codebeispiel Raspberry==
+
==Raspberry Installation==
   
+
 
 +
Zunächst muss die Echtzeituhr an den I2C-Port des Raspberry-Linkerkit-Shields angeschlossen werden.
 +
Als nächstes muss über die Kommandozeile das I2C-System installiert werden:
 +
 
 +
<pre class="brush:bash">sudo apt-get install i2c-tools
 +
sudo bash
 +
</pre>
 +
 
 +
Nun muss festgelegt werden, dass die benötigten Module auch beim Systemstart geladen werden:
 +
 
 +
<pre class="brush:bash">nano /etc/modules</pre>
 +
 
 +
Hier tragen wir folgende Module ein:
 +
''snd-bcm2835''
 +
''spi-bcm2708''
 +
''i2c-bcm2708''
 +
''i2c-dev''
 +
''rtc-ds1307''
 +
 
 +
Folgende Module müssen nun aktiviert werden:
 +
 
 +
<pre class="brush:bash">modprobe i2c_bcm2708
 +
modprobe i2c_dev
 +
modprobe rtc_ds1307</pre>
 +
 
 +
Nun lassen wir das System nach einem I2C-Gerät suchen.
 +
<pre class="brush:bash">i2cdetect -y 1</pre>
 +
 
 +
Das Ergebnis sollte so aussehen:
 +
<pre class="code">   
 +
0 1  2  3  4  5  6  7  8  9  a  b  c  d  e  f
 +
00:          -- -- -- -- -- -- -- -- -- -- -- -- --
 +
10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
 +
20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
 +
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
 +
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
 +
50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
 +
60: -- -- -- -- -- -- -- -- 68 -- -- -- -- -- -- --
 +
70: -- -- -- -- -- -- -- --
 +
</pre>
 +
Dies bedeutet, das die Uhr unter der Adresse 68 gefunden wurde.
 +
 
 +
Die Uhr kann nun in das System eingebunden werden.
 +
<pre class="brush:bash">echo ds1307 0x68 > /sys/class/i2c-adapter/i2c-1/new_device</pre>
 +
 
 +
Mit folgendem Befehl kann die aktuelle Uhrzeit ausgelesen werden:
 +
<pre class="brush:bash">hwclock -r</pre>
 +
 
 +
Und mit diesem Befehl kann die aktuelle Systemzeit in die Echtzeituhr gespeichert werden:
 +
<pre class="brush:bash">hwclock -w</pre>
 +
 
 
==Downloads==
 
==Downloads==
 
Infos:<br />Englisch: [[Medium:001267860-da-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf|001267860-da-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf]]
 
Infos:<br />Englisch: [[Medium:001267860-da-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf|001267860-da-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf]]
  
 
Schaltung: [[Medium:001267860-sp-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf|001267860-sp-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf]]
 
Schaltung: [[Medium:001267860-sp-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf|001267860-sp-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf]]

Version vom 16. November 2016, 17:12 Uhr

Bild

LK-RTC.png

Technische Daten / Kurzbeschreibung

Linker Kit Platine mit RTC (Echtzeituhr), ohne Batterie. Das RTC Modul basiert auf dem Uhr-Chip DS1307, welches das I2C Protokoll unterstützt. Für eine genaue Anzeige benötigt man eine Lithium Zellen Batterie(CR1225). Die Uhr liefert Sekunden, Minuten, Stunden, Tage, Monat und Jahr. Das Modul liefert das richtige Datum trotz Monate die weniger als 31 Tage haben, zusätzlich werden Schaltjahre berücksichtigt. Die Uhr arbeitet im 24 Stunden oder im 12 Stunden Format mit einer AM/PM Anzeige. Und sie ist gültig bis 2100. Wenn das Modul nur mit der primären Stromversorgung versorgt wird, funktioniert das Modul nicht richtig, weil der Kristall nicht schwingen kann.

Spezifikation

Maße: 42,1 × 24,2 × 10,6mm
Gewicht: 3,8g
IO Struktur: SCL,SDA,VCC,GND
ROHS: Ja
Vcc:4,5 ~ 5,5V
Logik High Level Eingang:2,2 - Vcc+0,3V
Logik Low Level Eingang:-0,3 - +0,8V
Batterie Spannung:2,0 - 3,5V

Codebeispiel Arduino

#include  "Wire.h"
#define  DS1307_I2C_ADDRESS  0x68 // Das ist die I2C Adresse
// Globale Variablen
int command = 0; // Das ist der Befehl char, in ascii Form, aus dm seriellen Port gesendet 
byte zero=0; 
byte second, minute, hour, dayOfWeek, dayOfMonth, month, year;
byte test;
 
byte decToBcd(byte val) 
{
   return ( (val/10*16) + (val%10) );
}
// Konventiert BCD-Code Zahlen zu normalen Dezimalzahlen
byte bcdToDec(byte val) 
{
  return ( (val/16*10) + (val%16) );
}
 
void setDateDs1307(void)
{
  second = (byte) ((Serial.read() - 48) * 10 + (Serial.read() - 48)); 
  minute = (byte) ((Serial.read() - 48) *10 +  (Serial.read() - 48));
  hour  = (byte) ((Serial.read() - 48) *10 +  (Serial.read() - 48));
  dayOfWeek = (byte) (Serial.read() - 48);
  dayOfMonth = (byte) ((Serial.read() - 48) *10 +  (Serial.read() - 48));
  month = (byte) ((Serial.read() - 48) *10 +  (Serial.read() - 48));
  year= (byte) ((Serial.read() - 48) *10 +  (Serial.read() - 48));
  Wire.beginTransmission(DS1307_I2C_ADDRESS);
  Wire.write(zero);
  Wire.write(decToBcd(second));    // 0 bis bit 7 startet die Uhr
  Wire.write(decToBcd(minute));
  Wire.write(decToBcd(hour));      // Wenn Sie eine 12 Stunden Uhr (am/pm) haben wollen, müssen Sie
                                  // Bit 6 setzten (Es muss readDateDS1307 verändert werden)
  Wire.write(decToBcd(dayOfWeek));
  Wire.write(decToBcd(dayOfMonth));
  Wire.write(decToBcd(month));
  Wire.write(decToBcd(year));
  Wire.endTransmission();
}
 
 // Ruft das Datum und die Uhrzeit aus dem DS1307 
void getDateDs1307() 
{
 // Registerzeiger wird zurückgesetzt
 Wire.beginTransmission(DS1307_I2C_ADDRESS);
 Wire.write(zero);
 Wire.endTransmission();
 Wire.requestFrom(DS1307_I2C_ADDRESS, 7);
 // Einige von diesen benötigen Masken, weil bestimmte Bits Steuerbits sind.
 second     = bcdToDec(Wire.read() & 0x7f);
 minute     = bcdToDec(Wire.read());
 hour       = bcdToDec(Wire.read() & 0x3f);  // Dies muss verändert werden,
                                             // wenn der 12Stunden Modus(am/pm) eingeschaltet ist
 dayOfWeek  = bcdToDec(Wire.read());
 dayOfMonth = bcdToDec(Wire.read());
 month      = bcdToDec(Wire.read());
 year       = bcdToDec(Wire.read());
 
 Serial.print(hour, DEC);
 Serial.print(":");
 Serial.print(minute, DEC);
 Serial.print(":");
 Serial.print(second, DEC);
 Serial.print("  ");
 Serial.print(month, DEC);
 Serial.print("/");
 Serial.print(dayOfMonth, DEC);
 Serial.print("/");
 Serial.print(year, DEC);
 Serial.println("  ");
}
 
void setup() 
{
  Wire.begin();
  Serial.begin(9600); 
} 
void loop()
{
  delay(2000);
  /*T(00-59)(00-59)(00-23)(1-7)(01-31)(01-12)(00-99) - T(sec)(min)(hour)(dayOfWeek)(dayOfMonth)(month)(year)
  - T stellt das Datum des RTC DS1307 Chip. 
   Beispiel zum setzten der Zeit für 02-DEC-10 @ 19:57:11 für den dritten Wochentag, senden Sie diesen Befehl
   - T1157193021210
  */
    if (Serial.available()) 
    {      // Wenn es festgestellt wurde, geben Sie char in der seriellen Warteschlange und Prozess
     command = Serial.read();
     if (command == 84)
     {      //Wenn command = "T" setze Datum
       setDateDs1307();
       getDateDs1307();
       Serial.println(" ");
     }
     while(1)
     {
       getDateDs1307();
       delay(1000);
     }
  }
}

Raspberry Installation

Zunächst muss die Echtzeituhr an den I2C-Port des Raspberry-Linkerkit-Shields angeschlossen werden. Als nächstes muss über die Kommandozeile das I2C-System installiert werden:

sudo apt-get install i2c-tools
sudo bash

Nun muss festgelegt werden, dass die benötigten Module auch beim Systemstart geladen werden:

nano /etc/modules

Hier tragen wir folgende Module ein: snd-bcm2835 spi-bcm2708 i2c-bcm2708 i2c-dev rtc-ds1307

Folgende Module müssen nun aktiviert werden:

modprobe i2c_bcm2708
modprobe i2c_dev
modprobe rtc_ds1307

Nun lassen wir das System nach einem I2C-Gerät suchen.

i2cdetect -y 1

Das Ergebnis sollte so aussehen:

     
0  1  2  3  4  5  6  7  8  9  a  b  c  d  e  f
00:          -- -- -- -- -- -- -- -- -- -- -- -- --
10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
60: -- -- -- -- -- -- -- -- 68 -- -- -- -- -- -- --
70: -- -- -- -- -- -- -- --

Dies bedeutet, das die Uhr unter der Adresse 68 gefunden wurde.

Die Uhr kann nun in das System eingebunden werden.

echo ds1307 0x68 > /sys/class/i2c-adapter/i2c-1/new_device

Mit folgendem Befehl kann die aktuelle Uhrzeit ausgelesen werden:

hwclock -r

Und mit diesem Befehl kann die aktuelle Systemzeit in die Echtzeituhr gespeichert werden:

hwclock -w

Downloads

Infos:
Englisch: 001267860-da-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf

Schaltung: 001267860-sp-01-en-linker_kit_platine_mit_rtc_echtzeituhr_.pdf