Forum: Digitale Signalverarbeitung / DSP / Machine Learning Fehlerhafte Simulation von Gleitkomma


von Christian (Gast)


Lesenswert?

Hallo,

ich habe Probleme, Programme, die Gleitkomma-Instruktionen enthalten,
für meinen TriCore DSP zu simulieren. Zur Erzeugung des Codes nutze
ich den Compiler tricore-gcc.
Anbei der zu simulierende C-Code:

int main( void )
{
  float a = 10.5;
  float b = 20.62;
  float c = a + b;

  return 0;
}

Daraus erzeugt der tricore-gcc folgenden Assembler-Code, wenn man ihn
mit dem Parameter "-mhard-float" zwingt, echte Gleitkomma-Befehle
(und nicht Software-Routineaufrufe) zu erzeugen.

...
movh    %d1, 16680
        st.w    [%a10] 12, %d1
        movh    %d1, 16805
        addi    %d1, %d1, -2621
        st.w    [%a10] 8, %d1
        ld.w    %d15, [%a10] 12
        ld.w    %d0, [%a10] 8
        add.f   %d15, %d15, %d0
        st.w    [%a10] 4, %d15
...

Wenn ich nun aus dem o.g. Assembler-Code ein binary mache und es dann
mit tricore-gdb versuche zu simulieren, entsteht folgendes Problem:
Nach dem Ausführen der letzten Load-Instruktion
"ld.w    %d0, [%a10] 8" (also vor dem add.f) wird automatisch eine
neue Routine aufgerufen:

0xa0000140 <__clear_dword>:     st.d [%a15+]8,%e14
0xa0000144 <__clear_dword+4>:   loop %a2,0xa0000140 <__clear_dword>

Diese kann aber nie abgeschlossen werden, weil einige Register bisher
nicht initisiert wurden. Wenn ich tricore-gdb mit "cont" fortfahren
lasse, wird in einer Endlosschleife folgende Fehlermeldung ausgege-
ben:

Trap: FCU- btv_reg:a0000100, handler_size:5, pc_reg: a0000160

Kann sich jemand von Euch vorstellen, warum die Simulation nicht
klappt?

Danke.

Gruß,
Christian

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.