Hi
I think that I have found two problems with this port:
1.
See the following code in RESTORE_CONTEXT macro:
LDMFD LR, {R0-R14}^
NOP
LDR LR, [LR, #+60]
It seems that the first line corrupts the LR value used by the third one as R14==LR.
It should be:
LDMFD LR, {R0-R13}^
2. The WDG_IRQHandler calls vTaskSwitchContext for preemption. But this call only finds the next TCB without switching the context. Thus no preemption occures.
If I’m correct, what is the solution for the second problem?
>It seems that the first line corrupts the LR value used by the third one as R14==LR.
No - the system mode lr at this point is being used as a pseudo stack pointer. If you make the change as you suggest then the lr will not be saved. It is the user mode lr that is being saved.
>The WDG_IRQHandler calls vTaskSwitchContext for preemption. But this call only finds the next TCB without switching the >context. Thus no preemption occurs.