Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лаб2012 / 319433-011.pdf
Скачиваний:
27
Добавлен:
02.02.2015
Размер:
2.31 Mб
Скачать

POST-32NM PROCESSOR INSTRUCTIONS

NOTES:

1.If a source is denormal relative to input format with DM masked and at least one of PM or UM unmasked, then an exception will be raised with DE, UE and PE set.

8.4VECTOR INSTRUCTION EXCEPTION SPECIFICATION

The exception behavior of instructions operating on YMM states follows the updated classification table of Table 8-11. The instructions VCVTPS2PH and VCVTPS2PH are described by type 11.

Table 8-11. Exception class description

Exception Class

NI Family

Mem arg

Floating-Point

 

 

 

Exceptions

 

 

 

(#XM)

 

 

 

 

Type 1

AVX,

16/32 byte

none

 

Legacy SSE

explicitly aligned

 

 

 

 

 

Type 2

AVX, FMA,

16/32 byte; not

yes

 

Legacy SSE

explicitly aligned

 

 

 

with VEX prefix;

 

 

 

explicitly aligned

 

 

 

without VEX

 

 

 

 

 

Type 3

AVX, FMA,,

< 16 byte

yes

 

Legacy SSE

 

 

 

 

 

 

Type 4

AVX,

16/32 byte not

no

 

Legacy SSE

explicitly aligned

 

 

 

with VEX prefix;

 

 

 

explicitly aligned

 

 

 

without VEX

 

 

 

 

 

Type 5

AVX,

< 16 byte

no

 

Legacy SSE

 

 

 

 

 

 

Type 6

AVX (no Legacy

Varies

(At present,

 

SSE)

 

none do)

 

 

 

 

Type 7

AVX,

none

none

 

Legacy SSE

 

 

 

 

 

 

Type 8

AVX

none

none

 

 

 

 

Type 9

AVX

4 byte

none

 

 

 

 

Type 10

AVX, Legacy SSE

16/32 byte; not

no

 

 

explicitly aligned

 

 

 

 

 

Type 11

AVX

Not explicitly

yes

 

 

aligned, no AC#

 

 

 

 

 

Ref. # 319433-011

8-9

POST-32NM PROCESSOR INSTRUCTIONS

8.4.1Exception Type 11 (VEX-only, mem arg no AC, floating-point exceptions)

Exception

Real

Virtual 80x86

Protected and Compatibility

64-bit

Cause of Exception

 

 

 

 

 

 

 

 

 

X

X

 

 

VEX prefix

 

 

 

 

 

 

 

 

 

 

 

VEX prefix:

 

 

 

X

X

If XFEATURE_ENABLED_MASK[2:1] != ‘11b’.

Invalid Opcode, #UD

 

 

 

 

If CR4.OSXSAVE[bit 18]=0.

 

 

 

 

 

X

X

X

X

If preceded by a LOCK prefix (F0H)

 

 

 

 

 

 

 

 

 

 

X

X

If any REX, F2, F3, or 66 prefixes precede a

 

 

 

VEX prefix

 

 

 

 

 

 

 

 

 

 

 

 

X

X

X

X

If any corresponding CPUID feature flag is ‘0’

 

 

 

 

 

 

Device Not Available,

X

X

X

X

If CR0.TS[bit 3]=1

#NM

 

 

 

 

 

 

 

 

 

 

 

 

 

 

X

 

For an illegal address in the SS segment

Stack, SS(0)

 

 

 

 

 

 

 

 

X

If a memory address referencing the SS seg-

 

 

 

 

ment is in a non-canonical form

 

 

 

 

 

 

 

 

 

 

 

 

 

 

X

 

For an illegal memory operand effective

 

 

 

 

address in the CS, DS, ES, FS or GS segments.

 

 

 

 

 

 

 

 

 

 

 

General Protection,

 

 

 

X

If the memory address is in a non-canonical

#GP(0)

 

 

 

form.

 

 

 

 

 

 

 

 

 

 

 

X

X

 

 

If any part of the operand lies outside the

 

 

 

effective address space from 0 to FFFFH

 

 

 

 

 

 

 

 

 

 

 

Page Fault

 

X

X

X

For a page fault

#PF(fault-code)

 

 

 

 

 

 

 

 

 

 

 

 

SIMD Floating-Point

X

X

X

X

If an unmasked SIMD floating-point exception

Exception, #XM

 

 

 

 

and CR4.OSXMMEXCPT[bit 10] = 1

 

 

 

 

 

 

8.5FS/GS BASE SUPPORT FOR 64-BIT SOFTWARE

64-bit code can use new instructions to access and modify FS and GS base. These new instructions are available to software in all privilege levels. CR4 register bit 16 allows system software to control the availability of these instructions to software.

CR4.FSGSBASE

8-10

Ref. # 319433-011

POST-32NM PROCESSOR INSTRUCTIONS

FSGSBASE-Enable Bit (bit 16 of CR4) — Enables RDFSBASE/RDGSBASE/WRFSBASE/WRGSBASE instructions in all privilege levels when set. When clear, RDFSBASE/RDGSBASE/WRFSBASE/WRGSBASE instructions cause #UD in all privilege level. The default value of this bit is zero after RESET.

RDFSBASE/RDGSBASE/WRFSBASE/WRGSBASE instructions are available only 64-bit sub-mode of the IA-32e mode. Access to CR4.FSGSBASE is available in all operating modes if CPUID.(EAX=07H, ECX=0H):EBX.FSGSBASE is 1.

NOTE

It is highly recommended that REX.W prefix is used with these instructions to read/write full 64-bit value. If REX.W prefix is omitted, when reading from segment base, upper 32-bits will be ignored and will be set to zero in destination registers. If REX.W prefix is omitted for write to segment base, the upper 32-bits of source resister will be ignored and the corresponding bits for segment base will be set to zero. Additionally, if the OS enables these instructions it must also context switch GS and FS base to ensure that any changes made by the applications to the segment base are appropriately context switched.

8.6USING RDRAND INSTRUCTION AND INTRINSIC

The RDRAND instruction returns a random number. All Intel processors that support the RDRAND instruction indicate the availability of the RDRAND instruction via reporting CPUID.01H:ECX.RDRAND[bit 30] = 1.

RDRAND returns random numbers that are supplied by a cryptographically secure, deterministic random bit generator (DRBG). The DRBG is designed to meet the NIST SP 800-90 standard. The DRBG is re-seeded frequently from a on-chip non-deter- ministic entropy source to guarantee data returned by RDRAND is statistically uniform, non-periodic and non-deterministic.

In order for the hardware design to meet its security goals, the random number generator continuously tests itself and the random data it is generating. Runtime failures in the random number generator circuitry or statistically anomalous data occurring by chance will be detected by the self test hardware and flag the resulting data as being bad. In such extremely rare cases, the RDRAND instruction will return no data instead of bad data.

Under heavy load, with multiple cores executing RDRAND in parallel, it is possible, though unlikely, for the demand of random numbers by software processes/threads to exceed the rate at which the random number generator hardware can supply them. This will lead to the RDRAND instruction returning no data transitorily. The RDRAND instruction indicates the occurrence of this rare situation by clearing the CF flag.

The RDRAND instruction returns with the carry flag set (CF = 1) to indicate valid data is returned. It is recommended that software using the RDRAND instruction to get random numbers retry for a limited number of iterations while RDRAND returns CF=0

Ref. # 319433-011

8-11

Соседние файлы в папке Лаб2012