- MultiPlus Wechselrichter Insel und Nulleinspeisung Conrad         
Ergebnis 1 bis 10 von 12

Thema: C++ Macht Atmega16 Kaputt?

Hybrid-Darstellung

Vorheriger Beitrag Vorheriger Beitrag   Nächster Beitrag Nächster Beitrag
  1. #1
    Erfahrener Benutzer Roboter-Spezialist Avatar von schorsch_76
    Registriert seit
    25.03.2012
    Ort
    Kurz vor Neuschwanstein
    Alter
    48
    Beiträge
    456
    C++ macht den Atmega sicher nicht kaputt Ich selbst nutze auf dem Atmega C++ und er steuert meine Heizung

    Das Problem liegt eher Richtung Fusebits/Takt/Quarz.
    Siehe bsp. https://www.roboternetz.de/community...hlight=Verfust

    Es ist auch möglich das deine IRQs so häufig auftreten, das der µC auf nichts mehr reagiert. Ich hatte so ein ähnliches Problem. Das IRQ Handling bei meinem I2C war nicht richtig und der IRQ hat alles lahm gelegt.

  2. #2
    Erfahrener Benutzer Roboter Genie
    Registriert seit
    02.11.2005
    Alter
    49
    Beiträge
    1.146
    Interessant wäre jetzt, die Unterschiede des C-Progamms und des C++-Programms zu sehen.

    Abgesehen davon - es macht nicht viel Sinn Klassen zu benutzen, wenn man keine Objekte erstellt... dann kann man auch bei C bleiben.

    Gruß,
    askazo

  3. #3
    Erfahrener Benutzer Robotik Einstein Avatar von wkrug
    Registriert seit
    17.08.2006
    Ort
    Dietfurt
    Beiträge
    2.242
    Hast Du noch andere Chips auf den Programmierpins MISO MOSI SCK angeschlossen?
    Ich hatte das Problem auch schon mal.
    Die Fusebits verstellten sich während des Programmiervorganges, weil der angeschlossene Chip Bits auf die Leitungen gegeben hat.
    Das hatte dann zur Folge, das sich immer wieder mal die Takteinstellungen geändert haben und der Controller somit keinen gültigen Takt mehr hatte.
    Dadurch war dann auch kein ISP mehr möglich.
    Mit externem Takt konnte ich die Fuses dann wieder umstellen.
    Nachdem der Reset Pin des angeschlossenen Chips per Pulldown Widerstand aktiviert wurde ( der externe Chip also abgeschaltet war), trat das Problem nie mehr auf.
    Absteckbare Jumper könnten auch ne Lösung sein.
    Poste doch bitte mal den Schaltplan deiner Entwicklung.

  4. #4
    Erfahrener Benutzer Roboter-Spezialist
    Registriert seit
    22.09.2009
    Ort
    Geilenkirchen
    Beiträge
    419
    Hi!
    Danke, für die Antworten!

    Ich denke, das wird das Problem sein.
    Ein Schaltplan ist nicht nötig (existiert auch nur in meinem Kopf), es ist einfach ein Atmega16 mit MSP2515 über SPI, Textdisplay, UART, Taster und Piezo mit Transistor, also nichts wildes.
    Habe einen MCP2515 über SPI dran.
    Da werde ich mal den Reset pin über nen Jumper auf Low legen, während des Programmierens.
    Kann das aber erst morgen ausprobieren, ich werde dann davon berichten.

    mfg
    Olaf

  5. #5
    Erfahrener Benutzer Roboter-Spezialist
    Registriert seit
    22.09.2009
    Ort
    Geilenkirchen
    Beiträge
    419
    Mahlzeit!

    Ich habe den Reset Pin vom MCP2515 per Jumper auf low gelegt, das brachte keine Besserung, selbst wenn ich das IC komplett entferne habe ich immer noch das gleiche Problem.
    Ich denke auch, dass es an den Fusebits liegt.
    Aber irgendwie muss man ja verhindern können, dass die gesetzt werden.
    Das ergibt einfach keinen Sinn, dass die gesetzt werden.

    Im Moment habe ich keine Anwendung für Objekte, da ich nur ein paar Funktionen zum Senden und Empfangen habe.
    Erst wenn das Projekt größer wird, brauche ich Objekte.
    Daher verwende ich C++.

    mfg
    Olaf

  6. #6
    Erfahrener Benutzer Roboter-Spezialist Avatar von schorsch_76
    Registriert seit
    25.03.2012
    Ort
    Kurz vor Neuschwanstein
    Alter
    48
    Beiträge
    456
    Wenn nichts anderes an den Pins hängt, wird es ziemlich sicher eine IRQ Geschichte sein die dir dann den Atmega lahm legt.

    mach einfach ein "Hello LED blink" Programm mit c++ und lass das laufen. Dann langsam schritt für Schritt die IRQ geschichte rein. Hier ist mit SPI/I2C wirklich ganz enorm wichtig das die Schritte zur Behandlung des IRQ richtig sind.

    Das mit dem IRQ: Auch wenn du keine Hardware am Pin drann hast, schiebt bei SPI das Schieberegister Daten "raus" und löst IRQs aus.
    Geändert von schorsch_76 (23.06.2015 um 08:00 Uhr)

  7. #7
    Erfahrener Benutzer Robotik Einstein Avatar von wkrug
    Registriert seit
    17.08.2006
    Ort
    Dietfurt
    Beiträge
    2.242
    Das mit dem IRQ: Auch wenn du keine Hardware am Pin drann hast, schiebt bei SPI das Schieberegister Daten "raus" und löst IRQs aus.
    Das ist im Prinzip schon richtig.
    Allerdings wird während des Programmierens mittels ISP der Reset Pin an GND gelegt, der Controller selber also Lahm gelegt.
    Nur wenn das nicht sicher klappt könnte da was reinspucken.

Ähnliche Themen

  1. [ERLEDIGT] RP6 Kaputt ??
    Von Mr.Deepbass im Forum Robby RP6
    Antworten: 17
    Letzter Beitrag: 24.05.2012, 11:39
  2. LCD kaputt?
    Von skyscater im Forum Elektronik
    Antworten: 34
    Letzter Beitrag: 12.01.2012, 00:03
  3. [ERLEDIGT] RN-Control macht komische Piepstöne. - Kaputt??
    Von robonooby im Forum Schaltungen und Boards der Projektseite Mikrocontroller-Elektronik.de
    Antworten: 19
    Letzter Beitrag: 28.10.2011, 12:01
  4. Atmega16 macht nicht was er soll.....
    Von Pollin im Forum Assembler-Programmierung
    Antworten: 4
    Letzter Beitrag: 28.01.2007, 14:22
  5. mc kaputt?
    Von pat88 im Forum AVR Hardwarethemen
    Antworten: 2
    Letzter Beitrag: 28.03.2005, 14:45

Berechtigungen

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

12V Akku bauen