16

GCC 和 Clang 具有128 位整数运算的__int128_t和扩展。__uint128_t

我希望__m128i为英特尔 C 编译器提供类似的东西,但是(如果可能的话)在我看来,我必须编写显式的 SSE2 函数调用才能使用__m128i,而不是使用“内置”运算符像+, -, *, /, 和%. 我希望做这样的事情(这不起作用):

#if defined(__INTEL_COMPILER) && defined(__SSE2__)
  #include "xmmintrin.h"
  typedef __u128 uint128_t;
#elif defined (__GNUC__)
  typedef __uint128_t uint128_t;
#else
  #error For 128-bit arithmetic we need GCC or ICC, or uint128_t
#endif

+运算符, -, *,/%埋在 icc 中的某个地方是否支持 128 位整数?

4

1 回答 1

10

据我所知,至少icc 13.0.1+支持__int128_t__uint128_t. 由Matt Godbolt 的编译器资源管理器提供:

__int128_t ai (__int128_t x, __int128_t y) {
  return x + y;
}

__int128_t mi (__int128_t x, __int128_t y) {
  return x * y;
}

__int128_t di (__int128_t x, __int128_t y) {
  return x / y;
}

__int128_t ri (__int128_t x, __int128_t y) {
  return x % y;
}

编译为:

L__routine_start_ai_0:
ai:
        add       rdi, rdx                                      #2.14
        mov       rax, rdi                                      #2.14
        adc       rsi, rcx                                      #2.14
        mov       rdx, rsi                                      #2.14
        ret                                                     #2.14
L__routine_start_mi_1:
mi:
        mov       rax, rdi                                      #6.14
        imul      rsi, rdx                                      #6.14
        imul      rcx, rdi                                      #6.14
        mul       rdx                                           #6.14
        add       rsi, rcx                                      #6.14
        add       rdx, rsi                                      #6.14
        ret                                                     #6.14
L__routine_start_di_2:
di:
        push      rsi                                           #9.44
        call      __divti3                                      #10.14
        pop       rcx                                           #10.14
        ret                                                     #10.14
L__routine_start_ri_3:
ri:
        push      rsi                                           #13.44
        call      __modti3                                      #14.14
        pop       rcx                                           #14.14
        ret                                                     #14.14

icc 13.0.1http://goo.gl/UnxEFt)。

于 2015-03-04T03:33:54.957 回答