Structura procesoarelor din familia INTEL

Slides:



Advertisements
Similar presentations
Intel (32 bit microprocessor) In addition to the previous features, it has an additional feature, the built-in math coprocessor It is same as
Advertisements

8086 [2] Ahad. Internal! External? 8086 vs _bit Data Bus 20_bit Address 8_bit Data Bus 20_bit Address Only external bus of 8088 is.
8086.  The 8086 is Intel’s first 16-bit microprocessor  The 8086 can run at different clock speeds  Standard 8086 – 5 MHz  –10 MHz 
80486 Microprocessor The 32-bit is the next evolutionary step up from the One of the most obvious feature included in a is a built in.
80486 Processor math co-processor is the first processor to have built-in math coprocessor. This being integrated on the chip allows it to execute.
Microcomputer & Interfacing Lecture 2
Khaled A. Al-Utaibi  8086 Pinout & Pin Functions  Minimum & Maximum Mode Operations  Microcomputer System Design  Minimum Mode.
MODES OF Details of Pins Pin 1 –Connected Ground Pins 2-16 –acts as both input/output. Outputs address at the first part of the cycle and outputs.
Intel
Basic Microcomputer Design. Inside the CPU Registers – storage locations Control Unit (CU) – coordinates the sequencing of steps involved in executing.
Wait states Wait states can be inserted into a bus cycle
8086/8088 Hardware Specifications Power supply:  +5V with tolerance of ±10%;  360mA. Input characteristics:  Logic 0 – 0.8V maximum, ±10μA maximum;
MODES OF Details of Pins Pin 1GND –Connected Ground Pins 2-16 AD14-AD0–acts as both input/output. Outputs address at the first part of the cycle.
Architecture of The Internal Architecture of is divided into 3 sections. Central processing unit Memory management unit Bus interface unit.
Introduction First 32 bit Processor in Intel Architecture. Full 32 bit processor family Sixth member of 8086 Family SX.
UNIT-I 80386DX functional Block Diagram PIN Description Register set
80386DX. Features of 80386DX It supports 8/16/32 bit data operands It has 32-bit internal registers It supports 32-bit data bus and 32-bit non-multiplexed.
80386DX functional Block Diagram PIN Description Register set Flags Physical address space Data types.
EFLAG Register of The The only new flag bit is the AC alignment check, used to indicate that the microprocessor has accessed a word at an odd.
Information Security - 2. Other Registers EFLAGS – 32 Bit Register CFPFAFZFSFTFIFDFOFIO PL IO PL NTRFVM Bits 1,3,5,15,22-31 are RESERVED. 18: AC, 19:VIF,
-Modelul Entitate-Legatura (ER)-
Unit Microprocessor.
32- bit Microprocessor-Intel 80386
Protection in Virtual Mode
COURSE OUTCOMES OF Microprocessor and programming
16.317: Microprocessor System Design I
80486 Microprocessor The 32-bit is the next evolutionary step up from the One of the most obvious feature included in a is a built.
Introduction to the processor and its pin configuration
PIN description of 8086 in Minimum Mode
COURSE OUTCOMES OF Microprocessor and programming
8086 MICROPROCESSOR ARCHITECTURE & SEGMENTATION
EE3541 Introduction to Microprocessors
Basic Microprocessor Architecture
contains 8086 processor and several additional functional chips: clock generator 2 independent DMA channels PIC 3 programmable 16-bit timers.
8086/8088 Hardware Specifications
8085 Microprocessor Architecture
Mikroişlemci Sistemleri
Subinterogări multiple
Prof. Elena Răducanu, Colegiul Naţional Bănăţean,Timişoara
CUPRINS Tastatura Imprimanta Scanner Bibliografie Recapitulare.
An Introduction to Microprocessor Architecture using intel 8085 as a classic processor
Structura unui calculator
Proiectarea Microsistemelor Digitale
METODA BACKTRACKING Examenul de bacalaureat 2012
6 Gestiunea memoriei 21 martie martie 2011
MANAGEMENT EDUCAŢIONAL PERFORMANT Limbajul de programare Borland Pacal
Tipuri structurate Tipul tablou
Subject Name: Microprocessors Subject Code:10EC46 Department: Electronics and Communication Date: /19/2018.
Curs 2 1 Sistem de operare-concepte: 2 Apeluri de sistem
Modificarea structurii unei tabele
Curs 6: Introducere în programarea SAS
Tehnoredactarea computerizată
Forms (Formulare).
Universitatea POLITEHNICA din București - Curs de 16 ore – Curs 11
Functia de documentare
Bazele Tehnologiei Informaţiei Curs 13
Din punct de vedere structural:
Unitatea centrală de prelucrare
Aplicaţii specializate pentru realizarea unei prezentări – PowerPoint
Introduction to Advanced Processors
8085 Microprocessor Architecture
Funcții NULL.
第四章 80386的存贮器和输入/输出接口 作业:P335 5,7,13,17,21,25,36,37,41,44,45,46,48,52,65 21:46.
UNIT-VII Advanced Micro Processors Introduction to 80286
Flags Carry flag Overflow Parity flag Direction Interrupt enable
8085 Microprocessor Architecture
AGENDA Architecture Microprocessor Communication and Bus Timings
First Generation 32–Bit microprocessor
AGENDA Architecture Microprocessor Communication and Bus Timings
8086 microprocessior PIN OUT DIAGRAM OF  Power supply and frequency signals  It uses 5V DC supply at V CC pin 40, and uses ground at V SS pin.
Presentation transcript:

Structura procesoarelor din familia INTEL Structura procesorului 286 Funcţionarea (ciclul) procesorului: 1.Citeşte instrucţiunea - pe durata acestui ciclu se transmite adresa instrucţiunii de executat şi se aduce, din memorie, instrucţiunea în CPU (ciclul Fetch); 2. Decodifică instrucţiunea (şi în paralel citeşte un posibil operand de 16 biţi); 3. Transmite adresa şi citeşte un operand sursă, din memorie, dacă se specifică în instrucţiune, şi citeşte valoarea registrului destinaţie (ciclul Read); 4. Execută instrucţiunea (ciclul Execution); 5. Transmite adresa şi scrie rezultatul în memorie, dacă instrucţiunea cere (ciclul Write); C2

C2

C2

D15 ÷ D0 = magistrala, bidirecţională, de date; ea este folosită ca intrare pentru date de la memorie, porturi de I/O, cicluri de recunoaştere întrerupere şi folosită ca ieşire pentru datele transmise la memorie sau porturi de I/O; A23 ÷ A0 = magistrala de adrese (de ieşire), care furnizează adresa fizică de memorie sau adresa unui port de I/O; BHE\ = acest semnal indică un transfer de date pe octetul superior (Bus High Enable), al magistralei de date (D15 ÷ D8). Acest semnal, de ieşire, împreună cu linia de adresă A0 determină tipul de transfer realizat pe magistrală: octet superior (D15 ÷ D8), octet inferior (D7 ÷ D0) sau cuvânt (D15 ÷ D0); M/IO\ = acest semnal, de ieşire, separă accesele la memorie de cele din spaţiul I/O (Memory / Input-Output); dacă este 1 pe durata lui TS se execută un ciclu de memorie sau halt; dacă este 0 se execută un ciclu I/O sau recunoaştere întrerupere. C2

S1\, S0\ = stare magistrală, care indică iniţierea unui ciclu, şi împreună cu M/IO\ şi COD/INTA\ definesc tipul ciclului: halt, recunoaştere întrerupere, citire/scriere de date în memorie, citire/scriere date de la/la porturi I/O, citire instrucţiune din memorie (fetch), nu este ciclu magistrală, şi unele rezervate. COD/INTA\ = semnal (Code/ INTerrupt Acknowledge), de ieşire, utilizat pentru separarea ciclurilor fetch de ciclurile de citire date din memorie, respectiv cicluri de recunoaştere întrerupere de cicluri I/O, în combinaţie cu celelalte semnale (S1\, S0\, M/IO\). LOCK\ = semnalul 'bus LOCK' specifică unui alt modul master de pe magistrala sistemului că nu poate prelua controlul magistralei. Semnalul este activat de prefixul instrucţiune cu acelaşi nume, LOCK, sau automat de hard- ul procesorului 286 pe durata execuţiei unei instrucţiuni XCHG cu memoria, pe durata recunoaşterii unei întreruperi sau pe durata unui acces la tabela de descriptori de segment. C2

READY\ = semnalul de intrare 'bus READY' termină un ciclu de magistrală; ciclurile de magistrală sunt extinse fără limită până când semnalul READY\ devine activ (LOW). HOLD, HLDA = cele două semnale 'bus HOLD request' şi 'bus HOLD Acknowledge', primul de intrare, iar cel de-al doilea de ieşire permit controlul magistralei; semnalul HOLD permite unui alt modul master (procesor) să ceară controlul asupra magistralei locale; când controlul este recunoscut (cedat), procesorul 286 trece magistrala sa (date, adrese, stări) în starea de mare impedanţă, şi activează semnalul de răspuns HLDA, intrând în starea 'hold' (magistrala suspendată). Magistrala este preluată de celalalt master (procesor) până când semnalul HOLD devine inactiv (LOW), iar procesorul 286 dezactivează linia HLDA, recâştigând controlul asupra magistralei locale. C2

INTR = activarea acestui semnal, de intrare, (HIGH) va cere procesorului 286 să-şi suspende execuţia programului curent şi să servească o cerere externă ('INTerrupt Request'). Întreruperile pot fi mascate (anulate), când IF = 0. Când 286 răspunde la o cerere de întrerupere, el realizează 2 cicluri magistrală de recunoaştere întrerupere, pentru a citi un vector de întrerupere, de 8 biţi, care identifică sursa întreruperii. Pentru a asigura întreruperea programului, INTR trebuie să rămână activ până este completat primul ciclu de recunoaştere întrerupere, pe durata căruia se transmite semnalul de recunoaştere a întreruperii INTA\. NMI = semnalul de intrare 'Non Maskable Interrupt', activ (HIGH), reprezintă tot o cerere de întrerupere externă, dar nemascabilă, deci nu are nici o semnificaţie starea indicatorului IF pentru acest semnal. Pentru această întrerupere nu se realizează cicluri de recunoaştere întrerupere, şi se generează un vector de întrerupere intern, cu valoarea 2. C2

PEREQ, = 'Processor Extension operand REQuest', intrare şi PEACK\, = 'Processor Extension operand ACKnowledge', de ieşire, extind facilităţile de protecţie şi administrare a memoriei virtuale, ale procesorului 286, şi pentru extensii procesor (80287); BUSY\, = semna intrare, 'processor extension BUSY' şi ERROR\, = 'processor extension ERROR', indică condiţia de operare a unei extensii procesor pentru procesorul 286; C2

C2

Pe durata unui ciclu de magistrală se realizează operaţiile: se activează pe magistrala de adrese, adresa unei locaţii de memorie, sau a unui port I/O, şi se memorează într-un registru de adrese, extern; se generează semnalul de comandă corespunzător, pentru citire/scriere date; dispozitivul selectat (memoria sau portul I/O) realizează transferul de date, şi transmite procesorului un semnal de răspuns, pentru a încheia ciclul. Controllerul de magistrală (82288) decodifică semnalele de stare (S1\, S0\, M/IO\, COD/INTA\ şi READY\) pentru a genera comenzi de citire /scriere (MRDC\, MWTC\, IORC, IOWC) şi semnale pentru comanda latch-urilor de adrese şi transmisie/recepţie date (ALE, DEN, DT/R\). C2

C2 Limit and Attribute PLA Translation Lookaside Buffer Bus Control BRDY#, BLAST# 128 Prefetcher 32 Physical Address 32 – bit Data Bus BS16#, BS8# W/R#, D/C#, M/IO#, PCD, PWT, RDY#, LOCK#, PLOCK#, BOFF#, A20M#, BREQ, HOLD, HLDA, INTR, NMI, RESET, FERR A2 - A31, BE0# - BE3# Bus Interface PCD, PWT micro-instruction Decoded Instruct. Write Buffers 4 x 80 Data Bus Transceivers Barrel Shifter Register File ALU Segmentation Unit Descriptor Registers Limit and Attribute PLA Paging Unit Translation Lookaside Buffer Cache Unit Base/ Index Bus 8K Byte Cache 20 32 Byte Code Queue 2 x 16 Bytes Displacement Bus Instruction Decode Control and Protection Test Unit Control ROM 24 Code Stream Floating Point F. P. Register File Bus Control Request Sequencer Burst Bus Control Bus Size Control Cache Control Parity Generation and Control D0 - D31 KEN#, FLUSH# AHOLD, EADS# PCHK# DP0 – DP3 Linear Address Bus 64 – bit Interunit Transfer Bus C2

C2

La procesorul 386/486 acest registru (EFLAGS) are 32 biţi, dintre care ultimii 16 sunt identici cu aceştia, dar în plus mai sunt utilizaţi încă doi biţi (16 şi 17) care au următoarea semnificaţie: RF (Resume Flag) - acest indicator dezactivează, temporar, excepţiile de depanare (debug), astfel încât să se poată restarta o instrucţiune după o excepţie de depanare, fără a se genera, imediat, o altă excepţie de depanare; adică nu se execută o instrucţiune de breakpoint, dacă este returnat controlul de excepţia de depanare direct la o astfel de instrucţiune. VM (Virtual 8086 Mode) - acest bit indică că se execută un program 8086, dacă este poziţionat pe 1. Bitul VM furnizează modul V86, in modul protejat de operare C2

C2

C2

- dimensiunea segmentului (1 ÷ 64 Kocteţi); Descriptorii de segment de date şi cod, conţin, pe lângă adresa de bază a segmentului, şi alte atribute de segment: - dimensiunea segmentului (1 ÷ 64 Kocteţi); - drepturi de acces (read only, read/write, execute only, execute/read); - prezenţa în memorie (pentru sistemele cu memorie virtuală). C2

C2

Nivelurile de privilegiu Mecanismele de protecţie ale procesorului 286 se bazează pe noţiunea de 'ierarhie de încredere' (sau de privilegiu). Există patru niveluri de privilegiu:0 - cel mai privilegiat, 3 - cel mai puţin privilegiat. Următoarele obiecte, recunoscute de procesor, conţin niveluri de privilegiu: descriptorii de segment conţin un câmp DPL - Descriptor Privilege Level, adică descriptor de nivel de privilegiu; selectoarele de segment conţin un câmp RPL - Requestor's Privilege Level, adică nivelul de privilegiu al procedurii căreia aparţine selectorul; un registru intern al procesorului memorează CPL - Current Privilege Level, care este egal cu DPL al segmentului pe care îl executa procesorul. C2

C2

C2

C2

Segmente de stare task (TSS) Un TSS este un segment special de memorie, pe care procesorul îl utilizează pentru a suporta mutitasking. Acesta conţine o copie a tuturor registrelor ce trebuie salvate, pentru a reface starea unui task; el mai conţine valori ce sunt asociate task-ului, dar nu sunt memorate în registrele CPU. TSS conţine trei selectori de segment de stivă, adiţionali, (SS0, SS1, SS2), şi trei pointeri de stivă corespunzători (ESP0, ESP1, ESP2). Când un apel sau întrerupere, printr-o poartă determină o modificare în privilegiu, noile SS:ESP, sunt încărcate din TSS. Registrul de task (TR) conţine selectorul TSS activ, curent. Când apare o comutare de task, toate registrele task-ului curent executat sunt salvate în TSS-ul activ. Registrul task se încarcă, apoi, cu selectorul unui nou TSS, şi fiecare registru general este încărcat cu valorile respective, din noul TSS. TSS mai conţine ‘legătura înapoi’ (back link) care reprezintă selectorul TSS-ul executat anterior. C2

Organizarea spaţiului de I/O Procesorul are două spaţii de adrese fizice distincte: memoria şi I/O (intrări/ieşiri). Locaţiile din spaţiul I/O sunt denumite registre dispozitiv sau porturi de I/O. În general perifericele sunt plasate în acest spaţiu, deşi procesorul poate permite maparea (suprapunerea) în memorie a perifericelor. Pentru a accesa acest spaţiu nu se utilizează registre segment, şi deci nici mecanismul de segmentare sau pagină. Pinul M/IO\ specifică spaţiul de memorie adresat (fizică sau I/O). Instrucţiunile I/O, IN şi respectiv OUT, pot furniza adresa direct în instrucţiune, ca o constantă de 8 biţi (deci pentru porturile din spaţiul 0-255), sau indirect prin registrul DX (deci pentru tot spaţiul de 64 K). DMA (Direct Memory Access) C2