Escolar Documentos
Profissional Documentos
Cultura Documentos
Computadores
Prof. Fernando V. Salina
Cap. 17 – pags 514-552
William Stallings
Arquitetura e Organização de Computadores
Processamento Paralelo
Organizações de múltiplos
processadores
• Processador único.
• Única sequência de instruções.
• Dados armazenados na única memória.
• Uniprocessadores.
Instrução única, múltiplos dados −
SIMD
• Única instrução de máquina.
• Controla execução simultânea.
• Número de elementos de processamento.
• Base inflexível.
• Cada elemento de processamento possui memória de
dados associada.
• Cada instrução executada em conjunto diferente de
dados por processadores diferentes.
• Processadores de vetores e matrizes.
Múltiplas instruções, único dado −
MISD
• Sequência de dados.
• Transmitidos ao conjunto de processadores.
• Cada processador executa uma sequência de
instruções diferente.
• Nunca foi implementado comercialmente.
Múltiplas instruções, múltiplos dados
− MIMD
• Conjunto de processadores.
• Executam simultaneamente diferentes sequências
de instruções.
• Diferentes conjuntos de dados.
• SMPs, clusters e sistemas NUMA.
Taxonomia das arquiteturas de
processador paralelo
MIMD – Visão geral
• Desempenho:
• Se algum trabalho puder ser feito em paralelo.
• Disponibilidade:
• Como todos os processadores podem realizar as mesmas
funções, a falha de um único processador não interrompe o
sistema.
• Crescimento incremental:
• Usuário pode melhorar o desempenho acrescentando
processadores adicionais.
• Escalabilidade:
• Fornecedores podem oferecer uma série de produtos com base
no número de processadores.
Diagrama de blocos do multiprocessador
fortemente acoplado
Organização do multiprocessador
simétrico
Considerações sobre sistema
operacional
• Thread em processadores multithreaded podem ou não ser o mesmo que threads por software.
• Processo:
• Uma instância do programa executando no computador.
• Posse do recurso.
• Espaço de endereço virtual para manter imagem do processo.
• Escalonamento/execução.
• Troca de processos.
• Thread: unidade de trabalho do processo que pode ser despachada.
• Inclui contexto do processador (que inclui o contador de programa e ponteiro de pilha) e
área de dados para pilha.
• Thread executada sequencialmente.
• Interrupção: processador pode passar para outra thread.
• Troca de thread:
• Troca do processador entre threads do mesmo processo.
• Normalmente, custa menos que a troca de processo.
Multithreading implícito e explícito