Zur Übersicht - INFO - Neueste 50 Beiträge - Neuer Beitrag - Suchen - FAQ - Zum CC1-Forum - Zum CC-Pro-Forum

Wichtig: Bevor Du wegen einem Problem mit der CC2 postest, stelle sicher, daß Du
die neueste OS-Version, die neuseste Compiler-DLL und die neuesten Modulversionen benutzt!
Beachte, daß sich auf der CD zur CC2-Unit/Station auch jetzt noch die ältesten Dateien befinden!
Es gelten folgende Anleitung und Regeln: Regeln CC2Net.de-Forum
Zurück zum Artikel  (Blaue Felder sind Pflichtfelder)


Name:   UserID: 
 E-Mail:
Kategorie
Betreff
Homepage:
Link-Titel:
Link-URL:
Cookie für Name, UserID, E-Mail, Homepage-URL setzen
(Erspart die Neueingabe bei Beiträgen und Antworten)
(Zum Löschen des Cookies hier klicken)
Ich nutze:
C-Control II Unit
C164CI-Controllerboard
C-Control II Station
CCRP5 mit CC2-Unit (Conrad Roboter)
CC2-Application-Board
CC2-StarterBoard
CC2-ReglerBoard
eigenes Board
original OS     OSOPT_V2     OSOPT V3.0 OSOPT V3.1

Kommentar:
Einfügen von HTML im Kommentar:

Link einfügen: <a href="LINKURL" target="_blank">LINKTITEL</a>
Bild einfügen: <img src="BILDURL">
Text formatieren: <b>fetter Text</b>  <i>kursiver Text</i> <u>unterstrichener Text</u>
Kombinationen sind auch möglich z.B.: <b><i>fetter & kursiver Text</i></b>
C2 Quellcode formatieren: <code>Quellcode</code>
ASM Quellcode formatieren: <asm>Quellcode</asm>
(Innerhalb eines Quellcodeabschnitts ist kein html möglich.)
Wichtig: Bitte mache Zeilenumbrüche, bevor Du am rechten Rand des Eingabefeldes ankommst !  

> Ralf, > so ganz kann ich deine Argumentation mit dem wann muss ich wie > globale varibalen bei multithreading schützen nicht nachvollziehen. > > Im Conrad Handbuch ist die Probelmatik bei Multithreading doch wunderbar (und richtig) erläutert > • Aliasing von Speicherzugriffen > • Konkurrenz mehrerer Prozesse um eine Ressource > > Weiter unten im Handbuch steht dann wie capture und release funktionieren. > Damit gilt (zumindest unter original OS und OSOPT_V2) > > "Die capture-Anweisung existiert in einer expliziten und einer impliziten Form. Die > explizite Form erwartet die Angabe eines Bezeichners einer globalen (!) byte-Variable." > > ... mein tipp nur die explizite benutzen, die implizite ist nicht so gut nachvollziehbar und spart > weder speicher noch rechenzeit.... > > "Beim Ausführen der capture-Anweisung testet der aktuelle Thread, ob der Wert der > Variablen 0 ist (= “Freizeichen”). Wenn ja, dann schreibt der Thread seine eigene Nummer > (Wert 1 … 255) in die Variable und merkt sich die Adresse der byte-Variable. Wie > bereits erwähnt, dieser Vorgang läuft atomar, in einer einzigen Operation der virtuellen > Maschine ab." > > So, und damit ist dann wohl auch klar das nur ein schützen von Lese oder Schreibzugriffen > auf globale Variablen NICHT ausreicht. Im Multithreading müssen, sofern ein schreibender thread > exisitert, ALLE also sowohl Schreib- als auch Lesezugriffe mit capture/release geschützt werden !! > > Ansonsten kann genau der Fall eintreten den Ralf unten beschreibt... > > > hat z.B Thread xy gerade in Byte 3 und Byte 2 der Variable einen Teil > > vom neuen Wert eingetragen und dann wird umgeschaltet auf Thread z. Von Thread z wird gerade > > jetzt die Variable gelesen, und schon existiert ein Wert, den es so gar nicht geben dürfte. > > und wie jemand anders gesagt hat irgend wann wird der Fall auch eintreten ! > > Wenn man dieses nicht tut braucht man sich nicht über die Langzeitstabilität wundern und > auch keine Hardware tauschen... > > Übrigens betreibe ich eine Haussteuerung mit ca. 60 I/O ports 2 externen LCD display, diverser > Zusatzhardware. Die Software ist voll multithreaded, arbeitet mit Interrupts von den MAX7311 > und PCF chips und ist sehr flexibel und erweiterbar entworfen. Die volle Ausbaustufe habe ich noch nicht > erreicht aber die CC2Station läuft seit fast 2 Jahren (ich hatte damals eine der ersten) ohne Probleme oder > undeterministschem Verhalten. Allerdings auch im Keller, wo immer ca. 15 Grad Temp sind. > Inzwischen bin ich sehr zuversichtlich was die Langzeitstabilität der Hardware und des OS angeht. > > Olaf > > > > > Hallo Frank > > > > ( sun ist eine globale long-Variable ) > > capture glob.cFlag; > > glob.sun = 0; > > release; > > > > Nach einem capture muß mit release das Multitasking so schnell wie möglich wieder frei gegeben > > werden. > > Dieses Verfahren ist erforderlich, wenn über globale Variablen Daten zwischen Threads ausgetauscht > > werden. Wenn es möglich ist, dass zwei Threads gleichzeitig auf die Variable zugreifen, einer zum > > lesen, der andere zum schreiben, dann tun sie das auch irgend wann mal, das ist sicher. > > Bei so einem Fehler hat z.B Thread xy gerade in Byte 3 und Byte 2 der Variable einen Teil > > vom neuen Wert eingetragen und dann wird umgeschaltet auf Thread z. Von Thread z wird gerade > > jetzt die Variable gelesen, und schon existiert ein Wert, den es so gar nicht geben dürfte. > > > > Eins von beiden muß dann geschützt werden: Die Lese- oder die Schreibzugriffe. Man wird > > die Schreibzugriffe schützen, wenn sie von verschiedenen Threads ausgeführt werden und/oder > > wenn die Zahl der Lesezugriffe größer ist als die der Schreibzugriffe. Nur wenn von einem Thread > > relativ wenig Lesezugriffe erfolgen und viele Schreibzugriffe in EINEM Thread (nacheinander) > > ausgeführt werden, wird man den/die Lesezugriffe schützen. > > > > Bei Hardwarezugriffen ist es ähnlich (wenn die Treiber nicht schon gecapturet sind, da muss Du > > Dir die Funktionen mal genau ansehen). > > > > Beim Fehlersuchen kannst Du capture/release ruhig verstreuen wie Salz. Noch besser ist: Andere > > Threads erstmal abzuschalten um zu gucken, was passiert dann. > > > > Viele Grüße > > Ralf > > > > > > > > > Hallo Ralf! > > > > > > Vielleicht löst das ja auch mein Problem, wäre zu schön um wahr zu sein. Du hast wirklich jeden > > > Zugriff auf eine globale Variable geschützt? Könntest Du mir vielleicht mal Auszüge Deines > > > Programms zeigen? Würd mich mal interessieren, wie die das nun genau gemacht hast? Will ja nun > > > auch keine capture/release verstreuen wie das Salz in der Suppe. > > > > > > Besten Dank im Voraus, > > > Frank
Dateianhang: (.gif, .png., .jpg, .zip, .rar)
max. 256kB
max. 256kB