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

 
 
> atmega8535 + scmRTOS + куча процессов, не хватает памяти
MBR
сообщение Sep 30 2010, 06:56
Сообщение #1


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

Группа: Участник
Сообщений: 107
Регистрация: 26-09-10
Пользователь №: 59 748



Первые впечатления - Ртось приятная. Отличная документация, в компилированном виде мало места занимает. С шаблонами, автор, конечно, перемудрил местами...

Все понятно, кроме одного но. У атмеги8535 512 байт ОЗУ. Память закончилась уже на 4 процессе с размером стека 100. Собственно вопрос, имеет ли смысл использовать дальше RTOS, если процессов предполагается 8-9 - опрос разнотипных датчиков. Можно, теоретически, попробовать уменьшить количество процессов - но тогда весь смысл ртоси пойдет на нет.

Итак, если используем:

1. Как выглядит формула для расчета размера стека? Насколько можно его безболезненно уменьшить, чтобы это не привело к краху системы?
2. Отключение регистров. Если не использовать вещественные библиотеки - насколько сложно все перекомпилировать (gcc) и как в 3 версии с урезанными регистрами?

Если не используем:

1. Что из легких кооперативных ртосей посоветуете? Предпочтителен ++
2. В принципе, уже готова заготовка кооперативной ртоси - системный таймер тиков и шедулер процессов. Что еще я упустил?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Сергей Борщ
сообщение Sep 30 2010, 20:29
Сообщение #2


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(MBR @ Sep 30 2010, 09:56) *
У атмеги8535 512 байт ОЗУ.
....
процессов предполагается 8-9
Да вы оптимист smile.gif Вы не указали компилятор, у ИАР так вообще два стека на каждый процес. Еще учтите, что весь контекст прерываний кладется на стек текущего процесса, значит в стеке каждого процесса надо зарезервировать место под контекст самого охочего до стека прерывания. Мое мнение - или менять проц, или отказываться от ОС.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
MBR
сообщение Oct 1 2010, 06:48
Сообщение #3


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

Группа: Участник
Сообщений: 107
Регистрация: 26-09-10
Пользователь №: 59 748



Цитата(Сергей Борщ @ Oct 1 2010, 00:29) *
Да вы оптимист smile.gif Вы не указали компилятор, у ИАР так вообще два стека на каждый процес. Еще учтите, что весь контекст прерываний кладется на стек текущего процесса, значит в стеке каждого процесса надо зарезервировать место под контекст самого охочего до стека прерывания. Мое мнение - или менять проц, или отказываться от ОС.

Указал же - gcc. Спасибо за ответ, уже переделал на опрос датчиков в основном цикле без ОС. Увы, не так удобно и надежно, но работает
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 28th June 2025 - 23:32
Рейтинг@Mail.ru


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