Sometimes GCC generates this instruction when compiling with -march=atom
. Does each and every Intel Atom CPU support MOVBE?
What other processors suppo
This instruction was originally unique to the Intel® Atom™ processor.
From Intel side:
The Intel® Compilers 11.0 allow you to target the Intel® Atom™ processor using the /QxSSE3_ATOM or -xSSE3_ATOM compiler options. These options enable the generation of the movbe instruction which is unique to the Intel® Atom™ processor.
In other microarchitectures (http://instlatx64.atw.hu/ with uop info from https://agner.org/optimize/):
bswap
+ load or store.non-mainstream CPUs:
AMD Jaguar. Decodes efficiently to a single uop.
Intel Xeon Phi: Knight's Landing (based on Silvermont) and later. (Maybe not on Knight's corner.)