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

 
 
> Инициализация стека в Cortex M3
Yogen
сообщение Dec 6 2016, 04:37
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 22
Регистрация: 16-11-09
Из: Омск
Пользователь №: 53 657



Здравствуйте.

Написал приложение с собственным загрузчиком на ADuCM360. Работает, но до последнего момента был неясен вопрос инициализации вершины стека при переходе с загрузчика на основное приложение. Понятно, что при старте загрузчика по ресету стек инициализируется автоматически по указателю на нулевом адресе. Но при переходе на основное приложение этого не происходит и его нужно инициализировать вручную, например так:

Код
__set_MSP(*(__IO uint32_t*) FLASH_APPLICATION_ADDR); // Новая вершина стека.

Насколько успел разобраться, указатель стека по адресу начала основного приложения инициализируется компилятором в соответствии с директивами файла конфигурации *icf линкера. В файлах *icf из примеров написано:

Код
place in RAM_region   { readwrite,
                        block CSTACK, block HEAP };

но при таком размещении стек гуляет по памяти в зависимости от размера пользовательских данных в RAM и размера самого стека.
Однако здесь же на форуме читал что народ ставит вершину стека в конец RAM, поэтому переписал так:

Код
place at address mem: (__ICFEDIT_region_RAM_end__ - __ICFEDIT_size_cstack__)  { block CSTACK};
place in RAM_region   { readwrite, block HEAP };


Всё ли правильно сделал и какие могут быть подводные камни?
Где посмотреть пример файла конфигурации с привязкой вершины стека к концу RAM скажем для STM32?
Go to the top of the page
 
+Quote Post



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

 


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


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