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> C Quellcode formatieren: <code>Quellcode</code> BASIC Quellcode formatieren: <basic>Quellcode</basic> (Innerhalb eines Quellcodeabschnitts ist kein html möglich.) Wichtig: Bitte mache Zeilenumbrüche, bevor Du am rechten Rand des Eingabefeldes ankommst ! -> I > > > > > hallo > > > > > das problem besteht darin, dass die interruptroutine keine abfrage (if, switch usw.) > > > > > oder einen Unterprogrammaufruf verträgt. > > > > > > > > Hi, das mag Dir so erscheinen ist aber nicht so. If's etc. funktionieren In IRQ Routinen, sonst > > > > würde die ganze DCF Library nicht funkionieren. > > > > > > > > > sobald ich in die unten angeführte interruptroutine ein if einbaue verabschiedet sich der prozessor. > > > > > > > > > > void Timer3_ISR(void) > > > > > { > > > > > x[a]=Timer_T3GetPM(); > > > > > Irq_GetCount(INT_TIM3CAPT); // Interrupt zurücksetzen > > > > > } > > > > > > > > > > will man nun ein signal mit unterschiedlichen Pulslängen messen, funktioniert das nur > > > > > wenn man im hauptprogamm ein while (x[a]==0; einbaut und anschließend die Messung > > > > > wieder startet (Bemerkung: ist aber nicht sinn eines interrupts, wenn man wartet bis der interrupt > > > > > abgearbeitet ist) > > > > > > > > Man sollte immer! im Interrupt nur das nötigste erledigen, und den Rest im normalen Programm > > > > verarbeiten. Dabei erlaubt der Interpreter seinen IRQ Routinen viel mehr, als eine wirkliche > > > > CPU durchgehen liesse. > > > > > > > > Gruss Peter > > > > > > > > > oder man lässt den code durchrasseln und macht immer wieder eine abfrage -> dann übersieht man > > > > > irgendwann einen puls, wenn der codedurchlauf zu lange wird. > > > > > gibts hier eine lösung? > > > > > > > > > > gruß > > > > > josef > > > > > > :-( -> schwache antwort > > > > Nein, denn das ist eine Verhaltensregel, und keine Erklärung von Fehlern. Eine laufende Interrupt- > > routine blockiert das Multithreading und andere Interrupts. Deshalb ist es normalerweise unklug, > > zuviel in einer IRQ Routine zu erledigen. > > > > > ich glaube nicht, wenn man eine if x[a]>0 m++; Abfrage in die interruptroutine einbaut, das eine lange ist. > > > beim 10msec interrupt -> DCF 77 programm werden auch unterprogrogramme in der interruptroutine > > > ausgeführt und es funktioniert. > > > warum genau beim timer 3 nicht? > > > > Ich kann Dir versichern, das es keinen Unterschied in der Abarbeitung von 10msec IRQs oder Timer3 > > IRQs gibt. Ich muß es eigentlich wissen, denn ich habe es implementiert. Es gibt aber wie oft, > > auch andere Faktoren. Wie lang sind eigentlich die Impulse, die Du messen willst? Wäre es möglich, > > das Deine Programmlogik durcheinanderkommt, wenn die Impulse kürzer sind, als die Abarbeitung > > der IRQ Routine? Da ich Dein Hauptprogramm nicht kenne, ist das natürlich nur eine von mehreren > > möglichen Hypothesen. > > > > Gruss Peter > > > > > gruß josef > > hallo Peter > > habe aufgrund deiner ausführungen ein setup durchgeführt und siehe da alles das wie oben beschrieben > funktioniert. der UTI Baustein auch 3Stück mit je 3 PT1000 werden einwandfrei abgearbeitet. > > danke für deine Hilfe > gruß josef > wenn es erwünscht ist könnte ich das Projekt als Beispiel zur verfügug stellen. > > noch zwei fragen > wird es bei der definition von der seriellen in zukunft auch 9 Datenbits zu definieren geben? > und kann man die Ports, die auf ausgang geschaltet sind abfragen auf deren zustand?