Arquitetura risc e cisc
Hoje vamos falar de um assunto que, vez ou outra, costuma ser cobrado em provas de concursos, principalmente para cargos de infra-estrutura ou mesmo naqueles cargos genéricos que não separam desenvolvimento de infra. É um assunto básico, geralmente ensinado no início do curso de Ciência da Computação (e correlatos), mas que é de extrema importância para entendermos a arquitetura por trás dos computadores. Estamos falando das arquiteturas RISC e CISC.
Nosso objetivo é entender as definições destas arquiteturas e, principalmente a diferença entre elas, ponto que costuma ser cobrado incessantemente nas provas.
Vamos lá.
Máquinas CISC ( complex Instruction Set Computer) tem um conjunto de instruções grande, de tamanhos variáveis, com formatos complexos. Muitas dessas instruções são bastante complicadas, executando múltiplas operações quando uma única instrução é dada (por exemplo, é possível realizar um loop complexo usando apenas uma operação assembly). O problema básico com máquinas CISC é que um conjunto pequeno de instruções complexas torna o sistema consideravelmente mais lento. Os projetistas decidiram retornar a uma arquitetura mais simples, delegando ao compilador a responsabilidade de produzir código eficiente com esse novo conjunto de instruções. Máquinas que utilizam essa filosofia são chamadas máquinas RISC.
A arquitetura RISC (Reduced Instruction Set Computer), como o próprio nome já diz, tem como principal objetivo simplificar as instruções de modo que elas possam ser executadas mais rapidamente. Cada instrução executa apenas uma operação, que são todas do mesmo tamanho, tem poucos formatos, e todas as operações aritméticas devem ser executadas entre registradores (dados da memória não podem ser utilizados como operandos). Praticamente todos os conjuntos de instruções (para qualquer arquitetura) lançados desde 1982 tem sido RISC, ou alguma combinação entre RISC e CISC.
Membros da família x86 de arquitetura Intel são