Beginning
Jul 14 2010, 14:59
Стоит цель написать свой кооперативный планировщик под компилятор IAR под архитектуру AVR.
Почему свой, это отдельная тема, да и не стоит её здесь обсуждать.
Вобщем ищу любую информацию где и как сохраняет компилятор IAR переменные и адреса возвратов. Интересует любая информация по поводу написания планировщиков.
Спасибо.
SSerge
Jul 14 2010, 15:11
И в чём проблема?
У IAR вполне понятная и подробная документация (в папке avr/doc), всё расписано, раэжёвано и примеры приведены.
вроде неплохая
на маленьком пике хорошо живет, есть и для IAR AVR
http://wiki.pic24.ru/doku.php/osa/avr
Beginning
Jul 14 2010, 15:30
Долго мучал OSA, пытался викинуть всё лишнее для меня - поддержку других контроллеров и компиляторов. Но блин - шаг вправо, шаг влево и не работает. ИМХО, и не прошу сильно пинать но написанна в стиле
http://habrahabr.ru/blogs/arbeit/99016/#habracut, по крайней мере некоторые обзацы я точно почувствовал на себе.
По этому решил написать свой.
sergeeff
Jul 14 2010, 15:35
Решил написать - пиши! К чему тогда всякие расспросы?
setjmp/longjmp - исходники для них есть тоже.
Beginning
Jul 15 2010, 15:55
Цитата(sergeeff)
Решил написать - пиши! К чему тогда всякие расспросы?
А чего ты так возмущаемся? Расспросы как расспросы. Я нигде не писал что, цель стоит написать своё - непохожее ни на что. Меня, прежде всего, волнует результат. И я с удовольствием воспользуюсь чужим кодом и примерами.
P.S. Пытался найти исходники jaCOC И SALVO – не нашёл.
shreck
Jul 16 2010, 02:45
Когда-то давным-давно начинал делать кооперативную ось для развлекухи. Но не доделал. В прищепке результат того труда. Может чем поможет. Нормальной доки нет, только то, что в коментах.
Fktrctq
Jul 16 2010, 04:46
Цитата(Beginning @ Jul 14 2010, 19:30)

Но блин - шаг вправо, шаг влево и не работает.
А зачем Вы этим занимались? ИМХО это лишний и бесполезный труд, компилироваться будет та конфигурация которую Вы укажите, и в Вашей программе не будет никакой поддержки "других контроллеров и компиляторов". Ну или вот решите Вы перейти на другой компилятор и придется вам "дописывать обратно" то, что вы наудаляли. Или выйдет новая версия ОС, и Вы снова будете шаманить над её внутренностями? Поверьте я сам этим когда-то по глупости занимался, времени потратите много - а польза от этого сомнительная. Ровно как и написание своего планировщика, если у вас нет жестких требований, из-за которых нельзя использовать существующие, то и не стоит начинать, опять же пустая трата времени, а время, как говорится - деньги.
К стати, обратите внимание на freeRTOS и scmRTOS.
Beginning
Jul 16 2010, 06:29
To shreck: спасибо посмотрю.
To Fktrctq:
scmRTOS как раз сейчас смотрю. Забавно – но когда разрабатывал свой планировщик – задался вопросом, а как же с локальными переменными в других кооперативных RTOS? И оказалось никак – не сохраняются, бери глобальные (а я не хочу “костыли”). И плавно пришёл к выводу, что надо сохранять весь банк регистров – а от сюда до вытесняющей один шаг, вот и смотрю на scmRTOS.
А насчёт - своё чужое, здесь может быть много мнений,в сё зависит от опыта. Пример – мой напарник был ярым приверженцем outsource – инга. Сколотил огромный сайт. Но после года –двух, выкинул всё и начал писать своё – говорит это ад, каждый месяц ломают сайт, установка новых обновлений – ад. Вообщем поменял он своё мнение.
Я работаю с контроллерами и тоже много раз сталкивался с проблемой – время, затраченное на изучение и поддержку чужого кода, оказывалось больше чем писание своего – а результат несоизмеримо меньше – что то добавить нереально. Но повторяю это всё зависит от ситуации и с опытом понимаешь где какой путь принять. Разумеется linux/windows никто писать не будет.
MrYuran
Jul 16 2010, 06:40
_Pasha в таких случаях пеарит свой любимый
protothreadЦитата
Protothreads are extremely lightweight stackless threads designed for severely memory constrained systems, such as small embedded systems or wireless sensor network nodes. Protothreads provide linear code execution for event-driven systems implemented in C. Protothreads can be used with or without an underlying operating system to provide blocking event-handlers. Protothreads provide sequential flow of control without complex state machines or full multi-threading.
Вроде бы и не операционка, но нагляднее стэйт-машин
Микрюков Вячеслав
Aug 28 2010, 07:24
По моему все операционки делятся на две категории:
1: Те в которых задачи сами завершают свою работу в текущем цикле, заботясь при этом о своих параметрах.
2: Те которые прерываются операционной системой с соответствующим сохранением всех параметров задач. При запуске задачам передаются ранее сохраненные параметры.
Мне лично нравится первый тип, на AVR сам написал операционку. Очень удобно новые задачи подключать, главное чтобы задача не превысила отведённое ей время в текущем 1ms цикле. А глобальные, короткие ссылки, переменные это всё пофигу, где написал там и компилирует. Как до задачи дойдёт очередь она сама определяет активная она или нет, если нет - в конец себя goto.
Переход гораздо быстрей работает, чем сохранение параметров.
Цитата(Микрюков Вячеслав @ Aug 28 2010, 11:24)

По моему все операционки делятся на две категории:
Не операционки, а планировщики (многозадачность), называются
1. Кооперативная
2. Вытесняющаая
У вас больше похоже на отсутствие планировщика вообще, просто главный цикл из которого по очереди функции вызываются.
zltigo
Aug 28 2010, 19:21
QUOTE (KRS @ Aug 28 2010, 18:18)

У вас больше похоже на отсутствие планировщика вообще
Сие имеет красивое название Super-Loop, но системой дейсвительно не является.
Микрюков Вячеслав
Sep 2 2010, 04:18
Цитата(KRS @ Aug 28 2010, 19:18)

Не операционки, а планировщики (многозадачность), называются
1. Кооперативная
2. Вытесняющаая
У вас больше похоже на отсутствие планировщика вообще, просто главный цикл из которого по очереди функции вызываются.
Спасибо за уточнения.
У меня функции разбиты на фрагменты, по этому активны одновременно много функций на разных стадиях исполнения. Прошу не упрощать.
Для просмотра полной версии этой страницы, пожалуйста,
пройдите по ссылке.