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

 
 
 
Reply to this topicStart new topic
> Помогите определиться с RTOS, для CortexM3-like MCU
Algol
сообщение Jan 18 2012, 13:01
Сообщение #1


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

Группа: Свой
Сообщений: 140
Регистрация: 7-04-05
Из: Россия, Владимир
Пользователь №: 3 941



Доброго времени суток!
Решил в качестве самообразования освоить для себя применение RTOS для embedded.
В приоритете Cortex-M3..возможно M4 в недалеком будущем.

Пока есть начальные представления о TNKernel и FreeRTOS - создание задач моргания светодиодами. Наверное между ними и сводится выбор в конечном счете.
Задачи наверное типовые - опрос периферии, ethernet.
Субъективно TNKernel понравилась гораздо больше, но смущает только один нюанс - не слишком широкое распространение. Боюсь остаться один на один с возникающими граблями.

Наверное вопрос больше религиозный, но все же...что скажет купечество?
Go to the top of the page
 
+Quote Post
sparcmaster
сообщение Jan 18 2012, 13:18
Сообщение #2


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

Группа: Свой
Сообщений: 93
Регистрация: 13-01-12
Из: Гатчина
Пользователь №: 69 333



Цитата(Algol @ Jan 18 2012, 17:01) *
Субъективно TNKernel понравилась гораздо больше, но смущает только один нюанс - не слишком широкое распространение. Боюсь остаться один на один с возникающими граблями.

TNKernel используют достаточно много народа, так что не переживайте на счет распространения. Сам сижу на FreeRTOS - выбирал по доступности обучающих материалов.
Go to the top of the page
 
+Quote Post
haker_fox
сообщение Jan 19 2012, 03:12
Сообщение #3


Познающий...
******

Группа: Свой
Сообщений: 2 963
Регистрация: 1-09-05
Из: г. Иркутск
Пользователь №: 8 125



QUOTE (Algol @ Jan 18 2012, 21:01) *
Субъективно TNKernel понравилась гораздо больше,

Добрый день! Понимаю, что спрашиваю Вас о субъективном, но все же... расскажите, пожалуйста, чем Вам понравилась TNKernel? Дело в том, что я тоже стою на грани выбора между этими двумя ОС... Обе мощные, серьезные системы... Ничего не знаю об одной из нихж такого, что бы сдвинуло весы из равновесия...

Спасибо!


--------------------
Выбор.
Go to the top of the page
 
+Quote Post
Algol
сообщение Jan 19 2012, 08:04
Сообщение #4


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

Группа: Свой
Сообщений: 140
Регистрация: 7-04-05
Из: Россия, Владимир
Пользователь №: 3 941



Цитата(haker_fox @ Jan 19 2012, 06:12) *
Добрый день! Понимаю, что спрашиваю Вас о субъективном, но все же... расскажите, пожалуйста, чем Вам понравилась TNKernel?

День добрый!
Субъективно - стиль написания TNKernel понравился больше. Меньше файлов ядра, пример мигания светодиодом запустил сразу. При этом даже предупреждений компилятор не выдал. С FreeRTOS пытался начинать ранее. Там и файлов не в пример больше и предупреждений было уйма насколько помню.
TNKernel видится мне более легковесной по сравнению с FreeRTOS.
Go to the top of the page
 
+Quote Post
Mahagam
сообщение Jan 19 2012, 08:16
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 322
Регистрация: 2-07-04
Из: Minsk
Пользователь №: 240



Crossworks tasking library (CTL) - крайне просто, логично и красиво написана. исходники есть и легко собираются. примеры понятны. справка понятная и с примерами. есть всё для счастья.
Go to the top of the page
 
+Quote Post
EugenyAM
сообщение Jan 31 2012, 07:53
Сообщение #6


Участник
*

Группа: Свой
Сообщений: 73
Регистрация: 14-10-08
Из: Omsk
Пользователь №: 40 929



Больше года использую TNKernel под ARM7, полгода под Cortex M3. Использовал все фичи, кроме выделения буферов памяти. Граблей пока не обнаружено. Недавно начал писать набор макросов для быстрого создания задач, семафоров, событий с наиболее часто используемым набором параметров. С данными макросами легко можно будет перейти на другую ОС в случае необходимости.
На тот момент, когда стояла такая же проблема выбора, у FreeRTOS не было примеров для ARM7 под IAR, у TNKernel они были и запустились сразу и без проблем - это и стало причиной выбора. Под Cortex M3 пришлось немного допилить проект для совместного использования с последней StdPeriferialLibrary и IAR 6.21. Еще где-то на форуме видел бенчмарк по переключению контекста для различных ОС - TNKernel в числе лидеров. TN-Net пока не пробовал, пока экспериментирую с LwIP.

Сообщение отредактировал EugenyAM - Jan 31 2012, 08:11
Go to the top of the page
 
+Quote Post
haker_fox
сообщение Jan 31 2012, 08:55
Сообщение #7


Познающий...
******

Группа: Свой
Сообщений: 2 963
Регистрация: 1-09-05
Из: г. Иркутск
Пользователь №: 8 125



QUOTE (EugenyAM @ Jan 31 2012, 15:53) *
Больше года использую TNKernel под ARM7, полгода под Cortex M3. Использовал все фичи,

Добрый день!
Можно спросить? Есть ли возможность динамического создания и удаления задач в этой ОС? Если да, то это делается во флеши, или можно и к ОЗУ прикрутить (как во взрослых системах)?
Спасибо!


--------------------
Выбор.
Go to the top of the page
 
+Quote Post
EugenyAM
сообщение Jan 31 2012, 09:42
Сообщение #8


Участник
*

Группа: Свой
Сообщений: 73
Регистрация: 14-10-08
Из: Omsk
Пользователь №: 40 929



Цитата(haker_fox @ Jan 31 2012, 15:55) *
Есть ли возможность динамического создания и удаления задач в этой ОС? Если да, то это делается во флеши, или можно и к ОЗУ прикрутить (как во взрослых системах)?


Задача использует для своей работы две области ОЗУ - структуру TCB и стек задачи, а также, собствено функцию задачи ,которая размещается во флеш при компиляции. Указатели на эти три области памяти передаются функции tn_task_create.
Теоретически никто не мешает выделить память под TCB и стек динамически перед вызовом функции создания задачи. Если куча находится не на стеке, (в IAR вроде бы она лежит в отдельном сегменте) - все должно сработать.
Если речь идет о загрузке кода функции в ОЗУ и объявления его задачей - тоже подводных камней не видно (хотя сам не проверял). В описании функции задачи отсутствуют какие-либо специальные макросы и определения - она не отличается от обычной Си-функции void func(void). Для ее работы должно выполняться два условия - бесконечный цикл и хотя-бы один системный вызов внутри него (например tn_task_sleep или tn_event_wait) - без него программа зависает.
В любой момент задачу можно остановить и удалить из списка. Задача может быть остановлена и удалена как другой задачей (tn_task_terminate, tn_task_delete), так и сама собой (tn_task_exit, если нужно, с опцией TN_EXIT_AND_DELETE_TASK). Имхо, все сделано "по взрослому, но без излишеств".
Насколько я помню, в uCOS/II задачу можно было остановить только из самой себя.

Сообщение отредактировал EugenyAM - Jan 31 2012, 09:44
Go to the top of the page
 
+Quote Post
dxp
сообщение Jan 31 2012, 11:20
Сообщение #9


Adept
******

Группа: Свой
Сообщений: 3 469
Регистрация: 6-12-04
Из: Novosibirsk
Пользователь №: 1 343



QUOTE (haker_fox @ Jan 31 2012, 15:55) *
Добрый день!
Можно спросить? Есть ли возможность динамического создания и удаления задач в этой ОС?

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


--------------------
«Отыщи всему начало, и ты многое поймёшь» К. Прутков
Go to the top of the page
 
+Quote Post
haker_fox
сообщение Jan 31 2012, 13:57
Сообщение #10


Познающий...
******

Группа: Свой
Сообщений: 2 963
Регистрация: 1-09-05
Из: г. Иркутск
Пользователь №: 8 125



QUOTE (dxp @ Jan 31 2012, 19:20) *
А что это вам даст? Какую цель вы преследуете, стремясь к использованию динамического создания/удаления задач?

Пока только академический интерес...


--------------------
Выбор.
Go to the top of the page
 
+Quote Post
dac
сообщение Jan 31 2012, 14:35
Сообщение #11


Знающий
****

Группа: Свой
Сообщений: 600
Регистрация: 27-05-05
Пользователь №: 5 482



делаю на TNKernel под М3. в дальнейшем планирую постоянно использовать, радует что есть GUI, хотя его пока не смотрел но в дальнейшем понадобится, как раз плату развожу под это дело. выбирал тоже между freertos и TNKernel - последняя больше понравилась наглядностью понятностью и скоростью. на www.pic24.ru очень хорошая документация на русском и примеры
Go to the top of the page
 
+Quote Post
kan35
сообщение Feb 5 2012, 10:03
Сообщение #12


Знающий
****

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



Цитата(dac @ Jan 31 2012, 18:35) *
делаю на TNKernel под М3. в дальнейшем планирую постоянно использовать, радует что есть GUI, хотя его пока не смотрел но в дальнейшем понадобится, как раз плату развожу под это дело. выбирал тоже между freertos и TNKernel - последняя больше понравилась наглядностью понятностью и скоростью. на www.pic24.ru очень хорошая документация на русском и примеры

Я остановился на FreeRTOS почти случайно, потом с удовольствием узнал, что команда lwIP очень дружит с FreeRTOS и это правда полезно.
Не могу сказать лучше ли она или хуже, чем TNKernel, но в целом пользоваться просто, и задачи динамически создавать и удалять можно и таймеры есть и т д
Go to the top of the page
 
+Quote Post
Algol
сообщение Feb 5 2012, 10:18
Сообщение #13


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

Группа: Свой
Сообщений: 140
Регистрация: 7-04-05
Из: Россия, Владимир
Пользователь №: 3 941



Цитата(dac @ Jan 31 2012, 18:35) *
делаю на TNKernel под М3. в дальнейшем планирую постоянно использовать, радует что есть GUI


Добрый день! КМК, фича довольно бесполезная для такого класса мк. Я на скриншоты этого GUI смотрел мельком - без слез не взглянешь. Если нужен GUI, Qt мне очень нравится в этом плане, но это уже другая весовая категория.

Цитата(kan35)
Я остановился на FreeRTOS почти случайно, потом с удовольствием узнал, что команда lwIP очень дружит с FreeRTOS и это правда полезно.


Да, радует еще и что аппноты у СТ тоже основаны на FreeRTOS+LwIP. Запустил у себя на плате Lwip 1.4.0 и FreeRTOS 7.1.0. Теперь осталось подружить их вместе rolleyes.gif
Go to the top of the page
 
+Quote Post
Alex Black
сообщение Mar 23 2012, 15:09
Сообщение #14





Группа: Участник
Сообщений: 7
Регистрация: 29-11-07
Из: Украина, Донецк
Пользователь №: 32 792



Недавно встал вопрос об операционке, выбрал ChibiOS. До этого операционками не пользовался, да и ARM только начал осваивать.
Взлетел за пару дней. Изначально казалось, что все супер документировано и описание уж очень привлекло. После реальной работы выяснил, что иной раз надо таки копаться в коде, чтобы понять что и как. Думаю это справедливо для всех OPEN проектов, так как разработчики думают раз код есть, зачем человеческую документацию писать. В принципе пока доволен, но волнует слабая распространенность, боюсь со сложной проблемой придется в разработчику обращаться, надеюсь не откажет.
Go to the top of the page
 
+Quote Post

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

 


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


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