Unterstützt die Montage mehrerer Geräte am Bus (ein Master und mehrere Slaves, mehrere Master und mehrere Slaves)
Ein Master, mehrere Slaves: Der Mikrocontroller fungiert als Host und dominiert den Betrieb des I2C-Busses. Alle am I2C-Bus montierten externen Module sind Slaves, die den I2C-Bus nur nach Benennung durch den Host steuern und nicht berühren können ohne Erlaubnis. I2C-Bus, um Konflikte zu vermeiden.
Multi-Master und Multi-Slave: Jedes Modul am Bus kann aktiv herausspringen und als Master fungieren. Wenn ein Buskonflikt auftritt, führt das I2C-Protokoll eine Schlichtung durch. Die Partei, die die Schlichtung gewinnt, erhält die Kontrolle über den Bus und die unterlegene Partei wird automatisch zum Slave.
1.2 Hardware-Schaltung
Die SCL aller I2C-Geräte sind miteinander verbunden, und der SDA ist miteinander verbunden.
Sowohl SCL als auch SDA des Geräts müssen im Open-Drain-Ausgabemodus konfiguriert sein.
Fügen Sie SCL und SDA jeweils einen Pull-up-Widerstand hinzu. Der Widerstandswert beträgt im Allgemeinen etwa 4,7 kΩ
Ein Master und mehrere Slaves: Die CPU ist ein Single-Chip-Mikrocomputer. Als Master des Busses verfügt sie jederzeit über die volle Kontrolle über die SCL-Leitung. Darüber hinaus kann der Host im Ruhezustand die Steuerung von SDA aktiv initiieren. Nur wenn der Slave Daten sendet und der Slave antwortet, überträgt der Host die Steuerung von SDA auf den Slave.
Der gesteuerte IC ist ein am I2C-Bus montierter Slave, der ein Lagesensor, OLED, Speicher, Uhrenmodul usw. sein kann. Die Leistung des Slaves ist für die SCL-Taktleitung relativ gering und kann jederzeit nur passiv gelesen werden. Der Slave darf die SCL-Leitung nicht steuern. Für die SDA-Datenleitung ist es dem Slave nicht gestattet, aktiv die Steuerung von SDA einzuleiten. Erst nachdem der Master einen Befehl zum Lesen des Slaves gesendet hat oder wenn der Slave antwortet, kann der Slave kurzzeitig die Kontrolle über den SDA erlangen.
Abbildung 2: SCL links und SDA rechts. Alle Daten können über einen Datenpuffer oder einen Schmitt-Trigger eingegeben werden.
Da der Eingang keinen Einfluss auf die Schaltung hat, kann jedes Gerät jederzeit einen Eingang haben.
Der Ausgang verwendet eine Open-Drain-Ausgangskonfiguration. Wenn der Ausgang niedrig ist, ist der Schalter eingeschaltet und der Pin ist direkt mit Masse verbunden. Wenn der Ausgang hoch ist, ist der Stift ausgeschaltet ist mit nichts verbunden und befindet sich in einem schwebenden Zustand, sodass alle Geräte nur einen niedrigen Pegel, aber keinen hohen Pegel ausgeben können. Um ein durch hohen Pegel verursachtes Schweben zu vermeiden, müssen SCL und SDA einen externen Pull-up-Widerstand haben Der Bus wird durch einen Widerstand auf einen hohen Pegel gezogen, es handelt sich also um einen schwachen Pull-up. Auf diese Weise wird erstens das Phänomen des Stromkurzschlusses vollständig eliminiert und die Sicherheit des Stromkreises gewährleistet; zweitens wird ein häufiges Umschalten der Pin-Modi vermieden. Im Open-Drain-Modus entspricht die Ausgabe eines hohen Pegels dem Trennen des Pins, sodass Sie vor der Eingabe direkt einen hohen Pegel ausgeben können. Drittens weist dieser Modus ein „Wired AND“-Phänomen auf. Solange ein oder mehrere Geräte einen niedrigen Pegel ausgeben, ist der Bus auf einem hohen Pegel. . Daher kann I2C dieses Phänomen nutzen, um Taktsynchronisierung und Busarbitrierung im Multi-Master-Modus durchzuführen. Obwohl SCL hier den Push-Pull-Ausgang in einem Master- und mehreren Slave-Modus verwenden kann, verwendet es dennoch den Open-Drain-Plus-Pull-Out-Ausgangsmodus.
1.3 I2C-Timing-Grundeinheit
1.3.1 Startbedingungen und Endbedingungen
Ausgangsbedingung: Während SCL-High-Pegel schaltet SDA von High-Pegel auf Low-Pegel um
Beendigungsbedingung: Während SCL-High-Pegel wechselt SDA von Low-Pegel auf High-Pegel
unter Anfangsbedingungen : Wenn sich der I2C-Bus im Leerlaufzustand befindet, befinden sich sowohl SCL als auch SDA auf einem hohen Pegel, d in einem ruhigen Zustand. Wenn der Host Daten senden und empfangen muss, muss er zuerst die Stille des Busses durchbrechen und eine Startbedingung generieren, dh SCL befindet sich auf einem hohen Pegel, ohne ihn zu berühren, und dann SDA nach unten ziehen, um eine fallende Flanke zu erzeugen. Wenn der Slave den hohen SCL-Pegel und das fallende SDA-Flankensignal erfasst, setzt er sich selbst zurück und wartet auf den Anruf des Masters. Nach der fallenden Flanke von SDA muss der Host SCL erneut herunterziehen, um einerseits den Bus zu belegen und andererseits auch das Spleißen der Basiseinheit zu erleichtern. Später wird sichergestellt, dass mit Ausnahme der Start- und Stoppbedingungen der SCL jeder sequentiellen Einheit mit einem niedrigen Pegel beginnt und mit einem niedrigen Pegel endet.
Im Zustand der Beendigungsbedingung : SCL lässt zuerst los und springt auf den hohen Pegel zurück, dann lässt SDA los und springt auf den hohen Pegel zurück, wodurch eine steigende Flanke erzeugt wird, die die Abbruchbedingung auslöst. Nach der gleichzeitigen Beendigungsbedingung sind sowohl SCL als auch SDA hoch und kehren in den anfänglichen ruhigen Zustand zurück. Start und Stopp werden vom Host generiert, und der Slave darf keinen Start und Stopp generieren. Daher muss der Slave im Ruhezustand des Busses immer seine Hände loslassen und darf nicht herausspringen und den Bus berühren.
1.3.2 Ein Byte senden
Senden Sie ein Byte: Während des niedrigen SCL-Pegels legt der Host die Datenbits der Reihe nach auf die SDA-Leitung (hohes Bit zuerst) und gibt dann SCL frei. Der Slave liest die Datenbits während des hohen SCL-Pegels, sodass SDA nicht zulässig ist Um während der hohen SCL-Ebene Daten zu erhalten, führen Sie den oben genannten Vorgang achtmal durch, um ein Byte zu senden.
Der Low-Level-Host stellt Daten ein und der High-Level-Slave liest Daten. Nach der Startbedingung muss auch das erste Byte vom Host gesendet werden. Wenn SCL niedrig ist und der Host 0 senden möchte, zieht er SDA auf niedrig; wenn er 1 senden möchte, lässt er los und SDA springt auf hohen Pegel zurück. Während der niedrigen SCL-Stufe darf sich die SDA-Stufe ändern. Nachdem die Daten platziert wurden, gibt der Host die Taktleitung frei und SCL springt auf die hohe Stufe zurück. Während des High-Pegels ist es die Zeit, in der der Slave SDA liest, sodass sich SDA während des High-Pegels nicht ändern darf. Nachdem SCL einen hohen Pegel erreicht hat, muss der Slave SDA so schnell wie möglich lesen. Im Allgemeinen hat der Slave den Lesevorgang bei der steigenden Flanke von SCL abgeschlossen. Da die Uhr vom Master gesteuert wird, weiß der Slave nicht, wann die fallende Flanke auftritt, sodass der Slave die Daten an der steigenden Flanke von SCL liest. Nachdem der Host SCL für eine gewisse Zeit losgelassen hat, kann er SCL weiterhin auf Low ziehen und das nächste Bit übertragen. Der Host muss außerdem Daten so schnell wie möglich nach der fallenden Flanke von SCL auf SDA übertragen. Da der Host jedoch die Kontrolle über die Uhr hat, muss er nur dann Daten auf den SDA übertragen, wenn der niedrige Pegel niedrig ist. Nachdem die Daten freigegeben wurden, gibt der Host SCL erneut frei, SCL ist hoch und der Slave liest dieses Bit. Schleifen Sie diesen Prozess ab: Der Host zieht SCL auf Low, legt die Daten auf SDA, der Host gibt SCL frei und der Slave liest SDA-Daten. Bei der SCL-Synchronisation sendet der Master nacheinander und der Slave empfängt nach 8 Zyklen 8-Bit-Daten, also ein Byte. Da es das höherwertige Bit zuerst ist, ist das erste Bit das höchste Bit B7 eines Bytes und das niedrigste Bit B0 wird zuletzt gesendet.
1.3.3 Ein Byte empfangen
ein Byte erhalten: Während des niedrigen SCL-Pegels legt der Slave die Datenbits der Reihe nach auf die SDA-Leitung (hohes Bit zuerst) und gibt dann SCL frei. Der Host liest die Datenbits während des hohen SCL-Pegels, sodass SDA nicht zulässig ist Um während der hohen SCL-Ebene Daten zu haben, führen Sie den oben genannten Vorgang achtmal durch, um ein Byte zu empfangen (der Host muss SDA vor dem Empfang freigeben).
Low-Level-Slave stellt Daten ein, High-Level-Host liest Daten SDA-Leitung: Der Master muss SDA freigeben, bevor er empfängt. Wenn der Slave 0 senden muss, zieht er SDA auf Low springt auf hohes Niveau zurück. Low-Level konvertiert Daten, High-Level liest Daten. Die durchgezogene Linie stellt den vom Master gesteuerten Pegel dar, und die gepunktete Linie stellt den vom Slave gesteuerten Pegel dar. SCL wird während des gesamten Prozesses vom Host gesteuert. Der SDA-Host muss vor dem Empfang freigegeben und zur Steuerung an den Slave übergeben werden. Da der SCL-Takt vom Host gesteuert wird, erfolgt die Datenkonvertierung des Slaves grundsätzlich an der fallenden Flanke von SCL, und der Host kann jederzeit lesen, wenn SCL hoch ist.
1.3.4 Antwort senden und Antwort empfangen
Antwort senden: Nach dem Empfang eines Bytes sendet der Host beim nächsten Takt ein Datenbit. Daten 0 zeigt eine Antwort an, und Daten 1 zeigen eine Nichtantwort an.
Antwort erhalten: Nachdem der Host ein Byte gesendet hat, empfängt er beim nächsten Takt ein Datenbit, um zu bestimmen, ob der Slave antwortet. Daten 0 zeigen eine Antwort an, Daten 1 zeigen eine Nichtantwort an (der Host muss SDA vor dem Empfang freigeben).
Das heißt, nach dem Aufruf des Sendezeitpunkts eines Bytes muss der Zeitpunkt des Aufrufs der Empfangsantwort folgen, anhand derer ermittelt wird, ob der Slave die ihm gerade übergebenen Daten empfangen hat. Wenn der Slave es empfängt, sollte der Slave im Antwortbit, wenn der Master SDA freigibt, SDA sofort herunterziehen, und dann, während der SCL-High-Pegel ist, liest der Host das Antwortbit. Wenn das Antwortbit 0 ist, bedeutet dies, dass der Slave es tatsächlich empfangen hat. Wenn Sie ein Byte empfangen, müssen Sie die Sendeantwort aufrufen. Der Zweck des Sendens einer Antwort besteht darin, dem Slave mitzuteilen, ob Sie mit dem Senden fortfahren möchten. Wenn der Slave-Computer nach dem Senden eines Datenelements eine Antwort vom Master erhält, sendet der Slave-Computer weiterhin. Wenn der Slave-Computer keine Antwort vom Master-Computer erhält, geht der Slave-Computer davon aus, dass ein Datenelement vorhanden ist wurde gesendet, aber der Master-Computer ignoriert mich möglicherweise. Der Host möchte dies nicht. Zu diesem Zeitpunkt gibt der Slave gehorsam die Kontrolle über SDA frei, um eine Beeinträchtigung der nachfolgenden Vorgänge des Hosts zu verhindern.
1.4 I2C-Timing
1.4.1 Geben Sie die zu schreibende Adresse an
Geben Sie die zu schreibende Adresse an
Schreiben Sie für das angegebene Gerät (Slave-Adresse) die angegebenen Daten (Daten) an die angegebene Adresse (Reg-Adresse) (d. h. die Registeradresse des angegebenen Geräts).
Verfahren: (1) Startbedingungen (2) Zeitpunkt des Sendens eines Bytes – 0xD0 (Slave-Adresse (7 Bit) + Schreiben (1 Bit)-0) (1101 0000) (3) Antwort empfangen: RA = 0 (Antwort vom Slave empfangen) (4) Angegebene Adresse: 0x19 (0001 1001) (5) Antwort empfangen: RA = 0 (Antwort vom Slave empfangen) (6) Spezifizierte Daten schreiben: 0xAA (1010 1010) (7) Antwort empfangen: RA = 0 (8) Stoppbit P (Abbruchbedingung)
Nach der Startbedingung muss der Zeitpunkt zum Senden eines Bytes sein. Der Inhalt des Bytes muss die Slave-Adresse + Lese- und Schreibbits sein. Die Slave-Adresse beträgt 7 Bits und die Lese- und Schreibbits sind genau 1 Bit 8 Bit. Das Senden der Slave-Adresse dient der Bestimmung des Kommunikationsobjekts und das Senden des Lese- und Schreibbits dient der Bestätigung, ob als nächstes geschrieben oder gelesen werden soll. Jetzt sendet der Host ein Datenelement, das zuerst in ein Hexadezimalformat umgewandelt wird, nämlich 0xD0. Die folgende Einheit ist das Antwortbit (RA) des empfangenden Slaves. Das Schreibbit endet und SCL wird auf Low gesetzt. Danach muss der Host SDA freigeben, gefolgt vom Bestätigungsbit RA.
Der High-Pegel nach dem Ende des Antwortbits RA wird durch die Freigabe von SDA durch den Slave erzeugt. Da der Slave so schnell wie möglich Daten austauschen möchte, ist die steigende Flanke von SDA erforderlich Die fallende Flanke von SCL erfolgte fast gleichzeitig.
Wenn Sie nach Abschluss der Antwort weiterhin ein Byte senden, kann das zweite Byte an das Innere des angegebenen Geräts gesendet werden. Das Slave-Gerät kann die Verwendung des zweiten Selbst und nachfolgender Bytes definieren. Im Allgemeinen kann das zweite Byte eine Registeradresse oder ein Befehlssteuerwort usw. sein, und das dritte Byte ist der Inhalt, den der Host in die Registeradresse schreiben möchte (zweites Byte).
P ist das Stoppbit.
Der Zweck dieses Datenrahmens besteht darin, für das Gerät, das die Slave-Adresse 1101000 angibt, die Daten 0xAA in sein internes Register an der Adresse 0x19 zu schreiben. 0 bedeutet: Der Host führt im nachfolgenden Timing einen Schreibvorgang aus; 1 bedeutet: Der Host führt in der nachfolgenden Zeitsequenz einen Auslesevorgang durch;
1.4.2 Aktuelle Adresse lesen
Aktuelle Adresse gelesen
Lesen Sie für das angegebene Gerät (Slave-Adresse) die Slave-Daten (Daten) an der Adresse, die durch den aktuellen Adresszeiger angegeben wird.
Verfahren: (1) Startbedingungen (2) Zeitpunkt des Sendens eines Bytes – 0xD1 (Slave-Adresse (7 Bit) + Lesen (1 Bit)-1) (1101 0001) (3) Antwort empfangen: RA = 0 (Antwort vom Slave empfangen) (4) Slave-Daten lesen: 0x0F (0000 1111) (7) Antwort senden: SA = 0 (8) Stoppbit P (Abbruchbedingung)
Das Lese- und Schreibbit ist 1 und zeigt an, dass der nächste Lesevorgang ausgeführt werden soll. Nachdem der Slave geantwortet hat (RA=0), wird die Richtung der Datenübertragung umgekehrt. Der Master möchte die Kontrolle über SDA an den Slave übergeben, und der Master ruft den Zeitpunkt des Empfangs eines Bytes auf, um den Empfangsvorgang auszuführen.
Im zweiten Byte erhält der Slave die Erlaubnis vom Master und kann auf SCL schreiben. Der Master liest SDA auf der hohen SCL-Ebene 8 Bit, ein Byte der vom Slave gesendeten Daten wird empfangen, nämlich 0x0F. Aber welches Register des Slaves ist 0x0F? Beim Lesetiming legt das I2C-Protokoll fest, dass bei der Adressierung des Hosts das Lese- und Schreibflag einmal auf 1 gesetzt ist. Das nächste Byte wechselt sofort zum Lesetiming. Daher beginnt der Host mit dem Empfang, bevor er angeben kann, welches Register er lesen möchte. Daher gibt es hier keinen Link zur Angabe der Adresse. In der Slave-Maschine sind alle Register einem linearen Bereich zugeordnet, und es gibt eine separate Zeigervariable, die eines der Register angibt. Dieser Zeiger zeigt standardmäßig auf die Adresse 0 und jedes Mal, wenn ein Byte geschrieben wird Nach dem Lesen eines Bytes erhöht sich der Zeiger automatisch einmal und bewegt sich zur nächsten Position. Wenn der Host dann den Zeitpunkt des Lesens der aktuellen Adresse nicht angibt, kehrt der Slave zu dem Register zurück, auf das er zeigt aktueller Zeigerwert.
1.4.3 An angegebener Adresse lesen
Geben Sie die Adresse zum Lesen an
Lesen Sie für das angegebene Gerät (Slave-Adresse) unter der angegebenen Adresse (Reg-Adresse) die Slave-Daten (Daten).
Zuerst starten, dann den Start wiederholen und dann stoppen Verfahren: (1) Startbedingungen (2) Zeitpunkt des Sendens eines Bytes – 0xD0 (Slave-Adresse (7 Bit) + Schreiben (1 Bit)-0) (1101 0000) (3) Antwort empfangen: RA = 0 (Antwort vom Slave empfangen) (4) Angegebene Adresse: 0x19 (0001 1001) (5) Antwort empfangen: RA = 0 (Antwort vom Slave empfangen) (6) Wiederholen Sie die Ausgangsbedingung (7) Zeitpunkt des Sendens eines Bytes – 0xD1 (Slave-Adresse (7 Bit) + Lesen (1 Bit)-1) (1101 0001) (8) Antwort empfangen: RA = 0 (9) Slave-Daten lesen: 0xAA (1010 1010) (10) Antwort senden: SA = 0 (11) Stoppbit P (Abbruchbedingung)
Der erste Teil besteht darin, an die angegebene Adresse zu schreiben, es wird jedoch nur die Adresse angegeben, und es bleibt keine Zeit zum Schreiben. Der zweite Teil besteht darin, die aktuelle Adresse zu lesen, da die Adresse gerade angegeben wurde, sodass die aktuelle Adresse gelesen wird noch einmal angerufen.
Die angegebene Slave-Adresse ist 1101000, das Lese-/Schreib-Flag ist 0, und nachdem der Slave geantwortet hat, wird ein weiteres Byte (das zweite Byte) geschrieben, um die Adresse 0x19 anzugeben Adresszeiger, das heißt, nachdem der Slave die Daten empfangen hat, zeigt sein Registerzeiger auf die Position 0x19.
Sr ist eine wiederholte Startbedingung, die dem Starten eines neuen Timings entspricht. Da das angegebene Lese- und Schreibflag nur dem ersten Byte der Startbedingung folgen kann, ist dies nur möglich, wenn Sie die Lese- und Schreibrichtung ändern möchten eine weitere Startbedingung.
Nach der Startbedingung wird das Lese-Schreib-Flag-Bit erneut adressiert und angegeben. Zu diesem Zeitpunkt ist das Lese-Schreib-Flag-Bit 1, was darauf hinweist, dass es gelesen werden soll. Dann empfängt der Host ein Byte, bei dem es sich um die Daten handelt 0xAA an der Adresse 0x19.
2. MPU6050
2.1 Einführung in MPU6050
MPU6050 ist ein 6-Achsen-Lagesensor, der die Beschleunigungs- und Winkelgeschwindigkeitsparameter der eigenen X-, Y- und Z-Achsen messen kann. Durch Datenfusion kann der Lagewinkel (Euler-Winkel) weiter ermittelt werden Balancieren von Fahrzeugen, Flugzeugen usw., die sich selbst in der Gestenszene erkennen müssen
3-Achsen-Beschleunigungsmesser (Beschleunigungsmesser): Misst die Beschleunigung der X-, Y- und Z-Achse
3-Achsen-Gyrosensor (Gyroskop): Misst die Winkelgeschwindigkeit der X-, Y- und Z-Achse
Am Beispiel des Flugzeugrumpfs ist der Euler-Winkel der Winkel zwischen dem Flugzeugrumpf und den ersten drei Achsen.
FlugzeugDie Nase des Flugzeugs neigt sich nach unten oder oben, der Winkel zwischen dieser Achse heißtTonhöhe;
FlugzeugDer Rumpf rollt nach links oder rechts, der Winkel zwischen dieser Achse heißtRollen;
FlugzeugHalten Sie den Rumpf gerade,Drehen Sie die Nase des Flugzeugs nach links oder rechts, der Winkel zwischen dieser Achse heißtGieren。
Der Euler-Winkel stellt die Fluglage des Flugzeugs zu diesem Zeitpunkt dar, unabhängig davon, ob es nach oben oder unten, nach links oder rechts geneigt ist.
Zu den gängigen Datenfusionsalgorithmen gehören im Allgemeinen Komplementärfilterung, Kalman-Filterung usw. sowie die Lageberechnung in der Trägheitsnavigation.
Beschleunigungsmesser : Die gestrichelte Linie in der Mitte ist die Induktionsachse. In der Mitte befindet sich ein kleiner Schieber mit einer bestimmten Masse, der links und rechts dagegen gleiten kann. Wenn sich der Schieber bewegt, wird das darauf befindliche Potentiometer in Bewegung gesetzt. Dieses Potentiometer ist ein Spannungsteilerwiderstand. Durch Messen der vom Potentiometer ausgegebenen Spannung können Sie den Beschleunigungswert des kleinen Schiebers ermitteln. Dieser Beschleunigungsmesser ist eigentlich ein Federkraftmesser, F = ma. Wenn Sie die Beschleunigung a messen möchten, können Sie ein Objekt mit der Einheitsmasse finden und die Kraft F messen. Auf jeder der X-, Y- und Z-Achsen befindet sich ein Beschleunigungsmesser. Beschleunigungsmesser haben statische Stabilität, aber keine dynamische Stabilität.
Gyrosensor : In der Mitte befindet sich ein rotierendes Rad mit einer bestimmten Masse. Wenn sich das rotierende Rad mit hoher Geschwindigkeit dreht, hat das rotierende Rad die Tendenz, seinen ursprünglichen Drehimpuls beizubehalten Richtung der Rotationsachse unverändert. Wenn sich die Richtung des externen Objekts dreht, dreht sich die Richtung der internen Rotationsachse nicht, was zu einer Winkelabweichung an der Verbindung des Ausgleichsrings führt. Wenn man am Anschluss ein Drehpotentiometer anbringt und die Spannung des Potentiometers misst, erhält man den Drehwinkel. Das Gyroskop sollte in der Lage sein, den Winkel direkt zu ermitteln, aber das Gyroskop dieser MPU6050 kann den Winkel nicht direkt messen. Es misst die Winkelgeschwindigkeit, also die Winkelgeschwindigkeit des Chips, der sich um die X-Achse, Y-Achse und Z dreht -Achse. Das Integral der Winkelgeschwindigkeit ist der Winkel. Wenn das Objekt jedoch stationär ist, kann der Wert der Winkelgeschwindigkeit aufgrund von Rauschen nicht vollständig auf Null zurückgesetzt werden. Nach der kontinuierlichen Anhäufung von Integralen führt dieses kleine Rauschen dazu, dass der berechnete Winkel langsam driftet. Dies ist der Winkel, der durch Integration der Winkelgeschwindigkeit erhalten wird. Er kann den Test der Zeit nicht bestehen, aber dieser Winkel stellt kein Problem dar, egal ob er stationär oder bewegt ist, und wird durch die Bewegung des Objekts nicht beeinflusst. Gyroskope haben dynamische Stabilität, keine statische Stabilität.
Dem Beschleunigungsmesser zufolge verfügt er über statische Stabilität, aber nicht über dynamische Stabilität. Diese beiden Eigenschaften können wir aus den Stärken des anderen lernen und die Schwächen des anderen ergänzen Wir können sowohl statische als auch dynamische Stabilität integrieren. Die Haltung ist unangenehm.
2.2 MPU6050-Parameter
16-Bit-ADC sammelt das analoge Signal des Sensors, Quantisierungsbereich: -32768~32767
Auswahl des Vollausschlags des Beschleunigungsmessers: ±2, ±4, ±8, ±16 (g) (1 g = 9,8 m/s2)
Vollskalenauswahl des Gyroskops: ±250, ±500, ±1000, ±2000 (°/s, Grad/Sekunde, Winkelgeschwindigkeitseinheit, wie viele Grad Drehung pro Sekunde) (je größer die Vollskalenauswahl, desto breiter Je kleiner der Messbereich ist, desto höher ist die Messauflösung.
Konfigurierbarer digitaler Tiefpassfilter: Ein Register kann konfiguriert werden, um die Tiefpassfilterung der Ausgangsdaten auszuwählen.
Konfigurierbare Taktquelle
Konfigurierbare Sampling-Frequenzteilung: Die Taktquelle kann durch den Frequenzteiler geteilt werden, um Takte für die AD-Umwandlung und andere interne Schaltkreise bereitzustellen. Durch die Steuerung des Frequenzteilungskoeffizienten können Sie die Geschwindigkeit der AD-Umwandlung steuern.
I2C-Slave-Adresse: 1101000 (AD0=0) oder 1101001 (AD0=1)
110 1000 wird in Hexadezimalzahl umgewandelt, also 0x68, daher sagen einige, dass die Slave-Adresse von MPU6050 0x68 ist. Bei der I2C-Kommunikation sind jedoch die oberen 7 Bits des ersten Bytes die Slave-Adresse und das niedrigste Bit das Lese- und Schreibbit. Wenn Sie also denken, dass 0x68 die Slave-Adresse ist, müssen Sie beim Senden des ersten Bytes zuerst ändern 0x68 Um 1 Bit nach links verschieben (0x68 << 1), dann Bits bitweise oder nach oben lesen und schreiben, 1 lesen und 0 schreiben.
Eine andere Methode besteht darin, die Daten von 0x68 als Slave-Adresse um 1 Bit nach links zu verschieben (0x68 << 1), also 0xD0. In diesem Fall ist die Slave-Adresse von MPU6050 0xD0. Wenn Sie zu diesem Zeitpunkt tatsächlich das erste Byte senden möchten, verwenden Sie einfach 0xD0 als erstes Byte. Wenn Sie lesen möchten, verwenden Sie 0xD0 oder 0x01 (0xD0 | 0x01), dh 0xD1 . Diese Darstellung erfordert keine Linksverschiebungsoperation, oder mit anderen Worten, diese Darstellung integriert die Lese- und Schreibbits in die Slave-Adresse. 0xD0 ist die Schreibadresse und 0xD1 ist die Leseadresse.
2.3 Hardware-Schaltung
Stift
Funktion
VCC, GND
Stromversorgung
SCL, SDA
I2C-Kommunikationspin
XCL, XDA
Host-I2C-Kommunikationspins
AD0
Das niedrigste Bit der Slave-Adresse
INT
Signalausgabe unterbrechen
LDO: Linearer Spannungsregler mit niedrigem Dropout, 3,3-V-Spannungsregler.
SCL und SDA: Es handelt sich um I2C-Kommunikationspins. Das Modul verfügt über zwei integrierte 4,7-K-Pull-up-Widerstände. Bei der Verkabelung müssen Sie also einfach SDA und SCL direkt an den GPIO-Port anschließen. Es ist nicht erforderlich, externe Pull-up-Widerstände anzuschließen .
XCL, XDA: Host-I2C-Kommunikationspins Diese beiden Pins dienen zur Erweiterung der Chipfunktionen. Wird normalerweise für externe Magnetometer oder Barometer verwendet. Wenn diese Erweiterungschips angeschlossen sind, kann die Host-Schnittstelle des MPU6050 direkt auf die Daten dieser Erweiterungschips zugreifen und diese über eine DMP-Einheit einlesen Haltungsberechnung. AD0-Pin: Dies ist das niedrigste Bit der Slave-Adresse. Wenn es mit einem niedrigen Pegel verbunden ist, lautet die 7-Bit-Slave-Adresse 1101000. Wenn es mit einem hohen Pegel verbunden ist, lautet die 7-Bit-Slave-Adresse 1101001. Im Schaltplan gibt es einen Widerstand, der standardmäßig schwach auf den niedrigen Pegel heruntergezogen wird. Wenn der Pin also schwebend bleibt, liegt er auf niedrigem Pegel. Wenn Sie ihn auf den hohen Pegel verbinden möchten, können Sie AD0 direkt an VCC anschließen und ziehen Sie ihn kräftig auf ein hohes Niveau.
INT: Interrupt-Ausgangspin Sie können einige Ereignisse innerhalb des Chips konfigurieren, um die Ausgabe des Interrupt-Pins auszulösen, z. B. Daten bereit, I2C-Hostfehler usw.
Der Chip verfügt außerdem über integrierte Funktionen: Freifallerkennung, Bewegungserkennung, Nullbewegungserkennung usw. Diese Signale können den INT-Pin auslösen, um einen Pegelübergang zu erzeugen, und bei Bedarf können Interrupt-Signale konfiguriert werden.
Die Stromversorgung des MPU6050-Chips beträgt 2,375–3,46 V, was einem 3,3-V-Stromversorgungsgerät entspricht und nicht direkt an 5 V angeschlossen werden kann. Daher wird ein 3,3-V-Spannungsregler hinzugefügt, und die Eingangsklemmenspannung VCC_5V kann zwischen 3,3 V und 5 V liegen. Dann gibt der 3,3-V-Spannungsregler eine stabile 3,3-V-Spannung aus, um den Chip mit Strom zu versorgen , Die Betriebskontrollleuchte leuchtet auf.
2.4 MPU6050-Blockdiagramm
CLKIN und CLKOUT sind Takteingangspins und Taktausgangspins, wir verwenden jedoch im Allgemeinen den internen Takt.
Der graue Teil: ist der Sensor im Chip, der Beschleunigungsmesser auf der XYZ-Achse und das Gyroskop auf der XYZ-Achse.
Es gibt auch einen eingebauten Temperatursensor, mit dem die Temperatur gemessen werden kann.
Diese Sensoren entsprechen im Wesentlichen variablen Widerständen, geben eine analoge Spannung aus und führen dann eine Analog-Digital-Wandlung durch. Nach Abschluss der Wandlung werden die Daten dieser Sensoren einheitlich in die Daten eingefügt Register, das durch Auslesen des Datenregisters abgerufen werden kann. Der vom Sensor gemessene Wert. Alle Konvertierungen innerhalb dieses Chips erfolgen vollständig automatisiert.
Jeder Sensor verfügt über eine Selbsttesteinheit, mit der die Qualität des Chips überprüft wird. Wenn der Selbsttest gestartet wird, simuliert der Chip eine auf den Sensor ausgeübte externe Kraft größer als üblich. Selbsttestprozess: Sie können zuerst den Selbsttest aktivieren, die Daten lesen, dann den Selbsttest aktivieren, die Daten lesen, die beiden Daten subtrahieren und die resultierenden Daten als Selbsttestantwort bezeichnen. Für diese Selbsttest-Antwort gibt das Handbuch einen Bereich an. Liegt er innerhalb dieses Bereichs, bedeutet dies, dass kein Problem mit dem Chip vorliegt.
Ladungspumpe: Es handelt sich um eine Ladungspumpe oder Ladungspumpe. Die Ladungspumpe ist eine Boost-Schaltung.
Der CPOUT-Pin erfordert einen externen Kondensator.
Interrupt-Statusregister: Kann steuern, welche internen Ereignisse an den Interrupt-Pin ausgegeben werden.
FIFO: First-In-First-Out-Register, das den Datenstrom zwischenspeichern kann.
Konfigurationsregister: Sie können verschiedene interne Schaltkreise konfigurieren
Sensorregister: Datenregister, das die Daten jedes Sensors speichert.
Werkskalibriert: Dies bedeutet, dass die Sensoren im Inneren kalibriert sind.
Digitaler Bewegungsprozessor: Kurz DMP, ein Hardware-Algorithmus zur Lageberechnung, der im Chip enthalten ist. Er kann zur Lageberechnung mit der offiziellen DMP-Bibliothek verwendet werden.
FSYNC: Frame-Synchronisation.
3. 10-1 Software-I2C-Lesen und Schreiben von MPU6050
3.1 Hardware-Anschluss
Durch Software-I2C-Kommunikation können Sie die Register im MPU6050-Chip lesen und schreiben. Durch Lesen des Datenregisters können Sie die Daten des Plug-in-Moduls abrufen Die gelesenen Daten werden auf OLED angezeigt. Die obersten Daten sind die ID-Nummer des Geräts. Die ID-Nummer dieses MPU6050 ist auf 0x68 festgelegt. Unten sind die drei auf der linken Seite die Ausgangsdaten des Beschleunigungssensors, nämlich die Beschleunigung der X-Achse, der Y-Achse und der Z-Achse. Die drei auf der rechten Seite sind die Ausgangsdaten des Gyroskopsensors. Dies sind die Winkelgeschwindigkeiten der X-Achse, der Y-Achse und der Z-Achse. SCL ist mit dem PB10-Pin von STM32 verbunden und SDA ist mit dem PB11-Pin verbunden. Da hier das Software-Level-Flipping implementiert ist, können zwei GPIO-Ports beliebig verbunden werden.
3.2 Operationsergebnisse
3.3 Codefluss
STM32 ist der Host und MPU6050 ist der Slave, was einem Master-Slave-Modus entspricht.
Richten Sie die Module .c und .h der I2C-Kommunikationsschicht ein
Schreiben Sie die zugrunde liegende GPIO-Initialisierung von I2C
Basierend auf dem I2C-Kommunikationsmodul implementiert es das Lesen an der angegebenen Adresse, das Schreiben an der angegebenen Adresse, das Schreiben von Registern zum Konfigurieren des Chips und das Lesen der Register zum Erhalten von Sensordaten.
Haupt c
Rufen Sie das MPU6050-Modul auf, initialisieren Sie es, rufen Sie die Daten ab und zeigen Sie die Daten an
STM32 integriert eine Hardware-I2C-Transceiverschaltung, die automatisch Funktionen wie Taktgenerierung, Start- und Endbedingungsgenerierung, Übertragung und Empfang von Antwortbits sowie Datenübertragung und -empfang durch die Hardware ausführen kann, wodurch die Belastung der CPU verringert wird.
Unterstützt das Multi-Host-Modell
Unterstützt den 7-Bit/10-Bit-Adressmodus
Unterstützt verschiedene Kommunikationsgeschwindigkeiten, Standardgeschwindigkeit (bis zu 100 kHz), schnell (bis zu 400 kHz)
Unterstützen Sie DMA
Kompatibel mit dem SMBus-Protokoll
STM32F103C8T6 Hardware-I2C-Ressourcen: I2C1, I2C2
4.2 I2C-Blockdiagramm
Auf der linken Seite befinden sich die Kommunikationspins: SDA und SCL werden von SMBus verwendet; Die von allgemeinen Peripheriegeräten abgeleiteten Pins werden normalerweise über den Multiplexmodus des GPIO-Ports mit der Außenwelt verbunden (siehe Tabelle).
Das Obige ist der Datensteuerungsteil: SDA Der Kernteil der Datenübertragung und des Datenempfangs ist das Datenregister DR (DATA REGISTER) und das Datenschieberegister. Wenn Daten gesendet werden müssen, kann ein Datenbyte in das Datenregister DR geschrieben werden. Wenn das Schieberegister keine zu verschiebenden Daten hat, wird der Wert des Datenregisters weiter an das Schieberegister übertragen. Während des Schiebevorgangs können die nächsten Daten direkt im Datenregister abgelegt und abgewartet werden. Sobald die vorherige Datenverschiebung abgeschlossen ist, können die nächsten Daten nahtlos verbunden und weiterhin gesendet werden. Wenn Daten vom Datenregister zum Schieberegister übertragen werden, wird das TXE-Bit des Statusregisters auf 1 gesetzt, was anzeigt, dass das Senderegister leer ist.
Empfangen: Die Eingangsdaten werden Stück für Stück vom Pin zum Schieberegister verschoben. Wenn ein Datenbyte erfasst ist, werden die Daten als Ganzes vom Schieberegister zum Datenregister übertragen und das Flag RXNE wird gesetzt Gleichzeitig wird angezeigt, dass das Register nicht leer ist, dann können die Daten aus dem Datenregister ausgelesen werden. Für den Zeitpunkt des Empfangs und des Sendens müssen die entsprechenden Bits in das Steuerregister geschrieben werden. Die Startbedingungen, Beendigungsbedingungen, Antwortbits usw. werden durch die Datensteuerung vervollständigt.
Der Komparator und das Adressregister werden im Slave-Modus verwendet.
SCL: Die Taktsteuerung dient zur Steuerung der SCL-Leitung. Schreiben Sie das entsprechende Bit in das Taktsteuerregister, und die Schaltung führt die entsprechende Funktion aus. Steuerlogikschaltung: Durch Schreiben in das Steuerregister kann die gesamte Schaltung gesteuert werden. Der Betriebsstatus der Schaltung kann durch Lesen des Statusregisters ermittelt werden.
Beim Senden und Empfangen vieler Bytes kann DMA zur Effizienzsteigerung eingesetzt werden.
4.3 I2C-Grundstruktur
SDA: Da I2C zuerst hochrangig ist, verschiebt sich dieses Schieberegister nach links. Beim Senden wird zuerst das High-Bit herausgeschoben, dann das zweite High-Bit. Ein SCL-Takt wird einmal und achtmal verschoben, und auf der SDA-Leitung können 8 Bytes vom High-Bit zum Low-Bit platziert werden. Beim Empfang werden die Daten von rechts über den GPIO-Port eingezogen und schließlich achtmal ein Byte empfangen. Die Ausgabedaten werden über den GPIO-Port an den Port ausgegeben. Die Eingabedaten werden über den GPIO-Port in das Schieberegister eingegeben.
Der GPIO-Port muss für den Multiplex-Open-Drain-Ausgabemodus konfiguriert werden. Multiplexing bedeutet, dass der Status des GPIO-Ports durch On-Chip-Peripheriegeräte gesteuert wird und die Open-Drain-Ausgabe die vom I2C-Protokoll geforderte Portkonfiguration ist. Selbst im Open-Drain-Ausgabemodus kann der GPIO-Port eingegeben werden.
SCL: Der Taktcontroller steuert die Taktleitung über GPIO.
4.4 Host sendet
Wenn STM32 an eine bestimmte Adresse schreiben möchte, muss es dem Übertragungssequenzdiagramm des Senders folgen.
7-Bit-Adresse: Das eine Byte nach der Startbedingung wird adressiert
10-Bit-Adresse: Die beiden Bytes nach der Startbedingung sind die Adressierung. Das erste Byte ist der Frame-Header und der Inhalt ist das 5-Bit-Flag-Bit 11110 + 2-Bit-Adresse + 1 Lese-/Schreibbit Reine 8-Bit-Adresse.
Nach der Initialisierung wechselt der Bus standardmäßig in den Ruhezustand und STM in den Slave-Modus. Um eine Startbedingung zu generieren, muss STM32 in das Steuerregister (CR1) schreiben, 1 schreiben und dann wechselt STM32 vom Slave-Modus in den Master-Modus .
Das EV5-Ereignis kann als Flag-Bit betrachtet werden. SB ist ein Bit des Statusregisters, das den Status der Hardware anzeigt. SB=1 bedeutet, dass die Startbedingung gesendet wurde.
Anschließend können Sie ein Byte der Slave-Adresse in das Datenregister DR schreiben. Nach dem Schreiben in das DR überträgt die Hardwareschaltung das Adressbyte automatisch in das Schieberegister und überträgt dann das Wort Der Knoten an den I2C-Bus gesendet, und dann empfängt die Hardware automatisch die Antwort und beurteilt. Wenn keine Antwort erfolgt, setzt die Hardware das Antwortfehler-Flag, und dann kann das Flag einen Interrupt anfordern, um uns daran zu erinnern.
Wenn die Adressierung abgeschlossen ist, tritt das EV6-Ereignis auf und das ADDR-Flag-Bit ist 1. Dieses Flag-Bit zeigt das Ende der Adressübertragung im Master-Modus an.
Das EV8_1-Ereignis bedeutet, dass das TxE-Flag 1 ist, das Schieberegister leer ist und das Datenregister leer ist. Wir müssen in das Datenregister DR schreiben, um Daten nach DR zu senden, da das Schieberegister leer ist wechselt sofort zum Register zum Senden. Das EV8-Ereignis wird auftreten. Das Schieberegister ist nicht leer und das Datenregister ist leer, was bedeutet, dass das Schieberegister hier Daten 1 generiert. In diesem Moment werden die Daten 2 in das Datenregister geschrieben und warten darauf, dass die Datenbits zur Übertragung an das Schieberegister übertragen werden. Zu diesem Zeitpunkt ist das Schieberegister nicht leer Das Datenregister ist leer, daher ist der EV8-Vorfall zu diesem Zeitpunkt erneut aufgetreten.
Dann werden Daten 2 gesendet, aber dieses Mal wurden die nächsten Daten in das Datenregister geschrieben und warten. Sobald das EV8-Ereignis erkannt wird, können die nächsten Daten geschrieben werden.
Nachdem die Daten, die Sie senden möchten, geschrieben wurden, werden keine neuen Daten in das Datenregister geschrieben. Wenn die aktuelle Datenverschiebung im Schieberegister abgeschlossen ist, ist das Schieberegister leer und das Datenregister ist ebenfalls leer. EV8_2-Ereignis, TxE = 1 bedeutet, dass das Schieberegister leer ist, das Datenregister leer ist, BTF: Byte-Übertragungsende-Flag, wenn beim Senden neue Daten gesendet werden und das Datenregister nicht mit neuen Daten beschrieben wurde. Wenn EV8_2 erkannt wird, kann die Abbruchbedingung Stop generiert werden. Um eine Beendigungsbedingung zu erzeugen, müssen natürlich entsprechende Bits im Steuerregister vorhanden sein, die gesteuert werden können. Damit ist die Sendesequenz beendet.
Schreiben Sie zunächst das Startbit des Steuerregisters, um eine Startbedingung zu generieren, und warten Sie dann auf das EV5-Ereignis (das anzeigt, dass die Startbedingung gesendet wurde).
Nach der Adressierung wird die Antwort empfangen und nach dem Ende ein EV6-Ereignis generiert (das anzeigt, dass die Adressierung abgeschlossen ist).
Daten 1 bedeutet, dass Daten über das Schieberegister eingegeben werden.
EV6_1 zeigt an, dass die Daten noch verschoben werden. Nach dem Empfang der Antwort bedeutet dies, dass das Schieberegister ein Datenbyte erfolgreich verschoben hat. Zu diesem Zeitpunkt wird das verschobene Byte als Ganzes in das Datenregister übertragen Gleichzeitig wird das RxNE-Flag gesetzt, was darauf hinweist, dass das Datenregister nicht leer ist, d. h. ein Byte Daten empfangen wurde. Das Lesen des DR-Registers löscht das Ereignis dass die Daten empfangen wurden. Nachdem wir die Daten gelesen haben, gibt es kein Ereignis mehr.
Wenn Daten 1 nicht gelesen wurden, können Daten 2 natürlich direkt in das Schieberegister verschoben werden. Danach ist die Verschiebung von Daten 2 abgeschlossen, Daten 2 werden empfangen, ein EV7-Ereignis wird generiert, Daten 2 werden gelesen und Das EV7-Event ist weg.
Wenn kein Empfang mehr erforderlich ist, muss das Antwortbit-Steuerregister ACK vorab auf 0 gesetzt werden, wenn die letzte Zeiteinheit auftritt, und die Beendigungsbedingungsanforderung wird festgelegt, d. h. das Ereignis EV7_1. Danach erfolgt eine Nichtantwort-NA Da das STOP-Bit gesetzt ist, wird eine Beendigungsbedingung generiert.
5.2 Hardware-I2C-Lese- und Schreib-MPU6050-Implementierung
5.2.1 Hardware-Anschluss
SCL ist mit dem PB10-Pin von STM32 verbunden und SDA ist mit dem PB11-Pin verbunden. Da hier das Software-Level-Flipping implementiert ist, können zwei GPIO-Ports beliebig verbunden werden. Die obersten Daten von OLED sind die ID-Nummer des Geräts. Die ID-Nummer dieses MPU6050 ist auf 0x68 festgelegt. Unten sind die drei auf der linken Seite die Ausgangsdaten des Beschleunigungssensors, nämlich die Beschleunigung der X-Achse, der Y-Achse und der Z-Achse. Die drei auf der rechten Seite sind die Ausgangsdaten des Gyroskopsensors. Dies sind die Winkelgeschwindigkeiten der X-Achse, der Y-Achse und der Z-Achse.
5.2.2 Operationsergebnisse
5.2.3 Code-Implementierungsprozess
I2C-Peripheriegeräte konfigurieren, I2C-Peripheriegeräte initialisieren, MyI2C_Init ersetzen (1) Schalten Sie die Uhr des I2C-Peripheriegeräts und des entsprechenden GPIO-Ports ein. (2) Initialisieren Sie den GPIO-Port, der dem I2C-Peripheriegerät entspricht, für den Multiplex-Open-Drain-Modus (3) Verwenden Sie die Struktur, um den gesamten I2C zu konfigurieren (4) I2C_Cmd, I2C aktivieren
Steuern Sie periphere Schaltkreise, erkennen Sie den Zeitpunkt des Schreibens an bestimmte Adressen und ersetzen Sie WriteReg
Steuern Sie die Peripherieschaltung, um den Zeitpunkt des Lesens der angegebenen Adresse zu erkennen und ReadReg zu ersetzen