Difference between revisions of "I2C (Deutsch)"
m (→Anschluss) |
|||
Line 40: | Line 40: | ||
==Anschluss== | ==Anschluss== | ||
− | Die Leitungen SCL (Clock) und SDA (Data) liegen als "Alternate Function" auf I/O Leitungen der Controller. Beim ATmega32 sind dies PC0 (SCL) und PC1 (SDA). | + | Die Leitungen SCL (Clock) und SDA (Data) liegen als "Alternate Function" auf I/O Leitungen der Controller. Beim ATmega32/644/644p sind dies PC0 (SCL) und PC1 (SDA). |
=Etherrape= | =Etherrape= |
Revision as of 14:31, 24 January 2016
I2C | |
---|---|
Status | Stable
|
menuconfig | I/O-I2C Master Support |
Pinning | no |
Ecmd | yes |
Control6 | - |
Depends on | - |
Requires | CONFIG_EXPERIMENTAL |
Code | https://github.com/ethersex/ethersex/tree/master/hardware/i2c/master |
Der I2C-Bus (Inter Integrated Circuit) ist ein einfacher Zweidraht-Bus, der für die Kommunikation zwischen ICs innerhalb eines größeren Systems verwendet wird. Insbesondere bietet er sich an zur Kommunikation zwischen Microcontrollern und Peripheriegeräten.
Das Ethersex-System kann sowohl als Master als auch als Slave in einem I2C-Bus arbeiten.
In der Atmel-Dokumentation wird I2C als TWI (Two Wire Interface) geführt.
Contents
Allgemeines
Master Mode
Im Master-Mode kann das Ethersex-System auf angeschlossene I2C-Slaves zugreifen. Unterstützt werden im Moment:
- 24cXX EEPROMs (Als Storage Backend für das Virtuelle Dateisystem)
- LM75 Temperatursensoren
- PCA9531 8 bit LED Dimmer
- PCF8574x Port Extension
Slave Mode
- Kann per I2C auf die ECMD Schnittstelle zugegriffen werden.
- In menuconfig -> Protocols -> ECMD -> I2C aktivieren
Beispielimplementierung mit Ethersex (Slave) und einem zweiten AVR (Master).
Anschluss
Die Leitungen SCL (Clock) und SDA (Data) liegen als "Alternate Function" auf I/O Leitungen der Controller. Beim ATmega32/644/644p sind dies PC0 (SCL) und PC1 (SDA).
Etherrape
Beim Etherrape ist der I2C-Bus auf einem separaten Steckverbinder herausgeführt.
Pollin AVR-NET-IO
Beim Pollin AVR-NET-IO liegen die Leitungen des Ports C auf J3, dem 25poligen SUB-D Steckverbinder. Dort lassen sich auch Versorgungsspannung und Masse für die angeschlossenen Slaves abgreifen:
Pin | Funktion |
---|---|
2 | PC0 (SCL) |
3 | PC1 (SDA) |
15 | 5V |
18 | GND |
Konfiguration
Die Leitungen sind fest vorgegeben, daher muss keine Konfiguration des Pinnings erfolgen.
Die Einstellungen für den Master-Mode finden sich unter:
│ │ Load a Default Configuration ---> │ │ General Setup ---> │ │ Network ---> │ │ I/O ---> │ │ I2C ---> │ │ [*] I2C master ---> │ │ [*] I2C detection support
ECMD
I2C
Mittels "i2c detect" werden die gefundenen I2C Adressen aufgelistet
i2c detect detected at: 0x20 (32) detected at: 0x48 (72) detected at: 0x60 (96)
Mit den allgemeinen I2C-Kommandos können alle I2C-Chips angesprochen werden. Mit dem Befehl
i2c wbb 72 81
wird z. B. die Temperatur-Konvertierung auf einem DS1631 gestartet. Geschrieben wird ein Byte mit dem Wert 81 an den Chip mit der Adresse 72.
Mit dem Befehl
i2c rwd 72 170
wird ein Word von der Adresse 170 des Chips mit der Adresse 72 gelesen. Damit wird die Temperatur des DS1631 ausgelesen. Die Umrechung muß man dann per Hand durchführen.
I2C Sensoren
LM75
Um den LM75 Temperatursensor auszulesen (Basisadresse 0x48) muss die IC Adresse angegeben werden. In diesem Falle ist das "0" weil die IC Adresse a0 bis a2 auf Masse gesetzt werden. -> binär 000 = 0
lm75 0 21.5
DS1631
Ein DS1631 Temperatursensor muß nach dem Einschalten der Stromversorgung erst aktiviert werden. Der erste DS1631 mit der Adresse 0x48 hat im Befehl die Adresse 0. Mit dem folgenden Befehl wird die Temperatur-Konvertierung eingeschaltet:
ds1631 convert 0 1
Jetzt kann die Temperatur ausgelesen werden. Die Genauigkeit beträgt immer die vollen 12bits.
ds1631 temp 0 22.875
Wahrscheinlich können auch DS1621-Sensoren ausgelesen werden, das wurde aber noch nicht getestet!
PCF8574
Für die Porterweiterung gilt das Schema "pcf8574x read adresse chip" wobei die adresse 0-7 sein kann, und chip "0" oder "1", je nachdem ob man den pcf8574 oder den pcf8574A benutzt.
pcf8574x read 0 0 FFFF
Schalten von Ausgängen mit Wert 0xF0 am PCF8574 mit Adresse 5 (Das bedeutet das a0=1 und a2=1 ist, ergo 101) d.h. die ersten 4 Ausgänge werden auf "1" die anderen 4 Ausgänge auf "0" gesetzt.
pcf8574x set 5 0 F0
TSL2561 Licht/Digital-Wandler
(tested commit e927b0e)
I/O --> I2C--> [*]I2C master --> [*] I2C detection support [*] I2C TSL2561 light sensor
Abfrage via http ecmd:
/ecmd?i2c detect // detected at: 0x39 (57), funktioniert und wird erkannt. /ecmd?tsl2561 raw // parse error, funktioniert derzeit nicht?. 24.01.2016 /ecmd?tsl2561 lux // parse error, funktioniert derzeit nicht?. 24.01.2016