Implementation notes: aarch64, googlecoraldev, crypto_core/invhrss701

Computer: googlecoraldev
Architecture: aarch64
CPU ID: 410fd034
SUPERCOP version: 20191221
Operation: crypto_core
Primitive: invhrss701
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
75765604576 0 017249 896 784simplergcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221
101511003900 0 017640 824 776simplerclang_-mcpu=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020010220191221
158243403448 0 016055 888 784refgcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221
1649448011584 0 025312 824 776refclang_-mcpu=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020010220191221
59537700772 0 012102 880 768simplergcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221
59541480672 0 011254 864 760simplergcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221
81364320816 0 012254 880 768simplergcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221
869814001052 0 011614 864 760refgcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221
908875801144 0 012478 880 768refgcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221
929826001292 0 012742 880 768refgcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020010220191221

Compiler output

Implementation: avx2
Security model: unknown
Compiler: clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
poly_s3_inv.S: poly_s3_inv.S:3:8: error: invalid alignment value
poly_s3_inv.S: .align 32
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:465:1: error: unknown directive
poly_s3_inv.S: .att_syntax prefix
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:467:6: error: unknown token in expression
poly_s3_inv.S: push %r12
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:467:6: error: invalid operand
poly_s3_inv.S: push %r12
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:468:6: error: unknown token in expression
poly_s3_inv.S: push %r13
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:468:6: error: invalid operand
poly_s3_inv.S: push %r13
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:469:6: error: unknown token in expression
poly_s3_inv.S: push %r14
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:469:6: error: invalid operand
poly_s3_inv.S: push %r14
poly_s3_inv.S: ^
poly_s3_inv.S: poly_s3_inv.S:470:5: error: unknown token in expression
poly_s3_inv.S: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx2

Compiler output

Implementation: avx2
Security model: unknown
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
poly_s3_inv.S: poly_s3_inv.S: Assembler messages:
poly_s3_inv.S: poly_s3_inv.S:465: Error: unknown pseudo-op: `.att_syntax'
poly_s3_inv.S: poly_s3_inv.S:467: Error: unknown mnemonic `push' -- `push %r12'
poly_s3_inv.S: poly_s3_inv.S:468: Error: unknown mnemonic `push' -- `push %r13'
poly_s3_inv.S: poly_s3_inv.S:469: Error: unknown mnemonic `push' -- `push %r14'
poly_s3_inv.S: poly_s3_inv.S:470: Error: operand 1 must be an integer register -- `mov %rsp,%r8'
poly_s3_inv.S: poly_s3_inv.S:471: Error: unknown mnemonic `andq' -- `andq $-32,%rsp'
poly_s3_inv.S: poly_s3_inv.S:472: Error: unknown mnemonic `subq' -- `subq $768,%rsp'
poly_s3_inv.S: poly_s3_inv.S:473: Error: operand 1 must be an integer register -- `mov $281479271743489,%r9'
poly_s3_inv.S: poly_s3_inv.S:474: Error: operand 1 must be an integer register -- `mov $562958543486978,%rdx'
poly_s3_inv.S: poly_s3_inv.S:475: Error: operand 1 must be an integer register -- `mov $0,%r10'
poly_s3_inv.S: poly_s3_inv.S:476: Error: operand 1 must be an integer register -- `mov $0,%r11'
poly_s3_inv.S: poly_s3_inv.S:477: Error: operand 1 must be an integer register -- `mov 0(%rsi),%rax'
poly_s3_inv.S: poly_s3_inv.S:478: Error: unknown mnemonic `pext' -- `pext %r9,%rax,%rcx'
poly_s3_inv.S: poly_s3_inv.S:479: Error: unknown mnemonic `pext' -- `pext %rdx,%rax,%rax'
poly_s3_inv.S: poly_s3_inv.S:480: Error: unknown mnemonic `or' -- `or %rcx,%r10'
poly_s3_inv.S: poly_s3_inv.S:481: Error: unknown mnemonic `or' -- `or %rax,%r11'
poly_s3_inv.S: poly_s3_inv.S:482: Error: operand 1 must be an integer register -- `mov 8(%rsi),%rax'
poly_s3_inv.S: poly_s3_inv.S:483: Error: unknown mnemonic `pext' -- `pext %r9,%rax,%rcx'
poly_s3_inv.S: poly_s3_inv.S:484: Error: unknown mnemonic `pext' -- `pext %rdx,%rax,%rax'
poly_s3_inv.S: poly_s3_inv.S:485: Error: operand 1 must be a SIMD scalar register -- `shl $4,%rcx'
poly_s3_inv.S: poly_s3_inv.S:486: Error: operand 1 must be a SIMD scalar register -- `shl $4,%rax'
poly_s3_inv.S: poly_s3_inv.S:487: Error: unknown mnemonic `or' -- `or %rcx,%r10'
poly_s3_inv.S: poly_s3_inv.S:488: Error: unknown mnemonic `or' -- `or %rax,%r11'
poly_s3_inv.S: poly_s3_inv.S:489: Error: operand 1 must be an integer register -- `mov 16(%rsi),%rax'
poly_s3_inv.S: ...

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE avx2
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE avx2
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv -fPIC -fPIE avx2
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE avx2

Compiler output

Implementation: faster
Security model: unknown
Compiler: clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
core.c: In file included from core.c:4:
core.c: In file included from /usr/lib/llvm-7/lib/clang/7.0.1/include/immintrin.h:28:
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:64:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_vec_init_v2si(__i, 0);
core.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:143:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_packsswb((__v4hi)__m1, (__v4hi)__m2);
core.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:173:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_packssdw((__v2si)__m1, (__v2si)__m2);
core.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:203:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_packuswb((__v4hi)__m1, (__v4hi)__m2);
core.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:230:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_punpckhbw((__v8qi)__m1, (__v8qi)__m2);
core.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:253:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_punpckhwd((__v4hi)__m1, (__v4hi)__m2);
core.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:274:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_punpckhdq((__v2si)__m1, (__v2si)__m2);
core.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
core.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:301:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
core.c: return (__m64)__builtin_ia32_punpcklbw((__v8qi)__m1, (__v8qi)__m2);
core.c: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE faster

Compiler output

Implementation: faster
Security model: unknown
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
core.c: core.c:4:10: fatal error: immintrin.h: No such file or directory
core.c: #include <immintrin.h>
core.c: ^~~~~~~~~~~~~
core.c: compilation terminated.

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE faster
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE faster
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv -fPIC -fPIE faster
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE faster

Compiler output

Implementation: faster821
Security model: unknown
Compiler: clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
core.s: core.s:9:8: error: unknown token in expression
core.s: pushq %rbp
core.s: ^
core.s: core.s:9:8: error: invalid operand
core.s: pushq %rbp
core.s: ^
core.s: core.s:12:7: error: unknown token in expression
core.s: xorl %ecx, %ecx
core.s: ^
core.s: core.s:12:7: error: invalid operand
core.s: xorl %ecx, %ecx
core.s: ^
core.s: core.s:13:11: error: unknown token in expression
core.s: vpcmpeqd %ymm7, %ymm7, %ymm7
core.s: ^
core.s: core.s:13:11: error: invalid operand
core.s: vpcmpeqd %ymm7, %ymm7, %ymm7
core.s: ^
core.s: core.s:14:7: error: unknown token in expression
core.s: movq %rsp, %rbp
core.s: ^
core.s: core.s:14:7: error: invalid operand
core.s: movq %rsp, %rbp
core.s: ^
core.s: core.s:16:8: error: unknown token in expression
core.s: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE faster821

Compiler output

Implementation: faster821
Security model: unknown
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
core.s: core.s: Assembler messages:
core.s: core.s:9: Error: unknown mnemonic `pushq' -- `pushq %rbp'
core.s: core.s:12: Error: unknown mnemonic `xorl' -- `xorl %ecx,%ecx'
core.s: core.s:13: Error: unknown mnemonic `vpcmpeqd' -- `vpcmpeqd %ymm7,%ymm7,%ymm7'
core.s: core.s:14: Error: unknown mnemonic `movq' -- `movq %rsp,%rbp'
core.s: core.s:16: Error: unknown mnemonic `pushq' -- `pushq %rbx'
core.s: core.s:18: Error: unknown mnemonic `movq' -- `movq %rdi,%rbx'
core.s: core.s:19: Error: unknown mnemonic `andq' -- `andq $-32,%rsp'
core.s: core.s:20: Error: unknown mnemonic `subq' -- `subq $5760,%rsp'
core.s: core.s:21: Error: unknown mnemonic `movzbl' -- `movzbl 1400(%rsi),%edi'
core.s: core.s:22: Error: unknown mnemonic `vmovdqa' -- `vmovdqa .LC2(%rip),%ymm3'
core.s: core.s:23: Error: unknown mnemonic `vmovdqa' -- `vmovdqa .LC3(%rip),%ymm6'
core.s: core.s:24: Error: unknown mnemonic `vmovdqa' -- `vmovdqa .LC4(%rip),%ymm5'
core.s: core.s:25: Error: unknown mnemonic `notl' -- `notl %edi'
core.s: core.s:26: Error: unknown mnemonic `vmovdqa' -- `vmovdqa .LC5(%rip),%ymm4'
core.s: core.s:27: Error: unknown mnemonic `andl' -- `andl $3,%edi'
core.s: core.s:28: Error: unknown mnemonic `movsbl' -- `movsbl %dil,%eax'
core.s: core.s:29: Error: unknown mnemonic `subl' -- `subl $3,%eax'
core.s: core.s:30: Error: unknown mnemonic `sarl' -- `sarl $5,%eax'
core.s: core.s:31: Error: unknown mnemonic `andl' -- `andl %eax,%edi'
core.s: core.s:32: Error: unknown mnemonic `incl' -- `incl %edi'
core.s: core.s:33: Error: unknown mnemonic `vmovd' -- `vmovd %edi,%xmm8'
core.s: core.s:34: Error: unknown mnemonic `vpbroadcastb' -- `vpbroadcastb %xmm8,%ymm8'
core.s: core.s:38: Error: unknown mnemonic `vpand' -- `vpand 32(%rsi,%rcx,2),%ymm3,%ymm0'
core.s: core.s:39: Error: unknown mnemonic `vpand' -- `vpand (%rsi,%rcx,2),%ymm3,%ymm1'
core.s: ...

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE faster821
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE faster821
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv -fPIC -fPIE faster821
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE faster821