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

 
 
 
Reply to this topicStart new topic
> stm32f207+lwIP+FreeRTOS, Не создается задача
l_fin_l
сообщение Sep 27 2012, 11:39
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 31
Регистрация: 23-08-11
Пользователь №: 66 836



Здравствйте, обращаюсь к вам с вопросом по FreeRTOS и LwIP.
За основу я взял STM'овский пример "HTTP server netconn demo"(под IAR), по примеру вопросов нету, все стабильно работает. Добавил две задачи, одна из них создается нормально, вторая при создании возвращает ошибку errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY, мол в куче мало места. Хотя размер configTOTAL_HEAP_SIZE позволяет разместить задачу. В чем может быть проблема? Заранее спасибо!
Go to the top of the page
 
+Quote Post
kan35
сообщение Sep 27 2012, 17:40
Сообщение #2


Знающий
****

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



Цитата(l_fin_l @ Sep 27 2012, 15:39) *
Здравствйте, обращаюсь к вам с вопросом по FreeRTOS и LwIP.
За основу я взял STM'овский пример "HTTP server netconn demo"(под IAR), по примеру вопросов нету, все стабильно работает. Добавил две задачи, одна из них создается нормально, вторая при создании возвращает ошибку errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY, мол в куче мало места. Хотя размер configTOTAL_HEAP_SIZE позволяет разместить задачу. В чем может быть проблема? Заранее спасибо!

Может быть вы назначили этой задаче слишком много стека? И как вы делаете вывод что памяти достаточно?
Go to the top of the page
 
+Quote Post
l_fin_l
сообщение Sep 28 2012, 03:54
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 31
Регистрация: 23-08-11
Пользователь №: 66 836



Попытался уменьшить объем стека до 512, не помогло(((.350+1000+500+2048+512=4410, а значение configTOTAL_HEAP_SIZE равно ( ( size_t ) ( 40 * 1024 ) ). Еще стал замечать, что если закомментить создание одной из задач, то программа работает нормально, а если создаются все, тогда после запуска планировщика программа крутится в main'е в цикле for(;;);
Go to the top of the page
 
+Quote Post
Gunner
сообщение Sep 28 2012, 11:41
Сообщение #4


Частый гость
**

Группа: Участник
Сообщений: 99
Регистрация: 23-06-04
Из: Kiev
Пользователь №: 146



350+1000+500+2048+512=4410
Это что?
Go to the top of the page
 
+Quote Post
kan35
сообщение Sep 28 2012, 12:59
Сообщение #5


Знающий
****

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



если мне не изменяет память эти цифры - 16 битные слова.
и момент: configTOTAL_HEAP_SIZE 40к - это думаете много? не забыли что у вас крутится lwIP?
И еще, есть API функция, которая возвращает размер свободной памяти ОСи - в ней найдете переменную, ее добавьте в Live Watch.

Сообщение отредактировал kan35 - Sep 28 2012, 13:00
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 22:56
Рейтинг@Mail.ru


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