- MultiPlus Wechselrichter Insel und Nulleinspeisung Conrad         
Ergebnis 1 bis 9 von 9

Thema: Drehimpulsgeber schiesst ATmega644 ab

  1. #1
    Erfahrener Benutzer Robotik Einstein Avatar von Jaecko
    Registriert seit
    16.10.2006
    Ort
    Lkr. Rottal/Inn
    Alter
    42
    Beiträge
    2.009

    Drehimpulsgeber schiesst ATmega644 ab

    Anzeige

    Praxistest und DIY Projekte
    Moin.

    Hab nach langer Zeit mal wieder ein elektr(on)isches Problem mit einem AVR, Kategorie "Kopfnuss aus Granit".
    Schaltung: http://cihome.de/forendaten/rn/tr_schaltplan.png

    ATMega644 mit 16MHz, soll als Temperaturregler für eine bestimmte Apparatur dienen; soll temperaturabhängig 2 Heizungen/Motor für Rührgerät steuern. Die Bedienung erfolgt über ein 128x64-LCD (KS0108-Controller) und 2 Drehimpulsgeber mit Tastfunktion. Und genau an einem dieser Impulsgeber bzw. den Pins, an denen der angeschlossen ist, gibt es ein Problem. An den VCC/GND-Pin-Paaren des AVR sind direkt noch weitere 100nF-Kerkos gelötet (nicht im Schaltplan eingezeichnet)

    Betroffen ist Encoder 1; an PD2 (INT0) ist einer der beiden Signalpins des Encoders angeschlossen. Auf eine fallende Flanke hin wird ein Interrupt ausgelöst, in dem ich mir dann PD0 anschau und in Abhängigkeit des Pegels die Drehrichtung weiss.

    Dreh ich in die eine Richtung, scheint alles ok zu sein. Dreh ich jedoch in die andere Richtung, startet mit fast jedem Schritt des Impulsgebers der AVR neu.

    Erste Vermutung: Irgendas stimmt mit den Interrupts nicht, falsch konfiguriert, irgend ein Überlauf etc. Darum hab ich das ganze auf nen minimalen Code gestaucht (s.u.), der nix anderes macht, als den an PB4 angeschlossenen Buzzer mal kurz "klicken" zu lassen. D.h. jeden Neustart des AVR krieg ich durch einen Klick mit.

    Code:
    int main(void)
    {
      PORTB &=~ (1 << 4);
      DDRB  |=  (1 << 4);  
    
      PORTB |=  (1 << 4);
      _delay_ms(2);
      PORTB &=~  (1 << 4);
    
      while(1);
      return 0;
    }
    Dreh ich in die eine Richtung: stille.
    Dreh ich in die andere Richtung: *tickticktickticktick*, also ständige Neustarts bei so gut wie jedem Drehschritt.

    Encoder 2 (PD1/PD3) funktioniert perfekt. Auch wenn ich die beiden Encoder umstecke, bleibt das Problem bei dem, der an PD0/PD2 angeschlossen ist.

    Auch der Verdacht, dass evtl. der Quarz gestört wird, dessen Pins ja direkt daneben verlaufen, haben sich als nicht ganz zutreffend erwiesen. Ich kann zwar am Oszi sehen, dass beim Drehen des Encoders XTAL2 kurz mit der Spannung leicht hochgeht. Aber auch, wenn ich auf den internen Taktgeber mit 8 MHz umschalte, (und auch den Quarz auslöte) bleibt dieses Problem bestehen.
    Ansonsten kann ich mit dem Oszi keine weiteren Spannungseinbrüche o.ä. sehen.
    Auch die Art der Spannungsversorgung spielt keine Rolle. Sowohl über ein 12V-Netzteli über den 7805, als auch direkt versorgt über ISP gibts das Problem.

    Gibts da beim M644 irgendwas bestimmtes zu beachten? Oder weiss jemand, was das sonst für ein Problem sein könnte?

    MfG
    Geändert von Jaecko (18.01.2016 um 16:32 Uhr) Grund: Typos gefixt
    #ifndef MfG
    #define MfG

  2. #2
    Erfahrener Benutzer Roboter Genie
    Registriert seit
    07.04.2015
    Beiträge
    899
    Kann eigentlich nur der Reset oder die BOD-Fuse sein, wenn die Versorgung i.O. ist.
    (1k am Reset finde ich "knapp")

  3. #3
    Erfahrener Benutzer Robotik Einstein Avatar von Jaecko
    Registriert seit
    16.10.2006
    Ort
    Lkr. Rottal/Inn
    Alter
    42
    Beiträge
    2.009
    Thx, das mit dem BOD scheints tatsächlich gewesen zu sein. War auf 4,3V gesetzt. Habs jetzt auf 2,7V runter; ich dreh mir grad nen Wolf und bisher tickt nichts.
    Aber da wunderts mich etwas, warum das dann nur bei Encoder 1 hackt und beim 2er nicht.
    Das mit den 1k am Reset mach ich eigentlich "schon immer" so, da gabs bisher eigentlich nie Probleme, solange man nicht direkt mitm Finger auf die Resetleitung langt.

    MfG
    #ifndef MfG
    #define MfG

  4. #4
    Erfahrener Benutzer Roboter Genie
    Registriert seit
    07.04.2015
    Beiträge
    899
    Das tut aber nicht not. Du hängst einen Kondensator dran, der Dir Spikes auf dem Reset filtert und lutschst Ihn über den 1k- Widerstand gleich wieder leer. Übliche Werte sind 4.7..10k.

    Noch eine Anmerkung: Deine Entprellung schaltet den gesamten Strom in den Kondensatoren auf die Masse kurz, wenn die Encoder schließen???!!!???
    Vielleicht ist das die eigentliche Ursache des Problems.
    Geändert von Holomino (18.01.2016 um 17:53 Uhr)

  5. #5
    Erfahrener Benutzer Robotik Visionär Avatar von oberallgeier
    Registriert seit
    01.09.2007
    Ort
    Oberallgäu
    Beiträge
    8.687
    .. BOD scheints tatsächlich gewesen zu sein. War auf 4,3V gesetzt. Habs jetzt auf 2,7V runter; ich dreh mir grad nen Wolf und bisher tickt nichts ..
    Also mir wäre das ein sicherer Hinweis darauf, dass die Controllerspannung kurzzeitig gestört ist. Siehe Datenblatt ATmega164A/164PA/324A/324PA/644A/644PA/1284/1284P (Atmel-8272G-AVR-01/2015), Seite 326, 28.4 System and reset characteristics: .. tRST Minimum pulse width on RESET Pin 2.5 μs .. Wobei das (grübel - wenn ich mich nicht irre) 40 (vierzig) Controllertakte bei Deiner Quarzrate wären. Das hätte Dein Oskar doch eigentlich anzeigen müssen - und die 2.5 μs sind ja aussagegemäß das Minimum *kopfschüttel*.
    Ciao sagt der JoeamBerg

  6. #6
    Erfahrener Benutzer Robotik Einstein Avatar von Jaecko
    Registriert seit
    16.10.2006
    Ort
    Lkr. Rottal/Inn
    Alter
    42
    Beiträge
    2.009
    Leider zu früh gefreut (zumindest teilweise). Ne halbe Stunde ca. gings und jetzt gehts wieder los. Gleiches Problem wie oben, sogar bei BOD = 1,8V. Hab auch mal den Reset-Widerstand etwas erhöht (5,6k), ebenfalls keine Änderung. Das Oszi würde sogar bis 40MHz/25ns gehen. Hab auch grad nochmal nachgemessen; der Spannungsregler spuckt hinten 4,95V aus, schön glatt; da hätte der BOD (wenns der gewesen wäre) ja noch garnicht triggern dürfen. Auch direkt in der Nähe des AVR ist nichts zu sehen, wenn gedreht wird. Reset ist auch sauber.

    Ich hab jetzt mal spontan den AVR gegen einen 644P getauscht, den ich schnell aus nem anderen Projekt gepflückt hab. Da gehts dann. 644 (ohne P) wieder rein: tickticktick.
    Hab jetzt gut 5-6x den AVR hin und hergetauscht, mit immer dem gleichen Ergebnis: Mit dem 644er scheints das Problem zu geben, mit dem 644P nicht. Scheint so, als hätt ich nen AVR erwischt, der scheinbar ab Werk schon nen kleinen Schlag hat (ist ja jetzt vermutlich nicht unbedingt auszuschliessen).

    Ich werd das jetzt mal weiter beobachten, ob das Problem beim 644P tatsächlich weg bleibt oder sich auch nach und nach wieder reinschleicht.

    MfG
    #ifndef MfG
    #define MfG

  7. #7
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    07.03.2011
    Beiträge
    1.899
    Etwaige Störungen oder Spannungseinbrüche sind manchmal nicht so leicht zu messen. Was wirklich zählt, ist die Spannung direkt am Die, am Silizium. Dort läßt sich so einfach nichts messen. Das nächstbeste ist direkt am Baustein, aber mit beiden Anschlüssen des Scopes. Störungen können auch über die Masse kommen. Aber auch Stromstöße über Portpins können intern einen Reset auslösen.

    Zitat Zitat von Holomino Beitrag anzeigen
    Noch eine Anmerkung: Deine Entprellung schaltet den gesamten Strom in den Kondensatoren auf die Masse kurz, wenn die Encoder schließen???!!!???
    100nf sind schon eine ganze Menge. Sie machen das Signal auch so langsam, daß es lange im verbotenen Bereich des Eingangs bleibt. Das kann zum Schwingen des Eingangs führen. Solange Prozessor und Encoder auf dem selben Board sind, gehören da gar keine Kondensatoren hin.

    Ein zweites Problem ist die Verwendung eines Flankeninterrupts. Wenn das Signal prellt, und das könnte z.B. von der Drehrichtung abhängen, wird ein Interruptsturm ausgelöst, auch das kann zum Absturz führen.

    Ein brauchbare Lösung ist das regelmäßige Abfragen der Encoderleitungen. das Prinzip ist hier beschrieben. Wenn man sowieso einen Timertick hat, und den braucht man eigentlich immer, sind das nur ein paar Zeilen Code. Das ist das gleiche Prinzip, daß die Hardwaredecoder, die manche Prozessoren eingebaut haben, auch verwenden.

    MfG Klebwax
    Strom fließt auch durch krumme Drähte !

  8. #8
    Erfahrener Benutzer Roboter Genie
    Registriert seit
    03.09.2009
    Ort
    Berlin (Mariendorf)
    Beiträge
    1.023
    Such mal bei Pollin nach panasonic eveq.
    Das Datenblatt, Seite 2, zeigt eine Beschaltung des Encoders mit Kondensatoren und Widerständen. Die 10nF-Kondensatoren werden dort über Widerstände von den Encoder-Schaltkontakten entladen statt kurzgeschlossen. Das hat vermutlich nicht nur mit der Lebensdauer zu tun.
    So ganz ohne Dämpfung ist vielleicht auch nicht perfekt. Ich vermute, dass Kontakte auch beim gleiten springen/prellen können, wenngleich wesentlich kurzzeitiger.

  9. #9
    Erfahrener Benutzer Roboter Genie Avatar von Michael
    Registriert seit
    17.01.2004
    Ort
    Karlstadt
    Alter
    55
    Beiträge
    1.258
    Die 10nF-Kondensatoren werden dort über Widerstände von den Encoder-Schaltkontakten entladen statt kurzgeschlossen. Das hat vermutlich nicht nur mit der Lebensdauer zu tun.
    richtig, so und nicht anders wird es gemacht.
    Die Schaltung nach Beitrag #1 ist, gelinde gesagt, Murks.
    Die Kontakte verbrennen und die Versorgung leidet unter Spikes, das Ergebnis ist ja bekannt.

    Gruß, Michael

Ähnliche Themen

  1. Drehimpulsgeber
    Von Bumbum im Forum C - Programmierung (GCC u.a.)
    Antworten: 35
    Letzter Beitrag: 05.10.2009, 19:34
  2. Drehimpulsgeber Selbstbau
    Von -FX- im Forum Mechanik
    Antworten: 7
    Letzter Beitrag: 27.05.2009, 17:24
  3. Schaltungsaufbau mit Drehimpulsgeber
    Von 1hdsquad im Forum Elektronik
    Antworten: 5
    Letzter Beitrag: 25.05.2006, 14:28
  4. Problem mit Drehimpulsgeber
    Von nover im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 1
    Letzter Beitrag: 15.04.2006, 20:17
  5. Drehimpulsgeber mit 8051
    Von Marten83 im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 5
    Letzter Beitrag: 29.06.2005, 13:03

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

Solar Speicher und Akkus Tests