Статья добавлена 21 июня 2010, в понедельник, в 15:59. С того момента...
2935 |
просмотров |
0 | добавлений в избранное |
0 | комментариев |
Представлена в разделах:
Что такое драйверы и откуда они взялись?
Сим начинаю небольшой цикл статей - Ликбез. В которых буду рассказывать как так получилось и почему так происходит, про разные вещи. Сегодня про драйверы.
Данная статья предназначена для людей, которым интересно как оно на самом деле устроено и почему. Сегодня речь пойдет о драйверах.
Много-много лет назад, когда деревья были большими, компьютеры были монолитны, т.е. были выполнены технически на одной плате. Представьте себе коробку, в которой смонтировано несколько плат с микросхемами, конденсаторами, трансформаторами. Все это переплетено кучей проводов. Такие машины выпускались серийно и апгрейду не подлежали, ибо для этого их нужно было перепаивать, а умели это далеко не все.
ПО для таких компьютеров выпускалось отдельно под каждую модель: каждая программа точно знала на каком компьютере, с каким набором инструкций она будет выполняться. Т.е. если программе нужно было вызвать звук - она генерировала прерывание, процессор передавал данные звуковому устройству и звук воспроизводился. В то время только зарождалось понятие об операционной системе, в современном ее понимании.
Эта ситуация кардинально изменилась с появлением IBM-совместимых компьютеров. Для тех кто не знает, главная "фишка" этой архитектуры в том, что компьютер превращается в своеобразный конструктор. Устройства конструктивно разводятся по разным платам, разрабатываются интерфейсы для взаимодействия устройств между собой. Именно на этом этапе возникает понятие "устройство" в современном его понимании. Появляются процессор, материнская плата, звуковая плата, видеокарта, дисковод.
Компьютер стараются сделать максимально простым для сборки и для апгрейда, все кажется просто и логично... НО! Как быть с программным обеспечением? Откуда программа, запущенная на таком компьютере, узнает с каким устройством она работает? Может на компьютере установлена мощная видеокарта, а может самая простая? Предположим мы пишем текстовый редактор. С помощью каких программных средств организовывать вывод графического интерфейса? Можно, конечно, "зашить" поддержку всех существующих на данный момент видеокарт, однако это много работы, плюс как быть, если видеокарта увидела свет уже после выхода программного продукта? Выпускать обновления? Это же сколько работы для программистов фирмы, выпускающей наш текстовый редактор? Совершенно очевидно, что это тупиковый путь.
Архитекторы IBM нашли более элегантное решение: API - Application Programm Interface (программный интерфейс приложений). Коротко суть идеи вот в чем: придумывается некий стандартный "язык" на котором все приложения должны сообщать команду устройству, возвращаясь к примеру с видеокартой, придумывается набор методов рисования, вызывая которые приложение может рисовать на экране некие примитивы: точку, линию, прямоугольник, текст. Из этих методов разработчики операционной системы составляют целые библиотеки и бесплатно распространяют для всех ключевых, на данный момент, языков программирования.
Получается программисту, который работает над текстовым редактором, для того чтобы нарисовать на экране линию, совсем не обязательно заботиться о поддержке всех известных видеокарт, а достаточно просто написать фрагмент кода, вроде:
ДОБАВИТЬ("библиотека_видеопроцедур");
НАРИСОВАТЬ_ЛИНИЮ(0,0,100,100);
Таким образом пользовательские приложения научились общаться с операционной системой на стандартном языке, однако это не решило проблемы множества устройств, обладающих разными возможностями. Как операционная система узнает каким образом подавать команду именно этому устройству? Вот тут-то и придумали драйвера. Идея такова: пусть операционная система подает специальной программе сигналы на стандартном, для этой ОС, языке, а уже эта программа будет давать команды устройству. Эта программа, драйвер, пишется для каждого устройства отдельно, поэтому она умеет с ним общаться, пишется и распространяется драйвер фирмой, которая разработала устройство.
Слово driver можно перевести как "управлятель" в этом контексте так называют программу, предназначенную для обеспечения взаимодействия операционной системы и устройства. Путь, который сигнал проходит от момента возникновения "желания" приложения нарисовать примитив, до момента появления его на экране монитора, можно символически изобразить так:
1. Приложение вызывает API-метод операционной системы.
2. Операционная система обращается к драйверу видеокарты и на стандартном языке дает инструкции по рисованию примитива.
3. Драйвер видеокарты, используя низкоуровневый, уникальный для этой модели видеокарты, язык, дает ей (видеокарте) инструкции для рисования примитива.
4. Видеокарта преобразует цифровой сигнал от драйвера в электрический ток, который передается монитору.
5. Монитор, интерпретируя сигнал, пришедший ему, рисует изображение.
На первый взгляд неоправданная сложность, однако использование такой модели дает множество преимуществ, некоторые из них, я описал выше.
Надеюсь, после прочтения этой статьи, читателю стало понятно что такое драйвер, и почему он возник.
Автор: Kosmich
Оригинал статьи: Цератопс.ру
Источник: kosmich