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

 
 
 
Reply to this topicStart new topic
> Как узнать, запущена ли уже ось?
AHTOXA
сообщение Apr 7 2010, 14:04
Сообщение #1


фанат дивана
******

Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684



Что-то с ходу не соображу.
У меня для вывода в отладочную в качестве буфера передачи используется OS::channel. Соответственно, если я пытаюсь что-то выдать до вызова OS::Run(), то всё наглухо зависает... Пока придумалось определять, запущена ли ось, и, если нет, то выдавать напрямую в регистр передачи, в обход OS::channel.
Короче, субжsmile.gif


--------------------
Если бы я знал, что такое электричество...
Go to the top of the page
 
+Quote Post
jorikdima
сообщение Apr 7 2010, 15:29
Сообщение #2


тут может быть ваша реклама
*****

Группа: Свой
Сообщений: 1 164
Регистрация: 15-03-06
Из: Санкт-Петербург/CA
Пользователь №: 15 280



Зачем же пользоваться средствами ОС до ее запуска? Не делайте ничего до запуска, а всю инициализацию в самом приоритетном потоке.
Go to the top of the page
 
+Quote Post
AHTOXA
сообщение Apr 7 2010, 15:57
Сообщение #3


фанат дивана
******

Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684



Конструкторы глобальных/статических объектов вызываются до запуска оси. А для них желательно уже иметь инициализированной всю периферию. Так, имхо, идеологически правильнее (и гораздо удобнее, что даже важнее smile.gif )


--------------------
Если бы я знал, что такое электричество...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Apr 7 2010, 17:01
Сообщение #4


Гуру
******

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



Цитата(AHTOXA @ Apr 7 2010, 16:19) *
Что-то с ходу не соображу.

Да, проблема sad.gif для простых OS создающих задачи статически. У меня периферии обычно много + PnP + диагностика... Посему система с динамически создаваемыми задачами поднимается постепенно ядро, idle, консолька с буфером, который в случае чего можно и принудительно разгрузить. Потом отдельная задача медленно и печально читает конфигурацию, продолжает инициализировать перефирию, создает нужные задачи и кончает жизнь самоубийством. В процессе работы тоже могут возникать задачи типа калибровок, заказной диагностики.... Может пора подумать о других системах?


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
AHTOXA
сообщение Apr 7 2010, 17:22
Сообщение #5


фанат дивана
******

Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684



Цитата(zltigo @ Apr 7 2010, 23:16) *
Да, проблема sad.gif для простых OS создающих задачи статически.

Да на самом деле не так чтоб очень, можно просто флажок добавить и взводить его в OS::Run() smile.gif
Просто думал, может есть более легитимное решение, без внесения добавлений в исходники оси.
Цитата
Посему система с динамически создаваемыми задачами поднимается постепенно ядро, idle, консолька с буфером, который в случае чего можно и принудительно разгрузить. Потом отдельная задача медленно и печально читает конфигурацию, продолжает инициализировать перефирию, создает нужные задачи и кончает жизнь самоубийством. В процессе работы тоже могут возникать задачи типа калибровок, заказной диагностики....

Всё это решаемо, вместо динамически создаваемых задач - статическая задача (или несколько), вызывающая нужные функции - "подзадачи".
Цитата
Может пора подумать о других системах?

Мне плюсы нравятся. И scmRTOS пока вполне покрывает мои потребности. Чего нет - добавим. Да и компания душевная, а это немаловажно для меняsmile.gif


--------------------
Если бы я знал, что такое электричество...
Go to the top of the page
 
+Quote Post
zltigo
сообщение Apr 7 2010, 17:41
Сообщение #6


Гуру
******

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



Цитата(AHTOXA @ Apr 7 2010, 19:37) *
Всё это решаемо, вместо динамически создаваемых задач - статическая задача (или несколько), вызывающая нужные функции - "подзадачи".

Гениально sad.gif следующим шагом останется выбросить систему.
Цитата
Чего нет - добавим.

smile.gif В рамках концепции не разгуляешся.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
dxp
сообщение Apr 8 2010, 03:45
Сообщение #7


Adept
******

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



Цитата(zltigo @ Apr 8 2010, 00:56) *
Гениально sad.gif следующим шагом останется выбросить систему.

Напрасный сарказм. Делегирование действий одной задачи другой (с иным приоритетом) - мощный паттерн проектирования, и на плюсах получается красиво и безопасно. Конечно, это полностью не покрывает функционала, достигаемого честным созданием и удалением объектов-задач, но позволяет достичь изрядной части целей, ради которых обычно затевается вся эта кухня. Кроме того, делегирование действий позволяет эффективно бороться с проблемами, для решения которых применяется инверсия приоритетов (в mutex'ах).

Цитата(zltigo @ Apr 8 2010, 00:56) *
smile.gif В рамках концепции не разгуляешся.

В определенном смысле да. Но смена концепции - другая цена. Т.ч. везде компромиссы.

Цитата(AHTOXA @ Apr 7 2010, 21:19) *
Короче, субжsmile.gif

Не очень понял - тебе надо, чтобы оно работало до запуска оси, или чтобы, если ось не запущена, то чтобы можно было это на рантайме диагностировать и не запускать соответствующий код, чтобы программа не падала? Если второе, то действительно, задача решается просто добавлением флажка, взводимого при старте.


--------------------
«Отыщи всему начало, и ты многое поймёшь» К. Прутков
Go to the top of the page
 
+Quote Post
zltigo
сообщение Apr 8 2010, 05:28
Сообщение #8


Гуру
******

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



Цитата(dxp @ Apr 8 2010, 06:00) *
Напрасный сарказм. Делегирование действий одной задачи другой (с иным приоритетом) - мощный паттерн проектирования....

Читаем первоисточник вызвавший "сарказм":
Цитата
статическая задача (или несколько), вызывающая нужные функции - "подзадачи"

Цитата(dxp @ Apr 8 2010, 06:00) *
Но смена концепции - другая цена.

О чем и речь sad.gif.
Цитата(dxp @ Apr 8 2010, 06:00) *
Т.ч. везде компромиссы.

Вопрос в оценке (можете считать субъективной smile.gif )предлагаемого scmRTOS уровня компромиссов.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
AHTOXA
сообщение Apr 8 2010, 05:28
Сообщение #9


фанат дивана
******

Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684



Цитата(dxp @ Apr 8 2010, 10:00) *
Не очень понял - тебе надо, чтобы оно работало до запуска оси, или чтобы, если ось не запущена, то чтобы можно было это на рантайме диагностировать и не запускать соответствующий код, чтобы программа не падала? Если второе, то действительно, задача решается просто добавлением флажка, взводимого при старте.

Мне нужно чтоб работало, поэтому нужно не запускать соответствующий код, а запускать вместо него осенезависимый вариантsmile.gif Уже сделал флажок. Вечером тормозил, не сообразил, что его совершенно необязательно запихивать внутрь осиsmile.gif


--------------------
Если бы я знал, что такое электричество...
Go to the top of the page
 
+Quote Post
dxp
сообщение Apr 8 2010, 07:35
Сообщение #10


Adept
******

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



Цитата(AHTOXA @ Apr 8 2010, 12:43) *
его совершенно необязательно запихивать внутрь осиsmile.gif

Действительно! Тоже об этом не подумал. smile.gif Стереотипы мышления давят.


--------------------
«Отыщи всему начало, и ты многое поймёшь» К. Прутков
Go to the top of the page
 
+Quote Post

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

 


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


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