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

Thema: Programm springt immer wieder in Init

Hybrid-Darstellung

Vorheriger Beitrag Vorheriger Beitrag   Nächster Beitrag Nächster Beitrag
  1. #1

    Programm springt immer wieder in Init

    Hallo

    Ich hätte eine kleine Frage und zwar hab ich folgendes Programm bei dem mit der Zeit die Pulsbreite von Timer2 erhöht werden soll:


    Code:
    #include <avr/io.h>
    #include <avr/interrupt.h>
    
    //Funktionsdeklaration
    void init();
    void init_timer0();
    void init_timer2();
    
    //Timer0:
    #define T0_TEILER64	TCCR0|=0x03;TCCR0 &=0xFB
    #define T0_NORMAL	TCCR0&=0x87
    #define T0_RESET	TCNT0=0
    #define T0_OVL_INT	TIMSK|=0x01;SREG|=0x80
    
    //Timer2:
    #define T2_INT_OVL_ENABLE	TIMSK|=0x40;SREG|=0x80
    #define T2_FAST_PWM_EIN		TCCR2&=0x00;TCCR2|=0x68
    #define T2_PULSBREITE		        OCR2
    #define T2_TEILER_1			TCCR2&=0xF8;TCCR2|=0x07
    
    int main()//
    {
    	//Initialisierung der Baugruppen)
    	init();
    	init_timer0();
    	init_timer2();
    	// Hintergrundschleife bzw. Hintergrundprozess
    	do
    	{
    		
    	}
    	while(1);	
    	
    
    	return 0;
    }
    
    void init()
    {
    	DDRA &=0x00;
    	//PB5 als Ausgang konfigurieren
    	DDRD |=0xFF; 
    }
    
    void init_timer0()
    {
    	//Normalbetrieb einstellen
    	T0_NORMAL;
    	//Teiler (64) einstellen
    	T0_TEILER64;
    	//Zählerstand Reset
    	T0_RESET;
    	//Interrupt freischalten (Überlaufinterrupt freischalten)
    	T0_OVL_INT;	
    }
    
    void init_timer2()
    {
    	// PWM-Betrieb einstellen
    	T2_FAST_PWM_EIN;
    	// Pulsbreite auf 0 einstellen
    	T2_PULSBREITE = 0;
    	// Maximale Frequenz - Teiler
    	T2_TEILER_1;
    	// Overflow Interrupt freigeben
    	T2_INT_OVL_ENABLE;
    }
    
    //ISR für Timer0 Überlauf (alle 2ms)
    ISR(TIMER0_OVF_vect)
    {
    	static unsigned char zaehler=0;
    
    	zaehler ++;
    	
            if(zaehler >= 49)//ca alle 98ms
            {
    		zaehler = 0;
    		if(T2_PULSBREITE<=250)
    		{
    			
    			T2_PULSBREITE += 5;
    		}
    	}	
    }


    Das Problem ist das wenn die Variable zaehler den Wert 16 erreicht das Programm wieder zu init springt und dann wieder init_timer0 und init_timer2 durchläuft und das ganze wieder von vorne beginnt.

    Vielleicht weiß jemand wo da der Fehler liegt!

    Ich bin totaler Anfänger und weiß auch nicht ob ich hier in diesem Forum mit dieser Frage richtig bin...

    Aber ich würde mich über die Lösung des Problems freuen!!!
    Geändert von radbruch (15.02.2012 um 06:38 Uhr) Grund: Code-Tag eingefügt und Thread nach C verschoben

  2. #2
    Erfahrener Benutzer Roboter Experte Avatar von Thomas E.
    Registriert seit
    29.12.2011
    Beiträge
    638
    Sollte das nicht in die Abteilung für C?
    Grüße
    Thomas

  3. #3
    Erfahrener Benutzer Roboter Experte Avatar von ePyx
    Registriert seit
    14.05.2008
    Ort
    Falkensee
    Beiträge
    700
    Füge mal die ISR für Timer 2 ein. Ist die nicht vorhanden läuft das Programm ab der Sprungadresse des IRQ weiter und geht ohne reti ( das macht unter anderem der ISR-Block) nicht zurück sondern läuft weiter. Etwas weiter oben im Speicher liegt deine Init und wird ausgeführt.

    Zitat Zitat von Thomas E. Beitrag anzeigen
    Sollte das nicht in die Abteilung für C?
    Ja.
    Geändert von ePyx (15.02.2012 um 05:56 Uhr)
    Grüße,
    Daniel

  4. #4
    Erfahrener Benutzer Roboter-Spezialist
    Registriert seit
    01.10.2009
    Beiträge
    437
    Zitat Zitat von ePyx Beitrag anzeigen
    läuft das Programm ab der Sprungadresse des IRQ weiter und geht ohne reti ( das macht unter anderem der ISR-Block) nicht zurück sondern läuft weiter.
    Es ist zwar richtig, dass der TO die ISR vergessen hat, aber so wie Du das beschreibst funktioniert das in der Regel nicht.

    Das Verhalten des Programms würde zufällig werden, wenn ein nicht definierter Interrupt wild im Speicher läuft, deshalb werden alle Interrupts ohne ISR auf einen Fehlervektor umgeleitet, welcher dann selbst wieder auf den Resetvektor umleitet. Der µC bekommt also 'nen SW-reset und das ist der Grund, warum die Init's erneut ausgeführt werden.

    Findest Du hier unter default Interrupt:
    http://www.rn-wissen.de/index.php/Av...ault_Interrupt

    Bei anderen C-Compilern dürfte das nicht viel anders sein.

  5. #5
    Erfahrener Benutzer Roboter Experte Avatar von ePyx
    Registriert seit
    14.05.2008
    Ort
    Falkensee
    Beiträge
    700
    Kann nur aus meiner Erfahrung heraus antworten und diese lautet, ISR vergessen -> Dauerreset. Was auch recht lustig ist, wenn man durch die uneinheitlichen Bezeichnungen den falschen Interruptvektor nimmt, da man das Programm von einem µC auf einen anderen portiert hat.

    Das mit dem reti beruhte auf Halbwissen und habe ich mir aus der Vorstellung eines ASM-Listing zusammengereimt. Was ohne den __default_interrupt__ auch stimmt.
    Grüße,
    Daniel

  6. #6
    Erfahrener Benutzer Roboter-Spezialist
    Registriert seit
    01.10.2009
    Beiträge
    437
    Zitat Zitat von ePyx Beitrag anzeigen
    aus der Vorstellung eines ASM-Listing zusammengereimt. Was ohne den __default_interrupt__ auch stimmt.
    Nein, ohne Einbinden eines eigenen Default-Vektors sieht's aus wie unten dargestellt.
    Die undefinierten Interruptvektoren gehen standardmäßig auf einen Punkt zusammen, an diesem Punkt würde bei selbst definiertem Bad-Interrupthandler der Weitersprung darauf erfolgen, ansonsten geht's (wie im Listing) auf den Resetvektor. Mit RETI hat das nix zu tun.
    Code:
    L0000:
        jmp    __start    ; L002A
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
         jmp    L0047
    ; L002A:
    ; ... startup code
        call L0049
        jmp L03C5
     L0047:
        jmp    L0000
    ; main    
     L0049:
    ; ...
    L03C5:
        cli
    L03C6:
        rjmp    L03C6

Ähnliche Themen

  1. switch-Anweisung springt immer zum selben case X Befehl
    Von HF SHOOTER im Forum C - Programmierung (GCC u.a.)
    Antworten: 3
    Letzter Beitrag: 05.11.2007, 19:06
  2. immer wieder pwm tiny45
    Von meldano im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 1
    Letzter Beitrag: 23.04.2007, 02:23
  3. Immer wieder - Labornetzteil...
    Von Vaterssohn im Forum Elektronik
    Antworten: 2
    Letzter Beitrag: 15.11.2006, 21:47
  4. Immer wieder....I2C Bus
    Von JensB im Forum Elektronik
    Antworten: 1
    Letzter Beitrag: 16.09.2004, 16:26
  5. [ERLEDIGT] Immer wieder LCD Probleme
    Von Bruce im Forum Robby CCRP5
    Antworten: 7
    Letzter Beitrag: 03.08.2004, 12:26

Berechtigungen

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

fchao-Sinus-Wechselrichter AliExpress