mirror of
https://github.com/FreeRTOS/FreeRTOS-Kernel.git
synced 2025-04-19 21:11:57 -04:00
Fix cmake example errors (#1037)
Add typecasts to prevent compiler warnings. Remove ULL suffix to adhere to C90.
This commit is contained in:
parent
e143832ad4
commit
bbc058967b
|
@ -1,5 +1,4 @@
|
||||||
cmake_minimum_required(VERSION 3.15)
|
cmake_minimum_required(VERSION 3.15)
|
||||||
|
|
||||||
project(example)
|
project(example)
|
||||||
|
|
||||||
set(FREERTOS_KERNEL_PATH "../../")
|
set(FREERTOS_KERNEL_PATH "../../")
|
||||||
|
@ -71,3 +70,5 @@ add_executable(${PROJECT_NAME}
|
||||||
)
|
)
|
||||||
|
|
||||||
target_link_libraries(${PROJECT_NAME} freertos_kernel freertos_config)
|
target_link_libraries(${PROJECT_NAME} freertos_kernel freertos_config)
|
||||||
|
|
||||||
|
set_property(TARGET freertos_kernel PROPERTY C_STANDARD 90)
|
|
@ -40,20 +40,20 @@
|
||||||
* item value. It is important they don't clash with the
|
* item value. It is important they don't clash with the
|
||||||
* taskEVENT_LIST_ITEM_VALUE_IN_USE definition. */
|
* taskEVENT_LIST_ITEM_VALUE_IN_USE definition. */
|
||||||
#if ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_16_BITS )
|
#if ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_16_BITS )
|
||||||
#define eventCLEAR_EVENTS_ON_EXIT_BIT ( ( uint16_t ) 0x0100U )
|
#define eventCLEAR_EVENTS_ON_EXIT_BIT ( ( uint16_t ) 0x0100 )
|
||||||
#define eventUNBLOCKED_DUE_TO_BIT_SET ( ( uint16_t ) 0x0200U )
|
#define eventUNBLOCKED_DUE_TO_BIT_SET ( ( uint16_t ) 0x0200 )
|
||||||
#define eventWAIT_FOR_ALL_BITS ( ( uint16_t ) 0x0400U )
|
#define eventWAIT_FOR_ALL_BITS ( ( uint16_t ) 0x0400 )
|
||||||
#define eventEVENT_BITS_CONTROL_BYTES ( ( uint16_t ) 0xff00U )
|
#define eventEVENT_BITS_CONTROL_BYTES ( ( uint16_t ) 0xff00 )
|
||||||
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_32_BITS )
|
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_32_BITS )
|
||||||
#define eventCLEAR_EVENTS_ON_EXIT_BIT ( ( uint32_t ) 0x01000000UL )
|
#define eventCLEAR_EVENTS_ON_EXIT_BIT ( ( uint32_t ) 0x01000000 )
|
||||||
#define eventUNBLOCKED_DUE_TO_BIT_SET ( ( uint32_t ) 0x02000000UL )
|
#define eventUNBLOCKED_DUE_TO_BIT_SET ( ( uint32_t ) 0x02000000 )
|
||||||
#define eventWAIT_FOR_ALL_BITS ( ( uint32_t ) 0x04000000UL )
|
#define eventWAIT_FOR_ALL_BITS ( ( uint32_t ) 0x04000000 )
|
||||||
#define eventEVENT_BITS_CONTROL_BYTES ( ( uint32_t ) 0xff000000UL )
|
#define eventEVENT_BITS_CONTROL_BYTES ( ( uint32_t ) 0xff000000 )
|
||||||
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_64_BITS )
|
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_64_BITS )
|
||||||
#define eventCLEAR_EVENTS_ON_EXIT_BIT ( ( uint64_t ) 0x0100000000000000ULL )
|
#define eventCLEAR_EVENTS_ON_EXIT_BIT ( ( uint64_t ) 0x0100000000000000 )
|
||||||
#define eventUNBLOCKED_DUE_TO_BIT_SET ( ( uint64_t ) 0x0200000000000000ULL )
|
#define eventUNBLOCKED_DUE_TO_BIT_SET ( ( uint64_t ) 0x0200000000000000 )
|
||||||
#define eventWAIT_FOR_ALL_BITS ( ( uint64_t ) 0x0400000000000000ULL )
|
#define eventWAIT_FOR_ALL_BITS ( ( uint64_t ) 0x0400000000000000 )
|
||||||
#define eventEVENT_BITS_CONTROL_BYTES ( ( uint64_t ) 0xff00000000000000ULL )
|
#define eventEVENT_BITS_CONTROL_BYTES ( ( uint64_t ) 0xff00000000000000 )
|
||||||
#endif /* if ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_16_BITS ) */
|
#endif /* if ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_16_BITS ) */
|
||||||
|
|
||||||
/* *INDENT-OFF* */
|
/* *INDENT-OFF* */
|
||||||
|
|
|
@ -322,19 +322,19 @@ typedef struct xLIST
|
||||||
#define listREMOVE_ITEM( pxItemToRemove ) \
|
#define listREMOVE_ITEM( pxItemToRemove ) \
|
||||||
do { \
|
do { \
|
||||||
/* The list item knows which list it is in. Obtain the list from the list \
|
/* The list item knows which list it is in. Obtain the list from the list \
|
||||||
* item. */ \
|
* item. */ \
|
||||||
List_t * const pxList = ( pxItemToRemove )->pxContainer; \
|
List_t * const pxList = ( pxItemToRemove )->pxContainer; \
|
||||||
\
|
\
|
||||||
( pxItemToRemove )->pxNext->pxPrevious = ( pxItemToRemove )->pxPrevious; \
|
( pxItemToRemove )->pxNext->pxPrevious = ( pxItemToRemove )->pxPrevious; \
|
||||||
( pxItemToRemove )->pxPrevious->pxNext = ( pxItemToRemove )->pxNext; \
|
( pxItemToRemove )->pxPrevious->pxNext = ( pxItemToRemove )->pxNext; \
|
||||||
/* Make sure the index is left pointing to a valid item. */ \
|
/* Make sure the index is left pointing to a valid item. */ \
|
||||||
if( pxList->pxIndex == ( pxItemToRemove ) ) \
|
if( pxList->pxIndex == ( pxItemToRemove ) ) \
|
||||||
{ \
|
{ \
|
||||||
pxList->pxIndex = ( pxItemToRemove )->pxPrevious; \
|
pxList->pxIndex = ( pxItemToRemove )->pxPrevious; \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
( pxItemToRemove )->pxContainer = NULL; \
|
( pxItemToRemove )->pxContainer = NULL; \
|
||||||
( ( pxList )->uxNumberOfItems ) -= ( UBaseType_t ) 1U; \
|
( ( pxList )->uxNumberOfItems ) = ( UBaseType_t ) ( ( ( pxList )->uxNumberOfItems ) - 1U ); \
|
||||||
} while( 0 )
|
} while( 0 )
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -371,17 +371,17 @@ typedef struct xLIST
|
||||||
\
|
\
|
||||||
/* Insert a new list item into ( pxList ), but rather than sort the list, \
|
/* Insert a new list item into ( pxList ), but rather than sort the list, \
|
||||||
* makes the new list item the last item to be removed by a call to \
|
* makes the new list item the last item to be removed by a call to \
|
||||||
* listGET_OWNER_OF_NEXT_ENTRY(). */ \
|
* listGET_OWNER_OF_NEXT_ENTRY(). */ \
|
||||||
( pxNewListItem )->pxNext = pxIndex; \
|
( pxNewListItem )->pxNext = pxIndex; \
|
||||||
( pxNewListItem )->pxPrevious = pxIndex->pxPrevious; \
|
( pxNewListItem )->pxPrevious = pxIndex->pxPrevious; \
|
||||||
\
|
\
|
||||||
pxIndex->pxPrevious->pxNext = ( pxNewListItem ); \
|
pxIndex->pxPrevious->pxNext = ( pxNewListItem ); \
|
||||||
pxIndex->pxPrevious = ( pxNewListItem ); \
|
pxIndex->pxPrevious = ( pxNewListItem ); \
|
||||||
\
|
\
|
||||||
/* Remember which list the item is in. */ \
|
/* Remember which list the item is in. */ \
|
||||||
( pxNewListItem )->pxContainer = ( pxList ); \
|
( pxNewListItem )->pxContainer = ( pxList ); \
|
||||||
\
|
\
|
||||||
( ( pxList )->uxNumberOfItems ) += ( UBaseType_t ) 1U; \
|
( ( pxList )->uxNumberOfItems ) = ( UBaseType_t ) ( ( ( pxList )->uxNumberOfItems ) + 1U ); \
|
||||||
} while( 0 )
|
} while( 0 )
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
6
list.c
6
list.c
|
@ -130,7 +130,7 @@ void vListInsertEnd( List_t * const pxList,
|
||||||
/* Remember which list the item is in. */
|
/* Remember which list the item is in. */
|
||||||
pxNewListItem->pxContainer = pxList;
|
pxNewListItem->pxContainer = pxList;
|
||||||
|
|
||||||
( pxList->uxNumberOfItems ) += ( UBaseType_t ) 1U;
|
( pxList->uxNumberOfItems ) = ( UBaseType_t ) ( pxList->uxNumberOfItems + 1U );
|
||||||
|
|
||||||
traceRETURN_vListInsertEnd();
|
traceRETURN_vListInsertEnd();
|
||||||
}
|
}
|
||||||
|
@ -205,7 +205,7 @@ void vListInsert( List_t * const pxList,
|
||||||
* item later. */
|
* item later. */
|
||||||
pxNewListItem->pxContainer = pxList;
|
pxNewListItem->pxContainer = pxList;
|
||||||
|
|
||||||
( pxList->uxNumberOfItems ) += ( UBaseType_t ) 1U;
|
( pxList->uxNumberOfItems ) = ( UBaseType_t ) ( pxList->uxNumberOfItems + 1U );
|
||||||
|
|
||||||
traceRETURN_vListInsert();
|
traceRETURN_vListInsert();
|
||||||
}
|
}
|
||||||
|
@ -237,7 +237,7 @@ UBaseType_t uxListRemove( ListItem_t * const pxItemToRemove )
|
||||||
}
|
}
|
||||||
|
|
||||||
pxItemToRemove->pxContainer = NULL;
|
pxItemToRemove->pxContainer = NULL;
|
||||||
( pxList->uxNumberOfItems ) -= ( UBaseType_t ) 1U;
|
( pxList->uxNumberOfItems ) = ( UBaseType_t ) ( pxList->uxNumberOfItems - 1U );
|
||||||
|
|
||||||
traceRETURN_uxListRemove( pxList->uxNumberOfItems );
|
traceRETURN_uxListRemove( pxList->uxNumberOfItems );
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ typedef unsigned char UBaseType_t;
|
||||||
#define portMAX_DELAY ( TickType_t ) 0xffffffffUL
|
#define portMAX_DELAY ( TickType_t ) 0xffffffffUL
|
||||||
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_64_BITS )
|
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_64_BITS )
|
||||||
typedef uint64_t TickType_t;
|
typedef uint64_t TickType_t;
|
||||||
#define portMAX_DELAY ( TickType_t ) 0xffffffffffffffffULL
|
#define portMAX_DELAY ( TickType_t ) 0xffffffffffffffff
|
||||||
#else
|
#else
|
||||||
#error configTICK_TYPE_WIDTH_IN_BITS set to unsupported tick type width.
|
#error configTICK_TYPE_WIDTH_IN_BITS set to unsupported tick type width.
|
||||||
#endif
|
#endif
|
||||||
|
|
18
tasks.c
18
tasks.c
|
@ -255,7 +255,7 @@
|
||||||
pxTemp = pxDelayedTaskList; \
|
pxTemp = pxDelayedTaskList; \
|
||||||
pxDelayedTaskList = pxOverflowDelayedTaskList; \
|
pxDelayedTaskList = pxOverflowDelayedTaskList; \
|
||||||
pxOverflowDelayedTaskList = pxTemp; \
|
pxOverflowDelayedTaskList = pxTemp; \
|
||||||
xNumOfOverflows += ( BaseType_t ) 1; \
|
xNumOfOverflows = ( BaseType_t ) ( xNumOfOverflows + 1 ); \
|
||||||
prvResetNextTaskUnblockTime(); \
|
prvResetNextTaskUnblockTime(); \
|
||||||
} while( 0 )
|
} while( 0 )
|
||||||
|
|
||||||
|
@ -291,11 +291,11 @@
|
||||||
* responsibility of whichever module is using the value to ensure it gets set back
|
* responsibility of whichever module is using the value to ensure it gets set back
|
||||||
* to its original value when it is released. */
|
* to its original value when it is released. */
|
||||||
#if ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_16_BITS )
|
#if ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_16_BITS )
|
||||||
#define taskEVENT_LIST_ITEM_VALUE_IN_USE ( ( uint16_t ) 0x8000U )
|
#define taskEVENT_LIST_ITEM_VALUE_IN_USE ( ( uint16_t ) 0x8000 )
|
||||||
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_32_BITS )
|
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_32_BITS )
|
||||||
#define taskEVENT_LIST_ITEM_VALUE_IN_USE ( ( uint32_t ) 0x80000000UL )
|
#define taskEVENT_LIST_ITEM_VALUE_IN_USE ( ( uint32_t ) 0x80000000 )
|
||||||
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_64_BITS )
|
#elif ( configTICK_TYPE_WIDTH_IN_BITS == TICK_TYPE_WIDTH_64_BITS )
|
||||||
#define taskEVENT_LIST_ITEM_VALUE_IN_USE ( ( uint64_t ) 0x8000000000000000ULL )
|
#define taskEVENT_LIST_ITEM_VALUE_IN_USE ( ( uint64_t ) 0x8000000000000000 )
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Indicates that the task is not actively running on any core. */
|
/* Indicates that the task is not actively running on any core. */
|
||||||
|
@ -903,7 +903,7 @@ static void prvAddNewTaskToReadyList( TCB_t * pxNewTCB ) PRIVILEGED_FUNCTION;
|
||||||
/* System idle tasks are being assigned a priority of tskIDLE_PRIORITY - 1 here. */
|
/* System idle tasks are being assigned a priority of tskIDLE_PRIORITY - 1 here. */
|
||||||
if( ( pxCurrentTCBs[ xCoreID ]->uxTaskAttributes & taskATTRIBUTE_IS_IDLE ) != 0U )
|
if( ( pxCurrentTCBs[ xCoreID ]->uxTaskAttributes & taskATTRIBUTE_IS_IDLE ) != 0U )
|
||||||
{
|
{
|
||||||
xCurrentCoreTaskPriority = xCurrentCoreTaskPriority - 1;
|
xCurrentCoreTaskPriority = ( BaseType_t ) ( xCurrentCoreTaskPriority - 1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( ( taskTASK_IS_RUNNING( pxCurrentTCBs[ xCoreID ] ) != pdFALSE ) && ( xYieldPendings[ xCoreID ] == pdFALSE ) )
|
if( ( taskTASK_IS_RUNNING( pxCurrentTCBs[ xCoreID ] ) != pdFALSE ) && ( xYieldPendings[ xCoreID ] == pdFALSE ) )
|
||||||
|
@ -2022,7 +2022,7 @@ static void prvInitialiseNewTask( TaskFunction_t pxTaskCode,
|
||||||
* updated. */
|
* updated. */
|
||||||
taskENTER_CRITICAL();
|
taskENTER_CRITICAL();
|
||||||
{
|
{
|
||||||
uxCurrentNumberOfTasks += ( UBaseType_t ) 1U;
|
uxCurrentNumberOfTasks = ( UBaseType_t ) ( uxCurrentNumberOfTasks + 1U );
|
||||||
|
|
||||||
if( pxCurrentTCB == NULL )
|
if( pxCurrentTCB == NULL )
|
||||||
{
|
{
|
||||||
|
@ -3594,7 +3594,7 @@ static BaseType_t prvCreateIdleTasks( void )
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
vApplicationGetPassiveIdleTaskMemory( &pxIdleTaskTCBBuffer, &pxIdleTaskStackBuffer, &uxIdleTaskStackSize, xCoreID - 1 );
|
vApplicationGetPassiveIdleTaskMemory( &pxIdleTaskTCBBuffer, &pxIdleTaskStackBuffer, &uxIdleTaskStackSize, ( BaseType_t ) ( xCoreID - 1 ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* if ( configNUMBER_OF_CORES == 1 ) */
|
#endif /* if ( configNUMBER_OF_CORES == 1 ) */
|
||||||
|
@ -3816,7 +3816,7 @@ void vTaskSuspendAll( void )
|
||||||
|
|
||||||
/* The scheduler is suspended if uxSchedulerSuspended is non-zero. An increment
|
/* The scheduler is suspended if uxSchedulerSuspended is non-zero. An increment
|
||||||
* is used to allow calls to vTaskSuspendAll() to nest. */
|
* is used to allow calls to vTaskSuspendAll() to nest. */
|
||||||
uxSchedulerSuspended += ( UBaseType_t ) 1U;
|
uxSchedulerSuspended = ( UBaseType_t ) ( uxSchedulerSuspended + 1U );
|
||||||
|
|
||||||
/* Enforces ordering for ports and optimised compilers that may otherwise place
|
/* Enforces ordering for ports and optimised compilers that may otherwise place
|
||||||
* the above increment elsewhere. */
|
* the above increment elsewhere. */
|
||||||
|
@ -3969,7 +3969,7 @@ BaseType_t xTaskResumeAll( void )
|
||||||
* previous call to vTaskSuspendAll(). */
|
* previous call to vTaskSuspendAll(). */
|
||||||
configASSERT( uxSchedulerSuspended != 0U );
|
configASSERT( uxSchedulerSuspended != 0U );
|
||||||
|
|
||||||
uxSchedulerSuspended -= ( UBaseType_t ) 1U;
|
uxSchedulerSuspended = ( UBaseType_t ) ( uxSchedulerSuspended - 1U );
|
||||||
portRELEASE_TASK_LOCK();
|
portRELEASE_TASK_LOCK();
|
||||||
|
|
||||||
if( uxSchedulerSuspended == ( UBaseType_t ) 0U )
|
if( uxSchedulerSuspended == ( UBaseType_t ) 0U )
|
||||||
|
|
Loading…
Reference in a new issue