Комментарии 39
Глядя на первую картинку ожидал рассказ про другие драйверы
+11
Хм. И только в конце статьи выяснил что тема про драйвер под ЛИНУКС. Даже теги 3 раза перечитал… но нет.
Вот ведь западлянка…
Вот ведь западлянка…
+2
Отличная тема и интересная, обязательно пишите больше об этом!
0
А что за схема в шапке? Напомнила мою дипломную работу с автоматическим включателем света
0
Похоже на диодную лампочку с удаленным управлением на микроконтроллере.
-1
Очень очень нужна статья! как раз сейчас! как раз недавно стал интересоваться как написать драйвера
+1
Если вы пишете про модули ядра, так и пишите!
Я, честно говоря, ожидал, что рассказ будет о каких-нибудь приводах двигателей и т.п. Но никак не модулях ядра!
«Драйвер». Бгггг! Ну и терминология! Вы еще системный блок «процессором» назовите.
Я, честно говоря, ожидал, что рассказ будет о каких-нибудь приводах двигателей и т.п. Но никак не модулях ядра!
«Драйвер». Бгггг! Ну и терминология! Вы еще системный блок «процессором» назовите.
+1
«Обеспечитель интерфейса» звучит круче, да…
+1
В следующий раз обязательно напишем про модули ядра, спасибо за ваш комментарий.
0
«Драйвер». Бгггг! Ну и терминология! Вы еще системный блок «процессором» назовите.
А в чем проблема-то? Всю жизнь в русском языке встречался с тем, что программа обслуживания устройства называлась драйвером. То, что в Линуксе это называется «модули ядра» — это вещь специфичная исключительно для Линукса.
В MS-DOS, Windows и многих других операционных системах (даже просто средах исполнения, не обязательно ОС) такие программы принято называть «драйверами», на жаргоне — «дрова». В некоторых средах исполнения нет понятия «ядро», и поэтому программа обслуживания устройства в принципе не может являться модулем ядра. С другой стороны, в Windows есть так называемые User-mode drivers, которые тоже никаким боком не являются частью ядра ОС.
+3
Акститесь! Со своей программой вы сейчас лишаете бесплатного секса чая с печеньем тысячи подростков по всей стране! Я вас умоляю, опомнитесь!
-1
Совершенно бесполезный рекламный пост, не дотягивающий даже до аналогичной статьи в русскоязычной Википедии, и при этом в «лучшем за сутки»…
+6
НЛО прилетело и опубликовало эту надпись здесь
В этой статье вообще есть много моментов, вызывающих сомнения в компетентности её автора:
низкоуровневые машинные команды являются двоичным кодом (прерываниями) которые на выходе отправляют в драйвер результат, полученный в ходе выполнения этой самой инструкции
При создании драйвера для Линукса, вам необходимо знать не только тип шины и ее адрес, но и схематику самого устройства, а также весь набор электрических прерываний, в ходе исполнения которых устройство отдает результат драйверу.
+6
Резонно, подправили.
-1
Я понимаю, что краткость — сестра таланта, но это несколько не то, чего я обычно ожидаю от статьи на Хабре.
+3
Для всего остального нужен драйвер, который переводит команды операционной системы в последовательность прерываний – пресловутый «двоичный код».
Последний раз такое слышал на уроках ОС в универе. Вела женщина не способная отличить компьютер от компилятора.
+5
И сам «продукт» соответствующего качества.
+1
Нет такой команды на уровне ядра как «форматирование» диска. Есть команда записать нули в определенные блоки, например в суперблок и таблицу айнод при быстром форматировании. «Форматирование» это человеческий термин, который сам жесткий диск, как устройство, не понимает.
Я не критикую, просто уточняю.
Я не критикую, просто уточняю.
0
Если уж уточняете, что в НЖМД для военных/спец. служб обычно есть аппаратная «самоудалялка», которой достаточно передать что-то вроде «FORMAT» для начала работы. И таки да, она именно заформатирует винт и отдаст комманду «Готово» по окончании
0
Вообще-то команда есть, но для современных винчестеров она не актуальна. Такая команда была еще на древних винчестерах, я помню еще то время когда в БИОС-е была такая утилита для форматирования винчестера. На современных такой уже нет, а команда отданная винчестеру в зависимости от производителя либо ничего не делает либо делает REMAP тех секторов которые находятся в ожидании замены на резерв. т.е. технически команда такая есть, результат её работы нынче зависит от производителя железа.
0
коммент удален
-1
Ни о чём статья. Драйвер не является компилятором. Драйвер не является интерпретатором. Драйвер не является браузером. Драйвер не является архиватором. Драйвер не является программой 3д-моделирования.
В контексте драйверов, даже про верхнюю/нижнюю часть не рассказали, не говоря уже про нюансики работы с NUMA.
В контексте драйверов, даже про верхнюю/нижнюю часть не рассказали, не говоря уже про нюансики работы с NUMA.
+4
Пойду обновлю все драйверы на драйверы с вашего сайта. Ведь драйверы на официальных сайтах часто устаревшие. А главное, драйверам с вашего сайта всегда можно доверять! Не то что всяким стрёмным исполняемым файлам с сайта асуса или интела.
0
Не покидает ощушение, что статья либо плохой перевод, либо человек ее писавший сам лично этой темой не занимается. Каким-то странным языком написано.
Несколько раз перечитал, каша какая-то. Что за инструкция такая? В коробку с устройством ее чтоли вкладывают?
Каким образом некие низкоуровневые команды вдруг стали машинным кодом да плюс к тому еще и прерываниями? Примером такого симбиоза не поделитесь?
Ну и стрелочки на диаграмме я бы поосторожней рисовал. У вас там приложение пользователя напрямую ныряет в разные подсистемы ядра причем минуя само ядро.
Для каждого устройства существует свой строгий порядок выполнения команд, называемой «инструкцией». Не зная инструкцию к устройству, невозможно написать для него драйвер, так как низкоуровневые машинные команды являются двоичным кодом (прерываниями) которые на выходе отправляют в драйвер результат, полученный в ходе выполнения этой самой инструкции.
При создании драйвера для Линукса, вам необходимо знать не только тип шины и ее адрес, но и схематику самого устройства, а также весь набор электрических прерываний, в ходе исполнения которых устройство отдает результат драйверу.
Несколько раз перечитал, каша какая-то. Что за инструкция такая? В коробку с устройством ее чтоли вкладывают?
Каким образом некие низкоуровневые команды вдруг стали машинным кодом да плюс к тому еще и прерываниями? Примером такого симбиоза не поделитесь?
Ну и стрелочки на диаграмме я бы поосторожней рисовал. У вас там приложение пользователя напрямую ныряет в разные подсистемы ядра причем минуя само ядро.
+1
машинный код — это код которым общаются машины. На человеческом языке — это двоичный код, который плохо воспринимается человеком.
0
Они им не общаются, они его исполняют. Об этом даже Wikipedia пишет. Общение между устройствами осуществляется посредством протоколов более высокого уровня которые абстрагированы от системы команд конкретной вычислительной машины.
Единственный случай, который я могу вспомнить, когда драйвер передает в устройство машинный код — это когда он грузит в устройство прошивку на этапе инициализации.
Единственный случай, который я могу вспомнить, когда драйвер передает в устройство машинный код — это когда он грузит в устройство прошивку на этапе инициализации.
0
Какое-то у вас узкое понимание двоичного кода.
Исполняемый код — это лишь частный случай двоичного кода.
Двоичный код — это именно двоичный код а не только инструкции процессора.
Характерная черта двоичного кода — человеку его трудно воспринять. Например когда числа кодируются в двоичном виде 0xD623 или 54819 в удобной для восприятия человеком.
Пример НЕ двоичного кода — это HTML, XML или JSON но на низком уровне это не практично.
Исполняемый код — это лишь частный случай двоичного кода.
Двоичный код — это именно двоичный код а не только инструкции процессора.
Характерная черта двоичного кода — человеку его трудно воспринять. Например когда числа кодируются в двоичном виде 0xD623 или 54819 в удобной для восприятия человеком.
Пример НЕ двоичного кода — это HTML, XML или JSON но на низком уровне это не практично.
0
Лучше вы бы просто дали ссылку на книгу Linux Device Drives
0
Зарегистрируйтесь на Хабре, чтобы оставить комментарий
Драйвер устройства и с чем его едят