Implementation notes: armeabi, h7beagle, crypto_aead/norx3241v1

Computer: h7beagle
Architecture: armeabi
CPU ID: unknown CPU ID
SUPERCOP version: 20140622
Operation: crypto_aead
Primitive: norx3241v1
TimeImplementationCompilerBenchmark dateSUPERCOP version
68574neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014062120140529
68674neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014062120140529
71404neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014062120140529
71453neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014062120140529
85760neongcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014062120140529
85811neongcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014062120140529
134286refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014062120140529
134479refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014062120140529
136472refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014062120140529
137121refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014062120140529
137542refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014062120140529
138035refgcc -mcpu=cortex-a9 -O3 -fomit-frame-pointer2014062120140529
138545refgcc -funroll-loops -O3 -fomit-frame-pointer2014062120140529
138683refgcc -mcpu=cortex-a9 -O2 -fomit-frame-pointer2014062120140529
140005refgcc -funroll-loops -O2 -fomit-frame-pointer2014062120140529
142176refgcc -O3 -fomit-frame-pointer2014062120140529
142552refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer2014062120140529
143767refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014062120140529
145847refgcc -O2 -fomit-frame-pointer2014062120140529
146187refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O2 -fomit-frame-pointer2014062120140529
147323refgcc -mcpu=cortex-a5 -O3 -fomit-frame-pointer2014062120140529
154391refgcc -mcpu=cortex-a5 -Os -fomit-frame-pointer2014062120140529
155262refgcc -fno-schedule-insns -Os -fomit-frame-pointer2014062120140529
155266refgcc -Os -fomit-frame-pointer2014062120140529
155289refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014062120140529
157087refgcc -funroll-loops -Os -fomit-frame-pointer2014062120140529
157324refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014062120140529
158657refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014062120140529
158659refgcc -funroll-loops -O -fomit-frame-pointer2014062120140529
163108refgcc -fno-schedule-insns -O -fomit-frame-pointer2014062120140529
163110refgcc -O -fomit-frame-pointer2014062120140529
163122refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014062120140529
163168refgcc -mcpu=cortex-a5 -O2 -fomit-frame-pointer2014062120140529
163192refgcc -mcpu=cortex-a5 -O -fomit-frame-pointer2014062120140529
163219refgcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O -fomit-frame-pointer2014062120140529
163448refgcc -mcpu=cortex-a9 -O -fomit-frame-pointer2014062120140529
165381refgcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -Os -fomit-frame-pointer2014062120140529
165424refgcc -mcpu=cortex-a9 -Os -fomit-frame-pointer2014062120140529
208362refgcc -mcpu=arm8 -O3 -fomit-frame-pointer2014062120140529
208505refgcc -mcpu=strongarm -O3 -fomit-frame-pointer2014062120140529
208527refgcc -mcpu=strongarm1100 -O3 -fomit-frame-pointer2014062120140529
208527refgcc -mcpu=strongarm110 -O3 -fomit-frame-pointer2014062120140529
208561refgcc -mcpu=arm810 -O3 -fomit-frame-pointer2014062120140529
217376refgcc -mcpu=arm810 -O2 -fomit-frame-pointer2014062120140529
217383refgcc -mcpu=strongarm110 -O2 -fomit-frame-pointer2014062120140529
217392refgcc -mcpu=arm8 -O2 -fomit-frame-pointer2014062120140529
217432refgcc -mcpu=strongarm1100 -O2 -fomit-frame-pointer2014062120140529
217487refgcc -mcpu=strongarm -O2 -fomit-frame-pointer2014062120140529
243378refgcc -mcpu=strongarm1100 -O -fomit-frame-pointer2014062120140529
243397refgcc -mcpu=arm810 -O -fomit-frame-pointer2014062120140529
243399refgcc -mcpu=strongarm -O -fomit-frame-pointer2014062120140529
243412refgcc -mcpu=strongarm110 -O -fomit-frame-pointer2014062120140529
243436refgcc -mcpu=arm8 -O -fomit-frame-pointer2014062120140529
254120refgcc -mcpu=arm810 -Os -fomit-frame-pointer2014062120140529
254124refgcc -mcpu=strongarm -Os -fomit-frame-pointer2014062120140529
254134refgcc -mcpu=arm8 -Os -fomit-frame-pointer2014062120140529
254139refgcc -mcpu=strongarm1100 -Os -fomit-frame-pointer2014062120140529
254144refgcc -mcpu=strongarm110 -Os -fomit-frame-pointer2014062120140529
1279621refgcc2014062120140529
1279719refgcc -funroll-loops2014062120140529
1279774refcc2014062120140529

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

Compiler output

Implementation: crypto_aead/norx3241v1/neon
Compiler: gcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer
norx.c: virtual memory exhausted: Cannot allocate memory

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -mcpu=cortex-a8 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer neon

Compiler output

Implementation: crypto_aead/norx3241v1/neon
Compiler: gcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer
norx.c:
norx.c: cc1: out of memory allocating 17860 bytes after a total of 3018752 bytes

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -mcpu=cortex-a9 -mfloat-abi=hard -mfpu=neon -O3 -fomit-frame-pointer neon