Jump to content

Intel ADX

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by BattyBot (talk | contribs) at 18:28, 24 February 2015 (removed Template:Multiple issues & general fixes using AWB (10835)). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Intel ADX (Multi-Precision Add-Carry Instruction Extensions) is an extension by Intel to the x86 instruction set architecture for arbitrary-precision arithmetic. It was first supported in the Broadwell microarchitecture.[1][2]

New instructions

The instruction set extension contains just two new instructions, though MULX from BMI2 is also considered part the large integer arithmetic support.[3]

Both instructions are more efficient variants of the existing ADC instruction, with the difference being the two new each only affect one flag, where ADC as a signed addition may set both overflow and carry flag, and as an old-style x86 instruction also reset the rest of the CPU flags.

Instruction Description
ADCX Adds two unsigned integers with carry set and read from the carry flag. Does not affect other flags than carry.
ADOX Adds two unsigned integers with carry set and read from the overflow flag. Does not affect other flags than overflow.

References

  1. ^ "Intel Software Development Emulator". software.intel.com. July 23, 2013. Retrieved October 16, 2013.
  2. ^ Intel Architecture Instruction Set Extensions Programming Reference (Document number 319433-013B) // Intel, July 2012, Chapter 9: Additional new instructions
  3. ^ "New Instructions Supporting Large Integer Arithmetic on Intel®Architecture Processors" (PDF). Intel. Retrieved 2 January 2015.