Hello all,
I found something a little odd with delay slot scheduling. If i had the following bit of code (Note that "get" builtin functions in picochip stand for port communication)

int mytest ()
{
 int a[5];
 int i;
 for (i = 0; i < 5; i++)
 {
   a[i] = (int) getctrlIn();
 }
 switch (a[3])
 {
   case 0:
       return 4;
   default:
       return 13;
 }
}

The relevant bit of assembly for this compiled at -Os is

_L2:
       GET 0,R[5:4]    // R[5:4] := PORT(0)
_picoMark_LBE5=
_picoMark_LBE4=
       .loc 1 13 0
       STW R4,(R3)0            // Mem((R3)0{byte}) := R4
       ADD.0 R3,2,R3   // R3 := R3 + 2 (HI)
       .loc 1 11 0
       SUB.0 R3,R2,r15 // CC := (R3!=R2)
       BNE _L2
       =->     LDW (FP)3,R5            // R5 = Mem((FP)6{byte})
       .loc 1 22 0

=-> is the delay slot marker. Note that the LDW instruction has been moved into the delay slot. This corresponds to the load in "switch (a[3]" statement above. The first 3 times around this loop, LDW would be loading uninitialised memory. The loaded value is ignored until we come out of the loop and hence the code is functionally correct, but i am not sure introduction of uninitialised memory access by the compiler when there was none in the source is good.

I browsed around the delay branch code in reorg.c, but couldn't find anything that checks for this. Is this the intended behaviour? Can anyone familiar with delay branch code help?

Thanks
Hari

Reply via email to