|
|
  |
scmRTOS, Перезапуск процесса |
|
|
|
Jun 18 2008, 18:39
|
Участник

Группа: Участник
Сообщений: 54
Регистрация: 25-09-07
Пользователь №: 30 836

|
Здравствуйте! Вопрос, наверое, к авторам в первую очередь. Можно ли в scmRTOS организовать перезапуск процесса (повторный вход в Exec со сбросом стека в начальное состояние), е еще лучше - подмену процесса другим, пусть даже с тем же размером стека и приоритетом. Обьясню зачем - устройство может работать в различных режимах и в каждом из них нужен свой набор примерно похожих, но отличающихся процессов. Одновременно держать их в памяти слишком накладно из-за стеков. Приходится на один процесс вешать разную функциональность в разных режимах. При этом каждый раз при смене режима выпутываться из вложенных циклов в кажом процессе, чтобы выйти на верхний уровень. Вот если бы была возможность просто плюнуть на текущий процесс, зная что он мне уже не нужен, и запустить вместо него другой, пусть с тем же стеком и приоритетом... или, на худой конец, просто быстро выскочить в начальное состояние процеса и пустить его по другой ветке... Понимаю, что в принципе должно быть возможно, но мешает не блестящее знание плюсов и раскиданнность самой ОС по нескольким файлам + дефицит времени для принятия решения. Тупой вызов Exec для процесса перезапускает его, но только один раз. дальше система начинает чудить. Очевидно, надо чистить стек, но как- пока не пойму. Буду признателен за помощь.
|
|
|
|
|
Jun 18 2008, 20:34
|

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

|
Цитата(=DS= @ Jun 18 2008, 20:39)  Вот если бы была возможность просто плюнуть на текущий процесс, зная что он мне уже не нужен, и запустить вместо него другой, пусть с тем же стеком и приоритетом... Посто нужно воспользоваться более сложными системами. Оптимальной в этом отношении представляется FreeRTOS. Динамическое выделение памяти под контекст задачи позволяет порождать, убивать, заменять задачи, создавать наборы задач в зависимости от конкретной конфигурации... Передача параметров при создании задачи штатно тоже предусмотрнна. scmRTOS уж слишком во многих случаях минималистична и не всегда сособна быть "доработана" ввиду изначально заложеной концепции.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jun 18 2008, 22:25
|
Участник

Группа: Участник
Сообщений: 54
Регистрация: 25-09-07
Пользователь №: 30 836

|
Цитата(zltigo @ Jun 19 2008, 00:34)  Посто нужно воспользоваться более сложными системами. Беда в том, что контроллер - MSP430 с их традиционно микроскопической оперативкой. scmRTOS и была выбрана из-за ее минималистчности и самых низких требований к ОЗУ. В ней как раз есть все то, что мне иужно и ничего сверх этого для решения моей конкретной задачи. Еще бы позможность перезапуска процессов или их подмены... Оффтоп, навеянный аватаром - давно ищу в сети сборник рисунков Бидструпа. Случайно не знаете, где его можно найти?
Сообщение отредактировал =DS= - Jun 18 2008, 22:29
|
|
|
|
|
Jun 19 2008, 05:06
|

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

|
Цитата(=DS= @ Jun 19 2008, 01:39)  Здравствуйте! Вопрос, наверое, к авторам в первую очередь. Можно ли в scmRTOS организовать перезапуск процесса (повторный вход в Exec со сбросом стека в начальное состояние), е еще лучше - подмену процесса другим, пусть даже с тем же размером стека и приоритетом. Обьясню зачем - устройство может работать в различных режимах и в каждом из них нужен свой набор примерно похожих, но отличающихся процессов. Одновременно держать их в памяти слишком накладно из-за стеков. Приходится на один процесс вешать разную функциональность в разных режимах. При этом каждый раз при смене режима выпутываться из вложенных циклов в кажом процессе, чтобы выйти на верхний уровень. Вот если бы была возможность просто плюнуть на текущий процесс, зная что он мне уже не нужен, и запустить вместо него другой, пусть с тем же стеком и приоритетом... или, на худой конец, просто быстро выскочить в начальное состояние процеса и пустить его по другой ветке... Понимаю, что в принципе должно быть возможно, но мешает не блестящее знание плюсов и раскиданнность самой ОС по нескольким файлам + дефицит времени для принятия решения. Тупой вызов Exec для процесса перезапускает его, но только один раз. дальше система начинает чудить. Очевидно, надо чистить стек, но как- пока не пойму. Буду признателен за помощь. Почему бы не поступить так: для реализации разных по функциональности вариантов написать соответствующее количество функций и вызывать их из одного и того же процесса. Если функция уже не нужна, то делать return из нее и запускать другую, нужную.
--------------------
«Отыщи всему начало, и ты многое поймёшь» К. Прутков
|
|
|
|
|
Jun 19 2008, 05:25
|

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

|
Цитата(=DS= @ Jun 19 2008, 00:25)  Беда в том, что контроллер - MSP430 с.. Да, это резко меняет дело. Цитата ..давно ищу в сети сборник рисунков Бидструпа. Cколько себя помню  , в родительской библиотеке были несколько альбомов. Посему особой необходимости искать в сети и не было. Тем более, что чисто политические его рисунки меня как-то и не очень привлекают.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jun 19 2008, 06:33
|
Участник

Группа: Участник
Сообщений: 54
Регистрация: 25-09-07
Пользователь №: 30 836

|
Цитата(dxp @ Jun 19 2008, 09:06)  Почему бы не поступить так: для реализации разных по функциональности вариантов написать соответствующее количество функций и вызывать их из одного и того же процесса. Если функция уже не нужна, то делать return из нее и запускать другую, нужную. Смена режима вызывается внешним событием (подключением к компьютеру и тд), а не логикой программы. В Вашем варианте приходится приходится во всех этих процессах все время проверять флаги этих событий, чтобы сменить режим. А так можно поставить один мелкий процессик - диспетчер, который по возникновению смены режима быстро перезапустил или заменил процессы и снова завалился спать. Цитата(zltigo @ Jun 19 2008, 09:06)  Cколько себя помню , в родительской библиотеке ... То-же самое. Только библиотека эта теперь далеко....
|
|
|
|
|
Jun 19 2008, 12:36
|

Нечётный пользователь.
     
Группа: Свой
Сообщений: 2 033
Регистрация: 26-05-05
Из: Бровари, Україна
Пользователь №: 5 417

|
Цитата(=DS= @ Jun 19 2008, 09:33)  Смена режима вызывается внешним событием (подключением к компьютеру и тд), а не логикой программы. В Вашем варианте приходится приходится во всех этих процессах все время проверять флаги этих событий, чтобы сменить режим. А так можно поставить один мелкий процессик - диспетчер, который по возникновению смены режима быстро перезапустил или заменил процессы и снова завалился спать. Дописать нечто, сбрасывающего контекст некоего процесса в состояние "как перед OS::Run()" не проблема (а там пусть проверяет глобальную переменную режима и вызывает нужную функцию). Только этот процесс мог в данный момент чего-то ждать, т.е. его бит может сидеть в маске какого-то синхронизирующего объекта. Поскольку минимализм - эти объекты никак недоступны ядру, т.е. не сидят в каком-то списке всех (активных) объектов - нельзя пройтись по всем и сбросить бит данного процесса (уровня приоритета). Если вдруг активируется event, которого ждал данный процесс в прошлой жизни, то процессу взведётся готовность к выполнению. А он в это время уже может ждать чего-то другого. Во что это выльется - надо внимательно смотреть исходники всех синхронизирующих объектов. А ещё он в прошлой жизни мог lock-нуть какой-то ресурс, а в новой не помнить, что он это сделал - кто разлочит? Если бы все объекты сидели в общем списке (помещали туда себя в своём конструкторе либо в "активирующих" функциях) - можно было бы при "перезапуске" процесса пройтись и убрать все ожидания и освободить все ресурсы, но это усложнение, оправданность которого подлежит обсуждению. Цитата То-же самое. Только библиотека эта теперь далеко.... Аналогично... Но скоро на недельку собираюсь поближе :-) отмазка - времени на сканирование того же сотворения мира не будет :-)
--------------------
Ну, я пошёл… Если что – звоните…
|
|
|
|
|
Jun 19 2008, 13:06
|
Участник

Группа: Участник
Сообщений: 54
Регистрация: 25-09-07
Пользователь №: 30 836

|
2 ReAl Да уж... Собственно, когда я начинал тему, думал, что данные процессов (статическая часть, естественно) находятся в ROM, и больше думал, как обойти это ограничение. Сегодня полез в отладчик, обнаружил, что они в RАМ и радостно полез все править. Потихоньку дошел и до высказанных Вами соображений. Ну у меня в любом случае выбора нет, придется все-таки идти этим путем, но включение этой возможности в ОС мне лично кажется весьма полезным.
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|