Implementation notes: armeabi, flops, crypto_aead/norx3241v1

Computer: flops
Architecture: armeabi
CPU ID: unknown CPU ID
SUPERCOP version: 20140622
Operation: crypto_aead
Primitive: norx3241v1
TimeImplementationCompilerBenchmark dateSUPERCOP version
67537neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
67886neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
68552neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
68674neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
71389neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
71392neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
85773neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
85799neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
134273refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014060620140529
134483refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014060620140529
136487refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014060620140529
137131refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
137549refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
138022refgcc -mcpu=cortex-a9 -O3 -fomit-frame-pointer2014060620140529
138610refgcc -funroll-loops -O3 -fomit-frame-pointer2014060620140529
138647refgcc -mcpu=cortex-a9 -O2 -fomit-frame-pointer2014060620140529
139992refgcc -funroll-loops -O2 -fomit-frame-pointer2014060620140529
142139refgcc -O3 -fomit-frame-pointer2014060620140529
142553refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014060620140529
143796refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014060620140529
146044refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014060620140529
146124refgcc -O2 -fomit-frame-pointer2014060620140529
147321refgcc -mcpu=cortex-a5 -O3 -fomit-frame-pointer2014060620140529
154379refgcc -mcpu=cortex-a5 -Os -fomit-frame-pointer2014060620140529
155250refgcc -fno-schedule-insns -Os -fomit-frame-pointer2014060620140529
155282refgcc -Os -fomit-frame-pointer2014060620140529
155341refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
157066refgcc -funroll-loops -Os -fomit-frame-pointer2014060620140529
157074refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014060620140529
158670refgcc -funroll-loops -O -fomit-frame-pointer2014060620140529
158670refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014060620140529
163108refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
163122refgcc -fno-schedule-insns -O -fomit-frame-pointer2014060620140529
163130refgcc -O -fomit-frame-pointer2014060620140529
163136refgcc -mcpu=cortex-a9 -O -fomit-frame-pointer2014060620140529
163180refgcc -mcpu=cortex-a5 -O2 -fomit-frame-pointer2014060620140529
163224refgcc -mcpu=cortex-a5 -O -fomit-frame-pointer2014060620140529
163242refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014060620140529
165390refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014060620140529
165538refgcc -mcpu=cortex-a9 -Os -fomit-frame-pointer2014060620140529
208408refgcc -mcpu=arm8 -O3 -fomit-frame-pointer2014060620140529
208463refgcc -mcpu=strongarm1100 -O3 -fomit-frame-pointer2014060620140529
208501refgcc -mcpu=arm810 -O3 -fomit-frame-pointer2014060620140529
208531refgcc -mcpu=strongarm -O3 -fomit-frame-pointer2014060620140529
208540refgcc -mcpu=strongarm110 -O3 -fomit-frame-pointer2014060620140529
217382refgcc -mcpu=arm8 -O2 -fomit-frame-pointer2014060620140529
217384refgcc -mcpu=strongarm110 -O2 -fomit-frame-pointer2014060620140529
217431refgcc -mcpu=arm810 -O2 -fomit-frame-pointer2014060620140529
217440refgcc -mcpu=strongarm1100 -O2 -fomit-frame-pointer2014060620140529
217460refgcc -mcpu=strongarm -O2 -fomit-frame-pointer2014060620140529
243383refgcc -mcpu=strongarm110 -O -fomit-frame-pointer2014060620140529
243390refgcc -mcpu=arm810 -O -fomit-frame-pointer2014060620140529
243398refgcc -mcpu=arm8 -O -fomit-frame-pointer2014060620140529
243416refgcc -mcpu=strongarm -O -fomit-frame-pointer2014060620140529
243484refgcc -mcpu=strongarm1100 -O -fomit-frame-pointer2014060620140529
254116refgcc -mcpu=strongarm110 -Os -fomit-frame-pointer2014060620140529
254138refgcc -mcpu=arm810 -Os -fomit-frame-pointer2014060620140529
254140refgcc -mcpu=strongarm -Os -fomit-frame-pointer2014060620140529
254147refgcc -mcpu=strongarm1100 -Os -fomit-frame-pointer2014060620140529
254258refgcc -mcpu=arm8 -Os -fomit-frame-pointer2014060620140529
1279696refgcc -funroll-loops2014060620140529
1279735refcc2014060620140529
1279766refgcc2014060620140529

Compiler output

Implementation: crypto_aead/norx3241v1/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_norx3241v1_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/norx3241v1/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/norx3241v1/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/norx3241v1/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_norx3241v1_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/norx3241v1/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