quarta-feira, 4 de fevereiro de 2009

Organização de Computadores


Organização de Computadores


Conteúdo das apostilas:

INF-1

Capa: é só a capa!

INF-2

Sumário

INF-3

1.1 Representação da informação: nessa apostila são tratados tópicos mais introdutórios e históricos, como:

  • o que é informação – é qualquer sinal transmitido (Shannon), sinal elétrico, visual, palavras...

  • o que é processamento da informação – refere-se ao armazenamento, transmissão, combinação e comparação da informação;

  • representação da informação – fala sobre gestos, pinturas nas paredes, até chegar no alfabeto e nos algarismos e nos sistemas de númeração.

INF-4

1.2 Evolução do computador: nesse capítulo há um pouco da história das máquinas de computação e seus inventores (Pascal, Babbage, Ada...). Um item importante historicamente é a calculadora analítica de Babbage, essa calculadora era composta por um dispositivo analítico chamado de MOINHO (máquina de somar com precisão de 50 casas decimais), um dispositivo de ENTRADA que leria cartões perfurados contendo não somente números (dados) mas também INSTRUÇÕES (o que fazer com os dados), um memória chamada de ARMAZÉM para guardar números (originados da entrada ou do moinho) e um dispositivo impressor para dar a SAÍDA dos resultados. Para a elaboração desta máquina ele contou com a ajuda da matemática Ada Byron. Babbage é considerado o percursor do computador e Ada a percursora do software.

1.3 Modelo hipotético de um computador: dá uma visão superficial do computador (elementos básicos e funcionamento), da seguinte forma:

  • Operador: só faz o que for ordenado, não toma decisões;

  • Conjunto de escaninhos: com capacidade para um cartão;

  • Máquina de calcular: executa as operações;

  • Caixa de entrada: para receber cartões de fora;

  • Máquina de escrever: para dar saída as informações/resultados

Em cada cartão há instruções, o operador percorrer todos os escaninhos executando as instruções, até que haja uma instrução de parada.

Ainda nesse capítulo o autor dá uma série de definições fazendo analogias com o modelo hipotético, por exemplo, escaninho = memória; processador = operador e máquina de calcular, além de outras definições como hardware, firmware, software...

1.4 A arquitetura de um computador: o capítulo começa dizendo que a arquitetura básica dos computadores atuais segue o modelo criado por Von Neumann. Na arquitetura de Von Neumann os computadores teriam que:

  • Codificar instruções que pudessem ser armazenadas na memória, ele sugeriu utilizar cadeias de 0s e 1s para essa codificação;

  • Armazenar na memória as instruções e todas as informações necessárias para execução da instrução;

  • Buscar as instruções diretamente na memória quando o programa fosse processado.

    Diagrama de Blocos de um Computador


    1.4.1 Unidade central de processamento (UCP): é a responsável por processar e executar os programas que estão na memória principal. É composta por:

  • Unidade lógica e aritmética (ULA): realiza as operações lógicas (e, ou...) e aritméticas (soma...);

  • Unidade de controle: envia sinais de controle para toda a máquina, de forma que todos os dispositivos funcionem adequadamente e sincronizadamente.

Com isso a tem duas funções básicas: executar as instruções (realizar aquilo que a instrução determinar); e realizar o controle das operações do computador.

1.4.2 Memória principal: armazena toda a informação que é manipulada pelo computador – programas e dados. Para que um programa possa ser manipulado pela máquina, ele precisa estar na memória principal. É a memória RAM.

Hierarquia de memória: a memória principal não é a única memória existente. É montada uma hierarquia para classificar as outras em função do tempo de acesso, do custo e da capacidade:


Tipo: capac. | velocidade | custo | localização | volátil
Registrador: bytes | muito alta | muito alto | ucp | sim
Memória cache: KBytes | alta | alto | ucp/placa | sim
Memória principal: MBytes | média | médio | placa | sim
Memória auxiliar: GBytes | baixa | baixo | externo | não


A unidade central de processamento vê nessa ordem e acessa primeiro as que estão mais próximas e são mais rápidas. A medida que se afasta da UCP, as memórias ficam mais lentas, mais baratas e com maior capacidade.

Registradores: surgiram da necessidade de armazenar dados temporariamente durante o processamento, são rápidos, caros, com capacidade para apenas um dado e estão localizados na UCP. Eles são voláteis, ou seja, precisam estar energizados para armazenar a informação.

Memória Cache: as UCPs evoluíram em termos de velocidade enquanto as memórias evoluíram em termos de capacidade de armazenamento, com isso, o tempo de acesso as memórias tornou-se insatisfatório pois a UCP ao buscar um dado na memória precisava esperar vários ciclos (wait states) até a memória retornar o dado buscado e isso tornou-se um gargalo (botleneck) para os sistemas. Para resolver esse problema criou-se um tipo de memória que dava privilégio ao tempo de acesso.

A arquitetura da memória cache é diferente da arquitetura da memória principal e o acesso a ela é muito mais rápido. Como o custo da memória cache é superior ao da memória principal é inviável construir um computador apenas com memória cache, por isso, a forma de resolver o problema do gargalo foi incorporar uma pequena porção de memória cache, localizada entre a UCP e a MP, que funciona como espelho da memória principal.

Desenvolveram-se algoritmos que fazem com que, a cada momento, a memória cache armazene uma porção dos dados ou códigos que estão sendo utilizados pela UCP. A transferência

MP<->Cache é feita por hardware, nem o programador, nem o sistema operacional sabem da existência da cache. O funcionamento da memória cache é baseado nas estatísticas das execuções dos programas que dizem que pequenos trechos de códigos são referenciados várias vezes, logo, eles são candidatos a ficar na cache. Quando a UCP procura determinado trecho de código e o encontra na cache, sem ter que procurar na mp, dá-se um cache-hit. Quando o dado não é encontrado na cache, ocorre um cache-miss, e o mesmo terá que ser buscado na MP. A taxa de cache-hit é superior a 90%. Memórias cache são voláteis e precisam estar energizadas para armazenar informação.

Memórias auxiliares: resolvem o problema do armazenamento de grandes quantidades de informação. O custo por bit armazenado é muito menor que o da mp. São não voláteis. Exemplos: HD, CD, DVD, 

Nenhum comentário: