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

 
 
> RTOS с единым стеком, Ищу аналог RTX166 Tiny
scifi
сообщение Mar 28 2010, 08:55
Сообщение #1


Гуру
******

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



Добрый день!
Давным-давно мне довелось использовать Keil RTX166 Tiny. Там есть интересная фича: задачи используют единый стек, и при переключении задач стек передвигается нужным образом автоматически:
RTX166 Tiny Stack Management
Таким образом, нет нужды выделять отдельный стек для каждой задачи, то есть имеет место существенная экономия памяти.
Вопрос: где найти RTOS с такой фичей, которую можно прикрутить к ARM и Coldfire?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
zltigo
сообщение Mar 28 2010, 14:04
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(scifi @ Mar 28 2010, 11:55) *
Там есть интересная фича: задачи используют единый стек, и при переключении задач....

Это не фича, это обманка, ибо "переключения задач" собственно быть не может sad.gif. Со стеком при прерывании задачи в произвольном месте все очень просто - либо он нужен такого размера каждой из задач, либо нет. Посему просто надо четко представлять необходимые размеры стеков для вытесняющих задач и комбинировать их с кооперативными задачами имеющими по определению общий стек.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
scifi
сообщение Mar 28 2010, 19:58
Сообщение #3


Гуру
******

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



Цитата(zltigo @ Mar 28 2010, 18:04) *
Это не фича, это обманка, ибо "переключения задач" собственно быть не может sad.gif. Со стеком при прерывании задачи в произвольном месте все очень просто - либо он нужен такого размера каждой из задач, либо нет. Посему просто надо четко представлять необходимые размеры стеков для вытесняющих задач и комбинировать их с кооперативными задачами имеющими по определению общий стек.

Что такое "переключение задач" и почему его "быть не может" спорить не стану. Одно знаю точно: многопотоковость имела место. Да и не в этом вопрос.
Переформулирую: какие есть RTOS (или как их там, прошу к терминам не предираться), в которых не выделяется отдельный стек для каждой задачи, а используется общий? С целью экономии памяти, естественно.
Спасибо alcosar за ссылку про SST. На что-то похожее натыкался, когда читал про smx RTOS и One-Shot Tasks.
Я понимаю, что единый стек требует жертв. Например, в RTX166 Tiny нельзя использовать указатели на локальные переменные, так как стек "двигается" при переключении контекста. Видел также Salvo RTOS, где ограничения ещё более строгие, но подкупает крайняя нетребовательность к объёму памяти.
Все эти подходы имеют право на жизнь в зависимости от задачи. Я просто хочу понять, какие бывают варианты.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Mar 28 2010, 20:35
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(scifi @ Mar 28 2010, 22:58) *
Я понимаю, что единый стек требует жертв.

Слишком большие жертвы sad.gif. И главное зачем? От фонаря с явным запасом выбрать один стек и при этом никак не решить проблему правильного выбора размера стека? Надо решать проблему оптимального выбора стека для задач и тогда сумма стеков по крайней мере не будет резко отличаться от тяжко прогнозируемого "объединенного" стека и при этом не иметь ограничений.


Цитата(scifi @ Mar 28 2010, 22:58) *
Видел также Salvo RTOS, где ограничения ещё более строгие, но подкупает крайняя нетребовательность к объёму памяти.

Вот и используйте, как уже писал, там где возможно и кооперативные задачи, как у Salvo. Сочетайте ОБА подхода,а не сводите все к примитиву в угоду идее бездумной экономии стека.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
scifi
сообщение Mar 28 2010, 20:55
Сообщение #5


Гуру
******

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



Цитата(zltigo @ Mar 29 2010, 00:35) *
Вот и используйте, как уже писал, там где возможно и кооперативные задачи, как у Salvo. Сочетайте ОБА подхода,а не сводите все к примитиву в угоду идее бездумной экономии стека.

Значит, есть RTOS, в которых можно сочетать подходы "единый стек" и "раздельный стек"? Если не трудно, назовите примеры.
Go to the top of the page
 
+Quote Post



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

 


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


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