我正在尝试在Mac上编译C应用程序.我使用SSE4和AES-NI内在函数.
在Linux中,我只使用-msse4和-maes标志调用gcc并包含wmmintrin.h标头,我可以调用SSE内在函数_mm_add_epi64(a,b)或AES-NI内在函数,_mm_aesenc_si128(a, b)并且一切正常.
在Mac上,它更难,因为Apple用llvm-gcc替换了GCC,而llvm-gcc还不支持AES-NI.因此SSE4内在函数工作正常,但不是AES.即使是对AES指令的内联汇编调用也无法识别.
英特尔在他们的网站上有很多AES示例代码,但它仅适用于Linux和Windows.
我注意到llvm-gcc也不支持RDRAND指令,但英特尔通过使用扩展为原始机器字节代码的C宏为此提供了解决方法.(请参阅此英特尔库中的rdrand.h示例文件)
遗憾的是,AES-NI指令没有类似的解决方法,可能是因为指令有参数而不能作为静态机器代码字节进行求值.
在Mac上使用AES-NI的程序确实存在,包括Apple自己的File Vault,因此必须有一些方法可行!
为了使我的问题具体化,我将如何使用最新的Mac gcc-llvm 4.2(Mountain Lion xcode 4.4.1中的最新公开发布)进行以下简单调用:
__m128i A, B, C;
/* A, B, C initialized here... */
A = _mm_aesenc_si128(B, C);
Run Code Online (Sandbox Code Playgroud)
谢谢你的帮助!