It just keeps running that function over and over again. And no other task will get executed anymore.
It usually happens when the Rx buffer has overflowed. However, in the same interrupt, before i get the data, I check if an overflow has occurred. And if it does, i just discard the the data and clear the overflow stat bit.
The most of the UART code is based on the example supplied in the demo. I do not set/read any variable during the interrupt. I only send a queue using the correct interrupt routine provided for it.
I notice that the error occurs much less when i remove the following function:
You don’t say which port you are using. Not all the ports allow interrupt nesting, so that might be what the problem is.
The idle task is meant to sit in a loop if there are no other tasks that can run so the problem seems to be that none of your other tasks are wanting to do anything.
Interrupts above kernel priority are not allowed to call freeRTOS routines, so I suspect you are corrupting some system data.
When freeRTOS is manipulating critical data, is enters a critical section which disables interrupts of kernel level and below so nothing else will try and adjust the data area while it is being updated. If an interrupt above kernel level calls an RTOS routine, it may manipulate that area that is in the middle of being manipulated and mess it up.
Richard,
Your documentation says that for ports that support configMAX_SYSCALL_INTERRUPT_PRIORITY, then that is the highest level interrupt that can call the FromISR routines, and that those ports support not disabling all interrupts when in a critical section.
That is correct. Interrupts at priority level configMAX_SYSCALL_INTERRUPT_PRIORITY and below can call API functions that end in "FromISR". Interrupts that are above that priority cannot call any API functions. API functions that do not end if "FromISR" must not be called from any interrupts.
Sorry if I’m not being clear - its been a long day.
Its difficult to answer definitively without knowing the port being used.
And these are the only function call’s that are used in the interrupt:
cChar = ReadUART2(); // used to get the data from the Rx buffer
xQueueSendFromISR( xRxedChars, &cChar, &xHigherPriorityTaskWoken );
mU2RXClearIntFlag();
The first and last functions are predefined by microchip.
Looks like I made an error myself. Yesterday, MPLab crashed. And when i reopened the program it opens the last opened project as usual.
At the moment I have to almost similar devices and code, so i didn’t see that MPLab opened the other project instead of the correct one. And i forgot to check it. And just programmed it. So the problems above are not that strange, since it was for another device. Sorry guys!
However, with the correct code, there was almost the same error. And it happened too when i integrated the uart2 Rx interrupt.
But that didn’t come so frequently as with the wrong code I used above (so that’s had me wondering today that it just might be the wrong code ).
For the moment, I just discovered one error with might be just it.
With the demo code supplied with the OS, errors from the UART are not monitored (like, overflow/parity/framing error).
So when one of the errors occurs, the UART-error interrupt flag get set. This will cause that no other Rx interrupts will happen anymore until this flag, including the [ OERR: Receive Buffer Overrun Error Status bit ] get cleared.
There is nothing obviously wrong there, assuming ReadUART2() returns immediately with the register data and does not attempt to poll until data is available.
Are you defining the interrupt with the asm wrapper as per the example in the FreeRTOS download?
Richard,
Indeed I`m using the interrupt wrapper from the example.
Still the problem does exist. The OS doesn’t run anymore any task. Looks like it will randomly stall in a task after some interrupts happened from the UART2 (even when there is no error with the UART, i checked the SFR’s), it just keeps running and running and no switch to another task will happen anymore.
So I`m still looking for an error in the UART2 interrupt. My next move is to be sure that the microchip supplied functions like ReadUART2(); do not stall to wait for data.
Richard,
Indeed I`m using the interrupt wrapper from the example.
Still the problem does exist. The OS doesn’t run anymore any task. Looks like it will randomly stall in a task after some interrupts happened from the UART2 (even when there is no error with the UART, i checked the SFR’s), it just keeps running and running and no switch to another task will happen anymore.
So I`m still looking for an error in the UART2 interrupt. My next move is to be sure that the microchip supplied functions like ReadUART2(); do not stall to wait for data.