Implementation notes: armeabi, flops, crypto_aead/norx3261v1

Computer: flops
Architecture: armeabi
CPU ID: unknown CPU ID
SUPERCOP version: 20140622
Operation: crypto_aead
Primitive: norx3261v1
TimeImplementationCompilerBenchmark dateSUPERCOP version
100136neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
100407neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
100966neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
101088neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
105101neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
105136neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
126627neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
126778neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
186978refgcc -funroll-loops -O2 -fomit-frame-pointer2014060620140529
187688refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014060620140529
189635refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014060620140529
190225refgcc -mcpu=cortex-a9 -O2 -fomit-frame-pointer2014060620140529
191022refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
192091refgcc -funroll-loops -O3 -fomit-frame-pointer2014060620140529
192345refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014060620140529
193540refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
193588refgcc -O2 -fomit-frame-pointer2014060620140529
196177refgcc -mcpu=cortex-a9 -O3 -fomit-frame-pointer2014060620140529
196654refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
196877refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
196933refgcc -O3 -fomit-frame-pointer2014060620140529
199182refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014060620140529
212721refgcc -mcpu=cortex-a5 -Os -fomit-frame-pointer2014060620140529
213523refgcc -Os -fomit-frame-pointer2014060620140529
213531refgcc -fno-schedule-insns -Os -fomit-frame-pointer2014060620140529
213560refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
214444refgcc -mcpu=cortex-a5 -O3 -fomit-frame-pointer2014060620140529
216295refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014060620140529
216309refgcc -funroll-loops -Os -fomit-frame-pointer2014060620140529
219151refgcc -mcpu=cortex-a5 -O2 -fomit-frame-pointer2014060620140529
224372refgcc -funroll-loops -O -fomit-frame-pointer2014060620140529
224372refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014060620140529
228503refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
228553refgcc -mcpu=cortex-a9 -Os -fomit-frame-pointer2014060620140529
229506refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
229525refgcc -fno-schedule-insns -O -fomit-frame-pointer2014060620140529
229527refgcc -mcpu=cortex-a9 -O -fomit-frame-pointer2014060620140529
229536refgcc -O -fomit-frame-pointer2014060620140529
229586refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
229597refgcc -mcpu=cortex-a5 -O -fomit-frame-pointer2014060620140529
267452refgcc -mcpu=arm8 -O3 -fomit-frame-pointer2014060620140529
267457refgcc -mcpu=strongarm1100 -O3 -fomit-frame-pointer2014060620140529
267464refgcc -mcpu=strongarm -O3 -fomit-frame-pointer2014060620140529
267500refgcc -mcpu=arm810 -O3 -fomit-frame-pointer2014060620140529
267577refgcc -mcpu=strongarm110 -O3 -fomit-frame-pointer2014060620140529
276175refgcc -mcpu=strongarm -O2 -fomit-frame-pointer2014060620140529
276176refgcc -mcpu=arm810 -O2 -fomit-frame-pointer2014060620140529
276238refgcc -mcpu=strongarm110 -O2 -fomit-frame-pointer2014060620140529
276247refgcc -mcpu=arm8 -O2 -fomit-frame-pointer2014060620140529
276313refgcc -mcpu=strongarm1100 -O2 -fomit-frame-pointer2014060620140529
308438refgcc -mcpu=strongarm -O -fomit-frame-pointer2014060620140529
308459refgcc -mcpu=arm810 -O -fomit-frame-pointer2014060620140529
308461refgcc -mcpu=strongarm110 -O -fomit-frame-pointer2014060620140529
308468refgcc -mcpu=arm8 -O -fomit-frame-pointer2014060620140529
308656refgcc -mcpu=strongarm1100 -O -fomit-frame-pointer2014060620140529
315449refgcc -mcpu=arm810 -Os -fomit-frame-pointer2014060620140529
315510refgcc -mcpu=strongarm110 -Os -fomit-frame-pointer2014060620140529
315522refgcc -mcpu=arm8 -Os -fomit-frame-pointer2014060620140529
315528refgcc -mcpu=strongarm -Os -fomit-frame-pointer2014060620140529
315534refgcc -mcpu=strongarm1100 -Os -fomit-frame-pointer2014060620140529
1822156refgcc2014060620140529
1822199refgcc -funroll-loops2014060620140529
1822232refcc2014060620140529

Compiler output

Implementation: crypto_aead/norx3261v1/neon
Compiler: cc
norx.c: In file included from norx.c:24:0:
norx.c: /usr/lib/gcc/arm-linux-gnueabihf/4.7/include/arm_neon.h:32:2: error: #error You must enable NEON instructions (e.g. -mfloat-abi=softfp -mfpu=neon) to use arm_neon.h
norx.c: norx.c: In function 'crypto_aead_norx3261v1_neon_encrypt':
norx.c: norx.c:299:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:301:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'A_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'A_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'A_') [enabled by default]
norx.c: norx.c:309:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'C_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'C_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'C_') [enabled by default]
norx.c: norx.c:309:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'D_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'D_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: ...

Number of similar (compiler,implementation) pairs: 27, namely:
CompilerImplementations
cc neon
gcc neon
gcc -O2 -fomit-frame-pointer neon
gcc -O3 -fomit-frame-pointer neon
gcc -O -fomit-frame-pointer neon
gcc -Os -fomit-frame-pointer neon
gcc -fno-schedule-insns -O2 -fomit-frame-pointer neon
gcc -fno-schedule-insns -O3 -fomit-frame-pointer neon
gcc -fno-schedule-insns -O -fomit-frame-pointer neon
gcc -fno-schedule-insns -Os -fomit-frame-pointer neon
gcc -funroll-loops neon
gcc -funroll-loops -O2 -fomit-frame-pointer neon
gcc -funroll-loops -O3 -fomit-frame-pointer neon
gcc -funroll-loops -O -fomit-frame-pointer neon
gcc -funroll-loops -Os -fomit-frame-pointer neon
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer neon
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer neon
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer neon
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer neon
gcc -mcpu=cortex-a5 -O2 -fomit-frame-pointer neon
gcc -mcpu=cortex-a5 -O3 -fomit-frame-pointer neon
gcc -mcpu=cortex-a5 -O -fomit-frame-pointer neon
gcc -mcpu=cortex-a5 -Os -fomit-frame-pointer neon
gcc -mcpu=cortex-a9 -O2 -fomit-frame-pointer neon
gcc -mcpu=cortex-a9 -O3 -fomit-frame-pointer neon
gcc -mcpu=cortex-a9 -O -fomit-frame-pointer neon
gcc -mcpu=cortex-a9 -Os -fomit-frame-pointer neon

Compiler output

Implementation: crypto_aead/norx3261v1/xmm
Compiler: cc
norx.c: norx.c:27:27: fatal error: x86intrin.h: No such file or directory
norx.c: compilation terminated.

Number of similar (compiler,implementation) pairs: 35, namely:
CompilerImplementations
cc xmm
gcc xmm
gcc -O2 -fomit-frame-pointer xmm
gcc -O3 -fomit-frame-pointer xmm
gcc -O -fomit-frame-pointer xmm
gcc -Os -fomit-frame-pointer xmm
gcc -fno-schedule-insns -O2 -fomit-frame-pointer xmm
gcc -fno-schedule-insns -O3 -fomit-frame-pointer xmm
gcc -fno-schedule-insns -O -fomit-frame-pointer xmm
gcc -fno-schedule-insns -Os -fomit-frame-pointer xmm
gcc -funroll-loops xmm
gcc -funroll-loops -O2 -fomit-frame-pointer xmm
gcc -funroll-loops -O3 -fomit-frame-pointer xmm
gcc -funroll-loops -O -fomit-frame-pointer xmm
gcc -funroll-loops -Os -fomit-frame-pointer xmm
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer xmm
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer xmm
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer xmm
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer xmm
gcc -mcpu=cortex-a5 -O2 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a5 -O3 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a5 -O -fomit-frame-pointer xmm
gcc -mcpu=cortex-a5 -Os -fomit-frame-pointer xmm
gcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer xmm
gcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -O2 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -O3 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -O -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -Os -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer xmm
gcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer xmm

Compiler output

Implementation: crypto_aead/norx3261v1/ref
Compiler: gcc -mcpu=arm810 -O2 -fomit-frame-pointer
caesar.c: caesar.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
norx.c: norx.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
try.c: try.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
try.c: try-anything.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
try.c: try.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
try.c: try-anything.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
measure.c: measure.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
measure.c: measure-anything.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]

Number of similar (compiler,implementation) pairs: 20, namely:
CompilerImplementations
gcc -mcpu=arm810 -O2 -fomit-frame-pointer ref
gcc -mcpu=arm810 -O3 -fomit-frame-pointer ref
gcc -mcpu=arm810 -O -fomit-frame-pointer ref
gcc -mcpu=arm810 -Os -fomit-frame-pointer ref
gcc -mcpu=arm8 -O2 -fomit-frame-pointer ref
gcc -mcpu=arm8 -O3 -fomit-frame-pointer ref
gcc -mcpu=arm8 -O -fomit-frame-pointer ref
gcc -mcpu=arm8 -Os -fomit-frame-pointer ref
gcc -mcpu=strongarm1100 -O2 -fomit-frame-pointer ref
gcc -mcpu=strongarm1100 -O3 -fomit-frame-pointer ref
gcc -mcpu=strongarm1100 -O -fomit-frame-pointer ref
gcc -mcpu=strongarm1100 -Os -fomit-frame-pointer ref
gcc -mcpu=strongarm110 -O2 -fomit-frame-pointer ref
gcc -mcpu=strongarm110 -O3 -fomit-frame-pointer ref
gcc -mcpu=strongarm110 -O -fomit-frame-pointer ref
gcc -mcpu=strongarm110 -Os -fomit-frame-pointer ref
gcc -mcpu=strongarm -O2 -fomit-frame-pointer ref
gcc -mcpu=strongarm -O3 -fomit-frame-pointer ref
gcc -mcpu=strongarm -O -fomit-frame-pointer ref
gcc -mcpu=strongarm -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_aead/norx3261v1/neon
Compiler: gcc -mcpu=arm810 -O2 -fomit-frame-pointer
norx.c: norx.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
norx.c: In file included from norx.c:24:0:
norx.c: /usr/lib/gcc/arm-linux-gnueabihf/4.7/include/arm_neon.h:32:2: error: #error You must enable NEON instructions (e.g. -mfloat-abi=softfp -mfpu=neon) to use arm_neon.h
norx.c: norx.c: In function 'crypto_aead_norx3261v1_neon_encrypt':
norx.c: norx.c:299:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:301:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'A_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'A_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'A_') [enabled by default]
norx.c: norx.c:309:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'C_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'C_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'C_') [enabled by default]
norx.c: norx.c:309:5: error: unknown type name 'uint32x4_t'
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'D_') [enabled by default]
norx.c: norx.c:309:5: warning: excess elements in scalar initializer [enabled by default]
norx.c: norx.c:309:5: warning: (near initialization for 'D_') [enabled by default]
norx.c: ...

Number of similar (compiler,implementation) pairs: 20, namely:
CompilerImplementations
gcc -mcpu=arm810 -O2 -fomit-frame-pointer neon
gcc -mcpu=arm810 -O3 -fomit-frame-pointer neon
gcc -mcpu=arm810 -O -fomit-frame-pointer neon
gcc -mcpu=arm810 -Os -fomit-frame-pointer neon
gcc -mcpu=arm8 -O2 -fomit-frame-pointer neon
gcc -mcpu=arm8 -O3 -fomit-frame-pointer neon
gcc -mcpu=arm8 -O -fomit-frame-pointer neon
gcc -mcpu=arm8 -Os -fomit-frame-pointer neon
gcc -mcpu=strongarm1100 -O2 -fomit-frame-pointer neon
gcc -mcpu=strongarm1100 -O3 -fomit-frame-pointer neon
gcc -mcpu=strongarm1100 -O -fomit-frame-pointer neon
gcc -mcpu=strongarm1100 -Os -fomit-frame-pointer neon
gcc -mcpu=strongarm110 -O2 -fomit-frame-pointer neon
gcc -mcpu=strongarm110 -O3 -fomit-frame-pointer neon
gcc -mcpu=strongarm110 -O -fomit-frame-pointer neon
gcc -mcpu=strongarm110 -Os -fomit-frame-pointer neon
gcc -mcpu=strongarm -O2 -fomit-frame-pointer neon
gcc -mcpu=strongarm -O3 -fomit-frame-pointer neon
gcc -mcpu=strongarm -O -fomit-frame-pointer neon
gcc -mcpu=strongarm -Os -fomit-frame-pointer neon

Compiler output

Implementation: crypto_aead/norx3261v1/xmm
Compiler: gcc -mcpu=arm810 -O2 -fomit-frame-pointer
norx.c: norx.c:1:0: warning: target CPU does not support THUMB instructions [enabled by default]
norx.c: norx.c:27:27: fatal error: x86intrin.h: No such file or directory
norx.c: compilation terminated.

Number of similar (compiler,implementation) pairs: 20, namely:
CompilerImplementations
gcc -mcpu=arm810 -O2 -fomit-frame-pointer xmm
gcc -mcpu=arm810 -O3 -fomit-frame-pointer xmm
gcc -mcpu=arm810 -O -fomit-frame-pointer xmm
gcc -mcpu=arm810 -Os -fomit-frame-pointer xmm
gcc -mcpu=arm8 -O2 -fomit-frame-pointer xmm
gcc -mcpu=arm8 -O3 -fomit-frame-pointer xmm
gcc -mcpu=arm8 -O -fomit-frame-pointer xmm
gcc -mcpu=arm8 -Os -fomit-frame-pointer xmm
gcc -mcpu=strongarm1100 -O2 -fomit-frame-pointer xmm
gcc -mcpu=strongarm1100 -O3 -fomit-frame-pointer xmm
gcc -mcpu=strongarm1100 -O -fomit-frame-pointer xmm
gcc -mcpu=strongarm1100 -Os -fomit-frame-pointer xmm
gcc -mcpu=strongarm110 -O2 -fomit-frame-pointer xmm
gcc -mcpu=strongarm110 -O3 -fomit-frame-pointer xmm
gcc -mcpu=strongarm110 -O -fomit-frame-pointer xmm
gcc -mcpu=strongarm110 -Os -fomit-frame-pointer xmm
gcc -mcpu=strongarm -O2 -fomit-frame-pointer xmm
gcc -mcpu=strongarm -O3 -fomit-frame-pointer xmm
gcc -mcpu=strongarm -O -fomit-frame-pointer xmm
gcc -mcpu=strongarm -Os -fomit-frame-pointer xmm