8087 Numeryczny procesor danych
8087 numeryczny procesor danych jest również znany jako Math co-processor, Numeric processor extension i Floating point unit. Był to pierwszy koprocesor matematyczny zaprojektowany przez firmę Intel w połączeniu z 8086/8088, co skutkowało łatwiejszymi i szybszymi obliczeniami.
Gdy instrukcje zostaną zidentyfikowane przez procesor 8086/8088, są one przydzielane koprocesorowi 8087 w celu dalszego wykonania.
Typy danych obsługiwane przez 8087 to -
- Binarne liczby całkowite
- Pakowane liczby dziesiętne
- Liczby rzeczywiste
- Tymczasowy rzeczywisty format
Najważniejsze cechy numerycznego procesora danych 8087 są następujące:
Obsługuje dane typu integer, float i rzeczywiste w zakresie od 2 do 10 bajtów.
Szybkość przetwarzania jest tak wysoka, że może obliczyć mnożenie dwóch 64-bitowych liczb rzeczywistych w ~ 27 µs, a także może obliczyć pierwiastek kwadratowy w ~ 35 µs.
Jest zgodny ze standardami zmiennoprzecinkowymi IEEE.
8087 Architektura
Architektura 8087 dzieli się na dwie grupy, tj. Control Unit (CU) i Numeric Extension Unit (NEU).
Plik control unit obsługuje całą komunikację między procesorem a pamięcią, na przykład odbiera i dekoduje instrukcje, odczytuje i zapisuje operandy pamięci, utrzymuje kolejkę równoległą itp. Wszystkie instrukcje koprocesora są instrukcjami ESC, tj. zaczynają się od „F”, tylko koprocesor wykonuje instrukcje ESC, podczas gdy inne instrukcje są wykonywane przez mikroprocesor.
Plik numeric extension unitobsługuje wszystkie numeryczne instrukcje procesora, takie jak instrukcje arytmetyczne, logiczne, transcendentalne i instrukcje przesyłania danych. Ma 8 stosów rejestrów, w których znajdują się operandy instrukcji i ich wyniki.
Architektura koprocesora 8087 jest następująca -
Opis pinów 8087
Przyjrzyjmy się najpierw schematowi pinów 8087 -
Poniższa lista zawiera opis pinów 8087 -
AD0 – AD15 - Są to zmultipleksowane czasowo linie adresowe / danych, które przenoszą adresy podczas pierwszego cyklu zegara i dane począwszy od drugiego cyklu zegara.
A19 / S6 – A16/S- Te linie to multipleksowane czasowo linie adresu / stanu. Działa podobnie do odpowiednich pinów 8086. S 6 , S 4 i S3 są stale w stanie wysokim, podczas gdy S 5 jest stale w stanie niskim.
$\overline{BHE}$/S7- Podczas pierwszego cyklu zegarowego, $ \ overline {BHE} $ / S 7 jest używany do udostępnienia danych na wyższym bajcie magistrali danych 8086, a następnie działa jako linia stanu S 7 .
QS1, QS0 - Są to sygnały wejściowe stanu kolejki, które zapewniają stan kolejki instrukcji, ich stan, jak pokazano w poniższej tabeli -
QS 0 | QS 1 | Status |
---|---|---|
0 | 0 | Bez operacji |
0 | 1 | Pierwszy bajt kodu z kolejki |
1 | 0 | Opróżnij kolejkę |
1 | 1 | Kolejny bajt z kolejki |
INT - Jest to sygnał przerwania, który zmienia się na wysoki, gdy podczas wykonywania został odebrany niezamaskowany wyjątek.
BUSY - Jest to sygnał wyjściowy, gdy jest wysoki, wskazuje procesorowi zajętość.
READY - Jest to sygnał wejściowy używany do informowania koprocesora, czy magistrala jest gotowa do odbioru danych, czy nie.
RESET - Jest to sygnał wejściowy służący do odrzucenia wewnętrznych działań koprocesora i przygotowania go do dalszego wykonania, gdy jest to wymagane przez CPU.
CLK - Wejście CLK zapewnia podstawowe taktowanie operacji procesora.
VCC - Jest to sygnał zasilający, który do działania obwodu wymaga zasilania + 5V.
S0, S1, S2- Są to sygnały stanu, które zapewniają stan operacji, który jest używany przez kontroler magistrali 8087 do generowania pamięci i sygnałów sterujących we / wy. Sygnały te są aktywne podczas czwartego cyklu zegara.
S 2 | S 1 | S 0 | Stan kolejki |
---|---|---|---|
0 | X | X | Nie używany |
1 | 0 | 0 | Nie używany |
1 | 0 | 1 | Odczyt pamięci |
1 | 1 | 0 | Zapis do pamięci |
1 | 1 | 1 | Bierny |
RQ/GT1 & RQ/GT0 - To są Request/Grant sygnały używane przez procesory 8087 do uzyskania kontroli nad magistralą z procesora hosta 8086/8088 do przesyłania argumentów.