www.mikrocontroller.net

Forum: Hausbus Protokollfrage

Autor: Holger Gerwenat (Gast)
Datum: 29.01.2007 11:12

Hallo,

ich plane ein kleines projekt zur Hauswasser-Anlagen Steuerung. Ich habe
mich für den RS485 Bus entschieden. Später soll das Projekt dann
erweitert werden. Dabei werde ich zwar eine Haupteinheit haben, aber
auch Module, die nicht nur auf Anforderung senden werden. Ich habe mir
nun ein kleines Protokoll ausgedacht mit Startbyte Adressen Daten und
Checksumme. Ich dachte standardmäßig die Datenrichtung vom MAX485 auf
Empfang zu stellen also alle Teilnehmer horchen. Will nun ein Teilnehmer
Senden, wird auf Senden geschaltet, das Startbyte geschickt. Durch den
Empfang wird Senden bei allen anderen Modulen gesperrt. Was passiert
allerdings in der Zeitspanne zwischen dem Umschalten auf Sendebetrieb
und dem vollständigen Empfang des ersten Zeichens bei den anderen
Teilnehmern. Das dauert ja eine (kurze) Zeit. Wenn nun zufällig ein
anderes Modul auch was mitteilen will und auf Senden schaltet kommt es
doch zu einer Kollision. Wie fängt man sowas ab?


Danke!

Gruß Holger
Autor: A.K. (Gast)
Datum: 29.01.2007 11:26

Wenn zwei RS485 Transceiver gleichzeitig senden, ist das Signal auf dem
Bus undefiniert. Das kann jeder Transceiver anders verstehen, das kann
auch abhängig von seiner Position im Strang sein.

Bei Multimaster-RS485 mit RS485-Transceivern besteht die Aufgabe also
darin, diesen Zustand von vorneherein zu vermeiden, z.B. mit token
passing.

Steht RS485 als Protokoll unverrückbar fest, bleibt als Ausweg die
Verwendung von CAN-Bus-Transceivern, da diese bei einer Kollision ein
klar definiertes Verhalten haben.
Autor: Rahul, der Trollige (Gast)
Datum: 29.01.2007 11:29

Wie wäre es gleich mit CAN?
Das erfordert zwar etwas mehr Hardware (CAN-Controller), dafür muß man
sich aber nicht um Kollisionen auf dem kümmern...

>Wie fängt man sowas ab?
Indem man konstant auf dem Bus mithorcht und seine gesendeten Daten
wieder empfängt. Sowas geht allerdings nur richtig gut mit
CAN-Transceivern, da die besser darauf ausgelegt sind (reine
RS485-Transceiver sind u.U. zu niederohnimg beim Senden).
Wenn die Daten, die man auf den Bus gelegt hat, nicht das gleich
Aussehen haben, wie die, die man empfangen hat, schaltet man zurück auf
Empfang.
Autor: Holger Gerwenat (Gast)
Datum: 29.01.2007 12:16

Unverrückbar....

sollte gar nix sein. Ich hab nur keine Ahnung von CAN Bus, bin glücklich
daß ich in C den AVR so programmieren kann, daß die UART funktioniert
und habe mich für den 485 Bus entschieden, weil ich ja dann einfach 'nen
MAX485 an die  AVR UART klemmen kann und alles ist chic. Muss ich halt
doch mal gucken, wie CAN Bus funktioniert....

Danke für die Antworten!

Gruß Holger
Autor: Rahul, der Trollige (Gast)
Datum: 29.01.2007 12:26

>Muss ich halt doch mal gucken, wie CAN Bus funktioniert....

Du kannst auch einen PCA82C250 als RS485-Transceiver benutzen und die
Sendedaten gleichzeitig empfangen und vergleichen.
Autor: A.K. (Gast)
Datum: 29.01.2007 12:31

Daumenregel: Single-Master => RS485, Multi-Master => CAN. Das ist nicht
zwingend, aber seit CAN günstig zu kriegen ist, lohnt sich der
Software-Aufwand für Arbitrierung eigentlich nicht mehr. Ist auch eine
Sache der Zuverlässigkeit, eine Arbitrierung wirklich zuverlässig
hinzukriegen ist nicht trivial. Bei CAN haben andere Leute dieses
Problem schon für einen erledigt.
Autor: der mechatroniker (Gast)
Datum: 29.01.2007 12:33

Der entscheidende Kniff bei CAN-Transceivern ist, daß diese beim Senden
recht hochohmig auf High (Pullup) und recht niederohmig auf Low
(Transistor) ziehen. Dadurch ist der Buspegel bei Kollisionen immer
definiert, nämlich Low. Ein CAN-Transceiver schaltet sich ab, wenn er
beim High-Senden ein Low zurückliest -> Kollisionsvermeidung.
Autor: A.K. (Gast)
Datum: 29.01.2007 12:39

Nicht der Transceiver sondern der Controller kontrolliert das.
Autor: Rainer (Gast)
Datum: 29.01.2007 12:43

Wie wär's denn mit LIN.
Da kannst du auch deine UART verwenden (mit etwas Modifikation siehe
Atmel Applikation Note). Dein Master frägt zyklisch jeden slave ab und
du hast immer eine definierte Zeit wie und wann welcher slave was sagen
darf.
Ich will auch gerade anfangen den Code aus dem App Note auf den Mega32
zu übertragen um mich an einem Hausinstallationsbus zu probieren.
Autor: Rahul, der Trollige (Gast)
Datum: 29.01.2007 13:21

>Nicht der Transceiver sondern der Controller kontrolliert das.

Das Abschalten, aber nicht die Hochohmigkeit (Impedanz müsste das
heissen, oder?) des Busses.
Autor: Joerg (Gast)
Datum: 29.01.2007 13:29

ich stehe auch gerade vor der selben Aufgabe... habe mehrere devices
über UART und CAN-Treiber Bausteine verbunden.

Habe gerade folgendes gefunden:
http://ulan.sourceforge.net/index.php

vielleicht auch für dich interessant.
Autor: Holger Gerwenat (Gast)
Datum: 01.02.2007 09:50

Danke sehr für Eure Antworten!

Es kristallisiert sich also raus: UART und Can Bus Treiberbausteine! OK.


@Joerg

klingt seeeehr interessant. Und das mit meinen miserablen
Englischkenntnissen. Werde mal versuchen mich durchzubeißen.


Gruß Holger
Autor: Holger Gerwenat (Gast)
Datum: 01.02.2007 09:51

Entschuldigung!

@Rainer: Auch LIN werde ich mir anschauen.

Gruß Holger
Autor: Champus (Gast)
Datum: 13.02.2007 22:01

hi,

na na na.
wer wird denn da wieder aufgeben wollen in sachen RS485? ich stand vor
einem aehnlichen problem rs485 oder can. ich habe mich vorlaeufig klar
fuer rs485 entschieden.
die hardwarekosten bei rs485 sind ohne bedeutung. lediglich die
protokoll-definition ist nicht ganz ohne. das stichwort fuer
multi-masterbetrieb lautet csma/cd. das netz ist voll davon mit genauen
bechreibungen. das selber zu programmieren ist nicht ganz ohne, macht
aber echt spass, wenn es denn laeuft.

das ist kein statement gegen can!
Autor: Besenstil (Gast)
Datum: 13.02.2007 23:24

CAN ist nur geeignet fuer ultrakuze Meldungen. Was Laengeres zu senden
ist eher sehr muehsam damit.

B
Autor: Rahul, der Trollige (Gast)
Datum: 14.02.2007 09:05

>CAN ist nur geeignet fuer ultrakuze Meldungen. Was Laengeres zu senden
>ist eher sehr muehsam damit.

Willst du etwa Video über CAN streamen?
Es gibt ja auch schon diverse Protokolle, die auf CAN aufbauen. Sowas
sollte sich benutzen lassen.
Autor: Dirk (Gast)
Datum: 14.02.2007 20:46

>Willst du etwa Video über CAN streamen?

Falls ja solltest du auf den MOST Bus aufsetzen. Ein relativ simpler
Baustein ist der OS8104.
Autor: Gast (Gast)
Datum: 16.02.2007 15:24

Man kann zur Erkennung einer Kollision im Bus einen 1,2 Ohm Widerstand
in die Spannungszuführung des RS485 Bausteins hängen. Mit einem
Komparator kann man dann erkennen, wieviel Strom der Baustein zieht.
Kommt es zu einer Kollision, wird der Baustein der eine 1 senden will
höheren Strom ziehen, was den Komparator zuschlagen lässt.
Autor: MC (Gast)
Datum: 14.05.2008 01:21

Tag an alle,
wollter mal fragen, welche Erfahrungen die Zeit und etwas
Experimentieren mit sich gebracht haben.

Antwort schreiben

Die Angabe einer Email-Adresse ist freiwillig. Wenn Sie automatisch per Email über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Suchfunktion und Betreffsuche benutzen - vielleicht gibt es schon einen ähnlichen Beitrag
  • Aussagekräftigen Betreff wählen
  • Im Betreff angeben um welchen Controllertyp es geht (AVR, PIC, ...)
  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang
  • JPEG-Dateien (.jpg) nur für Fotos und Scans verwenden
  • Schaltpläne, Screenshots usw. als PNG oder GIF anhängen

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [pre]vorformatierter Text (z.B. Code in anderen Sprachen)[/pre]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel





Hinweis: der Originalbeitrag ist mehr als 6 Monate alt.

webmaster@mikrocontroller.netImpressumWerbung auf Mikrocontroller.net