Indice
Intel 8087
Intel 8087 Central processing unit | |
---|---|
Un coprocessore matematico Intel 8087 | |
Prodotto | 1980 |
Produttore | Intel, AMD, Cyrix |
Specifiche tecniche | |
Frequenza CPU | 5 MHz / 10 MHz |
Set di istruzioni | x87 |
Package | 40 pin DIP |
L'Intel 8087 è il primo coprocessore matematico prodotto da Intel a partire dal 1980. Fu progettato per essere utilizzato insieme all'Intel 8088 e all'8086.[1] Lo scopo dell'8087 era di accelerare i calcoli in virgola mobile: la velocità di calcolo aumentava dal 20% al 500% a seconda dell'applicazione specifica. Fu prodotto inizialmente con clock di 5 MHz, e successivamente portato ad 8 MHz (modello 8087-2) e 10 MHz (modello 8087-1).[2]
Questo coprocessore aggiungeva circa 60 nuove istruzioni disponibili al programmatore, il set x87, il cui codice mnemonico iniziava per "F" per distinguerle dalle istruzioni standard per gli interi dell'8086/88, e i cui opcodes iniziavano tutti con i cinque bit "11011": oltre a divisione, somma e moltiplicazione l'8087 poteva calcolare radici quadrate, tangenti ed elevamenti a potenza. Poteva operare anche con interi, sebbene molto più lentamente.
L'interfaccia fra l'8087 e il processore principale 8086/8088 era, in pratica, una "non interfaccia": l'8087 condivideva gli stessi bus dati, indirizzi e segnali della CPU e duplicava internamente tutta la logica di decodifica delle istruzioni dell'8086. Quindi leggeva le istruzioni caricate dal processore principale finché non riconosceva una istruzione in virgola mobile (compito facile, vista la particolarità dei suoi opcodes): allora l'8086 si fermava e subentrava l'8087, che a operazione finita accedeva alla memoria (se necessario) e poi segnalava al processore principale di ripartire.
L'8087 (e tutti i suoi successori) non fornisce un insieme di registri utilizzabili liberamente, ma offre uno stack di 8 registri da 80 bit che vanno da ST0 a ST7, e tutte le istruzioni operano implicitamente su ST0, la cima dello stack, se non altrimenti specificato: per questo motivo le istruzioni del coprocessore non hanno quasi mai argomenti. I risultati dei calcoli vengono salvati in memoria effettuando push e pop dei valori di questo stack.
Quando la Intel progettò l'8087 puntava a creare un formato standard per i futuri progetti. In effetti, una delle caratteristiche di maggior successo di questo coprocessore fu l'introduzione di uno dei primi standard per i PC x86: il formato in virgola mobile IEEE 754. L'8087 forniva due tipi base di tipi di dati a virgola mobile: singola precisione a 32 e doppia precisione a 64 bit, anche se internamente tutti i dati venivano silenziosamente portati a 80 bit per aumentare la precisione sui calcoli complessi. Inoltre l'8087 forniva un formato BCD a 80 bit e dati interi a 16, 32 e 64 bit.
L'8087, annunciato nel 1980, fu affiancato da nuove versioni per i successivi modelli di CPU: prima l'80287, poi l'80387DX/SX. L'Intel 80486, il Pentium e tutte le CPU successive inclusero un coprocessore matematico direttamente nel proprio core ponendo fine, di fatto, all'era dei coprocessori matematici esterni. L'Intel 486SX era una CPU con la FPU disabilitata, ed era possibile affiancarla a un 487.
Essendo un componente relativamente costoso, e al tempo stesso non necessario a tutti gli utilizzatori dei personal computer del tempo, i costruttori prevedevano sulla scheda madre uno zoccolo vuoto, atto all'inserimento del coprocessore, fornito come opzione, all'eventuale cliente che ne avesse fatto richiesta.
Note
[modifica | modifica wikitesto]- ^ Intel 8087, su cpu-world.com. URL consultato il 02/04/2013.
- ^ Intel 8087, su cpu-museo.it, CPU Museo. URL consultato il 02/04/2013.
Altri progetti
[modifica | modifica wikitesto]- Wikimedia Commons contiene immagini o altri file su Intel 8087
Collegamenti esterni
[modifica | modifica wikitesto]- Motorola 68881/68882 FPU Command Reference, su intel-assembler.it. URL consultato il 7 aprile 2010 (archiviato dall'url originale il 15 febbraio 2011).
- Intel 8087 FPU Instruction Set, su intel-assembler.it. URL consultato il 7 aprile 2010 (archiviato dall'url originale il 23 luglio 2012).
Controllo di autorità | LCCN (EN) sh85067151 · GND (DE) 4129509-2 · BNF (FR) cb119701833 (data) · J9U (EN, HE) 987007555628105171 |
---|