Konfigurační prostor PCI - PCI configuration space

Konfigurační prostor PCI je základní způsob, jakým Konvenční PCI, PCI-X a PCI Express provést automatickou konfiguraci karet vložených do jejich sběrnice.

Přehled

Zařízení PCI mají sadu registrů označovaných jako konfigurační prostor a PCI Express rozšířený konfigurační prostor pro zařízení. Registry konfiguračního prostoru jsou mapovány na paměťová místa. Ovladače zařízení a diagnostický software musí mít přístup do konfiguračního prostoru a operační systémy obvykle používají rozhraní API k povolení přístupu do konfiguračního prostoru zařízení. Když operační systém nemá definované přístupové metody nebo API pro požadavky na konfigurační prostor mapované paměti, má ovladač nebo diagnostický software zátěž pro přístup do konfiguračního prostoru způsobem, který je kompatibilní s příslušnými pravidly přístupu operačního systému. Ve všech systémech se ovladačům zařízení doporučuje používat API poskytovaná operačním systémem pro přístup do konfiguračního prostoru zařízení.

Technické informace

Jedním z hlavních vylepšení PCI místní sběrnice měl nad jinými I / O architekturami jeho konfigurační mechanismus. Kromě normálních paměťově mapovaných a I / O portových prostorů má každá funkce zařízení na sběrnici a konfigurační prostor, který je 256 bajtů dlouhý, adresovatelný znalostí 8bitové PCI autobus, pětibitová zařízení a tříbitová čísla funkcí zařízení (běžně označovaná jako BDF nebo B / D / F, ve zkratce sběrnice / zařízení / funkce). To umožňuje až 256 sběrnic, každá s až 32 zařízeními, z nichž každá podporuje osm funkcí. Jedna rozšiřující karta PCI může reagovat jako zařízení a musí implementovat alespoň číslo funkce nula. Prvních 64 bajtů konfiguračního prostoru je standardizovaných; zbytek je k dispozici pro účely definované prodejcem.

Aby bylo možné standardizovat více částí konfiguračního prostoru bez konfliktu s existujícím použitím, může existovat seznam schopnosti definováno během prvních 192 bajtů konfiguračního prostoru PCI. Každá funkce má jeden bajt, který popisuje, o kterou schopnost se jedná, a jeden bajt, který ukazuje na další funkci. Počet dalších bajtů závisí na ID schopnosti. Pokud jsou schopnosti využívány, trochu v Postavení registr je nastaven a ukazatel na první v propojeném seznamu schopností je uveden v souboru Víčko. ukazatel registr definovaný ve standardizovaných registrech.

PCI-X 2.0 a PCI Express představil rozšířený konfigurační prostor, až 4096 bajtů. Jedinou standardizovanou částí rozšířeného konfiguračního prostoru jsou první čtyři bajty v 0x100 které jsou začátkem seznamu rozšířených schopností. Rozšířené funkce jsou velmi podobné běžným funkcím, kromě toho, že mohou odkazovat na jakýkoli bajt v rozšířeném konfiguračním prostoru (pomocí 12 bitů místo osmi), mají čtyřbitové číslo verze a ID 16bitové funkce. ID rozšířených schopností se překrývají s ID běžných schopností, ale neexistuje žádná šance na záměnu, protože jsou v samostatných seznamech.

Standardizované registry

Standardní registry záhlaví konfiguračního prostoru PCI typu 0 (bez můstku)

The ID zařízení (DID) a ID dodavatele (VID) registry identifikují zařízení (například IC ) a běžně se jim říká PCI ID. 16bitové ID dodavatele přiděluje PCI-SIG. 16bitové ID zařízení poté přidělí dodavatel. Existuje neaktivní projekt ke shromažďování všech známých ID prodejců a zařízení. (Viz externí odkazy níže.)

The Postavení register slouží k hlášení, které funkce jsou podporovány a zda došlo k určitým druhům chyb. The Příkaz registr obsahuje bitovou masku funkcí, které lze jednotlivě povolit a zakázat. The Typ záhlaví hodnoty registru určují různá rozložení zbývajících 48 bajtů (64-16) záhlaví, v závislosti na funkci zařízení. To znamená záhlaví typu 1 pro kořenový komplex, přepínače a můstky. Potom zadejte 0 pro koncové body. The Velikost řádku mezipaměti registr musí být naprogramován dříve, než je zařízení informováno, že může použít transakci zápisu do paměti a zneplatnění. Normálně by to mělo odpovídat Vyrovnávací paměť CPU velikost řádku, ale správné nastavení závisí na systému. Tento registr se nevztahuje na PCI Express.

The ID subsystému (SSID) a ID dodavatele subsystému (SVID) odlišit konkrétní model (například přídavnou kartu). Zatímco ID prodejce je ID chipset výrobce, je ID dodavatele subsystému identifikačním číslem výrobce karty. ID subsystému je přiřazeno prodejcem subsystému ze stejného číselného prostoru jako ID zařízení. Jako příklad v případě bezdrátové síťové karty, může být výrobcem čipové sady Broadcom nebo Atheros a může to být i výrobce karty Netgear nebo D-Link. Obecně kombinace Vendor ID – ID zařízení označuje, které Řidič hostitel by se měl načíst, aby zvládl zařízení, protože všechny karty se stejnou kombinací VID: DID mohou být zpracovány stejným ovladačem. Kombinace ID dodavatele subsystému – ID subsystému identifikuje kartu, což je druh informací, které může řidič použít k provedení drobné změny specifické pro kartu v její činnosti.

Výčet sběrnice

Chcete-li adresovat zařízení PCI, musí být povoleno mapováním do adresního prostoru I / O portu systému nebo do adresového prostoru mapovaného v paměti. Firmware systému, ovladače zařízení nebo operační systém naprogramujte Registry základních adres (běžně nazývané BAR) informovat zařízení o mapování adres zápisem konfiguračních příkazů do řadiče PCI. Protože všechna zařízení PCI jsou v neaktivní stavu po obnovení systému, nebudou jim přiděleny žádné adresy, kterými by operační systém nebo ovladače zařízení může s nimi komunikovat. Buď BIOS nebo operační systém geograficky adresuje sloty PCI (například první slot PCI, druhý slot PCI nebo třetí slot PCI atd., na základní deska ) prostřednictvím řadiče PCI pomocí signálů IDSEL (výběr inicializačního zařízení) na slot.

Bity PCI BAR
BityPopisHodnoty
Pro všechny PCI BARy
0Typ regionu0 = paměť
1 = I / O
Pro paměťové lišty
2-1Vyhledatelné0 = libovolný 32bitový
1 = < 1 MiB
2 = libovolný 64bitový
3Přednastavitelné0 = ne
1 = ano
31-4Základní adresa16 bajtů zarovnáno
Pro I / O BARy
1Rezervováno
31-2Základní adresa4-byte zarovnáno

Protože pro systém BIOS nebo operační systém neexistuje přímá metoda, která by určovala, které sloty PCI mají nainstalovaná zařízení (ani aby určily, které funkce zařízení implementuje), musí být sběrnice PCI vyjmenovaný. Výčet sběrnice se provádí pokusem o načtení registru dodavatele a ID zařízení (VID / DID) pro každou kombinaci čísla sběrnice a čísla zařízení na funkci zařízení # 0. Číslo zařízení, odlišné od DID, je pouze sekvenční zařízení číslo v tom autobuse. Navíc poté, co je detekován nový most, je definováno nové číslo sběrnice a výčet zařízení se restartuje na nulu čísla zařízení.

Pokud z funkce # 0 zařízení není přijata žádná odpověď, pán autobusu provede přerušení a vrátí hodnotu all-bits-on (FFFFFFFF v šestnáctkové soustavě), což je neplatná hodnota VID / DID, takže ovladač zařízení může zjistit, že zadaná kombinace sběrnice / číslo_zařízení / funkce (B / D / F) není k dispozici. Takže když čtení na nulu ID funkce pro danou sběrnici / zařízení způsobí přerušení hlavního (iniciátoru), pak je třeba předpokládat, že na této sběrnici neexistuje žádné funkční zařízení, protože zařízení jsou povinna implementovat číslo funkce nula. V tomto případě není načtení zbývajících čísel funkcí (1–7) nutné, protože také nebudou existovat.

Když je čtení na zadanou kombinaci B / D / F pro registr ID dodavatele úspěšné, ovladač zařízení ví, že existuje; zapíše všechny do svých BARů a přečte požadovanou velikost paměti zařízení v zakódované podobě. Návrh naznačuje, že všechny velikosti adresního prostoru jsou mocninou dvou a jsou přirozeně zarovnány.[1]

V tomto okamžiku program BIOS nebo operační systém naprogramuje adresy mapované paměti a adresy I / O portů do konfiguračního registru BAR zařízení. Tyto adresy zůstanou v platnosti, dokud systém zůstane zapnutý. Po vypnutí jsou všechna tato nastavení ztracena a postup se opakuje při příštím zapnutí systému. Protože celý tento proces je plně automatizovaný, uživatel je ušetřen úlohy ruční konfigurace jakéhokoli nově přidaného hardwaru změnou DIP přepínače na samotných kartách. Toto automatické zjišťování zařízení a přiřazení adresního prostoru je jak zapoj a hraj je implementován.

Pokud je nalezen most PCI-PCI, musí systém přiřadit sekundární sběrnici PCI za mostem jiné číslo sběrnice než nula a poté vyjmenovat zařízení na této sekundární sběrnici. Pokud se najde více mostů PCI, zjišťování pokračuje rekurzivně, dokud nebudou naskenovány všechny možné kombinace domén / sběrnic / zařízení.

Každá funkce nemůstkového zařízení PCI může implementovat až 6 BARů, z nichž každý může reagovat na různé adresy v I / O portu a adresně namapovaný paměťový prostor. Každý BAR popisuje region:[2][1]

Zařízení PCI může mít také možnost ROM který může obsahovat kód ovladače nebo informace o konfiguraci.

Hardwarová implementace

Při provádění a Konfigurační prostor přístup, zařízení PCI nedekóduje adresu, aby určilo, zda má reagovat, ale místo toho se podívá na Vyberte inicializační zařízení signál (IDSEL). Pro každý signál IDSEL existuje celosystémová jedinečná metoda aktivace. Zařízení PCI je povinno dekódovat pouze 11 bitů adresního / adresního prostoru (AD [10] až AD [0]) adresního prostoru (AD [10] až AD [0]) a může ignorovat dekódování 21 A / D signálů vysokého řádu (AD [31]) AD [11]), protože a Konfigurační prostor implementace přístupu má každý slot IDSEL připojený k jiné adresové / datové lince vyššího řádu AD [11] až AD [31]. Signál IDSEL je jiný pin pro každý slot zařízení PCI / adaptéru.

Konfigurace karty ve slotu n, můstek sběrnice PCI provádí cyklus přístupu do konfiguračního prostoru s registrem zařízení PCI, který má být adresován na linkách AD [7: 2] (AD [1: 0] jsou vždy nulové, protože registry jsou dvojitá slova (32 bitů)), a číslo funkce PCI uvedené na bitech AD [10: 8], se všemi nulami bitů vyššího řádu kromě AD [n+11] se používá jako signál IDSEL na daném slotu.

Aby se snížilo elektrické načítání dolů časově kritické (a tedy elektricky citlivé) sběrnice AD ​​[], je signál IDSEL na konektoru slotu PCI obvykle připojen k přiřazenému AD []n+11] pin přes rezistor. To způsobí, že signál IDSEL PCI dosáhne svého aktivního stavu pomaleji než ostatní signály sběrnice PCI (kvůli časové konstantě RC rezistoru a vstupní kapacitě odporu IDSEL pinu). Tím pádem Konfigurační prostor přístupy jsou prováděny pomaleji, aby bylo možné čas IDSEL signálu dosáhnout platné úrovně.

Skenování na sběrnici se provádí na platformě Intel přístupem ke dvěma definovaným standardizované porty. Tyto porty jsou Adresa konfiguračního prostoru (0xCF8) I / O port a Data konfiguračního prostoru (0xCFC) I / O port. Hodnota zapsaná do Adresa konfiguračního prostoru I / O port je vytvořen kombinací B / D / F hodnot a hodnoty adresy registrů do 32bitového slova.

Implementace softwaru

Konfigurace čtení a zápisu lze z CPU inicializovat dvěma způsoby: jednou starší metodou přes I / O adresy 0xCF8 a 0xCFCa další s názvem konfigurace mapovaná do paměti.[3]

Starší metoda byla přítomna v původním PCI a nazývá se Configuration Access Mechanism (CAM). Umožňuje nepřímo dosáhnout 256 bajtů adresního prostoru zařízení prostřednictvím dvou 32bitových registrů nazývaných PCI CONFIG_ADDRESS a PCI CONFIG_DATA. Tyto registry jsou na adresách 0xCF8 a 0xCFC v adresním prostoru x86 I / O.[4] Například softwarový ovladač (firmware, jádro OS nebo ovladač jádra) může tyto registry použít ke konfiguraci zařízení PCI zapsáním adresy registru zařízení do CONFIG_ADDRESS a vložením dat, která mají být do zařízení zapsána, do CONFIG_DATA. Protože tento proces vyžaduje zápis do registru, aby bylo možné zapsat do registru zařízení, je označován jako „indirection“.

Formát CONFIG_ADDRESS je následující:

0x80000000 | autobus << 16 | přístroj << 11 | funkce <<  8 | offset

Jak již bylo vysvětleno dříve, adresování zařízení prostřednictvím sběrnice, zařízení a funkce (BDF) se také označuje jako „geografické adresování zařízení“. Vidět arch / x86 / pci / early.c v Linuxové jádro kód pro příklad kódu, který používá geografické adresování.[5]

Když se na některých procesorech AMD používá rozšířený konfigurační prostor, zapisují se extra bity 11: 8 ofsetu na bity 27:24 registru CONFIG_ADDRESS:[6][7]

0x80000000 | (offset & 0xf00) << 16 | autobus << 16 | přístroj << 11 | funkce <<  8 | (offset & 0xff)

Druhá metoda byla vytvořena pro PCI Express. Nazývá se Enhanced Configuration Access Mechanism (ECAM). Rozšiřuje konfigurační prostor zařízení na 4k, přičemž spodní 256 bajtů překrývá původní (starší) konfigurační prostor v PCI. Část adresovatelného prostoru je „odcizena“, aby přístupy z CPU nechodily do paměti, ale dosáhly daného zařízení ve struktuře PCI Express. Během inicializace systému určí firmware základní adresu pro tuto „ukradenou“ oblast adresy a sdělí ji kořenovému komplexu a operačnímu systému. Tato komunikační metoda je specifická pro implementaci a není definována ve specifikaci PCI Express.

Každé zařízení má svůj vlastní prostor 4 KiB a informace o každém zařízení jsou přístupné prostřednictvím jednoduchého pole dev [bus] [zařízení] [funkce] takže pro toto použití je „ukradeno“ 256 MiB fyzického souvislého prostoru (256 sběrnic × 32 zařízení × 8 funkcí × 4 KiB = 256 MiB). Základní fyzická adresa tohoto pole není zadána. Například na počítačích Intel obsahují tabulky ACPI potřebné informace.[8]

Viz také

Reference

  1. ^ A b „Registry základních adres“. PCI. osdev.org. 2013-12-24. Citováno 2014-04-17.
  2. ^ „Metody konfigurace PCI“. cs.ucla.edu. 2011-11-22. Citováno 2014-04-17.
  3. ^ „Přístup k registrům konfigurace PCI Express * pomocí čipových sad Intel®“ (PDF). Intel Corporation. Citováno 27. září 2018.
  4. ^ „PCI Configuration Mechanism # 1“. osdev.org. 2015-01-01. Citováno 2015-01-01.
  5. ^ "kernel / git / stable / linux-stable.git: arch / x86 / pci / early.c (stabilní strom Linuxu, verze 3.12.7)". kernel.org. Citováno 2014-01-10.
  6. ^ "kernel / git / stable / linux-stable.git: arch / x86 / pci / direct.c (stabilní strom systému Linux, verze 3.12.7)". kernel.org. Citováno 2017-09-11.
  7. ^ Richter, Robert. „x86: přidat PCI rozšířený přístup do konfiguračního prostoru pro AMD Barcelona“. kernel.org. Citováno 26. září 2018.
  8. ^ „XSDT - OSDev Wiki“. Citováno 2017-04-30.

externí odkazy