Aygıt sürücüsü - Device driver

İçinde bilgi işlem, bir aygıt sürücüsü bir bilgisayar programı belirli bir türü çalıştıran veya kontrol eden cihaz bir bilgisayar.[1] Bir sürücü bir yazılım sağlar arayüz -e donanım cihazlar, etkinleştirme işletim sistemleri ve kullanılan donanım hakkında kesin ayrıntıları bilmeye gerek kalmadan donanım işlevlerine erişmek için diğer bilgisayar programları.

Bir sürücü cihazla iletişim kurar. bilgisayar veriyolu veya donanımın bağlandığı iletişim alt sistemi. Zaman arama program bir rutin sürücüde, sürücü aygıta komutlar verir. Aygıt veriyi sürücüye geri gönderdikten sonra, sürücü orijinal çağıran programdaki rutinleri başlatabilir.

Sürücüler donanıma bağlıdır ve işletim sistemine özeldir. Genellikle sağlarlar kesmek gerekli herhangi bir işlem asenkron zamana bağlı donanım arayüzü.[2]

Amaç

Aygıt sürücülerinin temel amacı, bir donanım aygıtı ile uygulamalar arasında çevirmen olarak hareket ederek soyutlama sağlamaktır. işletim sistemleri onu kullanan.[1] Programcılar, son kullanıcının kullandığı belirli donanımdan bağımsız olarak daha yüksek seviyeli uygulama kodu yazabilir. Örneğin, bir ile etkileşim için yüksek seviyeli bir uygulama seri port sadece "veri gönderme" ve "veri alma" için iki işlevi olabilir. Daha düşük bir seviyede, bu işlevleri uygulayan bir aygıt sürücüsü, bir kullanıcının bilgisayarına kurulan belirli seri bağlantı noktası denetleyicisiyle iletişim kuracaktır. Kontrol etmek için gereken komutlar 16550 UART kontrol etmek için gereken komutlardan çok farklıdır. FTDI seri bağlantı noktası dönüştürücü, ancak her donanıma özgü aygıt sürücüsü özetler bu ayrıntıları aynı (veya benzer) yazılım arayüzüne aktarın.

Geliştirme

Bir aygıt sürücüsünün yazılması, donanımın ve yazılımın belirli bir sürücü için platform işlevi. Sürücüler, çalışmak için donanım işlevlerine düşük seviyeli erişim gerektirdiğinden, sürücüler genellikle ayrıcalıklı ve bir şeyler ters giderse sistemin çalışma sorunlarına neden olabilir. Buna karşılık, modern sistemdeki çoğu kullanıcı düzeyinde yazılım işletim sistemleri sistemin geri kalanını büyük ölçüde etkilemeden durdurulabilir. Hatta çalışan sürücüler bile Kullanıcı modu cihaz bir sistemi çökertebilir hatalı programlanmış. Bu faktörler problemleri teşhis etmeyi daha zor ve tehlikeli hale getirir.[3]

Sürücüleri yazma görevi bu nedenle genellikle Yazılım mühendisleri veya bilgisayar mühendisleri donanım geliştirme şirketleri için çalışan. Bunun nedeni, donanımlarının tasarımı hakkında çoğu yabancıdan daha iyi bilgiye sahip olmalarıdır. Dahası, geleneksel olarak donanımda kabul edildi üretici firma müşterilerinin donanımlarını en iyi şekilde kullanabilmelerini garanti etme ilgisi. Tipik olarak Mantıksal Aygıt Sürücüsü (LDD), işletim sistemi satıcısı tarafından yazılırken Fiziksel Aygıt Sürücüsü (PDD), aygıt satıcısı tarafından uygulanır. Bununla birlikte, son yıllarda, satıcı olmayanlar tescilli cihazlar için, özellikle ücretsiz ve açık kaynak işletim sistemleri. Bu gibi durumlarda, donanım üreticisinin aygıtın nasıl iletişim kurduğu hakkında bilgi sağlaması önemlidir. Bu bilgi bunun yerine şu şekilde öğrenilebilir: tersine mühendislik Bu, donanımda yazılımda olduğundan çok daha zordur.

Microsoft kötü yazılmış aygıt sürücülerinden kaynaklanan sistem kararsızlığını, sürücü geliştirme için yeni bir çerçeve oluşturarak azaltmaya çalıştı. Windows Sürücü Vakfı (WDF). Bu içerir Kullanıcı Modu Sürücü Çerçevesi (UMDF) belirli sürücü türlerinin geliştirilmesini teşvik eden - özellikle mesaj tabanlı protokol aygıtlarıyla iletişim kurmak için - kullanıcı modu sürücüleri olarak. Bu tür sürücüler arızalanırsa, sistem kararsızlığına neden olmazlar. Çekirdek Modu Sürücü Çerçevesi (KMDF) modeli, çekirdek modu aygıt sürücülerinin geliştirilmesine izin vermeye devam eder, ancak G / Ç işlemlerinin iptali, güç yönetimi ve tak ve çalıştır aygıt desteği dahil olmak üzere sorunlara neden olduğu bilinen işlevlerin standart uygulamalarını sağlamaya çalışır.

elma üzerinde sürücüleri geliştirmek için açık kaynaklı bir çerçeveye sahiptir Mac os işletim sistemi, G / Ç Kiti denir.

İçinde Linux programcılar, aygıt sürücülerini çekirdek ayrı ayrı yüklenebilir modüller veya kullanıcı modu sürücüleri olarak (USB aygıtları gibi çekirdek arabirimlerinin bulunduğu belirli aygıt türleri için). Makedev ttyS (terminal), lp () dahil olmak üzere Linux'taki cihazların bir listesini içerirparalel bağlantı noktası ), hd (disk), döngü ve ses (bunlara mikser, sıralayıcı, dsp ve ses).[4]

Microsoft Windows .sys dosyalar ve Linux .ko dosyaları yüklenebilir aygıt sürücüleri içerebilir. Yüklenebilir aygıt sürücülerinin avantajı, yalnızca gerektiğinde yüklenebilmeleri ve ardından kaldırılabilmeleri ve böylece çekirdek belleğinden tasarruf etmeleridir.

Çekirdek modu ve kullanıcı modu

Cihaz sürücüleri, özellikle modern Microsoft Windows platformlar, içinde çalışabilir çekirdek modu (X86 CPU'larda 0 çal ) veya içinde Kullanıcı modu (X86 CPU'larda Zil 3).[5] Bir sürücüyü kullanıcı modunda çalıştırmanın birincil faydası, kötü yazılmış bir kullanıcı modu aygıt sürücüsü çekirdek belleğinin üzerine yazarak sistemi çökertemeyeceğinden, geliştirilmiş kararlılıktır.[6] Öte yandan, kullanıcı / çekirdek modu geçişleri genellikle önemli bir performans yükü getirir, bu nedenle düşük gecikmeli ağ için çekirdek modu sürücülerini tercih eder.

Çekirdek alanına, yalnızca sistem çağrıları kullanılarak kullanıcı modülü tarafından erişilebilir. UNIX kabuğu veya diğer GUI tabanlı uygulamalar gibi son kullanıcı programları, kullanıcı alanının bir parçasıdır. Bu uygulamalar, çekirdek destekli işlevler aracılığıyla donanımla etkileşime girer.

Başvurular

Modernin çeşitliliği nedeniyle donanım ve işletim sistemleri, sürücüler birçok farklı ortamda çalışır.[7] Sürücüler olabilir arayüz ile:

Aygıt sürücüleri için genel soyutlama düzeyleri şunları içerir:

  • Donanım için:
    • Doğrudan arayüz oluşturma
    • Yazmak veya okumak cihaz kontrol kaydı
    • Daha üst düzey bir arayüz kullanarak (ör. Video BIOS )
    • Daha düşük seviyeli başka bir aygıt sürücüsü kullanma (örneğin, disk sürücülerini kullanan dosya sistemi sürücüleri)
    • Tamamen farklı bir şey yaparken donanımla çalışmayı simüle etme[8]
  • Yazılım için:
    • İşletim sisteminin donanım kaynaklarına doğrudan erişmesine izin verme
    • Yalnızca uygulama ilkeller
    • Sürücü olmayan yazılımlar için bir arayüz uygulama (ör. TWAIN )
    • Bazen oldukça üst düzey bir dil uygulamak (ör. PostScript )

Bu nedenle, belirli bir donanım için doğru aygıt sürücülerinin seçilmesi ve yüklenmesi genellikle bilgisayar sistemi yapılandırmasının önemli bir bileşenidir.[9]

Sanal aygıt sürücüleri

Sanal aygıt sürücüleri, aygıt sürücülerinin belirli bir çeşidini temsil eder. Bir donanım aygıtını taklit etmek için kullanılırlar, özellikle sanallaştırma ortamlar, örneğin DOS program bir Microsoft Windows bilgisayar ya da misafir işletim sistemi çalıştırıldığında, örneğin bir Xen ev sahibi. Konuk işletim sisteminin donanımla iletişim kurmasını sağlamak yerine, sanal aygıt sürücüleri ters rolü üstlenir ve bir donanım parçasını taklit eder, böylece konuk işletim sistemi ve sürücüleri bir sanal makine gerçek donanıma erişme yanılsamasına sahip olabilir. Konuk işletim sisteminin donanıma erişme girişimleri, ana bilgisayar işletim sistemindeki sanal aygıt sürücüsüne örn.işlev çağrıları. Sanal aygıt sürücüsü ayrıca simüle edilmiş işlemci düzeyinde olaylar da gönderebilir. keser sanal makineye.

Sanal cihazlar, sanallaştırılmamış bir ortamda da çalışabilir. Örneğin, bir sanal ağ adaptörü ile kullanılır sanal özel ağ sanal iken disk cihaz ile kullanılır iSCSI. Sanal aygıt sürücülerine iyi bir örnek, Daemon araçları.

Aşağıdakiler gibi sanal aygıt sürücülerinin birkaç çeşidi vardır: VxD'ler, VLM'ler ve VDD'ler.

Açık kaynaklı sürücüler

Solaris yaygın olarak kullanılan aygıt sürücülerinin açıklamaları:

  • fas: Hızlı / geniş SCSI denetleyicisi
  • hme: Hızlı (10/100 Mbit / s) Ethernet
  • isp: Diferansiyel SCSI denetleyicileri ve SunSwift kartı
  • glm: (Gigabaud Bağlantı Modülü[12]) UltraSCSI denetleyicileri
  • scsi: Küçük Bilgisayar Seri Arabirimi (SCSI) aygıtları
  • sf: soc + veya sosyal Fiber Kanal Tahkim Döngüsü (FCAL)
  • soc: SPARC Storage Array (SSA) denetleyicileri ve denetim aygıtı
  • sosyal: FCAL için seri optik denetleyiciler (soc +)

API'ler

Tanımlayıcılar

Bir cihaz PCI veri yolu veya USB, 4 taneden oluşan iki kimlik ile tanımlanır onaltılık her biri numara. Satıcı kimliği, aygıtın satıcısını tanımlar. Cihaz kimliği, o üreticiden / satıcıdan belirli bir cihazı tanımlar.

Bir PCI aygıtı, genellikle aygıtın ana yongası için bir kimlik çiftine ve ayrıca, yonga üreticisinden farklı olabilen, satıcıyı tanımlayan bir alt sistem kimlik çiftine sahiptir.

Ayrıca bakınız

Referanslar

  1. ^ a b "Tüm aygıt sürücüsü nedir?". WhatIs.com. TechTarget. Alındı 19 Mart 2018.
  2. ^ EMC Eğitim Hizmetleri (2010). Bilgi Depolama ve Yönetimi: Dijital Bilgilerin Saklanması, Yönetilmesi ve Korunması. John Wiley & Sons. ISBN  9780470618332.
  3. ^ Burke, Timothy (1995). Aygıt sürücülerini yazma: öğretici ve referans. Dijital Basın. ISBN  9781555581411.
  4. ^ "MAKEDEV - Linux Komutu - Unix Komutu". Linux.about.com. 2009-09-11. Alındı 2009-09-17.
  5. ^ "Kullanıcı modu ile Kernel modu Sürücüler". Microsoft. 2003-03-01. Arşivlenen orijinal 2008-03-09 tarihinde. Alındı 2008-03-04.
  6. ^ "Kullanıcı Modu Sürücü Çerçevesine (UMDF) Giriş". Microsoft. 2006-10-10. Alındı 2008-03-04.
  7. ^ Deborah Morley (2009). Bilgisayarları Anlamak 2009: Bugün ve Yarın. Cengage Learning. ISBN  9780324830132.
  8. ^ Bilgisayar Çevre Birimleri ve Arayüzleri. Teknik Yayınlar Pune. Ocak 2008. s. 5–8. ISBN  978-8184314748. Alındı 2016-05-03.
  9. ^ "Aygıt Sürücüleri nedir ve neden onlara ihtiyacımız var?". drivers.com. 17 Nisan 2015. Alındı 19 Mart, 2018.
  10. ^ "CCISS". SourceForge. 2010. Alındı 2010-08-11. Donanım RAID özelliği sağlayan HP (önceden Compaq) Smart Array denetleyicilerinin sürücüleri.
  11. ^ Russell, Steve; et al. (2003-10-21). Kelime Kısaltmaları ve Baş Harf Kısaltmaları. IBM eserver xSeries 440 ve VMware ESX Serve ile Sunucu Konsolidasyonu. IBM Uluslararası Teknik Destek Organizasyonu. s. 207. ISBN  0-7384-2684-9. Alındı 2011-08-14.[kalıcı ölü bağlantı ]
  12. ^ "ABD Patenti 5969841 - alınan güç algılama sinyaline sahip Gigabaud bağlantı modülü". PatentStorm LLC. Arşivlenen orijinal 2011-06-12 tarihinde. Alındı 2009-09-08. Bir ana cihaz ile bir seri aktarım ortamı arasında çift yönlü veri aktarımlarını gerçekleştirmek için geliştirilmiş bir Gigabaud Bağlantı Modülü (GLM) sağlanmıştır.
  13. ^ "Birleşik Ses Modeli (Windows CE 5.0)". msdn.microsoft.com. Alındı 2016-09-19.
  14. ^ Dell ABD. "DCH sürücüleri nedir ve neden onlar hakkında bilmeniz gerekir? | Dell US". www.dell.com. Alındı 2020-10-29.
  15. ^ "dxd - dynax sürücü çerçevesi: Ana Sayfa". dxd.dynax.at. Alındı 2016-09-19.

Dış bağlantılar