See artikkel ootab keeletoimetamist. |
PCI Expressi logo | |
Loomise aasta | 2003 |
---|---|
Looja | Intel (koostöös Delli, IBM-i ja HP-ga) |
Seadmete arv | 1 iga otspunkti jaoks |
Stiil | jadasiin |
Käigultvahetuse liides | Jah |
Väline liides | Jah |
PCI Express (Peripheral Component Interconnect Express) ehk PCIe või PCI-E (tuntud ka kui 3GIO (3rd Generation I/O); mitte segamini ajada PCI-X ja PXI) on kiire jadasiin, mis loodi asendamaks vanemaid PCI, PCI-X ja AGP standardeid.
Erinevalt PCI siinist, mis kasutab andmete edastamiseks ühissiini, põhineb PCI Expressi kakspunkt-topoloogial, kus iga seade on juurkompeksiga ühendatud eraldi jadaühendusega. PCI Expressi seadmed suhtlevad teineteisega kommutaatorite vahendusel. Iga seade on kommutaatoriga seotud kakspunktühendusega.
PCI Expressi siin toetab kaartide käigultvahetust, teenusekvaliteeti (QoS), energiatarbimise kontrolli ja edastatud andmete terviklikkuse kontrolli.
PCI Expressi standardi arendamist alustas Intel. Esimene ametlik PCI Expressi baasspetsifikatsioon ilmus 2002. aasta juulis. PCI Expressi standardi arendamisega tegeleb organisatsioon PCI Special Interest Group, mis ühendab enam kui 900 ettevõtet.
PCI Expressi siini eesmärgiks on selle kasutamine ainult lokaalse siinina. Kuna PCI Expressi tarkvaraline mudel on suures osas päritud PCI-lt, siis olemasolevad süsteemid ja kontrollerid võivad olla kohandatud PCI Expressi siini kasutamiseks ainult füüsiliselt, ilma tarkvara versiooni uuendamata. PCI Expressi siini kõrge piiktulemuslikkus võimaldab selle kasutamist AGP ning PCI ja PCI-X siinide asemel. Loodetakse, et PCI Express vahetab need siinid personaalarvutites välja.
PCI Expressi väljundid X1 | |||
---|---|---|---|
Väljundi nr | Määramine | Väljundi nr | Määramine |
B1 | +12 V | A1 | PRSNT1# |
B2 | +12 V | A2 | +12 V |
B3 | +12 V | A3 | +12 V |
B4 | GND | A4 | GND |
B5 | SMCLK | A5 | JTAG2 |
B6 | SMDAT | A6 | JTAG3 |
B7 | GND | A7 | JTAG4 |
B8 | +3,3 V | A8 | JTAG5 |
B9 | JTAG1 | A9 | +3,3 V |
B10 | 3,3 V__AUX | A10 | +3,3 V |
B11 | WAKE# | A11 | PERST# |
B12 | RSVD | A12 | GND_A12 |
B13 | GND | A13 | REFCLK+ |
B14 | PETP0 | A14 | REFCLK- |
B15 | PETN0 | A15 | GND |
B16 | GND | A16 | PERP0 |
B17 | PRSNT2# | A17 | PERN0 |
B18 | GND | A18 | GND |
Mini PCI Express – PCI Expressi siini formaat kaasaskantavate seadmete jaoks.
Selle standardi pistiku jaoks toodetakse hulgaliselt lisaseadmeid:
Väljundid Mini PCI-E | |||
---|---|---|---|
Väljundi nr | Määramine | Väljundi nr | Määramine |
51 | Reserveeritud | 52 | +3,3 V |
49 | Reserveeritud | 50 | GND |
47 | Reserveeritud | 48 | +1,5 V |
45 | Reserveeritud | 46 | LED_WPAN# |
43 | Reserveeritud | 44 | LED_WLAN# |
41 | Reserveeritud (+3,3 V) | 42 | LED_WWAN# |
39 | Reserveeritud (+3,3 V) | 40 | GND |
37 | Reserveeritud (GND) | 38 | USB_D+ |
35 | GND | 36 | USB_D- |
33 | PETp0 | 34 | GND |
31 | PETn0 | 32 | SMB_DATA |
29 | GND | 30 | SMB_CLK |
27 | GND | 28 | +1,5 V |
25 | PERp0 | 26 | GND |
23 | PERn0 | 24 | +3,3 V aux |
21 | GND | 22 | PERST# |
19 | Reserveeritud (UIM_C4) | 20 | W_DISABLE# |
17 | Reserveeritud (UIM_C8) | 18 | GND |
15 | GND | 16 | UIM_VPP |
13 | REFCLK+ | 14 | UIM_RESET |
11 | REFCLK- | 12 | UIM_CLK |
9 | GND | 10 | UIM_DATA |
7 | CLKREQ# | 8 | UIM_PWR |
5 | Reserveeritud (COEX2) | 6 | 1,5 V |
3 | Reserveeritud (COEX1) | 4 | GND |
1 | WAKE# | 2 | 3,3 V |
Väljundid SSD Mini PCI Express | |||
---|---|---|---|
Väljundi nr | Määramine | Väljundi nr | Määramine |
51 | +3,3 V | 52 | IDE_DASP |
49 | +3,3 V | 50 | GND |
47 | +3,3 V | 48 | IDE_CS1 |
45 | IDE_PDIAG | 46 | IDE_CS0 |
43 | NC | 44 | IDE_INTRQ |
41 | IDE_A2 | 42 | IDE_READY |
39 | IDE_A1 | 40 | GND |
37 | IDE_A0 | 38 | USB_D+ |
35 | GND | 36 | USB_D- |
33 | Sata TX+ | 34 | GND |
31 | Sata TX- | 32 | IDE_DMARQ |
29 | GND | 30 | IDE_DMACK |
27 | GND | 28 | IDE_IOREAD |
25 | Sata RX+ | 26 | GND |
23 | Sata RX+ | 24 | IDE_IOWR |
21 | GND | 22 | IDE_RESET |
19 | IDE_D7 | 20 | IDE_D8 |
17 | IDE_D6 | 18 | GND |
15 | GND | 16 | IDE_D9 |
13 | IDE_D5 | 14 | IDE_D10 |
11 | IDE_D4 | 12 | IDE_D11 |
9 | GND | 10 | IDE_D12 |
7 | IDE_D3 | 8 | IDE_D13 |
5 | IDE_D2 | 6 | IDE_D14 |
3 | IDE_D1 | 4 | GND |
1 | IDE_D0 | 2 | IDE_D15 |
ExpressCardi pesi kasutatakse 2010. aasta novembri seisuga järgmiste seadmete ühendamiseks:[1]
PCI Express seadmete ühendamiseks kasutatakse kahesuunalist punkt-punkt tüüpi jadaühendust, mida nimetatakse rajaks (Lane). See vastandub teravalt PCI-le, milles kõik seadmed ühenduvad üldise 32-bitilisele paralleelsele kahesuunalisele siinile. Kahe PCI Expressi seadme vahelist ühendust nimetatakse liiniks (Link), ja see koosneb ühest (nimetatakse x1) või mitmest (x2, x4, x8, x12, x16 ja x32) rajast, ehk kahesuunalisest seeriaühendusest. Liini iga seade peab toetama vähemalt ühendust x1.
Üks suuri erinevusi PCI ja PCIe vahel on veel nende siinide topoloogia. Erinevalt PCI paralleelsiinist, kus kõik seadmed jagavad ühiseid aadressi-, andme- ja juhtimisliine, kasutab PCIe kakspunktühendust, kus igal liinil saab olla maksimaalselt kaks seadet. Selleks, et ühendada samasse süsteemi rohkem seadmeid, kasutab PCIe süsteem kommutaatoreid (switche) ja sildu (bridge). PCIe süsteemi hierarhia tipuks on protsessor, liidest protsessori ja muude siini komponentide vahel nimetatakse juurkompleksiks (Root complex). Igal PCIe komponendil on pordid, mille külge ühenduvad teised seadmed, juurkompleksi porte nimetatakse juurportideks. Kommutaator võimaldab ühe PCIe pordi külge ühendada rohkem kui üht seadet, ehk omab ühte ülesvoolu porti protsessori suunas ning mitut allavoolu porti otspunktide suunas. Seadet, mis on PCIe süsteemis "lõpus" ega ole kommutaator või sild, nimetatakse otspunktiks (endpoint) ja mis on võimeline toimima transaktsioonide algatajana (initiator) ja lõpetajana (completer). Sellistel seadmetel on ainult üks ülesvoolu port. Sild võimaldab PCIe süsteemi ühendada teist tüüpi siine (näiteks PCI või PCI-X), sellisel juhul on tegemist pärisillaga (forward bridge). Kui aga ühendatakse vastupidi (PCI süsteemi külge PCIe siin), siis sellist vahendatavat silda nimetatakse pöördsillaks (reverse bridge). Seadmed, mis on algselt disainitud PCI või PCI-X jaoks, aga millele on hiljem külge arendatud PCIe liides nimetatakse pärand otspunktideks (legacy endpoint) ja koheselt PCIe süsteemi jaoks disainitud seadmeid nimetatakse põlis-otspunktideks (native endpoint).[2]
Elektrilisel tasemel kasutab iga ühendus madalpingelist diferentsiaalset signaaliedastamist (LVDS), kus iga ühenduse raja kaudu saadetakse sama signaali positiivne ja negatiivne „versioon". Sellega saavutatakse veakindlus - immuunsus mürade ja pingelangu vastu. Kuna viigud on üksteisele lähedal, siis välised mürad mõjutavad neid peaaegu võrdselt. Informatsiooni vastuvõtt ja edastamine toimub iga PCI Expressi seadmega kahe eraldatud juhi kaudu. Nii loob seade ühenduse PCI Expressi kommutaatoriga ainult nelja juhi abil.
Sellisel lähenemisviisil on järgnevad eelised:
PCI Expressi siinil läheb kasutusse maksimaalne kogus lane'e, mis on saadaval nii kaardil kui ka pesal, kuid see ei võimalda seadmel töötada pesas, mis on mõeldud PCI Express siinist väiksema ribalaiusega kaartidele. Näiteks kaart x4 ei mahu füüsiliselt standardsesse x1 pesasse, vaatamata sellele, et ta saaks töötada x1 pesas, kasutades ainult üht lane'i. Osadel emaplaatidel võib näha mittestandardseid pesi x1 ja x4, millel puudub äärmine vahesein, ja sellisel juhul võib paigaldada nendesse kaarte, mis on suurema pikkusega kui pistik. Samal ajal ühte osa kaardist ei varustata toitega ja maandusega, mis võib kaasa tuua erinevaid probleeme.
PCI Express edastab kõiki kontrollandmeid, sealhulgas katkestusi, samade liinide kaudu, mida kasutatakse andmete edastamiseks. Jadaprotokoll ei saa olla kunagi lukustatud, niiviisi on PCI Expressi siini viivitused võrreldavad PCI omadega (PCI siin kasutab signaali edastamist katkestuste kohta eraldiolevaid füüsilisi liine IRQ#A, IRQ#B, IRQ#C, IRQ#D).
Kõikides ülikiiretes jadaprotokollides, näiteks gigabitine Ethernet, peab olema sünkroonimise informatsiooni kandev edastamissignaal (ehk Taktsignaal) sisseehitatud. Sünkroonimissignaali tekitab andmevoo allikas ning saadab selle andmevoo sees vastuvõtjale, kus vastuvõtja taastab faasiluku (PLL) ahela abil andmevoost sünkroonimissignaali. Füüsilisel tasandil kasutatakse PCI Expressi kanali kodeerimise meetodit 8b/10b (8 bitti 10-s, koondamine 20%) konstantse osa kõrvaldamiseks edastamissignaalis ja kinnistades sünkroonimisinfo andmevoo sisse. Alates PCI Express 3.0st kasutatakse säästlikumat 128b/130b kodeeringut 1,5% koondamisega.
Mõned protokollid (näiteks SONET/SDH) kasutavad meetodit, mida nimetatakse scrambling'uks, sünkroonimisinfo kinnistamiseks andmevoo sisse ja edastatava signaali spektri "erosiooni" jaoks. PCI Expressi spetsifikatsiooni on ette nähtud scrambling-funktsioon, kuid scrambling PCI Expressis erineb sellest, mis on SONET'il.
PCIe 1.0 puhas bitikiirus on 2,5 GT/s (gigatehingut sekundis). Siini ribalaiuse (ehk teisisõnu suurima läbilaskevõime) arvutamiseks tuleb arvesse võtta dupleksi[3] ja koondamist 8b/10b (8 bitti 10-s), mille tulemusel on saadud ribalaiuse ühikuks GB/s. Näiteks on PCI-E 1.0 x1 ühenduses dupleksi maksimaalne läbilaskevõime (kahel suunal):
Bitikiirus (GT/s) |
Ribalaius ühel suunal (GB/s) | ||||||
---|---|---|---|---|---|---|---|
x1 | x2 | x4 | x8 | x12 | x16 | ||
PCIe 1.0 | 2.5 | 0.250 | 0.500 | 1.000 | 2.000 | 3.000 | 4.000 |
PCIe 2.0 | 5.0 | 0.500 | 1.000 | 2.000 | 4.000 | 6.000 | 8.000 |
PCIe 3.0 | 8.0 | 0.985 | 1.969 | 3.938 | 7.877 | 11.816 | 15.754 |
PCIe 4.0 | 16.0 | 1.969 | 3.938 | 7.877 | 15.754 | 23.631 | 31.508 |
PCIe 5.0 | 32.0 | 3.938 | 7.877 | 15.754 | 31.508 | 47.261 | 63.015 |
Lisaks PCI Expressile on veel mitmeid ülikiireid standardiseeritud jadaliideseid, näiteks HyperTransport, InfiniBand, RapidIO ja StarFabric. Protokollide väljatöötamiseks on kulunud märkimisväärsed rahasummad, seetõttu eelistab iga tootja omi liideseid. Standarditud ülikiire liides peaks ühelt poolt olema paindlik ja venivusega, teiselt poolt peaks olema madala latentsusega ja omama madalaid üldkulusid (see tähendab, et ametliku informatsiooni paketi osa ei tohi olla suur). Sisuliselt on erinevused kahe liidese vahel täpselt arendajate valitud konkreetse liidese kompromissis nende kahe vasturääkivate nõudmiste vahel.
Näiteks võimaldab ametlik marsruudi lisainformatsioon paketis organiseerida keerulise ja paindliku paketi marsruutimist, kuid suurendab üldkulusid paketi töötlemisel, samuti väheneb liidese läbilaskevõime, tarkvara, mis algväärtustab ja seadistab seadeid, mis on ühendatud liidese juurde, läheb keerulisemaks. Selleks, et saaks seadmeid "kuumalt" ühendada on vaja spetsiaalne tarkvara, mis jälgiks muudatusi võrgu topoloogias. Näited liidestest, mis on selleks kohandatud, on RapidIO, InfiniBand ja StarFabric.
Samal ajal, lühendades pakette saab vähendada andmete edastamise viivitused, mis on oluline eeldus mälu liidesele. Kuid väike pakettide arv toob kaasa selle, et osa paketti ametlikust valdkonnast suureneb, mis vähendab liidese efektiivset läbilaskevõimet. Sellise liidese näiteks on HyperTransport.
PCI Expressi seisukoht – kirjutatud lähenemisviiside vahel, kuna PCI Expressi siin on kavandatud tööks kohaliku siinina, mitte protsessor-mälu siinina või keerulise marsruutimisvõrgustiku siinina. Lisaks, PCI Express on algselt mõeldud kui siin, mis on loogilises kooskõlas PCI siiniga, mis samuti tõi kaasa omad piirangud.
PCI-SIG grupp laskis välja PCI Express 2.0 spetsifikatsiooni 15. jaanuaril 2007. Peamised uuendused PCI Express 2.0-s:
7. veebruaril 2007 lasi PCI-SIG grupp välja süsteemivälise kaabelduspetsifikatsiooni ePCIe. Kaabli maksimaalne pikkus pole määratud. Kaabel edastab andmeid kiirusel kuni 2,5 GT/s. Standardkaablid ja konnektorid on loodud x1, x4, x8 ja x16 liini laiustele.
Füüsilised omadused (kiirus, ühenduspesa) vastavad 2.0-le, tarkvarale on aga lisatud funktsioonid, mida kavatsetakse täielikult rakendada versioonis 3.0. Kuna enamik emaplaate müüakse versiooniga 2.0, ei anna üksnes 2.1 versiooniga graafikakaardi olemasolul antud režiimi kasutada.
2010. aasta novembris[4] kinnitati PCI Express 3.0 versiooni spetsifikatsioonid. 3.0 liidese andmeedastuskiiruseks on 8 GT/s (gigatehingut/s). Kuid sellest hoolimata oli selle reaalne läbilaskevõime ikka kahekordistatud võrreldes PCI Express 2.0 standardiga. See sai võimalikuks tänu agressiivsemale kodeerimisskeemile 128b/130b, kus 128 bitti andmeid, mis saadakse siini kaudu, kodeeritakse 130 bitiga. PCI Express 2.0-l on andmesidekiirus 5 GT/s ja kodeerimisskeem 8b/10b. Säilis ühilduvus varasemate PCI Expressi versioonidega.
29. novembril 2011 kuulutas PCI-SIG avalikult välja esialgse PCI Express 4.0 standardi, mille bitikiirust ja ribalaiust oli taas kahekordistatud (võrreldes eelmise standardiga) vastavalt kiirusele 16 GT/s ja ~32 GB/s. Säilis nii tarkvaraline kui ka mehaaniline tagasiühilduvus[5]. 4.0 standard on toetatud alates 11. põlvkonna Intel Core ning AMD 3000 ja 5000 seeria protsessorites ning vastavaid protsessoreid toetavates emaplaatides[6]. Standard loodi nii serverites kui ka lauaarvutites kasutamiseks.
Esimesed füüsilised seadmed, mis kasutasid PCIe 4.0 standardit ehitati alles 2016. aasta augustis[7] ning standard avalikustati alles 2017[8], kaubanduslikult muutusid saadavaks 4.0 seadmed veelgi hiljem, venitades standardi väljalaske ligi 7 aasta peale.
2017. aasta juunis avalikustas PCI-SIG esmased PCI Express 5.0 spetsifikatsioonid[9], järjekordselt kahekordistades ribalaiust kuni 128GB/s x16 liini korral ning bitikiirust kiiruseni 32GT/s, seejuures säilitades nii tarkvaralise kui ka mehaanilise tagasiühilduvuse. Ametlikult kinnitati 5.0 spetsifikatsioon 2019. aasta maikuus[10], mis oli PCIe ajaloos esmakordne juhtum, kus uus spetsifikatsioon avaldati enne seda, kui eelmine versioon oleks kommertsturule jõudnud. PCIe 5.0 standardit toetavad alates 12. põlvkonna Intel Core protsessorid ja Intel 600 kiibistikuga emaplaadid.
2022 jaanuaris avalikustas PCI-SIG PCI Express 6.0 spetsifikatsiooni, mille puhas bitikiirus ulatub kuni 64GT/s ning ribalaius x16 liini korral kuni 256GB/s. Standard loodi suuremahuliste andmete töötlemiseks (näiteks masinõppe/tehisintellekti, kõrgjõudlustöötluse, andmekeskuste, nutistu, militaar- ja kosmosetehnoloogiate arenduseks)[11].
PCIe 6.0-ga plaanitakse kasutusele võtta NRZ (Non-return-to-zero) signaaliedastuse asemel PAM4 (Pulsi-amplituudmodulatsiooni) signaaliedastamine, mis jagab kahendsignaali (0 või 1) omakorda kaheks, tekitades neli võimalikku signaaliolekut (00, 01, 10 või 11). See tehnoloogia võimaldab ühe signaaliga edastada kaks korda rohkem andmeid ilma ribalaiust kahekordistamata ja tänu sellele võib PCIe 6.0 töötada sagedusel kuni 30 GHz ilma liinide pikkuseid suurendamata.[12]
2022. aasta aprilli seisuga pole teadaolevalt ühtegi 6.0 standardile vastavat seadet veel toodetud.
Pildid, videod ja helifailid Commonsis: PCI Express |