Warnings in tasks.c 5.4.1 IAR
I receive the following warnings in tasks.c in freertos 5.4.1 in IAR arm 5.20 for cortex-m3:
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 611
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 617
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 672
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 678
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 1551
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 1593
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 1598
Warning[Pa082]: undefined behavior: the order of volatile accesses is undefined in this statement freeRTOStasks.c 1970
While these warnings seem to have no ill effects, our internal coding standard prohibits having any warnings in our code. Any thoughts on the proper way to resolve these warnings?
Warnings in tasks.c 5.4.1 IAR
The warning is quite correct, but as far as I recall from inspection, also quite benign. It comes from trying to support lots of different compilers, all of which generate warnings in different and sometimes contradictory ways.
You could try casting away the volatile from one or other side of the statement.
I will take a look at the code lines again to see what can be done. In the provided demos I think you will find the warning is just switched off.
Regards.
Warnings in tasks.c 5.4.1 IAR
I ended up satisfying this warning by forcing the order in which these variables were accessed:
xList xlXList;
xListItem xliXListItem;
…
if( xTimeToWake < xTickCount )
{
/* Wake time has overflowed. Place this item in the
overflow list. */
xlXList = *((xList *) pxOverflowDelayedTaskList);
xliXListItem = *((xListItem *) &( pxCurrentTCB->xGenericListItem ));
vListInsert( &xlXList, &xliXListItem);
}
else
{
/* The wake time has not overflowed, so we can use the
current block list. */
xlXList = *((xList *) pxDelayedTaskList);
xliXListItem = *((xListItem *) &( pxCurrentTCB->xGenericListItem ));
vListInsert( &xlXList, &xliXListItem);
} wouldn’t this be ‘better’ than just turning off the warning?
xListItem xliXListItem;
…
if( xTimeToWake < xTickCount )
{
/* Wake time has overflowed. Place this item in the
overflow list. */
xlXList = *((xList *) pxOverflowDelayedTaskList);
xliXListItem = *((xListItem *) &( pxCurrentTCB->xGenericListItem ));
vListInsert( &xlXList, &xliXListItem);
}
else
{
/* The wake time has not overflowed, so we can use the
current block list. */
xlXList = *((xList *) pxDelayedTaskList);
xliXListItem = *((xListItem *) &( pxCurrentTCB->xGenericListItem ));
vListInsert( &xlXList, &xliXListItem);
} wouldn’t this be ‘better’ than just turning off the warning?