Arquitetura de computadores: diferenças entre revisões

Origem: Wikipédia, a enciclopédia livre.
Conteúdo apagado Conteúdo adicionado
→‎Pipeline ou segmentação das instruções: Correção do uso indevido de maiúscula. Inserção de itálico em termos ingleses. Emprego de termos equivalentes em língua portuguesa, quando existentes.
Troquei o d pelo s
Linha 24: Linha 24:
Historicamente, a memória de acesso aleatório (RAM) foi centenas de vezes mais cara que o armazenamento mecânico rotativo, isto é, [[discos rígidos]], num computador moderno.
Historicamente, a memória de acesso aleatório (RAM) foi centenas de vezes mais cara que o armazenamento mecânico rotativo, isto é, [[discos rígidos]], num computador moderno.


O [[Processador gráfico|processador]] só pode executar uma instrução que esteja na memória real. O mecanismo de Memória Virtual divide a memória real em framed e divide um arquivo no disco em páginas de mesmo tamanho dos ''frames''. No disco existem muito mais páginas do que ''frames'' na memória. Sempre que for preciso uma página é copiada da memória virtual (arquivo em disco) para um ''[[frame]]'' da memória real. Surge a necessidade de saber quando é preciso copiar. Surge a necessidade de saber se um ''frame'' pode ser descartado ou se precisa ser recopiado para sua página correspondente no [[Arquivo de computador|arquivo]] em disco. Sempre que uma instrução é executada a partir de um ''frame'' o hardware controlador de [[memória virtual]] testa se o dado a que ela se refere já se encontra em algum ''frame''. Se for o caso, uma interrupção ocorre para que a rotina de tratamento cuide de copiar do disco para a memória real uma página completa contendo o dado necessário.
O [[Processador gráfico|processador]] só pode executar uma instrução que esteja na memória real. O mecanismo de Memória Virtual divide a memória real em frames e divide um arquivo no disco em páginas de mesmo tamanho dos ''frames''. No disco existem muito mais páginas do que ''frames'' na memória. Sempre que for preciso uma página é copiada da memória virtual (arquivo em disco) para um ''[[frame]]'' da memória real. Surge a necessidade de saber quando é preciso copiar. Surge a necessidade de saber se um ''frame'' pode ser descartado ou se precisa ser recopiado para sua página correspondente no [[Arquivo de computador|arquivo]] em disco. Sempre que uma instrução é executada a partir de um ''frame'' o hardware controlador de [[memória virtual]] testa se o dado a que ela se refere já se encontra em algum ''frame''. Se for o caso, uma interrupção ocorre para que a rotina de tratamento cuide de copiar do disco para a memória real uma página completa contendo o dado necessário.


== Segmentação das instruções (''pipeline'') ==
== Segmentação das instruções (''pipeline'') ==

Revisão das 20h29min de 10 de maio de 2018

A evolução da informática foi caracterizada pelo desenvolvimento de computadores com as mais diversas características, traduzidas pelos diferentes parâmetros, cada vez mais conhecidos da maioria de usuários de computador: a CPU adotada, a capacidade de memória, a capacidade do disco rígido, a existência de memória cache e outros menos conhecidos. A definição destes parâmetros e a forma como os diversos componentes de um computador são organizados, define aquilo que é conhecido por arquitetura de computador e vai determinar aspectos relacionados à qualidade, ao desempenho e à aplicação para a qual o computador vai ser orientado.[1][2]

Existem vários modos de uso do termo, que podem se referir a:

A arquitetura é frequentemente definida como o conjunto de atributos da máquina que um programador deve compreender para que consiga programar o computador específico com sucesso, ou seja, para que consiga compreender o que o programa irá fazer quando da sua execução. Por exemplo, parte da arquitetura são as instruções e o raio de operadores manipulados por elas. De uma maneira semelhante, a frequência em que o sistema opera não é incluída na arquitetura. Esta definição revela as duas principais considerações dos arquitetos de computadores: desenhar hardware que se comporta como o programador pensa que se irá comportar e utilizar implementações existentes de tecnologias (por exemplo, semicondutores), para construir o melhor computador possível. A segunda consideração é frequentemente referida como a microarquitetura.[3]

História

A expressão "arquitetura de computadores", na literatura, pode ser atribuída a Lyle R. Johnson, Muhammad Usman Khan e Frederick P. Brooks, Jr. Em 1959, eram membros do departamento de Organização de Máquinas da IBM.

Johnson teve a oportunidade de escrever uma comunicação de pesquisa proprietária sobre Strech, um supercomputador desenvolvido pela IBM para o Laboratório Nacional de Los Alamos. Na tentativa de caracterizar o seu nível desejado de detalhe, ele observou que sua descrição de formatos, tipos de instruções, os parâmetros de hardware e melhorias de velocidade foi no nível de "arquitetura do sistema" - Um termo que parecia ser mais útil do que "organização de máquina".

Posteriormente, Brooks, um dos projetistas do Strech, começou o capítulo 2 de um livro (Planning a Computer System: Project Stretch, ed W. Buchholz, 1962), escrevendo: "Arquitetura de computadores, como outra arquitetura, é a arte de determinar as necessidades do usuário de uma estrutura e, possível dentro das limitações econômicas e tecnológicas.".

Brooks passou a desempenhar um papel no desenvolvimento do IBM System/360(agora chamado de IBM System z) linha de computadores, onde a "arquitetura" ganhou moeda como um substantivo com a definição como "o que o usuário precisa saber". Mais tarde, o mundo da informática, empregaria o termo, em formas muito menos explícitas.

Memória virtual

Outro problema recorrente envolve a memória virtual.

Historicamente, a memória de acesso aleatório (RAM) foi centenas de vezes mais cara que o armazenamento mecânico rotativo, isto é, discos rígidos, num computador moderno.

O processador só pode executar uma instrução que esteja na memória real. O mecanismo de Memória Virtual divide a memória real em frames e divide um arquivo no disco em páginas de mesmo tamanho dos frames. No disco existem muito mais páginas do que frames na memória. Sempre que for preciso uma página é copiada da memória virtual (arquivo em disco) para um frame da memória real. Surge a necessidade de saber quando é preciso copiar. Surge a necessidade de saber se um frame pode ser descartado ou se precisa ser recopiado para sua página correspondente no arquivo em disco. Sempre que uma instrução é executada a partir de um frame o hardware controlador de memória virtual testa se o dado a que ela se refere já se encontra em algum frame. Se for o caso, uma interrupção ocorre para que a rotina de tratamento cuide de copiar do disco para a memória real uma página completa contendo o dado necessário.

Segmentação das instruções (pipeline)

O conjunto e instruções orienta fortemente como funcionará a segmentação de instruções. A ideia é análoga a linha de produções em série, mas utilizada na execução das instruções. Primeiro divide-se as instruções em pedaços menores de forma que uma instrução em código de máquina demore muitos ciclos curtos para ser executada. Depois disso o controle do microprocessador encarrega-se de executar várias instruções ao mesmo tempo, cada uma utilizando um pedaço distinto do processador. Isto tem como objetivo que na média cada instrução demore um ciclo curto para ser executada. Existem diversas complicações em instruções de desvio (condicionais), que são tratadas por paralelismo de código conhecida como threading (nome comercial da Intel Hyperthreading).

Referências

  1. Gerrit A. Blaauw & Frederick P. Brooks (1997). Computer Architecture: Concepts and Evolution. [S.l.]: Addison-Wesley. ISBN 0-201-10557-8 
  2. Anthony Ralston & Edwin D. Reilly (1993). Encyclopedia of Computer Science Third Edition. [S.l.]: Van Nostrand Reinhold. ISBN 0-442-27679-6 
  3. [1]

Ligações externas