Forum: Digitale Signalverarbeitung / DSP / Machine Learning schleife wird ungewollt verlassen


von Andi (Gast)


Lesenswert?

Hallo zusammen!

Habe folgendes Problem bei meinem TI F2812 DSP
mein Programm sieht grob gesagt folgendermaßen aus:

void main()
{
puts("start")
while(TRUE)
{
 puts("prozess")
}
}

Eigentlich sollte einmal 'start' ausgegeben werden, endlos gefolgt von 
'prozess'.
Bei mir schaut die Ausgabe allerdings so aus, dass einmal 'start' 
ausgegeben wird und dann nach 13 mal prozess, woraufhin das programm 
wieder bei der main funktion beginnt, start ausgiebt, anschließend 13 
mal prozess usw.
Woran liegt das? Konnte in anderen Beiträgen nichts finden, außer dass 
ich die Vermutung habe, dass es etwas mit Interrupts zu tun hat. Aber 
wie steuer ich diese auf einem DSP?

Über Antworten würde ich mich riesig freuen!
Viele Grüße
Andi

von Kai G. (runtimeterror)


Lesenswert?

Ich kenne deine Architektur nicht, aber wenn puts() Daten in einen 
Buffer ablegt und dann sofort zurückkehrt, kann es sein, dass der Buffer 
überläuft -> Stack kaputt -> Reset

Vielleicht musst du ihm zum Senden einfach etwas mehr Zeit geben.

Nur so eine Idee.

von Martin L. (melvin_the_moose)


Lesenswert?

Ich kenne mich mit DSPs nicht im Speziellen aus.

Aber mir fällt noch ein:

-Evtl. ist ein Watchdog aktiviert, der nicht bedient wird?
-Interrupts "enabled", die zuschlagen und für die keine ISR angelegt ist 
(somit Sprung ins Nirvana oder "unimplemented Opcade Trap")?

von Michael K. (Gast)


Lesenswert?

Ich tippe auch auf den Watchdog.

Benutzt du die Example-Header-Files von TI?
Falls ja: rufst du die InitSysCtrl auf? Dort wird nämlich der Watchdog 
deaktiviert.

Ich schätze dein Programm schafft es 13mal prozess auszugeben bevor der 
WD auslöst...

von Andi (Gast)


Lesenswert?

wow, danke für die zahlreichen und schnellen antworten!!

wenn ich die ausgabe verkürze(z.B. 'sta' und 'pro'), schafft er mehr 
ausgaben, bevor der reset stattfindet -> könnte am watchdog liegen.
wollte versuchen den Watchdog zu reseten mit WDKEY = 0x55 und 
anschließend WDKEY = 0xAA.
Welche Datei muss ich einbinden, damit der Compiler nicht meckert bei 
WDKEY?
Mein Target ist ein TMS320F2812.

Bis jetzt hab ich folgende Dateien eingebunden: stdio.h, volume.h (aus 
dem Code Composer Tutorial; definiert einige wenige variablen aber keine 
Register oder so)

von Kai G. (runtimeterror)


Lesenswert?

Füg mal ne Verzögerung ein. Wenn der dann mehr schafft, liegt's 
wahrscheinlich am Puffer, wenn der weniger schafft am Watchdog oder an 
'nem anderen Timeout.

von Michael K. (Gast)


Lesenswert?

Benutzt du die Example-Header-Files von TI?

Falls nein: die erleichtern dir so einiges...

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.