0

我们在 Sun Studio 12.3 下进行测试。我们正在捕获 12.4 及更高版本下不存在的编译器错误。它在 12.1 及更早版本下不存在,但那是因为编译器在 AES 指令方面存在问题。它也不存在于其他编译器下,如 Clang、GCC、ICPC 和 VC++。错误是:

/opt/solarisstudio12.3/bin/CC -DDEBUG -g3 -xO0 -D__SSE2__ -D__SSE3__ -D__SSSE3__ \
-D__SSE4_1__ -D__SSE4_2__ -D__AES__ -D__PCLMUL__ -D__RDRND__ -D__RDSEED__ -D__AVX__ \
-D__AVX2__ -D__BMI__ -D__BMI2__  -native -m64 -KPIC -template=no%extdef -c rijndael.cpp

"/opt/solarisstudio12.3/prod/include/CC/Cstd/algorithm", line 283: Error: Cannot use vector unsigned long long[2] to initialize vector unsigned long long[2].
"rijndael.cpp", line 277:     Where: While instantiating "std::swap<vector unsigned long long[2]>(unsigned long long(&)[2], unsigned long long(&)[2])".
"rijndael.cpp", line 277:     Where: Instantiated from non-template code.
1 Error(s) detected.
gmake: *** [rijndael.o] Error 2
gmake: *** Waiting for unfinished jobs....
ERROR: failed to make cryptest.exe

有问题的代码是:

std::swap(*(__m128i*)(rk), *(__m128i*)(rk+4*m_rounds));

我有一些问题:

  • 编译器有什么问题?
  • 清除错误的最佳方法是什么?

我必须问第二个问题,因为我不确定 SunCC 以及__m128i给定的类型我可以使用 raw memcpy,尝试编写我自己的交换,甚至尝试iter_swap不取消引用。

4

0 回答 0