Intel 80386

Versiunea actuală a paginii nu a fost încă examinată de colaboratori experimentați și poate diferi semnificativ de versiunea revizuită pe 11 decembrie 2021; verificările necesită 4 modificări .
Intel 80386
CPU

Microprocesor Intel 80386
Productie 17 octombrie 1985 până în septembrie 2007 [1] [2]
Dezvoltator Intel
Producătorii
frecvența procesorului 12-40  MHz
Tehnologia de producție 1,5–1,0  µm
Seturi de instrucțiuni x86
conector
Nuclei
Intel 80286Intel 80486

Intel 80386 (cunoscut și sub numele de i386 sau pur și simplu 386 ) este un microprocesor x86 de a treia generație pe 32 de biți de la Intel , lansat pe 17 octombrie 1985. Acest procesor a fost primul procesor pe 32 de biți pentru PC . Folosit în principal pe computere desktop și laptop. În prezent, se utilizează în principal în controlere.

Descriere

Procesorul i386 este pe deplin compatibil cu predecesorii săi, procesoarele 8086 - 80286 . Execută programe destinate acestora fără a fi nevoie de modificare și recompilare a codului (sau cu modificări minime) și face acest lucru mai eficient:

În același timp, i386 este o revizuire majoră a procesorului 80286 . Potrivit unor estimări, nici înainte, nici după i386, arhitectura procesoarelor x86 nu a fost niciodată modificată atât de radical. Procesoarele acestei arhitecturi au fost primele care au introdus mecanismele de bază pentru suportarea sistemelor de operare moderne pe 32 de biți pentru platformele compatibile cu PC.

Principalele modificări:

32 de biți

Întreaga arhitectură x86 a fost extinsă la 32 de biți - toate registrele (cu excepția celor segmentate) au devenit pe 32 de biți, primind prefixul „E” în ​​nume (EAX, EBX, EIP, EFLAGS etc.), menținând totodată set de comenzi pentru lucrul cu ele. Inclusiv:

Adresarea în modul protejat a devenit, de asemenea, pe 32 de biți (cu posibilitatea de a crea segmente de 16 biți pentru compatibilitate cu 80286). A permis pentru prima dată de la apariția lui 8086 să uităm de segmentare sau, mai degrabă, de limita de dimensiune a segmentului de 64 de kiloocteți (limită de adrese de 16 biți), care a încetat de mult să se potrivească programatorilor.

Înainte de apariția lui i386, programele și sistemele de operare foloseau mai multe modele de organizare a memoriei enigmatice (mic - mic, mic - mic, mare - mare, imens - uriaș), care diferă în organizarea codului, stivei și a segmentelor de date din memorie. Adresa pe 32 de biți a făcut posibilă utilizarea unui model plat simplu în locul lor (în engleză  flat ) - o versiune pe 32 de biți a unui model mic în care toate segmentele de activitate sunt în același spațiu de adrese. Modelul plat oferă dimensiunea unui astfel de segment „general” la aproape 4 gigaocteți, ceea ce la acea vreme era suficient pentru orice sarcină imaginabilă.

Modelul plat are și dezavantaje:

Modelul plat a intrat în uz atât de larg încât programatorii moderni nu sunt adesea conștienți că programele accesează memoria prin segmente.

Paginare

I386 a introdus un nou mecanism de gestionare a memoriei - spațiul de adrese pe care procesorul îl accesează pentru datele și codul în care se află segmentele (numit spațiu de adrese liniar ) poate să nu corespundă memoriei fizice reale. Memoria fizică (inclusiv bufferele dispozitivelor externe, de exemplu, bufferul video ) poate fi mapată în spațiul de adrese liniar într-un mod arbitrar - fiecare pagină (cu dimensiunea de 4 kiloocteți) de spațiu liniar poate fi redirecționată către orice pagină de memorie fizică prin pagină. directorul aflat în RAM (paginile de adrese ale directorului sunt determinate de valoarea noului registru de control „CR3”).

La fel ca și segmentele, paginile dintr-un spațiu de adrese liniar pot fi declarate neprezente (referirea la astfel de pagini invocă gestionarea erorilor de pagină a sistemului de operare ). Paginile care nu sunt prezente sunt folosite în principal pentru a organiza memoria virtuală - gestionarea încălcării paginii schimbă paginile de memorie cu dispozitive de stocare externe. De asemenea, paginile care nu sunt prezente sunt folosite în modelul de memorie plată (unde dimensiunea segmentului este de obicei între 2 și 4 gigaocteți, chiar dacă computerul nu are atât de multă memorie fizică) pentru a marca paginile segmentului cărora sistemul de operare nu le-a alocat memorie. la. În acest caz, o întrerupere de pagină de obicei încheie sarcina sau începe depanarea acesteia.

Prin paginare, i386 se poate adresa până la 4 GB de memorie fizică și până la 64 GB de memorie virtuală.

Multitasking și suport de securitate îmbunătățit

Suportul pentru multitasking pe procesoarele x86 denotă suport hardware pentru trecerea „transparentă” de la un program obișnuit ( sarcină ) la altul. La comutare, procesorul își salvează starea (inclusiv adresa următoarei instrucțiuni, selectoare de segment ) în segmentul de stare (TSS; segment de memorie, cu un selector din registrul TR) al unei sarcini, după care restabilește starea alteia. task din segmentul său de stare (noul selector al segmentului de stare al sarcinii este încărcat din descriptorul segmentului său de cod).

Comutarea între sarcini se face de obicei:

În i386, mecanismele de securitate și multitasking au fost mult extinse și îmbunătățite. În funcție de natura încălcărilor, acestea pot fi ignorate în tăcere (de exemplu, unii biți din registrul EFLAGS nu pot fi modificați prin încărcarea steagurilor din stivă), poate fi apelat un handler de excepții (al sistemului de operare). Erorile grave la nivelul sistemului de operare (sau în modul real) pot aduce procesorul într-un mod de oprire de urgență (de exemplu, în cazul unei încălcări în gestionarea unei încălcări duble), din care puteți ieși numai cu un resetare hardware (resetare în limba engleză  ) a procesorului.

De exemplu, i386 acceptă restricționarea accesului la porturile I/O și dezactivarea semnalizatorului de întrerupere prin:

O încercare de a executa o comandă I/O nerezolvată are ca rezultat o excepție al cărei handler (deținut de sistemul de operare) poate termina sarcina din greșeală, o poate ignora (relua execuția la următoarea comandă) sau poate emula I/O.

În plus, i386 multitasking acceptă pe deplin toate funcțiile noi - pentru sarcinile pe 32 de biți, segmentul de stare conține toate registrele de 32 de biți și noii necesare (de exemplu, registrul CR3 cu adresa directorului paginii pentru această sarcină).

Modul virtual

Cu procesorul i386, Intel a recunoscut nevoia unui suport mai bun pentru modul real, deoarece software-ul la momentul introducerii sale nu era pe deplin pregătit pentru a rula în modul protejat. Prin urmare, de exemplu, în i386 este posibilă trecerea din modul protejat înapoi în modul real (în timpul dezvoltării lui 80286 s-a considerat că acest lucru nu ar fi necesar, prin urmare, pe computerele cu procesor 80286, se realizează revenirea la modul real scos prin circuite - printr-o resetare a procesorului).

Ca suport extins pentru modul real, i386 permite ca una sau mai multe sarcini să ruleze în modul virtual  , un mod care emulează modul de adresă reală.

Este important de înțeles că „modul virtual”, în ciuda asemănării numelui, nu este „al treilea mod al procesorului” (adică real, protejat și virtual), ci doar modul de funcționare al unei sarcini într-un mediu multitasking în mod protejat.

Modul virtual este destinat execuției simultane a programelor în mod real (de exemplu, programe DOS) sub un sistem de operare în mod protejat multitasking.

Execuția în modul virtual este aproape identică cu modul real, cu câteva excepții datorate faptului că sarcina virtuală este executată în modul protejat:

De exemplu, începând de la versiunile 4.01 - 5.0, atunci când se utilizează managerul de memorie EMM386 (și analogii acestuia de la alți dezvoltatori) , sistemul de operare MS-DOS funcționează ca o sarcină în modul virtual. EMM386 în acest caz este ca un sistem de operare în mod protejat (trecând majoritatea capcanelor la kernelul MS-DOS într-o sarcină virtuală).

Modul virtual 8086 este acceptat și în procesoarele ulterioare x86 pe 32 de biți până la modul de compatibilitate x86-64 .

Depanare hardware

Ca și în procesoarele anterioare (începând cu 8086), depanarea în i386 este efectuată prin apelarea unei întreruperi de depanare, al cărei handler transferă controlul programului de depanare. În procesoarele anterioare, depanarea ar putea fi declanșată de două evenimente:

în i386, depanarea poate începe și:

Pas cu pas

Pasul sau urmărirea (apelarea unei întreruperi de depanare după executarea fiecărei comenzi cu steag-ul TF setat) în i386 rămâne la fel ca în procesoarele anterioare, lucrând în toate modurile noi (adresare pe 32 de biți și modul task virtual).

Puncte de întrerupere

Breakpoint ( în engleză  breakpoint ) - întreruperea execuției programului atunci când este atinsă o anumită adresă.

La procesoarele x86 timpurii, pentru a organiza un punct de întrerupere, a fost necesar să se înlocuiască primul octet al comenzii cu comanda de a apela întreruperea de depanare (int 3), apelând întreruperea a returnat controlul depanatorului, care a returnat valoarea inițială a primul octet al comenzii. În plus, punctele de întrerupere de acest fel nu au putut fi setate în ROM. i386 acceptă astfel de puncte de întrerupere pentru compatibilitate.

Punctele de întrerupere i386 sunt definite de o adresă în registrele de depanare. Managerul de depanare este apelat dacă adresa următoarei instrucțiuni se potrivește cu adresa din registru. Deoarece astfel de puncte de întrerupere nu necesită scriere în memorie, ele pot fi folosite pentru a depana programe în ROM. i386 vă permite să setați până la patru puncte de întrerupere în același timp.

Punctele de întrerupere i386 pot fi, de asemenea, setate pentru a accesa (citește sau scrie) o variabilă la o anumită adresă de memorie. Procesorul apelează handlerul de depanare atunci când instrucțiunea accesează memoria la adresa dată.

Capcana comutatorului de sarcini

O întrerupere de depanare poate fi declanșată la trecerea la o sarcină (un bit special este furnizat în segmentul de stare a sarcinii pentru aceasta).

Alte modificări

Liniile de date și adrese din procesorul 80386, ca și în procesorul 80286, nu sunt multiplexate: există 32 de linii de date și 32 de linii de adresă independente.

Registre

Microprocesorul are 8 registre de uz general pe 32 de biți (EAX, EBX, ECX, EDX, ESI, EDI, EBP, ESP). Jumătatea inferioară, pe 16 biți, a fiecăruia dintre aceste registre corespunde registrelor AX, BX, CX, DX, SI, DI, BP, SP din procesoarele anterioare din familia x86. La fel ca și înainte, este posibil să se adreseze jumătățile de 8 biți scăzute și înalte, jumătatea inferioară de 16 biți a registrelor de date de 32 de biți (AL și AH, BL și BH, CL și CH, DL și DH). Registrul indicator al instrucțiunilor și registrul steagurilor au devenit, de asemenea, pe 32 de biți (EIP și, respectiv, EFLAGS), cu un nou grup de steaguri adăugate la registrul steagurilor. La 4 registre de segmente de 16 biți (ES, CS, SS, DS) au fost adăugate încă 2 registre de 16 biți (FS și GS), acum există 6 registre de segmente. Au fost adăugate mai multe grupuri de registre noi (fiecare registru are 32 de biți): 3 registre de control (CR0 (MSW), CR2, CR3), 8 registre de depanare (DR0, DR1, DR2, DR3, DR6, DR7), 2 registre de testare ( TR6, TR7).

Set de instrucțiuni

Setul de instrucțiuni i386 a fost extins în principal prin adăugarea de variante de 32 de biți ale instrucțiunilor existente (formate din prefixe de 32 de biți), inclusiv cele ale căror variante de 32 de biți au mnemonice diferite (pushad/popad, pushfd/popfd, cwd*/cdq, movsd/cmpsd/scasd/lodsd/insd/outsd, iretd), precum și comenzi mov pentru registre noi. Alte instrucțiuni noi:

  • setarea unui octet după condiție (set*)
  • instrucțiuni de salt (jmp, j*) cu offset relativ de 16 biți
  • instrucțiuni complete de încărcare a adresei pentru noile registre de segmente (lfs, lgs)
  • comenzile logice (și, sau, xor) atunci când lucrează cu date imediate de 16 biți au capacitatea de a utiliza extensii de octeți semnati, ceea ce permite ca astfel de comenzi să fie reduse pe octet atunci când datele sunt plasate într-un octet (această caracteristică a fost descrisă pentru prima dată în documentația proprietară 80386, dar este posibil să fi fost prezentă în procesoarele anterioare)

Lungimea medie a instrucțiunii este de 3,2 octeți.

Coprocesor matematic

La fel ca și în cazul pachetului 80286-80287, schimbul de date al procesorului 80386 cu coprocesorul său a trecut prin porturi cu adrese 0F0H-0FFH și, în principiu, cu un mic adaos la circuit, a fost posibil să se conecteze 80287 coprocesor la procesorul 80386DX [3] [4] , aceasta a fost oferită ca o alternativă ieftină la utilizarea coprocesorului 80387.

În special pentru microprocesoarele Intel 80386, au fost dezvoltate coprocesoarele matematice 387SX și 387DX, unite sub numele unic Intel 80387. Aceste coprocesoare sunt compatibile cu procesoarele 386SX și, respectiv, 386DX; de exemplu, coprocesorul 387DX poate fi conectat la o magistrală de procesor pe 32 de biți. În rest, ambele modele sunt similare cu coprocesorul matematic 80287, care poate fi folosit și cu procesorul 80386.

Modele

Din 1985, au fost lansate multe modificări ale procesorului i386, care diferă în funcție de performanță, consum de energie, conectori, carcase și alte caracteristici.

386DX

Primul procesor al familiei 386 a fost lansat pe 13 octombrie 1985 și avea o viteză de ceas de 16 MHz . După lansarea procesoarelor 386SX, procesoarele acestei serii au primit indexul ''DX'' - ''D''double-word e''X''ternal, care indica magistrala externă de 32 de biți. Procesorul a fost poziționat ca o soluție productivă pentru sisteme desktop. Procesorul a fost produs folosind tehnologia CHMOS IV și a consumat 400 mA, ceea ce este mult mai puțin decât Intel 8086. La 16 februarie 1987, a fost anunțat un model cu o frecvență de 20 MHz ; 4 aprilie 1988 la 25 MHz și 10 aprilie 1989 la 33 MHz . Procesorul a fost produs în pachete PQFP -132 (astfel de procesoare aveau litera „NG” la începutul numelui, de exemplu, NG80386DX25) sau în ceramică PGA-132 (astfel de procesoare aveau litera „A” la începutul nume, de exemplu, A80386DX25)

Procesoarele 386DX timpurii au avut o eroare care dădea uneori rezultate incorecte atunci când lucrați cu numere pe 32 de biți în programe precum OS/2 2.x, UNIX/386 sau Windows în modul avansat. Eroarea a cauzat blocarea sistemului. Din cauza unor probleme, inclusiv a lipsei sistemelor de operare pe 32 de biți, eroarea a fost remediată abia în aprilie 1987 . Procesoarele deja lansate au fost testate, drept urmare procesoarele care nu au avut o eroare au fost marcate cu un simbol „sigma” dublu și/sau un singur simbol „IV”, și cu o eroare - NUMAI 16 BIT S/W.

386SX

Primul model din această familie a fost introdus pe 16 iunie 1988 și avea o frecvență de 16 MHz , ulterior au fost introduse modele mai rapide: 20 MHz ( 25 ianuarie 1989 ), 25 MHz și 33 MHz (ambele procesoare au fost introduse pe 26 octombrie, 1992 ). Procesoarele au fost poziționate ca soluții pentru desktop-uri și laptopuri entry-level. Familia SX diferă de familia DX prin faptul că lățimea magistralei de date externe era de 16 biți, iar lățimea magistralei de adrese externe era de 24 de biți, drept urmare procesorul putea adresa doar 16 MB de memorie fizică, ceea ce a făcut ca sistemele de calcul să fie construite. pe baza hardware-ului său compatibil cu procesoarele anterioare Intel 80286. În același timp, procesorul 386SX putea rula toate programele scrise pentru 386DX, iar acest lucru l-a făcut popular pentru realizarea de „plăci Turbo”, cum ar fi Cumulus 386SX, Intel InBoard sau Orchid Turbo minuscul.

Ca parte a seriei SX, au fost lansate procesoare marcate 80386SXTA, 80386SXSA, 80386SXLP, care au fost procesoare încorporate (seria SXSA), procesoare cu putere redusă (Putere scăzută) și au fost, de asemenea, utilizate în alte scopuri.

386SL

Primul model din această familie a fost introdus pe 15 octombrie 1990 și avea o frecvență de 20 MHz , ulterior a fost introdus un model de 25 MHz ( 30 septembrie 1991 ). Procesoarele au fost poziționate ca fiind primele microprocesoare eficiente din punct de vedere energetic special concepute pentru PC-uri portabile. Familia SL diferă de familia SX prin faptul că avea și un controler RAM, un controler extern pentru memorie cache cu o capacitate de 16 până la 64 KB și un controler de magistrală pe cip.

386EX

Este o modificare a procesorului 386SX. Procesorul a fost destinat aplicațiilor încorporate cu integrare ridicată și consum redus de energie. Caracteristicile cheie ale acestui procesor sunt consumul redus de energie, tensiunea de alimentare scăzută, controlerul de întrerupere pe cip, cip de selectare a cipului, contoare și temporizatoare, logica de testare JTAG . Această serie de procesoare a avut mai multe modificări: EXSA, EXTA, EXTB, EXTC. Curentul maxim absorbit de procesoare este de 320 mA pentru procesoarele din seria EXTC și 140 mA pentru procesoarele din seria EXTB.

Folosit la bordul diverșilor sateliți și microsateliți care orbitează și în proiectul FlightLinux al NASA .

Calculatoare bazate pe procesorul Intel 80386

Pe baza microprocesoarelor 80386, IBM a creat calculatoare personale IBM AT 386 (familia PC) și IBM PS / 2-80 (familia PS / 2). Primul a folosit PC-DOS , iar al doilea a folosit OS/2 .

Echipa de dezvoltare

  • John Crawford, arhitect șef
  • Jim Slager, inginer șef
  • Patrick Gelsinger
  • Khaled El Ayat
  • Riaz Haq
  • Gene Hill
  • Jan William L. Prak
  • David Vannier
  • Joseph „Chip” Krauskopf
  • Ken Shoemaker
  • Paul Ries
  • Saurabha Radhika

Specificații pentru diverse modele

Date relevante pentru toate modelele

Caracteristic, parametru 386DX 386SX 386SL 386EX
Data anunțării primului model 13 octombrie 1985 16 iunie 1988 15 octombrie 1990 august 1994
Frecvențe de ceas ( MHz ) 16, 20, 25, 33, 40 12 (seria SXSA), 16, 20, 25, 33, 40 (seria SXSA și SXTA) 20, 25 16, 20, 25, 33 (s-ar putea să fi existat alte modele)
Lățimea magistralei de date externe 32 de biți 16 biți 16 biți 16 biți
Lățimea de biți a magistralei de adrese externe 32 de biți 24 de biți 24 de biți 26 de biți
Cantitatea de memorie fizică adresabilă 4 GB [5] 16 MB 16 MB 64 MB (pentru seria EXTB, EXTC)
Tensiune de alimentare, volt 5 5 5 2,7~3,6V (seria EXTB)
4,5~5,5V (seria EXTC)
Numărul de tranzistori 275 000 275 000 855 000 275 000
Tehnologia procesului (nm) 1500 și 1000 (model de 33 MHz) 1500 și 1000 1000 800
Zona de cristal 42 mm² (pentru modelul de 33 MHz) Nu există date Nu există date Nu există date
Consum maxim de curent 0,39 A (model de 33 MHz) 0,38 A (model de 33 MHz) Nu există date Nu există date
Consumul maxim de energie, W 1,95 (model de 33 MHz) 1.9 (model 33MHz) Nu există date Nu există date
conector Socket de tip „Socket” sau lipit pe placă Procesorul a fost lipit pe placă Procesorul a fost lipit pe placă Procesorul a fost lipit pe placă
Cadru PGA ceramică cu 132 de pini sau PQFP cu 132 de pini PQFP cu 100 de pini PQFP cu 196 de pini PQFP cu 132 de pini , TQFP cu 144 de pini
Set de instructiuni x86 (150 de instrucțiuni, fără a număra modurile) x86 (150 de instrucțiuni, fără a număra modurile) x86 x86

Note

  1. Intel încasează în cipuri antice  (ing.)  (downlink) . Consultat la 10 aprilie 2010. Arhivat din original pe 22 august 2011.
  2. Notificare de modificare a produsului #106013-00 . Preluat la 24 august 2011. Arhivat din original la 11 ianuarie 2012.
  3. 80287 scurtă descriere la cadcenter Arhivat 26 aprilie 2008.
  4. BootPrompt-HOWTO pe Linux Arhivat 12 aprilie 2010 la Wayback Machine : „Opțiunea de pornire a kernelului „no387”: Unele coprocesoare i387 au erori care se manifestă în modul protejat pe 32 de biți. De exemplu, unele cipuri ULSI-387 timpurii provoacă blocări în virgulă mobilă, aparent din cauza unei erori în instrucțiunile FRSAV/FRRESTOR. Opțiunea de pornire „no387” îi spune lui Linux să ignore înjurăturile. coprocesor, chiar dacă unul este prezent. Desigur, atunci trebuie să aveți un nucleu care acceptă emularea matematică. Acest lucru poate fi util și dacă aveți de fapt una dintre vechile mașini 386 cu 80287 FPU, deoarece Linux nu poate folosi 80287."; original în engleză Arhivat la 30 august 2009 la Wayback Machine
  5. 1 2 P3 (386) Procesoare din a treia generație | Tipuri și specificații de microprocesoare | InformIT . Consultat la 12 noiembrie 2017. Arhivat din original la 23 octombrie 2017.

Literatură

  • Manual de referință pentru programator Intel 80386
  • Manual de referință pentru programator Intel 80387 (1987)
  • Bramm P., Bramm D. Microprocesor 80386 și programarea acestuia. — M .: Mir, 1990. — 448 p. — ISBN 5-03-001441-1 .
  • Pappas K., Marie W. Microprocessor 80386. - M . : Radio și comunicare, 1993. - 320 p. — ISBN 5-256-00826-9 .

Link -uri