реклама на сайте
подробности

 
 
aaarrr
сообщение Jul 7 2008, 22:18
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Наступил на довольно неприятные грабельки.

Стек задачи создается следующим образом (tasks.c):
Код
static tskTCB *prvAllocateTCBAndStack( unsigned portSHORT usStackDepth )
{
        ...
        pxNewTCB->pxStack = ( portSTACK_TYPE * ) pvPortMalloc( ( ( size_t )}
        ...
}

signed portBASE_TYPE xTaskCreate( pdTASK_CODE pvTaskCode, const signed portCHAR * const pcName, unsigned portSHORT usStackDepth, void *pvParameters, unsigned portBASE_TYPE uxPriority, xTaskHandle *pxCreatedTask )
{
    ...
    pxNewTCB = prvAllocateTCBAndStack( usStackDepth );

    if( pxNewTCB != NULL )
    {        
        portSTACK_TYPE *pxTopOfStack;

        #if portSTACK_GROWTH < 0
        {
            pxTopOfStack = pxNewTCB->pxStack + ( usStackDepth - 1 );
        }
        #else
        {
            pxTopOfStack = pxNewTCB->pxStack;    
        }
        #endif
    ...


В prvAllocateTCBAndStack все хорошо - получаем указатель, выровненный по границе 8-и байт. А вот в xTaskCreate случается бяка: pxTopOfStack = pxNewTCB->pxStack + ( usStackDepth - 1 ) - стек уже выровнен по границе 4-х байт, и в таком виде его получает задача.

При этом в стандарте ATPCS прямо указывается необходимость выравнивания стека по 8-и байтной границе:
Цитата
When a publicly visible function is called, the stack pointer value is 8-byte aligned.


Обходится все это дело легко, жалко только времени, потраченного на вылавливание "странных глюков".
Это я один такой счастливый?
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 11th July 2025 - 08:45
Рейтинг@Mail.ru


Страница сгенерированна за 0.01972 секунд с 7
ELECTRONIX ©2004-2016