Udev - udev - Wikipedia

udev
VývojářiGreg Kroah-Hartman a Kay Sievers
První vydáníListopad 2003; Před 17 lety (2003-11)
Stabilní uvolnění247 (26. listopadu 2020; Před 22 dny (2020-11-26)) [±][1]
Úložiště Upravte to na Wikidata
NapsánoC
Operační systémLinuxové jádro
TypUzel zařízení
LicenceGPLv2
webová stránkaOficiální webové stránky

udev (userspace / dev) je správce zařízení pro Linuxové jádro. Jako nástupce devfsd a hotplug, udev primárně spravuje uzly zařízení v / dev adresář. Současně udev také zpracovává všechny uživatelský prostor události vyvolané při přidání nebo odebrání hardwarových zařízení ze systému, včetně firmware načítání podle požadavků určitých zařízení.

Odůvodnění

Je to operační systém je jádro který je zodpovědný za poskytnutí abstraktního rozhraní hardwaru ke zbytku softwaru. Být a monolitické jádro, Linuxové jádro dělá přesně to a ovladače zařízení jsou součástí linuxového jádra, které tvoří více než 50% jeho zdrojového kódu.[2] K hardwaru lze přistupovat prostřednictvím systémová volání nebo nad jejich uzly zařízení.

Umět pracovat s periferními zařízeními, která jsou hotplug - uživatelsky přívětivý způsob, část zpracování všech těchto hardwarových zařízení podporujících hotplug byla předána z jádra do démon běží v uživatelském prostoru. Běh v uživatelském prostoru slouží účelům zabezpečení a stability.

Design

Ovladače zařízení jsou součástí linuxového jádra, ve kterém jejich primární funkce zahrnují zjišťování zařízení, detekci změn stavu zařízení a podobné hardwarové funkce na nízké úrovni. Po načtení ovladače zařízení do paměti z jádra jsou detekované události odeslány démonovi uživatelského prostoru udevd. Je to správce zařízení, udevd, který zachytí všechny tyto události a poté rozhodne, co se bude dít dál. Pro tohle, udevd má velmi komplexní sadu konfiguračních souborů, které může správce počítače upravit podle svých potřeb.

  • V případě, že je nové USB zařízení připojeno přes USB, udevd je upozorněn jádrem a sám upozorňuje udisksd-démona. Ten démon pak mohl připojit souborové systémy.
  • V případě, že je k ethernetové síťové kartě připojen nový ethernetový kabel, udevd je upozorněn jádrem a sám upozorňuje démona NetworkManager. Síťový démon NetworkManager mohl spustit dhclient pro danou síťovou kartu nebo nakonfigurovat podle nějaké ruční konfigurace.

Složitost toho nutí autory aplikací, aby znovu implementovali logiku podpory hardwaru. Některá hardwarová zařízení také vyžadují privilegované pomocné programy, které je připraví k použití. Ty musí být často vyvolány způsoby, které mohou být nepříjemné vyjádřit pomocí modelu oprávnění Unix (například umožnit uživatelům připojit se bezdrátové sítě pouze pokud jsou přihlášeni do video konzoly). Autoři aplikace se uchylují k používání setuid binární soubory nebo spustit službu démoni poskytnout vlastní kontrolu přístupu a oddělení privilegií, což může pokaždé způsobit bezpečnostní mezery.[3]

HAL byl vytvořen, aby se s tím vyrovnal, ale nyní je zastaralý ve většině distribucí Linuxu.

Přehled

Na rozdíl od tradičních Unix systémy, kde uzly zařízení v / dev adresář byly statickou sadou souborů, správce zařízení udev Linuxu dynamicky poskytuje pouze uzly pro zařízení skutečně přítomná v systému. Ačkoli devfs slouží k zajištění podobné funkce, Greg Kroah-Hartman uvedl řadu důvodů[4] pro upřednostnění udev před devfs:

  • udev podporuje trvalé pojmenování zařízení, které nezávisí například na pořadí, v jakém jsou zařízení připojena k systému. Výchozí nastavení udev poskytuje trvalé názvy úložných zařízení. Jakýkoli pevný disk je rozpoznán podle jeho jedinečného ID souborového systému, názvu disku a fyzického umístění na hardwaru, ke kterému je připojen.
  • udev vykonává zcela v uživatelský prostor, na rozdíl od devfs prostor jádra. Jedním z důsledků je, že udev přesunul zásady pojmenování z jádra a může spouštět libovolné programy, které před vytvořením uzlu vytvoří název zařízení z jeho vlastností; tam je také celý proces přerušitelný a běží s nižší prioritou.

Udev jako celek je rozdělen do tří částí:

  • Knihovna libudev který umožňuje přístup k informacím o zařízení; bylo začleněno do systemd 183 softwarový balíček.[5]
  • Uživatelský prostor démon udevd který spravuje virtuální / dev.
  • Správní příkazový řádek nástroj udevadm pro diagnostiku.

Systém přijímá hovory z jádra prostřednictvím netlink zásuvka. Použité starší verze hotplug, přidáním odkazu na sebe v /etc/hotplug.d/default s tímto účelem.

Úkon

udev byl začleněn do systemd 183[5]

udev je obecný správce zařízení běžící jako démon v systému Linux a poslech (přes a netlink socket) k uevents jádro odešle, pokud je inicializováno nové zařízení nebo je zařízení odebráno ze systému. Balíček udev je dodáván s rozsáhlou sadou pravidel, která odpovídají exportovaným hodnotám události a vlastnostem objeveného zařízení. Odpovídající pravidlo případně pojmenuje a vytvoří uzel zařízení a spustí nakonfigurované programy pro nastavení a konfiguraci zařízení.

Pravidla udev se mohou shodovat s vlastnostmi, jako je subsystém jádra, název zařízení jádra, fyzické umístění zařízení nebo vlastnosti, jako je sériové číslo zařízení. Pravidla mohou také vyžadovat informace od externích programů k pojmenování zařízení nebo k zadání vlastního názvu, který bude vždy stejný, bez ohledu na pořadí, v jakém zařízení zařízení zjistí.

V minulosti běžným způsobem, jak používat udev v systémech Linux, bylo nechat jej posílat události přes soket na HAL, které by prováděly další akce specifické pro zařízení. Například HAL upozorní další software spuštěný v systému, že nový hardware dorazil, vydáním zprávy o vysílání na serveru D-Bus IPC systém všem zájemcům procesy. Tímto způsobem mohou pracovní plochy jako GNOME nebo K Desktopové prostředí 3 mohl začít prohlížeč souborů procházet souborové systémy nově připojených USB flash disky a SD karty.[6]

V polovině roku 2011 byla podpora HAL zastaralá většinou distribucí Linuxu i KDE, GNOME[7] a Xfce[8] desktopová prostředí, mimo jiné. Funkce dříve ztělesněná v HAL byla integrována do samotného udev nebo přesunuta do samostatného softwaru, jako jsou udisks a síla.

  • udev poskytuje nízkoúrovňový přístup do linuxového stromu zařízení. Umožňuje programům vyjmenovat zařízení a jejich vlastnosti a dostávat oznámení, když zařízení přicházejí a odcházejí.
  • dbus je rámec, který umožňuje programům vzájemně komunikovat bezpečně, spolehlivě as objektově orientovaným programovacím rozhraním na vysoké úrovni.
  • udisks (dříve známý jako DeviceKit-disky) je démon, který sedí nad libudevem a dalšími rozhraními jádra a poskytuje rozhraní vysoké úrovně pro úložná zařízení a je přístupný prostřednictvím dbus k aplikacím.
  • upower (dříve známý jako DeviceKit-power) je démon, který sedí nad libudevem a dalšími rozhraními jádra a poskytuje rozhraní na vysoké úrovni pro správu napájení a je přístupný prostřednictvím dbus k aplikacím.
  • NetworkManager je démon, který sedí nad libudevem a dalšími rozhraními jádra (a několika dalšími démony) a poskytuje rozhraní na vysoké úrovni pro konfiguraci a nastavení sítě a je přístupný přes dbus do aplikací.[9]

udev přijímá zprávy z jádra a předává je démonům subsystému, jako je Network Manager. Aplikace komunikují se správcem sítě přes D-Bus.

HAL je zastaralý a používá ho pouze starší kód. Ubuntu 10.04 dodáván bez HAL. Zpočátku byl plánován nový démon DeviceKit, který by nahradil určité aspekty HAL, ale v březnu 2009 byla podpora DeviceKit ukončena ve prospěch přidání stejného kódu do udev jako balíčku: udev-extras a některé funkce se nyní přesunuly do udev proper.

Dějiny

udev byl představen v Linux 2.5. Linuxové jádro verze 2.6.13 představilo nebo aktualizovalo novou verzi uevent rozhraní. Systém používající novou verzi udev se nespustí s jádry staršími než 2.6.13, pokud není udev deaktivován a tradiční / dev adresář se používá pro přístup k zařízení.

V dubnu 2012 udev's kódová základna byl sloučen do systemd zdrojový strom, díky čemuž je systemd 183 první verzí, která obsahuje udev.[5][10][11] V říjnu 2012 Linus Torvalds kritizován Kay Sievers přístup k údržbě udev a opravě chyb souvisejících s firmware načítání, uvedení:[12]

Ano, dělat to v jádře je „robustnější“. Ale nehrajte hry a přestaňte lhát. Je to robustnější, protože máme pečovatele, kteří se o to starají, a protože víme, že regrese nejsou něco, s čím bychom mohli hrát rychle a volně. Pokud se něco zlomí a my nevíme, jaká je správná oprava pro tento zlom, my vrátit se věc, která se zlomila. Takže ano, jasně jsme na tom lépe v jádře. Ne proto, že načtení firmwaru nelze provést v uživatelském prostoru. Ale jednoduše proto, že údržba udev od doby, kdy se ho Greg vzdal, šla z kopce.

V roce 2012 Gentoo Linux projekt vytvořil a Vidlička systemd's udev codebase, aby se zabránilo závislosti na architektuře systemd. Výsledná vidlice se volá eudev a zpřístupňuje funkčnost udev bez systemd. Stanoveným cílem projektu je udržet eudev na sobě nezávislý Linuxová distribuce nebo inic Systém.[13] Projekt Gentoo popisuje eudev následovně:[14]

eudev je vidlice systemd-udev s cílem získat lepší kompatibilitu se stávajícím softwarem, jako je OpenRC a Povýšenec, starší jádra, různé řetězce nástrojů a cokoli jiného požadovaného uživateli a různé distribuce.

29. května 2014 byla ze systému systemd zrušena podpora načítání firmwaru prostřednictvím udev, protože bylo rozhodnuto, že je načtením firmwaru úkolem jádra.[15] O dva dny později, Lennart Poettering navrhl tuto opravu odložit na kdbus začíná být využíván udev; v tomto okamžiku se plánuje přepnout udev na použití kdbus jako základního systému zasílání zpráv a zbavit se přenosu založeného na netlinkovém propojení mezi uživatelským prostorem a uživatelem.[16]

Autoři

udev vyvinul Greg Kroah-Hartman a Kay Sievers, s velkou pomocí od Dan Stekloff, mezi ostatními.

Reference

  1. ^ Vydání v247, 26. listopadu 2020, vyvoláno 27. listopadu 2020
  2. ^ Marti, Done. „Ztrácejí nejlepší vývojáři Linuxu vůli kódovat?“. ComputerworldUK. Citováno 2016-06-19.
  3. ^ Pennington, Havoc (10.7.2003), Aby hardware fungoval
  4. ^ Greg Kroah-Hartman. "udev a devfs - poslední slovo". Archivovány od originál (Prostý text ) dne 09.07.2011. Citováno 2008-01-24.
  5. ^ A b C "systemd / systemd". GitHub. Citováno 2016-08-21.
  6. ^ „Dynamic Device Management in Udev“ (PDF). Linux Magazine. 2006-10-01. Citováno 2008-07-14.
  7. ^ „HALRemoval“. 2011-06-28. Citováno 2011-09-13.
  8. ^ „Thunar-volman a podpora HAL v Xfce“. 2010-01-17. Citováno 2017-12-25.
  9. ^ Lennart Poettering (2010-04-25). „Vztah mezi udev, hal, Dbus a DeviceKit?“.
  10. ^ Sievers, Kay (03.04.2012). "Budoucnost zdrojového stromu udev". linux-hotplug (Poštovní seznam). Citováno 2013-05-22.
  11. ^ Sievers, Kay, "Potvrdit import udev do systemd", systemd, vyvoláno 2013-05-22
  12. ^ Linus Torvalds (03.10.2012). „Re: udev breakages“. linux-kernel (Poštovní seznam). Citováno 2014-10-28.
  13. ^ „gentoo / eudev - README.md“. Citováno 2017-12-25.
  14. ^ „Projekty Gentoo Linux - projekt Gentoo eudev“. Citováno 2017-12-25.
  15. ^ „[systemd-devel] [PATCH] Zrušte zavaděč firmwaru udev“. 2014-05-29.
  16. ^ „[systemd-devel] [PATCH] Zrušte zavaděč firmwaru udev“. 2014-05-31.

externí odkazy