OSDev http://osdev.su/ |
|
Какую архитектуру ядра вы используете? http://osdev.su/viewtopic.php?f=5&t=971 |
Страница 1 из 7 |
Автор: | Rammstein [ 22 июл 2014, 23:59 ] |
Заголовок сообщения: | Какую архитектуру ядра вы используете? |
Изначально я задумывал сделать микроядро, в котором будут реализованы только самые базовые функции ОС: планировщик процессов и управление памятью, а также обработка некоторых прерываний. сейчас у меня уже получается нечто между микроядром и монолитным, ибо я уже добавил в ядро поддержку работы с консолью, работу с дисками. А что у вас? |
Автор: | SII [ 23 июл 2014, 00:40 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Монолит с возможностью размещения драйверов как в ядре, так и в виде отдельных задач режима пользователя. То, что сейчас называют микроядром, зачастую таковым не является. Пример -- QNX, в которой от микроядерности остался только вынос драйверов в независимые процессы; всё остальное там в ядре. (Потому, собственно, сейчас выдумали "наноядра" -- этим называют примерно то, что изначально именовалось микроядром. В общем, обесцениваются не только деньги, но и терминология). |
Автор: | phantom-84 [ 23 июл 2014, 10:15 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Аналогично, хотя поддержка драйверов режима пользователя не проработана до конца (многие категории таких драйверов нуждаются в доп. прослойке режима ядра). Т.е. пока больше похоже на монолит (модульный). Поддержка дисков/ФС полностью вынесена в модули ядра. Драйвер загрузочного диска/ФС загружается вместе с ядром в виде отдельного файла, потом ядро его инициализирует и уже после продолжает загрузку, используя этот драйвер. |
Автор: | doc1456 [ 23 июл 2014, 11:28 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Одназначна Гибритные ядра , Так как каждые из концепций имеют свой плюсы и минусы . |
Автор: | pavia [ 23 июл 2014, 21:19 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Аналогично. Ядро монолитное. А вот всё что поставляется сторонними разработчиками в отдельных процессах - драйвера, программы, сервисы. |
Автор: | Demonikss [ 23 июл 2014, 22:23 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Мне вот интересно, зачем пытаться писать подобие уже существующих ядер? Я к примеру зачитался концепцией экзоядра, где ядрышко только дает доступ к ресурсам компьютера и осуществляет их защиту. Остальное реализовано в виде подгружаемых библиотек, которые могут реализовывать какой угодно API. Принципиально там даже управление процессами из ядра выкинуто. Получается ядро маленькое, без наворотов и хорошо управляемое, то есть вполне под силу одному человеку. Монолиты пишутся обычно десятками-сотнями программистов, и это приводит к трудностям при отладке. Думаю что если не задумывается крупная коммерческая ось, то имеет смысл глядеть в сторону такого подхода. А не городить кучу костылей и припарок, чтобы потом гордо обозвать ядром и положить на полочку как со всеми начинаниями и происходит обычно. Не зря ведь и MS, и Линух призадумались над размерами своих ядер и проблемами поиска ошибок. Все ж понимают что до бесконечности увеличивать мощность процессоров не получится. А если ядро только разделяет и властвует, то остальное уже зависит от криворукости прикладных программистов, и путем отмирания оных система в целом будет развиваться. Ну даже к примеру работа с консолью может быть написана разными способами, и постоянно приклеивать ее к ядру неудобно. А будет это отдельным процессом, и управлять легче, и возможности получить уязвимость намного меньше. Как говорится, кесарю - кесарево, а ядру - только то что необходимо. Написать с лету такое ядро конечно не выйдет, зато есть над чем голову поломать. |
Автор: | SII [ 24 июл 2014, 00:09 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Лично я, почитав про экзоядра, пришёл к выводу, что эта концепция неработоспособна принципиально. |
Автор: | D-S [ 24 июл 2014, 09:13 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Надо развивать правильные идеи а не тупиковые. Экзоядро - типичное академическое упражнение - пусть там и остается. Кстати, радоватся как разработчику тому что ядро маленькое - не стоит, если что-то из него удалено то это что-то всё равно придётся сделать в проекте чтобы проект "взлетел" и пару раз хлопнул крыльями. Самое идеальное экзоядро без сервисов и драйверов - сферический конь в вакууме. Вспоминайте историю - линуксом стали позоватся только после того как он стал запускающейся системой. Если-бы в нем не появились дрова и юзерспейс то хранился бы он на складе истории. Консоль вполне может существовать в качестве отдельно процесса в самом-самом монолитном ядре. |
Автор: | Rammstein [ 24 июл 2014, 18:04 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Demonikss, я как бы и не стараюсь что-то скопировать, поэтому выпендриваться не нужно. изначально я подразумевал (как писал выше) делать микроядро, однако потом я решил что если впихнуть в него пару обязательных для юзабельности сервисов, то это не слишком большой "костыль", а тему создал не для того чтобы почитать что у людей и сделать также, а чтобы узнать как еще можно сделать. по сути структура ядра у меня уже расписана от А до Я. |
Автор: | Demonikss [ 24 июл 2014, 19:40 ] |
Заголовок сообщения: | Re: Какую архитектуру ядра вы используете? |
Я не выпендриваюсь, если так могло показаться то жаль. На форуме колибриков я задавал несколько вопросов и получал ответ типа зачем трогать и переделывать если и так все работает. В итоге даже с первых строчек кода ядра там видно что система дырявая как решето и до зрелости там еще пилить и пилить. А по поводу я знаю структуру будущего ядра... Завтра придумают новую клавиатуру, несовместимую с нынешними интерфейсами, будем ядро переписывать? А потом опять отлавливать ошибки? Экзоядро может и кажется чисто академической разработкой, если не задумываться о развитии системы в целом. Я считаю что код который не нужен в ядре, может и должен быть вынесен из ядра. Я конечно не великий специалист, но переключаться на каждое нажатие клавиши в контекст ядра - не самое рациональное использование ресурсов системы. Или речь идет не об операционной системе защищенного режима? |
Страница 1 из 7 | Часовой пояс: UTC + 3 часа |
Powered by phpBB® Forum Software © phpBB Group http://www.phpbb.com/ |