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

 
 
> Расход RAM в зависимости от уровня оптимизации, Для ARM, а может и для всех
kan35
сообщение Apr 26 2012, 16:53
Сообщение #1


Знающий
****

Группа: Участник
Сообщений: 537
Регистрация: 22-02-06
Пользователь №: 14 594



Разрабатываю ПО на STM32 с использованием FreeRTOS, и заметил, что при компиляции без оптимизации кода происходит не только раздутие памяти программ, но и идет увеличенный расход памяти RAM в стеках. Видимо под все переменные выделяется гарантированное место в стеке на все время жизни задачи, а когда оптимизация включена, то видимо переменные убиваются и возникают динамично, подчищая стек за собой. Правильно ли я это понимаю?

Если так, то конечно с этим можно смириться, но крайне неудобно, что с определенного момента debug target перестает работать, так как случается нехватка стека, при этом прога сваливается в самом начала жизни потока, то есть переменные видимо как то разом инициализируются... При этом release отлично работает, но отлаживаться сложнее.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 4)
scifi
сообщение Apr 26 2012, 18:13
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(kan35 @ Apr 26 2012, 20:53) *
Видимо под все переменные выделяется гарантированное место в стеке на все время жизни задачи, а когда оптимизация включена, то видимо переменные убиваются и возникают динамично, подчищая стек за собой. Правильно ли я это понимаю?

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

Цитата(kan35 @ Apr 26 2012, 20:53) *
Если так, то конечно с этим можно смириться, но крайне неудобно, что с определенного момента debug target перестает работать, так как случается нехватка стека, при этом прога сваливается в самом начала жизни потока, то есть переменные видимо как то разом инициализируются... При этом release отлично работает, но отлаживаться сложнее.

Ну да, обычное дело. Точно так же в режиме отладки код может просто не поместиться в память программ.
Go to the top of the page
 
+Quote Post
Dog Pawlowa
сообщение Apr 26 2012, 18:42
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823



Да-да, бывает, что с неполной оптимизацией программа вообще неработоспособна - прерывания наползают друг на друга sm.gif
Вечная проблема резерва ресурсов.
Обычное правило - фактор 2. По памяти, по программной памяти, по быстродействию.
И все будет хорошо.


--------------------
Уходя, оставьте свет...
Go to the top of the page
 
+Quote Post
KRS
сообщение Apr 26 2012, 19:36
Сообщение #4


Профессионал
*****

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



а я у IAR всегда ставлю максимальную оптимизацию и для отладки и для релиза! потому что IAR при максимальной оптимизации генерирует совсем другой код, многое выбрасывает, надо везде где надо использовать volatile и т.п. и что бы не пришлось отлаживать два раза...
А отладчик нормально работает и при максимальной оптимизации, в крайнем случае можно и по асму пройтись.
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Apr 27 2012, 04:58
Сообщение #5


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153



Присоединяюсь. Отлаживайте релиз - код совсем другой, могут быть разные наборы багов sm.gif

Если какой-то кусочек после оптимизации уж совсем непонятен - добавьте сохранение результатов в промежуточные переменные (volatile) или пометьте его неоптимизируемым.
Go to the top of the page
 
+Quote Post

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

 


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


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