SuperHSuperH (ou SH) é uma arquitetura de microcontroladores e microprocessadores. O núcleo SuperH é fundamentalmente uma arquitetura RISC encontrada em uma grande quantidade de sistemas embarcados. HistóriaA arquitetura SuperH foi criada pela Hitachi no início da década de 1990 para suceder o H8. O SH-1 e o SH-2 foram utilizados nos videogames Sega Saturn e Sega 32X e possuem instruções de 16 bits com o objetivo de ter maior densidade que instruções de 32 bits, isso era um benefício devido ao alto custo das memórias. Após alguns anos, o SH-3 passou a fazer parte da família de microprocessadores SuperH, nele foram incluídos um outro conceito de interrupção, uma unidade de gerenciamento de memória e uma modificação no conceito de cache. O SH-3 também possui uma extensão de DSP que foi nomeado SH-3-DSP. Entre 1994 e 1996, 35,1 milhões de dispositivos SuperH haviam sido vendidos pelo mundo. Em 1998 a Hitachi desenvolveu o SH-4 para o videogame Sega Dreamcast. Os destaques do SH-4 foram uma arquitetura superescalar (2-way) de execução de instruções e uma unidade de execução em ponto flutuante. No início de 2001 a Hitachi juntamente com a STMicroelectronics fundou a SuperH Inc, que além de licenciar o SH-4 para outras empresas estava desenvolvendo o SH-5, que seria o primeiro microprocessador da SuperH Inc de 64 bits, porém, em 2004 a SuperH Inc vendeu a patente dos microprocessadores para a Renesas Technology, que passou a ser chamada de Renesas Electronics em 2010. O SH-5 possui dois modos de operação: o SHcompact é equivalente ao conjunto de instruções do SH-4. O diferencial é o SHmedia que utiliza instruções de 32 bits, possui sessenta e quatro registradores de 64 bits e paralelismo SIMD. A evolução da arquitetura SuperH continua, o último passo revolucionário ocorreu em 2003, onde os núcleos do SH-2 até o SH-4 foram unificados em um núcleo superescalar denominado SH-X, que forma uma espécie de conjunto de instruções das arquiteturas anteriores. Atualmente, os microprocessadores SuperH pertencem a Renesas Electronics, uma fusão dos grupos de semicondutores Hitachi e Mitsubishi Electric. J Core O último núcleo da série SH-2 expirou em 2014. Na LinuxCon de 2015 no Japão, os desenvolvedores do J-Core apresentaram uma reimplementação cleanroom do conjunto de instruções SH-2 ISA com extensões (conhecida como "J2 Core").[1] Subsequentemente, um design passo a passo foi apresentado na ELC 2016.[2] O open source BSD licenciado VHDL para o J2 Core tem sido testado nas FPGAs da Xilinx e no ASICs produzido por TSMC's através do método 180 nm, e é capaz de inicializar o µClinux.[3] J2 é oposto a ISA compatível com o SH-2, implementado com uma pipeline de 5 etapas, com Instruções e Dados em memórias separadas, e um Decodificador de Instruções gerado por máquina, suporta a densa e complexa ISA. Instruções adicionais são fáceis de acrescentar. J2 implementa instruções para troca dinâmica (usando o SH-3 e mais tarde padrões de instruções) Várias características do SuperH tem sido citadas como motivações para o desenvolvimento de novos núcleos baseados nessa arquitetura:[3]
Modelos da arquitetura SuperH
SH-1[5]O SH-1 é o primeiro núcleo de CPU dos produtos da Família SuperH, é utilizado no console Sega Saturn para controlar o drive de CD e checar a proteção contra cópias nos discos de jogo. Características SH-1
Registradores de uso geral Existem 16 registradores de uso geral numerados de R0 a R15, que têm um tamanho de 32 bits. Os registradores gerais são usados para processamento de dados e cálculo de endereços. R0 também é usado como um indexador. Várias instruções usam R0 como fonte fixa ou registrador de destino. R15 é usado como o stack pointer (SP). O processamento de exceções é realizado referenciando a pilha usando R15. Registradores de Controle Os registradores de controle de 32 bits consistem em:
O registrador de status indica os estados de processamento. O registrador base vetorial funciona como endereço base do vetor de processamento de exceção (incluindo interrupções). Registradores do Sistema Os registradores do sistema consistem em quatro registradores de 32 bits:
Os registradores de multiplicação e acumulação armazenam os resultados das operações. O registrador de processo armazena o endereço de retorno do processo de subrotina. O program counter aponta os quatro bytes de endereço da próxima instrução a ser executada. Formato dos dados nos registradores Os operandos dos registradores são sempre longwords (32 bits). Quando um dado em memória é carregado para um registrador e o operando da memória é apenas um byte (8 bits) ou uma palavra (16 bits) ele é sign-extendend ou zero-extended em uma longword. Conjunto de Instruções tipo RISC Todas as instruções têm tamanho fixo de 16 bits. Instruções básicas podem ser executadas em um ciclo usando o pipeline. As instruções são executadas em 50 ns a 20 MHz, em 35 ns a 28,7 MHz. Longword é o tamanho padrão para todas as operações. A memória pode ser acessada em bytes, palavras ou longwords. Arquitetura Load-Store: operações básicas são executadas entre registradores. Para operações que envolvem acesso à memória, os dados são carregados nos registradores e executados. Instruções como AND que manipulam bits, no entanto, são executadas diretamente na memória. SH-1 tem 56 instruções. SH-2O SH-2 é uma arquitetura [RISC] de 32 bits, que possui 16 registradores de uso geral. O tamanho de suas instruções são de 16 bits e seu pipeline é composto por 5 estágios. Também conta com um registrador base para vetores, um registrador base global e um registrador de procedimentos. Atualmente é utilizada em uma variedade de dispositivos com diferentes periféricos, tais como CAN, Ethernet, unidade de temporização de controle do motor e outros. SH-2 é o processador principal por trás do Sega 32X e do Sega Saturn. Os dois consoles usam dois processadores SH-2 em paralelo. SH-2 tem 62 instruções. SH-2AUma otimização do SH-2, em 2007 foi considerado um dos microcontroladores mais rápidos do mundo devido ao seu clock de 160 MHz. As novas funcionalidades incluíam:
SH-4[6]O SH-4 é uma UCP baseada na filosofia RISC e foi desenvolvida inicialmente para aplicações multimídia, caso do Sega Dreamcast e o Sistema de jogos Naomi e incluía uma unidade de execução em ponto flutuante, juntamente com o processamento inteiro de 32-bit padrão e tamanho instrução de 16 bits. As novas funcionalidades incluíam:
Registradores em SH-4:
Existem 16 tipos de registradores, R0 até R15, os registradores gerais R0 a R7 são registradores programáveis.
Acesso para registradores que não dependem do modo do processador.
Existem trinta e dois registradores de ponto flutuante, FR0 – FR15 e XF0 – XF15. FR0 – FR15 e XF0 – XF15 podem ser atribuídos a um dos dois banks (FPR0_BANK0 – FPR15_BANK0 ou FPR0_BANK1 – FPR15_BANK1). Unidade de Gerenciamento de Memória (MMU): O MMU executa a tradução de endereços de alta velocidade, armazenando em cache informações da tabela de tradução de endereços criadas pelo usuário, em um buffer de tradução de endereços (translation lookaside buffer: TLB). O SH-4 possui quatro entradas TLB de instrução (ITLB) e 64 TLB unificado (UTLB). Entradas. As cópias UTLB são armazenadas no ITLB por hardware. O objetivo principal de uma MMU é garantir que o uso eficiente da memória física seja feito, que na maioria dos sistemas é um recurso limitante. A MMU é normalmente gerenciada pelo sistema operacional, que aloca páginas físicas de memória para páginas virtuais de memória, conforme exigido por uma tarefa. Páginas que são comutadas pelo sistema operacional são colocadas em um dispositivo de armazenamento secundário, como um disco rígido. SH-5[7]É um processador RISC de 64 bits que possui dois modos de operação: SHmedia e SHcompact.
Conjunto de instruções A maioria das instruções presentes no SH-5 é baseada na operação de dados, porém, há muitas outras com funções mais específicas e necessárias, como as de controle, memória e especiais. Referências
Ligações externas |