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

 
 
> Можно ли узнать максимальный размер кучи?, Выделяемой в ходе выполнения программ на NIOS
Koluchiy
сообщение Dec 10 2013, 11:03
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 972
Регистрация: 12-04-09
Из: Москва
Пользователь №: 47 543



Здравствуйте, уважаемые гуру.

Есть такая конфигурация: NIOS+uC/OSII+Niche stack.
На всем этом работает некоторое количество задач.
Нужно понять, сколько всему этому надо динамической памяти (Heap).
Соответственно, вопрос - как это узнать?
Нет ли какого счетчика в ходе отладки, который бы показывал максимальный размер выделенной памяти?
Тогда можно было бы в режиме отладки погонять задачи в максимальных режимах и получить минимально-достаточный размер памяти.

В общем, подскажите, куда копать.

Всем заранее спасибо за ответы.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 4)
Corner
сообщение Dec 19 2013, 17:09
Сообщение #2


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

Группа: Участник
Сообщений: 1 072
Регистрация: 11-12-12
Пользователь №: 74 815



Цитата(Koluchiy @ Dec 10 2013, 15:03) *
Здравствуйте, уважаемые гуру.

Есть такая конфигурация: NIOS+uC/OSII+Niche stack.
На всем этом работает некоторое количество задач.
Нужно понять, сколько всему этому надо динамической памяти (Heap).
Соответственно, вопрос - как это узнать?
Нет ли какого счетчика в ходе отладки, который бы показывал максимальный размер выделенной памяти?
Тогда можно было бы в режиме отладки погонять задачи в максимальных режимах и получить минимально-достаточный размер памяти.

В общем, подскажите, куда копать.

Всем заранее спасибо за ответы.

Обычно heapsize это параметр определяемый на этапе сборки кода если код просто исполняемый. А вот если у вас ОС, то это уже надо рыть в настройках ядра.
Go to the top of the page
 
+Quote Post
Golikov A.
сообщение Dec 19 2013, 21:13
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 4 256
Регистрация: 17-02-06
Пользователь №: 14 454



странно это как - то

берем тср стэк к примеру, он под все сообщения выделяет динамически память, а после отправки ее грохает. Если обмен плотный, сообщений много, то и памяти много пойдет, а если обмен вялый, то ее мало пойдет. И как такое на этапе сборки определить?

Правильнее тут писать программу с правильной реакцией на окончание кучу, ИМХО...
Go to the top of the page
 
+Quote Post
WitFed
сообщение Oct 29 2014, 13:04
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 271
Регистрация: 6-12-11
Из: Taganrog
Пользователь №: 68 701



Обычно считается, что выделять память после стартового инита приложения -- неправильно, ибо менеджер кучи обладает непредсказуемым временем ответа в общем случае из-за фрагментации, хотя возможны хитрые варианты.
Но если архитектура памяти стека не настраиваема сразу на старте, можно предложить универсальную динамическую схему экспериментального этапа -- периодически запускать нить с максимальным приоритетом, которая будет выгребать у ОС всю возможную память дихотомией размеров и сразу же возвращать, выведя нужные данные в лог.
Для конкретной ОС можно в map-файле подглядеть не свои глобальные переменные -- вполне вероятно, что учёт уже ведётся, и осталось его только вывести наружу.
Также обычно компиляторы поддерживают "перегрузку" любой системной функции -- "повесив" свои версии malloc()/free()/calloc(), мы получим proxy, через которое все станут работать. Только вот надо ещё суметь вызвать прежние версии... wink.gif
Go to the top of the page
 
+Quote Post
Golikov A.
сообщение Oct 29 2014, 13:17
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 4 256
Регистрация: 17-02-06
Пользователь №: 14 454



чего то вы такое сложное сказали, что даже не понятно о чем...

Цитата
что выделять память после стартового инита приложения -- неправильно

вот это к примеру что значит? Что вы динамическую память используете как статическую? А нафига тогда ее делать динамической? Какой в ней смысл если вы знаете изначально сколько ее вам надо?

Go to the top of the page
 
+Quote Post

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

 


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


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