Streaming SIMD Extensions: diferenças entre revisões

Origem: Wikipédia, a enciclopédia livre.
Conteúdo apagado Conteúdo adicionado
Hgfernan (discussão | contribs)
m Sugestão de figura
Hgfernan (discussão | contribs)
m Pequena edição
Linha 5: Linha 5:
'''SSE''' ('''''S'''treaming [[SIMD|'''S'''IMD]] '''E'''xtensions'', inicialmente chamado '''ISSE''', de '''''I'''nternet '''S'''treaming '''S'''IMD '''E'''xtensions'') é um [[conjunto de instruções]] do tipo [[SIMD]] projetado pela [[Intel]]. Foi introduzido no mercado em [[1999]] no processador [[Pentium III]] como resposta à tecnologia [[3DNow!]] da [[AMD]] (que foi lançada um ano antes). O '''SSE''' trazia 70 novas instruções. O nome completo significa "Extensões SIMD para [[streaming]]".
'''SSE''' ('''''S'''treaming [[SIMD|'''S'''IMD]] '''E'''xtensions'', inicialmente chamado '''ISSE''', de '''''I'''nternet '''S'''treaming '''S'''IMD '''E'''xtensions'') é um [[conjunto de instruções]] do tipo [[SIMD]] projetado pela [[Intel]]. Foi introduzido no mercado em [[1999]] no processador [[Pentium III]] como resposta à tecnologia [[3DNow!]] da [[AMD]] (que foi lançada um ano antes). O '''SSE''' trazia 70 novas instruções. O nome completo significa "Extensões SIMD para [[streaming]]".


O SSE trazia 70 novas instruções.
O SSE trazia 70 novas instruções em relação ao conjunto de instruções anterior, do Pentium [[MMX]].


O SSE foi primeiro conhecido como '''KNI''', de ''Katmai New Instructions'', onde ''Katmai'' era o apelido do primeiro Pentium III com núcleo revisto. Durante o projeto Katmai a Intel procurava distingui-lo da sua linha anterior de produtos, particularmente do projeto [[Pentium II]].
O SSE foi primeiro conhecido como '''KNI''', de ''Katmai New Instructions'', onde ''Katmai'' era o apelido do primeiro Pentium III com núcleo revisto. Durante o projeto Katmai a Intel procurava distingui-lo da sua linha anterior de produtos, particularmente do projeto [[Pentium II]].

Revisão das 16h40min de 9 de agosto de 2007

Evolução das instruções SIMD

SSE (Streaming SIMD Extensions, inicialmente chamado ISSE, de Internet Streaming SIMD Extensions) é um conjunto de instruções do tipo SIMD projetado pela Intel. Foi introduzido no mercado em 1999 no processador Pentium III como resposta à tecnologia 3DNow! da AMD (que foi lançada um ano antes). O SSE trazia 70 novas instruções. O nome completo significa "Extensões SIMD para streaming".

O SSE trazia 70 novas instruções em relação ao conjunto de instruções anterior, do Pentium MMX.

O SSE foi primeiro conhecido como KNI, de Katmai New Instructions, onde Katmai era o apelido do primeiro Pentium III com núcleo revisto. Durante o projeto Katmai a Intel procurava distingui-lo da sua linha anterior de produtos, particularmente do projeto Pentium II.

O SSE foi uma resposta à tecnologia 3DNow! da AMD, lançada um ano antes. Mas a AMD rapidamente contra-atacou, aproveitando do projeto da Intel e adicionou suporte às instruções SSE, começando assim a era do famoso processador Athlon XP.

A Intel desapontou-se com seu primeiro esforço de desenvolvimento SIMD o IA-32 e o MMX. MMX possuía dois grandes problemas: ele re-utilizava pontos de flutuação registrados, fazendo com que a CPU ficasse impossibilitada de trabalhar em ambos Ponto de flutuação e instruções SIMD ao mesmo tempo, só funcionava com instruções simples.

O SSE adiciona oito novos registros 128-bits, conhecidos como XMM0 até XMM7. Cada registro pode armazenar quatro números 32-bit de ponto de flutuação ao mesmo tempo (single-precision).

Because these 128-bit registers are additional program states that the operating system must preserve across task switches, they are disabled by default until the operating system explicitly enables them. This means that the OS must know how to use the FXSAVE and FXRSTR instructions, which is the extended pair of instructions which can save all x87 and SSE register states all at once. This support was quickly added to all major IA-32 operating systems.

Because SSE adds floating point support, it sees much more use than MMX now that the graphics cards all handle integer calculations internally. Integer SIMD operations may still be performed with the eight 64-bit MMX registers. The MMX registers are "aliased" on top of the eight FPU registers. Later, Intel augmented SSE with the SSE2 instruction set, which added support for integer math. While redundant, MMX operations can be executed in parallel with SSE operations; offering great performance in limited situations.

O primeiro CPU a ter suporte ao SSE, o Pentium III, compartilhava recursos entre o SSE e o FPU. Enquanto aplicações eram compiladas de forma a utilizar instruções FPU e SSE lado a lado, os processadores Pentium III não eram capazes de operar estes dois tipos de instruções simultaneamente (num mesmo ciclo). Estas limitações reduziram a eficiência do chamado pipelining, embora os registros isolados XMM permitiam instruções SIMD e operações de ponto de flutuação escalares serem misturadas mas não tão eficientes quanto o modo MMX/floating point.

Versões posteriores

  • SSE2 foi introduzida com os processadores Pentium 4, e trouxeram melhorias significativas ao SSE (que alguns programadores passaram a chamar de "SSE1"). SSE2 adds new math instructions for double-precision (64-bit) floating point and 8/16/32-bit integer data types, all operating on the same 128-bit XMM vector register-file previously introduced with SSE. SSE2 enables the programmer to perform SIMD math of virtually any type (from 8-bit integer to 64-bit float) entirely with the XMM vector-register file, without the need to touch the (legacy) MMX/FPU registers. Many programmers consider SSE2 to be "everything SSE should have been", as SSE2 offers an orthogonal set of instructions for dealing with common datatypes.
  • SSE3 chamado de Prescott New Instructions, é um upgrade incremental ao SSE2, adicionando instruções matemáticas orientadas à DSP (DSP-oriented) e algumas instruções de manipulação de processos (thread).
  • SSSE3 é um upgrade ao SSE3, adicionando 16 novos códigos (opcode).
  • SSE4 é uma melhoria do padrão antecessor e adiciona um ponto de instrução do produto, diversas instruções adicionais (do tipo integer), uma instrução do tipo popcnt, entre outras.